zek 16.0.23 → 16.0.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,11 +2,6 @@ import { Directive, forwardRef, Input } from "@angular/core";
2
2
  import { NG_VALIDATORS } from "@angular/forms";
3
3
  import { matchValidator, nullValidator, rangeValidator } from "./validator";
4
4
  import * as i0 from "@angular/core";
5
- const RANGE_VALIDATOR = {
6
- provide: NG_VALIDATORS,
7
- useExisting: forwardRef(() => RangeValidator),
8
- multi: true
9
- };
10
5
  function toFloat(value) {
11
6
  return typeof value === 'number' ? value : parseFloat(value);
12
7
  }
@@ -49,6 +44,11 @@ class AbstractValidatorDirective {
49
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AbstractValidatorDirective, decorators: [{
50
45
  type: Directive
51
46
  }] });
47
+ export const RANGE_VALIDATOR = {
48
+ provide: NG_VALIDATORS,
49
+ useExisting: forwardRef(() => RangeValidator),
50
+ multi: true
51
+ };
52
52
  class RangeValidator extends AbstractValidatorDirective {
53
53
  constructor() {
54
54
  super(...arguments);
@@ -79,7 +79,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
79
79
  */
80
80
  export const MATCH_VALIDATOR = {
81
81
  provide: NG_VALIDATORS,
82
- useExisting: forwardRef(() => matchValidator),
82
+ useExisting: forwardRef(() => MatchValidator),
83
83
  multi: true
84
84
  };
85
85
  class MatchValidator extends AbstractValidatorDirective {
@@ -88,22 +88,22 @@ class MatchValidator extends AbstractValidatorDirective {
88
88
  /** @internal */
89
89
  this.inputName = 'match';
90
90
  /** @internal */
91
- this.normalizeInput = (input) => input.trim();
91
+ this.normalizeInput = (input) => input;
92
92
  /** @internal */
93
- this.createValidator = (target) => matchValidator(target);
93
+ this.createValidator = (input) => matchValidator(input);
94
94
  }
95
95
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
96
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MatchValidator, selector: "input[match][formControlName],input[match][formControl],input[match][ngModel]", inputs: { equals: "equals" }, host: { properties: { "attr.match": "_enabled ? match : null" } }, providers: [MATCH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
96
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MatchValidator, selector: "[match][formControlName],match][formControl],[match][ngModel]", inputs: { match: "match" }, host: { properties: { "attr.match": "_enabled ? match : null" } }, providers: [MATCH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
97
97
  }
98
98
  export { MatchValidator };
99
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, decorators: [{
100
100
  type: Directive,
101
101
  args: [{
102
- selector: 'input[match][formControlName],input[match][formControl],input[match][ngModel]',
102
+ selector: '[match][formControlName],match][formControl],[match][ngModel]',
103
103
  providers: [MATCH_VALIDATOR],
104
104
  host: { '[attr.match]': '_enabled ? match : null' }
105
105
  }]
106
- }], propDecorators: { equals: [{
106
+ }], propDecorators: { match: [{
107
107
  type: Input
108
108
  }] } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directive.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/validators/directive.ts"],"names":[],"mappings":"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","sourcesContent":["const RANGE_VALIDATOR: any = {\r\n    provide: NG_VALIDATORS,\r\n    useExisting: forwardRef(() => RangeValidator),\r\n    multi: true\r\n};\r\n\r\n\r\nimport { Directive, forwardRef, Input, OnChanges, OnInit, SimpleChanges } from \"@angular/core\";\r\nimport { AbstractControl, NG_VALIDATORS, ValidationErrors, Validator, ValidatorFn } from \"@angular/forms\";\r\nimport { matchValidator, nullValidator, rangeValidator } from \"./validator\";\r\nimport { StringHelper } from \"../../utils\";\r\n\r\nfunction toFloat(value: string | number): number {\r\n    return typeof value === 'number' ? value : parseFloat(value);\r\n}\r\n\r\n\r\n@Directive()\r\nabstract class AbstractValidatorDirective implements Validator, OnChanges {\r\n    private _validator: ValidatorFn = nullValidator;\r\n    private _onChange!: () => void;\r\n\r\n    /**\r\n     * A flag that tracks whether this validator is enabled.\r\n     *\r\n     * Marking it `internal` (vs `protected`), so that this flag can be used in host bindings of\r\n     * directive classes that extend this base class.\r\n     * @internal\r\n     */\r\n    _enabled?: boolean;\r\n\r\n    /**\r\n     * Name of an input that matches directive selector attribute (e.g. `minlength` for\r\n     * `MinLengthDirective`). An input with a given name might contain configuration information (like\r\n     * `minlength='10'`) or a flag that indicates whether validator should be enabled (like\r\n     * `[required]='false'`).\r\n     *\r\n     * @internal\r\n     */\r\n    abstract inputName: string;\r\n\r\n    /**\r\n     * Creates an instance of a validator (specific to a directive that extends this base class).\r\n     *\r\n     * @internal\r\n     */\r\n    abstract createValidator(input: unknown): ValidatorFn;\r\n\r\n    /**\r\n     * Performs the necessary input normalization based on a specific logic of a Directive.\r\n     * For example, the function might be used to convert string-based representation of the\r\n     * `minlength` input to an integer value that can later be used in the `Validators.minLength`\r\n     * validator.\r\n     *\r\n     * @internal\r\n     */\r\n    abstract normalizeInput(input: unknown): unknown;\r\n\r\n    /** @nodoc */\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (this.inputName in changes) {\r\n            const input = this.normalizeInput(changes[this.inputName].currentValue);\r\n            this._enabled = this.enabled(input);\r\n            this._validator = this._enabled ? this.createValidator(input) : nullValidator;\r\n            if (this._onChange) {\r\n                this._onChange();\r\n            }\r\n        }\r\n    }\r\n\r\n    /** @nodoc */\r\n    validate(control: AbstractControl): ValidationErrors | null {\r\n        return this._validator(control);\r\n    }\r\n\r\n    /** @nodoc */\r\n    registerOnValidatorChange(fn: () => void): void {\r\n        this._onChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Determines whether this validator should be active or not based on an input.\r\n     * Base class implementation checks whether an input is defined (if the value is different from\r\n     * `null` and `undefined`). Validator classes that extend this base class can override this\r\n     * function with the logic specific to a particular validator directive.\r\n     */\r\n    enabled(input: unknown): boolean {\r\n        return input != null /* both `null` and `undefined` */;\r\n    }\r\n}\r\n\r\n\r\n\r\n@Directive({\r\n    selector: 'input[type=number][range][formControlName],input[type=number][range][formControl],input[type=number][range][ngModel]',\r\n    providers: [RANGE_VALIDATOR],\r\n    host: { '[attr.range]': '_enabled ? range : null' }\r\n})\r\nexport class RangeValidator extends AbstractValidatorDirective {\r\n    @Input() range!: [number, number] | null;\r\n\r\n    /** @internal */\r\n    override inputName = 'range';\r\n    /** @internal */\r\n    override normalizeInput = (input: string | number): number => toFloat(input);\r\n    /** @internal */\r\n    override createValidator = (range: [number]): ValidatorFn => rangeValidator(range);\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n/**\r\n * @description\r\n * Provider which adds `MatchValidator` to the `NG_VALIDATORS` multi-provider list.\r\n */\r\nexport const MATCH_VALIDATOR: any = {\r\n    provide: NG_VALIDATORS,\r\n    useExisting: forwardRef(() => matchValidator),\r\n    multi: true\r\n  };\r\n\r\n@Directive({\r\n    selector: 'input[match][formControlName],input[match][formControl],input[match][ngModel]',\r\n    providers: [MATCH_VALIDATOR],\r\n    host: { '[attr.match]': '_enabled ? match : null' }\r\n})\r\nexport class MatchValidator extends AbstractValidatorDirective {\r\n    @Input() equals?: string | null;\r\n\r\n    /** @internal */\r\n    override inputName = 'match';\r\n    /** @internal */\r\n    override normalizeInput = (input: string): string => input.trim();\r\n    /** @internal */\r\n    override createValidator = (target: string): ValidatorFn => matchValidator(target);\r\n}"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directive.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/validators/directive.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Directive, forwardRef, Input, OnChanges, SimpleChanges } from \"@angular/core\";\r\nimport { AbstractControl, NG_VALIDATORS, ValidationErrors, Validator, ValidatorFn } from \"@angular/forms\";\r\nimport { matchValidator, nullValidator, rangeValidator } from \"./validator\";\r\n\r\nfunction toFloat(value: string | number): number {\r\n    return typeof value === 'number' ? value : parseFloat(value);\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n@Directive()\r\nabstract class AbstractValidatorDirective implements Validator, OnChanges {\r\n    private _validator: ValidatorFn = nullValidator;\r\n    private _onChange!: () => void;\r\n\r\n    /**\r\n     * A flag that tracks whether this validator is enabled.\r\n     *\r\n     * Marking it `internal` (vs `protected`), so that this flag can be used in host bindings of\r\n     * directive classes that extend this base class.\r\n     * @internal\r\n     */\r\n    _enabled?: boolean;\r\n\r\n    /**\r\n     * Name of an input that matches directive selector attribute (e.g. `minlength` for\r\n     * `MinLengthDirective`). An input with a given name might contain configuration information (like\r\n     * `minlength='10'`) or a flag that indicates whether validator should be enabled (like\r\n     * `[required]='false'`).\r\n     *\r\n     * @internal\r\n     */\r\n    abstract inputName: string;\r\n\r\n    /**\r\n     * Creates an instance of a validator (specific to a directive that extends this base class).\r\n     *\r\n     * @internal\r\n     */\r\n    abstract createValidator(input: unknown): ValidatorFn;\r\n\r\n    /**\r\n     * Performs the necessary input normalization based on a specific logic of a Directive.\r\n     * For example, the function might be used to convert string-based representation of the\r\n     * `minlength` input to an integer value that can later be used in the `Validators.minLength`\r\n     * validator.\r\n     *\r\n     * @internal\r\n     */\r\n    abstract normalizeInput(input: unknown): unknown;\r\n\r\n    /** @nodoc */\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (this.inputName in changes) {\r\n            const input = this.normalizeInput(changes[this.inputName].currentValue);\r\n            this._enabled = this.enabled(input);\r\n            this._validator = this._enabled ? this.createValidator(input) : nullValidator;\r\n            if (this._onChange) {\r\n                this._onChange();\r\n            }\r\n        }\r\n    }\r\n\r\n    /** @nodoc */\r\n    validate(control: AbstractControl): ValidationErrors | null {\r\n        return this._validator(control);\r\n    }\r\n\r\n    /** @nodoc */\r\n    registerOnValidatorChange(fn: () => void): void {\r\n        this._onChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @description\r\n     * Determines whether this validator should be active or not based on an input.\r\n     * Base class implementation checks whether an input is defined (if the value is different from\r\n     * `null` and `undefined`). Validator classes that extend this base class can override this\r\n     * function with the logic specific to a particular validator directive.\r\n     */\r\n    enabled(input: unknown): boolean {\r\n        return input != null /* both `null` and `undefined` */;\r\n    }\r\n}\r\n\r\n\r\n\r\n\r\nexport const RANGE_VALIDATOR: any = {\r\n    provide: NG_VALIDATORS,\r\n    useExisting: forwardRef(() => RangeValidator),\r\n    multi: true\r\n};\r\n\r\n@Directive({\r\n    selector: 'input[type=number][range][formControlName],input[type=number][range][formControl],input[type=number][range][ngModel]',\r\n    providers: [RANGE_VALIDATOR],\r\n    host: { '[attr.range]': '_enabled ? range : null' }\r\n})\r\nexport class RangeValidator extends AbstractValidatorDirective {\r\n    @Input() range!: [number, number] | null;\r\n\r\n    /** @internal */\r\n    override inputName = 'range';\r\n    /** @internal */\r\n    override normalizeInput = (input: string | number): number => toFloat(input);\r\n    /** @internal */\r\n    override createValidator = (range: [number]): ValidatorFn => rangeValidator(range);\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n/**\r\n * @description\r\n * Provider which adds `MatchValidator` to the `NG_VALIDATORS` multi-provider list.\r\n */\r\nexport const MATCH_VALIDATOR: any = {\r\n    provide: NG_VALIDATORS,\r\n    useExisting: forwardRef(() => MatchValidator),\r\n    multi: true\r\n};\r\n\r\n@Directive({\r\n    selector: '[match][formControlName],match][formControl],[match][ngModel]',\r\n    providers: [MATCH_VALIDATOR],\r\n    host: { '[attr.match]': '_enabled ? match : null' }\r\n})\r\nexport class MatchValidator extends AbstractValidatorDirective {\r\n    @Input() match!: string;\r\n\r\n    /** @internal */\r\n    override inputName = 'match';\r\n    /** @internal */\r\n    override normalizeInput = (input: string): string => input;\r\n    /** @internal */\r\n    override createValidator = (input: string): ValidatorFn => matchValidator(input);\r\n}"]}
@@ -5,7 +5,8 @@ import * as i0 from "@angular/core";
5
5
  class ValidatorsModule {
6
6
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
7
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, declarations: [RangeValidator,
8
- MatchValidator], imports: [CommonModule], exports: [RangeValidator] }); }
8
+ MatchValidator], imports: [CommonModule], exports: [RangeValidator,
9
+ MatchValidator] }); }
9
10
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, imports: [CommonModule] }); }
10
11
  }
11
12
  export { ValidatorsModule };
@@ -19,7 +20,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
19
20
  RangeValidator,
20
21
  MatchValidator,
21
22
  ],
22
- exports: [RangeValidator]
23
+ exports: [
24
+ RangeValidator,
25
+ MatchValidator
26
+ ]
23
27
  }]
24
28
  }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy92YWxpZGF0b3JzL21vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFFN0QsTUFVYSxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQUxyQixjQUFjO1lBQ2QsY0FBYyxhQUpkLFlBQVksYUFNTixjQUFjOytHQUVmLGdCQUFnQixZQVJyQixZQUFZOztTQVFQLGdCQUFnQjsyRkFBaEIsZ0JBQWdCO2tCQVY1QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3FCQUNmO29CQUNELFlBQVksRUFBRTt3QkFDVixjQUFjO3dCQUNkLGNBQWM7cUJBQ2pCO29CQUNELE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBNYXRjaFZhbGlkYXRvciwgUmFuZ2VWYWxpZGF0b3IgfSBmcm9tICcuL2RpcmVjdGl2ZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFJhbmdlVmFsaWRhdG9yLFxyXG4gICAgICAgIE1hdGNoVmFsaWRhdG9yLFxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtSYW5nZVZhbGlkYXRvcl1cclxufSlcclxuZXhwb3J0IGNsYXNzIFZhbGlkYXRvcnNNb2R1bGUgeyB9Il19
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy92YWxpZGF0b3JzL21vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFFN0QsTUFhYSxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQVJyQixjQUFjO1lBQ2QsY0FBYyxhQUpkLFlBQVksYUFPWixjQUFjO1lBQ2QsY0FBYzsrR0FHVCxnQkFBZ0IsWUFYckIsWUFBWTs7U0FXUCxnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFiNUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTtxQkFDZjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1YsY0FBYzt3QkFDZCxjQUFjO3FCQUNqQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wsY0FBYzt3QkFDZCxjQUFjO3FCQUNqQjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE1hdGNoVmFsaWRhdG9yLCBSYW5nZVZhbGlkYXRvciB9IGZyb20gJy4vZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgUmFuZ2VWYWxpZGF0b3IsXHJcbiAgICAgICAgTWF0Y2hWYWxpZGF0b3IsXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1xyXG4gICAgICAgIFJhbmdlVmFsaWRhdG9yLFxyXG4gICAgICAgIE1hdGNoVmFsaWRhdG9yXHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWYWxpZGF0b3JzTW9kdWxlIHsgfSJdfQ==
@@ -1,4 +1,3 @@
1
- // import { AbstractControl, Validators, ValidatorFn, ValidationErrors } from '@angular/forms'
2
1
  // export const range = (range?: Array<number> | null): ValidatorFn => {
3
2
  // return (control: AbstractControl): { [key: string]: any } | null => {
4
3
  // if (!range) return null;
@@ -92,20 +91,29 @@ export function rangeValidator(range) {
92
91
  return null;
93
92
  };
94
93
  }
95
- export function matchValidator(target) {
94
+ export function matchValidator(input) {
96
95
  return (control) => {
97
96
  if (isEmptyInputValue(control.value)) {
98
97
  return null; // don't validate empty values to allow optional controls
99
98
  }
100
- const targetCtrl = control.get(target);
101
- if (!targetCtrl)
102
- return null;
103
- const value = control.value;
104
- const targetValue = targetCtrl.value;
105
- if (targetValue !== value) {
106
- return { 'mismatch': { 'target': targetValue, 'actual': control.value } };
99
+ const targetCtrl = control.get(input);
100
+ let targetValue;
101
+ if (!targetCtrl) {
102
+ let el = document.getElementById(input);
103
+ if (el) {
104
+ targetValue = el.value;
105
+ }
106
+ else {
107
+ return null;
108
+ }
109
+ }
110
+ else {
111
+ targetValue = targetCtrl.value;
112
+ }
113
+ if (targetValue !== control.value) {
114
+ return { 'mismatch': { 'requiredValue': targetValue, 'actual': control.value } };
107
115
  }
108
116
  return null;
109
117
  };
110
118
  }
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/validators/validator.ts"],"names":[],"mappings":"AAAA,8FAA8F;AAK9F,wEAAwE;AACxE,4EAA4E;AAE5E,mCAAmC;AACnC,yDAAyD;AAEzD,0CAA0C;AAC1C,gHAAgH;AAChH,SAAS;AACT,KAAK;AACL,wCAAwC;AACxC,0EAA0E;AAC1E,kDAAkD;AAClD,sDAAsD;AACtD,IAAI;AAGJ,SAAS,iBAAiB,CAAC,KAAU;IACjC;;;;OAIG;IACH,OAAO,OAAO,KAAK,KAAK,WAAW,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;AACxI,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,OAAwB;IAClD,OAAO,IAAI,CAAC;AAChB,CAAC;AAGD,MAAM,OAAO,UAAU;IAEnB;;;;;;;;;;;;;;;;;;;MAmBE;IACF,MAAM,CAAC,KAAK,CAAC,GAAW,EAAE,GAAW;QACjC,OAAO,cAAc,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACtC,CAAC;IAGD;;;;;;;;;;;;;;;;;;;EAmBF;IACE,MAAM,CAAC,KAAK,CAAC,KAAa;QACtB,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;CACJ;AAGD;;;GAGG;AACH,MAAM,UAAU,cAAc,CAAC,KAAoB;IAC/C,OAAO,CAAC,OAAwB,EAA2B,EAAE;QACzD,IAAI,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,iBAAiB,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAClF,OAAO,IAAI,CAAC,CAAE,yDAAyD;SAC1E;QACD,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACnB,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,KAAK,GAAG,GAAG,CAAC,EAAE;YAC/C,OAAO,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;SAC3E;QAED,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;AACN,CAAC;AAGD,MAAM,UAAU,cAAc,CAAC,MAAc;IACzC,OAAO,CAAC,OAAwB,EAA2B,EAAE;QACzD,IAAI,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAClC,OAAO,IAAI,CAAC,CAAE,yDAAyD;SAC1E;QAED,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU;YACX,OAAO,IAAI,CAAC;QAEhB,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC;QACrC,IAAI,WAAW,KAAK,KAAK,EAAE;YACvB,OAAO,EAAE,UAAU,EAAE,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;SAC7E;QACD,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;AACN,CAAC","sourcesContent":["// import { AbstractControl, Validators, ValidatorFn, ValidationErrors } from '@angular/forms'\r\n\r\nimport { transition } from \"@angular/animations\";\r\nimport { AbstractControl, ValidationErrors, ValidatorFn } from \"@angular/forms\";\r\n\r\n// export const range = (range?: Array<number> | null): ValidatorFn => {\r\n//     return (control: AbstractControl): { [key: string]: any } | null => {\r\n\r\n//         if (!range) return null;\r\n//         if (Validators.required(control)) return null;\r\n\r\n//         let v: number = +control.value;\r\n//         return v >= range[0] && v <= range[1] ? null : { actualValue: v, requiredValue: range, range: true };\r\n//     };\r\n// };\r\n// export function blue(): ValidatorFn {\r\n//     return (control: AbstractControl): { [key: string]: any } | null =>\r\n//         control.value?.toLowerCase() === 'blue'\r\n//             ? null : { wrongColor: control.value };\r\n// }\r\n\r\n\r\nfunction isEmptyInputValue(value: any): boolean {\r\n    /**\r\n     * Check if the object is a string or array before evaluating the length attribute.\r\n     * This avoids falsely rejecting objects that contain a custom length attribute.\r\n     * For example, the object {id: 1, length: 0, width: 0} should not be returned as empty.\r\n     */\r\n    return typeof value === 'undefined' || value == null || ((typeof value === 'string' || Array.isArray(value)) && value.length === 0);\r\n}\r\n\r\n/**\r\n * Function that has `ValidatorFn` shape, but performs no operation.\r\n */\r\nexport function nullValidator(control: AbstractControl): ValidationErrors | null {\r\n    return null;\r\n}\r\n\r\n\r\nexport class Validators {\r\n\r\n    /**\r\n    * @description\r\n    * Validator that requires the control's value to be less than or equal to the provided number.\r\n    *\r\n    * @usageNotes\r\n    *\r\n    * ### Validate against a range 0 - 15\r\n    *\r\n    * ```typescript\r\n    * const control = new FormControl(16, Validators.max([0,15]));\r\n    *\r\n    * console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}\r\n    * ```\r\n    *\r\n    * @returns A validator function that returns an error map with the\r\n    * `range` property if the validation check fails, otherwise `null`.\r\n    *\r\n    * @see `updateValueAndValidity()`\r\n    *\r\n    */\r\n    static range(min: number, max: number): ValidatorFn {\r\n        return rangeValidator([min, max]);\r\n    }\r\n\r\n\r\n    /**\r\n* @description\r\n* Validator that requires the control's value to be less than or equal to the provided number.\r\n*\r\n* @usageNotes\r\n*\r\n* ### Validate against a range 0 - 15\r\n*\r\n* ```typescript\r\n* const control = new FormControl(16, Validators.max([0,15]));\r\n*\r\n* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}\r\n* ```\r\n*\r\n* @returns A validator function that returns an error map with the\r\n* `range` property if the validation check fails, otherwise `null`.\r\n*\r\n* @see `updateValueAndValidity()`\r\n*\r\n*/\r\n    static match(value: string): ValidatorFn {\r\n        return matchValidator(value);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validator that requires the control's value to be between provided numbers.\r\n * See `Validators.range` for additional information.\r\n */\r\nexport function rangeValidator(range: Array<number>): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n        if (isEmptyInputValue(control.value) || isEmptyInputValue(range) || range.length < 2) {\r\n            return null;  // don't validate empty values to allow optional controls\r\n        }\r\n        const value = parseFloat(control.value);\r\n        let max = range[0];\r\n        let min = range[1];\r\n        if (!isNaN(value) && (value < min || value > max)) {\r\n            return { 'range': { 'min': min, 'max': max, 'actual': control.value } };\r\n        }\r\n\r\n        return null;\r\n    };\r\n}\r\n\r\n\r\nexport function matchValidator(target: string): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n        if (isEmptyInputValue(control.value)) {\r\n            return null;  // don't validate empty values to allow optional controls\r\n        }\r\n\r\n        const targetCtrl = control.get(target);\r\n        if (!targetCtrl)\r\n            return null;\r\n\r\n        const value = control.value;\r\n        const targetValue = targetCtrl.value;\r\n        if (targetValue !== value) {\r\n            return { 'mismatch': { 'target': targetValue, 'actual': control.value } };\r\n        }\r\n        return null;\r\n    };\r\n}"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/validators/validator.ts"],"names":[],"mappings":"AAGA,wEAAwE;AACxE,4EAA4E;AAE5E,mCAAmC;AACnC,yDAAyD;AAEzD,0CAA0C;AAC1C,gHAAgH;AAChH,SAAS;AACT,KAAK;AACL,wCAAwC;AACxC,0EAA0E;AAC1E,kDAAkD;AAClD,sDAAsD;AACtD,IAAI;AAGJ,SAAS,iBAAiB,CAAC,KAAU;IACjC;;;;OAIG;IACH,OAAO,OAAO,KAAK,KAAK,WAAW,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;AACxI,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,OAAwB;IAClD,OAAO,IAAI,CAAC;AAChB,CAAC;AAGD,MAAM,OAAO,UAAU;IAEnB;;;;;;;;;;;;;;;;;;;MAmBE;IACF,MAAM,CAAC,KAAK,CAAC,GAAW,EAAE,GAAW;QACjC,OAAO,cAAc,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACtC,CAAC;IAGD;;;;;;;;;;;;;;;;;;;EAmBF;IACE,MAAM,CAAC,KAAK,CAAC,KAAa;QACtB,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;CACJ;AAGD;;;GAGG;AACH,MAAM,UAAU,cAAc,CAAC,KAAoB;IAC/C,OAAO,CAAC,OAAwB,EAA2B,EAAE;QACzD,IAAI,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,iBAAiB,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAClF,OAAO,IAAI,CAAC,CAAE,yDAAyD;SAC1E;QACD,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACnB,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,KAAK,GAAG,GAAG,CAAC,EAAE;YAC/C,OAAO,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;SAC3E;QAED,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;AACN,CAAC;AAGD,MAAM,UAAU,cAAc,CAAC,KAAa;IACxC,OAAO,CAAC,OAAwB,EAA2B,EAAE;QACzD,IAAI,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAClC,OAAO,IAAI,CAAC,CAAE,yDAAyD;SAC1E;QAED,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,WAAgB,CAAC;QACrB,IAAI,CAAC,UAAU,EAAE;YACb,IAAI,EAAE,GAAG,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAQ,CAAC;YAC/C,IAAI,EAAE,EAAE;gBACJ,WAAW,GAAG,EAAE,CAAC,KAAK,CAAC;aAC1B;iBAAM;gBACH,OAAO,IAAI,CAAC;aACf;SACJ;aAAM;YACH,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC;SAClC;QAED,IAAI,WAAW,KAAK,OAAO,CAAC,KAAK,EAAE;YAC/B,OAAO,EAAE,UAAU,EAAE,EAAE,eAAe,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC;SACpF;QACD,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC;AACN,CAAC","sourcesContent":["// import { AbstractControl, Validators, ValidatorFn, ValidationErrors } from '@angular/forms'\r\nimport { AbstractControl, ValidationErrors, ValidatorFn } from \"@angular/forms\";\r\n\r\n// export const range = (range?: Array<number> | null): ValidatorFn => {\r\n//     return (control: AbstractControl): { [key: string]: any } | null => {\r\n\r\n//         if (!range) return null;\r\n//         if (Validators.required(control)) return null;\r\n\r\n//         let v: number = +control.value;\r\n//         return v >= range[0] && v <= range[1] ? null : { actualValue: v, requiredValue: range, range: true };\r\n//     };\r\n// };\r\n// export function blue(): ValidatorFn {\r\n//     return (control: AbstractControl): { [key: string]: any } | null =>\r\n//         control.value?.toLowerCase() === 'blue'\r\n//             ? null : { wrongColor: control.value };\r\n// }\r\n\r\n\r\nfunction isEmptyInputValue(value: any): boolean {\r\n    /**\r\n     * Check if the object is a string or array before evaluating the length attribute.\r\n     * This avoids falsely rejecting objects that contain a custom length attribute.\r\n     * For example, the object {id: 1, length: 0, width: 0} should not be returned as empty.\r\n     */\r\n    return typeof value === 'undefined' || value == null || ((typeof value === 'string' || Array.isArray(value)) && value.length === 0);\r\n}\r\n\r\n/**\r\n * Function that has `ValidatorFn` shape, but performs no operation.\r\n */\r\nexport function nullValidator(control: AbstractControl): ValidationErrors | null {\r\n    return null;\r\n}\r\n\r\n\r\nexport class Validators {\r\n\r\n    /**\r\n    * @description\r\n    * Validator that requires the control's value to be less than or equal to the provided number.\r\n    *\r\n    * @usageNotes\r\n    *\r\n    * ### Validate against a range 0 - 15\r\n    *\r\n    * ```typescript\r\n    * const control = new FormControl(16, Validators.max([0,15]));\r\n    *\r\n    * console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}\r\n    * ```\r\n    *\r\n    * @returns A validator function that returns an error map with the\r\n    * `range` property if the validation check fails, otherwise `null`.\r\n    *\r\n    * @see `updateValueAndValidity()`\r\n    *\r\n    */\r\n    static range(min: number, max: number): ValidatorFn {\r\n        return rangeValidator([min, max]);\r\n    }\r\n\r\n\r\n    /**\r\n* @description\r\n* Validator that requires the control's value to be less than or equal to the provided number.\r\n*\r\n* @usageNotes\r\n*\r\n* ### Validate against a range 0 - 15\r\n*\r\n* ```typescript\r\n* const control = new FormControl(16, Validators.max([0,15]));\r\n*\r\n* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}\r\n* ```\r\n*\r\n* @returns A validator function that returns an error map with the\r\n* `range` property if the validation check fails, otherwise `null`.\r\n*\r\n* @see `updateValueAndValidity()`\r\n*\r\n*/\r\n    static match(value: string): ValidatorFn {\r\n        return matchValidator(value);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validator that requires the control's value to be between provided numbers.\r\n * See `Validators.range` for additional information.\r\n */\r\nexport function rangeValidator(range: Array<number>): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n        if (isEmptyInputValue(control.value) || isEmptyInputValue(range) || range.length < 2) {\r\n            return null;  // don't validate empty values to allow optional controls\r\n        }\r\n        const value = parseFloat(control.value);\r\n        let max = range[0];\r\n        let min = range[1];\r\n        if (!isNaN(value) && (value < min || value > max)) {\r\n            return { 'range': { 'min': min, 'max': max, 'actual': control.value } };\r\n        }\r\n\r\n        return null;\r\n    };\r\n}\r\n\r\n\r\nexport function matchValidator(input: string): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n        if (isEmptyInputValue(control.value)) {\r\n            return null;  // don't validate empty values to allow optional controls\r\n        }\r\n\r\n        const targetCtrl = control.get(input);\r\n        let targetValue: any;\r\n        if (!targetCtrl) {\r\n            let el = document.getElementById(input) as any;\r\n            if (el) {\r\n                targetValue = el.value;\r\n            } else {\r\n                return null;\r\n            }\r\n        } else {\r\n            targetValue = targetCtrl.value;\r\n        }\r\n\r\n        if (targetValue !== control.value) {\r\n            return { 'mismatch': { 'requiredValue': targetValue, 'actual': control.value } };\r\n        }\r\n        return null;\r\n    };\r\n}"]}
package/fesm2022/zek.mjs CHANGED
@@ -6370,7 +6370,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
6370
6370
  type: Input
6371
6371
  }] } });
6372
6372
 
6373
- // import { AbstractControl, Validators, ValidatorFn, ValidationErrors } from '@angular/forms'
6374
6373
  // export const range = (range?: Array<number> | null): ValidatorFn => {
6375
6374
  // return (control: AbstractControl): { [key: string]: any } | null => {
6376
6375
  // if (!range) return null;
@@ -6464,28 +6463,32 @@ function rangeValidator(range) {
6464
6463
  return null;
6465
6464
  };
6466
6465
  }
6467
- function matchValidator(target) {
6466
+ function matchValidator(input) {
6468
6467
  return (control) => {
6469
6468
  if (isEmptyInputValue(control.value)) {
6470
6469
  return null; // don't validate empty values to allow optional controls
6471
6470
  }
6472
- const targetCtrl = control.get(target);
6473
- if (!targetCtrl)
6474
- return null;
6475
- const value = control.value;
6476
- const targetValue = targetCtrl.value;
6477
- if (targetValue !== value) {
6478
- return { 'mismatch': { 'target': targetValue, 'actual': control.value } };
6471
+ const targetCtrl = control.get(input);
6472
+ let targetValue;
6473
+ if (!targetCtrl) {
6474
+ let el = document.getElementById(input);
6475
+ if (el) {
6476
+ targetValue = el.value;
6477
+ }
6478
+ else {
6479
+ return null;
6480
+ }
6481
+ }
6482
+ else {
6483
+ targetValue = targetCtrl.value;
6484
+ }
6485
+ if (targetValue !== control.value) {
6486
+ return { 'mismatch': { 'requiredValue': targetValue, 'actual': control.value } };
6479
6487
  }
6480
6488
  return null;
6481
6489
  };
6482
6490
  }
6483
6491
 
6484
- const RANGE_VALIDATOR = {
6485
- provide: NG_VALIDATORS,
6486
- useExisting: forwardRef(() => RangeValidator),
6487
- multi: true
6488
- };
6489
6492
  function toFloat(value) {
6490
6493
  return typeof value === 'number' ? value : parseFloat(value);
6491
6494
  }
@@ -6528,6 +6531,11 @@ class AbstractValidatorDirective {
6528
6531
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AbstractValidatorDirective, decorators: [{
6529
6532
  type: Directive
6530
6533
  }] });
6534
+ const RANGE_VALIDATOR = {
6535
+ provide: NG_VALIDATORS,
6536
+ useExisting: forwardRef(() => RangeValidator),
6537
+ multi: true
6538
+ };
6531
6539
  class RangeValidator extends AbstractValidatorDirective {
6532
6540
  constructor() {
6533
6541
  super(...arguments);
@@ -6557,7 +6565,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
6557
6565
  */
6558
6566
  const MATCH_VALIDATOR = {
6559
6567
  provide: NG_VALIDATORS,
6560
- useExisting: forwardRef(() => matchValidator),
6568
+ useExisting: forwardRef(() => MatchValidator),
6561
6569
  multi: true
6562
6570
  };
6563
6571
  class MatchValidator extends AbstractValidatorDirective {
@@ -6566,28 +6574,29 @@ class MatchValidator extends AbstractValidatorDirective {
6566
6574
  /** @internal */
6567
6575
  this.inputName = 'match';
6568
6576
  /** @internal */
6569
- this.normalizeInput = (input) => input.trim();
6577
+ this.normalizeInput = (input) => input;
6570
6578
  /** @internal */
6571
- this.createValidator = (target) => matchValidator(target);
6579
+ this.createValidator = (input) => matchValidator(input);
6572
6580
  }
6573
6581
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
6574
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MatchValidator, selector: "input[match][formControlName],input[match][formControl],input[match][ngModel]", inputs: { equals: "equals" }, host: { properties: { "attr.match": "_enabled ? match : null" } }, providers: [MATCH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
6582
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MatchValidator, selector: "[match][formControlName],match][formControl],[match][ngModel]", inputs: { match: "match" }, host: { properties: { "attr.match": "_enabled ? match : null" } }, providers: [MATCH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
6575
6583
  }
6576
6584
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, decorators: [{
6577
6585
  type: Directive,
6578
6586
  args: [{
6579
- selector: 'input[match][formControlName],input[match][formControl],input[match][ngModel]',
6587
+ selector: '[match][formControlName],match][formControl],[match][ngModel]',
6580
6588
  providers: [MATCH_VALIDATOR],
6581
6589
  host: { '[attr.match]': '_enabled ? match : null' }
6582
6590
  }]
6583
- }], propDecorators: { equals: [{
6591
+ }], propDecorators: { match: [{
6584
6592
  type: Input
6585
6593
  }] } });
6586
6594
 
6587
6595
  class ValidatorsModule {
6588
6596
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6589
6597
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, declarations: [RangeValidator,
6590
- MatchValidator], imports: [CommonModule], exports: [RangeValidator] }); }
6598
+ MatchValidator], imports: [CommonModule], exports: [RangeValidator,
6599
+ MatchValidator] }); }
6591
6600
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, imports: [CommonModule] }); }
6592
6601
  }
6593
6602
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, decorators: [{
@@ -6600,7 +6609,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
6600
6609
  RangeValidator,
6601
6610
  MatchValidator,
6602
6611
  ],
6603
- exports: [RangeValidator]
6612
+ exports: [
6613
+ RangeValidator,
6614
+ MatchValidator
6615
+ ]
6604
6616
  }]
6605
6617
  }] });
6606
6618
 
@@ -6711,5 +6723,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
6711
6723
  * Generated bundle index. Do not edit.
6712
6724
  */
6713
6725
 
6714
- export { API_BASE_URL, AgeModule, AgePipe, Alert, AlertModule, AlertService, AppBaseModule, ArrayHelper, AuthGuardService, AuthService, AutoCompleteDirective, AutoCompleteModule, Base64Helper, BaseAlert, BaseComponent, BaseService, BitwiseHelper, BootstrapHelper, ButtonBrowseComponent, ButtonBrowseModalBaseComponent, ButtonBrowseModalToolbarComponent, ButtonBrowseModule, CallbackModule, CallbackPipe, CardComponent, CardModule, Color, ComponentType, Convert, CoreComponent, CoreUiComponent, CrudService, CssHelper, CustomHttpParamEncoder, DATE_FORMAT, DateAgoModule, DateAgoPipe, DateHelper, DateValueAccessor, DatepickerModule, EditBase, EditBaseComponent, EditComponent, EditFormComponent, EditToolbarComponent, EditToolbarModule, FileBase, FileBytes, FileHelper, FileModule, FileSizePipe, FileString, FileViewerModule, FilterBase, FilterHelper, Gender, GridToolbarBarComponent, GridToolbarComponent, GridToolbarModule, HtmlHelper, HttpErrorHandler, JwtHelper, KeyPair, KeyPairChecked, KeyPairEx, KeyPairRequired, LANGUAGE, ListBase, ListBaseComponent, ListToolbarComponent, ListToolbarModule, MATCH_VALIDATOR, MatchValidator, MathHelper, Month, ObjectHelper, OverlapHelper, PageTitleComponent, PageTitleModule, PagedList, PagedListBase, Pager, PagerBase, PagerHelper, PasswordModule, PeriodRelation, PrintType, ProgressModule, RECAPTCHA_SITE_KEY, RadioComponent, RadioModule, RandomHelper, RangeValidator, ReCaptchaService, ReadOnlyDirective, ReadOnlyModule, RecaptchaModule, Select2Component, Select2Module, StorageHelper, StringHelper, TimeHelper, TimeModule, TimePipe, TimerService, Toast, Tree, UrlHelper, ValidEventArgs, ValidationHelper, ValidatorModule, Validators, ValidatorsModule, WebApiClient, WebApiModule, WizardComponent, WizardComponent2, WizardModule, ZekAlert, ZekApproveModal, ZekDeleteModal, ZekDisapproveModal, ZekFieldValidator, ZekFileViewer, ZekFilterModal, ZekLoading, ZekLoadingModule, ZekModal, ZekModalModule, ZekPager, ZekPagerModule, ZekPassword, ZekProgress, ZekRestoreModal, ZekSafeModule, ZekSafePipe, ZekSelect2Multiple, ZekSelect2MultipleModule, ZekSelectModule, ZekSelectMultiple, ZekSort, ZekSortButtonGroup, ZekSortModule, ZekSubmitModal, ZekSumModal, ZekToast, ZekValidation, firstBy, handler, matchValidator, nullValidator, rangeValidator };
6726
+ export { API_BASE_URL, AgeModule, AgePipe, Alert, AlertModule, AlertService, AppBaseModule, ArrayHelper, AuthGuardService, AuthService, AutoCompleteDirective, AutoCompleteModule, Base64Helper, BaseAlert, BaseComponent, BaseService, BitwiseHelper, BootstrapHelper, ButtonBrowseComponent, ButtonBrowseModalBaseComponent, ButtonBrowseModalToolbarComponent, ButtonBrowseModule, CallbackModule, CallbackPipe, CardComponent, CardModule, Color, ComponentType, Convert, CoreComponent, CoreUiComponent, CrudService, CssHelper, CustomHttpParamEncoder, DATE_FORMAT, DateAgoModule, DateAgoPipe, DateHelper, DateValueAccessor, DatepickerModule, EditBase, EditBaseComponent, EditComponent, EditFormComponent, EditToolbarComponent, EditToolbarModule, FileBase, FileBytes, FileHelper, FileModule, FileSizePipe, FileString, FileViewerModule, FilterBase, FilterHelper, Gender, GridToolbarBarComponent, GridToolbarComponent, GridToolbarModule, HtmlHelper, HttpErrorHandler, JwtHelper, KeyPair, KeyPairChecked, KeyPairEx, KeyPairRequired, LANGUAGE, ListBase, ListBaseComponent, ListToolbarComponent, ListToolbarModule, MATCH_VALIDATOR, MatchValidator, MathHelper, Month, ObjectHelper, OverlapHelper, PageTitleComponent, PageTitleModule, PagedList, PagedListBase, Pager, PagerBase, PagerHelper, PasswordModule, PeriodRelation, PrintType, ProgressModule, RANGE_VALIDATOR, RECAPTCHA_SITE_KEY, RadioComponent, RadioModule, RandomHelper, RangeValidator, ReCaptchaService, ReadOnlyDirective, ReadOnlyModule, RecaptchaModule, Select2Component, Select2Module, StorageHelper, StringHelper, TimeHelper, TimeModule, TimePipe, TimerService, Toast, Tree, UrlHelper, ValidEventArgs, ValidationHelper, ValidatorModule, Validators, ValidatorsModule, WebApiClient, WebApiModule, WizardComponent, WizardComponent2, WizardModule, ZekAlert, ZekApproveModal, ZekDeleteModal, ZekDisapproveModal, ZekFieldValidator, ZekFileViewer, ZekFilterModal, ZekLoading, ZekLoadingModule, ZekModal, ZekModalModule, ZekPager, ZekPagerModule, ZekPassword, ZekProgress, ZekRestoreModal, ZekSafeModule, ZekSafePipe, ZekSelect2Multiple, ZekSelect2MultipleModule, ZekSelectModule, ZekSelectMultiple, ZekSort, ZekSortButtonGroup, ZekSortModule, ZekSubmitModal, ZekSumModal, ZekToast, ZekValidation, firstBy, handler, matchValidator, nullValidator, rangeValidator };
6715
6727
  //# sourceMappingURL=zek.mjs.map