MOBILE-2795 dashboard: Filter all courses

main
Pau Ferrer Ocaña 2018-12-19 11:19:45 +01:00
parent 138221e136
commit f6732dbf22
3 changed files with 14 additions and 10 deletions

View File

@ -1,7 +1,7 @@
<ion-item-divider color="light"> <ion-item-divider color="light">
<h2>{{ 'addon.block_myoverview.pluginname' | translate }}</h2> <h2>{{ 'addon.block_myoverview.pluginname' | translate }}</h2>
<!-- Download all courses. --> <!-- Download all courses. -->
<div *ngIf="downloadAllCoursesEnabled && courses[selectedFilter] && courses[selectedFilter].length > 1" class="core-button-spinner" item-end> <div *ngIf="downloadAllCoursesEnabled && courses[selectedFilter] && courses[selectedFilter].length > 1 && !showFilter" class="core-button-spinner" item-end>
<button *ngIf="prefetchCoursesData[selectedFilter].icon && prefetchCoursesData[selectedFilter].icon != 'spinner'" ion-button icon-only clear color="dark" (click)="prefetchCourses()"> <button *ngIf="prefetchCoursesData[selectedFilter].icon && prefetchCoursesData[selectedFilter].icon != 'spinner'" ion-button icon-only clear color="dark" (click)="prefetchCourses()">
<core-icon [name]="prefetchCoursesData[selectedFilter].icon"></core-icon> <core-icon [name]="prefetchCoursesData[selectedFilter].icon"></core-icon>
</button> </button>

View File

@ -177,17 +177,17 @@ export class AddonBlockMyOverviewComponent extends CoreBlockBaseComponent implem
*/ */
filterChanged(event: any): void { filterChanged(event: any): void {
const newValue = event.target.value && event.target.value.trim().toLowerCase(); const newValue = event.target.value && event.target.value.trim().toLowerCase();
if (!newValue || !this.courses[this.selectedFilter]) { if (!newValue || !this.courses['all']) {
this.filteredCourses = this.courses[this.selectedFilter]; this.filteredCourses = this.courses['all'];
} else { } else {
// Use displayname if avalaible, or fullname if not. // Use displayname if avalaible, or fullname if not.
if (this.courses[this.selectedFilter].length > 0 && if (this.courses['all'].length > 0 &&
typeof this.courses[this.selectedFilter][0].displayname != 'undefined') { typeof this.courses['all'][0].displayname != 'undefined') {
this.filteredCourses = this.courses[this.selectedFilter].filter((course) => { this.filteredCourses = this.courses['all'].filter((course) => {
return course.displayname.toLowerCase().indexOf(newValue) > -1; return course.displayname.toLowerCase().indexOf(newValue) > -1;
}); });
} else { } else {
this.filteredCourses = this.courses[this.selectedFilter].filter((course) => { this.filteredCourses = this.courses['all'].filter((course) => {
return course.fullname.toLowerCase().indexOf(newValue) > -1; return course.fullname.toLowerCase().indexOf(newValue) > -1;
}); });
} }
@ -311,7 +311,7 @@ export class AddonBlockMyOverviewComponent extends CoreBlockBaseComponent implem
switchFilter(): void { switchFilter(): void {
this.showFilter = !this.showFilter; this.showFilter = !this.showFilter;
this.courses.filter = ''; this.courses.filter = '';
this.filteredCourses = this.courses[this.selectedFilter]; this.filteredCourses = this.courses[this.showFilter ? 'all' : this.selectedFilter];
if (this.showFilter) { if (this.showFilter) {
setTimeout(() => { setTimeout(() => {
this.searchbar.setFocus(); this.searchbar.setFocus();
@ -325,7 +325,7 @@ export class AddonBlockMyOverviewComponent extends CoreBlockBaseComponent implem
* @return {boolean} If switch button that enables the filter input is shown or not. * @return {boolean} If switch button that enables the filter input is shown or not.
*/ */
showFilterSwitchButton(): boolean { showFilterSwitchButton(): boolean {
return this.loaded && this.courses[this.selectedFilter] && this.courses[this.selectedFilter].length > 5; return this.loaded && this.courses['all'] && this.courses['all'].length > 5;
} }
/** /**

View File

@ -1,6 +1,10 @@
ion-app.app-root.ios { ion-app.app-root.ios {
.button-ios { .button-ios {
min-height: $button-ios-height min-height: $button-ios-height;
}
ion-searchbar.searchbar-ios .button-ios {
min-height: auto;
} }
// Light buttons color. // Light buttons color.