mirror of
https://github.com/bitwarden/browser
synced 2025-12-18 09:13:33 +00:00
* Rename service-factory folder * Move cryptographic service factories * Move crypto models * Move crypto services * Move domain base class * Platform code owners * Move desktop log services * Move log files * Establish component library ownership * Move background listeners * Move background background * Move localization to Platform * Move browser alarms to Platform * Move browser state to Platform * Move CLI state to Platform * Move Desktop native concerns to Platform * Move flag and misc to Platform * Lint fixes * Move electron state to platform * Move web state to Platform * Move lib state to Platform * Fix broken tests * Rename interface to idiomatic TS * `npm run prettier` 🤖 * Resolve review feedback * Set platform as owners of web core and shared * Expand moved services * Fix test types --------- Co-authored-by: Hinton <hinton@users.noreply.github.com>
58 lines
1.8 KiB
TypeScript
58 lines
1.8 KiB
TypeScript
import { AbstractControl, UntypedFormGroup, ValidatorFn } from "@angular/forms";
|
|
|
|
import { FormGroupControls } from "@bitwarden/common/platform/abstractions/form-validation-errors.service";
|
|
|
|
export class InputsFieldMatch {
|
|
//check to ensure two fields do not have the same value
|
|
static validateInputsDoesntMatch(matchTo: string, errorMessage: string): ValidatorFn {
|
|
return (control: AbstractControl) => {
|
|
if (control.parent && control.parent.controls) {
|
|
return control?.value === (control?.parent?.controls as FormGroupControls)[matchTo].value
|
|
? {
|
|
inputsMatchError: {
|
|
message: errorMessage,
|
|
},
|
|
}
|
|
: null;
|
|
}
|
|
|
|
return null;
|
|
};
|
|
}
|
|
|
|
//check to ensure two fields have the same value
|
|
static validateInputsMatch(matchTo: string, errorMessage: string): ValidatorFn {
|
|
return (control: AbstractControl) => {
|
|
if (control.parent && control.parent.controls) {
|
|
return control?.value === (control?.parent?.controls as FormGroupControls)[matchTo].value
|
|
? null
|
|
: {
|
|
inputsDoesntMatchError: {
|
|
message: errorMessage,
|
|
},
|
|
};
|
|
}
|
|
|
|
return null;
|
|
};
|
|
}
|
|
|
|
//checks the formGroup if two fields have the same value and validation is controlled from either field
|
|
static validateFormInputsMatch(field: string, fieldMatchTo: string, errorMessage: string) {
|
|
return (formGroup: UntypedFormGroup) => {
|
|
const fieldCtrl = formGroup.controls[field];
|
|
const fieldMatchToCtrl = formGroup.controls[fieldMatchTo];
|
|
|
|
if (fieldCtrl.value !== fieldMatchToCtrl.value) {
|
|
fieldMatchToCtrl.setErrors({
|
|
inputsDoesntMatchError: {
|
|
message: errorMessage,
|
|
},
|
|
});
|
|
} else {
|
|
fieldMatchToCtrl.setErrors(null);
|
|
}
|
|
};
|
|
}
|
|
}
|