From a34af0ae9fc1f119682265f2c8184fa397515974 Mon Sep 17 00:00:00 2001 From: Felipe Barreta Date: Mon, 6 Jan 2025 11:35:38 -0800 Subject: [PATCH] ALCS-2453 Handle unique descriptions on condition types --- .../decision-condition-types-dialog.component.html | 3 +++ .../decision-condition-types-dialog.component.ts | 3 ++- .../decision-condition-types.component.ts | 4 ++++ .../decision-dialog-data.interface.ts | 1 + .../app/shared/validators/code-exists-validator.ts | 11 +++++++++++ 5 files changed, 21 insertions(+), 1 deletion(-) diff --git a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.html b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.html index 45bfff2b04..8cbfc8c446 100644 --- a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.html +++ b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.html @@ -25,6 +25,9 @@

{{ isEdit ? 'Edit' : 'Create' }} Decision Condition Type

Description +
+ +
diff --git a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.ts b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.ts index 2a50be3b59..1830a2e6f3 100644 --- a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.ts +++ b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types-dialog/decision-condition-types-dialog.component.ts @@ -17,7 +17,7 @@ import { import { ApplicationDecisionConditionService } from '../../../../services/application/decision/application-decision-v2/application-decision-condition/application-decision-condition.service'; import { NoticeOfIntentDecisionConditionService } from '../../../../services/notice-of-intent/decision-v2/notice-of-intent-decision-condition/notice-of-intent-decision-condition.service'; import { catchError, debounceTime, map, Observable, of, switchMap } from 'rxjs'; -import { codeExistsValidator } from '../../../../shared/validators/code-exists-validator'; +import { codeExistsValidator, descriptionExistsValidator } from '../../../../shared/validators/code-exists-validator'; enum ValidationFields { Dates, @@ -54,6 +54,7 @@ export class DecisionConditionTypesDialogComponent { this.conditionTypeForm = new FormGroup({ description: new FormControl(this.data?.content?.description ? this.data.content.description : '', [ Validators.required, + descriptionExistsValidator(this.data?.existingDescriptions ? this.data.existingDescriptions : []), ]), label: new FormControl(this.data?.content?.label ? this.data.content.label : '', [Validators.required]), code: new FormControl(this.data?.content?.code ? this.data.content.code : '', [ diff --git a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types.component.ts b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types.component.ts index c3e8c00b7e..c6e10de474 100644 --- a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types.component.ts +++ b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-condition-types.component.ts @@ -30,6 +30,7 @@ export class DecisionConditionTypesComponent implements OnInit { decisionConditionTypeDtos: ApplicationDecisionConditionTypeDto[] | NoticeOfIntentDecisionConditionTypeDto[] = []; decisionConditionTypeCodeDtos: string[] = []; + decisionConditionTypeDescriptionDtos: string[] = []; displayedColumns: string[] = ['label', 'description', 'code', 'isActive', 'actions']; constructor( @@ -45,6 +46,7 @@ export class DecisionConditionTypesComponent implements OnInit { if (!this.service) return; this.decisionConditionTypeDtos = await this.service.fetch(); this.decisionConditionTypeCodeDtos = await this.service.fetchCodesWithDeleted(); + this.decisionConditionTypeDescriptionDtos = this.decisionConditionTypeDtos.map((d) => d.description); } async onCreate() { @@ -57,6 +59,7 @@ export class DecisionConditionTypesComponent implements OnInit { service: this.service, conditionService: this.conditionService, existingCodes: this.decisionConditionTypeCodeDtos, + existingDescriptions: this.decisionConditionTypeDescriptionDtos, }, }); dialog.beforeClosed().subscribe(async (result) => { @@ -77,6 +80,7 @@ export class DecisionConditionTypesComponent implements OnInit { conditionService: this.conditionService, content: dto, existingCodes: this.decisionConditionTypeCodeDtos, + existingDescriptions: this.decisionConditionTypeDescriptionDtos, }, }); dialog.beforeClosed().subscribe(async (result) => { diff --git a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-dialog-data.interface.ts b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-dialog-data.interface.ts index 751c90a4c6..6c7487106c 100644 --- a/alcs-frontend/src/app/features/admin/decision-condition-types/decision-dialog-data.interface.ts +++ b/alcs-frontend/src/app/features/admin/decision-condition-types/decision-dialog-data.interface.ts @@ -9,4 +9,5 @@ export interface DecisionDialogDataInterface { conditionService: ApplicationDecisionConditionService | NoticeOfIntentDecisionConditionService; content: ApplicationDecisionConditionTypeDto; existingCodes: string[]; + existingDescriptions: string[]; } diff --git a/alcs-frontend/src/app/shared/validators/code-exists-validator.ts b/alcs-frontend/src/app/shared/validators/code-exists-validator.ts index 491639e3b7..365b1eaf00 100644 --- a/alcs-frontend/src/app/shared/validators/code-exists-validator.ts +++ b/alcs-frontend/src/app/shared/validators/code-exists-validator.ts @@ -12,6 +12,17 @@ export function codeExistsValidator(existingCodes: string[]): ValidatorFn { }; } +export function descriptionExistsValidator(existingDescriptions: string[]): ValidatorFn { + return (control: AbstractControl): ValidationErrors | null => { + if (!control.value) return null; + const inputValue = control.value.toLowerCase(); + if (existingDescriptions.some((description) => description.toLowerCase() === inputValue)) { + return { descriptionExists: true }; + } + return null; + }; +} + export function codeExistsDirectiveValidator(model: NgModel, existingCodes: string[], code: string) { const existingErrors = model.control.errors || {}; const isExisting = existingCodes.includes(code.toLowerCase());