У меня есть две введенные даты - «дата начала» и «дата окончания» - у меня также есть две директивы, в которых я использую в качестве валидаторов - допустимое минимальное и максимально допустимое значение для каждого поля (так, чтобы начальная дата победилане позже даты окончания)Если, например, я изменю дату начала на более позднюю, чем дата окончания, валидатор предупредит, что она недействительна.когда я изменяю дату окончания на более позднюю дату от даты начала - это предупреждение не исчезнет, так как я не запустил валидатор «customMax».Как я могу запускать оба валидатора одновременно при каждом изменении в одном из полей?
Спасибо,
вводит HTML:
<input
type="text" class="form-control"
name="startDate{{d.index}}"
required
[customMax]="d.endDate"
(dateChange)="onDateChange('startDate', d.index, $event)"
[(ngModel)]="d.startDate"
appMyDatePicker>
<input type="text" class="form-control"
required
[customMin]="d.startDate"
name="endDate{{d.index}}"
(dateChange)="onDateChange('endDate', d.index, $event)"
[(ngModel)]="d.endDate"
appMyDatePicker>
customMax директива:
@Directive({
selector: '[appCustomMaxValidator],[customMax][ngModel]',
providers: [{provide: NG_VALIDATORS, useExisting:
CustomMaxValidatorDirective, multi: true}]
})
export class CustomMaxValidatorDirective implements Validator {
@Input()
customMax: Date;
constructor() { }
validate(c: FormControl): {[key: string]: any} {
const maxDateConvertInit = moment(this.customMax, 'DD/MM/YYYY HH:mm:ss').format('DD/MM/YYYY HH:mm:ss');
console.log('cant be greater than:' + maxDateConvertInit);
const maxDateConvertCompare = moment(c.value, 'DD/MM/YYYY HH:mm:ss').format('DD/MM/YYYY HH:mm:ss');
console.log('check date:' + maxDateConvertCompare);
const testScore = (maxDateConvertInit <= maxDateConvertCompare) ? {'customMax': true} : null;
return testScore;
}
}
Директива customMin:
@Directive({
selector: '[appCustomMinValidator],[customMin][ngModel]',
providers: [{provide: NG_VALIDATORS, useExisting: CustomMinValidatorDirective, multi: true}]
})
export class CustomMinValidatorDirective implements Validator {
@Input()
customMin: Date;
constructor() { }
validate(c: FormControl): {[key: string]: any} {
const minDateConvertInit = moment(this.customMin, 'DD/MM/YYYY HH:mm:ss').format('DD/MM/YYYY HH:mm:ss');
const minDateConvertCompare = moment(c.value, 'DD/MM/YYYY HH:mm:ss').format('DD/MM/YYYY HH:mm:ss');
const testScore = (minDateConvertInit >= minDateConvertCompare) ? {'customMin': true} : null;
return testScore;
}
}