MOBILE-2803 course: Prefetch course options
parent
abddc4766d
commit
cee98a94fa
|
@ -220,9 +220,12 @@ export class AddonCompetencyProvider {
|
||||||
* @param {number} competencyId ID of the competency.
|
* @param {number} competencyId ID of the competency.
|
||||||
* @param {number} [userId] ID of the user. If not defined, current user.
|
* @param {number} [userId] ID of the user. If not defined, current user.
|
||||||
* @param {string} [siteId] Site ID. If not defined, current site.
|
* @param {string} [siteId] Site ID. If not defined, current site.
|
||||||
|
* @param {boolean} [ignoreCache] True if it should ignore cached data (it will always fail in offline or server down).
|
||||||
* @return {Promise<any>} Promise to be resolved when the plans are retrieved.
|
* @return {Promise<any>} Promise to be resolved when the plans are retrieved.
|
||||||
*/
|
*/
|
||||||
getCompetencyInCourse(courseId: number, competencyId: number, userId?: number, siteId?: string): Promise<any> {
|
getCompetencyInCourse(courseId: number, competencyId: number, userId?: number, siteId?: string, ignoreCache?: boolean)
|
||||||
|
: Promise<any> {
|
||||||
|
|
||||||
return this.sitesProvider.getSite(siteId).then((site) => {
|
return this.sitesProvider.getSite(siteId).then((site) => {
|
||||||
userId = userId || site.getUserId();
|
userId = userId || site.getUserId();
|
||||||
|
|
||||||
|
@ -233,10 +236,15 @@ export class AddonCompetencyProvider {
|
||||||
competencyid: competencyId,
|
competencyid: competencyId,
|
||||||
userid: userId
|
userid: userId
|
||||||
},
|
},
|
||||||
preSets = {
|
preSets: any = {
|
||||||
cacheKey: this.getCompetencyInCourseCacheKey(courseId, competencyId, userId)
|
cacheKey: this.getCompetencyInCourseCacheKey(courseId, competencyId, userId)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (ignoreCache) {
|
||||||
|
preSets.getFromCache = false;
|
||||||
|
preSets.emergencyCache = false;
|
||||||
|
}
|
||||||
|
|
||||||
return site.read('tool_lp_data_for_user_competency_summary_in_course', params, preSets).then((response) => {
|
return site.read('tool_lp_data_for_user_competency_summary_in_course', params, preSets).then((response) => {
|
||||||
if (response.usercompetencysummary) {
|
if (response.usercompetencysummary) {
|
||||||
return response;
|
return response;
|
||||||
|
@ -253,9 +261,10 @@ export class AddonCompetencyProvider {
|
||||||
* @param {number} competencyId ID of the competency.
|
* @param {number} competencyId ID of the competency.
|
||||||
* @param {number} [userId] ID of the user. If not defined, current user.
|
* @param {number} [userId] ID of the user. If not defined, current user.
|
||||||
* @param {string} [siteId] Site ID. If not defined, current site.
|
* @param {string} [siteId] Site ID. If not defined, current site.
|
||||||
|
* @param {boolean} [ignoreCache] True if it should ignore cached data (it will always fail in offline or server down).
|
||||||
* @return {Promise<any>} Promise to be resolved when the plans are retrieved.
|
* @return {Promise<any>} Promise to be resolved when the plans are retrieved.
|
||||||
*/
|
*/
|
||||||
getCompetencySummary(competencyId: number, userId?: number, siteId?: string): Promise<any> {
|
getCompetencySummary(competencyId: number, userId?: number, siteId?: string, ignoreCache?: boolean): Promise<any> {
|
||||||
return this.sitesProvider.getSite(siteId).then((site) => {
|
return this.sitesProvider.getSite(siteId).then((site) => {
|
||||||
userId = userId || site.getUserId();
|
userId = userId || site.getUserId();
|
||||||
|
|
||||||
|
@ -265,10 +274,15 @@ export class AddonCompetencyProvider {
|
||||||
competencyid: competencyId,
|
competencyid: competencyId,
|
||||||
userid: userId
|
userid: userId
|
||||||
},
|
},
|
||||||
preSets = {
|
preSets: any = {
|
||||||
cacheKey: this.getCompetencySummaryCacheKey(competencyId, userId)
|
cacheKey: this.getCompetencySummaryCacheKey(competencyId, userId)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (ignoreCache) {
|
||||||
|
preSets.getFromCache = false;
|
||||||
|
preSets.emergencyCache = false;
|
||||||
|
}
|
||||||
|
|
||||||
return site.read('tool_lp_data_for_user_competency_summary', params, preSets).then((response) => {
|
return site.read('tool_lp_data_for_user_competency_summary', params, preSets).then((response) => {
|
||||||
if (response.competency) {
|
if (response.competency) {
|
||||||
return response.competency;
|
return response.competency;
|
||||||
|
@ -285,9 +299,10 @@ export class AddonCompetencyProvider {
|
||||||
* @param {number} courseId ID of the course.
|
* @param {number} courseId ID of the course.
|
||||||
* @param {number} [userId] ID of the user.
|
* @param {number} [userId] ID of the user.
|
||||||
* @param {string} [siteId] Site ID. If not defined, current site.
|
* @param {string} [siteId] Site ID. If not defined, current site.
|
||||||
|
* @param {boolean} [ignoreCache] True if it should ignore cached data (it will always fail in offline or server down).
|
||||||
* @return {Promise<any>} Promise to be resolved when the course competencies are retrieved.
|
* @return {Promise<any>} Promise to be resolved when the course competencies are retrieved.
|
||||||
*/
|
*/
|
||||||
getCourseCompetencies(courseId: number, userId?: number, siteId?: string): Promise<any> {
|
getCourseCompetencies(courseId: number, userId?: number, siteId?: string, ignoreCache?: boolean): Promise<any> {
|
||||||
return this.sitesProvider.getSite(siteId).then((site) => {
|
return this.sitesProvider.getSite(siteId).then((site) => {
|
||||||
|
|
||||||
this.logger.debug('Get course competencies for course ' + courseId);
|
this.logger.debug('Get course competencies for course ' + courseId);
|
||||||
|
@ -295,10 +310,15 @@ export class AddonCompetencyProvider {
|
||||||
const params = {
|
const params = {
|
||||||
courseid: courseId
|
courseid: courseId
|
||||||
},
|
},
|
||||||
preSets = {
|
preSets: any = {
|
||||||
cacheKey: this.getCourseCompetenciesCacheKey(courseId)
|
cacheKey: this.getCourseCompetenciesCacheKey(courseId)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (ignoreCache) {
|
||||||
|
preSets.getFromCache = false;
|
||||||
|
preSets.emergencyCache = false;
|
||||||
|
}
|
||||||
|
|
||||||
return site.read('tool_lp_data_for_course_competencies_page', params, preSets).then((response) => {
|
return site.read('tool_lp_data_for_course_competencies_page', params, preSets).then((response) => {
|
||||||
if (response.competencies) {
|
if (response.competencies) {
|
||||||
return response;
|
return response;
|
||||||
|
|
|
@ -90,4 +90,30 @@ export class AddonCompetencyCourseOptionHandler implements CoreCourseOptionsHand
|
||||||
|
|
||||||
return this.competencyProvider.invalidateCourseCompetencies(courseId);
|
return this.competencyProvider.invalidateCourseCompetencies(courseId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a course is downloaded. It should prefetch all the data to be able to see the addon in offline.
|
||||||
|
*
|
||||||
|
* @param {any} course The course.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
prefetch(course: any): Promise<any> {
|
||||||
|
// Get the competencies in the course.
|
||||||
|
return this.competencyProvider.getCourseCompetencies(course.id, undefined, undefined, true).then((competencies) => {
|
||||||
|
const promises = [];
|
||||||
|
|
||||||
|
// Prefetch all the competencies.
|
||||||
|
if (competencies && competencies.competencies) {
|
||||||
|
competencies.competencies.forEach((competency) => {
|
||||||
|
promises.push(this.competencyProvider.getCompetencyInCourse(course.id, competency.competency.id, undefined,
|
||||||
|
undefined, true));
|
||||||
|
|
||||||
|
promises.push(this.competencyProvider.getCompetencySummary(competency.competency.id, undefined, undefined,
|
||||||
|
true));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return Promise.all(promises);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,4 +86,17 @@ export class AddonCourseCompletionCourseOptionHandler implements CoreCourseOptio
|
||||||
invalidateEnabledForCourse(courseId: number, navOptions?: any, admOptions?: any): Promise<any> {
|
invalidateEnabledForCourse(courseId: number, navOptions?: any, admOptions?: any): Promise<any> {
|
||||||
return this.courseCompletionProvider.invalidateCourseCompletion(courseId);
|
return this.courseCompletionProvider.invalidateCourseCompletion(courseId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a course is downloaded. It should prefetch all the data to be able to see the addon in offline.
|
||||||
|
*
|
||||||
|
* @param {any} course The course.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
prefetch(course: any): Promise<any> {
|
||||||
|
return this.courseCompletionProvider.getCompletion(course.id, undefined, {
|
||||||
|
getFromCache: false,
|
||||||
|
emergencyCache: false
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,4 +71,14 @@ export class AddonNotesCourseOptionHandler implements CoreCourseOptionsHandler {
|
||||||
component: AddonNotesListComponent,
|
component: AddonNotesListComponent,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a course is downloaded. It should prefetch all the data to be able to see the addon in offline.
|
||||||
|
*
|
||||||
|
* @param {any} course The course.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
prefetch(course: any): Promise<any> {
|
||||||
|
return this.notesProvider.getNotes(course.id, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ import { Injectable, Injector } from '@angular/core';
|
||||||
import { CoreCourseOptionsHandler, CoreCourseOptionsHandlerData } from '@core/course/providers/options-delegate';
|
import { CoreCourseOptionsHandler, CoreCourseOptionsHandlerData } from '@core/course/providers/options-delegate';
|
||||||
import { CoreCourseProvider } from '@core/course/providers/course';
|
import { CoreCourseProvider } from '@core/course/providers/course';
|
||||||
import { CoreGradesProvider } from './grades';
|
import { CoreGradesProvider } from './grades';
|
||||||
|
import { CoreGradesHelperProvider } from './helper';
|
||||||
import { CoreCoursesProvider } from '@core/courses/providers/courses';
|
import { CoreCoursesProvider } from '@core/courses/providers/courses';
|
||||||
import { CoreGradesCourseComponent } from '../components/course/course';
|
import { CoreGradesCourseComponent } from '../components/course/course';
|
||||||
|
|
||||||
|
@ -27,7 +28,8 @@ export class CoreGradesCourseOptionHandler implements CoreCourseOptionsHandler {
|
||||||
name = 'CoreGrades';
|
name = 'CoreGrades';
|
||||||
priority = 400;
|
priority = 400;
|
||||||
|
|
||||||
constructor(private gradesProvider: CoreGradesProvider, private coursesProvider: CoreCoursesProvider) {}
|
constructor(private gradesProvider: CoreGradesProvider, private coursesProvider: CoreCoursesProvider,
|
||||||
|
private gradesHelper: CoreGradesHelperProvider) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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.
|
||||||
|
@ -90,4 +92,28 @@ export class CoreGradesCourseOptionHandler implements CoreCourseOptionsHandler {
|
||||||
component: CoreGradesCourseComponent
|
component: CoreGradesCourseComponent
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a course is downloaded. It should prefetch all the data to be able to see the addon in offline.
|
||||||
|
*
|
||||||
|
* @param {any} course The course.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
prefetch(course: any): Promise<any> {
|
||||||
|
return this.gradesProvider.getCourseGradesTable(course.id, undefined, undefined, true).then((table) => {
|
||||||
|
const promises = [];
|
||||||
|
|
||||||
|
table = this.gradesHelper.formatGradesTable(table);
|
||||||
|
|
||||||
|
if (table && table.rows) {
|
||||||
|
table.rows.forEach((row) => {
|
||||||
|
if (row.itemtype != 'category') {
|
||||||
|
promises.push(this.gradesHelper.getGradeItem(course.id, row.id, undefined, undefined, true));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return Promise.all(promises);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,4 +89,30 @@ export class CoreUserParticipantsCourseOptionHandler implements CoreCourseOption
|
||||||
component: CoreUserParticipantsComponent
|
component: CoreUserParticipantsComponent
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when a course is downloaded. It should prefetch all the data to be able to see the addon in offline.
|
||||||
|
*
|
||||||
|
* @param {any} course The course.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
prefetch(course: any): Promise<any> {
|
||||||
|
return this.getParticipantsPage(course.id, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a participant page and, if there are more participants, call the function again to get it too.
|
||||||
|
*
|
||||||
|
* @param {number} courseId Course ID.
|
||||||
|
* @param {number} limitFrom The number of participants already loaded.
|
||||||
|
* @return {Promise<any>} Promise resolved when done.
|
||||||
|
*/
|
||||||
|
protected getParticipantsPage(courseId: number, limitFrom: number): Promise<any> {
|
||||||
|
return this.userProvider.getParticipants(courseId, limitFrom, undefined, undefined, true).then((result) => {
|
||||||
|
if (result.canLoadMore) {
|
||||||
|
// There are more participants, load the next ones.
|
||||||
|
return this.getParticipantsPage(courseId, limitFrom + result.participants.length);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,10 +116,12 @@ export class CoreUserProvider {
|
||||||
* @param {number} limitFrom Position of the first participant to get.
|
* @param {number} limitFrom Position of the first participant to get.
|
||||||
* @param {number} limitNumber Number of participants to get.
|
* @param {number} limitNumber Number of participants to get.
|
||||||
* @param {string} [siteId] Site Id. If not defined, use current site.
|
* @param {string} [siteId] Site Id. If not defined, use current site.
|
||||||
* @return {Promise<any>} Promise to be resolved when the participants are retrieved.
|
* @param {boolean} [ignoreCache] True if it should ignore cached data (it will always fail in offline or server down).
|
||||||
|
* @return {Promise<{participants: any[], canLoadMore: boolean}>} Promise resolved when the participants are retrieved.
|
||||||
*/
|
*/
|
||||||
getParticipants(courseId: number, limitFrom: number = 0, limitNumber: number = CoreUserProvider.PARTICIPANTS_LIST_LIMIT,
|
getParticipants(courseId: number, limitFrom: number = 0, limitNumber: number = CoreUserProvider.PARTICIPANTS_LIST_LIMIT,
|
||||||
siteId?: string): Promise<any> {
|
siteId?: string, ignoreCache?: boolean): Promise<{participants: any[], canLoadMore: boolean}> {
|
||||||
|
|
||||||
return this.sitesProvider.getSite(siteId).then((site) => {
|
return this.sitesProvider.getSite(siteId).then((site) => {
|
||||||
this.logger.debug(`Get participants for course '${courseId}' starting at '${limitFrom}'`);
|
this.logger.debug(`Get participants for course '${courseId}' starting at '${limitFrom}'`);
|
||||||
|
|
||||||
|
@ -139,10 +141,15 @@ export class CoreUserProvider {
|
||||||
value: 'siteorder'
|
value: 'siteorder'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}, preSets = {
|
}, preSets: any = {
|
||||||
cacheKey: this.getParticipantsListCacheKey(courseId)
|
cacheKey: this.getParticipantsListCacheKey(courseId)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (ignoreCache) {
|
||||||
|
preSets.getFromCache = false;
|
||||||
|
preSets.emergencyCache = false;
|
||||||
|
}
|
||||||
|
|
||||||
return site.read('core_enrol_get_enrolled_users', data, preSets).then((users) => {
|
return site.read('core_enrol_get_enrolled_users', data, preSets).then((users) => {
|
||||||
const canLoadMore = users.length >= limitNumber;
|
const canLoadMore = users.length >= limitNumber;
|
||||||
this.storeUsers(users, siteId);
|
this.storeUsers(users, siteId);
|
||||||
|
|
Loading…
Reference in New Issue