MOBILE-3071 core: Let site plugins add menu items in course

main
Dani Palou 2019-07-10 09:52:05 +02:00
parent 79cfc44e0d
commit 0b779f4ae8
7 changed files with 51 additions and 18 deletions

View File

@ -78,10 +78,10 @@ export class AddonBlogCourseOptionHandler implements CoreCourseOptionsHandler {
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> { getDisplayData(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> {
return { return {
title: 'addon.blog.blog', title: 'addon.blog.blog',
class: 'addon-blog-handler', class: 'addon-blog-handler',

View File

@ -63,10 +63,10 @@ export class AddonCompetencyCourseOptionHandler implements CoreCourseOptionsHand
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData?(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> { getDisplayData?(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> {
return { return {
title: 'addon.competency.competencies', title: 'addon.competency.competencies',
class: 'addon-competency-course-handler', class: 'addon-competency-course-handler',

View File

@ -12,7 +12,7 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
import { Injectable } from '@angular/core'; import { Injectable, Injector } from '@angular/core';
import { CoreCourseOptionsMenuHandler, CoreCourseOptionsMenuHandlerData } from '@core/course/providers/options-delegate'; import { CoreCourseOptionsMenuHandler, CoreCourseOptionsMenuHandlerData } from '@core/course/providers/options-delegate';
/** /**
@ -49,9 +49,11 @@ export class AddonStorageManagerCourseMenuHandler implements CoreCourseOptionsMe
/** /**
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector.
* @param {any} course The course.
* @return {CoreCourseOptionsMenuHandlerData} Data needed to render the handler. * @return {CoreCourseOptionsMenuHandlerData} Data needed to render the handler.
*/ */
getMenuDisplayData(): CoreCourseOptionsMenuHandlerData { getMenuDisplayData(injector: Injector, course: any): CoreCourseOptionsMenuHandlerData {
return { return {
icon: 'cube', icon: 'cube',
title: 'addon.storagemanager.managestorage', title: 'addon.storagemanager.managestorage',

View File

@ -52,10 +52,10 @@ export interface CoreCourseOptionsHandler extends CoreDelegateHandler {
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData?(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData>; getDisplayData?(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData>;
/** /**
* Should invalidate the data to determine if the handler is enabled for a certain course. * Should invalidate the data to determine if the handler is enabled for a certain course.
@ -84,10 +84,10 @@ export interface CoreCourseOptionsMenuHandler extends CoreCourseOptionsHandler {
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsMenuHandlerData|Promise<CoreCourseOptionsMenuHandlerData>} Data or promise resolved with data. * @return {CoreCourseOptionsMenuHandlerData|Promise<CoreCourseOptionsMenuHandlerData>} Data or promise resolved with data.
*/ */
getMenuDisplayData(injector: Injector, courseId: number): getMenuDisplayData(injector: Injector, course: any):
CoreCourseOptionsMenuHandlerData | Promise<CoreCourseOptionsMenuHandlerData>; CoreCourseOptionsMenuHandlerData | Promise<CoreCourseOptionsMenuHandlerData>;
} }

View File

@ -80,10 +80,10 @@ export class CoreGradesCourseOptionHandler implements CoreCourseOptionsHandler {
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> { getDisplayData(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> {
return { return {
title: 'core.grades.grades', title: 'core.grades.grades',
class: 'core-grades-course-handler', class: 'core-grades-course-handler',

View File

@ -14,7 +14,9 @@
import { Injector } from '@angular/core'; import { Injector } from '@angular/core';
import { CoreSitePluginsProvider } from '../../providers/siteplugins'; import { CoreSitePluginsProvider } from '../../providers/siteplugins';
import { CoreCourseOptionsHandler, CoreCourseOptionsHandlerData } from '@core/course/providers/options-delegate'; import {
CoreCourseOptionsHandler, CoreCourseOptionsHandlerData, CoreCourseOptionsMenuHandlerData
} from '@core/course/providers/options-delegate';
import { CoreSitePluginsBaseHandler } from './base-handler'; import { CoreSitePluginsBaseHandler } from './base-handler';
import { CoreSitePluginsCourseOptionComponent } from '../../components/course-option/course-option'; import { CoreSitePluginsCourseOptionComponent } from '../../components/course-option/course-option';
@ -23,12 +25,14 @@ import { CoreSitePluginsCourseOptionComponent } from '../../components/course-op
*/ */
export class CoreSitePluginsCourseOptionHandler extends CoreSitePluginsBaseHandler implements CoreCourseOptionsHandler { export class CoreSitePluginsCourseOptionHandler extends CoreSitePluginsBaseHandler implements CoreCourseOptionsHandler {
priority: number; priority: number;
isMenuHandler: boolean;
constructor(name: string, protected title: string, protected plugin: any, protected handlerSchema: any, constructor(name: string, protected title: string, protected plugin: any, protected handlerSchema: any,
protected initResult: any, protected sitePluginsProvider: CoreSitePluginsProvider) { protected initResult: any, protected sitePluginsProvider: CoreSitePluginsProvider) {
super(name); super(name);
this.priority = handlerSchema.priority; this.priority = handlerSchema.priority;
this.isMenuHandler = !!handlerSchema.ismenuhandler;
} }
/** /**
@ -46,13 +50,13 @@ export class CoreSitePluginsCourseOptionHandler extends CoreSitePluginsBaseHandl
} }
/** /**
* Returns the data needed to render the handler. * Returns the data needed to render the handler (if it isn't a menu handler).
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> { getDisplayData(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> {
return { return {
title: this.title, title: this.title,
class: this.handlerSchema.displaydata.class, class: this.handlerSchema.displaydata.class,
@ -63,6 +67,33 @@ export class CoreSitePluginsCourseOptionHandler extends CoreSitePluginsBaseHandl
}; };
} }
/**
* Returns the data needed to render the handler (if it's a menu handler).
*
* @param {Injector} injector Injector.
* @param {any} course The course.
* @return {CoreCourseOptionsMenuHandlerData|Promise<CoreCourseOptionsMenuHandlerData>} Data or promise resolved with data.
*/
getMenuDisplayData(injector: Injector, course: any):
CoreCourseOptionsMenuHandlerData | Promise<CoreCourseOptionsMenuHandlerData> {
return {
title: this.title,
class: this.handlerSchema.displaydata.class,
icon: this.handlerSchema.displaydata.icon || '',
page: 'CoreSitePluginsPluginPage',
pageParams: {
title: this.title,
component: this.plugin.component,
method: this.handlerSchema.method,
args: {
courseid: course.id
},
initResult: this.initResult
}
};
}
/** /**
* Called when a course is downloaded. It should prefetch all the data to be able to see the plugin in offline. * Called when a course is downloaded. It should prefetch all the data to be able to see the plugin in offline.
* *

View File

@ -79,10 +79,10 @@ export class CoreUserParticipantsCourseOptionHandler implements CoreCourseOption
* Returns the data needed to render the handler. * Returns the data needed to render the handler.
* *
* @param {Injector} injector Injector. * @param {Injector} injector Injector.
* @param {number} courseId The course ID. * @param {number} course The course.
* @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data. * @return {CoreCourseOptionsHandlerData|Promise<CoreCourseOptionsHandlerData>} Data or promise resolved with the data.
*/ */
getDisplayData(injector: Injector, courseId: number): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> { getDisplayData(injector: Injector, course: any): CoreCourseOptionsHandlerData | Promise<CoreCourseOptionsHandlerData> {
return { return {
title: 'core.user.participants', title: 'core.user.participants',
class: 'core-user-participants-handler', class: 'core-user-participants-handler',