master-control 0.1.6 → 0.1.8
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/add-document/add-document.component.mjs +18 -0
- package/esm2022/lib/addition-button/addition-button.component.mjs +14 -0
- package/esm2022/lib/age-date/age-date.component.mjs +82 -0
- package/esm2022/lib/amount-textbox/amount-textbox.component.mjs +24 -0
- package/esm2022/lib/autocomplete/autocomplete.component.mjs +47 -0
- package/esm2022/lib/button/button.component.mjs +14 -0
- package/esm2022/lib/checkbox/checkbox.component.mjs +46 -3
- package/esm2022/lib/dob/dob.component.mjs +69 -25
- package/esm2022/lib/download-document/download-document.component.mjs +18 -0
- package/esm2022/lib/email-with-domain/email-with-domain.component.mjs +22 -0
- package/esm2022/lib/hyperlink/hyperlink.component.mjs +14 -0
- package/esm2022/lib/icon-button/icon-button.component.mjs +14 -0
- package/esm2022/lib/image-upload/image-upload.component.mjs +18 -0
- package/esm2022/lib/info/info.component.mjs +3 -3
- package/esm2022/lib/info-textbox/info-textbox.component.mjs +24 -0
- package/esm2022/lib/master-control.component.mjs +56 -6
- package/esm2022/lib/master-control.service.mjs +11 -1
- package/esm2022/lib/mob-number/mob-number.component.mjs +40 -3
- package/esm2022/lib/multiple-select/multiple-select.component.mjs +50 -0
- package/esm2022/lib/otp-mob-number/otp-mob-number.component.mjs +25 -0
- package/esm2022/lib/otp-textbox/otp-textbox.component.mjs +29 -0
- package/esm2022/lib/radio/radio.component.mjs +38 -4
- package/esm2022/lib/select/select.component.mjs +43 -5
- package/esm2022/lib/select-textbox/select-textbox.component.mjs +22 -0
- package/esm2022/lib/suffix-textbox/suffix-textbox.component.mjs +27 -0
- package/esm2022/lib/tab/tab.component.mjs +16 -0
- package/esm2022/lib/tag-mob-number/tag-mob-number.component.mjs +28 -0
- package/esm2022/lib/textarea/textarea.component.mjs +6 -3
- package/esm2022/lib/textbox/textbox.component.mjs +42 -4
- package/esm2022/lib/textbox-with-image/textbox-with-image.component.mjs +19 -0
- package/esm2022/lib/textbox-with-underscore/textbox-with-underscore.component.mjs +32 -0
- package/esm2022/lib/toggle/toggle.component.mjs +4 -3
- package/esm2022/lib/underscore-mob-number/underscore-mob-number.component.mjs +35 -0
- package/esm2022/lib/upload/upload.component.mjs +6 -5
- package/esm2022/public-api.mjs +20 -1
- package/fesm2022/master-control.mjs +730 -51
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/add-document/add-document.component.d.ts +6 -0
- package/lib/addition-button/addition-button.component.d.ts +6 -0
- package/lib/age-date/age-date.component.d.ts +7 -0
- package/lib/amount-textbox/amount-textbox.component.d.ts +6 -0
- package/lib/autocomplete/autocomplete.component.d.ts +11 -0
- package/lib/button/button.component.d.ts +6 -0
- package/lib/checkbox/checkbox.component.d.ts +12 -1
- package/lib/dob/dob.component.d.ts +14 -12
- package/lib/download-document/download-document.component.d.ts +6 -0
- package/lib/email-with-domain/email-with-domain.component.d.ts +9 -0
- package/lib/hyperlink/hyperlink.component.d.ts +6 -0
- package/lib/icon-button/icon-button.component.d.ts +6 -0
- package/lib/image-upload/image-upload.component.d.ts +6 -0
- package/lib/info-textbox/info-textbox.component.d.ts +6 -0
- package/lib/master-control.component.d.ts +3 -1
- package/lib/master-control.service.d.ts +1 -0
- package/lib/mob-number/mob-number.component.d.ts +11 -1
- package/lib/multiple-select/multiple-select.component.d.ts +11 -0
- package/lib/otp-mob-number/otp-mob-number.component.d.ts +7 -0
- package/lib/otp-textbox/otp-textbox.component.d.ts +6 -0
- package/lib/radio/radio.component.d.ts +10 -1
- package/lib/select/select.component.d.ts +12 -1
- package/lib/select-textbox/select-textbox.component.d.ts +6 -0
- package/lib/suffix-textbox/suffix-textbox.component.d.ts +6 -0
- package/lib/tab/tab.component.d.ts +6 -0
- package/lib/tag-mob-number/tag-mob-number.component.d.ts +7 -0
- package/lib/textbox/textbox.component.d.ts +11 -1
- package/lib/textbox-with-image/textbox-with-image.component.d.ts +6 -0
- package/lib/textbox-with-underscore/textbox-with-underscore.component.d.ts +8 -0
- package/lib/underscore-mob-number/underscore-mob-number.component.d.ts +9 -0
- package/package.json +1 -1
- package/public-api.d.ts +19 -0
- package/master-control-0.1.2.tgz +0 -0
- package/master-control-0.1.3.tgz +0 -0
- package/master-control-0.1.4.tgz +0 -0
- package/master-control-0.1.5.tgz +0 -0
- package/master-control-0.1.6.tgz +0 -0
- package/radio/radio.component.css +0 -0
- package/radio/radio.component.html +0 -1
- package/radio/radio.component.ts +0 -12
- package/select/select.component.css +0 -0
- package/select/select.component.html +0 -1
- package/select/select.component.ts +0 -12
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
export class AddDocumentComponent {
|
|
7
|
+
field = input.required();
|
|
8
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AddDocumentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AddDocumentComponent, isStandalone: true, selector: "lib-add-document", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field().isVisible\">{{field().label}}</label>\r\n <input\r\n hidden\r\n [type]=\"field().controlType\"\r\n #fileInput\r\n (click)=\"(fileInput.value)\"\r\n [required]=\"field().validators?.isRequired\"\r\n />\r\n <button\r\n type=\"button\"\r\n class=\"upload-btn add-document-btn\"\r\n *ngIf=\"field() && field().isVisible\"\r\n >\r\n <span class=\"add-icon\">\r\n <span\r\n ><img class=\"mb-1\" src=\"https://cdn.godigit.com/retail-life/add.svg\"></span>\r\n <span class=\"upload-text\">{{ field().label }}</span>\r\n <span class=\"light-font\">(optional)</span>\r\n </span>\r\n </button>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }] });
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AddDocumentComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'lib-add-document', standalone: true, imports: [
|
|
14
|
+
CommonModule,
|
|
15
|
+
FormsModule
|
|
16
|
+
], template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field().isVisible\">{{field().label}}</label>\r\n <input\r\n hidden\r\n [type]=\"field().controlType\"\r\n #fileInput\r\n (click)=\"(fileInput.value)\"\r\n [required]=\"field().validators?.isRequired\"\r\n />\r\n <button\r\n type=\"button\"\r\n class=\"upload-btn add-document-btn\"\r\n *ngIf=\"field() && field().isVisible\"\r\n >\r\n <span class=\"add-icon\">\r\n <span\r\n ><img class=\"mb-1\" src=\"https://cdn.godigit.com/retail-life/add.svg\"></span>\r\n <span class=\"upload-text\">{{ field().label }}</span>\r\n <span class=\"light-font\">(optional)</span>\r\n </span>\r\n </button>\r\n" }]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWRvY3VtZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvYWRkLWRvY3VtZW50L2FkZC1kb2N1bWVudC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2FkZC1kb2N1bWVudC9hZGQtZG9jdW1lbnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBWTdDLE1BQU0sT0FBTyxvQkFBb0I7SUFDakMsS0FBSyxHQUFTLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQzt3R0FEdkIsb0JBQW9COzRGQUFwQixvQkFBb0IsK01DZGpDLHN0QkFvQkEseUREWkksWUFBWSxrSUFDWixXQUFXOzs0RkFLRixvQkFBb0I7a0JBVmhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7cUJBQ1oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItYWRkLWRvY3VtZW50JyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYWRkLWRvY3VtZW50LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYWRkLWRvY3VtZW50LmNvbXBvbmVudC5jc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBZGREb2N1bWVudENvbXBvbmVudCB7XHJcbmZpZWxkIDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xyXG59XHJcbiIsIjxsYWJlbCBjbGFzcz1cImZpZWxkLWxhYmxlIHVwbG9hZC1sYWJlbFwiICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpLmlzVmlzaWJsZVwiPnt7ZmllbGQoKS5sYWJlbH19PC9sYWJlbD5cclxuICA8aW5wdXRcclxuICAgIGhpZGRlblxyXG4gICAgW3R5cGVdPVwiZmllbGQoKS5jb250cm9sVHlwZVwiXHJcbiAgICAjZmlsZUlucHV0XHJcbiAgICAoY2xpY2spPVwiKGZpbGVJbnB1dC52YWx1ZSlcIlxyXG4gICAgW3JlcXVpcmVkXT1cImZpZWxkKCkudmFsaWRhdG9ycz8uaXNSZXF1aXJlZFwiXHJcbiAgLz5cclxuICA8YnV0dG9uXHJcbiAgICB0eXBlPVwiYnV0dG9uXCJcclxuICAgIGNsYXNzPVwidXBsb2FkLWJ0biBhZGQtZG9jdW1lbnQtYnRuXCJcclxuICAgICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpLmlzVmlzaWJsZVwiXHJcbiAgPlxyXG4gICAgICA8c3BhbiBjbGFzcz1cImFkZC1pY29uXCI+XHJcbiAgICAgICAgPHNwYW5cclxuICAgICAgICAgID48aW1nIGNsYXNzPVwibWItMVwiIHNyYz1cImh0dHBzOi8vY2RuLmdvZGlnaXQuY29tL3JldGFpbC1saWZlL2FkZC5zdmdcIj48L3NwYW4+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJ1cGxvYWQtdGV4dFwiPnt7IGZpZWxkKCkubGFiZWwgfX08L3NwYW4+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJsaWdodC1mb250XCI+KG9wdGlvbmFsKTwvc3Bhbj5cclxuICAgICAgPC9zcGFuPlxyXG4gIDwvYnV0dG9uPlxyXG4iXX0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class AdditionButtonComponent {
|
|
6
|
+
field = input.required();
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AdditionButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AdditionButtonComponent, isStandalone: true, selector: "lib-addition-button", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<Button class=\"additional-button\" *ngIf=\"field() && field().isVisible\">\r\n <span class=\"additional-button-text\">\r\n <img\r\n class=\"additional-button-img\"\r\n src=\"https://cdn.godigit.com/retail-life/add.svg\"\r\n />\r\n <span\r\n ><u>{{ field().label }}</u></span\r\n >\r\n </span>\r\n</Button>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AdditionButtonComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'lib-addition-button', standalone: true, imports: [CommonModule], template: "<Button class=\"additional-button\" *ngIf=\"field() && field().isVisible\">\r\n <span class=\"additional-button-text\">\r\n <img\r\n class=\"additional-button-img\"\r\n src=\"https://cdn.godigit.com/retail-life/add.svg\"\r\n />\r\n <span\r\n ><u>{{ field().label }}</u></span\r\n >\r\n </span>\r\n</Button>\r\n" }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkaXRpb24tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvYWRkaXRpb24tYnV0dG9uL2FkZGl0aW9uLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2FkZGl0aW9uLWJ1dHRvbi9hZGRpdGlvbi1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTakQsTUFBTSxPQUFPLHVCQUF1QjtJQUNwQyxLQUFLLEdBQVEsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO3dHQUR0Qix1QkFBdUI7NEZBQXZCLHVCQUF1QixrTkNWcEMscVZBV0EseURETFksWUFBWTs7NEZBSVgsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNFLHFCQUFxQixjQUNuQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1hZGRpdGlvbi1idXR0b24nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2FkZGl0aW9uLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2FkZGl0aW9uLWJ1dHRvbi5jb21wb25lbnQuY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQWRkaXRpb25CdXR0b25Db21wb25lbnQge1xyXG5maWVsZDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xyXG59XHJcbiIsIjxCdXR0b24gY2xhc3M9XCJhZGRpdGlvbmFsLWJ1dHRvblwiICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpLmlzVmlzaWJsZVwiPlxyXG4gIDxzcGFuIGNsYXNzPVwiYWRkaXRpb25hbC1idXR0b24tdGV4dFwiPlxyXG4gICAgPGltZ1xyXG4gICAgICBjbGFzcz1cImFkZGl0aW9uYWwtYnV0dG9uLWltZ1wiXHJcbiAgICAgIHNyYz1cImh0dHBzOi8vY2RuLmdvZGlnaXQuY29tL3JldGFpbC1saWZlL2FkZC5zdmdcIlxyXG4gICAgLz5cclxuICAgIDxzcGFuXHJcbiAgICAgID48dT57eyBmaWVsZCgpLmxhYmVsIH19PC91Pjwvc3BhblxyXG4gICAgPlxyXG4gIDwvc3Bhbj5cclxuPC9CdXR0b24+XHJcbiJdfQ==
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MomentDateModule } from '@angular/material-moment-adapter';
|
|
5
|
+
import { MAT_DATE_FORMATS } from '@angular/material/core';
|
|
6
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
7
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
8
|
+
import { MatInputModule } from '@angular/material/input';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/material/input";
|
|
11
|
+
import * as i2 from "@angular/material/form-field";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
import * as i4 from "@angular/material/datepicker";
|
|
14
|
+
export class AgeDateComponent {
|
|
15
|
+
field = input.required();
|
|
16
|
+
dateDivisionFormat(event) {
|
|
17
|
+
let evt = event.target;
|
|
18
|
+
if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {
|
|
19
|
+
evt.value = [evt.value.slice(0, 2), '-', evt.value.slice(2)].join('');
|
|
20
|
+
}
|
|
21
|
+
else if (evt.value.length > 5 &&
|
|
22
|
+
Number(evt.value.substr(3, 2)) &&
|
|
23
|
+
!evt.value.substr(5, 1).includes('-')) {
|
|
24
|
+
evt.value = [evt.value.slice(0, 5), '-', evt.value.slice(5)].join('');
|
|
25
|
+
}
|
|
26
|
+
else if (evt.value.length > 6 &&
|
|
27
|
+
!Number(evt.value.substr(3, 2)) &&
|
|
28
|
+
!evt.value.substr(6, 1).includes('-')) {
|
|
29
|
+
evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AgeDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AgeDateComponent, isStandalone: true, selector: "lib-age-date", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, providers: [{ provide: MAT_DATE_FORMATS, useValue: {
|
|
34
|
+
parse: {
|
|
35
|
+
dateInput: [
|
|
36
|
+
'DD-MM-YYYY',
|
|
37
|
+
'MM/DD/YYYY',
|
|
38
|
+
'YYYY/MM/DD',
|
|
39
|
+
'DD/MM/YYYY',
|
|
40
|
+
'DD MMM YYYY',
|
|
41
|
+
'DD MMMM YYYY',
|
|
42
|
+
'DD-MMM-YYYY',
|
|
43
|
+
],
|
|
44
|
+
},
|
|
45
|
+
display: {
|
|
46
|
+
dateInput: 'DD-MMM-YYYY',
|
|
47
|
+
monthYearLabel: 'MMM YYYY',
|
|
48
|
+
dateA11yLabel: 'DD-MMM-YYYY',
|
|
49
|
+
monthYearA11yLabel: 'MMMM YYYY',
|
|
50
|
+
},
|
|
51
|
+
} }], ngImport: i0, template: "<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators.isRequired\">*</span></label>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [placeholder]=\"field().placeHolder\"\r\n [maxLength]=\"field().validators.maxLength\"\r\n [minLength]=\"field().validators.minLength\"\r\n [required]=\"field().validators.isRequired\"\r\n [pattern]=\"field().validators.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [disabled]=\"field().isDisable\"\r\n />\r\n <span matSuffix class=\"right-date-text\">\r\n 33yrs\r\n </span>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators.patternMessage }}.\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i4.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
52
|
+
}
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AgeDateComponent, decorators: [{
|
|
54
|
+
type: Component,
|
|
55
|
+
args: [{ selector: 'lib-age-date', standalone: true, imports: [
|
|
56
|
+
MatInputModule,
|
|
57
|
+
MatFormFieldModule,
|
|
58
|
+
CommonModule,
|
|
59
|
+
MatDatepickerModule,
|
|
60
|
+
MomentDateModule,
|
|
61
|
+
ReactiveFormsModule
|
|
62
|
+
], providers: [{ provide: MAT_DATE_FORMATS, useValue: {
|
|
63
|
+
parse: {
|
|
64
|
+
dateInput: [
|
|
65
|
+
'DD-MM-YYYY',
|
|
66
|
+
'MM/DD/YYYY',
|
|
67
|
+
'YYYY/MM/DD',
|
|
68
|
+
'DD/MM/YYYY',
|
|
69
|
+
'DD MMM YYYY',
|
|
70
|
+
'DD MMMM YYYY',
|
|
71
|
+
'DD-MMM-YYYY',
|
|
72
|
+
],
|
|
73
|
+
},
|
|
74
|
+
display: {
|
|
75
|
+
dateInput: 'DD-MMM-YYYY',
|
|
76
|
+
monthYearLabel: 'MMM YYYY',
|
|
77
|
+
dateA11yLabel: 'DD-MMM-YYYY',
|
|
78
|
+
monthYearA11yLabel: 'MMMM YYYY',
|
|
79
|
+
},
|
|
80
|
+
} }], template: "<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators.isRequired\">*</span></label>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [placeholder]=\"field().placeHolder\"\r\n [maxLength]=\"field().validators.maxLength\"\r\n [minLength]=\"field().validators.minLength\"\r\n [required]=\"field().validators.isRequired\"\r\n [pattern]=\"field().validators.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [disabled]=\"field().isDisable\"\r\n />\r\n <span matSuffix class=\"right-date-text\">\r\n 33yrs\r\n </span>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators.patternMessage }}.\r\n</div>\r\n" }]
|
|
81
|
+
}] });
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"age-date.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/age-date/age-date.component.ts","../../../../../projects/master-control/src/lib/age-date/age-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { MomentDateModule } from '@angular/material-moment-adapter';\r\nimport { MAT_DATE_FORMATS } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\n\r\n@Component({\r\n  selector: 'lib-age-date',\r\n  standalone: true,\r\n  imports: [\r\n    MatInputModule,\r\n    MatFormFieldModule,\r\n    CommonModule,\r\n    MatDatepickerModule,\r\n    MomentDateModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  providers: [{ provide: MAT_DATE_FORMATS, useValue: {\r\n  parse: {\r\n    dateInput: [\r\n      'DD-MM-YYYY',\r\n      'MM/DD/YYYY',\r\n      'YYYY/MM/DD',\r\n      'DD/MM/YYYY',\r\n      'DD MMM YYYY',\r\n      'DD MMMM YYYY',\r\n      'DD-MMM-YYYY',\r\n    ],\r\n  },\r\n  display: {\r\n    dateInput: 'DD-MMM-YYYY',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'DD-MMM-YYYY',\r\n    monthYearA11yLabel: 'MMMM YYYY',\r\n  },\r\n} }],\r\n  templateUrl: './age-date.component.html',\r\n  styleUrl: './age-date.component.css',\r\n})\r\nexport class AgeDateComponent {\r\n  field: any = input.required<any>();\r\n\r\n  dateDivisionFormat(event: any) {\r\n    let evt = event.target;\r\n    if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {\r\n      evt.value = [evt.value.slice(0, 2), '-', evt.value.slice(2)].join('');\r\n    } else if (\r\n      evt.value.length > 5 &&\r\n      Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(5, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 5), '-', evt.value.slice(5)].join('');\r\n    } else if (\r\n      evt.value.length > 6 &&\r\n      !Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(6, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');\r\n    }\r\n  }\r\n}\r\n","<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators.isRequired\">*</span></label>\r\n<mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field().isVisible\">\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    [name]=\"field().fieldName\"\r\n    [id]=\"field().fieldName\"\r\n    [placeholder]=\"field().placeHolder\"\r\n    [maxLength]=\"field().validators.maxLength\"\r\n    [minLength]=\"field().validators.minLength\"\r\n    [required]=\"field().validators.isRequired\"\r\n    [pattern]=\"field().validators.pattern\"\r\n    [matDatepicker]=\"picker\"\r\n    (keyup)=\"dateDivisionFormat($event)\"\r\n    [disabled]=\"field().isDisable\"\r\n  />\r\n  <span matSuffix class=\"right-date-text\">\r\n    33yrs\r\n  </span>\r\n  <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n    <img\r\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n      style=\"width: 16px\"\r\n      matDatepickerToggleIcon\r\n    />\r\n  </mat-datepicker-toggle>\r\n  <mat-datepicker #picker></mat-datepicker>\r\n   <mat-error *ngIf=\"false\">\r\n    {{ field().validators.isRequiredMessage }}\r\n  </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field().validators.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field().validators.patternMessage }}.\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
4
|
+
import { MatInputModule } from '@angular/material/input';
|
|
5
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/material/form-field";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "@angular/material/input";
|
|
10
|
+
export class AmountTextboxComponent {
|
|
11
|
+
field = input.required();
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AmountTextboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AmountTextboxComponent, isStandalone: true, selector: "lib-amount-textbox", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<label class=\"field-lable\" *ngIf=\"field() && field().isVisible\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field().validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field class=\"w-100\" appearance=\"outline\">\r\n <input\r\n matInput\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field().placeHolder\"\r\n [maxLength]=\"field().validators.maxLength\"\r\n [minLength]=\"field().validators.minLength\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators.isRequired\"\r\n [pattern]=\"field().validators.pattern\"\r\n />\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol\">\u20B9</span>\r\n <span matSuffix class=\"mx-3 right-amount-text\"> \u20B9 3.50 L </span>\r\n </mat-form-field>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i1.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AmountTextboxComponent, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{ selector: 'lib-amount-textbox', standalone: true, imports: [
|
|
18
|
+
MatFormFieldModule,
|
|
19
|
+
CommonModule,
|
|
20
|
+
MatInputModule,
|
|
21
|
+
ReactiveFormsModule
|
|
22
|
+
], template: "<label class=\"field-lable\" *ngIf=\"field() && field().isVisible\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field().validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field class=\"w-100\" appearance=\"outline\">\r\n <input\r\n matInput\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field().placeHolder\"\r\n [maxLength]=\"field().validators.maxLength\"\r\n [minLength]=\"field().validators.minLength\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators.isRequired\"\r\n [pattern]=\"field().validators.pattern\"\r\n />\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol\">\u20B9</span>\r\n <span matSuffix class=\"mx-3 right-amount-text\"> \u20B9 3.50 L </span>\r\n </mat-form-field>\r\n" }]
|
|
23
|
+
}] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1vdW50LXRleHRib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFzdGVyLWNvbnRyb2wvc3JjL2xpYi9hbW91bnQtdGV4dGJveC9hbW91bnQtdGV4dGJveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2Ftb3VudC10ZXh0Ym94L2Ftb3VudC10ZXh0Ym94LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBY3JELE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsS0FBSyxHQUFTLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQzt3R0FEekIsc0JBQXNCOzRGQUF0QixzQkFBc0IsaU5DbEJuQyxnK0JBeUJBLHlERGZJLGtCQUFrQix3a0JBQ2xCLFlBQVksa0lBQ1osY0FBYywwV0FDZCxtQkFBbUI7OzRGQUtWLHNCQUFzQjtrQkFabEMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQO3dCQUNQLGtCQUFrQjt3QkFDbEIsWUFBWTt3QkFDWixjQUFjO3dCQUNkLG1CQUFtQjtxQkFDcEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWFtb3VudC10ZXh0Ym94JyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZVxyXG4gIF0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Ftb3VudC10ZXh0Ym94LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYW1vdW50LXRleHRib3guY29tcG9uZW50LmNzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIEFtb3VudFRleHRib3hDb21wb25lbnQge1xyXG4gIGZpZWxkIDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xyXG59XHJcbiIsIjxsYWJlbCBjbGFzcz1cImZpZWxkLWxhYmxlXCIgKm5nSWY9XCJmaWVsZCgpICYmIGZpZWxkKCkuaXNWaXNpYmxlXCJcclxuICA+e3sgZmllbGQoKS5sYWJlbFxyXG4gIH19PHNwYW4gc3R5bGU9XCJjb2xvcjogcmVkXCIgKm5nSWY9XCJmaWVsZCgpICYmIGZpZWxkKCkudmFsaWRhdG9ycy5pc1JlcXVpcmVkXCJcclxuICAgID4qPC9zcGFuXHJcbiAgPjwvbGFiZWxcclxuPlxyXG4gIDxtYXQtZm9ybS1maWVsZCBjbGFzcz1cInctMTAwXCIgYXBwZWFyYW5jZT1cIm91dGxpbmVcIj5cclxuICAgIDxpbnB1dFxyXG4gICAgICBtYXRJbnB1dFxyXG4gICAgICBbbmFtZV09XCJmaWVsZCgpLmZpZWxkTmFtZVwiXHJcbiAgICAgIFtpZF09XCJmaWVsZCgpLmZpZWxkTmFtZVwiXHJcbiAgICAgIGF1dG9jb21wbGV0ZT1cIm5vbmVcIlxyXG4gICAgICBbcGxhY2Vob2xkZXJdPVwiZmllbGQoKS5wbGFjZUhvbGRlclwiXHJcbiAgICAgIFttYXhMZW5ndGhdPVwiZmllbGQoKS52YWxpZGF0b3JzLm1heExlbmd0aFwiXHJcbiAgICAgIFttaW5MZW5ndGhdPVwiZmllbGQoKS52YWxpZGF0b3JzLm1pbkxlbmd0aFwiXHJcbiAgICAgIFtkaXNhYmxlZF09XCJmaWVsZCgpLmlzRGlzYWJsZVwiXHJcbiAgICAgIFtyZXF1aXJlZF09XCJmaWVsZCgpLnZhbGlkYXRvcnMuaXNSZXF1aXJlZFwiXHJcbiAgICAgIFtwYXR0ZXJuXT1cImZpZWxkKCkudmFsaWRhdG9ycy5wYXR0ZXJuXCJcclxuICAgIC8+XHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiZmFsc2VcIj5cclxuICAgICAge3sgZmllbGQoKS52YWxpZGF0b3JzLnJlcXVpcmVkTWVzc2FnZSB9fVxyXG4gICAgPC9tYXQtZXJyb3I+XHJcbiAgICA8c3BhbiBtYXRQcmVmaXggY2xhc3M9XCJydXBlZS1zeW1ib2xcIj7igrk8L3NwYW4+XHJcbiAgICA8c3BhbiBtYXRTdWZmaXggY2xhc3M9XCJteC0zIHJpZ2h0LWFtb3VudC10ZXh0XCI+IOKCuSAzLjUwIEwgPC9zcGFuPlxyXG4gIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiJdfQ==
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Component, input } from '@angular/core';
|
|
2
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { MatInputModule } from '@angular/material/input';
|
|
5
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
6
|
+
import { MatOptionModule } from '@angular/material/core';
|
|
7
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/material/form-field";
|
|
10
|
+
import * as i2 from "@angular/common";
|
|
11
|
+
import * as i3 from "@angular/material/input";
|
|
12
|
+
import * as i4 from "@angular/material/autocomplete";
|
|
13
|
+
import * as i5 from "@angular/material/core";
|
|
14
|
+
export class AutocompleteComponent {
|
|
15
|
+
field = input.required();
|
|
16
|
+
selectedOption = null;
|
|
17
|
+
filteredOptions = [];
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this.filteredOptions = this.field().options;
|
|
20
|
+
}
|
|
21
|
+
filterOptions() {
|
|
22
|
+
if (!this.selectedOption) {
|
|
23
|
+
this.filteredOptions = this.field().options;
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const filterValue = this.selectedOption.toLowerCase();
|
|
27
|
+
this.filteredOptions = this.field().options.filter((option) => option.label.toLowerCase().includes(filterValue));
|
|
28
|
+
}
|
|
29
|
+
displayFn(option) {
|
|
30
|
+
return option ? option : '';
|
|
31
|
+
}
|
|
32
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AutocompleteComponent, isStandalone: true, selector: "lib-autocomplete", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: " <label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators?.isRequired\">*</span></label>\r\n <mat-form-field class=\"w-100\" appearance=\"outline\" *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n type=\"text\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [matAutocomplete]=\"auto\"\r\n (ngModelChange)=\"filterOptions()\"\r\n (focus)=\"filterOptions()\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators?.isRequired\"\r\n [placeholder]=\"field().placeHolder\"\r\n />\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option.label\">\r\n {{ option.label }}\r\n </mat-option>\r\n</mat-autocomplete>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}\r\n </mat-error>\r\n </mat-form-field>\r\n <div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}.\r\n </div>\r\n <div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.patternMessage }}.\r\n </div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
34
|
+
}
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AutocompleteComponent, decorators: [{
|
|
36
|
+
type: Component,
|
|
37
|
+
args: [{ selector: 'lib-autocomplete', standalone: true, imports: [
|
|
38
|
+
MatFormFieldModule,
|
|
39
|
+
CommonModule,
|
|
40
|
+
MatInputModule,
|
|
41
|
+
MatAutocompleteModule,
|
|
42
|
+
MatOptionModule,
|
|
43
|
+
FormsModule,
|
|
44
|
+
ReactiveFormsModule
|
|
45
|
+
], template: " <label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators?.isRequired\">*</span></label>\r\n <mat-form-field class=\"w-100\" appearance=\"outline\" *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n type=\"text\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [matAutocomplete]=\"auto\"\r\n (ngModelChange)=\"filterOptions()\"\r\n (focus)=\"filterOptions()\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators?.isRequired\"\r\n [placeholder]=\"field().placeHolder\"\r\n />\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option.label\">\r\n {{ option.label }}\r\n </mat-option>\r\n</mat-autocomplete>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}\r\n </mat-error>\r\n </mat-form-field>\r\n <div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}.\r\n </div>\r\n <div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.patternMessage }}.\r\n </div>\r\n" }]
|
|
46
|
+
}] });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7O0FBaUJsRSxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLEtBQUssR0FBUSxLQUFLLENBQUMsUUFBUSxFQUFPLENBQUM7SUFDbkMsY0FBYyxHQUFRLElBQUksQ0FBQztJQUMzQixlQUFlLEdBQUssRUFBRSxDQUFDO0lBQ3ZCLFFBQVE7UUFDTixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFDOUMsQ0FBQztJQUVBLGFBQWE7UUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3pCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLE9BQU8sQ0FBQztZQUM1QyxPQUFPO1FBQ1QsQ0FBQztRQUNELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdEQsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQVUsRUFBRSxFQUFFLENBQ2hFLE1BQU0sQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUNqRCxDQUFDO0lBQ0osQ0FBQztJQUVILFNBQVMsQ0FBQyxNQUFXO1FBQ25CLE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUM5QixDQUFDO3dHQXJCWSxxQkFBcUI7NEZBQXJCLHFCQUFxQiwrTUN2QmxDLHN4Q0E2QkEseUREakJJLGtCQUFrQixzVUFDbEIsWUFBWSwrUEFDWixjQUFjLDBXQUNkLHFCQUFxQix3MUJBQ3JCLGVBQWUsOEJBQ2YsV0FBVyw4QkFDWCxtQkFBbUI7OzRGQUtWLHFCQUFxQjtrQkFmakMsU0FBUzsrQkFDRSxrQkFBa0IsY0FDaEIsSUFBSSxXQUNQO3dCQUNQLGtCQUFrQjt3QkFDbEIsWUFBWTt3QkFDWixjQUFjO3dCQUNkLHFCQUFxQjt3QkFDckIsZUFBZTt3QkFDZixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDcEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgTWF0QXV0b2NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYXV0b2NvbXBsZXRlJztcclxuaW1wb3J0IHsgTWF0T3B0aW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItYXV0b2NvbXBsZXRlJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG4gICAgTWF0QXV0b2NvbXBsZXRlTW9kdWxlLFxyXG4gICAgTWF0T3B0aW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5jc3MnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlQ29tcG9uZW50IHtcclxuICBmaWVsZDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xyXG4gIHNlbGVjdGVkT3B0aW9uOiBhbnkgPSBudWxsO1xyXG4gIGZpbHRlcmVkT3B0aW9uczphbnk9W107XHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuZmllbGQoKS5vcHRpb25zO1xyXG4gIH1cclxuXHJcbiAgIGZpbHRlck9wdGlvbnMoKSB7XHJcbiAgICBpZiAoIXRoaXMuc2VsZWN0ZWRPcHRpb24pIHtcclxuICAgICAgdGhpcy5maWx0ZXJlZE9wdGlvbnMgPSB0aGlzLmZpZWxkKCkub3B0aW9ucztcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgY29uc3QgZmlsdGVyVmFsdWUgPSB0aGlzLnNlbGVjdGVkT3B0aW9uLnRvTG93ZXJDYXNlKCk7XHJcbiAgICB0aGlzLmZpbHRlcmVkT3B0aW9ucyA9IHRoaXMuZmllbGQoKS5vcHRpb25zLmZpbHRlcigob3B0aW9uOmFueSkgPT5cclxuICAgICAgb3B0aW9uLmxhYmVsLnRvTG93ZXJDYXNlKCkuaW5jbHVkZXMoZmlsdGVyVmFsdWUpXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbmRpc3BsYXlGbihvcHRpb246IGFueSkge1xyXG4gIHJldHVybiBvcHRpb24gPyBvcHRpb24gOiAnJztcclxufVxyXG59XHJcbiIsIiAgPGxhYmVsICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpLmlzVmlzaWJsZVwiIGNsYXNzPVwiZmllbGQtbGFibGVcIj57e2ZpZWxkKCkubGFiZWx9fTxzcGFuIHN0eWxlPVwiY29sb3I6IHJlZDtcIiAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKS52YWxpZGF0b3JzPy5pc1JlcXVpcmVkXCI+Kjwvc3Bhbj48L2xhYmVsPlxyXG4gIDxtYXQtZm9ybS1maWVsZCBjbGFzcz1cInctMTAwXCIgYXBwZWFyYW5jZT1cIm91dGxpbmVcIiAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKS5pc1Zpc2libGVcIj5cclxuICAgIDxpbnB1dFxyXG4gICAgICBtYXRJbnB1dFxyXG4gICAgICB0eXBlPVwidGV4dFwiXHJcbiAgICAgIFtuYW1lXT1cImZpZWxkKCkuZmllbGROYW1lXCJcclxuICAgICAgW2lkXT1cImZpZWxkKCkuZmllbGROYW1lXCJcclxuICAgICAgW21hdEF1dG9jb21wbGV0ZV09XCJhdXRvXCJcclxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwiZmlsdGVyT3B0aW9ucygpXCJcclxuICAgICAgKGZvY3VzKT1cImZpbHRlck9wdGlvbnMoKVwiXHJcbiAgICAgIFtkaXNhYmxlZF09XCJmaWVsZCgpLmlzRGlzYWJsZVwiXHJcbiAgICAgIFtyZXF1aXJlZF09XCJmaWVsZCgpLnZhbGlkYXRvcnM/LmlzUmVxdWlyZWRcIlxyXG4gICAgICBbcGxhY2Vob2xkZXJdPVwiZmllbGQoKS5wbGFjZUhvbGRlclwiXHJcbiAgICAgLz5cclxuICAgPG1hdC1hdXRvY29tcGxldGUgYXV0b0FjdGl2ZUZpcnN0T3B0aW9uICNhdXRvPVwibWF0QXV0b2NvbXBsZXRlXCIgW2Rpc3BsYXlXaXRoXT1cImRpc3BsYXlGblwiPlxyXG4gIDxtYXQtb3B0aW9uICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgZmlsdGVyZWRPcHRpb25zXCIgW3ZhbHVlXT1cIm9wdGlvbi5sYWJlbFwiPlxyXG4gICAge3sgb3B0aW9uLmxhYmVsIH19XHJcbiAgPC9tYXQtb3B0aW9uPlxyXG48L21hdC1hdXRvY29tcGxldGU+XHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiZmFsc2VcIj5cclxuICAgICAge3sgZmllbGQoKS52YWxpZGF0b3JzPy5pc1JlcXVpcmVkTWVzc2FnZSB9fVxyXG4gICAgPC9tYXQtZXJyb3I+XHJcbiAgPC9tYXQtZm9ybS1maWVsZD5cclxuICA8ZGl2IGNsYXNzPVwiZXJyb3ItbWVzc2FnZVwiICpuZ0lmPVwiZmFsc2VcIj5cclxuICAgIHt7IGZpZWxkKCkudmFsaWRhdG9ycz8uaXNSZXF1aXJlZE1lc3NhZ2UgfX0uXHJcbiAgPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cImVycm9yLW1lc3NhZ2VcIiAqbmdJZj1cImZhbHNlXCI+XHJcbiAgICB7eyBmaWVsZCgpLnZhbGlkYXRvcnM/LnBhdHRlcm5NZXNzYWdlIH19LlxyXG4gIDwvZGl2PlxyXG4iXX0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class ButtonComponent {
|
|
6
|
+
field = input.required();
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: ButtonComponent, isStandalone: true, selector: "lib-button", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<Button \r\nclass=\"button\"\r\n*ngIf=\"field() && field().isVisible\" \r\n>\r\n<span class=\"button-text\">\r\n<img src=\"https://cdn.godigit.com/retail-life/add.svg\">\r\n<span>{{field().label}}</span>\r\n</span>\r\n</Button>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ButtonComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'lib-button', standalone: true, imports: [CommonModule], template: "<Button \r\nclass=\"button\"\r\n*ngIf=\"field() && field().isVisible\" \r\n>\r\n<span class=\"button-text\">\r\n<img src=\"https://cdn.godigit.com/retail-life/add.svg\">\r\n<span>{{field().label}}</span>\r\n</span>\r\n</Button>" }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTakQsTUFBTSxPQUFPLGVBQWU7SUFDMUIsS0FBSyxHQUFRLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQzt3R0FEeEIsZUFBZTs0RkFBZixlQUFlLHlNQ1Y1QixxT0FRUyx5RERGRyxZQUFZOzs0RkFJWCxlQUFlO2tCQVAzQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1idXR0b24nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2J1dHRvbi5jb21wb25lbnQuY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQnV0dG9uQ29tcG9uZW50IHtcclxuICBmaWVsZDogYW55ID0gaW5wdXQucmVxdWlyZWQ8YW55PigpO1xyXG59XHJcbiIsIjxCdXR0b24gXHJcbmNsYXNzPVwiYnV0dG9uXCJcclxuKm5nSWY9XCJmaWVsZCgpICYmIGZpZWxkKCkuaXNWaXNpYmxlXCIgXHJcbj5cclxuPHNwYW4gY2xhc3M9XCJidXR0b24tdGV4dFwiPlxyXG48aW1nIHNyYz1cImh0dHBzOi8vY2RuLmdvZGlnaXQuY29tL3JldGFpbC1saWZlL2FkZC5zdmdcIj5cclxuPHNwYW4+e3tmaWVsZCgpLmxhYmVsfX08L3NwYW4+XHJcbjwvc3Bhbj5cclxuPC9CdXR0b24+Il19
|
|
@@ -1,16 +1,59 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, input } from '@angular/core';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
3
4
|
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common";
|
|
6
7
|
import * as i2 from "@angular/material/checkbox";
|
|
7
8
|
export class CheckboxComponent {
|
|
8
9
|
field = input.required();
|
|
10
|
+
inputValue = null;
|
|
11
|
+
_onChange = (inputValue) => { };
|
|
12
|
+
_unTouched = () => { };
|
|
13
|
+
writeValue(obj) {
|
|
14
|
+
this.inputValue = obj;
|
|
15
|
+
}
|
|
16
|
+
;
|
|
17
|
+
registerOnChange(fn) {
|
|
18
|
+
this._onChange = fn;
|
|
19
|
+
}
|
|
20
|
+
;
|
|
21
|
+
registerOnTouched(fn) {
|
|
22
|
+
this._unTouched = fn;
|
|
23
|
+
}
|
|
24
|
+
;
|
|
25
|
+
setDisabledState(isDisabled) { }
|
|
26
|
+
;
|
|
27
|
+
onInputChange(event) {
|
|
28
|
+
this.inputValue = event.target.value;
|
|
29
|
+
this._onChange(this.inputValue);
|
|
30
|
+
}
|
|
31
|
+
onCheckboxChange(event) {
|
|
32
|
+
// const target = event.target as HTMLInputElement;
|
|
33
|
+
this.inputValue = event.checked;
|
|
34
|
+
this._onChange(this.inputValue);
|
|
35
|
+
this._unTouched();
|
|
36
|
+
}
|
|
37
|
+
onInputBlur() {
|
|
38
|
+
this._unTouched();
|
|
39
|
+
}
|
|
9
40
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CheckboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: CheckboxComponent, isStandalone: true, selector: "lib-checkbox", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } },
|
|
41
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: CheckboxComponent, isStandalone: true, selector: "lib-checkbox", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, providers: [
|
|
42
|
+
{
|
|
43
|
+
provide: NG_VALUE_ACCESSOR,
|
|
44
|
+
useExisting: CheckboxComponent,
|
|
45
|
+
multi: true
|
|
46
|
+
}
|
|
47
|
+
], ngImport: i0, template: "<mat-checkbox *ngIf=\"field() && field().isVisible\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators?.isRequired\"\r\n [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\"\r\n>\r\n{{ field().label }}\r\n</mat-checkbox>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field().validators?.isRequiredMessage}}.\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
11
48
|
}
|
|
12
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CheckboxComponent, decorators: [{
|
|
13
50
|
type: Component,
|
|
14
|
-
args: [{ selector: 'lib-checkbox', standalone: true, imports: [CommonModule, MatCheckboxModule],
|
|
51
|
+
args: [{ selector: 'lib-checkbox', standalone: true, imports: [CommonModule, MatCheckboxModule, ReactiveFormsModule], providers: [
|
|
52
|
+
{
|
|
53
|
+
provide: NG_VALUE_ACCESSOR,
|
|
54
|
+
useExisting: CheckboxComponent,
|
|
55
|
+
multi: true
|
|
56
|
+
}
|
|
57
|
+
], template: "<mat-checkbox *ngIf=\"field() && field().isVisible\"\r\n [name]=\"field().fieldName\"\r\n [id]=\"field().fieldName\"\r\n [disabled]=\"field().isDisable\"\r\n [required]=\"field().validators?.isRequired\"\r\n [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\"\r\n>\r\n{{ field().label }}\r\n</mat-checkbox>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field().validators?.isRequiredMessage}}.\r\n</div>\r\n" }]
|
|
15
58
|
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFzdGVyLWNvbnRyb2wvc3JjL2xpYi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7QUFnQi9ELE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIsS0FBSyxHQUFRLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQztJQUVuQyxVQUFVLEdBQVEsSUFBSSxDQUFDO0lBQ3ZCLFNBQVMsR0FBUSxDQUFDLFVBQWMsRUFBRSxFQUFFLEdBQUUsQ0FBQyxDQUFDO0lBQ3hDLFVBQVUsR0FBUSxHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7SUFFM0IsVUFBVSxDQUFDLEdBQVE7UUFDakIsSUFBSSxDQUFDLFVBQVUsR0FBQyxHQUFHLENBQUM7SUFDdEIsQ0FBQztJQUFBLENBQUM7SUFDRixnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFBQSxDQUFDO0lBQ0YsaUJBQWlCLENBQUMsRUFBTztRQUN2QixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBQUEsQ0FBQztJQUNGLGdCQUFnQixDQUFFLFVBQW1CLElBQVEsQ0FBQztJQUFBLENBQUM7SUFFL0MsYUFBYSxDQUFDLEtBQVU7UUFDdEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUNyQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBVTtRQUN6QixtREFBbUQ7UUFDbkQsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO3dHQWhDVSxpQkFBaUI7NEZBQWpCLGlCQUFpQiw4TEFSZjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxpQkFBaUI7Z0JBQzlCLEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRiwwQkNqQkwsMGJBYUEseURETFksWUFBWSxrSUFBRyxpQkFBaUIsb1lBQUUsbUJBQW1COzs0RkFXcEQsaUJBQWlCO2tCQWQ3QixTQUFTOytCQUNFLGNBQWMsY0FDWixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUcsaUJBQWlCLEVBQUUsbUJBQW1CLENBQUMsYUFHbkQ7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxtQkFBbUI7NEJBQzlCLEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdENoZWNrYm94TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItY2hlY2tib3gnLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSAsIE1hdENoZWNrYm94TW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9jaGVja2JveC5jb21wb25lbnQuY3NzJyxcclxuICAgIHByb3ZpZGVyczogW1xyXG4gICAgICB7XHJcbiAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgICAgdXNlRXhpc3Rpbmc6IENoZWNrYm94Q29tcG9uZW50LFxyXG4gICAgICAgIG11bHRpOiB0cnVlXHJcbiAgICAgIH1cclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENoZWNrYm94Q29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xyXG4gIGZpZWxkOiBhbnkgPSBpbnB1dC5yZXF1aXJlZDxhbnk+KCk7XHJcblxyXG4gIGlucHV0VmFsdWU6IGFueSA9IG51bGw7XHJcbiAgX29uQ2hhbmdlOiBhbnkgPSAoaW5wdXRWYWx1ZTphbnkpID0+IHt9O1xyXG4gIF91blRvdWNoZWQ6IGFueSA9ICgpID0+IHt9O1xyXG5cclxuICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZHtcclxuICAgIHRoaXMuaW5wdXRWYWx1ZT1vYmo7XHJcbiAgfTtcclxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lke1xyXG4gICAgdGhpcy5fb25DaGFuZ2UgPSBmbjtcclxuICB9O1xyXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lke1xyXG4gICAgdGhpcy5fdW5Ub3VjaGVkID0gZm47XHJcbiAgfTtcclxuICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZHt9O1xyXG5cclxuICBvbklucHV0Q2hhbmdlKGV2ZW50OiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMuaW5wdXRWYWx1ZSA9IGV2ZW50LnRhcmdldC52YWx1ZTtcclxuICAgIHRoaXMuX29uQ2hhbmdlKHRoaXMuaW5wdXRWYWx1ZSk7XHJcbiAgfVxyXG5cclxuICBvbkNoZWNrYm94Q2hhbmdlKGV2ZW50OiBhbnkpOiB2b2lkIHtcclxuICAgIC8vIGNvbnN0IHRhcmdldCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50O1xyXG4gICAgdGhpcy5pbnB1dFZhbHVlID0gZXZlbnQuY2hlY2tlZDtcclxuICAgIHRoaXMuX29uQ2hhbmdlKHRoaXMuaW5wdXRWYWx1ZSk7XHJcbiAgICB0aGlzLl91blRvdWNoZWQoKTtcclxuICB9XHJcblxyXG4gIG9uSW5wdXRCbHVyKCk6IHZvaWQge1xyXG4gICAgdGhpcy5fdW5Ub3VjaGVkKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxtYXQtY2hlY2tib3ggKm5nSWY9XCJmaWVsZCgpICYmIGZpZWxkKCkuaXNWaXNpYmxlXCJcclxuICBbbmFtZV09XCJmaWVsZCgpLmZpZWxkTmFtZVwiXHJcbiAgW2lkXT1cImZpZWxkKCkuZmllbGROYW1lXCJcclxuICBbZGlzYWJsZWRdPVwiZmllbGQoKS5pc0Rpc2FibGVcIlxyXG4gIFtyZXF1aXJlZF09XCJmaWVsZCgpLnZhbGlkYXRvcnM/LmlzUmVxdWlyZWRcIlxyXG4gIFtjaGVja2VkXT1cImlucHV0VmFsdWVcIlxyXG4gIChjaGFuZ2UpPVwib25DaGVja2JveENoYW5nZSgkZXZlbnQpXCJcclxuPlxyXG57eyBmaWVsZCgpLmxhYmVsIH19XHJcbjwvbWF0LWNoZWNrYm94PlxyXG48ZGl2IGNsYXNzPVwiZXJyb3ItbWVzc2FnZVwiICpuZ0lmPVwiZmFsc2VcIj5cclxuICAgIHt7ZmllbGQoKS52YWxpZGF0b3JzPy5pc1JlcXVpcmVkTWVzc2FnZX19LlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -1,27 +1,18 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, input } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';
|
|
5
|
+
import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
|
5
6
|
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
6
7
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
8
|
import { MatInputModule } from '@angular/material/input';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "
|
|
10
|
-
import * as i2 from "@angular/material/
|
|
11
|
-
import * as i3 from "@angular/
|
|
12
|
-
import * as i4 from "@angular/
|
|
10
|
+
import * as i1 from "../master-control.service";
|
|
11
|
+
import * as i2 from "@angular/material/input";
|
|
12
|
+
import * as i3 from "@angular/material/form-field";
|
|
13
|
+
import * as i4 from "@angular/common";
|
|
14
|
+
import * as i5 from "@angular/material/datepicker";
|
|
13
15
|
export const MY_DATE_FORMAT = {
|
|
14
|
-
parse: {
|
|
15
|
-
dateInput: 'DD/MM/YYYY'
|
|
16
|
-
},
|
|
17
|
-
display: {
|
|
18
|
-
dateInput: 'DD/MM/YYYY',
|
|
19
|
-
monthYearLabel: 'MMM YYYY',
|
|
20
|
-
dateA11yLabel: 'LL',
|
|
21
|
-
monthYearA11yLabel: 'MMMM YYYY'
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
|
-
export const MY_FORMATS = {
|
|
25
16
|
parse: {
|
|
26
17
|
dateInput: [
|
|
27
18
|
'DD-MM-YYYY',
|
|
@@ -41,7 +32,12 @@ export const MY_FORMATS = {
|
|
|
41
32
|
}
|
|
42
33
|
};
|
|
43
34
|
export class DobComponent {
|
|
35
|
+
service;
|
|
44
36
|
field = input.required();
|
|
37
|
+
inputValue = null;
|
|
38
|
+
constructor(service) {
|
|
39
|
+
this.service = service;
|
|
40
|
+
}
|
|
45
41
|
dateDivisionFormat(event) {
|
|
46
42
|
let evt = event.target;
|
|
47
43
|
if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {
|
|
@@ -58,15 +54,63 @@ export class DobComponent {
|
|
|
58
54
|
evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');
|
|
59
55
|
}
|
|
60
56
|
}
|
|
61
|
-
|
|
57
|
+
_onChange = (inputValue) => { };
|
|
58
|
+
_unTouched = () => { };
|
|
59
|
+
writeValue(obj) {
|
|
60
|
+
this.inputValue = obj;
|
|
61
|
+
}
|
|
62
|
+
;
|
|
63
|
+
registerOnChange(fn) {
|
|
64
|
+
this._onChange = fn;
|
|
65
|
+
}
|
|
66
|
+
;
|
|
67
|
+
registerOnTouched(fn) {
|
|
68
|
+
this._unTouched = fn;
|
|
69
|
+
}
|
|
70
|
+
;
|
|
71
|
+
setDisabledState(isDisabled) { }
|
|
72
|
+
;
|
|
73
|
+
onInputChange(event) {
|
|
74
|
+
this.inputValue = event.target.value;
|
|
75
|
+
this._onChange(this.inputValue);
|
|
76
|
+
}
|
|
77
|
+
onInputBlur(event) {
|
|
78
|
+
if (!this.service.checkIfValueIsEmpty(event.target.value)) {
|
|
79
|
+
if (isNaN(Date.parse(event.target.value))) {
|
|
80
|
+
event.target.value = '';
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
this._unTouched();
|
|
84
|
+
}
|
|
85
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DobComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
|
|
62
86
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DobComponent, isStandalone: true, selector: "lib-dob", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, providers: [
|
|
63
|
-
{
|
|
64
|
-
|
|
87
|
+
{
|
|
88
|
+
provide: NG_VALUE_ACCESSOR,
|
|
89
|
+
useExisting: DobComponent,
|
|
90
|
+
multi: true
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
provide: DateAdapter,
|
|
94
|
+
useClass: MomentDateAdapter,
|
|
95
|
+
deps: []
|
|
96
|
+
},
|
|
97
|
+
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
98
|
+
], ngImport: i0, template: "<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators?.isRequired\">*</span></label>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [placeholder]=\"field().placeHolder\"\r\n [required]=\"field().validators?.isRequired\"\r\n [pattern]=\"field().validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [disabled]=\"field().isDisable\"\r\n (dateChange)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.patternMessage }}.\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
65
99
|
}
|
|
66
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DobComponent, decorators: [{
|
|
67
101
|
type: Component,
|
|
68
|
-
args: [{ selector: 'lib-dob', standalone: true, imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule], providers: [
|
|
69
|
-
{
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
102
|
+
args: [{ selector: 'lib-dob', standalone: true, imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule], providers: [
|
|
103
|
+
{
|
|
104
|
+
provide: NG_VALUE_ACCESSOR,
|
|
105
|
+
useExisting: DobComponent,
|
|
106
|
+
multi: true
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
provide: DateAdapter,
|
|
110
|
+
useClass: MomentDateAdapter,
|
|
111
|
+
deps: []
|
|
112
|
+
},
|
|
113
|
+
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
114
|
+
], template: "<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators?.isRequired\">*</span></label>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field().isVisible\">\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [placeholder]=\"field().placeHolder\"\r\n [required]=\"field().validators?.isRequired\"\r\n [pattern]=\"field().validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [disabled]=\"field().isDisable\"\r\n (dateChange)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field().validators?.patternMessage }}.\r\n</div>\r\n" }]
|
|
115
|
+
}], ctorParameters: () => [{ type: i1.MasterControlService }] });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dob.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/dob/dob.component.ts","../../../../../projects/master-control/src/lib/dob/dob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';\r\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MasterControlService } from '../master-control.service';\r\n\r\n\r\nexport const MY_DATE_FORMAT = {\r\n  parse: {\r\n    dateInput: [\r\n      'DD-MM-YYYY',\r\n      'MM/DD/YYYY',\r\n      'YYYY/MM/DD',\r\n      'DD/MM/YYYY',\r\n      'DD MMM YYYY',\r\n      'DD MMMM YYYY',\r\n      'DD-MMM-YYYY'\r\n    ]\r\n  },\r\n  display: {\r\n    dateInput: 'DD-MMM-YYYY',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'DD-MMM-YYYY',\r\n    monthYearA11yLabel: 'MMMM YYYY'\r\n  }\r\n};\r\n\r\n@Component({\r\n  selector: 'lib-dob',\r\n  standalone: true,\r\n  imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule],\r\n    providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: DobComponent,\r\n        multi: true\r\n      },\r\n    {\r\n      provide: DateAdapter,\r\n      useClass: MomentDateAdapter,\r\n      deps: []\r\n    },\r\n    { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }\r\n  ],\r\n  templateUrl: './dob.component.html',\r\n  styleUrl: './dob.component.css',\r\n})\r\nexport class DobComponent implements ControlValueAccessor {\r\n  field: any = input.required<any>();\r\n  inputValue: any = null;\r\n\r\n  constructor(public service : MasterControlService) {}\r\n\r\n  dateDivisionFormat(event: any) {\r\n    let evt = event.target;\r\n    if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {\r\n      evt.value = [evt.value.slice(0, 2), '-', evt.value.slice(2)].join('');\r\n    } else if (\r\n      evt.value.length > 5 &&\r\n      Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(5, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 5), '-', evt.value.slice(5)].join('');\r\n    } else if (\r\n      evt.value.length > 6 &&\r\n      !Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(6, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');\r\n    }\r\n  }\r\n\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n\r\n  writeValue(obj: any): void{\r\n    this.inputValue=obj;\r\n  };\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    this.inputValue = event.target.value;\r\n    this._onChange(this.inputValue);\r\n  }\r\n\r\n  onInputBlur(event : any): void {\r\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\r\n      if (isNaN(Date.parse(event.target.value))) {\r\n        event.target.value = '';\r\n      }\r\n\r\n    }\r\n    this._unTouched();\r\n  }\r\n\r\n}\r\n","<label *ngIf=\"field() && field().isVisible\" class=\"field-lable\">{{field().label}}<span style=\"color: red;\" *ngIf=\"field() && field().validators?.isRequired\">*</span></label>\r\n<mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field().isVisible\">\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    type=\"text\"\r\n    [placeholder]=\"field().placeHolder\"\r\n    [required]=\"field().validators?.isRequired\"\r\n    [pattern]=\"field().validators?.pattern\"\r\n    [matDatepicker]=\"picker\"\r\n    (keyup)=\"dateDivisionFormat($event)\"\r\n    [disabled]=\"field().isDisable\"\r\n    (dateChange)=\"onInputChange($event)\"\r\n    (blur)=\"onInputBlur($event)\"\r\n    [value]=\"inputValue\"\r\n  />\r\n  <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"false\">\r\n    <img\r\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n      style=\"width: 16px\"\r\n      matDatepickerToggleIcon\r\n    />\r\n  </mat-datepicker-toggle>\r\n  <mat-datepicker #picker></mat-datepicker>\r\n   <mat-error *ngIf=\"false\">\r\n    {{ field().validators?.isRequiredMessage }}\r\n  </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field().validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field().validators?.patternMessage }}.\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, input } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
export class DownloadDocumentComponent {
|
|
7
|
+
field = input.required();
|
|
8
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadDocumentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DownloadDocumentComponent, isStandalone: true, selector: "lib-download-document", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field().isVisible\">{{field().label}}</label>\r\n <input\r\n hidden\r\n [type]=\"field().controlType\"\r\n #fileInput\r\n (click)=\"(fileInput.value)\"\r\n [required]=\"field().validators?.isRequired\"\r\n />\r\n <button\r\n type=\"button\"\r\n class=\"upload-btn lightbackground\"\r\n *ngIf=\"field() && field().isVisible\"\r\n >\r\n <span class=\"upload-icon\">\r\n <span\r\n ><img\r\n src=\"https://cdn.godigit.com/retail-life/Download_Icon.svg\"\r\n alt=\"\"\r\n class=\"mb-1\"\r\n /></span>\r\n <span class=\"upload-text\">{{ field().label }}</span>\r\n </span>\r\n </button>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }] });
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadDocumentComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'lib-download-document', standalone: true, imports: [
|
|
14
|
+
CommonModule,
|
|
15
|
+
FormsModule
|
|
16
|
+
], template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field().isVisible\">{{field().label}}</label>\r\n <input\r\n hidden\r\n [type]=\"field().controlType\"\r\n #fileInput\r\n (click)=\"(fileInput.value)\"\r\n [required]=\"field().validators?.isRequired\"\r\n />\r\n <button\r\n type=\"button\"\r\n class=\"upload-btn lightbackground\"\r\n *ngIf=\"field() && field().isVisible\"\r\n >\r\n <span class=\"upload-icon\">\r\n <span\r\n ><img\r\n src=\"https://cdn.godigit.com/retail-life/Download_Icon.svg\"\r\n alt=\"\"\r\n class=\"mb-1\"\r\n /></span>\r\n <span class=\"upload-text\">{{ field().label }}</span>\r\n </span>\r\n </button>\r\n" }]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQtZG9jdW1lbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFzdGVyLWNvbnRyb2wvc3JjL2xpYi9kb3dubG9hZC1kb2N1bWVudC9kb3dubG9hZC1kb2N1bWVudC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL2Rvd25sb2FkLWRvY3VtZW50L2Rvd25sb2FkLWRvY3VtZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVk3QyxNQUFNLE9BQU8seUJBQXlCO0lBQ3JDLEtBQUssR0FBUyxLQUFLLENBQUMsUUFBUSxFQUFPLENBQUM7d0dBRHhCLHlCQUF5Qjs0RkFBekIseUJBQXlCLG9OQ2R0Qyw2dUJBdUJBLHlERGZJLFlBQVksa0lBQ1osV0FBVzs7NEZBS0YseUJBQXlCO2tCQVZyQyxTQUFTOytCQUNFLHVCQUF1QixjQUNyQixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3FCQUNaIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWRvd25sb2FkLWRvY3VtZW50JyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vZG93bmxvYWQtZG9jdW1lbnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9kb3dubG9hZC1kb2N1bWVudC5jb21wb25lbnQuY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRG93bmxvYWREb2N1bWVudENvbXBvbmVudCB7XHJcbiBmaWVsZCA6IGFueSA9IGlucHV0LnJlcXVpcmVkPGFueT4oKTtcclxufVxyXG4iLCI8bGFiZWwgY2xhc3M9XCJmaWVsZC1sYWJsZSB1cGxvYWQtbGFiZWxcIiAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKS5pc1Zpc2libGVcIj57e2ZpZWxkKCkubGFiZWx9fTwvbGFiZWw+XHJcbiAgPGlucHV0XHJcbiAgICBoaWRkZW5cclxuICAgIFt0eXBlXT1cImZpZWxkKCkuY29udHJvbFR5cGVcIlxyXG4gICAgI2ZpbGVJbnB1dFxyXG4gICAgKGNsaWNrKT1cIihmaWxlSW5wdXQudmFsdWUpXCJcclxuICAgIFtyZXF1aXJlZF09XCJmaWVsZCgpLnZhbGlkYXRvcnM/LmlzUmVxdWlyZWRcIlxyXG4gIC8+XHJcbiAgPGJ1dHRvblxyXG4gICAgdHlwZT1cImJ1dHRvblwiXHJcbiAgICBjbGFzcz1cInVwbG9hZC1idG4gbGlnaHRiYWNrZ3JvdW5kXCJcclxuICAgICpuZ0lmPVwiZmllbGQoKSAmJiBmaWVsZCgpLmlzVmlzaWJsZVwiXHJcbiAgPlxyXG4gICAgICA8c3BhbiBjbGFzcz1cInVwbG9hZC1pY29uXCI+XHJcbiAgICAgICAgPHNwYW5cclxuICAgICAgICAgID48aW1nXHJcbiAgICAgICAgICAgIHNyYz1cImh0dHBzOi8vY2RuLmdvZGlnaXQuY29tL3JldGFpbC1saWZlL0Rvd25sb2FkX0ljb24uc3ZnXCJcclxuICAgICAgICAgICAgYWx0PVwiXCJcclxuICAgICAgICAgICAgY2xhc3M9XCJtYi0xXCJcclxuICAgICAgICAvPjwvc3Bhbj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cInVwbG9hZC10ZXh0XCI+e3sgZmllbGQoKS5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgPC9zcGFuPlxyXG4gIDwvYnV0dG9uPlxyXG4iXX0=
|