ngx-bimplus-components 0.0.160-29471-1 → 0.0.160-29471-2
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/assets/images/default/Calendar_18.svg +4 -0
- package/assets/images/default/Calendar_18_disabled.svg +1 -0
- package/assets/images/default/Calendar_18_gray.svg +1 -0
- package/esm2022/lib/components/bimplus-input-checkbox/bimplus-input-checkbox.component.mjs +3 -3
- package/esm2022/lib/components/bimplus-input-combobox/bimplus-input-combobox.component.mjs +1 -1
- package/esm2022/lib/components/bimplus-input-date/bimplus-input-date.component.mjs +271 -0
- package/esm2022/lib/components/bimplus-input-text-field/bimplus-input-text-field.component.mjs +3 -3
- package/esm2022/lib/components/object-properties/object-properties.component.mjs +16 -7
- package/esm2022/lib/components/object-properties-group/object-properties-group.component.mjs +8 -3
- package/esm2022/lib/pipes/get-attribute-value.pipe.mjs +2 -8
- package/esm2022/lib/validators/double-enum.validator.mjs +4 -1
- package/esm2022/lib/validators/guid-enum.validator.mjs +4 -1
- package/esm2022/lib/validators/guid.validator.mjs +4 -1
- package/esm2022/lib/validators/integer.validator.mjs +4 -1
- package/esm2022/lib/validators/string-combobox.validator.mjs +4 -1
- package/esm2022/lib/validators/string-enum.validator.mjs +4 -1
- package/fesm2022/ngx-bimplus-components.mjs +307 -19
- package/fesm2022/ngx-bimplus-components.mjs.map +1 -1
- package/lib/components/bimplus-input-date/bimplus-input-date.component.d.ts +46 -0
- package/lib/components/bimplus-input-text-field/bimplus-input-text-field.component.d.ts +1 -1
- package/lib/components/object-properties/object-properties.component.d.ts +1 -0
- package/lib/components/object-properties-group/object-properties-group.component.d.ts +1 -0
- package/package.json +3 -1
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
<svg width="18" height="18" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<path fill-rule="evenodd" clip-rule="evenodd" d="M13.0005 3V1H11.0005V4H13.0005V3ZM7.70049 13H9.00049L11.0005 8H7.00049V9H9.30049L7.70049 13ZM7.00049 3V1H5.00049V4H7.00049V3Z" fill="#0066CC"/>
|
|
3
|
+
<path fill-rule="evenodd" clip-rule="evenodd" d="M14.0005 3V5H10.0005V3H8.00049V5H4.00049V3H2.00049V16H16.0005V3H14.0005ZM14.0005 14H4.00049V7H14.0005V14Z" fill="#0066CC"/>
|
|
4
|
+
</svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" x="0" y="0" viewBox="0 0 18 18" xml:space="preserve"><style>.st0{fill-rule:evenodd;clip-rule:evenodd;fill:#bababa}</style><path class="st0" d="M13 3V1h-2v3h2zM7.7 13H9l2-5H7v1h2.3zM7 3V1H5v3h2z"/><path class="st0" d="M14 3v2h-4V3H8v2H4V3H2v13h14V3h-2zm0 11H4V7h10v7z"/></svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" x="0" y="0" viewBox="0 0 18 18" xml:space="preserve"><style>.st0{fill-rule:evenodd;clip-rule:evenodd;fill:#444}</style><path class="st0" d="M13 3V1h-2v3h2zM7.7 13H9l2-5H7v1h2.3zM7 3V1H5v3h2z"/><path class="st0" d="M14 3v2h-4V3H8v2H4V3H2v13h14V3h-2zm0 11H4V7h10v7z"/></svg>
|
|
@@ -44,7 +44,7 @@ export class BimplusInputCheckboxComponent {
|
|
|
44
44
|
useExisting: forwardRef(() => BimplusInputCheckboxComponent),
|
|
45
45
|
multi: true,
|
|
46
46
|
},
|
|
47
|
-
], ngImport: i0, template: "<div\n class=\"select-checkbox\"\n>\n <
|
|
47
|
+
], ngImport: i0, template: "<div\n class=\"select-checkbox\"\n>\n <div>\n <input\n type=\"checkbox\"\n [checked]=\"value\"\n (change)=\"onCheckboxChange($event)\"\n (click)=\"toggleAttributeValue()\"\n (keypress)=\"toggleAttributeValue()\"\n >\n <span></span>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;height:100%}.select-checkbox input{display:none}.select-checkbox input:checked+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%230066CC\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:checked+span:hover{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%23005BB6\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:checked:disabled+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%23D3D3D3\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:disabled+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"white\" stroke=\"%23D3D3D3\"/>%0A</svg>%0A')}.select-checkbox span{display:inline-block;background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"white\" stroke=\"%238D8D8D\"/>%0A</svg>%0A');width:1.8rem;height:1.8rem;margin-top:.1rem;vertical-align:middle;border:0;background-color:transparent;background-position:-.3rem center;background-size:100% 100%;background-repeat:no-repeat}.select-checkbox span:hover{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"%23F5F5F5\" stroke=\"%238D8D8D\"/>%0A</svg>%0A')}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: TranslateModule }], encapsulation: i0.ViewEncapsulation.ShadowDom }); }
|
|
48
48
|
}
|
|
49
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusInputCheckboxComponent, decorators: [{
|
|
50
50
|
type: Component,
|
|
@@ -57,8 +57,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
57
57
|
useExisting: forwardRef(() => BimplusInputCheckboxComponent),
|
|
58
58
|
multi: true,
|
|
59
59
|
},
|
|
60
|
-
], template: "<div\n class=\"select-checkbox\"\n>\n <
|
|
60
|
+
], template: "<div\n class=\"select-checkbox\"\n>\n <div>\n <input\n type=\"checkbox\"\n [checked]=\"value\"\n (change)=\"onCheckboxChange($event)\"\n (click)=\"toggleAttributeValue()\"\n (keypress)=\"toggleAttributeValue()\"\n >\n <span></span>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;height:100%}.select-checkbox input{display:none}.select-checkbox input:checked+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%230066CC\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:checked+span:hover{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%23005BB6\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:checked:disabled+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3\" y=\"3\" width=\"12\" height=\"12\" fill=\"%23D3D3D3\"/>%0A<path d=\"M13.0226 7.41421L11.6855 6L8.3428 9.5356L6.33707 7.41416L5 8.82837L8.34269 12.3639L13.0226 7.41421Z\" fill=\"white\"/>%0A</svg>%0A')}.select-checkbox input:disabled+span{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"white\" stroke=\"%23D3D3D3\"/>%0A</svg>%0A')}.select-checkbox span{display:inline-block;background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"white\" stroke=\"%238D8D8D\"/>%0A</svg>%0A');width:1.8rem;height:1.8rem;margin-top:.1rem;vertical-align:middle;border:0;background-color:transparent;background-position:-.3rem center;background-size:100% 100%;background-repeat:no-repeat}.select-checkbox span:hover{background-image:url('data:image/svg+xml,<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">%0A<rect x=\"3.5\" y=\"3.5\" width=\"11\" height=\"11\" fill=\"%23F5F5F5\" stroke=\"%238D8D8D\"/>%0A</svg>%0A')}\n"] }]
|
|
61
61
|
}], propDecorators: { enterKeyPressed: [{
|
|
62
62
|
type: Output
|
|
63
63
|
}] } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmltcGx1cy1pbnB1dC1jaGVja2JveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtYmltcGx1cy1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9iaW1wbHVzLWlucHV0LWNoZWNrYm94L2JpbXBsdXMtaW5wdXQtY2hlY2tib3guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWJpbXBsdXMtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvYmltcGx1cy1pbnB1dC1jaGVja2JveC9iaW1wbHVzLWlucHV0LWNoZWNrYm94LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1AsWUFBWSxFQUNaLFVBQVUsRUFDVixNQUFNLEVBQ04saUJBQWlCLEVBQ3BCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFFSCxpQkFBaUIsRUFDakIsbUJBQW1CLEVBQ3RCLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQW9CdEQsTUFBTSxPQUFPLDZCQUE2QjtJQWxCMUM7UUFtQlksb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRXJELFVBQUssR0FBWSxLQUFLLENBQUM7UUFDdkIsZUFBVSxHQUFZLEtBQUssQ0FBQztRQUU1Qiw2REFBNkQ7UUFDN0QsYUFBUSxHQUFHLENBQUMsS0FBYyxFQUFFLEVBQUU7UUFDOUIsQ0FBQyxDQUFDO1FBQ0YsY0FBUyxHQUFHLEdBQUcsRUFBRTtRQUNqQixDQUFDLENBQUM7S0ErQkg7SUE3QkMseUNBQXlDO0lBQ3pDLGdCQUFnQixDQUFDLEtBQVk7UUFDM0IsTUFBTSxPQUFPLEdBQUksS0FBSyxDQUFDLE1BQTJCLENBQUMsT0FBTyxDQUFDO1FBQzNELElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQywwQ0FBMEM7UUFDbEUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsOEJBQThCO0lBQ2xELENBQUM7SUFFRCxVQUFVLENBQUMsS0FBYztRQUN2QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsRUFBNEI7UUFDM0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQWM7UUFDOUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELGdCQUFnQixDQUFDLFVBQW1CO1FBQ2xDLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQy9CLENBQUM7SUFFRCxvQkFBb0I7UUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7K0dBeENVLDZCQUE2QjttR0FBN0IsNkJBQTZCLDBIQVI3QjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsNkJBQTZCLENBQUM7Z0JBQzVELEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRiwwQkM5QkgsaVNBY0EsMDNFRElJLG1CQUFtQiw4QkFDbkIsZUFBZTs7NEZBYU4sNkJBQTZCO2tCQWxCekMsU0FBUzsrQkFDRSw0QkFBNEIsY0FDMUIsSUFBSSxXQUNQO3dCQUNQLG1CQUFtQjt3QkFDbkIsZUFBZTtxQkFDaEIsaUJBR2MsaUJBQWlCLENBQUMsU0FBUyxhQUMvQjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw4QkFBOEIsQ0FBQzs0QkFDNUQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7OEJBR1MsZUFBZTtzQkFBeEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudFxuICAsIEV2ZW50RW1pdHRlclxuICAsIGZvcndhcmRSZWZcbiAgLCBPdXRwdXRcbiAgLCBWaWV3RW5jYXBzdWxhdGlvblxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIENvbnRyb2xWYWx1ZUFjY2Vzc29yXG4gICwgTkdfVkFMVUVfQUNDRVNTT1JcbiAgLCBSZWFjdGl2ZUZvcm1zTW9kdWxlXG59IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSBcIkBuZ3gtdHJhbnNsYXRlL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWJpbXBsdXMtaW5wdXQtY2hlY2tib3gnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGVcbiAgXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2JpbXBsdXMtaW5wdXQtY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYmltcGx1cy1pbnB1dC1jaGVja2JveC5jb21wb25lbnQubGVzcycsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLlNoYWRvd0RvbSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBCaW1wbHVzSW5wdXRDaGVja2JveENvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBCaW1wbHVzSW5wdXRDaGVja2JveENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgQE91dHB1dCgpIGVudGVyS2V5UHJlc3NlZCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICB2YWx1ZTogYm9vbGVhbiA9IGZhbHNlO1xuICBpc0Rpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICBvbkNoYW5nZSA9ICh2YWx1ZTogYm9vbGVhbikgPT4ge1xuICB9O1xuICBvblRvdWNoZWQgPSAoKSA9PiB7XG4gIH07XG5cbiAgLy8gQ2FsbGVkIHdoZW4gdGhlIGNoZWNrYm94IHZhbHVlIGNoYW5nZXNcbiAgb25DaGVja2JveENoYW5nZShldmVudDogRXZlbnQpIHtcbiAgICBjb25zdCBjaGVja2VkID0gKGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS5jaGVja2VkO1xuICAgIHRoaXMudmFsdWUgPSBjaGVja2VkO1xuICAgIHRoaXMub25DaGFuZ2UoY2hlY2tlZCk7IC8vIE5vdGlmeSB0aGUgcGFyZW50IGZvcm0gYWJvdXQgdGhlIGNoYW5nZVxuICAgIHRoaXMub25Ub3VjaGVkKCk7IC8vIE1hcmsgdGhlIGNvbnRyb2wgYXMgdG91Y2hlZFxuICB9XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgfVxuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46ICh2YWx1ZTogYm9vbGVhbikgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiAoKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcbiAgfVxuXG4gIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuaXNEaXNhYmxlZCA9IGlzRGlzYWJsZWQ7XG4gIH1cblxuICB0b2dnbGVBdHRyaWJ1dGVWYWx1ZSgpIHtcbiAgICB0aGlzLnZhbHVlID0gIXRoaXMudmFsdWU7XG4gICAgdGhpcy5vbkNoYW5nZSh0aGlzLnZhbHVlKTtcbiAgICB0aGlzLm9uVG91Y2hlZCgpO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwic2VsZWN0LWNoZWNrYm94XCJcbj5cbiAgPGRpdj5cbiAgICA8aW5wdXRcbiAgICAgIHR5cGU9XCJjaGVja2JveFwiXG4gICAgICBbY2hlY2tlZF09XCJ2YWx1ZVwiXG4gICAgICAoY2hhbmdlKT1cIm9uQ2hlY2tib3hDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAoY2xpY2spPVwidG9nZ2xlQXR0cmlidXRlVmFsdWUoKVwiXG4gICAgICAoa2V5cHJlc3MpPVwidG9nZ2xlQXR0cmlidXRlVmFsdWUoKVwiXG4gICAgPlxuICAgIDxzcGFuPjwvc3Bhbj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -158,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
158
158
|
}], selectedValue: [{
|
|
159
159
|
type: Input
|
|
160
160
|
}] } });
|
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-input-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-combobox/bimplus-input-combobox.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-combobox/bimplus-input-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, Output, ViewEncapsulation, signal, booleanAttribute, ViewChild, ElementRef, OnInit } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule } from \"@angular/forms\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { BehaviorSubject } from 'rxjs';\nimport { CommonModule} from '@angular/common';\n\ninterface EnumDefinition {\n  id: string;\n  name: string;\n};\n\n@Component({\n  selector: 'lib-bimplus-input-combobox',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    TranslateModule\n  ],\n  templateUrl: './bimplus-input-combobox.component.html',\n  styleUrl: './bimplus-input-combobox.component.less',\n  encapsulation: ViewEncapsulation.ShadowDom,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BimplusInputComboboxComponent),\n      multi: true,\n    },\n  ],\n})\n\nexport class BimplusInputComboboxComponent implements ControlValueAccessor, OnInit {\n  @ViewChild('inputValueBox', { static: false }) inputElement!: ElementRef;\n  @Input() placeholder: string = '';\n  @Output() enterKeyPressed = new EventEmitter<void>();\n\n  protected _validValue = signal<boolean>(true);\n  @Input({ transform: booleanAttribute }) set validValue(valid_value: boolean) {\n    this._validValue.set(valid_value);\n  }\n\n  private _type: string = 'enum';\n  protected _enumdefinition: Array<EnumDefinition> = [];\n  @Input() set enumdefinition(enum_definition: Record<number | string, string> | undefined | Array<string>) {\n    if(!enum_definition) {\n      return;\n    }\n    if(Array.isArray(enum_definition)) {\n      enum_definition.forEach((value, index) => {\n        this._enumdefinition.push({ id: index.toString(), name: value });\n      });\n      this._type = 'array';\n      return;\n    }\n    Object.keys(enum_definition).forEach((key) => {\n      if(typeof key === 'string') {\n        this._enumdefinition.push({ id: key, name: enum_definition[key] });\n      }\n      if(typeof key === 'number') {\n        this._enumdefinition.push({ id: key, name: enum_definition[Number(key)] });\n      }\n\n    });\n  }\n\n  private _setActiveEnumValue() {\n    const sel: EnumDefinition | undefined = this._enumdefinition.find((enumDef) => enumDef.id === this._selectedValue);\n    if(!sel){\n      return;\n    }\n    this.activeEnum = sel\n  }\n\n  _setActiveArrayValue() {\n    const sel: EnumDefinition | undefined = this._enumdefinition.find((enumDef) => enumDef.name === this._selectedValue);\n    if(!sel){\n      return;\n    }\n    this.activeEnum = sel\n  }\n\n  private _selectedValue: string | null = null;\n  @Input() set selectedValue(value: string | null) {\n    this._selectedValue = value;\n    if(this._type === 'enum') {\n      this._setActiveEnumValue();\n      return;\n    }\n    if(this._type === 'array') {\n      this._setActiveArrayValue();\n    }\n  }\n\n  ngOnInit() {\n    this.activeEnumSubject$.subscribe({\n      next: (value) => {\n        if(this._type === 'enum') {\n          this.value = value?.id ?? '';\n          this.onChange(this.value);\n        }\n        if(this._type === 'array') {\n            this.value = value?.name ?? '';\n            this.onChange(this.value);\n          }\n        }\n    });\n  }\n\n  set activeEnum(value : EnumDefinition | null){\n    this.activeEnumSubject$.next(value);\n  }\n\n  get activeEnum() : EnumDefinition | null {\n    return this.activeEnumSubject$.getValue();\n  }\n\n  activeEnumSubject$ = new BehaviorSubject<EnumDefinition | null> (null);\n\n  \n  value: string = '';\n  isDisabled: boolean = false;\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (value: string) => {\n  };\n  onTouched = () => {\n  };\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  handleInput(event: Event): void {\n    const input = event.target as HTMLInputElement;\n    this.value = input.value;\n    this.onChange(this.value);\n  }\n\n  handleBlur(): void {\n    this.onTouched();\n  }\n\n  protected handleKeyDown(event: KeyboardEvent): void {\n    if (event.key !== 'Enter') {\n      return;\n    }\n    this.enterKeyPressed.emit();\n  }\n}\n","<div\n  class=\"enum-wrapper\"\n  [class.invalid-value]=\"!_validValue()\"\n>\n  <div class=\"double-enumeration\">\n    <ng-select class=\"enum-dropdown\" [(ngModel)]=\"activeEnum\" [clearable]=\"false\" [searchable]=\"_enumdefinition.length >= 10\">\n      <ng-option *ngFor=\"let val of _enumdefinition\" [value]=\"val\">{{val.name}}</ng-option>\n    </ng-select>\n  </div>\n</div>\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-input-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-combobox/bimplus-input-combobox.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-combobox/bimplus-input-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component\n  , EventEmitter\n  , forwardRef\n  , Input\n  , Output\n  , ViewEncapsulation\n  , signal\n  , booleanAttribute\n  , ViewChild\n  , ElementRef\n  , OnInit\n} from '@angular/core';\nimport { ControlValueAccessor\n  , NG_VALUE_ACCESSOR\n  , ReactiveFormsModule\n  , FormsModule\n} from \"@angular/forms\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { BehaviorSubject } from 'rxjs';\nimport { CommonModule} from '@angular/common';\n\ninterface EnumDefinition {\n  id: string;\n  name: string;\n};\n\n@Component({\n  selector: 'lib-bimplus-input-combobox',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    TranslateModule\n  ],\n  templateUrl: './bimplus-input-combobox.component.html',\n  styleUrl: './bimplus-input-combobox.component.less',\n  encapsulation: ViewEncapsulation.ShadowDom,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BimplusInputComboboxComponent),\n      multi: true,\n    },\n  ],\n})\n\nexport class BimplusInputComboboxComponent implements ControlValueAccessor, OnInit {\n  @ViewChild('inputValueBox', { static: false }) inputElement!: ElementRef;\n  @Input() placeholder: string = '';\n  @Output() enterKeyPressed = new EventEmitter<void>();\n\n  protected _validValue = signal<boolean>(true);\n  @Input({ transform: booleanAttribute }) set validValue(valid_value: boolean) {\n    this._validValue.set(valid_value);\n  }\n\n  private _type: string = 'enum';\n  protected _enumdefinition: Array<EnumDefinition> = [];\n  @Input() set enumdefinition(enum_definition: Record<number | string, string> | undefined | Array<string>) {\n    if(!enum_definition) {\n      return;\n    }\n    if(Array.isArray(enum_definition)) {\n      enum_definition.forEach((value, index) => {\n        this._enumdefinition.push({ id: index.toString(), name: value });\n      });\n      this._type = 'array';\n      return;\n    }\n    Object.keys(enum_definition).forEach((key) => {\n      if(typeof key === 'string') {\n        this._enumdefinition.push({ id: key, name: enum_definition[key] });\n      }\n      if(typeof key === 'number') {\n        this._enumdefinition.push({ id: key, name: enum_definition[Number(key)] });\n      }\n\n    });\n  }\n\n  private _setActiveEnumValue() {\n    const sel: EnumDefinition | undefined = this._enumdefinition.find((enumDef) => enumDef.id === this._selectedValue);\n    if(!sel){\n      return;\n    }\n    this.activeEnum = sel\n  }\n\n  _setActiveArrayValue() {\n    const sel: EnumDefinition | undefined = this._enumdefinition.find((enumDef) => enumDef.name === this._selectedValue);\n    if(!sel){\n      return;\n    }\n    this.activeEnum = sel\n  }\n\n  private _selectedValue: string | null = null;\n  @Input() set selectedValue(value: string | null) {\n    this._selectedValue = value;\n    if(this._type === 'enum') {\n      this._setActiveEnumValue();\n      return;\n    }\n    if(this._type === 'array') {\n      this._setActiveArrayValue();\n    }\n  }\n\n  ngOnInit() {\n    this.activeEnumSubject$.subscribe({\n      next: (value) => {\n        if(this._type === 'enum') {\n          this.value = value?.id ?? '';\n          this.onChange(this.value);\n        }\n        if(this._type === 'array') {\n            this.value = value?.name ?? '';\n            this.onChange(this.value);\n          }\n        }\n    });\n  }\n\n  set activeEnum(value : EnumDefinition | null){\n    this.activeEnumSubject$.next(value);\n  }\n\n  get activeEnum() : EnumDefinition | null {\n    return this.activeEnumSubject$.getValue();\n  }\n\n  activeEnumSubject$ = new BehaviorSubject<EnumDefinition | null> (null);\n\n  \n  value: string = '';\n  isDisabled: boolean = false;\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (value: string) => {\n  };\n  onTouched = () => {\n  };\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  handleInput(event: Event): void {\n    const input = event.target as HTMLInputElement;\n    this.value = input.value;\n    this.onChange(this.value);\n  }\n\n  handleBlur(): void {\n    this.onTouched();\n  }\n\n  protected handleKeyDown(event: KeyboardEvent): void {\n    if (event.key !== 'Enter') {\n      return;\n    }\n    this.enterKeyPressed.emit();\n  }\n}\n","<div\n  class=\"enum-wrapper\"\n  [class.invalid-value]=\"!_validValue()\"\n>\n  <div class=\"double-enumeration\">\n    <ng-select class=\"enum-dropdown\" [(ngModel)]=\"activeEnum\" [clearable]=\"false\" [searchable]=\"_enumdefinition.length >= 10\">\n      <ng-option *ngFor=\"let val of _enumdefinition\" [value]=\"val\">{{val.name}}</ng-option>\n    </ng-select>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,271 @@
|
|
|
1
|
+
import { Component, forwardRef, Input, Output, booleanAttribute, signal, EventEmitter, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule } from "@angular/forms";
|
|
3
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { GetAttributeValueAsString } from '../../pipes/get-attribute-value-as-string.pipe';
|
|
6
|
+
import { MatNativeDateModule, DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
|
|
7
|
+
import { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from '@angular/material-moment-adapter';
|
|
8
|
+
import { MomentDateModule } from '@angular/material-moment-adapter';
|
|
9
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/forms";
|
|
12
|
+
import * as i2 from "@angular/material/datepicker";
|
|
13
|
+
export const MY_DATE_FORMATS = {
|
|
14
|
+
parse: {
|
|
15
|
+
dateInput: 'L',
|
|
16
|
+
},
|
|
17
|
+
display: {
|
|
18
|
+
dateInput: 'L',
|
|
19
|
+
monthYearLabel: 'MMM YYYY',
|
|
20
|
+
dateA11yLabel: 'L',
|
|
21
|
+
monthYearA11yLabel: 'MMM YYYY',
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export class BimplusInputDateComponent {
|
|
25
|
+
set showClearButton(show_clear_button) {
|
|
26
|
+
this._showClearButton.set(show_clear_button);
|
|
27
|
+
}
|
|
28
|
+
set validValue(valid_value) {
|
|
29
|
+
this._validValue.set(valid_value);
|
|
30
|
+
}
|
|
31
|
+
constructor() {
|
|
32
|
+
this.value = '';
|
|
33
|
+
this.dateValue = new Date();
|
|
34
|
+
this.isDisabled = false;
|
|
35
|
+
this.enterKeyPressed = new EventEmitter();
|
|
36
|
+
this._showClearButton = signal(false);
|
|
37
|
+
this._validValue = signal(true);
|
|
38
|
+
this.minValue = '';
|
|
39
|
+
this.maxValue = '';
|
|
40
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
41
|
+
this.onChange = (value) => {
|
|
42
|
+
};
|
|
43
|
+
this.onTouched = () => {
|
|
44
|
+
};
|
|
45
|
+
this.STYLE_ID = 'datepicker-styles';
|
|
46
|
+
}
|
|
47
|
+
writeValue(value) {
|
|
48
|
+
this.value = value;
|
|
49
|
+
this.dateValue = new Date(value);
|
|
50
|
+
}
|
|
51
|
+
registerOnChange(fn) {
|
|
52
|
+
this.onChange = fn;
|
|
53
|
+
}
|
|
54
|
+
registerOnTouched(fn) {
|
|
55
|
+
this.onTouched = fn;
|
|
56
|
+
}
|
|
57
|
+
setDisabledState(isDisabled) {
|
|
58
|
+
this.isDisabled = isDisabled;
|
|
59
|
+
}
|
|
60
|
+
injectGlobalStyles() {
|
|
61
|
+
// Check if the style tag already exists
|
|
62
|
+
if (document.getElementById(this.STYLE_ID)) {
|
|
63
|
+
return; // Style already injected, skip
|
|
64
|
+
}
|
|
65
|
+
// Create the style tag
|
|
66
|
+
const styleElement = document.createElement('style');
|
|
67
|
+
styleElement.id = this.STYLE_ID;
|
|
68
|
+
styleElement.textContent = `
|
|
69
|
+
mat-datepicker-content mat-calendar.bimplus-datepicker {
|
|
70
|
+
background-color: var(--brand-white-color);
|
|
71
|
+
border-color: var(--issue-details-view-select-border-color);
|
|
72
|
+
border: .1rem solid;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
mat-calendar.bimplus-datepicker .mat-mdc-button {
|
|
76
|
+
font-size: 1.6rem;
|
|
77
|
+
font-weight: 700;
|
|
78
|
+
}
|
|
79
|
+
mat-calendar.bimplus-datepicker .mat-mdc-button:hover {
|
|
80
|
+
border-radius: 0;
|
|
81
|
+
}
|
|
82
|
+
mat-calendar.bimplus-datepicker mat-calendar-header .mat-calendar-controls {
|
|
83
|
+
margin: 0;
|
|
84
|
+
}
|
|
85
|
+
mat-calendar.bimplus-datepicker mat-calendar-header .mat-calendar-header {
|
|
86
|
+
background-color: rgb(236, 239, 241);
|
|
87
|
+
padding: 0;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content {
|
|
91
|
+
padding: 0;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header{
|
|
95
|
+
height: 2rem;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header tr{
|
|
99
|
+
height: 2rem;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header tr th{
|
|
103
|
+
height: 2rem;
|
|
104
|
+
padding: 0;
|
|
105
|
+
font-size: 1.3rem;
|
|
106
|
+
font-weight: 700;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button{
|
|
110
|
+
font-size: 1.3rem;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-selected {
|
|
114
|
+
border-radius: 0;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-today {
|
|
118
|
+
border-radius: 0;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {
|
|
122
|
+
border-radius: 0;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td.mat-calendar-body-label {
|
|
126
|
+
font-size: 1.3rem;
|
|
127
|
+
font-weight: 700;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button{
|
|
131
|
+
font-size: 1.3rem;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button .mat-calendar-body-selected {
|
|
135
|
+
border-radius: 0;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {
|
|
139
|
+
border-radius: 0;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button{
|
|
143
|
+
font-size: 1.3rem;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button .mat-calendar-body-selected {
|
|
147
|
+
border-radius: 0;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {
|
|
151
|
+
border-radius: 0;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td.mat-calendar-body-label {
|
|
155
|
+
font-size: 1.3rem;
|
|
156
|
+
font-weight: 700;
|
|
157
|
+
}
|
|
158
|
+
`;
|
|
159
|
+
// Append the style tag to document.head
|
|
160
|
+
document.head.appendChild(styleElement);
|
|
161
|
+
}
|
|
162
|
+
ngOnInit() {
|
|
163
|
+
this.injectGlobalStyles();
|
|
164
|
+
console.log('BimplusInputDateComponent ngOnInit');
|
|
165
|
+
}
|
|
166
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
167
|
+
_clearValue(event) {
|
|
168
|
+
this.value = "";
|
|
169
|
+
this.dateValue = null;
|
|
170
|
+
this.onChange(this.value);
|
|
171
|
+
}
|
|
172
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
173
|
+
_showDatePicker(event) {
|
|
174
|
+
console.log('BimplusInputDateComponent _showDatePicker');
|
|
175
|
+
}
|
|
176
|
+
handleKeyDown(event) {
|
|
177
|
+
if (event.key !== 'Enter') {
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
this.enterKeyPressed.emit();
|
|
181
|
+
}
|
|
182
|
+
onDateChanged(event) {
|
|
183
|
+
const selectedDate = event.value;
|
|
184
|
+
if (selectedDate) {
|
|
185
|
+
this.value = selectedDate.toISOString();
|
|
186
|
+
this.onChange(this.value);
|
|
187
|
+
console.log('Selected Date (UTC):', selectedDate);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusInputDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
191
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.12", type: BimplusInputDateComponent, isStandalone: true, selector: "lib-bimplus-input-date", inputs: { showClearButton: ["showClearButton", "showClearButton", booleanAttribute], validValue: ["validValue", "validValue", booleanAttribute], minValue: "minValue", maxValue: "maxValue" }, outputs: { enterKeyPressed: "enterKeyPressed" }, providers: [
|
|
192
|
+
{
|
|
193
|
+
provide: NG_VALUE_ACCESSOR,
|
|
194
|
+
useExisting: forwardRef(() => BimplusInputDateComponent),
|
|
195
|
+
multi: true,
|
|
196
|
+
},
|
|
197
|
+
{
|
|
198
|
+
provide: DateAdapter,
|
|
199
|
+
useClass: MomentDateAdapter,
|
|
200
|
+
deps: [MAT_DATE_LOCALE, MAT_DATE_FORMATS, MAT_MOMENT_DATE_ADAPTER_OPTIONS]
|
|
201
|
+
},
|
|
202
|
+
{
|
|
203
|
+
provide: MAT_DATE_FORMATS,
|
|
204
|
+
useValue: MY_DATE_FORMATS
|
|
205
|
+
},
|
|
206
|
+
{
|
|
207
|
+
provide: MAT_DATE_LOCALE,
|
|
208
|
+
useValue: navigator.language
|
|
209
|
+
}, // Set the locale here!
|
|
210
|
+
{
|
|
211
|
+
provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS,
|
|
212
|
+
useValue: {
|
|
213
|
+
useUtc: false
|
|
214
|
+
}
|
|
215
|
+
},
|
|
216
|
+
], viewQueries: [{ propertyName: "inputDateBox", first: true, predicate: ["inputDateBox"], descendants: true }], ngImport: i0, template: "<div class=\"date-input-wrapper\">\n <mat-datepicker-toggle matIconPostfix [for]=\"picker\" [disableRipple]=\"true\"></mat-datepicker-toggle>\n <input matInput [matDatepicker]=\"picker\" readonly [(ngModel)]=\"dateValue\" #inputDateBox (dateChange)=\"onDateChanged($event)\" (click)=\"picker.open()\">\n <mat-datepicker #picker [panelClass]=\"'bimplus-datepicker'\"></mat-datepicker>\n <div\n class=\"clear-button\"\n (click)=\"_clearValue($event)\"\n (keydown)=\"handleKeyDown($event)\"\n ></div>\n</div>", styles: [":host{display:flex;flex-direction:row;--mdc-icon-button-icon-size: 1.6rem;--mdc-icon-button-state-layer-size: 1.9rem;--mat-datepicker-toggle-icon-color: gray}.date-input-wrapper{cursor:pointer;flex:1;border:.1rem solid;border-color:var(--issue-details-view-select-border-color);background-color:var(--issue-details-view-select-background-color);display:flex;flex-direction:row;width:100%;box-sizing:border-box;line-height:1.9rem;min-height:1.9rem}.date-input-wrapper input{background-color:transparent;border:none;flex-grow:1;flex-shrink:1;min-width:0;outline:none;font-size:1.2rem;font-family:Source Sans Pro,Helvetica,Arial,tahoma,sans-serif}.date-input-wrapper mat-datepicker-toggle{flex-grow:0;flex-shrink:0;line-height:1.9rem;height:1.9rem}.date-input-wrapper .clear-button{line-height:1.9rem;min-height:1.9rem;max-height:1.9rem;min-width:1.9rem;max-width:1.9rem;flex-grow:0;flex-shrink:0;background-image:url('data:image/svg+xml,<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0\" y=\"0\" width=\"18\" height=\"18\" xml:space=\"preserve\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" fill=\"%23d3d3d3\" d=\"M13.5 5.4L12.1 4 8.5 7.6 4.9 4 3.5 5.4 7.1 9l-3.6 3.6L4.9 14l3.6-3.6 3.6 3.6 1.4-1.4L9.9 9z\"/></svg>%0A');background-repeat:no-repeat;background-position:center;background-size:1.4rem 1.4rem;cursor:pointer}.date-input-wrapper .clear-button:hover{background-image:url('data:image/svg+xml,<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0\" y=\"0\" width=\"18\" height=\"18\" xml:space=\"preserve\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" fill=\"%23444\" d=\"M13.5 5.4L12.1 4 8.5 7.6 4.9 4 3.5 5.4 7.1 9l-3.6 3.6L4.9 14l3.6-3.6 3.6 3.6 1.4-1.4L9.9 9z\"/></svg>%0A')}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) input{background-color:var(--brand-light-color)}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) mat-datepicker-toggle{color:var(--primary-button-border-color-enabled);background-color:var(--brand-light-color)}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) .clear-button{background-color:var(--brand-light-color)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i2.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: MatNativeDateModule }], encapsulation: i0.ViewEncapsulation.ShadowDom }); }
|
|
217
|
+
}
|
|
218
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusInputDateComponent, decorators: [{
|
|
219
|
+
type: Component,
|
|
220
|
+
args: [{ selector: 'lib-bimplus-input-date', standalone: true, imports: [
|
|
221
|
+
CommonModule,
|
|
222
|
+
FormsModule,
|
|
223
|
+
ReactiveFormsModule,
|
|
224
|
+
TranslateModule,
|
|
225
|
+
GetAttributeValueAsString,
|
|
226
|
+
MatDatepickerModule,
|
|
227
|
+
MomentDateModule,
|
|
228
|
+
MatNativeDateModule
|
|
229
|
+
], providers: [
|
|
230
|
+
{
|
|
231
|
+
provide: NG_VALUE_ACCESSOR,
|
|
232
|
+
useExisting: forwardRef(() => BimplusInputDateComponent),
|
|
233
|
+
multi: true,
|
|
234
|
+
},
|
|
235
|
+
{
|
|
236
|
+
provide: DateAdapter,
|
|
237
|
+
useClass: MomentDateAdapter,
|
|
238
|
+
deps: [MAT_DATE_LOCALE, MAT_DATE_FORMATS, MAT_MOMENT_DATE_ADAPTER_OPTIONS]
|
|
239
|
+
},
|
|
240
|
+
{
|
|
241
|
+
provide: MAT_DATE_FORMATS,
|
|
242
|
+
useValue: MY_DATE_FORMATS
|
|
243
|
+
},
|
|
244
|
+
{
|
|
245
|
+
provide: MAT_DATE_LOCALE,
|
|
246
|
+
useValue: navigator.language
|
|
247
|
+
}, // Set the locale here!
|
|
248
|
+
{
|
|
249
|
+
provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS,
|
|
250
|
+
useValue: {
|
|
251
|
+
useUtc: false
|
|
252
|
+
}
|
|
253
|
+
},
|
|
254
|
+
], encapsulation: ViewEncapsulation.ShadowDom, template: "<div class=\"date-input-wrapper\">\n <mat-datepicker-toggle matIconPostfix [for]=\"picker\" [disableRipple]=\"true\"></mat-datepicker-toggle>\n <input matInput [matDatepicker]=\"picker\" readonly [(ngModel)]=\"dateValue\" #inputDateBox (dateChange)=\"onDateChanged($event)\" (click)=\"picker.open()\">\n <mat-datepicker #picker [panelClass]=\"'bimplus-datepicker'\"></mat-datepicker>\n <div\n class=\"clear-button\"\n (click)=\"_clearValue($event)\"\n (keydown)=\"handleKeyDown($event)\"\n ></div>\n</div>", styles: [":host{display:flex;flex-direction:row;--mdc-icon-button-icon-size: 1.6rem;--mdc-icon-button-state-layer-size: 1.9rem;--mat-datepicker-toggle-icon-color: gray}.date-input-wrapper{cursor:pointer;flex:1;border:.1rem solid;border-color:var(--issue-details-view-select-border-color);background-color:var(--issue-details-view-select-background-color);display:flex;flex-direction:row;width:100%;box-sizing:border-box;line-height:1.9rem;min-height:1.9rem}.date-input-wrapper input{background-color:transparent;border:none;flex-grow:1;flex-shrink:1;min-width:0;outline:none;font-size:1.2rem;font-family:Source Sans Pro,Helvetica,Arial,tahoma,sans-serif}.date-input-wrapper mat-datepicker-toggle{flex-grow:0;flex-shrink:0;line-height:1.9rem;height:1.9rem}.date-input-wrapper .clear-button{line-height:1.9rem;min-height:1.9rem;max-height:1.9rem;min-width:1.9rem;max-width:1.9rem;flex-grow:0;flex-shrink:0;background-image:url('data:image/svg+xml,<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0\" y=\"0\" width=\"18\" height=\"18\" xml:space=\"preserve\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" fill=\"%23d3d3d3\" d=\"M13.5 5.4L12.1 4 8.5 7.6 4.9 4 3.5 5.4 7.1 9l-3.6 3.6L4.9 14l3.6-3.6 3.6 3.6 1.4-1.4L9.9 9z\"/></svg>%0A');background-repeat:no-repeat;background-position:center;background-size:1.4rem 1.4rem;cursor:pointer}.date-input-wrapper .clear-button:hover{background-image:url('data:image/svg+xml,<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" x=\"0\" y=\"0\" width=\"18\" height=\"18\" xml:space=\"preserve\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" fill=\"%23444\" d=\"M13.5 5.4L12.1 4 8.5 7.6 4.9 4 3.5 5.4 7.1 9l-3.6 3.6L4.9 14l3.6-3.6 3.6 3.6 1.4-1.4L9.9 9z\"/></svg>%0A')}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) input{background-color:var(--brand-light-color)}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) mat-datepicker-toggle{color:var(--primary-button-border-color-enabled);background-color:var(--brand-light-color)}.date-input-wrapper:has(mat-datepicker-toggle.mat-datepicker-toggle-active) .clear-button{background-color:var(--brand-light-color)}\n"] }]
|
|
255
|
+
}], ctorParameters: () => [], propDecorators: { inputDateBox: [{
|
|
256
|
+
type: ViewChild,
|
|
257
|
+
args: ['inputDateBox', { static: false }]
|
|
258
|
+
}], enterKeyPressed: [{
|
|
259
|
+
type: Output
|
|
260
|
+
}], showClearButton: [{
|
|
261
|
+
type: Input,
|
|
262
|
+
args: [{ transform: booleanAttribute }]
|
|
263
|
+
}], validValue: [{
|
|
264
|
+
type: Input,
|
|
265
|
+
args: [{ transform: booleanAttribute }]
|
|
266
|
+
}], minValue: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], maxValue: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}] } });
|
|
271
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-input-date.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-date/bimplus-input-date.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-input-date/bimplus-input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component,\n  OnInit,\n  forwardRef,\n  Input,\n  Output,\n  booleanAttribute,\n  signal,\n  EventEmitter,\n  ViewChild,\n  ElementRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor\n  , NG_VALUE_ACCESSOR\n  , ReactiveFormsModule\n  , FormsModule\n} from \"@angular/forms\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { CommonModule} from '@angular/common';\nimport { GetAttributeValueAsString } from '../../pipes/get-attribute-value-as-string.pipe';\nimport { MatNativeDateModule, DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\nimport { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS } from '@angular/material-moment-adapter';\nimport { MomentDateModule } from '@angular/material-moment-adapter';\nimport { MatDatepickerModule, MatDatepickerInputEvent } from '@angular/material/datepicker';\n\nexport const MY_DATE_FORMATS = {\n  parse: {\n    dateInput: 'L', \n  },\n  display: {\n    dateInput: 'L', \n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'L',\n    monthYearA11yLabel: 'MMM YYYY',\n  }\n};\n\n@Component({\n  selector: 'lib-bimplus-input-date',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    GetAttributeValueAsString,\n    MatDatepickerModule,\n    MomentDateModule,\n    MatNativeDateModule\n  ],\n  templateUrl: './bimplus-input-date.component.html',\n  styleUrls: ['./bimplus-input-date.component.less'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BimplusInputDateComponent),\n      multi: true,\n    },\n    {\n      provide: DateAdapter,\n      useClass: MomentDateAdapter,\n      deps: [ MAT_DATE_LOCALE, MAT_DATE_FORMATS, MAT_MOMENT_DATE_ADAPTER_OPTIONS ]\n    },\n    {\n      provide: MAT_DATE_FORMATS\n      , useValue: MY_DATE_FORMATS\n    },\n    {\n      provide: MAT_DATE_LOCALE\n      , useValue: navigator.language\n    }, // Set the locale here!\n    {\n      provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS,\n      useValue: {\n        useUtc: false\n      }\n    },\n  ],\n  encapsulation: ViewEncapsulation.ShadowDom\n})\nexport class BimplusInputDateComponent  implements ControlValueAccessor, OnInit {\n  @ViewChild('inputDateBox', { static: false }) inputDateBox!: ElementRef;\n  \n  value: string = '';\n  dateValue: Date | null = new Date();\n  isDisabled: boolean = false;\n\n  @Output() enterKeyPressed = new EventEmitter<void>();\n\n  protected _showClearButton = signal<boolean>(false);\n  @Input({ transform: booleanAttribute }) set showClearButton(show_clear_button: boolean) {\n    this._showClearButton.set(show_clear_button);\n  }\n\n  protected _validValue = signal<boolean>(true);\n  @Input({ transform: booleanAttribute }) set validValue(valid_value: boolean) {\n    this._validValue.set(valid_value);\n  }\n\n  @Input() minValue: string = '';\n  @Input() maxValue: string = '';\n\n  constructor() { }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  onChange = (value: string) => {\n  };\n  onTouched = () => {\n  };\n\n  writeValue(value: string): void {\n    this.value = value;\n    this.dateValue = new Date(value);\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  private readonly STYLE_ID = 'datepicker-styles';\n  private injectGlobalStyles(): void {\n    // Check if the style tag already exists\n    if (document.getElementById(this.STYLE_ID)) {\n      return; // Style already injected, skip\n    }\n\n    // Create the style tag\n    const styleElement = document.createElement('style');\n    styleElement.id = this.STYLE_ID;\n\n    styleElement.textContent = `\n      mat-datepicker-content mat-calendar.bimplus-datepicker {\n          background-color: var(--brand-white-color);\n          border-color: var(--issue-details-view-select-border-color);\n          border: .1rem solid;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-mdc-button {\n          font-size: 1.6rem;\n          font-weight: 700;\n      }\n      mat-calendar.bimplus-datepicker .mat-mdc-button:hover {\n          border-radius: 0;\n      }\n      mat-calendar.bimplus-datepicker mat-calendar-header .mat-calendar-controls {\n          margin: 0;\n      }\n      mat-calendar.bimplus-datepicker mat-calendar-header .mat-calendar-header {\n          background-color: rgb(236, 239, 241);\n          padding: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content {\n          padding: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header{\n          height: 2rem;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header tr{\n          height: 2rem;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-table-header tr th{\n          height: 2rem;\n          padding: 0;\n          font-size: 1.3rem;\n          font-weight: 700;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button{\n          font-size: 1.3rem;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-selected {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-today {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-month-view .mat-calendar-body tr td.mat-calendar-body-label {\n          font-size: 1.3rem;\n          font-weight: 700;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button{\n          font-size: 1.3rem;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button .mat-calendar-body-selected {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-multi-year-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button{\n          font-size: 1.3rem;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button .mat-calendar-body-selected {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td button .mat-calendar-body-cell-content.mat-focus-indicator {\n          border-radius: 0;\n      }\n\n      mat-calendar.bimplus-datepicker .mat-calendar-content mat-year-view .mat-calendar-body tr td.mat-calendar-body-label {\n          font-size: 1.3rem;\n          font-weight: 700;\n      }\n    `;\n\n    // Append the style tag to document.head\n    document.head.appendChild(styleElement);\n  }\n  ngOnInit() {\n    this.injectGlobalStyles();\n    console.log('BimplusInputDateComponent ngOnInit'); \n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected _clearValue(event: Event): void {\n    this.value = \"\";\n    this.dateValue = null;\n    this.onChange(this.value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected _showDatePicker(event: Event): void {\n    console.log('BimplusInputDateComponent _showDatePicker');\n  }\n  \n  protected handleKeyDown(event: KeyboardEvent): void {\n    if (event.key !== 'Enter') {\n      return;\n    }\n    this.enterKeyPressed.emit();\n  }\n\n  onDateChanged(event: MatDatepickerInputEvent<Date>) {\n    const selectedDate = event.value;\n\n    if (selectedDate) {\n      this.value = selectedDate.toISOString();\n      this.onChange(this.value);\n      console.log('Selected Date (UTC):', selectedDate);\n    }\n  }\n}\n","<div class=\"date-input-wrapper\">\n    <mat-datepicker-toggle matIconPostfix [for]=\"picker\"  [disableRipple]=\"true\"></mat-datepicker-toggle>\n    <input matInput [matDatepicker]=\"picker\" readonly [(ngModel)]=\"dateValue\" #inputDateBox (dateChange)=\"onDateChanged($event)\" (click)=\"picker.open()\">\n    <mat-datepicker #picker [panelClass]=\"'bimplus-datepicker'\"></mat-datepicker>\n    <div\n      class=\"clear-button\"\n      (click)=\"_clearValue($event)\"\n      (keydown)=\"handleKeyDown($event)\"\n    ></div>\n</div>"]}
|
package/esm2022/lib/components/bimplus-input-text-field/bimplus-input-text-field.component.mjs
CHANGED
|
@@ -16,8 +16,8 @@ export class BimplusInputTextFieldComponent {
|
|
|
16
16
|
this.onTouched = () => {
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
|
-
set showClearButton(
|
|
20
|
-
this._showClearButton.set(
|
|
19
|
+
set showClearButton(show_clear_button) {
|
|
20
|
+
this._showClearButton.set(show_clear_button);
|
|
21
21
|
}
|
|
22
22
|
set validValue(valid_value) {
|
|
23
23
|
this._validValue.set(valid_value);
|
|
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
89
89
|
type: Input,
|
|
90
90
|
args: [{ transform: booleanAttribute }]
|
|
91
91
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmltcGx1cy1pbnB1dC10ZXh0LWZpZWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1iaW1wbHVzLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2JpbXBsdXMtaW5wdXQtdGV4dC1maWVsZC9iaW1wbHVzLWlucHV0LXRleHQtZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWJpbXBsdXMtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvYmltcGx1cy1pbnB1dC10ZXh0LWZpZWxkL2JpbXBsdXMtaW5wdXQtdGV4dC1maWVsZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDO0FBQ3ZKLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBb0J0RCxNQUFNLE9BQU8sOEJBQThCO0lBbEIzQztRQW9CVyxnQkFBVyxHQUFXLEVBQUUsQ0FBQztRQUN4QixvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFFM0MscUJBQWdCLEdBQUcsTUFBTSxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBSzFDLGdCQUFXLEdBQUcsTUFBTSxDQUFVLElBQUksQ0FBQyxDQUFDO1FBSzlDLFVBQUssR0FBVyxFQUFFLENBQUM7UUFDbkIsZUFBVSxHQUFZLEtBQUssQ0FBQztRQUU1Qiw2REFBNkQ7UUFDN0QsYUFBUSxHQUFHLENBQUMsS0FBYSxFQUFFLEVBQUU7UUFDN0IsQ0FBQyxDQUFDO1FBQ0YsY0FBUyxHQUFHLEdBQUcsRUFBRTtRQUNqQixDQUFDLENBQUM7S0F5Q0g7SUF6REMsSUFBNEMsZUFBZSxDQUFDLGlCQUEwQjtRQUNwRixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUdELElBQTRDLFVBQVUsQ0FBQyxXQUFvQjtRQUN6RSxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBV0QsVUFBVSxDQUFDLEtBQWE7UUFDdEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQTJCO1FBQzFDLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxFQUFjO1FBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxVQUFtQjtRQUNsQyxJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUMvQixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFDdEIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE1BQTBCLENBQUM7UUFDL0MsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDO1FBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCw2REFBNkQ7SUFDbkQsV0FBVyxDQUFDLEtBQVk7UUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7UUFDaEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDeEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVTLGFBQWEsQ0FBQyxLQUFvQjtRQUMxQyxJQUFJLEtBQUssQ0FBQyxHQUFHLEtBQUssT0FBTyxFQUFFLENBQUM7WUFDMUIsT0FBTztRQUNULENBQUM7UUFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7K0dBOURVLDhCQUE4QjttR0FBOUIsOEJBQThCLDhKQU1yQixnQkFBZ0IsNENBS2hCLGdCQUFnQixpRUFuQnpCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyw4QkFBOEIsQ0FBQztnQkFDN0QsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLHlJQ3BCSCx1bEJBeUJBLHUrRERqQkksbUJBQW1CLDhCQUNuQixlQUFlOzs0RkFhTiw4QkFBOEI7a0JBbEIxQyxTQUFTOytCQUNFLDhCQUE4QixjQUM1QixJQUFJLFdBQ1A7d0JBQ1AsbUJBQW1CO3dCQUNuQixlQUFlO3FCQUNoQixpQkFHYyxpQkFBaUIsQ0FBQyxTQUFTLGFBQy9CO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLCtCQUErQixDQUFDOzRCQUM3RCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjs4QkFHOEMsWUFBWTtzQkFBMUQsU0FBUzt1QkFBQyxlQUFlLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO2dCQUNwQyxXQUFXO3NCQUFuQixLQUFLO2dCQUNJLGVBQWU7c0JBQXhCLE1BQU07Z0JBR3FDLGVBQWU7c0JBQTFELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBS00sVUFBVTtzQkFBckQsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBmb3J3YXJkUmVmLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbiwgc2lnbmFsLCBib29sZWFuQXR0cmlidXRlLCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSBcIkBuZ3gtdHJhbnNsYXRlL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWJpbXBsdXMtaW5wdXQtdGV4dC1maWVsZCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIFRyYW5zbGF0ZU1vZHVsZVxuICBdLFxuICB0ZW1wbGF0ZVVybDogJy4vYmltcGx1cy1pbnB1dC10ZXh0LWZpZWxkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2JpbXBsdXMtaW5wdXQtdGV4dC1maWVsZC5jb21wb25lbnQubGVzcycsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLlNoYWRvd0RvbSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBCaW1wbHVzSW5wdXRUZXh0RmllbGRDb21wb25lbnQpLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQmltcGx1c0lucHV0VGV4dEZpZWxkQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICBAVmlld0NoaWxkKCdpbnB1dFZhbHVlQm94JywgeyBzdGF0aWM6IGZhbHNlIH0pIGlucHV0RWxlbWVudCE6IEVsZW1lbnRSZWY7XG4gIEBJbnB1dCgpIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSAnJztcbiAgQE91dHB1dCgpIGVudGVyS2V5UHJlc3NlZCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBwcm90ZWN0ZWQgX3Nob3dDbGVhckJ1dHRvbiA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XG4gIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBzZXQgc2hvd0NsZWFyQnV0dG9uKHNob3dfY2xlYXJfYnV0dG9uOiBib29sZWFuKSB7XG4gICAgdGhpcy5fc2hvd0NsZWFyQnV0dG9uLnNldChzaG93X2NsZWFyX2J1dHRvbik7XG4gIH1cblxuICBwcm90ZWN0ZWQgX3ZhbGlkVmFsdWUgPSBzaWduYWw8Ym9vbGVhbj4odHJ1ZSk7XG4gIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBzZXQgdmFsaWRWYWx1ZSh2YWxpZF92YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMuX3ZhbGlkVmFsdWUuc2V0KHZhbGlkX3ZhbHVlKTtcbiAgfVxuXG4gIHZhbHVlOiBzdHJpbmcgPSAnJztcbiAgaXNEaXNhYmxlZDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgb25DaGFuZ2UgPSAodmFsdWU6IHN0cmluZykgPT4ge1xuICB9O1xuICBvblRvdWNoZWQgPSAoKSA9PiB7XG4gIH07XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xuICB9XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogKHZhbHVlOiBzdHJpbmcpID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogKCkgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaGVkID0gZm47XG4gIH1cblxuICBzZXREaXNhYmxlZFN0YXRlKGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmlzRGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICB9XG5cbiAgaGFuZGxlSW5wdXQoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgY29uc3QgaW5wdXQgPSBldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudDtcbiAgICB0aGlzLnZhbHVlID0gaW5wdXQudmFsdWU7XG4gICAgdGhpcy5vbkNoYW5nZSh0aGlzLnZhbHVlKTtcbiAgfVxuXG4gIGhhbmRsZUJsdXIoKTogdm9pZCB7XG4gICAgdGhpcy5vblRvdWNoZWQoKTtcbiAgfVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgcHJvdGVjdGVkIF9jbGVhclZhbHVlKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSBcIlwiO1xuICAgIHRoaXMuaW5wdXRFbGVtZW50Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICB0aGlzLm9uQ2hhbmdlKHRoaXMudmFsdWUpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZUtleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcbiAgICBpZiAoZXZlbnQua2V5ICE9PSAnRW50ZXInKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuZW50ZXJLZXlQcmVzc2VkLmVtaXQoKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInRleHQtaW5wdXQtd3JhcHBlclwiXG4gIFtjbGFzcy5pbnZhbGlkLXZhbHVlXT1cIiFfdmFsaWRWYWx1ZSgpXCJcbiAgW2NsYXNzLndpdGgtY2xlYXItYnV0dG9uXT1cIl9zaG93Q2xlYXJCdXR0b24oKVwiXG4+XG4gIDxpbnB1dFxuICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICBbdmFsdWVdPVwidmFsdWVcIlxuICAgIChpbnB1dCk9XCJoYW5kbGVJbnB1dCgkZXZlbnQpXCJcbiAgICAoYmx1cik9XCJoYW5kbGVCbHVyKClcIlxuICAgIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIChrZXlkb3duKT1cImhhbmRsZUtleURvd24oJGV2ZW50KVwiXG4gICAgY2xhc3M9XCJ0ZXh0LWlucHV0XCJcbiAgICAjaW5wdXRWYWx1ZUJveFxuICAvPlxuICBAaWYoX3Nob3dDbGVhckJ1dHRvbigpKSB7XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJjbGVhci1idXR0b25cIlxuICAgICAgKGNsaWNrKT1cIl9jbGVhclZhbHVlKCRldmVudClcIlxuICAgICAgKGtleWRvd24pPVwiaGFuZGxlS2V5RG93bigkZXZlbnQpXCJcbiAgICA+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
|