147 lines
8.9 KiB
HTML
147 lines
8.9 KiB
HTML
<ion-header>
|
|
<ion-toolbar>
|
|
<ion-buttons slot="start">
|
|
<ion-back-button [text]="'core.back' | translate"></ion-back-button>
|
|
</ion-buttons>
|
|
<ion-title>
|
|
<h1>{{ 'addon.competency.coursecompetencies' | translate }}</h1>
|
|
</ion-title>
|
|
</ion-toolbar>
|
|
</ion-header>
|
|
<ion-content>
|
|
<ion-refresher slot="fixed" [disabled]="!competencies.loaded" (ionRefresh)="refreshCourseCompetencies($event.target)">
|
|
<ion-refresher-content pullingText="{{ 'core.pulltorefresh' | translate }}"></ion-refresher-content>
|
|
</ion-refresher>
|
|
<core-loading [hideUntil]="competencies.loaded">
|
|
<ion-card *ngIf="!user && courseCompetencies && courseCompetencies.statistics.competencycount > 0">
|
|
<ng-container *ngIf="courseCompetencies.cangradecompetencies">
|
|
<ion-item class="ion-text-wrap" *ngIf="courseCompetencies.settings.pushratingstouserplans">
|
|
<ion-label>{{ 'addon.competency.coursecompetencyratingsarepushedtouserplans' | translate }}</ion-label>
|
|
</ion-item>
|
|
<ion-item class="ion-text-wrap" *ngIf="!courseCompetencies.settings.pushratingstouserplans" color="danger">
|
|
<ion-label>{{ 'addon.competency.coursecompetencyratingsarenotpushedtouserplans' | translate }}</ion-label>
|
|
</ion-item>
|
|
</ng-container>
|
|
<ion-item class="ion-text-wrap" *ngIf="courseCompetencies.statistics.canbegradedincourse">
|
|
<ion-label>
|
|
<span id="addon-competency-course-{{courseId}}-progress">
|
|
{{ 'addon.competency.xcompetenciesproficientoutofyincourse' | translate: {$a:
|
|
{x: courseCompetencies.statistics.proficientcompetencycount, y: courseCompetencies.statistics.competencycount} } }}
|
|
</span>
|
|
<core-progress-bar [progress]="courseCompetencies.statistics.proficientcompetencypercentage"
|
|
ariaDescribedBy="addon-competency-course-{{courseId}}-progress">
|
|
</core-progress-bar>
|
|
</ion-label>
|
|
</ion-item>
|
|
<ion-item class="ion-text-wrap"
|
|
*ngIf="courseCompetencies.statistics.canmanagecoursecompetencies && courseCompetencies.statistics.leastproficientcount > 0">
|
|
<ion-label>
|
|
<p class="item-heading">{{ 'addon.competency.competenciesmostoftennotproficientincourse' | translate }}</p>
|
|
<p *ngFor="let comp of courseCompetencies.statistics.leastproficient">
|
|
<button class="as-link" (click)="openCompetencySummary(comp.id)">
|
|
{{ comp.shortname }} - {{ comp.idnumber }}
|
|
</button>
|
|
</p>
|
|
</ion-label>
|
|
</ion-item>
|
|
</ion-card>
|
|
|
|
<h2 class="ion-margin-horizontal" *ngIf="courseCompetencies && courseCompetencies.statistics.competencycount > 0">
|
|
{{ 'addon.competency.coursecompetencies' | translate }}
|
|
</h2>
|
|
<ion-card *ngIf="user">
|
|
<ion-item class="ion-text-wrap">
|
|
<core-user-avatar [user]="user" slot="start"></core-user-avatar>
|
|
<ion-label>
|
|
<h2>{{ user.fullname }}</h2>
|
|
</ion-label>
|
|
</ion-item>
|
|
</ion-card>
|
|
<core-empty-box *ngIf="courseCompetencies && courseCompetencies.statistics.competencycount == 0" icon="fas-award"
|
|
message="{{ 'addon.competency.nocompetenciesincourse' | translate }}">
|
|
</core-empty-box>
|
|
|
|
<div *ngIf="competencies.loaded">
|
|
<ion-card *ngFor="let competency of competencies.items">
|
|
<ion-item class="ion-text-wrap" (click)="competencies.select(competency)"
|
|
[attr.aria-label]="competency.competency.shortname" detail="true" button>
|
|
<ion-label>
|
|
<p class="item-heading">
|
|
{{competency.competency.shortname}} <em>{{competency.competency.idnumber}}</em>
|
|
</p>
|
|
</ion-label>
|
|
<ion-badge slot="end" *ngIf="competency.usercompetencycourse && competency.usercompetencycourse.gradename"
|
|
[color]="competency.usercompetencycourse.proficiency ? 'success' : 'danger'">
|
|
{{ competency.usercompetencycourse.gradename }}
|
|
</ion-badge>
|
|
</ion-item>
|
|
<ion-item class="ion-text-wrap">
|
|
<ion-label>
|
|
<p *ngIf="competency.competency.description">
|
|
<core-format-text [text]="competency.competency.description" contextLevel="course"
|
|
[contextInstanceId]="courseId">
|
|
</core-format-text>
|
|
</p>
|
|
<div>
|
|
<p class="item-heading">{{ 'addon.competency.path' | translate }}</p>
|
|
<p>
|
|
<a *ngIf="competency.comppath.showlinks" [href]="getCompetencyFrameworkUrl(competency)" core-link
|
|
[title]="competency.comppath.framework.name">
|
|
{{ competency.comppath.framework.name }}
|
|
</a>
|
|
<ng-container *ngIf="!competency.comppath.showlinks">
|
|
{{ competency.comppath.framework.name }}
|
|
</ng-container>
|
|
/
|
|
<ng-container *ngFor="let ancestor of competency.comppath.ancestors">
|
|
<button class="as-link" *ngIf="competency.comppath.showlinks"
|
|
(click)="openCompetencySummary(ancestor.id)">
|
|
{{ ancestor.name }}
|
|
</button>
|
|
<ng-container *ngIf="!competency.comppath.showlinks">{{ ancestor.name }}</ng-container>
|
|
<ng-container *ngIf="!ancestor.last"> / </ng-container>
|
|
</ng-container>
|
|
</p>
|
|
</div>
|
|
<div *ngIf="courseCompetencies?.statistics.canmanagecoursecompetencies">
|
|
<p class="item-heading">{{ 'addon.competency.uponcoursecompletion' | translate }}</p>
|
|
<ng-container *ngFor="let ruleoutcome of competency.ruleoutcomeoptions">
|
|
<span *ngIf="ruleoutcome.selected">{{ ruleoutcome.text }}</span>
|
|
</ng-container>
|
|
</div>
|
|
<div>
|
|
<p class="item-heading">{{ 'addon.competency.activities' | translate }}</p>
|
|
<p *ngIf="competency.coursemodules.length == 0">
|
|
{{ 'addon.competency.noactivities' | translate }}
|
|
</p>
|
|
<ion-item class="ion-text-wrap core-course-module-handler item-media" [attr.aria-label]="activity.name"
|
|
core-link *ngFor="let activity of competency.coursemodules" [href]="activity.url" capture="true">
|
|
<core-mod-icon slot="start" [modicon]="activity.iconurl" [showAlt]="false" *ngIf="activity.iconurl">
|
|
</core-mod-icon>
|
|
<ion-label>
|
|
<core-format-text [text]="activity.name" contextLevel="module" [contextInstanceId]="activity.id"
|
|
[courseId]="courseId">
|
|
</core-format-text>
|
|
</ion-label>
|
|
</ion-item>
|
|
</div>
|
|
<div *ngIf="competency.plans">
|
|
<p class="item-heading">{{ 'addon.competency.userplans' | translate }}</p>
|
|
<p *ngIf="competency.plans.length == 0">
|
|
{{ 'addon.competency.nouserplanswithcompetency' | translate }}
|
|
</p>
|
|
<ion-item class="ion-text-wrap" *ngFor="let plan of competency.plans" [href]="plan.url"
|
|
[attr.aria-label]="plan.name" core-link capture="true">
|
|
<ion-label>
|
|
<core-format-text [text]="plan.name" contextLevel="user" [contextInstanceId]="plan.userid">
|
|
</core-format-text>
|
|
</ion-label>
|
|
</ion-item>
|
|
</div>
|
|
</ion-label>
|
|
</ion-item>
|
|
</ion-card>
|
|
</div>
|
|
</core-loading>
|
|
</ion-content>
|