2017-12-15 14:12:01 +00:00
|
|
|
<ion-header>
|
|
|
|
<ion-navbar>
|
2018-07-03 14:11:45 +00:00
|
|
|
<ion-title><core-format-text [text]="siteName"></core-format-text></ion-title>
|
2017-12-15 14:12:01 +00:00
|
|
|
|
|
|
|
<ion-buttons end>
|
2018-01-10 12:08:08 +00:00
|
|
|
<button *ngIf="tabShown == 'courses' && courses[courses.selected] && courses[courses.selected].length > 5" ion-button icon-only [attr.aria-label]="'core.courses.filtermycourses' | translate" (click)="switchFilter()">
|
2017-12-29 17:05:52 +00:00
|
|
|
<ion-icon name="funnel"></ion-icon>
|
|
|
|
</button>
|
2017-12-15 14:12:01 +00:00
|
|
|
<button *ngIf="searchEnabled" ion-button icon-only (click)="openSearch()" [attr.aria-label]="'core.courses.searchcourses' | translate">
|
|
|
|
<ion-icon name="search"></ion-icon>
|
|
|
|
</button>
|
|
|
|
</ion-buttons>
|
|
|
|
</ion-navbar>
|
|
|
|
</ion-header>
|
|
|
|
<ion-content>
|
2018-01-19 08:00:59 +00:00
|
|
|
<core-tabs [selectedIndex]="firstSelectedTab" [hideUntil]="tabsReady">
|
|
|
|
<!-- Site home tab. -->
|
|
|
|
<core-tab [show]="siteHomeEnabled" [title]="'core.sitehome.sitehome' | translate" (ionSelect)="tabChanged('sitehome')">
|
2018-01-19 14:41:14 +00:00
|
|
|
<ng-template>
|
2018-07-13 07:37:57 +00:00
|
|
|
<ion-content>
|
|
|
|
<ion-refresher [enabled]="siteHomeComponent && siteHomeComponent.dataLoaded" (ionRefresh)="siteHomeComponent.doRefresh($event)">
|
|
|
|
<ion-refresher-content pullingText="{{ 'core.pulltorefresh' | translate }}"></ion-refresher-content>
|
|
|
|
</ion-refresher>
|
|
|
|
<core-sitehome-index></core-sitehome-index>
|
|
|
|
</ion-content>
|
2018-01-19 14:41:14 +00:00
|
|
|
</ng-template>
|
2018-01-19 08:00:59 +00:00
|
|
|
</core-tab>
|
|
|
|
|
2018-01-19 14:41:14 +00:00
|
|
|
<!-- Courses tab. -->
|
|
|
|
<core-tab [title]="'core.courses.courses' | translate" (ionSelect)="tabChanged('courses')">
|
|
|
|
<ng-template>
|
|
|
|
<ion-content>
|
|
|
|
<ion-refresher [enabled]="timeline.loaded || timelineCourses.loaded || courses.loaded" (ionRefresh)="refreshMyOverview($event)">
|
|
|
|
<ion-refresher-content pullingText="{{ 'core.pulltorefresh' | translate }}"></ion-refresher-content>
|
|
|
|
</ion-refresher>
|
|
|
|
|
|
|
|
<core-loading [hideUntil]="courses.loaded" class="core-loading-center">
|
|
|
|
<!-- "Time" selector. -->
|
|
|
|
<div no-padding class="clearfix" [hidden]="showFilter">
|
2018-01-24 14:28:47 +00:00
|
|
|
<ion-select [title]="'core.show' | translate" [(ngModel)]="courses.selected" float-start (ngModelChange)="selectedChanged()" interface="popover">
|
2018-01-19 14:41:14 +00:00
|
|
|
<ion-option value="inprogress">{{ 'core.courses.inprogress' | translate }}</ion-option>
|
|
|
|
<ion-option value="future">{{ 'core.courses.future' | translate }}</ion-option>
|
|
|
|
<ion-option value="past">{{ 'core.courses.past' | translate }}</ion-option>
|
|
|
|
</ion-select>
|
|
|
|
<!-- Download all courses. -->
|
2018-05-18 13:32:43 +00:00
|
|
|
<div *ngIf="downloadAllCoursesEnabled && courses[courses.selected] && courses[courses.selected].length > 1" class="core-button-spinner" float-end>
|
2018-01-19 14:41:14 +00:00
|
|
|
<button *ngIf="prefetchCoursesData[courses.selected].icon && prefetchCoursesData[courses.selected].icon != 'spinner'" ion-button icon-only clear color="dark" (click)="prefetchCourses()">
|
2018-06-07 09:22:51 +00:00
|
|
|
<core-icon [name]="prefetchCoursesData[courses.selected].icon"></core-icon>
|
2018-01-19 14:41:14 +00:00
|
|
|
</button>
|
|
|
|
<ion-spinner *ngIf="!prefetchCoursesData[courses.selected].icon || prefetchCoursesData[courses.selected].icon == 'spinner'"></ion-spinner>
|
|
|
|
<span float-end *ngIf="prefetchCoursesData[courses.selected].badge">{{prefetchCoursesData[courses.selected].badge}}</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
2018-07-05 14:40:25 +00:00
|
|
|
<core-empty-box *ngIf="courses[courses.selected].length == 0 && courses.selected == 'inprogress'" image="assets/img/icons/courses.svg" [message]="'core.courses.nocoursesinprogress' | translate"></core-empty-box>
|
|
|
|
<core-empty-box *ngIf="courses[courses.selected].length == 0 && courses.selected == 'future'" image="assets/img/icons/courses.svg" [message]="'core.courses.nocoursesfuture' | translate"></core-empty-box>
|
|
|
|
<core-empty-box *ngIf="courses[courses.selected].length == 0 && courses.selected == 'past'" image="assets/img/icons/courses.svg" [message]="'core.courses.nocoursespast' | translate"></core-empty-box>
|
|
|
|
|
2018-01-19 14:41:14 +00:00
|
|
|
<!-- Filter courses. -->
|
2018-06-19 10:29:12 +00:00
|
|
|
<ion-searchbar #searchbar *ngIf="showFilter" [(ngModel)]="courses.filter" (ionInput)="filterChanged($event)" (ionCancel)="filterChanged()" [placeholder]="'core.courses.filtermycourses' | translate">
|
2018-02-14 16:19:09 +00:00
|
|
|
</ion-searchbar>
|
2018-01-19 14:41:14 +00:00
|
|
|
<!-- List of courses. -->
|
|
|
|
<div>
|
|
|
|
<ion-grid no-padding>
|
|
|
|
<ion-row no-padding>
|
|
|
|
<ion-col *ngFor="let course of filteredCourses" no-padding col-12 col-sm-6 col-md-6 col-lg-4 col-xl-4 align-self-stretch>
|
|
|
|
<core-courses-course-progress [course]="course" class="core-courseoverview"></core-courses-course-progress>
|
|
|
|
</ion-col>
|
|
|
|
</ion-row>
|
|
|
|
</ion-grid>
|
|
|
|
</div>
|
|
|
|
</core-loading>
|
|
|
|
</ion-content>
|
|
|
|
</ng-template>
|
2018-01-12 11:27:57 +00:00
|
|
|
</core-tab>
|
2018-07-05 06:59:21 +00:00
|
|
|
|
|
|
|
<!-- Timeline tab. -->
|
|
|
|
<core-tab [title]="'core.courses.timeline' | translate" (ionSelect)="tabChanged('timeline')">
|
|
|
|
<ng-template>
|
|
|
|
<ion-content>
|
|
|
|
<ion-refresher [enabled]="timeline.loaded || timelineCourses.loaded || courses.loaded" (ionRefresh)="refreshMyOverview($event)">
|
|
|
|
<ion-refresher-content pullingText="{{ 'core.pulltorefresh' | translate }}"></ion-refresher-content>
|
|
|
|
</ion-refresher>
|
|
|
|
|
|
|
|
<div no-padding [hidden]="!(timeline.loaded || timelineCourses.loaded)">
|
|
|
|
<ion-select [(ngModel)]="timeline.sort" (ngModelChange)="switchSort()" interface="popover">
|
|
|
|
<ion-option value="sortbydates">{{ 'core.courses.sortbydates' | translate }}</ion-option>
|
|
|
|
<ion-option value="sortbycourses">{{ 'core.courses.sortbycourses' | translate }}</ion-option>
|
|
|
|
</ion-select>
|
|
|
|
</div>
|
|
|
|
<core-loading [hideUntil]="timeline.loaded" [hidden]="timeline.sort != 'sortbydates'" class="core-loading-center">
|
|
|
|
<core-courses-overview-events [events]="timeline.events" showCourse="true" [canLoadMore]="timeline.canLoadMore" (loadMore)="loadMoreTimeline()"></core-courses-overview-events>
|
|
|
|
</core-loading>
|
|
|
|
<core-loading [hideUntil]="timelineCourses.loaded" [hidden]="timeline.sort != 'sortbycourses'" class="core-loading-center">
|
|
|
|
<ion-grid no-padding>
|
|
|
|
<ion-row no-padding>
|
|
|
|
<ion-col *ngFor="let course of timelineCourses.courses" no-padding col-12 col-md-6>
|
|
|
|
<core-courses-course-progress [course]="course">
|
|
|
|
<core-courses-overview-events [events]="course.events" [canLoadMore]="course.canLoadMore" (loadMore)="loadMoreCourse(course)"></core-courses-overview-events>
|
|
|
|
</core-courses-course-progress>
|
|
|
|
</ion-col>
|
|
|
|
</ion-row>
|
|
|
|
</ion-grid>
|
|
|
|
<core-empty-box *ngIf="timelineCourses.courses.length == 0" image="assets/img/icons/courses.svg" [message]="'core.courses.nocoursesoverview' | translate"></core-empty-box>
|
|
|
|
</core-loading>
|
|
|
|
</ion-content>
|
|
|
|
</ng-template>
|
|
|
|
</core-tab>
|
2018-01-12 11:27:57 +00:00
|
|
|
</core-tabs>
|
2018-01-24 10:35:49 +00:00
|
|
|
</ion-content>
|