MOBILE-2359 workshop: Display correct number of dimensions

main
Pau Ferrer Ocaña 2018-07-05 16:30:53 +02:00
parent bfd4e9c936
commit 1515e2b678
5 changed files with 88 additions and 80 deletions

View File

@ -1,27 +1,29 @@
<ion-card *ngFor="let field of assessment.form.fields; let n = index"> <ng-container *ngFor="let field of assessment.form.fields; let n = index">
<ion-item text-wrap> <ion-card *ngIf="n < assessment.form.dimenssionscount">
<h2>{{ field.dimtitle }}</h2> <ion-item text-wrap>
<core-format-text [text]="field.description"></core-format-text> <h2>{{ field.dimtitle }}</h2>
</ion-item> <core-format-text [text]="field.description"></core-format-text>
<ion-item *ngIf="edit && field.grades"> </ion-item>
<ion-label [core-mark-required]="true" stacked>{{ 'addon.mod_workshop_assessment_accumulative.dimensiongradefor' | translate : {'$a': field.dimtitle } }}</ion-label> <ion-item *ngIf="edit && field.grades">
<ion-select [(ngModel)]="selectedValues[n].grade" interface="popover"> <ion-label [core-mark-required]="true" stacked>{{ 'addon.mod_workshop_assessment_accumulative.dimensiongradefor' | translate : {'$a': field.dimtitle } }}</ion-label>
<ion-option *ngFor="let grade of field.grades" [value]="grade.value">{{grade.label}}</ion-option> <ion-select [(ngModel)]="selectedValues[n].grade" interface="popover">
</ion-select> <ion-option *ngFor="let grade of field.grades" [value]="grade.value">{{grade.label}}</ion-option>
<core-input-errors item-content *ngIf="fieldErrors['grade_' + n]" [errorText]="fieldErrors['grade_' + n]"></core-input-errors> </ion-select>
</ion-item> <core-input-errors item-content *ngIf="fieldErrors['grade_' + n]" [errorText]="fieldErrors['grade_' + n]"></core-input-errors>
<ion-item *ngIf="!edit && field.grades" text-wrap> </ion-item>
<h2>{{ 'addon.mod_workshop_assessment_accumulative.dimensiongradefor' | translate : {'$a': field.dimtitle } }}</h2> <ion-item *ngIf="!edit && field.grades" text-wrap>
<ng-container *ngFor="let grade of field.grades"> <h2>{{ 'addon.mod_workshop_assessment_accumulative.dimensiongradefor' | translate : {'$a': field.dimtitle } }}</h2>
<p *ngIf="grade.value === selectedValues[n].grade">{{grade.label}}</p> <ng-container *ngFor="let grade of field.grades">
</ng-container> <p *ngIf="grade.value === selectedValues[n].grade">{{grade.label}}</p>
</ion-item> </ng-container>
<ion-item *ngIf="edit"> </ion-item>
<ion-label stacked>{{ 'addon.mod_workshop_assessment_accumulative.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label> <ion-item *ngIf="edit">
<ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" core-auto-rows></ion-textarea> <ion-label stacked>{{ 'addon.mod_workshop_assessment_accumulative.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
</ion-item> <ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" core-auto-rows></ion-textarea>
<ion-item *ngIf="!edit" text-wrap> </ion-item>
<h2>{{ 'addon.mod_workshop_assessment_accumulative.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2> <ion-item *ngIf="!edit" text-wrap>
<p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p> <h2>{{ 'addon.mod_workshop_assessment_accumulative.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2>
</ion-item> <p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p>
</ion-card> </ion-item>
</ion-card>
</ng-container>

View File

@ -1,15 +1,17 @@
<ion-card *ngFor="let field of assessment.form.fields; let n = index"> <ng-container *ngFor="let field of assessment.form.fields; let n = index">
<ion-item text-wrap> <ion-card *ngIf="n < assessment.form.dimenssionscount">
<h2>{{ field.dimtitle }}</h2> <ion-item text-wrap>
<core-format-text [text]="field.description"></core-format-text> <h2>{{ field.dimtitle }}</h2>
</ion-item> <core-format-text [text]="field.description"></core-format-text>
<ion-item *ngIf="edit"> </ion-item>
<ion-label stacked [core-mark-required]="true">{{ 'addon.mod_workshop_assessment_comments.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label> <ion-item *ngIf="edit">
<ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" core-auto-rows></ion-textarea> <ion-label stacked [core-mark-required]="true">{{ 'addon.mod_workshop_assessment_comments.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
<core-input-errors item-content *ngIf="fieldErrors['peercomment_' + n]" [errorText]="fieldErrors['peercomment_' + n]"></core-input-errors> <ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" core-auto-rows></ion-textarea>
</ion-item> <core-input-errors item-content *ngIf="fieldErrors['peercomment_' + n]" [errorText]="fieldErrors['peercomment_' + n]"></core-input-errors>
<ion-item *ngIf="!edit" text-wrap> </ion-item>
<h2>{{ 'addon.mod_workshop_assessment_comments.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2> <ion-item *ngIf="!edit" text-wrap>
<p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p> <h2>{{ 'addon.mod_workshop_assessment_comments.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2>
</ion-item> <p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p>
</ion-card> </ion-item>
</ion-card>
</ng-container>

View File

@ -1,28 +1,30 @@
<ion-card *ngFor="let field of assessment.form.fields; let n = index"> <ng-container *ngFor="let field of assessment.form.fields; let n = index">
<ion-item text-wrap> <ion-card *ngIf="n < assessment.form.dimenssionscount">
<h2>{{ field.dimtitle }}</h2> <ion-item text-wrap>
<core-format-text [text]="field.description"></core-format-text> <h2>{{ field.dimtitle }}</h2>
</ion-item> <core-format-text [text]="field.description"></core-format-text>
<ion-list radio-group [(ngModel)]="selectedValues[n].grade" [name]="'grade_' + n">
<ion-item>
<ion-label stacked [core-mark-required]="edit">{{ 'addon.mod_workshop.yourassessmentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
<core-input-errors item-content *ngIf="edit && fieldErrors['grade_' + n]" [errorText]="fieldErrors['grade_' + n]"></core-input-errors>
</ion-item> </ion-item>
<ion-item> <ion-list radio-group [(ngModel)]="selectedValues[n].grade" [name]="'grade_' + n">
<ion-label><core-format-text [text]="field.grade0"></core-format-text></ion-label> <ion-item>
<ion-radio [value]="-1" [disabled]="!edit"></ion-radio> <ion-label stacked [core-mark-required]="edit">{{ 'addon.mod_workshop.yourassessmentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
<core-input-errors item-content *ngIf="edit && fieldErrors['grade_' + n]" [errorText]="fieldErrors['grade_' + n]"></core-input-errors>
</ion-item>
<ion-item>
<ion-label><core-format-text [text]="field.grade0"></core-format-text></ion-label>
<ion-radio [value]="-1" [disabled]="!edit"></ion-radio>
</ion-item>
<ion-item>
<ion-label><core-format-text [text]="field.grade1"></core-format-text></ion-label>
<ion-radio [value]="1" [disabled]="!edit"></ion-radio>
</ion-item>
</ion-list>
<ion-item *ngIf="edit">
<ion-label stacked>{{ 'addon.mod_workshop_assessment_numerrors.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
<ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" [name]="'peercomment_' + n" core-auto-rows></ion-textarea>
</ion-item> </ion-item>
<ion-item> <ion-item *ngIf="!edit" text-wrap>
<ion-label><core-format-text [text]="field.grade1"></core-format-text></ion-label> <h2>{{ 'addon.mod_workshop_assessment_numerrors.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2>
<ion-radio [value]="1" [disabled]="!edit"></ion-radio> <p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p>
</ion-item> </ion-item>
</ion-list> </ion-card>
<ion-item *ngIf="edit"> </ng-container>
<ion-label stacked>{{ 'addon.mod_workshop_assessment_numerrors.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</ion-label>
<ion-textarea aria-multiline="true" [(ngModel)]="selectedValues[n].peercomment" [name]="'peercomment_' + n" core-auto-rows></ion-textarea>
</ion-item>
<ion-item *ngIf="!edit" text-wrap>
<h2>{{ 'addon.mod_workshop_assessment_numerrors.dimensioncommentfor' | translate : {'$a': field.dimtitle } }}</h2>
<p><core-format-text [text]="selectedValues[n].peercomment"></core-format-text></p>
</ion-item>
</ion-card>

View File

@ -1,13 +1,15 @@
<ion-card *ngFor="let field of assessment.form.fields; let n = index"> <ng-container *ngFor="let field of assessment.form.fields; let n = index">
<ion-item text-wrap> <ion-card *ngIf="n < assessment.form.dimenssionscount">
<h2 [core-mark-required]="edit">{{ field.dimtitle }}</h2> <ion-item text-wrap>
<core-format-text [text]="field.description"></core-format-text> <h2 [core-mark-required]="edit">{{ field.dimtitle }}</h2>
<core-input-errors *ngIf="edit && fieldErrors['chosenlevelid_' + n]" [errorText]="fieldErrors['chosenlevelid_' + n]"></core-input-errors> <core-format-text [text]="field.description"></core-format-text>
</ion-item> <core-input-errors *ngIf="edit && fieldErrors['chosenlevelid_' + n]" [errorText]="fieldErrors['chosenlevelid_' + n]"></core-input-errors>
<ion-list radio-group [(ngModel)]="selectedValues[n].chosenlevelid" [name]="'chosenlevelid_' + n">
<ion-item *ngFor="let subfield of field.fields">
<ion-label><p><core-format-text [text]="subfield.definition"></core-format-text></p></ion-label>
<ion-radio [value]="subfield.levelid" [disabled]="!edit"></ion-radio>
</ion-item> </ion-item>
</ion-list> <ion-list radio-group [(ngModel)]="selectedValues[n].chosenlevelid" [name]="'chosenlevelid_' + n">
</ion-card> <ion-item *ngFor="let subfield of field.fields">
<ion-label><p><core-format-text [text]="subfield.definition"></core-format-text></p></ion-label>
<ion-radio [value]="subfield.levelid" [disabled]="!edit"></ion-radio>
</ion-item>
</ion-list>
</ion-card>
</ng-container>

View File

@ -17,7 +17,7 @@
<ion-item stacked *ngIf="edit"> <ion-item stacked *ngIf="edit">
<ion-label stacked [core-mark-required]="overallFeedkbackRequired">{{ 'addon.mod_workshop.feedbackauthor' | translate }}</ion-label> <ion-label stacked [core-mark-required]="overallFeedkbackRequired">{{ 'addon.mod_workshop.feedbackauthor' | translate }}</ion-label>
<core-rich-text-editor item-content [control]="feedbackControl" [component]="component" [componentId]="workshop.coursemodule" (contentChanged)="onFeedbackChange($event)"></core-rich-text-editor> <core-rich-text-editor item-content [control]="feedbackControl" [component]="component" [componentId]="workshop.coursemodule" (contentChanged)="onFeedbackChange($event)"></core-rich-text-editor>
<core-input-errors item-content *ngIf="overallFeedkbackRequired && fieldErrors['feedbackauthor']" [errorText]="fieldErrors['feedbackauthor']"></core-input-errors> <core-input-errors item-content *ngIf="overallFeedkbackRequired && fieldErrors && fieldErrors['feedbackauthor']" [errorText]="fieldErrors['feedbackauthor']"></core-input-errors>
</ion-item> </ion-item>
<core-attachments *ngIf="edit && workshop.overallfeedbackfiles" [files]="data.assessment.feedbackattachmentfiles" [maxSize]="workshop.overallfeedbackmaxbytes" <core-attachments *ngIf="edit && workshop.overallfeedbackfiles" [files]="data.assessment.feedbackattachmentfiles" [maxSize]="workshop.overallfeedbackmaxbytes"
[maxSubmissions]="workshop.overallfeedbackfiles" [component]="component" [componentId]="componentId" [allowOffline]="true"></core-attachments> [maxSubmissions]="workshop.overallfeedbackfiles" [component]="component" [componentId]="componentId" [allowOffline]="true"></core-attachments>