From 2a6a3876b9a104f47015323db9dd7e1b9fd9f52e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pau=20Ferrer=20Oca=C3=B1a?= Date: Fri, 22 Nov 2019 13:44:49 +0100 Subject: [PATCH 1/2] MOBILE-3217 course: Support custom course card colors --- .../core-courses-course-progress.html | 4 +- .../course-progress/course-progress.scss | 1 + src/core/courses/providers/helper.ts | 38 ++++++++++++++----- 3 files changed, 31 insertions(+), 12 deletions(-) diff --git a/src/core/courses/components/course-progress/core-courses-course-progress.html b/src/core/courses/components/course-progress/core-courses-course-progress.html index fb870dbba..646d9edcb 100644 --- a/src/core/courses/components/course-progress/core-courses-course-progress.html +++ b/src/core/courses/components/course-progress/core-courses-course-progress.html @@ -1,5 +1,5 @@ - -
+ +
diff --git a/src/core/courses/components/course-progress/course-progress.scss b/src/core/courses/components/course-progress/course-progress.scss index ef274566e..a5f0f750a 100644 --- a/src/core/courses/components/course-progress/course-progress.scss +++ b/src/core/courses/components/course-progress/course-progress.scss @@ -21,6 +21,7 @@ ion-app.app-root core-courses-course-progress { position: relative; background-position: center; background-size: cover; + @include core-transition(all, 50ms); &.core-course-color-img { background: white; diff --git a/src/core/courses/providers/helper.ts b/src/core/courses/providers/helper.ts index 33d4ca571..b918d3b1c 100644 --- a/src/core/courses/providers/helper.ts +++ b/src/core/courses/providers/helper.ts @@ -15,6 +15,7 @@ import { Injectable } from '@angular/core'; import { PopoverController } from 'ionic-angular'; import { CoreUtilsProvider } from '@providers/utils/utils'; +import { CoreSitesProvider } from '@providers/sites'; import { CoreCoursesProvider } from './courses'; import { AddonCourseCompletionProvider } from '@addon/coursecompletion/providers/coursecompletion'; import { TranslateService } from '@ngx-translate/core'; @@ -26,11 +27,12 @@ import { CoreCoursePickerMenuPopoverComponent } from '@components/course-picker- @Injectable() export class CoreCoursesHelperProvider { - constructor(private coursesProvider: CoreCoursesProvider, - private utils: CoreUtilsProvider, - private courseCompletionProvider: AddonCourseCompletionProvider, - private translate: TranslateService, - private popoverCtrl: PopoverController) { } + constructor(protected coursesProvider: CoreCoursesProvider, + protected utils: CoreUtilsProvider, + protected courseCompletionProvider: AddonCourseCompletionProvider, + protected translate: TranslateService, + protected popoverCtrl: PopoverController, + protected sitesProvider: CoreSitesProvider) { } /** * Get the courses to display the course picker popover. If a courseId is specified, it will also return its categoryId. @@ -105,10 +107,22 @@ export class CoreCoursesHelperProvider { return Promise.resolve(); } - const promises = []; - let coursesInfo = []; + let coursesInfo = [], + courseInfoAvailable = false; - let courseInfoAvalaible = false; + const site = this.sitesProvider.getCurrentSite(), + promises = [], + colors = []; + + if (site.isVersionGreaterEqualThan('3.8')) { + promises.push(site.getConfig().then((configs) => { + for (let x = 0; x < 10; x++) { + colors[x] = configs['core_admin_coursecolor' + (x + 1)] || null; + } + }).catch(() => { + // Ignore errors. + })); + } if (this.coursesProvider.isGetCoursesByFieldAvailable() && (loadCategoryNames || (typeof courses[0].overviewfiles == 'undefined' && typeof courses[0].displayname == 'undefined'))) { @@ -116,7 +130,7 @@ export class CoreCoursesHelperProvider { return course.id; }).join(','); - courseInfoAvalaible = true; + courseInfoAvailable = true; // Get the extra data for the courses. promises.push(this.coursesProvider.getCoursesByField('ids', courseIds).then((coursesInfos) => { @@ -126,7 +140,11 @@ export class CoreCoursesHelperProvider { return Promise.all(promises).then(() => { courses.forEach((course) => { - this.loadCourseExtraInfo(course, courseInfoAvalaible ? coursesInfo[course.id] : course, loadCategoryNames); + this.loadCourseExtraInfo(course, courseInfoAvailable ? coursesInfo[course.id] : course, loadCategoryNames); + if (!course.courseImage) { + course.colorNumber = course.id % 10; + course.color = colors[course.colorNumber]; + } }); }); } From bc33ae3bf809b8d03f85b3675e36732aeb674771 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pau=20Ferrer=20Oca=C3=B1a?= Date: Wed, 4 Dec 2019 15:07:22 +0100 Subject: [PATCH 2/2] MOBILE-3217 course: Check colors array is populated --- src/core/courses/providers/helper.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/courses/providers/helper.ts b/src/core/courses/providers/helper.ts index b918d3b1c..0d98fe61e 100644 --- a/src/core/courses/providers/helper.ts +++ b/src/core/courses/providers/helper.ts @@ -143,7 +143,7 @@ export class CoreCoursesHelperProvider { this.loadCourseExtraInfo(course, courseInfoAvailable ? coursesInfo[course.id] : course, loadCategoryNames); if (!course.courseImage) { course.colorNumber = course.id % 10; - course.color = colors[course.colorNumber]; + course.color = colors.length && colors[course.colorNumber]; } }); });