@muziehdesign/forms 18.2.0-next.801 → 18.2.0-next.855
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/checkbox-group/checkbox-group.component.mjs +67 -0
- package/esm2022/lib/date-value-accessor.directive.mjs +4 -4
- package/esm2022/lib/field/field.component.mjs +37 -0
- package/esm2022/lib/field-errors/field-errors.component.mjs +4 -4
- package/esm2022/lib/field-schema.mjs +51 -0
- package/esm2022/lib/form/form.directive.mjs +35 -0
- package/esm2022/lib/forms.module.mjs +41 -5
- package/esm2022/lib/masks.mjs +1 -43
- package/esm2022/lib/model-schema.factory.mjs +70 -34
- package/esm2022/lib/model-schema.mjs +33 -0
- package/esm2022/lib/ng-form-model-state.service.mjs +4 -4
- package/esm2022/lib/ngform-model-state.mjs +1 -1
- package/esm2022/lib/type-annotations.mjs +46 -34
- package/esm2022/public-api.mjs +7 -3
- package/fesm2022/muziehdesign-forms.mjs +446 -211
- package/fesm2022/muziehdesign-forms.mjs.map +1 -1
- package/lib/checkbox-group/checkbox-group.component.d.ts +21 -0
- package/lib/field/field.component.d.ts +18 -0
- package/lib/field-schema.d.ts +88 -0
- package/lib/form/form.directive.d.ts +14 -0
- package/lib/forms.module.d.ts +12 -0
- package/lib/masks.d.ts +0 -23
- package/lib/model-schema.d.ts +21 -0
- package/lib/model-schema.factory.d.ts +7 -3
- package/lib/ngform-model-state.d.ts +2 -2
- package/lib/type-annotations.d.ts +8 -10
- package/package.json +5 -5
- package/public-api.d.ts +6 -2
- package/esm2022/lib/model-validator.mjs +0 -16
- package/lib/model-validator.d.ts +0 -7
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { Component, Input, forwardRef } from '@angular/core';
|
|
2
|
+
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class MzCheckboxGroup {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.disabled = false;
|
|
7
|
+
this.selections = [];
|
|
8
|
+
this.onChange = () => { };
|
|
9
|
+
this.onTouched = () => { };
|
|
10
|
+
}
|
|
11
|
+
// Writes the selected values from the form model
|
|
12
|
+
writeValue(values) {
|
|
13
|
+
this.selections = values || [];
|
|
14
|
+
}
|
|
15
|
+
// Registers the onChange function to propagate changes
|
|
16
|
+
registerOnChange(fn) {
|
|
17
|
+
this.onChange = fn;
|
|
18
|
+
}
|
|
19
|
+
// Registers the onTouched function
|
|
20
|
+
registerOnTouched(fn) {
|
|
21
|
+
this.onTouched = fn;
|
|
22
|
+
}
|
|
23
|
+
setDisabledState(isDisabled) {
|
|
24
|
+
this.disabled = isDisabled;
|
|
25
|
+
}
|
|
26
|
+
// Checks if a checkbox is selected
|
|
27
|
+
isChecked(option) {
|
|
28
|
+
return this.selections.includes(option.value);
|
|
29
|
+
}
|
|
30
|
+
// Handles changes when checkboxes are clicked
|
|
31
|
+
onCheckboxChange(event, option) {
|
|
32
|
+
const checked = event.target.checked;
|
|
33
|
+
if (checked) {
|
|
34
|
+
this.selections = [...this.selections, option.value];
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
this.selections = this.selections.filter((val) => val !== option.value);
|
|
38
|
+
}
|
|
39
|
+
this.onChange(this.selections);
|
|
40
|
+
this.onTouched();
|
|
41
|
+
}
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzCheckboxGroup, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MzCheckboxGroup, isStandalone: true, selector: "mz-checkbox-group", inputs: { options: "options", disabled: "disabled" }, providers: [
|
|
44
|
+
{
|
|
45
|
+
provide: NG_VALUE_ACCESSOR,
|
|
46
|
+
useExisting: forwardRef(() => MzCheckboxGroup),
|
|
47
|
+
multi: true,
|
|
48
|
+
},
|
|
49
|
+
], ngImport: i0, template: "@for(option of options; track $index) {\n <label class=\"field-option\">\n <input type=\"checkbox\" class=\"form-checkbox\" [disabled]=\"disabled\" [value]=\"option.value\" [checked]=\"isChecked(option)\" (change)=\"onCheckboxChange($event, option)\" />\n <span class=\"checkbox-label\">{{option.label}}</span>\n </label>\n}\n", dependencies: [{ kind: "ngmodule", type: FormsModule }] }); }
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzCheckboxGroup, decorators: [{
|
|
52
|
+
type: Component,
|
|
53
|
+
args: [{ selector: 'mz-checkbox-group', standalone: true, imports: [FormsModule], providers: [
|
|
54
|
+
{
|
|
55
|
+
provide: NG_VALUE_ACCESSOR,
|
|
56
|
+
useExisting: forwardRef(() => MzCheckboxGroup),
|
|
57
|
+
multi: true,
|
|
58
|
+
},
|
|
59
|
+
], template: "@for(option of options; track $index) {\n <label class=\"field-option\">\n <input type=\"checkbox\" class=\"form-checkbox\" [disabled]=\"disabled\" [value]=\"option.value\" [checked]=\"isChecked(option)\" (change)=\"onCheckboxChange($event, option)\" />\n <span class=\"checkbox-label\">{{option.label}}</span>\n </label>\n}\n" }]
|
|
60
|
+
}], propDecorators: { options: [{
|
|
61
|
+
type: Input,
|
|
62
|
+
args: [{ required: true }]
|
|
63
|
+
}], disabled: [{
|
|
64
|
+
type: Input,
|
|
65
|
+
args: [{ required: false }]
|
|
66
|
+
}] } });
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvY2hlY2tib3gtZ3JvdXAvY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvY2hlY2tib3gtZ3JvdXAvY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBd0IsV0FBVyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBb0J0RixNQUFNLE9BQU8sZUFBZTtJQWI1QjtRQWVnQyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRTdDLGVBQVUsR0FBVSxFQUFFLENBQUM7UUFFdkIsYUFBUSxHQUE4QixHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7UUFDL0MsY0FBUyxHQUFlLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztLQXNDcEM7SUFwQ0csaURBQWlEO0lBQ2pELFVBQVUsQ0FBQyxNQUFhO1FBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxJQUFJLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRUQsdURBQXVEO0lBQ3ZELGdCQUFnQixDQUFDLEVBQU87UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELG1DQUFtQztJQUNuQyxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3JCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNqQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUMvQixDQUFDO0lBRUQsbUNBQW1DO0lBQ25DLFNBQVMsQ0FBQyxNQUFtQjtRQUN6QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsOENBQThDO0lBQzlDLGdCQUFnQixDQUFDLEtBQVksRUFBRSxNQUFtQjtRQUM5QyxNQUFNLE9BQU8sR0FBSSxLQUFLLENBQUMsTUFBMkIsQ0FBQyxPQUFPLENBQUM7UUFFM0QsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pELENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxLQUFLLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1RSxDQUFDO1FBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7K0dBNUNRLGVBQWU7bUdBQWYsZUFBZSxzSEFSYjtZQUNQO2dCQUNJLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsZUFBZSxDQUFDO2dCQUM5QyxLQUFLLEVBQUUsSUFBSTthQUNkO1NBQ0osMEJDbkJMLDRWQU1BLDJDREtjLFdBQVc7OzRGQVVaLGVBQWU7a0JBYjNCLFNBQVM7K0JBQ0ksbUJBQW1CLGNBQ2pCLElBQUksV0FDUCxDQUFDLFdBQVcsQ0FBQyxhQUVYO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGdCQUFnQixDQUFDOzRCQUM5QyxLQUFLLEVBQUUsSUFBSTt5QkFDZDtxQkFDSjs4QkFHMEIsT0FBTztzQkFBakMsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBQ0csUUFBUTtzQkFBbkMsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBmb3J3YXJkUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgRm9ybXNNb2R1bGUsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5leHBvcnQgdHlwZSBGaWVsZE9wdGlvbiA9IHtcbiAgICBsYWJlbDogc3RyaW5nO1xuICAgIHZhbHVlOiBhbnk7XG59O1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ216LWNoZWNrYm94LWdyb3VwJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtGb3Jtc01vZHVsZV0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LWdyb3VwLmNvbXBvbmVudC5odG1sJyxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBNekNoZWNrYm94R3JvdXApLFxuICAgICAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTXpDaGVja2JveEdyb3VwIGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICAgIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIG9wdGlvbnMhOiBGaWVsZE9wdGlvbltdO1xuICAgIEBJbnB1dCh7IHJlcXVpcmVkOiBmYWxzZSB9KSBkaXNhYmxlZCA9IGZhbHNlO1xuXG4gICAgc2VsZWN0aW9uczogYW55W10gPSBbXTtcblxuICAgIG9uQ2hhbmdlOiAodmFsdWU6IHN0cmluZ1tdKSA9PiB2b2lkID0gKCkgPT4ge307XG4gICAgb25Ub3VjaGVkOiAoKSA9PiB2b2lkID0gKCkgPT4ge307XG5cbiAgICAvLyBXcml0ZXMgdGhlIHNlbGVjdGVkIHZhbHVlcyBmcm9tIHRoZSBmb3JtIG1vZGVsXG4gICAgd3JpdGVWYWx1ZSh2YWx1ZXM6IGFueVtdKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2VsZWN0aW9ucyA9IHZhbHVlcyB8fCBbXTtcbiAgICB9XG5cbiAgICAvLyBSZWdpc3RlcnMgdGhlIG9uQ2hhbmdlIGZ1bmN0aW9uIHRvIHByb3BhZ2F0ZSBjaGFuZ2VzXG4gICAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcbiAgICB9XG5cbiAgICAvLyBSZWdpc3RlcnMgdGhlIG9uVG91Y2hlZCBmdW5jdGlvblxuICAgIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcbiAgICB9XG4gICAgc2V0RGlzYWJsZWRTdGF0ZT8oaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICB0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcbiAgICB9XG5cbiAgICAvLyBDaGVja3MgaWYgYSBjaGVja2JveCBpcyBzZWxlY3RlZFxuICAgIGlzQ2hlY2tlZChvcHRpb246IEZpZWxkT3B0aW9uKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLnNlbGVjdGlvbnMuaW5jbHVkZXMob3B0aW9uLnZhbHVlKTtcbiAgICB9XG5cbiAgICAvLyBIYW5kbGVzIGNoYW5nZXMgd2hlbiBjaGVja2JveGVzIGFyZSBjbGlja2VkXG4gICAgb25DaGVja2JveENoYW5nZShldmVudDogRXZlbnQsIG9wdGlvbjogRmllbGRPcHRpb24pOiB2b2lkIHtcbiAgICAgICAgY29uc3QgY2hlY2tlZCA9IChldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkuY2hlY2tlZDtcblxuICAgICAgICBpZiAoY2hlY2tlZCkge1xuICAgICAgICAgICAgdGhpcy5zZWxlY3Rpb25zID0gWy4uLnRoaXMuc2VsZWN0aW9ucywgb3B0aW9uLnZhbHVlXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMuc2VsZWN0aW9ucyA9IHRoaXMuc2VsZWN0aW9ucy5maWx0ZXIoKHZhbCkgPT4gdmFsICE9PSBvcHRpb24udmFsdWUpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5vbkNoYW5nZSh0aGlzLnNlbGVjdGlvbnMpO1xuICAgICAgICB0aGlzLm9uVG91Y2hlZCgpO1xuICAgIH1cbn1cbiIsIkBmb3Iob3B0aW9uIG9mIG9wdGlvbnM7IHRyYWNrICRpbmRleCkge1xuICAgIDxsYWJlbCBjbGFzcz1cImZpZWxkLW9wdGlvblwiPlxuICAgICAgICA8aW5wdXQgdHlwZT1cImNoZWNrYm94XCIgY2xhc3M9XCJmb3JtLWNoZWNrYm94XCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgW3ZhbHVlXT1cIm9wdGlvbi52YWx1ZVwiIFtjaGVja2VkXT1cImlzQ2hlY2tlZChvcHRpb24pXCIgKGNoYW5nZSk9XCJvbkNoZWNrYm94Q2hhbmdlKCRldmVudCwgb3B0aW9uKVwiIC8+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiY2hlY2tib3gtbGFiZWxcIj57e29wdGlvbi5sYWJlbH19PC9zcGFuPlxuICAgIDwvbGFiZWw+XG59XG4iXX0=
|
|
@@ -70,8 +70,8 @@ export class DateValueAccessor {
|
|
|
70
70
|
newDate.setHours(0, 0, 0);
|
|
71
71
|
return newDate;
|
|
72
72
|
}
|
|
73
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.
|
|
74
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.
|
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateValueAccessor, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
74
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DateValueAccessor, isStandalone: true, selector: "[mzDate]", host: { listeners: { "input": "onChange($event.target.value)", "blur": "onTouched()" } }, providers: [
|
|
75
75
|
{
|
|
76
76
|
provide: NG_VALUE_ACCESSOR,
|
|
77
77
|
useExisting: forwardRef(() => DateValueAccessor),
|
|
@@ -79,7 +79,7 @@ export class DateValueAccessor {
|
|
|
79
79
|
},
|
|
80
80
|
], ngImport: i0 }); }
|
|
81
81
|
}
|
|
82
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateValueAccessor, decorators: [{
|
|
83
83
|
type: Directive,
|
|
84
84
|
args: [{
|
|
85
85
|
selector: '[mzDate]',
|
|
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
94
94
|
],
|
|
95
95
|
}]
|
|
96
96
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }] });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../projects/muziehdesign/forms/src/lib/date-value-accessor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatDate } from '@angular/common';\nimport { Directive, ElementRef, Renderer2, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Directive({\n  selector: '[mzDate]',\n  standalone: true,\n  host: { '(input)': 'onChange($event.target.value)', '(blur)': 'onTouched()' },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateValueAccessor),\n      multi: true,\n    },\n  ],\n})\nexport class DateValueAccessor implements ControlValueAccessor {\n  onChange = (_: any) => {};\n  onTouched = () => {};\n\n  constructor(private _renderer: Renderer2, private _elementRef: ElementRef) {}\n\n  writeValue(obj?: Date): void {\n    let normalizedValue = '';\n    if (!obj) {\n      normalizedValue = '';\n    } else if (this._elementRef.nativeElement.type === 'date') {\n      normalizedValue = obj.toISOString().split('T')[0];\n    } else {\n      normalizedValue = obj.toLocaleDateString('en-US', { month: '2-digit', day: '2-digit', year: 'numeric' }); // TODO: support other date formats\n    }\n    this.setProperty('value', normalizedValue);\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = (value) => {\n      const parsed = this.parseDate(value);\n      fn(parsed);\n    };\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.setProperty('disabled', isDisabled);\n  }\n  protected setProperty(key: string, value: any): void {\n    this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n  }\n\n  private parseDate(value: string): Date | undefined {\n    const validFormat = this._elementRef.nativeElement.type === 'date' ? /^(\\d{4}-\\d{2}-\\d{2})$/.test(value) : /^(\\d{1,2}\\/\\d{1,2}\\/\\d{4})$/.test(value);\n    if (!validFormat) {\n      return undefined;\n    }\n\n    const entry = new Date(value).toISOString().split('T')[0];\n\n    /* For ISO Strings without time the day, month and year must be extracted from the ISO String\n      before Date creation to avoid time offset and errors in the new Date.\n      If we only replace '-' with ',' in the ISO String (\"2015,01,01\"), and try to create a new\n      date, some browsers (e.g. IE 9) will throw an invalid Date error.\n      If we leave the '-' (\"2015-01-01\") and try to create a new Date(\"2015-01-01\") the timeoffset\n      is applied.\n      Note: ISO months are 0 for January, 1 for February, ... */\n    const [y, m = 1, d = 1] = entry.split('-').map((val: string) => +val);\n    return this.createDate(y, m - 1, d);\n  }\n\n  private createDate(year: number, month: number, date: number): Date {\n    // The `newDate` is set to midnight (UTC) on January 1st 1970.\n    // - In PST this will be December 31st 1969 at 4pm.\n    // - In GMT this will be January 1st 1970 at 1am.\n    // Note that they even have different years, dates and months!\n    const newDate = new Date(0);\n\n    // `setFullYear()` allows years like 0001 to be set correctly. This function does not\n    // change the internal time of the date.\n    // Consider calling `setFullYear(2019, 8, 20)` (September 20, 2019).\n    // - In PST this will now be September 20, 2019 at 4pm\n    // - In GMT this will now be September 20, 2019 at 1am\n\n    newDate.setFullYear(year, month, date);\n    // We want the final date to be at local midnight, so we reset the time.\n    // - In PST this will now be September 20, 2019 at 12am\n    // - In GMT this will now be September 20, 2019 at 12am\n    newDate.setHours(0, 0, 0);\n\n    return newDate;\n  }\n}\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Component, ContentChild, Input } from '@angular/core';
|
|
2
|
+
import { NgModel } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class MzField {
|
|
5
|
+
constructor(elementRef) {
|
|
6
|
+
this.elementRef = elementRef;
|
|
7
|
+
this.controlType = 'other';
|
|
8
|
+
}
|
|
9
|
+
ngAfterContentInit() {
|
|
10
|
+
//this.fieldMetadata = this.form.schema.getMetadata(this.ngModel?.path || []);
|
|
11
|
+
}
|
|
12
|
+
getErrorMessage() {
|
|
13
|
+
try {
|
|
14
|
+
const list = Object.values(this.ngModel.errors);
|
|
15
|
+
return list[0];
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return undefined;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzField, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MzField, isStandalone: true, selector: "mz-field", inputs: { label: "label", controlType: "controlType", schema: "schema" }, queries: [{ propertyName: "ngModel", first: true, predicate: NgModel, descendants: true }], ngImport: i0, template: "<label class=\"field\">\n @if(label && controlType !== 'checkbox') {\n <span class=\"field-label\">\n {{ label }} \n </span>\n }\n <ng-content></ng-content>\n\n @if(controlType === 'checkbox' && label) {\n <span class=\"checkbox-label\">{{ label }}</span>\n } \n @if(ngModel?.touched && ngModel?.invalid) {\n <div class=\"field-error\">\n {{ getErrorMessage() }}\n </div>\n }\n</label>\n" }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzField, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{ selector: 'mz-field', standalone: true, imports: [], template: "<label class=\"field\">\n @if(label && controlType !== 'checkbox') {\n <span class=\"field-label\">\n {{ label }} \n </span>\n }\n <ng-content></ng-content>\n\n @if(controlType === 'checkbox' && label) {\n <span class=\"checkbox-label\">{{ label }}</span>\n } \n @if(ngModel?.touched && ngModel?.invalid) {\n <div class=\"field-error\">\n {{ getErrorMessage() }}\n </div>\n }\n</label>\n" }]
|
|
27
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { label: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], controlType: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], schema: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], ngModel: [{
|
|
34
|
+
type: ContentChild,
|
|
35
|
+
args: [NgModel]
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvZmllbGQvZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvZmllbGQvZmllbGQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFvQixTQUFTLEVBQUUsWUFBWSxFQUFjLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDaEgsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQVd6QyxNQUFNLE9BQU8sT0FBTztJQU9oQixZQUFvQixVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBTGpDLGdCQUFXLEdBQTJDLE9BQU8sQ0FBQztJQUsxQixDQUFDO0lBRTlDLGtCQUFrQjtRQUNkLDhFQUE4RTtJQUNsRixDQUFDO0lBRUQsZUFBZTtRQUNYLElBQUksQ0FBQztZQUNELE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQVEsQ0FBQyxNQUFPLENBQUMsQ0FBQztZQUNsRCxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuQixDQUFDO1FBQUMsTUFBTSxDQUFDO1lBQ0wsT0FBTyxTQUFTLENBQUM7UUFDckIsQ0FBQztJQUNMLENBQUM7K0dBcEJRLE9BQU87bUdBQVAsT0FBTyxtTEFJRixPQUFPLGdEQ2hCekIsbWNBaUJBOzs0RkRMYSxPQUFPO2tCQU5uQixTQUFTOytCQUNJLFVBQVUsY0FDUixJQUFJLFdBQ1AsRUFBRTsrRUFJRixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ2lCLE9BQU87c0JBQTdCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyQ29udGVudEluaXQsIENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nTW9kZWwgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBGaWVsZFNjaGVtYSB9IGZyb20gJy4uL2ZpZWxkLXNjaGVtYSc7XG5pbXBvcnQgeyBNekZvcm0gfSBmcm9tICcuLi9mb3JtL2Zvcm0uZGlyZWN0aXZlJztcbmltcG9ydCB7IEZpZWxkTWV0YWRhdGEgfSBmcm9tICcuLi9tb2RlbC1zY2hlbWEnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ216LWZpZWxkJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maWVsZC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgTXpGaWVsZCBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQge1xuICAgIEBJbnB1dCgpIGxhYmVsPzogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGNvbnRyb2xUeXBlOiAnY2hlY2tib3gnIHwgJ2NoZWNrYm94Z3JvdXAnIHwgJ290aGVyJyA9ICdvdGhlcic7XG4gICAgQElucHV0KCkgc2NoZW1hPzogRmllbGRTY2hlbWE8YW55PjtcbiAgICBAQ29udGVudENoaWxkKE5nTW9kZWwpIG5nTW9kZWw/OiBOZ01vZGVsO1xuXG4gICAgZmllbGRNZXRhZGF0YT86IEZpZWxkTWV0YWRhdGE7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuXG4gICAgbmdBZnRlckNvbnRlbnRJbml0KCk6IHZvaWQge1xuICAgICAgICAvL3RoaXMuZmllbGRNZXRhZGF0YSA9IHRoaXMuZm9ybS5zY2hlbWEuZ2V0TWV0YWRhdGEodGhpcy5uZ01vZGVsPy5wYXRoIHx8IFtdKTtcbiAgICB9XG5cbiAgICBnZXRFcnJvck1lc3NhZ2UoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IGxpc3QgPSBPYmplY3QudmFsdWVzKHRoaXMubmdNb2RlbCEuZXJyb3JzISk7XG4gICAgICAgICAgICByZXR1cm4gbGlzdFswXTtcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGxhYmVsIGNsYXNzPVwiZmllbGRcIj5cbiAgICBAaWYobGFiZWwgJiYgY29udHJvbFR5cGUgIT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJmaWVsZC1sYWJlbFwiPlxuICAgICAgICAgICAge3sgbGFiZWwgfX0gXG4gICAgICAgIDwvc3Bhbj5cbiAgICB9XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG4gICAgQGlmKGNvbnRyb2xUeXBlID09PSAnY2hlY2tib3gnICYmIGxhYmVsKSB7XG4gICAgPHNwYW4gY2xhc3M9XCJjaGVja2JveC1sYWJlbFwiPnt7IGxhYmVsIH19PC9zcGFuPlxuICAgIH0gXG4gICAgQGlmKG5nTW9kZWw/LnRvdWNoZWQgJiYgbmdNb2RlbD8uaW52YWxpZCkge1xuICAgIDxkaXYgY2xhc3M9XCJmaWVsZC1lcnJvclwiPlxuICAgICAgICB7eyBnZXRFcnJvck1lc3NhZ2UoKSB9fVxuICAgIDwvZGl2PlxuICAgIH1cbjwvbGFiZWw+XG4iXX0=
|
|
@@ -6,13 +6,13 @@ export class FieldErrorsComponent {
|
|
|
6
6
|
const errorKeys = Object.keys(this.field?.errors || {});
|
|
7
7
|
return errorKeys.length > 0 ? (this.field?.errors)[errorKeys[0]] : '';
|
|
8
8
|
}
|
|
9
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.
|
|
10
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FieldErrorsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FieldErrorsComponent, selector: "mz-field-errors", inputs: { field: "field" }, ngImport: i0, template: "<div class=\"field-error\" *ngIf=\"errorMessage\">{{ errorMessage }}</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
11
11
|
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FieldErrorsComponent, decorators: [{
|
|
13
13
|
type: Component,
|
|
14
14
|
args: [{ selector: 'mz-field-errors', template: "<div class=\"field-error\" *ngIf=\"errorMessage\">{{ errorMessage }}</div>\n" }]
|
|
15
15
|
}], propDecorators: { field: [{
|
|
16
16
|
type: Input
|
|
17
17
|
}] } });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtZXJyb3JzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL211emllaGRlc2lnbi9mb3Jtcy9zcmMvbGliL2ZpZWxkLWVycm9ycy9maWVsZC1lcnJvcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvZmllbGQtZXJyb3JzL2ZpZWxkLWVycm9ycy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7O0FBUXpELE1BQU0sT0FBTyxvQkFBb0I7SUFHL0IsSUFBSSxZQUFZO1FBQ2QsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sSUFBSSxFQUFFLENBQUMsQ0FBQztRQUN4RCxPQUFPLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsTUFBMkIsQ0FBQSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDNUYsQ0FBQzsrR0FOVSxvQkFBb0I7bUdBQXBCLG9CQUFvQixtRkNSakMsOEVBQ0E7OzRGRE9hLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxpQkFBaUI7OEJBS2xCLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDb250cm9sLCBWYWxpZGF0aW9uRXJyb3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtei1maWVsZC1lcnJvcnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmllbGQtZXJyb3JzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmllbGQtZXJyb3JzLmNvbXBvbmVudC5jc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgRmllbGRFcnJvcnNDb21wb25lbnQge1xuICBASW5wdXQoKSBmaWVsZD86IE5nQ29udHJvbDtcblxuICBnZXQgZXJyb3JNZXNzYWdlKCk6IHN0cmluZyB7XG4gICAgY29uc3QgZXJyb3JLZXlzID0gT2JqZWN0LmtleXModGhpcy5maWVsZD8uZXJyb3JzIHx8IHt9KTtcbiAgICByZXR1cm4gZXJyb3JLZXlzLmxlbmd0aCA+IDAgPyAodGhpcy5maWVsZD8uZXJyb3JzIGFzIFZhbGlkYXRpb25FcnJvcnMpW2Vycm9yS2V5c1swXV0gOiAnJztcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImZpZWxkLWVycm9yXCIgKm5nSWY9XCJlcnJvck1lc3NhZ2VcIj57eyBlcnJvck1lc3NhZ2UgfX08L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
export var FieldSchemaType;
|
|
2
|
+
(function (FieldSchemaType) {
|
|
3
|
+
FieldSchemaType["string"] = "string";
|
|
4
|
+
FieldSchemaType["boolean"] = "boolean";
|
|
5
|
+
FieldSchemaType["date"] = "date";
|
|
6
|
+
FieldSchemaType["object"] = "object";
|
|
7
|
+
FieldSchemaType["number"] = "number";
|
|
8
|
+
FieldSchemaType["array"] = "array";
|
|
9
|
+
FieldSchemaType["file"] = "file";
|
|
10
|
+
})(FieldSchemaType || (FieldSchemaType = {}));
|
|
11
|
+
export const buildStringSchema = (path, constraints, label) => {
|
|
12
|
+
return {
|
|
13
|
+
name: path,
|
|
14
|
+
label: label,
|
|
15
|
+
type: FieldSchemaType.string,
|
|
16
|
+
constraints: { ...constraints },
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
export const buildBooleanSchema = (path, constraints, label) => {
|
|
20
|
+
return {
|
|
21
|
+
name: path,
|
|
22
|
+
label: label,
|
|
23
|
+
type: FieldSchemaType.boolean,
|
|
24
|
+
constraints: { ...constraints },
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
export const buildNumberSchema = (path, constraints, label) => {
|
|
28
|
+
return {
|
|
29
|
+
name: path,
|
|
30
|
+
label: label,
|
|
31
|
+
type: FieldSchemaType.number,
|
|
32
|
+
constraints: { ...constraints },
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
export const buildDateSchema = (path, constraints, label) => {
|
|
36
|
+
return {
|
|
37
|
+
name: path,
|
|
38
|
+
label: label,
|
|
39
|
+
type: FieldSchemaType.date,
|
|
40
|
+
constraints: { ...constraints },
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
export const buildArraySchema = (path, constraints, label) => {
|
|
44
|
+
return {
|
|
45
|
+
name: path,
|
|
46
|
+
label: label,
|
|
47
|
+
type: FieldSchemaType.array,
|
|
48
|
+
constraints: { ...constraints },
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtc2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvZmllbGQtc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBTixJQUFZLGVBUVg7QUFSRCxXQUFZLGVBQWU7SUFDdkIsb0NBQWlCLENBQUE7SUFDakIsc0NBQW1CLENBQUE7SUFDbkIsZ0NBQWEsQ0FBQTtJQUNiLG9DQUFpQixDQUFBO0lBQ2pCLG9DQUFpQixDQUFBO0lBQ2pCLGtDQUFlLENBQUE7SUFDZixnQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFSVyxlQUFlLEtBQWYsZUFBZSxRQVExQjtBQXFDRCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLElBQVksRUFBRSxXQUFrQyxFQUFFLEtBQWMsRUFBRSxFQUFFO0lBQ2xHLE9BQU87UUFDSCxJQUFJLEVBQUUsSUFBSTtRQUNWLEtBQUssRUFBRSxLQUFLO1FBQ1osSUFBSSxFQUFFLGVBQWUsQ0FBQyxNQUFNO1FBQzVCLFdBQVcsRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFO0tBQ1gsQ0FBQztBQUM3QixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLElBQVksRUFBRSxXQUFtQyxFQUFFLEtBQWMsRUFBRSxFQUFFO0lBQ3BHLE9BQU87UUFDSCxJQUFJLEVBQUUsSUFBSTtRQUNWLEtBQUssRUFBRSxLQUFLO1FBQ1osSUFBSSxFQUFFLGVBQWUsQ0FBQyxPQUFPO1FBQzdCLFdBQVcsRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFO0tBQ1YsQ0FBQztBQUM5QixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLElBQVksRUFBRSxXQUFrQyxFQUFFLEtBQWMsRUFBRSxFQUFFO0lBQ2xHLE9BQU87UUFDSCxJQUFJLEVBQUUsSUFBSTtRQUNWLEtBQUssRUFBRSxLQUFLO1FBQ1osSUFBSSxFQUFFLGVBQWUsQ0FBQyxNQUFNO1FBQzVCLFdBQVcsRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFO0tBQ1gsQ0FBQztBQUM3QixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxJQUFZLEVBQUUsV0FBZ0MsRUFBRSxLQUFjLEVBQUUsRUFBRTtJQUM5RixPQUFPO1FBQ0gsSUFBSSxFQUFFLElBQUk7UUFDVixLQUFLLEVBQUUsS0FBSztRQUNaLElBQUksRUFBRSxlQUFlLENBQUMsSUFBSTtRQUMxQixXQUFXLEVBQUUsRUFBRSxHQUFHLFdBQVcsRUFBRTtLQUNiLENBQUM7QUFDM0IsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxJQUFZLEVBQUUsV0FBaUMsRUFBRSxLQUFjLEVBQUUsRUFBRTtJQUNoRyxPQUFPO1FBQ0gsSUFBSSxFQUFFLElBQUk7UUFDVixLQUFLLEVBQUUsS0FBSztRQUNaLElBQUksRUFBRSxlQUFlLENBQUMsS0FBSztRQUMzQixXQUFXLEVBQUUsRUFBRSxHQUFHLFdBQVcsRUFBRTtLQUNaLENBQUM7QUFDNUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXJyYXlUeXBlQW5ub3RhdGlvbnMsIEJvb2xlYW5UeXBlQW5ub3RhdGlvbnMsIENvbnN0cmFpbnRBbm5vdGF0aW9ucywgRGF0ZVR5cGVBbm5vdGF0aW9ucywgRmlsZVR5cGVBbm5vdGF0aW9ucywgTnVtYmVyVHlwZUFubm90YXRpb25zLCBPYmplY3RUeXBlQW5ub3RhdGlvbnMsIFN0cmluZ1R5cGVBbm5vdGF0aW9ucyB9IGZyb20gJy4vdHlwZS1hbm5vdGF0aW9ucyc7XG5cbmV4cG9ydCBlbnVtIEZpZWxkU2NoZW1hVHlwZSB7XG4gICAgc3RyaW5nID0gJ3N0cmluZycsXG4gICAgYm9vbGVhbiA9ICdib29sZWFuJyxcbiAgICBkYXRlID0gJ2RhdGUnLFxuICAgIG9iamVjdCA9ICdvYmplY3QnLFxuICAgIG51bWJlciA9ICdudW1iZXInLFxuICAgIGFycmF5ID0gJ2FycmF5JyxcbiAgICBmaWxlID0gJ2ZpbGUnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpZWxkU2NoZW1hPFQgZXh0ZW5kcyBDb25zdHJhaW50QW5ub3RhdGlvbnM+IHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdHlwZTogRmllbGRTY2hlbWFUeXBlO1xuICAgIGxhYmVsPzogc3RyaW5nO1xuICAgIGNvbnN0cmFpbnRzOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0cmluZ1NjaGVtYSBleHRlbmRzIEZpZWxkU2NoZW1hPFN0cmluZ1R5cGVBbm5vdGF0aW9ucz4ge1xuICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5zdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyU2NoZW1hIGV4dGVuZHMgRmllbGRTY2hlbWE8TnVtYmVyVHlwZUFubm90YXRpb25zPiB7XG4gICAgdHlwZTogRmllbGRTY2hlbWFUeXBlLm51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCb29sZWFuU2NoZW1hIGV4dGVuZHMgRmllbGRTY2hlbWE8Qm9vbGVhblR5cGVBbm5vdGF0aW9ucz4ge1xuICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5ib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERhdGVTY2hlbWEgZXh0ZW5kcyBGaWVsZFNjaGVtYTxEYXRlVHlwZUFubm90YXRpb25zPiB7XG4gICAgdHlwZTogRmllbGRTY2hlbWFUeXBlLmRhdGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXJyYXlTY2hlbWEgZXh0ZW5kcyBGaWVsZFNjaGVtYTxBcnJheVR5cGVBbm5vdGF0aW9ucz4ge1xuICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5hcnJheTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGaWxlU2NoZW1hIGV4dGVuZHMgRmllbGRTY2hlbWE8RmlsZVR5cGVBbm5vdGF0aW9ucz4ge1xuICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5maWxlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9iamVjdFNjaGVtYSBleHRlbmRzIEZpZWxkU2NoZW1hPE9iamVjdFR5cGVBbm5vdGF0aW9ucz4ge1xuICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5vYmplY3Q7XG59XG5cbmV4cG9ydCBjb25zdCBidWlsZFN0cmluZ1NjaGVtYSA9IChwYXRoOiBzdHJpbmcsIGNvbnN0cmFpbnRzOiBTdHJpbmdUeXBlQW5ub3RhdGlvbnMsIGxhYmVsPzogc3RyaW5nKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgbmFtZTogcGF0aCxcbiAgICAgICAgbGFiZWw6IGxhYmVsLFxuICAgICAgICB0eXBlOiBGaWVsZFNjaGVtYVR5cGUuc3RyaW5nLFxuICAgICAgICBjb25zdHJhaW50czogeyAuLi5jb25zdHJhaW50cyB9LFxuICAgIH0gc2F0aXNmaWVzIFN0cmluZ1NjaGVtYTtcbn07XG5cbmV4cG9ydCBjb25zdCBidWlsZEJvb2xlYW5TY2hlbWEgPSAocGF0aDogc3RyaW5nLCBjb25zdHJhaW50czogQm9vbGVhblR5cGVBbm5vdGF0aW9ucywgbGFiZWw/OiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4ge1xuICAgICAgICBuYW1lOiBwYXRoLFxuICAgICAgICBsYWJlbDogbGFiZWwsXG4gICAgICAgIHR5cGU6IEZpZWxkU2NoZW1hVHlwZS5ib29sZWFuLFxuICAgICAgICBjb25zdHJhaW50czogeyAuLi5jb25zdHJhaW50cyB9LFxuICAgIH0gc2F0aXNmaWVzIEJvb2xlYW5TY2hlbWE7XG59O1xuXG5leHBvcnQgY29uc3QgYnVpbGROdW1iZXJTY2hlbWEgPSAocGF0aDogc3RyaW5nLCBjb25zdHJhaW50czogTnVtYmVyVHlwZUFubm90YXRpb25zLCBsYWJlbD86IHN0cmluZykgPT4ge1xuICAgIHJldHVybiB7XG4gICAgICAgIG5hbWU6IHBhdGgsXG4gICAgICAgIGxhYmVsOiBsYWJlbCxcbiAgICAgICAgdHlwZTogRmllbGRTY2hlbWFUeXBlLm51bWJlcixcbiAgICAgICAgY29uc3RyYWludHM6IHsgLi4uY29uc3RyYWludHMgfSxcbiAgICB9IHNhdGlzZmllcyBOdW1iZXJTY2hlbWE7XG59O1xuXG5leHBvcnQgY29uc3QgYnVpbGREYXRlU2NoZW1hID0gKHBhdGg6IHN0cmluZywgY29uc3RyYWludHM6IERhdGVUeXBlQW5ub3RhdGlvbnMsIGxhYmVsPzogc3RyaW5nKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgbmFtZTogcGF0aCxcbiAgICAgICAgbGFiZWw6IGxhYmVsLFxuICAgICAgICB0eXBlOiBGaWVsZFNjaGVtYVR5cGUuZGF0ZSxcbiAgICAgICAgY29uc3RyYWludHM6IHsgLi4uY29uc3RyYWludHMgfSxcbiAgICB9IHNhdGlzZmllcyBEYXRlU2NoZW1hO1xufTtcblxuZXhwb3J0IGNvbnN0IGJ1aWxkQXJyYXlTY2hlbWEgPSAocGF0aDogc3RyaW5nLCBjb25zdHJhaW50czogQXJyYXlUeXBlQW5ub3RhdGlvbnMsIGxhYmVsPzogc3RyaW5nKSA9PiB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgbmFtZTogcGF0aCxcbiAgICAgICAgbGFiZWw6IGxhYmVsLFxuICAgICAgICB0eXBlOiBGaWVsZFNjaGVtYVR5cGUuYXJyYXksXG4gICAgICAgIGNvbnN0cmFpbnRzOiB7IC4uLmNvbnN0cmFpbnRzIH0sXG4gICAgfSBzYXRpc2ZpZXMgQXJyYXlTY2hlbWE7XG59O1xuIl19
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { NgFormModelState } from '../ngform-model-state';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
export class MzForm {
|
|
6
|
+
constructor(ngForm) {
|
|
7
|
+
this.ngForm = ngForm;
|
|
8
|
+
}
|
|
9
|
+
ngAfterViewInit() {
|
|
10
|
+
this.modelState = new NgFormModelState(this.ngForm, this.schema);
|
|
11
|
+
}
|
|
12
|
+
onSubmit(event) {
|
|
13
|
+
this.ngForm.form.markAllAsTouched();
|
|
14
|
+
if (this.ngForm.invalid) {
|
|
15
|
+
event.preventDefault();
|
|
16
|
+
event.stopImmediatePropagation();
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzForm, deps: [{ token: i1.NgForm }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
20
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MzForm, isStandalone: true, selector: "[mzForm]", inputs: { schema: "schema" }, host: { listeners: { "submit": "onSubmit($event)" } }, ngImport: i0 }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzForm, decorators: [{
|
|
23
|
+
type: Directive,
|
|
24
|
+
args: [{
|
|
25
|
+
selector: '[mzForm]',
|
|
26
|
+
standalone: true,
|
|
27
|
+
}]
|
|
28
|
+
}], ctorParameters: () => [{ type: i1.NgForm }], propDecorators: { schema: [{
|
|
29
|
+
type: Input,
|
|
30
|
+
args: [{ required: true }]
|
|
31
|
+
}], onSubmit: [{
|
|
32
|
+
type: HostListener,
|
|
33
|
+
args: ['submit', ['$event']]
|
|
34
|
+
}] } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tdXppZWhkZXNpZ24vZm9ybXMvc3JjL2xpYi9mb3JtL2Zvcm0uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHdEYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7OztBQU16RCxNQUFNLE9BQU8sTUFBTTtJQUtmLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBRWxDLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFHRCxRQUFRLENBQUMsS0FBWTtRQUNqQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3BDLElBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNyQixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsS0FBSyxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDckMsQ0FBQztJQUNMLENBQUM7K0dBcEJRLE1BQU07bUdBQU4sTUFBTTs7NEZBQU4sTUFBTTtrQkFKbEIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsVUFBVTtvQkFDcEIsVUFBVSxFQUFFLElBQUk7aUJBQ25COzJFQUU4QixNQUFNO3NCQUFoQyxLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFhekIsUUFBUTtzQkFEUCxZQUFZO3VCQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ0Zvcm0gfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNb2RlbFNjaGVtYSB9IGZyb20gJy4uL21vZGVsLXNjaGVtYSc7XG5pbXBvcnQgeyBOZ0Zvcm1Nb2RlbFN0YXRlIH0gZnJvbSAnLi4vbmdmb3JtLW1vZGVsLXN0YXRlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbbXpGb3JtXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTXpGb3JtIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gICAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgc2NoZW1hITogTW9kZWxTY2hlbWE8dW5rbm93bj47XG5cbiAgICBwcml2YXRlIG1vZGVsU3RhdGUhOiBOZ0Zvcm1Nb2RlbFN0YXRlPHVua25vd24+O1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBuZ0Zvcm06IE5nRm9ybSkge1xuXG4gICAgfVxuICAgIFxuICAgIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5tb2RlbFN0YXRlID0gbmV3IE5nRm9ybU1vZGVsU3RhdGUodGhpcy5uZ0Zvcm0sIHRoaXMuc2NoZW1hKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdzdWJtaXQnLCBbJyRldmVudCddKVxuICAgIG9uU3VibWl0KGV2ZW50OiBFdmVudCkge1xuICAgICAgICB0aGlzLm5nRm9ybS5mb3JtLm1hcmtBbGxBc1RvdWNoZWQoKTtcbiAgICAgICAgaWYodGhpcy5uZ0Zvcm0uaW52YWxpZCkge1xuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -1,15 +1,22 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { FieldErrorsComponent } from './field-errors/field-errors.component';
|
|
4
|
+
import { MzField } from './field/field.component';
|
|
5
|
+
import { MzForm } from './form/form.directive';
|
|
6
|
+
import { DateValueAccessor } from './date-value-accessor.directive';
|
|
7
|
+
import { MzCheckboxGroup } from './checkbox-group/checkbox-group.component';
|
|
4
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
/**
|
|
10
|
+
* @deprecated
|
|
11
|
+
*/
|
|
5
12
|
export class FormsModule {
|
|
6
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.
|
|
7
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
14
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: FormsModule, declarations: [FieldErrorsComponent], imports: [CommonModule // TODO: can remove once done with temp error displaying
|
|
8
15
|
], exports: [FieldErrorsComponent] }); }
|
|
9
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.
|
|
16
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormsModule, imports: [CommonModule // TODO: can remove once done with temp error displaying
|
|
10
17
|
] }); }
|
|
11
18
|
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormsModule, decorators: [{
|
|
13
20
|
type: NgModule,
|
|
14
21
|
args: [{
|
|
15
22
|
providers: [],
|
|
@@ -24,4 +31,33 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
24
31
|
]
|
|
25
32
|
}]
|
|
26
33
|
}] });
|
|
27
|
-
|
|
34
|
+
export class MzFormsModule {
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzFormsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
36
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MzFormsModule, imports: [MzField,
|
|
37
|
+
MzForm,
|
|
38
|
+
DateValueAccessor,
|
|
39
|
+
MzCheckboxGroup], exports: [MzField,
|
|
40
|
+
MzForm,
|
|
41
|
+
DateValueAccessor,
|
|
42
|
+
MzCheckboxGroup] }); }
|
|
43
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzFormsModule, imports: [MzCheckboxGroup] }); }
|
|
44
|
+
}
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MzFormsModule, decorators: [{
|
|
46
|
+
type: NgModule,
|
|
47
|
+
args: [{
|
|
48
|
+
providers: [],
|
|
49
|
+
exports: [
|
|
50
|
+
MzField,
|
|
51
|
+
MzForm,
|
|
52
|
+
DateValueAccessor,
|
|
53
|
+
MzCheckboxGroup
|
|
54
|
+
],
|
|
55
|
+
imports: [
|
|
56
|
+
MzField,
|
|
57
|
+
MzForm,
|
|
58
|
+
DateValueAccessor,
|
|
59
|
+
MzCheckboxGroup
|
|
60
|
+
]
|
|
61
|
+
}]
|
|
62
|
+
}] });
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXV6aWVoZGVzaWduL2Zvcm1zL3NyYy9saWIvZm9ybXMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQUc1RTs7R0FFRztBQWFILE1BQU0sT0FBTyxXQUFXOytHQUFYLFdBQVc7Z0hBQVgsV0FBVyxpQkFUcEIsb0JBQW9CLGFBTXBCLFlBQVksQ0FBQyx3REFBd0Q7cUJBSHJFLG9CQUFvQjtnSEFNWCxXQUFXLFlBSHBCLFlBQVksQ0FBQyx3REFBd0Q7Ozs0RkFHNUQsV0FBVztrQkFadkIsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsRUFBRTtvQkFDYixZQUFZLEVBQUU7d0JBQ1osb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWSxDQUFDLHdEQUF3RDtxQkFDdEU7aUJBQ0Y7O0FBbUJELE1BQU0sT0FBTyxhQUFhOytHQUFiLGFBQWE7Z0hBQWIsYUFBYSxZQU50QixPQUFPO1lBQ1AsTUFBTTtZQUNOLGlCQUFpQjtZQUNqQixlQUFlLGFBVGYsT0FBTztZQUNQLE1BQU07WUFDTixpQkFBaUI7WUFDakIsZUFBZTtnSEFTTixhQUFhLFlBSHRCLGVBQWU7OzRGQUdOLGFBQWE7a0JBZnpCLFFBQVE7bUJBQUM7b0JBQ1IsU0FBUyxFQUFFLEVBQUU7b0JBQ2IsT0FBTyxFQUFFO3dCQUNQLE9BQU87d0JBQ1AsTUFBTTt3QkFDTixpQkFBaUI7d0JBQ2pCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxPQUFPO3dCQUNQLE1BQU07d0JBQ04saUJBQWlCO3dCQUNqQixlQUFlO3FCQUNoQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRFcnJvcnNDb21wb25lbnQgfSBmcm9tICcuL2ZpZWxkLWVycm9ycy9maWVsZC1lcnJvcnMuY29tcG9uZW50JztcbmltcG9ydCB7IE16RmllbGQgfSBmcm9tICcuL2ZpZWxkL2ZpZWxkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNekZvcm0gfSBmcm9tICcuL2Zvcm0vZm9ybS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGF0ZVZhbHVlQWNjZXNzb3IgfSBmcm9tICcuL2RhdGUtdmFsdWUtYWNjZXNzb3IuZGlyZWN0aXZlJztcbmltcG9ydCB7IE16Q2hlY2tib3hHcm91cCB9IGZyb20gJy4vY2hlY2tib3gtZ3JvdXAvY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50JztcblxuXG4vKipcbiAqIEBkZXByZWNhdGVkXG4gKi9cbkBOZ01vZHVsZSh7XG4gIHByb3ZpZGVyczogW10sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEZpZWxkRXJyb3JzQ29tcG9uZW50XG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBGaWVsZEVycm9yc0NvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlIC8vIFRPRE86IGNhbiByZW1vdmUgb25jZSBkb25lIHdpdGggdGVtcCBlcnJvciBkaXNwbGF5aW5nXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRm9ybXNNb2R1bGUgeyB9XG5cblxuQE5nTW9kdWxlKHtcbiAgcHJvdmlkZXJzOiBbXSxcbiAgZXhwb3J0czogW1xuICAgIE16RmllbGQsXG4gICAgTXpGb3JtLFxuICAgIERhdGVWYWx1ZUFjY2Vzc29yLFxuICAgIE16Q2hlY2tib3hHcm91cFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgTXpGaWVsZCxcbiAgICBNekZvcm0sXG4gICAgRGF0ZVZhbHVlQWNjZXNzb3IsXG4gICAgTXpDaGVja2JveEdyb3VwXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgTXpGb3Jtc01vZHVsZSB7IH1cbiJdfQ==
|
package/esm2022/lib/masks.mjs
CHANGED
|
@@ -1,45 +1,3 @@
|
|
|
1
|
-
import { format, isValid, parse } from 'date-fns';
|
|
2
|
-
import * as IMask from 'imask';
|
|
3
|
-
export const dateMaskOptions = {
|
|
4
|
-
mask: 'MM/dd/yyyy',
|
|
5
|
-
format: (date) => {
|
|
6
|
-
if (!date) {
|
|
7
|
-
return '';
|
|
8
|
-
}
|
|
9
|
-
return format(date, 'MM/dd/yyyy');
|
|
10
|
-
},
|
|
11
|
-
parse: (str) => {
|
|
12
|
-
const dateRegex = /(0[1-9]|1[0-2])\/(0[1-9]|[12]\d|3[01])\/([12]\d{3})/;
|
|
13
|
-
if (!str.match(dateRegex)) {
|
|
14
|
-
return undefined;
|
|
15
|
-
}
|
|
16
|
-
const parsed = parse(str, 'MM/dd/yyyy', new Date());
|
|
17
|
-
if (isValid(parsed)) {
|
|
18
|
-
return parsed;
|
|
19
|
-
}
|
|
20
|
-
return undefined;
|
|
21
|
-
},
|
|
22
|
-
blocks: {
|
|
23
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
24
|
-
MM: {
|
|
25
|
-
mask: IMask.MaskedRange,
|
|
26
|
-
from: 1,
|
|
27
|
-
to: 12,
|
|
28
|
-
},
|
|
29
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
30
|
-
dd: {
|
|
31
|
-
mask: IMask.MaskedRange,
|
|
32
|
-
from: 1,
|
|
33
|
-
to: 31,
|
|
34
|
-
},
|
|
35
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
36
|
-
yyyy: {
|
|
37
|
-
mask: IMask.MaskedRange,
|
|
38
|
-
from: 1000,
|
|
39
|
-
to: 9999,
|
|
40
|
-
},
|
|
41
|
-
},
|
|
42
|
-
};
|
|
43
1
|
export const phoneNumberOptions = {
|
|
44
2
|
mask: '(000) 000-0000',
|
|
45
3
|
};
|
|
@@ -62,4 +20,4 @@ export const integerOptions = {
|
|
|
62
20
|
radix: '.',
|
|
63
21
|
mapToRadix: ['.'],
|
|
64
22
|
};
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFza3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tdXppZWhkZXNpZ24vZm9ybXMvc3JjL2xpYi9tYXNrcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRztJQUNoQyxJQUFJLEVBQUUsZ0JBQWdCO0NBQ3ZCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsSUFBSSxFQUFFLGFBQWE7Q0FDcEIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixJQUFJLEVBQUUsTUFBTTtJQUNaLEtBQUssRUFBRSxDQUFDO0lBQ1Isa0JBQWtCLEVBQUUsR0FBRztJQUN2QixrQkFBa0IsRUFBRSxJQUFJO0lBQ3hCLEtBQUssRUFBRSxHQUFHO0lBQ1YsVUFBVSxFQUFFLENBQUMsR0FBRyxDQUFDO0NBQ2xCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7SUFDNUIsSUFBSSxFQUFFLE1BQU07SUFDWixLQUFLLEVBQUUsQ0FBQztJQUNSLGtCQUFrQixFQUFFLEdBQUc7SUFDdkIsa0JBQWtCLEVBQUUsSUFBSTtJQUN4QixLQUFLLEVBQUUsR0FBRztJQUNWLFVBQVUsRUFBRSxDQUFDLEdBQUcsQ0FBQztDQUNsQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZm9ybWF0LCBpc1ZhbGlkLCBwYXJzZSB9IGZyb20gJ2RhdGUtZm5zJztcbmltcG9ydCAqIGFzIElNYXNrIGZyb20gJ2ltYXNrJztcblxuZXhwb3J0IGNvbnN0IHBob25lTnVtYmVyT3B0aW9ucyA9IHtcbiAgbWFzazogJygwMDApIDAwMC0wMDAwJyxcbn07XG5cbmV4cG9ydCBjb25zdCBzc25PcHRpb25zID0ge1xuICBtYXNrOiAnMDAwLTAwLTAwMDAnLFxufTtcblxuZXhwb3J0IGNvbnN0IGN1cnJlbmN5T3B0aW9ucyA9IHtcbiAgbWFzazogTnVtYmVyLFxuICBzY2FsZTogMixcbiAgdGhvdXNhbmRzU2VwYXJhdG9yOiAnLCcsXG4gIHBhZEZyYWN0aW9uYWxaZXJvczogdHJ1ZSxcbiAgcmFkaXg6ICcuJyxcbiAgbWFwVG9SYWRpeDogWycuJ10sXG59O1xuXG5leHBvcnQgY29uc3QgaW50ZWdlck9wdGlvbnMgPSB7XG4gIG1hc2s6IE51bWJlcixcbiAgc2NhbGU6IDAsXG4gIHRob3VzYW5kc1NlcGFyYXRvcjogJywnLFxuICBwYWRGcmFjdGlvbmFsWmVyb3M6IHRydWUsXG4gIHJhZGl4OiAnLicsXG4gIG1hcFRvUmFkaXg6IFsnLiddLFxufTtcblxuIl19
|