Skip to content

Commit

Permalink
Keep residential structure question when changing between residential…
Browse files Browse the repository at this point in the history
… types
  • Loading branch information
trslater committed Nov 13, 2024
1 parent f366f40 commit dcfac3e
Showing 1 changed file with 26 additions and 24 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -331,22 +331,26 @@ export class AdditionalInformationComponent extends FilesStepComponent implement
}
}

private checkStructureTypeInput(type: STRUCTURE_TYPES | null) {
switch (type) {
case STRUCTURE_TYPES.FARM_STRUCTURE:
return !!(this.soilAgriParcelActivity.value || this.soilStructureFarmUseReason.value);
case STRUCTURE_TYPES.ACCESSORY_STRUCTURE:
return !!(
this.soilStructureResidentialUseReason.value || this.soilStructureResidentialAccessoryUseReason.value
);
case STRUCTURE_TYPES.OTHER_STRUCTURE:
return !!this.soilStructureOtherUseReason.value;
case STRUCTURE_TYPES.PRINCIPAL_RESIDENCE:
case STRUCTURE_TYPES.ADDITIONAL_RESIDENCE:
return !!this.soilStructureResidentialUseReason.value;
case null:
return false;
}
private structureChangeRequiresConfirmation(oldType: STRUCTURE_TYPES | null, newType: STRUCTURE_TYPES): boolean {
const residentialTypes = [
STRUCTURE_TYPES.PRINCIPAL_RESIDENCE,
STRUCTURE_TYPES.ADDITIONAL_RESIDENCE,
STRUCTURE_TYPES.ACCESSORY_STRUCTURE,
];
const changingFromResidentialType = oldType && residentialTypes.includes(oldType);
const changingToResidentialType = newType && residentialTypes.includes(newType);

return !!(
oldType !== newType &&
((oldType &&
oldType === STRUCTURE_TYPES.FARM_STRUCTURE &&
(this.soilAgriParcelActivity.value || this.soilStructureFarmUseReason.value)) ||
(changingFromResidentialType && !changingToResidentialType && this.soilStructureResidentialUseReason.value) ||
(oldType &&
oldType === STRUCTURE_TYPES.ACCESSORY_STRUCTURE &&
this.soilStructureResidentialAccessoryUseReason.value) ||
(oldType && oldType === STRUCTURE_TYPES.OTHER_STRUCTURE && this.soilStructureOtherUseReason.value))
);
}

private setStructureTypeInput(structure: FormProposedStructure, newType: STRUCTURE_TYPES) {
Expand All @@ -362,18 +366,16 @@ export class AdditionalInformationComponent extends FilesStepComponent implement
this.form.markAsDirty();
}

onChangeStructureType(id: string, value: STRUCTURE_TYPES) {
onChangeStructureType(id: string, newType: STRUCTURE_TYPES) {
const structure = this.proposedStructures.find((structure) => structure.id === id);
if (!structure) {
console.error('Failed to find structure');
return;
}
this.structuresSource = new MatTableDataSource(this.proposedStructures);
const prevType = structure.type;
const hasInput = this.checkStructureTypeInput(prevType);

if (!hasInput) {
return this.setStructureTypeInput(structure, value);
const oldType = structure.type;
if (!this.structureChangeRequiresConfirmation(oldType, newType)) {
return this.setStructureTypeInput(structure, newType);
} else {
const dialog = this.confirmationDialogService.openDialog({
title: 'Change Structure Type',
Expand All @@ -384,9 +386,9 @@ export class AdditionalInformationComponent extends FilesStepComponent implement

dialog.subscribe((isConfirmed) => {
if (isConfirmed) {
this.setStructureTypeInput(structure, value);
this.setStructureTypeInput(structure, newType);
} else {
this.structuresForm.get(structure.id + '-type')?.setValue(prevType);
this.structuresForm.get(structure.id + '-type')?.setValue(oldType);
}
});
}
Expand Down

0 comments on commit dcfac3e

Please sign in to comment.