diff --git a/src/main/webapp/app/exercises/text/participate/text-editor.component.html b/src/main/webapp/app/exercises/text/participate/text-editor.component.html index c070d57e29ea..c240142e10c2 100644 --- a/src/main/webapp/app/exercises/text/participate/text-editor.component.html +++ b/src/main/webapp/app/exercises/text/participate/text-editor.component.html @@ -1,5 +1,5 @@
- @if (displayHeader) { + @if (displayHeader()) { {{ 'artemisApp.textSubmission.textEditor' | artemisTranslate }}: @@ -54,7 +54,7 @@ @if (isReadOnlyWithShowResult) { @if (showHistory) {
- +
} } @@ -64,7 +64,7 @@ @if (textExercise) { @@ -79,7 +79,7 @@ @@ -87,7 +87,7 @@ @@ -104,7 +104,7 @@ [disabled]="!isActive || !submission || !isOwnerOfParticipation" (keydown.tab)="onTextEditorTab(textEditor, $event)" (input)="onTextEditorInput($event)" - [hidden]="submission && !submission.submitted && isExamSummary" + [hidden]="submission && !submission.submitted && isExamSummary()" > @if (textExercise?.teamMode) { (); + displayHeader = input(true); + expandProblemStatement = input(true); + inputExercise = input(); + inputSubmission = input(); + inputParticipation = input(); + isExamSummary = input(false); textExercise: TextExercise; participation: StudentParticipation; @@ -109,7 +108,7 @@ export class TextEditorComponent implements OnInit, OnDestroy, ComponentCanDeact if (this.inputValuesArePresent()) { this.setupComponentWithInputValues(); } else { - const participationId = this.participationId !== undefined ? this.participationId : Number(this.route.snapshot.paramMap.get('participationId')); + const participationId = this.participationId() !== undefined ? this.participationId() : Number(this.route.snapshot.paramMap.get('participationId')); this.submissionId = Number(this.route.snapshot.paramMap.get('submissionId')) || undefined; if (Number.isNaN(participationId)) { @@ -121,7 +120,7 @@ export class TextEditorComponent implements OnInit, OnDestroy, ComponentCanDeact this.updateParticipation(this.participation, this.submissionId); }); - this.textService.get(participationId).subscribe({ + this.textService.get(participationId!).subscribe({ next: (data: StudentParticipation) => this.updateParticipation(data, this.submissionId), error: (error: HttpErrorResponse) => onError(this.alertService, error), }); @@ -164,7 +163,7 @@ export class TextEditorComponent implements OnInit, OnDestroy, ComponentCanDeact } private inputValuesArePresent(): boolean { - return !!(this.inputExercise || this.inputSubmission || this.inputParticipation); + return !!(this.inputExercise() || this.inputSubmission() || this.inputParticipation()); } /** @@ -175,14 +174,14 @@ export class TextEditorComponent implements OnInit, OnDestroy, ComponentCanDeact * @private */ private setupComponentWithInputValues() { - if (this.inputExercise) { - this.textExercise = this.inputExercise; + if (this.inputExercise() !== undefined) { + this.textExercise = this.inputExercise()!; } - if (this.inputSubmission) { - this.submission = this.inputSubmission; + if (this.inputSubmission() !== undefined) { + this.submission = this.inputSubmission()!; } - if (this.inputParticipation) { - this.participation = this.inputParticipation; + if (this.inputParticipation() !== undefined) { + this.participation = this.inputParticipation()!; } if (this.submission?.text) { diff --git a/src/main/webapp/app/overview/result-history/result-history.component.html b/src/main/webapp/app/overview/result-history/result-history.component.html index cfa6cdbb897e..3748b2755790 100644 --- a/src/main/webapp/app/overview/result-history/result-history.component.html +++ b/src/main/webapp/app/overview/result-history/result-history.component.html @@ -5,12 +5,19 @@ @for (result of displayedResults; track result; let i = $index) {
-
- +
+
(); + exercise = input(); + selectedResultId = input(); showPreviousDivider = false; displayedResults: Result[]; movedLastRatedResult: boolean; ngOnChanges(): void { - this.showPreviousDivider = this.results.length > MAX_RESULT_HISTORY_LENGTH; - if (this.exercise?.type === ExerciseType.TEXT || this.exercise?.type === ExerciseType.MODELING) { - this.displayedResults = this.results.filter((result) => result.successful !== undefined); + this.showPreviousDivider = this.results().length > MAX_RESULT_HISTORY_LENGTH; + if (this.exercise()?.type === ExerciseType.TEXT || this.exercise()?.type === ExerciseType.MODELING) { + this.displayedResults = this.results().filter((result) => result.successful !== undefined); } else { - this.displayedResults = this.results; + this.displayedResults = this.results(); } const successfulResultsLength = this.displayedResults.length; if (successfulResultsLength > MAX_RESULT_HISTORY_LENGTH) { this.displayedResults = this.displayedResults.slice(successfulResultsLength - MAX_RESULT_HISTORY_LENGTH); - const lastRatedResult = this.results.filter((result) => result.rated).last(); + const lastRatedResult = this.results() + .filter((result) => result.rated) + .last(); if (!this.displayedResults.first()?.rated && lastRatedResult) { this.displayedResults[0] = lastRatedResult; this.movedLastRatedResult = true; diff --git a/src/test/javascript/spec/component/overview/result-history/result-history.component.spec.ts b/src/test/javascript/spec/component/overview/result-history/result-history.component.spec.ts index 8c5333322db6..b5746f24e492 100644 --- a/src/test/javascript/spec/component/overview/result-history/result-history.component.spec.ts +++ b/src/test/javascript/spec/component/overview/result-history/result-history.component.spec.ts @@ -1,8 +1,10 @@ +import { input, runInInjectionContext } from '@angular/core'; import { ComponentFixture, TestBed } from '@angular/core/testing'; import { ResultHistoryComponent } from 'app/overview/result-history/result-history.component'; import { MockPipe } from 'ng-mocks'; import { ArtemisDatePipe } from 'app/shared/pipes/artemis-date.pipe'; import { ArtemisTestModule } from '../../../test.module'; +import { Result } from 'app/entities/result.model'; describe('ResultHistoryComponent', () => { let component: ResultHistoryComponent; @@ -25,11 +27,13 @@ describe('ResultHistoryComponent', () => { }); it('should initialize with same rated results', () => { - component.results = [ - { rated: true, id: 1 }, - { rated: true, id: 2 }, - { rated: true, id: 3 }, - ]; + runInInjectionContext(TestBed, () => { + component.results = input([ + { rated: true, id: 1 }, + { rated: true, id: 2 }, + { rated: true, id: 3 }, + ]); + }); component.ngOnChanges(); expect(component.displayedResults).toEqual([ { rated: true, id: 1 }, @@ -39,14 +43,16 @@ describe('ResultHistoryComponent', () => { expect(component.showPreviousDivider).toBeFalse(); expect(component.movedLastRatedResult).toBeFalsy(); - component.results = [ - { rated: false, id: 1 }, - { rated: false, id: 2 }, - { rated: false, id: 3 }, - { rated: false, id: 4 }, - { rated: false, id: 5 }, - { rated: false, id: 6 }, - ]; + runInInjectionContext(TestBed, () => { + component.results = input([ + { rated: false, id: 1 }, + { rated: false, id: 2 }, + { rated: false, id: 3 }, + { rated: false, id: 4 }, + { rated: false, id: 5 }, + { rated: false, id: 6 }, + ]); + }); component.ngOnChanges(); expect(component.displayedResults).toEqual([ { rated: false, id: 2 }, @@ -60,11 +66,13 @@ describe('ResultHistoryComponent', () => { }); it('should initialize with mixed rated results', () => { - component.results = [ - { rated: true, id: 1 }, - { rated: false, id: 2 }, - { rated: false, id: 3 }, - ]; + runInInjectionContext(TestBed, () => { + component.results = input([ + { rated: true, id: 1 }, + { rated: false, id: 2 }, + { rated: false, id: 3 }, + ]); + }); component.ngOnChanges(); expect(component.displayedResults).toEqual([ { rated: true, id: 1 }, @@ -74,14 +82,16 @@ describe('ResultHistoryComponent', () => { expect(component.showPreviousDivider).toBeFalse(); expect(component.movedLastRatedResult).toBeFalsy(); - component.results = [ - { rated: true, id: 1 }, - { rated: false, id: 2 }, - { rated: false, id: 3 }, - { rated: false, id: 4 }, - { rated: false, id: 5 }, - { rated: false, id: 6 }, - ]; + runInInjectionContext(TestBed, () => { + component.results = input([ + { rated: true, id: 1 }, + { rated: false, id: 2 }, + { rated: false, id: 3 }, + { rated: false, id: 4 }, + { rated: false, id: 5 }, + { rated: false, id: 6 }, + ]); + }); component.ngOnChanges(); expect(component.displayedResults).toEqual([ { rated: true, id: 1 }, diff --git a/src/test/javascript/spec/component/text-editor/text-editor.component.spec.ts b/src/test/javascript/spec/component/text-editor/text-editor.component.spec.ts index 0f65d8bc2ef3..47902e658500 100644 --- a/src/test/javascript/spec/component/text-editor/text-editor.component.spec.ts +++ b/src/test/javascript/spec/component/text-editor/text-editor.component.spec.ts @@ -1,4 +1,4 @@ -import { DebugElement } from '@angular/core'; +import { DebugElement, input, runInInjectionContext } from '@angular/core'; import dayjs from 'dayjs/esm'; import { ActivatedRoute, RouterModule, convertToParamMap } from '@angular/router'; import { ComponentFixture, TestBed, fakeAsync, flush, tick } from '@angular/core/testing'; @@ -110,9 +110,11 @@ describe('TextEditorComponent', () => { }); it('should use inputValues if present instead of loading new details', fakeAsync(() => { - comp.inputExercise = textExercise; - comp.inputParticipation = participation; - comp.inputSubmission = { id: 1, text: 'test' }; + runInInjectionContext(TestBed, () => { + comp.inputExercise = input(textExercise); + comp.inputParticipation = input(participation); + comp.inputSubmission = input({ id: 1, text: 'test' }); + }); // @ts-ignore updateParticipation is private const updateParticipationSpy = jest.spyOn(comp, 'updateParticipation'); // @ts-ignore setupComponentWithInputValuesSpy is private