zek 16.0.20 → 16.0.22
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.
- package/esm2022/lib/modules/validator/field-validator.mjs +3 -3
- package/esm2022/lib/modules/validators/directive.mjs +35 -2
- package/esm2022/lib/modules/validators/validator.mjs +59 -20
- package/esm2022/lib/utils/jwt-helper.mjs +2 -2
- package/fesm2022/zek.mjs +94 -23
- package/fesm2022/zek.mjs.map +1 -1
- package/lib/modules/validators/directive.d.ts +16 -0
- package/lib/modules/validators/validator.d.ts +41 -19
- package/lib/utils/jwt-helper.d.ts +1 -1
- package/package.json +1 -1
|
@@ -9,13 +9,13 @@ class ZekFieldValidator {
|
|
|
9
9
|
console.log(this.field.errors);
|
|
10
10
|
}
|
|
11
11
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekFieldValidator, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekFieldValidator, selector: "zek-field-validator, [zek-field-validator]", inputs: { field: "field" }, host: { properties: { "class": "\"invalid-tooltip\"" } }, ngImport: i0, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekFieldValidator, selector: "zek-field-validator, [zek-field-validator]", inputs: { field: "field" }, host: { properties: { "class": "\"invalid-tooltip\"" } }, ngImport: i0, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.mismatch\">{{ 'Validation.Mismatch' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
13
13
|
}
|
|
14
14
|
export { ZekFieldValidator };
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekFieldValidator, decorators: [{
|
|
16
16
|
type: Component,
|
|
17
|
-
args: [{ selector: 'zek-field-validator, [zek-field-validator]', host: { '[class]': '"invalid-tooltip"' }, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>" }]
|
|
17
|
+
args: [{ selector: 'zek-field-validator, [zek-field-validator]', host: { '[class]': '"invalid-tooltip"' }, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.mismatch\">{{ 'Validation.Mismatch' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>" }]
|
|
18
18
|
}], ctorParameters: function () { return []; }, propDecorators: { field: [{
|
|
19
19
|
type: Input
|
|
20
20
|
}] } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtdmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy92YWxpZGF0b3IvZmllbGQtdmFsaWRhdG9yLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy92YWxpZGF0b3IvZmllbGQtdmFsaWRhdG9yLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFFakQsTUFLYSxpQkFBaUI7SUFFMUIsNEJBQTRCO0lBRTVCO1FBQ0ksSUFBSSxJQUFJLENBQUMsS0FBSztZQUNWLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2QyxDQUFDOzhHQVBRLGlCQUFpQjtrR0FBakIsaUJBQWlCLHdLQ1A5Qixpc0NBWWU7O1NETEYsaUJBQWlCOzJGQUFqQixpQkFBaUI7a0JBTDdCLFNBQVM7K0JBQ0ksNENBQTRDLFFBQ2hELEVBQUUsU0FBUyxFQUFFLG1CQUFtQixFQUFFOzBFQUkvQixLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnemVrLWZpZWxkLXZhbGlkYXRvciwgW3play1maWVsZC12YWxpZGF0b3JdJyxcclxuICAgIGhvc3Q6IHsgJ1tjbGFzc10nOiAnXCJpbnZhbGlkLXRvb2x0aXBcIicgfSxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9maWVsZC12YWxpZGF0b3IuaHRtbCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFpla0ZpZWxkVmFsaWRhdG9yIHtcclxuICAgIEBJbnB1dCgpIGZpZWxkOiBhbnk7XHJcbiAgICAvLyBASW5wdXQoKSBmaWVsZD86IE5nTW9kZWw7XHJcblxyXG4gICAgY29uc3RydWN0b3IoKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuZmllbGQpXHJcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKHRoaXMuZmllbGQuZXJyb3JzKTtcclxuICAgIH1cclxufSIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJmaWVsZFwiPlxyXG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImZpZWxkLmludmFsaWQgJiYgKGZpZWxkLmRpcnR5IHx8IGZpZWxkLnRvdWNoZWQgfHwgZmllbGQuZm9ybURpcmVjdGl2ZT8uc3VibWl0dGVkKVwiPlxyXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJmaWVsZC5lcnJvcnNcIj5cclxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImZpZWxkLmVycm9ycy5yZXF1aXJlZFwiPnt7ICdWYWxpZGF0aW9uLlJlcXVpcmVkJyB8IHRyYW5zbGF0ZSB9fTwvbmctY29udGFpbmVyPlxyXG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiZmllbGQuZXJyb3JzLm1pbmxlbmd0aFwiPnt7ICdWYWxpZGF0aW9uLk1pbkxlbmd0aEZvcm1hdCcgfCB0cmFuc2xhdGU6eyB2YWx1ZTogZmllbGQuZXJyb3JzLm1pbmxlbmd0aC5yZXF1aXJlZExlbmd0aCB9IH19PC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJmaWVsZC5lcnJvcnMubWF4bGVuZ3RoXCI+e3sgJ1ZhbGlkYXRpb24uTWF4TGVuZ3RoRm9ybWF0JyB8IHRyYW5zbGF0ZTp7IHZhbHVlOiBmaWVsZC5lcnJvcnMubWF4bGVuZ3RoLnJlcXVpcmVkTGVuZ3RoIH0gfX08L25nLWNvbnRhaW5lcj5cclxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImZpZWxkLmVycm9ycy5lbWFpbFwiPnt7ICdWYWxpZGF0aW9uLlBhdHRlcm4nIHwgdHJhbnNsYXRlIH19PC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJmaWVsZC5lcnJvcnMucGF0dGVyblwiPnt7ICdWYWxpZGF0aW9uLlBhdHRlcm4nIHwgdHJhbnNsYXRlIH19PC9uZy1jb250YWluZXI+PCEtLSB7eyBmaWVsZC5lcnJvcnMucGF0dGVybi5yZXF1aXJlZFBhdHRlcm4gfX0gLS0+XHJcbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJmaWVsZC5lcnJvcnMubWlzbWF0Y2hcIj57eyAnVmFsaWRhdGlvbi5NaXNtYXRjaCcgfCB0cmFuc2xhdGUgfX08L25nLWNvbnRhaW5lcj5cclxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImZpZWxkLmVycm9ycy5zZXJ2ZXJcIj57e2ZpZWxkLmVycm9ycy5zZXJ2ZXJ9fTwvbmctY29udGFpbmVyPlxyXG4gICAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgPC9uZy1jb250YWluZXI+XHJcbjwvbmctY29udGFpbmVyPiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Directive, forwardRef, Input } from "@angular/core";
|
|
2
2
|
import { NG_VALIDATORS } from "@angular/forms";
|
|
3
|
-
import { nullValidator, rangeValidator } from "./validator";
|
|
3
|
+
import { matchValidator, nullValidator, rangeValidator } from "./validator";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
const RANGE_VALIDATOR = {
|
|
6
6
|
provide: NG_VALIDATORS,
|
|
@@ -73,4 +73,37 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
73
73
|
}], propDecorators: { range: [{
|
|
74
74
|
type: Input
|
|
75
75
|
}] } });
|
|
76
|
-
|
|
76
|
+
/**
|
|
77
|
+
* @description
|
|
78
|
+
* Provider which adds `MatchValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
79
|
+
*/
|
|
80
|
+
export const MATCH_VALIDATOR = {
|
|
81
|
+
provide: NG_VALIDATORS,
|
|
82
|
+
useExisting: forwardRef(() => matchValidator),
|
|
83
|
+
multi: true
|
|
84
|
+
};
|
|
85
|
+
class MatchValidator extends AbstractValidatorDirective {
|
|
86
|
+
constructor() {
|
|
87
|
+
super(...arguments);
|
|
88
|
+
/** @internal */
|
|
89
|
+
this.inputName = 'match';
|
|
90
|
+
/** @internal */
|
|
91
|
+
this.normalizeInput = (input) => input.trim();
|
|
92
|
+
/** @internal */
|
|
93
|
+
this.createValidator = (target) => matchValidator(target);
|
|
94
|
+
}
|
|
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 }); }
|
|
97
|
+
}
|
|
98
|
+
export { MatchValidator };
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, decorators: [{
|
|
100
|
+
type: Directive,
|
|
101
|
+
args: [{
|
|
102
|
+
selector: 'input[match][formControlName],input[match][formControl],input[match][ngModel]',
|
|
103
|
+
providers: [MATCH_VALIDATOR],
|
|
104
|
+
host: { '[attr.match]': '_enabled ? match : null' }
|
|
105
|
+
}]
|
|
106
|
+
}], propDecorators: { equals: [{
|
|
107
|
+
type: Input
|
|
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}"]}
|
|
@@ -28,28 +28,51 @@ export function nullValidator(control) {
|
|
|
28
28
|
}
|
|
29
29
|
export class Validators {
|
|
30
30
|
/**
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
31
|
+
* @description
|
|
32
|
+
* Validator that requires the control's value to be less than or equal to the provided number.
|
|
33
|
+
*
|
|
34
|
+
* @usageNotes
|
|
35
|
+
*
|
|
36
|
+
* ### Validate against a range 0 - 15
|
|
37
|
+
*
|
|
38
|
+
* ```typescript
|
|
39
|
+
* const control = new FormControl(16, Validators.max([0,15]));
|
|
40
|
+
*
|
|
41
|
+
* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}
|
|
42
|
+
* ```
|
|
43
|
+
*
|
|
44
|
+
* @returns A validator function that returns an error map with the
|
|
45
|
+
* `range` property if the validation check fails, otherwise `null`.
|
|
46
|
+
*
|
|
47
|
+
* @see `updateValueAndValidity()`
|
|
48
|
+
*
|
|
49
|
+
*/
|
|
50
50
|
static range(min, max) {
|
|
51
51
|
return rangeValidator([min, max]);
|
|
52
52
|
}
|
|
53
|
+
/**
|
|
54
|
+
* @description
|
|
55
|
+
* Validator that requires the control's value to be less than or equal to the provided number.
|
|
56
|
+
*
|
|
57
|
+
* @usageNotes
|
|
58
|
+
*
|
|
59
|
+
* ### Validate against a range 0 - 15
|
|
60
|
+
*
|
|
61
|
+
* ```typescript
|
|
62
|
+
* const control = new FormControl(16, Validators.max([0,15]));
|
|
63
|
+
*
|
|
64
|
+
* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}
|
|
65
|
+
* ```
|
|
66
|
+
*
|
|
67
|
+
* @returns A validator function that returns an error map with the
|
|
68
|
+
* `range` property if the validation check fails, otherwise `null`.
|
|
69
|
+
*
|
|
70
|
+
* @see `updateValueAndValidity()`
|
|
71
|
+
*
|
|
72
|
+
*/
|
|
73
|
+
static match(value) {
|
|
74
|
+
return matchValidator(value);
|
|
75
|
+
}
|
|
53
76
|
}
|
|
54
77
|
/**
|
|
55
78
|
* Validator that requires the control's value to be between provided numbers.
|
|
@@ -69,4 +92,20 @@ export function rangeValidator(range) {
|
|
|
69
92
|
return null;
|
|
70
93
|
};
|
|
71
94
|
}
|
|
72
|
-
|
|
95
|
+
export function matchValidator(target) {
|
|
96
|
+
return (control) => {
|
|
97
|
+
if (isEmptyInputValue(control.value)) {
|
|
98
|
+
return null; // don't validate empty values to allow optional controls
|
|
99
|
+
}
|
|
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 } };
|
|
107
|
+
}
|
|
108
|
+
return null;
|
|
109
|
+
};
|
|
110
|
+
}
|
|
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}"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export class JwtHelper {
|
|
2
|
-
static
|
|
2
|
+
static decode(token) {
|
|
3
3
|
let base64Url = token.split('.')[1];
|
|
4
4
|
let base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');
|
|
5
5
|
let jsonPayload = decodeURIComponent(atob(base64).split('').map(function (c) {
|
|
@@ -8,4 +8,4 @@ export class JwtHelper {
|
|
|
8
8
|
return JSON.parse(jsonPayload);
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiand0LWhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL3V0aWxzL2p3dC1oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLFNBQVM7SUFFbEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFVO1FBQ3BCLElBQUksU0FBUyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDbkMsSUFBSSxNQUFNLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM3RCxJQUFJLFdBQVcsR0FBRyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUM7WUFDdkUsT0FBTyxHQUFHLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNqRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNiLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUNsQyxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgSnd0SGVscGVyIHtcclxuXHJcbiAgICBzdGF0aWMgZGVjb2RlKHRva2VuOiBhbnkpIHtcclxuICAgICAgICBsZXQgYmFzZTY0VXJsID0gdG9rZW4uc3BsaXQoJy4nKVsxXVxyXG4gICAgICAgIGxldCBiYXNlNjQgPSBiYXNlNjRVcmwucmVwbGFjZSgvLS9nLCAnKycpLnJlcGxhY2UoL18vZywgJy8nKTtcclxuICAgICAgICBsZXQganNvblBheWxvYWQgPSBkZWNvZGVVUklDb21wb25lbnQoYXRvYihiYXNlNjQpLnNwbGl0KCcnKS5tYXAoZnVuY3Rpb24gKGMpIHtcclxuICAgICAgICAgICAgcmV0dXJuICclJyArICgnMDAnICsgYy5jaGFyQ29kZUF0KDApLnRvU3RyaW5nKDE2KSkuc2xpY2UoLTIpO1xyXG4gICAgICAgIH0pLmpvaW4oJycpKTtcclxuICAgICAgICByZXR1cm4gSlNPTi5wYXJzZShqc29uUGF5bG9hZClcclxuICAgIH1cclxufSJdfQ==
|
package/fesm2022/zek.mjs
CHANGED
|
@@ -905,7 +905,7 @@ class HtmlHelper {
|
|
|
905
905
|
}
|
|
906
906
|
|
|
907
907
|
class JwtHelper {
|
|
908
|
-
static
|
|
908
|
+
static decode(token) {
|
|
909
909
|
let base64Url = token.split('.')[1];
|
|
910
910
|
let base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');
|
|
911
911
|
let jsonPayload = decodeURIComponent(atob(base64).split('').map(function (c) {
|
|
@@ -4906,11 +4906,11 @@ class ZekFieldValidator {
|
|
|
4906
4906
|
console.log(this.field.errors);
|
|
4907
4907
|
}
|
|
4908
4908
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekFieldValidator, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4909
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekFieldValidator, selector: "zek-field-validator, [zek-field-validator]", inputs: { field: "field" }, host: { properties: { "class": "\"invalid-tooltip\"" } }, ngImport: i0, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }] }); }
|
|
4909
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekFieldValidator, selector: "zek-field-validator, [zek-field-validator]", inputs: { field: "field" }, host: { properties: { "class": "\"invalid-tooltip\"" } }, ngImport: i0, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.mismatch\">{{ 'Validation.Mismatch' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }] }); }
|
|
4910
4910
|
}
|
|
4911
4911
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekFieldValidator, decorators: [{
|
|
4912
4912
|
type: Component,
|
|
4913
|
-
args: [{ selector: 'zek-field-validator, [zek-field-validator]', host: { '[class]': '"invalid-tooltip"' }, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>" }]
|
|
4913
|
+
args: [{ selector: 'zek-field-validator, [zek-field-validator]', host: { '[class]': '"invalid-tooltip"' }, template: "<ng-container *ngIf=\"field\">\r\n <ng-container *ngIf=\"field.invalid && (field.dirty || field.touched || field.formDirective?.submitted)\">\r\n <ng-container *ngIf=\"field.errors\">\r\n <ng-container *ngIf=\"field.errors.required\">{{ 'Validation.Required' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.minlength\">{{ 'Validation.MinLengthFormat' | translate:{ value: field.errors.minlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.maxlength\">{{ 'Validation.MaxLengthFormat' | translate:{ value: field.errors.maxlength.requiredLength } }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.email\">{{ 'Validation.Pattern' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.pattern\">{{ 'Validation.Pattern' | translate }}</ng-container><!-- {{ field.errors.pattern.requiredPattern }} -->\r\n <ng-container *ngIf=\"field.errors.mismatch\">{{ 'Validation.Mismatch' | translate }}</ng-container>\r\n <ng-container *ngIf=\"field.errors.server\">{{field.errors.server}}</ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>" }]
|
|
4914
4914
|
}], ctorParameters: function () { return []; }, propDecorators: { field: [{
|
|
4915
4915
|
type: Input
|
|
4916
4916
|
}] } });
|
|
@@ -6400,28 +6400,51 @@ function nullValidator(control) {
|
|
|
6400
6400
|
}
|
|
6401
6401
|
class Validators {
|
|
6402
6402
|
/**
|
|
6403
|
-
|
|
6404
|
-
|
|
6405
|
-
|
|
6406
|
-
|
|
6407
|
-
|
|
6408
|
-
|
|
6409
|
-
|
|
6410
|
-
|
|
6411
|
-
|
|
6412
|
-
|
|
6413
|
-
|
|
6414
|
-
|
|
6415
|
-
|
|
6416
|
-
|
|
6417
|
-
|
|
6418
|
-
|
|
6419
|
-
|
|
6420
|
-
|
|
6421
|
-
|
|
6403
|
+
* @description
|
|
6404
|
+
* Validator that requires the control's value to be less than or equal to the provided number.
|
|
6405
|
+
*
|
|
6406
|
+
* @usageNotes
|
|
6407
|
+
*
|
|
6408
|
+
* ### Validate against a range 0 - 15
|
|
6409
|
+
*
|
|
6410
|
+
* ```typescript
|
|
6411
|
+
* const control = new FormControl(16, Validators.max([0,15]));
|
|
6412
|
+
*
|
|
6413
|
+
* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}
|
|
6414
|
+
* ```
|
|
6415
|
+
*
|
|
6416
|
+
* @returns A validator function that returns an error map with the
|
|
6417
|
+
* `range` property if the validation check fails, otherwise `null`.
|
|
6418
|
+
*
|
|
6419
|
+
* @see `updateValueAndValidity()`
|
|
6420
|
+
*
|
|
6421
|
+
*/
|
|
6422
6422
|
static range(min, max) {
|
|
6423
6423
|
return rangeValidator([min, max]);
|
|
6424
6424
|
}
|
|
6425
|
+
/**
|
|
6426
|
+
* @description
|
|
6427
|
+
* Validator that requires the control's value to be less than or equal to the provided number.
|
|
6428
|
+
*
|
|
6429
|
+
* @usageNotes
|
|
6430
|
+
*
|
|
6431
|
+
* ### Validate against a range 0 - 15
|
|
6432
|
+
*
|
|
6433
|
+
* ```typescript
|
|
6434
|
+
* const control = new FormControl(16, Validators.max([0,15]));
|
|
6435
|
+
*
|
|
6436
|
+
* console.log(control.errors); // {range: {min: 0, max: 15, actual: 16}}
|
|
6437
|
+
* ```
|
|
6438
|
+
*
|
|
6439
|
+
* @returns A validator function that returns an error map with the
|
|
6440
|
+
* `range` property if the validation check fails, otherwise `null`.
|
|
6441
|
+
*
|
|
6442
|
+
* @see `updateValueAndValidity()`
|
|
6443
|
+
*
|
|
6444
|
+
*/
|
|
6445
|
+
static match(value) {
|
|
6446
|
+
return matchValidator(value);
|
|
6447
|
+
}
|
|
6425
6448
|
}
|
|
6426
6449
|
/**
|
|
6427
6450
|
* Validator that requires the control's value to be between provided numbers.
|
|
@@ -6441,6 +6464,22 @@ function rangeValidator(range) {
|
|
|
6441
6464
|
return null;
|
|
6442
6465
|
};
|
|
6443
6466
|
}
|
|
6467
|
+
function matchValidator(target) {
|
|
6468
|
+
return (control) => {
|
|
6469
|
+
if (isEmptyInputValue(control.value)) {
|
|
6470
|
+
return null; // don't validate empty values to allow optional controls
|
|
6471
|
+
}
|
|
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 } };
|
|
6479
|
+
}
|
|
6480
|
+
return null;
|
|
6481
|
+
};
|
|
6482
|
+
}
|
|
6444
6483
|
|
|
6445
6484
|
const RANGE_VALIDATOR = {
|
|
6446
6485
|
provide: NG_VALIDATORS,
|
|
@@ -6512,6 +6551,38 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
6512
6551
|
}], propDecorators: { range: [{
|
|
6513
6552
|
type: Input
|
|
6514
6553
|
}] } });
|
|
6554
|
+
/**
|
|
6555
|
+
* @description
|
|
6556
|
+
* Provider which adds `MatchValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
6557
|
+
*/
|
|
6558
|
+
const MATCH_VALIDATOR = {
|
|
6559
|
+
provide: NG_VALIDATORS,
|
|
6560
|
+
useExisting: forwardRef(() => matchValidator),
|
|
6561
|
+
multi: true
|
|
6562
|
+
};
|
|
6563
|
+
class MatchValidator extends AbstractValidatorDirective {
|
|
6564
|
+
constructor() {
|
|
6565
|
+
super(...arguments);
|
|
6566
|
+
/** @internal */
|
|
6567
|
+
this.inputName = 'match';
|
|
6568
|
+
/** @internal */
|
|
6569
|
+
this.normalizeInput = (input) => input.trim();
|
|
6570
|
+
/** @internal */
|
|
6571
|
+
this.createValidator = (target) => matchValidator(target);
|
|
6572
|
+
}
|
|
6573
|
+
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 }); }
|
|
6575
|
+
}
|
|
6576
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MatchValidator, decorators: [{
|
|
6577
|
+
type: Directive,
|
|
6578
|
+
args: [{
|
|
6579
|
+
selector: 'input[match][formControlName],input[match][formControl],input[match][ngModel]',
|
|
6580
|
+
providers: [MATCH_VALIDATOR],
|
|
6581
|
+
host: { '[attr.match]': '_enabled ? match : null' }
|
|
6582
|
+
}]
|
|
6583
|
+
}], propDecorators: { equals: [{
|
|
6584
|
+
type: Input
|
|
6585
|
+
}] } });
|
|
6515
6586
|
|
|
6516
6587
|
class ValidatorsModule {
|
|
6517
6588
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ValidatorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
@@ -6638,5 +6709,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
6638
6709
|
* Generated bundle index. Do not edit.
|
|
6639
6710
|
*/
|
|
6640
6711
|
|
|
6641
|
-
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, 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, nullValidator, rangeValidator };
|
|
6712
|
+
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 };
|
|
6642
6713
|
//# sourceMappingURL=zek.mjs.map
|