From 63332bd5e7a68cdf08c8f45700e0828d929de3d0 Mon Sep 17 00:00:00 2001 From: Hiroki Terashima Date: Mon, 16 Oct 2023 10:02:09 -0700 Subject: [PATCH] getLatestAnnotations() return null instead of undefined Refactor matchesScoreType() --- src/app/services/annotationService.spec.ts | 2 +- .../wise5/services/annotationService.ts | 24 ++++++++++--------- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/src/app/services/annotationService.spec.ts b/src/app/services/annotationService.spec.ts index 4ced47474f6..791ae80c8e0 100644 --- a/src/app/services/annotationService.spec.ts +++ b/src/app/services/annotationService.spec.ts @@ -66,7 +66,7 @@ function getLatestScoreAnnotation() { function getLatestScoreAnnotation_NoMatch_ReturnNull() { describe('no matching annotation is found', () => { it('returns null', () => { - expect(service.getLatestScoreAnnotation('nodeX', 'componentX', 10, 'any')).toBeUndefined(); + expect(service.getLatestScoreAnnotation('nodeX', 'componentX', 10, 'any')).toBeNull(); }); }); } diff --git a/src/assets/wise5/services/annotationService.ts b/src/assets/wise5/services/annotationService.ts index 6030ee93536..d14691f6b0b 100644 --- a/src/assets/wise5/services/annotationService.ts +++ b/src/assets/wise5/services/annotationService.ts @@ -536,15 +536,17 @@ export class AnnotationService { workgroupId: number, scoreType: 'score' | 'autoScore' | 'any' = 'any' ): Annotation { - return this.getAnnotations() - .filter( - (annotation) => - annotation.nodeId == nodeId && - annotation.componentId == componentId && - annotation.toWorkgroupId == workgroupId && - this.matchesScoreType(annotation, scoreType) - ) - .at(-1); + return ( + this.getAnnotations() + .filter( + (annotation) => + annotation.nodeId == nodeId && + annotation.componentId == componentId && + annotation.toWorkgroupId == workgroupId && + this.matchesScoreType(annotation, scoreType) + ) + .at(-1) || null + ); } private matchesScoreType( @@ -552,8 +554,8 @@ export class AnnotationService { scoreType: 'score' | 'autoScore' | 'any' ): boolean { return ( - ['autoScore', 'score'].includes(annotation.type) && - (scoreType === 'any' || annotation.type === scoreType) + (scoreType === 'any' && ['autoScore', 'score'].includes(annotation.type)) || + annotation.type === scoreType ); }