@magic-xpa/angular 4.1000.0-dev4100.99 → 4.1000.410-0.428
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/esm2020/index.mjs +2 -1
- package/esm2020/src/magic.core.module.mjs +16 -13
- package/esm2020/src/services/accessor.magic.service.mjs +28 -3
- package/esm2020/src/services/magic-color.service.mjs +4 -4
- package/esm2020/src/services/subform.magic.service.mjs +1 -1
- package/esm2020/src/services/table.magic.service.mjs +5 -2
- package/esm2020/src/services/task.magics.service.mjs +25 -4
- package/esm2020/src/ui/GuiInteractiveExecutor.mjs +7 -2
- package/esm2020/src/ui/components/base-magic-alert.component.mjs +3 -7
- package/esm2020/src/ui/components/base-magic-confirm.component.mjs +3 -7
- package/esm2020/src/ui/components/magic-alert.component.mjs +3 -35
- package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +3 -39
- package/esm2020/src/ui/directives/NonMagicControlDirective.mjs +6 -6
- package/esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs +76 -7
- package/esm2020/src/ui/directives/magic/combobox.magic.directive.mjs +11 -1
- package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +34 -5
- package/esm2020/src/ui/directives/magic/nocontrol.magic.directive.mjs +3 -3
- package/esm2020/src/ui/directives/magic.directive.mjs +11 -11
- package/esm2020/src/ui/directives/mgformat.magic.directive.mjs +336 -3
- package/esm2020/src/ui/magic-modal/base-magic-overlay-container.mjs +1 -1
- package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +4 -18
- package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +4 -4
- package/esm2020/src/ui/magic-root.component.mjs +4 -38
- package/esm2020/src/ui/mgerror.magic.component.mjs +9 -9
- package/esm2020/src/ui/pipes/time24.magic.pipe.mjs +34 -0
- package/esm2020/src/ui/router-container.magic.component.mjs +4 -4
- package/esm2020/src/ui/subform.magic.component.mjs +4 -4
- package/esm2020/src/ui/task-base.magic.component.mjs +8 -2
- package/fesm2015/magic-xpa-angular.mjs +605 -208
- package/fesm2015/magic-xpa-angular.mjs.map +1 -1
- package/fesm2020/magic-xpa-angular.mjs +603 -208
- package/fesm2020/magic-xpa-angular.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/package.json +11 -8
- package/src/magic.core.module.d.ts +8 -6
- package/src/services/accessor.magic.service.d.ts +3 -0
- package/src/services/table.magic.service.d.ts +2 -0
- package/src/services/task.magics.service.d.ts +1 -0
- package/src/ui/components/base-magic-alert.component.d.ts +1 -1
- package/src/ui/components/base-magic-confirm.component.d.ts +1 -1
- package/src/ui/components/magic-alert.component.d.ts +1 -1
- package/src/ui/components/magic-confirmation-box.component.d.ts +1 -1
- package/src/ui/directives/NonMagicControlDirective.d.ts +1 -1
- package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +1 -1
- package/src/ui/directives/magic/checkbox.magic.directive.d.ts +15 -2
- package/src/ui/directives/magic/combobox.magic.directive.d.ts +2 -1
- package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +1 -1
- package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +9 -3
- package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +1 -1
- package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +1 -1
- package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +1 -1
- package/src/ui/directives/magic/row.magic.directive.d.ts +1 -1
- package/src/ui/directives/magic-focus.directive.d.ts +1 -1
- package/src/ui/directives/magic.directive.d.ts +2 -2
- package/src/ui/directives/magicViewContainerRef.directive.d.ts +1 -1
- package/src/ui/directives/mgformat.magic.directive.d.ts +12 -2
- package/src/ui/directives/range-validator.magic.directive.d.ts +1 -1
- package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +1 -1
- package/src/ui/magic-modal/magic-overlay-container.d.ts +1 -1
- package/src/ui/magic-root.component.d.ts +1 -1
- package/src/ui/mgerror.magic.component.d.ts +1 -1
- package/src/ui/pipes/date.magic.pipe.d.ts +1 -1
- package/src/ui/pipes/time.magic.pipe.d.ts +1 -1
- package/src/ui/pipes/time24.magic.pipe.d.ts +10 -0
- package/src/ui/router-container.magic.component.d.ts +1 -1
- package/src/ui/subform.magic.component.d.ts +1 -1
- package/src/ui/task-base.magic.component.d.ts +2 -1
- package/magic-xpa-angular.d.ts +0 -2
@@ -9,14 +9,10 @@ export class BaseMagicConfirmComponent {
|
|
9
9
|
}
|
10
10
|
}
|
11
11
|
BaseMagicConfirmComponent.ɵfac = function BaseMagicConfirmComponent_Factory(t) { return new (t || BaseMagicConfirmComponent)(); };
|
12
|
-
BaseMagicConfirmComponent.ɵcmp = i0.ɵɵdefineComponent({ type: BaseMagicConfirmComponent, selectors: [["mg-base-alert"]], inputs: { title: "title", message: "message" }, outputs: { onClose: "onClose" }, decls: 0, vars: 0, template: function BaseMagicConfirmComponent_Template(rf, ctx) { }
|
12
|
+
BaseMagicConfirmComponent.ɵcmp = i0.ɵɵdefineComponent({ type: BaseMagicConfirmComponent, selectors: [["mg-base-alert"]], inputs: { title: "title", message: "message" }, outputs: { onClose: "onClose" }, decls: 0, vars: 0, template: function BaseMagicConfirmComponent_Template(rf, ctx) { } });
|
13
13
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseMagicConfirmComponent, [{
|
14
14
|
type: Component,
|
15
|
-
args: [{
|
16
|
-
selector: 'mg-base-alert',
|
17
|
-
template: '',
|
18
|
-
styles: ['']
|
19
|
-
}]
|
15
|
+
args: [{ selector: 'mg-base-alert', template: '' }]
|
20
16
|
}], null, { title: [{
|
21
17
|
type: Input
|
22
18
|
}], message: [{
|
@@ -24,4 +20,4 @@ BaseMagicConfirmComponent.ɵcmp = i0.ɵɵdefineComponent({ type: BaseMagicConfir
|
|
24
20
|
}], onClose: [{
|
25
21
|
type: Output
|
26
22
|
}] }); })();
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1tYWdpYy1jb25maXJtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2NvbXBvbmVudHMvYmFzZS1tYWdpYy1jb25maXJtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVd2RSxNQUFNLE9BQU8seUJBQXlCO0lBTHRDO1FBcUJZLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO0tBV2pEO0lBSEMsT0FBTyxDQUFDLE1BQU07UUFDWixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1QixDQUFDOztrR0ExQlUseUJBQXlCOzhEQUF6Qix5QkFBeUI7dUZBQXpCLHlCQUF5QjtjQUxyQyxTQUFTOzJCQUNFLGVBQWUsWUFDZixFQUFFO2dCQVFILEtBQUs7a0JBQWIsS0FBSztZQUtHLE9BQU87a0JBQWYsS0FBSztZQU1JLE9BQU87a0JBQWhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5cbi8qKlxuICogVGhpcyBpcyBhIGJhc2UgY2xhc3MgZm9yIHRoZSBtYWdpYyBjb25maXJtIGNvbXBvbmVudHNcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbWctYmFzZS1hbGVydCcsXG4gIHRlbXBsYXRlOiAnJyxcbiAgc3R5bGVzOiBbJyddXG59KVxuZXhwb3J0IGNsYXNzIEJhc2VNYWdpY0NvbmZpcm1Db21wb25lbnQgICB7XG5cbiAgLyoqXG4gICAqIHRpdGxlIG9mIHRoZSBjb21wb25lbnRcbiAgICovXG4gIEBJbnB1dCgpIHRpdGxlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIG1lc3NhZ2Ugb2YgdGhlIGNvbXBvbmVudFxuICAgKi9cbiAgQElucHV0KCkgbWVzc2FnZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBvbkNsb3NlIEV2ZW50IC0gdG8gYmUgcmFpc2VkIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBjbG9zZWRcbiAgICogc2hvdWxkIHBhc3MgdHJ1ZSB3aGVuIE9LIGlzIHByZXNzZWQgYW5kIGZhbHNlIHdoZW4gY2FuY2VsIGlzIHByZXNzZWRcbiAgICovXG4gIEBPdXRwdXQoKSBvbkNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG5cbiAgLyoqXG4gICAqIHJhaXNlcyBjbG9zZSBFdmVudFxuICAgKiBAcGFyYW0gcmVzdWx0IHRydWUgd2hlbiBPSyBpcyBwcmVzc2VkIGFuZCBmYWxzZSB3aGVuIGNhbmNlbCBpcyBwcmVzc2VkXG4gICAqXG4gICAqL1xuICBPbkNsb3NlKHJlc3VsdCkge1xuICAgIHRoaXMub25DbG9zZS5lbWl0KHJlc3VsdCk7XG4gIH1cbn1cbiJdfQ==
|
@@ -23,45 +23,13 @@ MagicAlertComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicAlertComponent,
|
|
23
23
|
} }, styles: [".mg-message-background[_ngcontent-%COMP%]{background-color:#f5f5f5;width:40%;font-family:Open Sans,Helvetica Neue,Helvetica,Arial,sans-serif;padding:17px;border-radius:5px;text-align:center;margin-top:10%;margin-left:auto;margin-right:auto;border:1px solid gray}button[_ngcontent-%COMP%]{background-color:#8cd4f5;color:#fff;border:none;box-shadow:none;font-size:17px;font-weight:500;border-radius:5px;padding:10px 32px;margin:26px 5px 0;cursor:pointer}"] });
|
24
24
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicAlertComponent, [{
|
25
25
|
type: Component,
|
26
|
-
args: [{
|
27
|
-
selector: 'sample-magic-alert-component',
|
28
|
-
template: `<div>
|
26
|
+
args: [{ selector: 'sample-magic-alert-component', template: `<div>
|
29
27
|
<div class="mg-message-background">
|
30
28
|
<h2> {{title}}</h2>
|
31
29
|
<p>{{message}} </p>
|
32
30
|
|
33
31
|
<button (click)="OnClose()">OK</button>
|
34
32
|
</div>
|
35
|
-
</div>`,
|
36
|
-
styles: [`
|
37
|
-
.mg-message-background {
|
38
|
-
background-color: #F5F5F5;
|
39
|
-
text-align: center;
|
40
|
-
width: 40%;
|
41
|
-
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
42
|
-
padding: 17px;
|
43
|
-
border-radius: 5px;
|
44
|
-
text-align: center;
|
45
|
-
margin-top: 10% ;
|
46
|
-
margin-left: auto;
|
47
|
-
margin-right: auto;
|
48
|
-
border: 1px solid gray;
|
49
|
-
}
|
50
|
-
|
51
|
-
button {
|
52
|
-
background-color: #8CD4F5;
|
53
|
-
color: white;
|
54
|
-
border: none;
|
55
|
-
box-shadow: none;
|
56
|
-
font-size: 17px;
|
57
|
-
font-weight: 500;
|
58
|
-
-webkit-border-radius: 4px;
|
59
|
-
border-radius: 5px;
|
60
|
-
padding: 10px 32px;
|
61
|
-
margin: 26px 5px 0 5px;
|
62
|
-
cursor: pointer;
|
63
|
-
}
|
64
|
-
`]
|
65
|
-
}]
|
33
|
+
</div>`, styles: [".mg-message-background{background-color:#f5f5f5;width:40%;font-family:Open Sans,Helvetica Neue,Helvetica,Arial,sans-serif;padding:17px;border-radius:5px;text-align:center;margin-top:10%;margin-left:auto;margin-right:auto;border:1px solid gray}button{background-color:#8cd4f5;color:#fff;border:none;box-shadow:none;font-size:17px;font-weight:500;border-radius:5px;padding:10px 32px;margin:26px 5px 0;cursor:pointer}\n"] }]
|
66
34
|
}], null, null); })();
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvY29tcG9uZW50cy9tYWdpYy1hbGVydC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUE4Q3ZFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUyx1QkFBdUI7O3lPQUFwRCxtQkFBbUIsU0FBbkIsbUJBQW1CO3dEQUFuQixtQkFBbUI7UUF0Q25CLDJCQUFLLGFBQUEsU0FBQTtRQUVQLFlBQVM7UUFBQSxpQkFBSztRQUNuQix5QkFBRztRQUFBLFlBQVk7UUFBQSxpQkFBSTtRQUVuQixpQ0FBNEI7UUFBcEIsZ0dBQVMsYUFBUyxJQUFDO1FBQUMsa0JBQUU7UUFBQSxpQkFBUyxFQUFBLEVBQUE7O1FBSGxDLGVBQVM7UUFBVCx5Q0FBUztRQUNYLGVBQVk7UUFBWiwyQ0FBWTs7dUZBbUNSLG1CQUFtQjtjQXhDL0IsU0FBUzsyQkFDRSw4QkFBOEIsWUFDOUI7Ozs7Ozs7U0FPSCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZU1hZ2ljQWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2Jhc2UtbWFnaWMtYWxlcnQuY29tcG9uZW50JztcblxuXG4vKioqXG4gKiBUaGlzIGlzIHNhbXBsZSBjb21wb25lbnQgZm9yIHRoZSBhbGVydCBtZXNzYWdlXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NhbXBsZS1tYWdpYy1hbGVydC1jb21wb25lbnQnLFxuICB0ZW1wbGF0ZTogYDxkaXY+XG4gICAgPGRpdiBjbGFzcz1cIm1nLW1lc3NhZ2UtYmFja2dyb3VuZFwiPlxuICAgICAgPGgyPiB7e3RpdGxlfX08L2gyPlxuICAgICAgPHA+e3ttZXNzYWdlfX0gPC9wPlxuXG4gICAgICA8YnV0dG9uIChjbGljayk9XCJPbkNsb3NlKClcIj5PSzwvYnV0dG9uPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5gLFxuICBzdHlsZXM6IFtgXG4gICAgLm1nLW1lc3NhZ2UtYmFja2dyb3VuZCB7XG4gIGJhY2tncm91bmQtY29sb3I6ICNGNUY1RjU7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgd2lkdGg6IDQwJTtcbiAgZm9udC1mYW1pbHk6ICdPcGVuIFNhbnMnLCAnSGVsdmV0aWNhIE5ldWUnLCBIZWx2ZXRpY2EsIEFyaWFsLCBzYW5zLXNlcmlmO1xuICBwYWRkaW5nOiAxN3B4O1xuICBib3JkZXItcmFkaXVzOiA1cHg7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgbWFyZ2luLXRvcDogMTAlIDtcbiAgbWFyZ2luLWxlZnQ6IGF1dG87XG4gIG1hcmdpbi1yaWdodDogYXV0bztcbiAgYm9yZGVyOiAxcHggc29saWQgIGdyYXk7XG4gIH1cblxuICBidXR0b24ge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjOENENEY1O1xuICBjb2xvcjogd2hpdGU7XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgZm9udC1zaXplOiAxN3B4O1xuICBmb250LXdlaWdodDogNTAwO1xuICAtd2Via2l0LWJvcmRlci1yYWRpdXM6IDRweDtcbiAgYm9yZGVyLXJhZGl1czogNXB4O1xuICBwYWRkaW5nOiAxMHB4IDMycHg7XG4gIG1hcmdpbjogMjZweCA1cHggMCA1cHg7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgfVxuICBgXVxufSlcbmV4cG9ydCBjbGFzcyBNYWdpY0FsZXJ0Q29tcG9uZW50IGV4dGVuZHMgIEJhc2VNYWdpY0FsZXJ0Q29tcG9uZW50e1xuXG59XG4iXX0=
|
@@ -26,9 +26,7 @@ MagicConfirmationBoxComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicConfir
|
|
26
26
|
} }, styles: [".mg-message-background[_ngcontent-%COMP%]{background-color:#f5f5f5;width:40%;font-family:Open Sans,Helvetica Neue,Helvetica,Arial,sans-serif;padding:17px;border-radius:5px;text-align:center;margin-top:10%;margin-left:auto;margin-right:auto;border:1px solid gray}button[_ngcontent-%COMP%]{background-color:#8cd4f5;color:#fff;border:none;box-shadow:none;font-size:17px;font-weight:500;border-radius:5px;padding:10px 32px;margin:26px 5px 0;cursor:pointer}button.cancel[_ngcontent-%COMP%]{background-color:#c1c1c1}"] });
|
27
27
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicConfirmationBoxComponent, [{
|
28
28
|
type: Component,
|
29
|
-
args: [{
|
30
|
-
selector: 'sample-magic-confirmation-box',
|
31
|
-
template: `<div>
|
29
|
+
args: [{ selector: 'sample-magic-confirmation-box', template: `<div>
|
32
30
|
<div class="mg-message-background">
|
33
31
|
<h2> {{title}}</h2>
|
34
32
|
{{message}}
|
@@ -38,40 +36,6 @@ MagicConfirmationBoxComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicConfir
|
|
38
36
|
<button (click)="OnClose(true)">OK</button>
|
39
37
|
<button class="cancel" (click)="OnClose(false)">Cancel</button>
|
40
38
|
</div>
|
41
|
-
</div>`,
|
42
|
-
styles: [`
|
43
|
-
.mg-message-background {
|
44
|
-
background-color: #F5F5F5;
|
45
|
-
text-align: center;
|
46
|
-
width: 40%;
|
47
|
-
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
48
|
-
padding: 17px;
|
49
|
-
border-radius: 5px;
|
50
|
-
text-align: center;
|
51
|
-
margin-top: 10% ;
|
52
|
-
margin-left: auto;
|
53
|
-
margin-right: auto;
|
54
|
-
border: 1px solid gray;
|
55
|
-
}
|
56
|
-
|
57
|
-
button {
|
58
|
-
background-color: #8CD4F5;
|
59
|
-
color: white;
|
60
|
-
border: none;
|
61
|
-
box-shadow: none;
|
62
|
-
font-size: 17px;
|
63
|
-
font-weight: 500;
|
64
|
-
-webkit-border-radius: 4px;
|
65
|
-
border-radius: 5px;
|
66
|
-
padding: 10px 32px;
|
67
|
-
margin: 26px 5px 0 5px;
|
68
|
-
cursor: pointer;
|
69
|
-
}
|
70
|
-
|
71
|
-
button.cancel {
|
72
|
-
background-color: #C1C1C1;
|
73
|
-
}
|
74
|
-
`]
|
75
|
-
}]
|
39
|
+
</div>`, styles: [".mg-message-background{background-color:#f5f5f5;width:40%;font-family:Open Sans,Helvetica Neue,Helvetica,Arial,sans-serif;padding:17px;border-radius:5px;text-align:center;margin-top:10%;margin-left:auto;margin-right:auto;border:1px solid gray}button{background-color:#8cd4f5;color:#fff;border:none;box-shadow:none;font-size:17px;font-weight:500;border-radius:5px;padding:10px 32px;margin:26px 5px 0;cursor:pointer}button.cancel{background-color:#c1c1c1}\n"] }]
|
76
40
|
}], null, null); })();
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtY29uZmlybWF0aW9uLWJveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy91aS9jb21wb25lbnRzL21hZ2ljLWNvbmZpcm1hdGlvbi1ib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0FBb0QzRSxNQUFNLE9BQU8sNkJBQThCLFNBQVEseUJBQXlCOzsyUkFBL0QsNkJBQTZCLFNBQTdCLDZCQUE2QjtrRUFBN0IsNkJBQTZCO1FBN0M3QiwyQkFBSyxhQUFBLFNBQUE7UUFFUCxZQUFTO1FBQUEsaUJBQUs7UUFDbkIsWUFDQTtRQUFBLHFCQUFJLFNBQUE7UUFHSixpQ0FBZ0M7UUFBeEIsMEdBQVMsWUFBUSxJQUFJLENBQUMsSUFBQztRQUFDLGtCQUFFO1FBQUEsaUJBQVM7UUFDM0MsaUNBQWdEO1FBQXpCLDBHQUFTLFlBQVEsS0FBSyxDQUFDLElBQUM7UUFBQyx1QkFBTTtRQUFBLGlCQUFTLEVBQUEsRUFBQTs7UUFOMUQsZUFBUztRQUFULHlDQUFTO1FBQ2QsZUFDQTtRQURBLDRDQUNBOzt1RkF5Q08sNkJBQTZCO2NBL0N6QyxTQUFTOzJCQUNFLCtCQUErQixZQUMvQjs7Ozs7Ozs7OztTQVVIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlTWFnaWNDb25maXJtQ29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLW1hZ2ljLWNvbmZpcm0uY29tcG9uZW50JztcblxuLyoqKlxuICogVGhpcyBpcyBzYW1wbGUgY29tcG9uZW50IGZvciB0aGUgY29uZmlybWF0aW9uIGJveFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYW1wbGUtbWFnaWMtY29uZmlybWF0aW9uLWJveCcsXG4gIHRlbXBsYXRlOiBgPGRpdj5cbiAgICA8ZGl2IGNsYXNzPVwibWctbWVzc2FnZS1iYWNrZ3JvdW5kXCI+XG4gICAgICA8aDI+IHt7dGl0bGV9fTwvaDI+XG4gICAgICB7e21lc3NhZ2V9fVxuICAgICAgPGJyPlxuICAgICAgPGJyPlxuXG4gICAgICA8YnV0dG9uIChjbGljayk9XCJPbkNsb3NlKHRydWUpXCI+T0s8L2J1dHRvbj5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJjYW5jZWxcIiAoY2xpY2spPVwiT25DbG9zZShmYWxzZSlcIj5DYW5jZWw8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+YCxcbiAgc3R5bGVzOiBbYFxuICAgIC5tZy1tZXNzYWdlLWJhY2tncm91bmQge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjRjVGNUY1O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHdpZHRoOiA0MCU7XG4gIGZvbnQtZmFtaWx5OiAnT3BlbiBTYW5zJywgJ0hlbHZldGljYSBOZXVlJywgSGVsdmV0aWNhLCBBcmlhbCwgc2Fucy1zZXJpZjtcbiAgcGFkZGluZzogMTdweDtcbiAgYm9yZGVyLXJhZGl1czogNXB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6IDEwJSA7XG4gIG1hcmdpbi1sZWZ0OiBhdXRvO1xuICBtYXJnaW4tcmlnaHQ6IGF1dG87XG4gIGJvcmRlcjogMXB4IHNvbGlkICBncmF5O1xuICB9XG5cbiAgYnV0dG9uIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogIzhDRDRGNTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXI6IG5vbmU7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGZvbnQtc2l6ZTogMTdweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgLXdlYmtpdC1ib3JkZXItcmFkaXVzOiA0cHg7XG4gIGJvcmRlci1yYWRpdXM6IDVweDtcbiAgcGFkZGluZzogMTBweCAzMnB4O1xuICBtYXJnaW46IDI2cHggNXB4IDAgNXB4O1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIH1cbiAgICBcbiAgICBidXR0b24uY2FuY2VsIHtcbiAgICAgIGJhY2tncm91bmQtY29sb3I6ICNDMUMxQzE7XG4gICAgfVxuICBgXVxufSlcbmV4cG9ydCBjbGFzcyBNYWdpY0NvbmZpcm1hdGlvbkJveENvbXBvbmVudCBleHRlbmRzIEJhc2VNYWdpY0NvbmZpcm1Db21wb25lbnQge1xuXG59XG4iXX0=
|
@@ -4,6 +4,11 @@ import { TaskMagicService } from '../../services/task.magics.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
import * as i1 from "../../services/task.magics.service";
|
6
6
|
export class NonMagicControlDirective {
|
7
|
+
set magic(val) {
|
8
|
+
this.id = val;
|
9
|
+
this.selector = 'NonMagicControl';
|
10
|
+
}
|
11
|
+
;
|
7
12
|
constructor(_task, element, renderer, vcRef) {
|
8
13
|
this._task = _task;
|
9
14
|
this.element = element;
|
@@ -13,11 +18,6 @@ export class NonMagicControlDirective {
|
|
13
18
|
this.eventsOnlyVal = false;
|
14
19
|
this.htmlElement = this.element.nativeElement;
|
15
20
|
}
|
16
|
-
set magic(val) {
|
17
|
-
this.id = val;
|
18
|
-
this.selector = 'NonMagicControl';
|
19
|
-
}
|
20
|
-
;
|
21
21
|
get task() {
|
22
22
|
return this._task;
|
23
23
|
}
|
@@ -46,4 +46,4 @@ NonMagicControlDirective.ɵdir = i0.ɵɵdefineDirective({ type: NonMagicControlD
|
|
46
46
|
type: Input,
|
47
47
|
args: ['NonMagicControl']
|
48
48
|
}] }); })();
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTm9uTWFnaWNDb250cm9sRGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvZGlyZWN0aXZlcy9Ob25NYWdpY0NvbnRyb2xEaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFVLFNBQVMsRUFBRSxnQkFBZ0IsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFFakQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7OztBQVVwRSxNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLElBQ0ksS0FBSyxDQUFDLEdBQUc7UUFDWCxJQUFJLENBQUMsRUFBRSxHQUFHLEdBQUcsQ0FBQztRQUNkLElBQUksQ0FBQyxRQUFRLEdBQUcsaUJBQWlCLENBQUM7SUFDcEMsQ0FBQztJQUFBLENBQUM7SUFzQ0YsWUFBc0IsS0FBdUIsRUFDdkIsT0FBbUIsRUFDbkIsUUFBbUIsRUFDbkIsS0FBdUI7UUFIdkIsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFDdkIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQUNuQixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLFVBQUssR0FBTCxLQUFLLENBQWtCO1FBNUJyQyxrQkFBYSxHQUFtQyxFQUFFLENBQUM7UUFlcEQsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFlM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQztJQUNoRCxDQUFDO0lBTUQsSUFBSSxJQUFJO1FBQ04sT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFLUyxTQUFTO1FBR2pCLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDeEQsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDN0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3hFLENBQUMsQ0FBQyxDQUFDO0lBRUwsQ0FBQztJQUtPLE9BQU87UUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsd0JBQXdCLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4RSxLQUFLLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztJQUM1QixDQUFDO0lBS0QsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDOztnR0FyRlUsd0JBQXdCOzZEQUF4Qix3QkFBd0I7dUZBQXhCLHdCQUF3QjtjQUpwQyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjthQUM5QjttSkFJSyxLQUFLO2tCQURSLEtBQUs7bUJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkluaXQsIFJlbmRlcmVyMiwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Z2V0R3VpRXZlbnRPYmp9IGZyb20gJ0BtYWdpYy14cGEvZW5naW5lJztcclxuaW1wb3J0IHtUYXNrQmFzZU1hZ2ljQ29tcG9uZW50fSBmcm9tICcuLi90YXNrLWJhc2UubWFnaWMuY29tcG9uZW50JztcclxuaW1wb3J0IHtUYXNrTWFnaWNTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy90YXNrLm1hZ2ljcy5zZXJ2aWNlJztcclxuaW1wb3J0IHtTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xyXG5cclxuLyoqXHJcbiAqIFJlc3BvbnNpYmxlIGZvciBjb25uZWN0aW5nIEhUTUwgZWxlbWVudHMgdG8gdGhlIE1hZ2ljIFdlYkNsaWVudCBlbmdpbmUgc2hvd2luZyBpdCBpcyBub3QgTWFnaWMgQ29udHJvbCBidXQgYSBEdW1teSBjb250cm9sIHdoaWNoIGlzIHVzZWQgdG8gbm90aWZ5IG9ubHkgcmVjZWVpdmUgZm9jdXMgZXZlbnQgZm9yIG5vd1xyXG4gKi9cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbTm9uTWFnaWNDb250cm9sXSdcclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBOb25NYWdpY0NvbnRyb2xEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgnTm9uTWFnaWNDb250cm9sJylcclxuICBzZXQgbWFnaWModmFsKSB7XHJcbiAgICB0aGlzLmlkID0gdmFsO1xyXG4gICAgdGhpcy5zZWxlY3RvciA9ICdOb25NYWdpY0NvbnRyb2wnO1xyXG4gIH07XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBIVE1MIGVsZW1lbnQgY29ubmVjdGVkIHRvIHRoaXMgZGlyZWN0aXZlXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIGh0bWxFbGVtZW50OiBIVE1MRWxlbWVudDtcclxuICAvKipcclxuICAgKiBNYWdpYydzIGNvbXBvbmVudCBoYW5kbGluZyB0aGlzIGNvbnRyb2xcclxuICAgKi9cclxuICBwdWJsaWMgY29tcG9uZW50OiBUYXNrQmFzZU1hZ2ljQ29tcG9uZW50O1xyXG4gIC8qKlxyXG4gICAqIENvbGxlY3Rpb24gb2YgZXZlbnQgaGFuZGxlcnMgZm9yIHRoaXMgZWxlbWVudFxyXG4gICAqL1xyXG4gIHByaXZhdGUgZXZlbnRIYW5kbGVyczogeyBba2V5OiBzdHJpbmddOiAoKSA9PiB2b2lkOyB9ID0ge307XHJcbiAgLyoqXHJcbiAgICogSWQgb2YgdGhpcyBlbGVtZW50XHJcbiAgICovXHJcbiAgcHVibGljIGlkOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQGlnbm9yZVxyXG4gICAqL1xyXG4gIHByb3RlY3RlZCBzZWxlY3Rvcjogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEBpZ25vcmVcclxuICAgKi9cclxuICBzdWJzY3JpYmVSZWZyZXNoRG9tOiBTdWJzY3JpcHRpb247XHJcblxyXG5cclxuICBwdWJsaWMgZXZlbnRzT25seVZhbCA9IGZhbHNlO1xyXG5cclxuXHJcbiAgLyoqXHJcbiAgICpcclxuICAgKiBAcGFyYW0gX3Rhc2sgVGhlIHRhc2sgc2VydmljZVxyXG4gICAqIEBwYXJhbSBlbGVtZW50IFRoZSBlbGVtZW50IGZvciB3aGljaCB0aGUgZGlyZWN0aXZlIGlzIGFwcGxpZWRcclxuICAgKiBAcGFyYW0gcmVuZGVyZXIgUmVuZGVyZXIgZm9yIHRoZSBlbGVtZW50XHJcbiAgICogQHBhcmFtIHZjUmVmXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIF90YXNrOiBUYXNrTWFnaWNTZXJ2aWNlLFxyXG4gICAgICAgICAgICAgIHByb3RlY3RlZCBlbGVtZW50OiBFbGVtZW50UmVmLFxyXG4gICAgICAgICAgICAgIHByb3RlY3RlZCByZW5kZXJlcjogUmVuZGVyZXIyLFxyXG4gICAgICAgICAgICAgIHByb3RlY3RlZCB2Y1JlZjogVmlld0NvbnRhaW5lclJlZikge1xyXG5cclxuICAgIHRoaXMuaHRtbEVsZW1lbnQgPSB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudDtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEdldCB0aGUgdGFzayBzZXJ2aWNlXHJcbiAgICogQHJldHVybnNcclxuICAgKi9cclxuICBnZXQgdGFzaygpOiBUYXNrTWFnaWNTZXJ2aWNlIHtcclxuICAgIHJldHVybiB0aGlzLl90YXNrO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmVnaXN0ZXIgdG8gdGhlIGV2ZW50cyB0aGlzIGVsZW1lbnQgbWF5IG5lZWQgdG8gaGFuZGxlXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIHJlZ0V2ZW50cygpIHtcclxuXHJcbiAgICAvLyBIYW5kbGUgZXZlbnRzIGZvciB3aGljaCBldmVudCBoYW5kbGVyIG1heSBiZSByZW1vdmVkIGFuZCByZXN0b3JlZFxyXG4gICAgdGhpcy5ldmVudEhhbmRsZXJzWydmb2N1c2luJ10gPSB0aGlzLk9uRm9jdXMuYmluZCh0aGlzKTtcclxuICAgIE9iamVjdC5rZXlzKHRoaXMuZXZlbnRIYW5kbGVycykuZm9yRWFjaCgoa2V5KSA9PiB7XHJcbiAgICAgICB0aGlzLnJlbmRlcmVyLmxpc3Rlbih0aGlzLmh0bWxFbGVtZW50LCBrZXksIHRoaXMuZXZlbnRIYW5kbGVyc1trZXldKTtcclxuICAgIH0pO1xyXG5cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEhhbmRsZSBmb2N1cyBldmVudFxyXG4gICAqL1xyXG4gIHByaXZhdGUgT25Gb2N1cygpIHtcclxuICAgIHRoaXMudGFzay5pbnNlcnRFdmVudChnZXRHdWlFdmVudE9iaignZm9jdXNPbk5vbk1hZ2ljQ29udHJvbCcsICcnLCAtMSkpO1xyXG4gICAgZXZlbnQuY2FuY2VsQnViYmxlID0gdHJ1ZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEluaXRpYWxpemUgdGhpcyBvYmplY3RcclxuICAgKi9cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMucmVnRXZlbnRzKCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
@@ -1,19 +1,86 @@
|
|
1
|
-
import { Directive, HostListener } from '@angular/core';
|
1
|
+
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
|
2
2
|
import { MagicDirective } from '../magic.directive';
|
3
|
+
import { TaskMagicService } from "../../../services/task.magics.service";
|
4
|
+
import { getGuiEventObj } from "@magic-xpa/engine";
|
5
|
+
import { filter } from "rxjs/operators";
|
6
|
+
import { CommandType, HtmlProperties } from "@magic-xpa/gui";
|
3
7
|
import * as i0 from "@angular/core";
|
4
8
|
import * as i1 from "../magic.directive";
|
9
|
+
import * as i2 from "../../../services/task.magics.service";
|
5
10
|
export class CheckboxMagicDirective {
|
6
|
-
constructor(magicDirective) {
|
11
|
+
constructor(magicDirective, el, task) {
|
7
12
|
this.magicDirective = magicDirective;
|
13
|
+
this.el = el;
|
14
|
+
this.task = task;
|
15
|
+
this.threeState = false;
|
16
|
+
this.subscribeRefreshDom = null;
|
17
|
+
this.isIndeterminate = false;
|
8
18
|
}
|
9
19
|
onChange($event) {
|
10
|
-
|
20
|
+
if (this.threeState) {
|
21
|
+
this.handleThreeState();
|
22
|
+
}
|
23
|
+
else {
|
24
|
+
this.magicDirective.task.onCheckChanged($event, this.magicDirective.id, +this.magicDirective.rowId);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
ngOnInit() {
|
28
|
+
if (this.threeState) {
|
29
|
+
let guiEvent = getGuiEventObj("setAsThreeState", this.magicDirective.id, +this.magicDirective.rowId);
|
30
|
+
this.task.insertEvent(guiEvent);
|
31
|
+
this.el.nativeElement.indeterminate = this.isIndeterminate = this.task.getProperty(this.magicDirective.id, HtmlProperties.CheckBoxIndeterminate, this.magicDirective.rowId);
|
32
|
+
this.regUpdatesUI();
|
33
|
+
}
|
34
|
+
}
|
35
|
+
regUpdatesUI() {
|
36
|
+
this.subscribeRefreshDom = this.task
|
37
|
+
.refreshDom.pipe(filter(c => this.magicDirective.IsSameElement(c)))
|
38
|
+
.subscribe(a => {
|
39
|
+
let command = a;
|
40
|
+
try {
|
41
|
+
this.handleCommand(command);
|
42
|
+
}
|
43
|
+
catch (ex) {
|
44
|
+
console.dir(ex);
|
45
|
+
}
|
46
|
+
});
|
47
|
+
}
|
48
|
+
handleCommand(command) {
|
49
|
+
if (command.CommandType == CommandType.SET_PROPERTY &&
|
50
|
+
command.Operation == HtmlProperties.CheckBoxIndeterminate) {
|
51
|
+
this.isIndeterminate = this.el.nativeElement.indeterminate = command.obj1;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
handleThreeState() {
|
55
|
+
let value = '';
|
56
|
+
let prevCheckedValue = this.task.getValue(this.magicDirective.id, this.magicDirective.rowId);
|
57
|
+
const checkbox = this.el.nativeElement;
|
58
|
+
if (this.isIndeterminate) {
|
59
|
+
checkbox.checked = false;
|
60
|
+
checkbox.indeterminate = false;
|
61
|
+
value = 'unchecked';
|
62
|
+
}
|
63
|
+
else if (prevCheckedValue) {
|
64
|
+
checkbox.checked = false;
|
65
|
+
checkbox.indeterminate = true;
|
66
|
+
value = 'indeterminate';
|
67
|
+
}
|
68
|
+
else if (!prevCheckedValue) {
|
69
|
+
checkbox.checked = true;
|
70
|
+
checkbox.indeterminate = false;
|
71
|
+
value = 'checked';
|
72
|
+
}
|
73
|
+
this.magicDirective.task.onCheckChanged(value, this.magicDirective.id, +this.magicDirective.rowId);
|
74
|
+
}
|
75
|
+
ngOnDestroy() {
|
76
|
+
if (this.subscribeRefreshDom !== null)
|
77
|
+
this.subscribeRefreshDom.unsubscribe();
|
11
78
|
}
|
12
79
|
}
|
13
|
-
CheckboxMagicDirective.ɵfac = function CheckboxMagicDirective_Factory(t) { return new (t || CheckboxMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective)); };
|
80
|
+
CheckboxMagicDirective.ɵfac = function CheckboxMagicDirective_Factory(t) { return new (t || CheckboxMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i2.TaskMagicService)); };
|
14
81
|
CheckboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: CheckboxMagicDirective, selectors: [["input", "type", "checkbox", "magic", "", 3, "noFormControl", ""]], hostBindings: function CheckboxMagicDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
15
82
|
i0.ɵɵlistener("change", function CheckboxMagicDirective_change_HostBindingHandler($event) { return ctx.onChange($event); });
|
16
|
-
} } });
|
83
|
+
} }, inputs: { threeState: "threeState" } });
|
17
84
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CheckboxMagicDirective, [{
|
18
85
|
type: Directive,
|
19
86
|
args: [{
|
@@ -21,8 +88,10 @@ CheckboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: CheckboxMagicDirec
|
|
21
88
|
input[type=checkbox][magic]:not([noFormControl])
|
22
89
|
`,
|
23
90
|
}]
|
24
|
-
}], function () { return [{ type: i1.MagicDirective }]; }, {
|
91
|
+
}], function () { return [{ type: i1.MagicDirective }, { type: i0.ElementRef }, { type: i2.TaskMagicService }]; }, { threeState: [{
|
92
|
+
type: Input
|
93
|
+
}], onChange: [{
|
25
94
|
type: HostListener,
|
26
95
|
args: ['change', ['$event']]
|
27
96
|
}] }); })();
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/checkbox.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, HostListener, Input} from '@angular/core';\r\nimport { MagicDirective } from '../magic.directive';\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {getGuiEventObj, IGuiEvent} from \"@magic-xpa/engine\";\r\nimport {filter} from \"rxjs/operators\";\r\nimport {CommandType, GuiCommand, HtmlProperties} from \"@magic-xpa/gui\";\r\n\r\n\r\n/**\r\n * Directive for checkboxes, to handle the 'change' event\r\n */\r\n@Directive({\r\n  selector:\r\n    `\r\n    input[type=checkbox][magic]:not([noFormControl])\r\n`,\r\n})\r\nexport class CheckboxMagicDirective {\r\n\r\n  @Input() threeState: boolean = false;\r\n  private subscribeRefreshDom: any = null;\r\n  private isIndeterminate: boolean = false;\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor(    protected magicDirective: MagicDirective,\r\n                  private el: ElementRef,\r\n                  protected task: TaskMagicService,) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Handles the Checkbox 'change' event - pass it to the Magic engine\r\n   */\r\n  @HostListener('change', ['$event'])\r\n  onChange($event) {\r\n    if(this.threeState) {\r\n      this.handleThreeState();\r\n    }\r\n    else {\r\n      this.magicDirective.task.onCheckChanged($event, this.magicDirective.id, +this.magicDirective.rowId);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    if(this.threeState){\r\n      let guiEvent: IGuiEvent = getGuiEventObj(\"setAsThreeState\", this.magicDirective.id, +this.magicDirective.rowId);\r\n      this.task.insertEvent(guiEvent);\r\n      this.el.nativeElement.indeterminate = this.isIndeterminate = this.task.getProperty(this.magicDirective.id, HtmlProperties.CheckBoxIndeterminate, this.magicDirective.rowId);\r\n\r\n      this.regUpdatesUI();\r\n    }\r\n  }\r\n\r\n  private regUpdatesUI() {\r\n    this.subscribeRefreshDom = this.task\r\n      .refreshDom.pipe(filter(c => this.magicDirective.IsSameElement(c)))\r\n      .subscribe(a => {\r\n          let command: GuiCommand = a;\r\n          try {\r\n            this.handleCommand(command);\r\n          } catch (ex) {\r\n            console.dir(ex);\r\n          }\r\n        }\r\n      );\r\n  }\r\n\r\n  handleCommand(command: GuiCommand){\r\n    if (command.CommandType == CommandType.SET_PROPERTY &&\r\n      command.Operation == HtmlProperties.CheckBoxIndeterminate) {\r\n      this.isIndeterminate = this.el.nativeElement.indeterminate = command.obj1;\r\n    }\r\n  }\r\n\r\n  private handleThreeState() {\r\n\r\n    let value : string = '';\r\n    let prevCheckedValue = this.task.getValue(this.magicDirective.id, this.magicDirective.rowId);\r\n\r\n    const checkbox = this.el.nativeElement;\r\n\r\n    if (this.isIndeterminate) {\r\n      checkbox.checked = false;\r\n      checkbox.indeterminate = false;\r\n      value = 'unchecked';\r\n    } else if (prevCheckedValue) {\r\n      checkbox.checked = false;\r\n      checkbox.indeterminate = true;\r\n      value = 'indeterminate';\r\n    } else if (!prevCheckedValue) {\r\n      checkbox.checked = true;\r\n      checkbox.indeterminate = false;\r\n      value = 'checked';\r\n    }\r\n\r\n    // @ts-ignore\r\n    this.magicDirective.task.onCheckChanged(value, this.magicDirective.id, +this.magicDirective.rowId);\r\n\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n    if(this.subscribeRefreshDom !== null)\r\n      this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n\r\n}\r\n\r\n\r\n"]}
|
@@ -1,14 +1,24 @@
|
|
1
1
|
import { Directive, HostListener } from '@angular/core';
|
2
2
|
import { MagicDirective } from '../magic.directive';
|
3
|
+
import { HtmlProperties } from "@magic-xpa/gui";
|
4
|
+
import { filter } from "rxjs/operators";
|
3
5
|
import * as i0 from "@angular/core";
|
4
6
|
import * as i1 from "../magic.directive";
|
5
7
|
export class ComboboxMagicDirective {
|
6
8
|
constructor(magicDirective) {
|
7
9
|
this.magicDirective = magicDirective;
|
10
|
+
this.magicDirective.task.refreshDom.pipe(filter(c => this.magicDirective.IsSameElement(c))).subscribe(value => {
|
11
|
+
let command = value;
|
12
|
+
if (command.Operation === HtmlProperties.ItemsList)
|
13
|
+
this.onComboboxItemsListChanged();
|
14
|
+
});
|
8
15
|
}
|
9
16
|
onChange($event) {
|
10
17
|
this.magicDirective.task.onComboboxSelectionChanged($event, this.magicDirective.id, +this.magicDirective.rowId);
|
11
18
|
}
|
19
|
+
onComboboxItemsListChanged() {
|
20
|
+
this.magicDirective.task.refreshView();
|
21
|
+
}
|
12
22
|
}
|
13
23
|
ComboboxMagicDirective.ɵfac = function ComboboxMagicDirective_Factory(t) { return new (t || ComboboxMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective)); };
|
14
24
|
ComboboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: ComboboxMagicDirective, selectors: [["select", "magic", "", 3, "multiple", ""]], hostBindings: function ComboboxMagicDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
@@ -23,4 +33,4 @@ ComboboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: ComboboxMagicDirec
|
|
23
33
|
type: HostListener,
|
24
34
|
args: ['change', ['$event']]
|
25
35
|
}] }); })();
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYm9ib3gubWFnaWMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvZGlyZWN0aXZlcy9tYWdpYy9jb21ib2JveC5tYWdpYy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3BELE9BQU8sRUFBYyxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVV4QyxNQUFNLE9BQU8sc0JBQXNCO0lBRWpDLFlBQXNCLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUlsRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDNUcsSUFBSSxPQUFPLEdBQWUsS0FBSyxDQUFDO1lBQ2hDLElBQUksT0FBTyxDQUFDLFNBQVMsS0FBSyxjQUFjLENBQUMsU0FBUztnQkFDaEQsSUFBSSxDQUFDLDBCQUEwQixFQUFFLENBQUM7UUFDdEMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBTUQsUUFBUSxDQUFDLE1BQU07UUFDYixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xILENBQUM7SUFLRCwwQkFBMEI7UUFDeEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDekMsQ0FBQzs7NEZBMUJVLHNCQUFzQjsyREFBdEIsc0JBQXNCOzJHQUF0QixvQkFBZ0I7O3VGQUFoQixzQkFBc0I7Y0FKbEMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFDTiwrQkFBK0I7YUFDakM7aUVBa0JBLFFBQVE7a0JBRFAsWUFBWTttQkFBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYWdpY0RpcmVjdGl2ZSB9IGZyb20gJy4uL21hZ2ljLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEd1aUNvbW1hbmQsIEh0bWxQcm9wZXJ0aWVzIH0gZnJvbSBcIkBtYWdpYy14cGEvZ3VpXCI7XHJcbmltcG9ydCB7IGZpbHRlciB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xyXG5cclxuXHJcbi8qKlxyXG4gKiBEaXJlY3RpdmUgZm9yIGNvbWJvYm94ZXMsIHRvIGhhbmRsZSB0aGUgJ2NoYW5nZScgZXZlbnRcclxuICovXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOlxyXG4gICAgYHNlbGVjdFttYWdpY106bm90KFttdWx0aXBsZV0pYCxcclxuIH0pXHJcbmV4cG9ydCBjbGFzcyBDb21ib2JveE1hZ2ljRGlyZWN0aXZle1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgbWFnaWNEaXJlY3RpdmU6IE1hZ2ljRGlyZWN0aXZlKSB7XHJcbiAgICAvLyBzdWJjcmliZSB0byByZWZyZXNoRG9tLiBUaGlzIGlzIGEgc3BlY2lhbCBjYXNlIGZvciBuYXRpdmUgc2VsZWN0IEhUTUwgY29udHJvbC5cclxuICAgIC8vIHRvIHJlZnJlc2ggdGhlIHNlbGVjdGVkIHByb3BlcnR5LiBFbHNlIGJ5IGRlZmF1bHQsIEhUTUwgZWxlbWVudCBkb2Vzbid0IGdldCByZWZyZXNoZWQgYXMgcGVyXHJcbiAgICAvLyBzZWxlY3RlZCB2YWx1ZSBhbmQgMXN0IGVsZW1lbnQgcmVtYWlucyBzZWxlY3RlZC5cclxuICAgIHRoaXMubWFnaWNEaXJlY3RpdmUudGFzay5yZWZyZXNoRG9tLnBpcGUoZmlsdGVyKGMgPT4gdGhpcy5tYWdpY0RpcmVjdGl2ZS5Jc1NhbWVFbGVtZW50KGMpKSkuc3Vic2NyaWJlKHZhbHVlID0+e1xyXG4gICAgICBsZXQgY29tbWFuZDogR3VpQ29tbWFuZCA9IHZhbHVlO1xyXG4gICAgICBpZiAoY29tbWFuZC5PcGVyYXRpb24gPT09IEh0bWxQcm9wZXJ0aWVzLkl0ZW1zTGlzdClcclxuICAgICAgICB0aGlzLm9uQ29tYm9ib3hJdGVtc0xpc3RDaGFuZ2VkKCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEhhbmRsZXMgdGhlIENvbWJvYm94ICdjaGFuZ2UnIGV2ZW50IC0gcGFzcyBpdCB0byB0aGUgTWFnaWMgZW5naW5lXHJcbiAgICovXHJcbiAgQEhvc3RMaXN0ZW5lcignY2hhbmdlJywgWyckZXZlbnQnXSlcclxuICBvbkNoYW5nZSgkZXZlbnQpIHtcclxuICAgIHRoaXMubWFnaWNEaXJlY3RpdmUudGFzay5vbkNvbWJvYm94U2VsZWN0aW9uQ2hhbmdlZCgkZXZlbnQsIHRoaXMubWFnaWNEaXJlY3RpdmUuaWQsICt0aGlzLm1hZ2ljRGlyZWN0aXZlLnJvd0lkKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFRvIHJlZnJlc2ggQ29tYm9ib3ggc2VsZWN0aW9uIGFzIHBlciBzZWxlY3RlZCBwcm9wZXJ0eS5cclxuICAgKi9cclxuICBvbkNvbWJvYm94SXRlbXNMaXN0Q2hhbmdlZCgpOiB2b2lkIHtcclxuICAgIHRoaXMubWFnaWNEaXJlY3RpdmUudGFzay5yZWZyZXNoVmlldygpO1xyXG4gIH1cclxufVxyXG5cclxuXHJcbiJdfQ==
|
package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs
CHANGED
@@ -1,18 +1,44 @@
|
|
1
1
|
import { Directive, ElementRef, forwardRef, HostListener, Renderer2 } from "@angular/core";
|
2
2
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
3
|
+
import { MagicDirective } from "../../../magic.directive";
|
4
|
+
import { TaskMagicService } from "../../../../../services/task.magics.service";
|
5
|
+
import { Environment, LastFocusedManager } from "@magic-xpa/engine";
|
3
6
|
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../../../magic.directive";
|
8
|
+
import * as i2 from "../../../../../services/task.magics.service";
|
4
9
|
export const DATE_VALUE_ACCESSOR = {
|
5
10
|
provide: NG_VALUE_ACCESSOR,
|
6
11
|
useExisting: forwardRef(() => DateValueAccessor),
|
7
12
|
multi: true
|
8
13
|
};
|
9
14
|
export class DateValueAccessor {
|
10
|
-
|
15
|
+
onBlurEvent(event) {
|
16
|
+
const century = Environment.Instance.GetCentury(LastFocusedManager.Instance.getCurrTask().getCompIdx());
|
17
|
+
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
18
|
+
this.formatDateWithCentury(event.target.value, century, control);
|
19
|
+
}
|
20
|
+
constructor(renderer, elementRef, magicDir, _task) {
|
11
21
|
this.renderer = renderer;
|
12
22
|
this.elementRef = elementRef;
|
23
|
+
this.magicDir = magicDir;
|
24
|
+
this._task = _task;
|
13
25
|
this.onChange = (_) => { };
|
14
26
|
this.onTouched = () => { };
|
15
27
|
}
|
28
|
+
formatDateWithCentury(userInput, century, control) {
|
29
|
+
const separator = userInput.includes('/') ? '/' : "-";
|
30
|
+
let centuryVal = parseInt(century.toString().slice(0, 2));
|
31
|
+
if (userInput.length == 0)
|
32
|
+
return;
|
33
|
+
const dateArray = userInput.split(separator);
|
34
|
+
const day = Number(dateArray[2]);
|
35
|
+
const month = Number(dateArray[1]);
|
36
|
+
const year = Number(dateArray[0]);
|
37
|
+
let updatedYear = year.toString().length === 2 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '' + year :
|
38
|
+
year.toString().length === 1 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '0' + year :
|
39
|
+
year;
|
40
|
+
control.setValue(new Date(`${updatedYear}${separator}${month}${separator}${day}`));
|
41
|
+
}
|
16
42
|
writeValue(value) {
|
17
43
|
if (!value) {
|
18
44
|
this.renderer.setProperty(this.elementRef.nativeElement, "value", null);
|
@@ -32,9 +58,9 @@ export class DateValueAccessor {
|
|
32
58
|
this.renderer.setProperty(this.elementRef.nativeElement, "disabled", isDisabled);
|
33
59
|
}
|
34
60
|
}
|
35
|
-
DateValueAccessor.ɵfac = function DateValueAccessor_Factory(t) { return new (t || DateValueAccessor)(i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ElementRef)); };
|
61
|
+
DateValueAccessor.ɵfac = function DateValueAccessor_Factory(t) { return new (t || DateValueAccessor)(i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MagicDirective), i0.ɵɵdirectiveInject(i2.TaskMagicService)); };
|
36
62
|
DateValueAccessor.ɵdir = i0.ɵɵdefineDirective({ type: DateValueAccessor, selectors: [["", "dateInput", ""]], hostBindings: function DateValueAccessor_HostBindings(rf, ctx) { if (rf & 1) {
|
37
|
-
i0.ɵɵlistener("input", function DateValueAccessor_input_HostBindingHandler($event) { return ctx.onChange($event.target.valueAsDate); })("blur", function DateValueAccessor_blur_HostBindingHandler() { return ctx.
|
63
|
+
i0.ɵɵlistener("input", function DateValueAccessor_input_HostBindingHandler($event) { return ctx.onChange($event.target.valueAsDate); })("blur", function DateValueAccessor_blur_HostBindingHandler($event) { return ctx.onBlurEvent($event); });
|
38
64
|
} }, features: [i0.ɵɵProvidersFeature([DATE_VALUE_ACCESSOR])] });
|
39
65
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DateValueAccessor, [{
|
40
66
|
type: Directive,
|
@@ -42,11 +68,14 @@ DateValueAccessor.ɵdir = i0.ɵɵdefineDirective({ type: DateValueAccessor, sele
|
|
42
68
|
selector: "[dateInput]",
|
43
69
|
providers: [DATE_VALUE_ACCESSOR]
|
44
70
|
}]
|
45
|
-
}], function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, { onChange: [{
|
71
|
+
}], function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.MagicDirective }, { type: i2.TaskMagicService }]; }, { onChange: [{
|
46
72
|
type: HostListener,
|
47
73
|
args: ["input", ["$event.target.valueAsDate"]]
|
48
74
|
}], onTouched: [{
|
49
75
|
type: HostListener,
|
50
76
|
args: ["blur", []]
|
77
|
+
}], onBlurEvent: [{
|
78
|
+
type: HostListener,
|
79
|
+
args: ['blur', ['$event']]
|
51
80
|
}] }); })();
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.cva.directive.js","sourceRoot":"","sources":["../../../../../../../../../../projects/angular/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  forwardRef,\r\n  HostListener,\r\n  Renderer2\r\n} from \"@angular/core\";\r\nimport {AbstractControl, ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {MagicDirective} from \"../../../magic.directive\";\r\nimport {TaskMagicService} from \"../../../../../services/task.magics.service\";\r\nimport {Environment, LastFocusedManager} from \"@magic-xpa/engine\";\r\n\r\nexport const DATE_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => DateValueAccessor),\r\n  multi: true\r\n};\r\n\r\n/**\r\n * The accessor for writing a value and listening to changes on a date input element\r\n *\r\n *  ### Example\r\n *  `<input type=\"date\" name=\"birthday\" ngModel dateInput>`\r\n *  OR\r\n *  `<input type=\"date\" formControlName=\"birthday\" dateInput>`\r\n */\r\n@Directive({\r\n  selector: \"[dateInput]\",\r\n  providers: [DATE_VALUE_ACCESSOR]\r\n})\r\nexport class DateValueAccessor implements ControlValueAccessor {\r\n  @HostListener(\"input\", [\"$event.target.valueAsDate\"])\r\n  onChange = (_: any) => {};\r\n  @HostListener(\"blur\", [])\r\n  onTouched = () => {};\r\n\r\n  @HostListener('blur', ['$event'])\r\n  public onBlurEvent(event) {\r\n    const century = Environment.Instance.GetCentury(LastFocusedManager.Instance.getCurrTask().getCompIdx());\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);\r\n\r\n    this.formatDateWithCentury(event.target.value, century, control);\r\n  }\r\n\r\n  constructor(private renderer: Renderer2, private elementRef: ElementRef,\r\n              protected magicDir: MagicDirective ,\r\n              protected _task: TaskMagicService) {}\r\n\r\n\r\n  /** Format year, if user enters 2 digits instead of 4 digits as per the century given in Magic.ini file */\r\n  formatDateWithCentury(userInput:string, century:number, control: AbstractControl){\r\n    const separator = userInput.includes('/')?'/':\"-\";\r\n    let centuryVal = parseInt(century.toString().slice(0, 2));\r\n    if(userInput.length == 0)\r\n      return ;\r\n\r\n    const dateArray: string[] = userInput.split(separator);\r\n    const day = Number(dateArray[2]);\r\n    const month = Number(dateArray[1]);\r\n    const year = Number(dateArray[0]);\r\n\r\n    let updatedYear = year.toString().length === 2 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '' + year :\r\n      year.toString().length === 1 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '0' + year :\r\n        year;\r\n\r\n    control.setValue(new Date(`${updatedYear}${separator}${month}${separator}${day}`))\r\n  }\r\n\r\n  /** Writes a new value to the element (model -> view) */\r\n  writeValue(value: Date): void {\r\n    if (!value) {\r\n      this.renderer.setProperty(this.elementRef.nativeElement, \"value\", null);\r\n      return;\r\n    }\r\n\r\n    this.renderer.setProperty(\r\n      this.elementRef.nativeElement,\r\n      \"valueAsDate\",\r\n      new Date(Date.UTC(value.getFullYear(), value.getMonth(), value.getDate()))\r\n    );\r\n  }\r\n\r\n  /** Registers a callback function, called when value changes (view -> model) */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this.onChange = v =>\r\n      fn(\r\n        v instanceof Date\r\n          ? new Date(v.getUTCFullYear(), v.getUTCMonth(), v.getUTCDate())\r\n          : v\r\n      );\r\n  }\r\n\r\n  /** Registers a callback function, called when the control is blurred */\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  /** Enables or disables the element when the control status changes */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.renderer.setProperty(\r\n      this.elementRef.nativeElement,\r\n      \"disabled\",\r\n      isDisabled\r\n    );\r\n  }\r\n}\r\n"]}
|
@@ -10,11 +10,11 @@ import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../../../services/task.magics.service";
|
11
11
|
import * as i2 from "./row.magic.directive";
|
12
12
|
export class NoControlMagicDirective extends MagicDirective {
|
13
|
+
set magic(val) { this.id = val; this.selector = 'magicnc'; }
|
14
|
+
;
|
13
15
|
constructor(_task, element, renderer, vcRef, magicRow) {
|
14
16
|
super(_task, element, renderer, vcRef, magicRow);
|
15
17
|
}
|
16
|
-
set magic(val) { this.id = val; this.selector = 'magicnc'; }
|
17
|
-
;
|
18
18
|
regEvents() {
|
19
19
|
super.regEvents();
|
20
20
|
if (this.htmlElement instanceof HTMLSelectElement) {
|
@@ -188,4 +188,4 @@ NoControlMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: NoControlMagicDir
|
|
188
188
|
type: Input,
|
189
189
|
args: ['magicnc']
|
190
190
|
}] }); })();
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nocontrol.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/nocontrol.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional} from '@angular/core';\r\nimport {CommandType, GuiCommand} from \"@magic-xpa/gui\";\r\nimport {IGuiEvent, getGuiEventObj} from \"@magic-xpa/engine\";\r\nimport {ControlMetadata} from \"../../../controls.metadata.model\";\r\nimport {HtmlProperties} from  \"@magic-xpa/gui\";\r\nimport {MagicDirective} from \"../magic.directive\";\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {StylesMapManager} from \"../../../services/StylesMapManager\";\r\nimport {RowMagicDirective} from \"./row.magic.directive\";\r\n\r\n/**\r\n * @ignore\r\n */\r\n@Directive({\r\n  selector: '[magicnc]'\r\n})\r\n\r\nexport class NoControlMagicDirective extends MagicDirective {\r\n\r\n  @Input('magicnc') set magic(val) {this.id = val; this.selector = 'magicnc';};\r\n\r\n  constructor(\r\n    _task   : TaskMagicService,\r\n    element : ElementRef,\r\n    renderer: Renderer2,\r\n    vcRef   : ViewContainerRef,\r\n    @Optional() magicRow: RowMagicDirective) {\r\n    super(_task, element, renderer,  vcRef, magicRow);\r\n  }\r\n\r\n  regEvents() {\r\n  super.regEvents()\r\n\r\n    if (this.htmlElement instanceof HTMLSelectElement) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString()\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if (this.isRadio()) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(e.target)).value;\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if(this.isTabControl()) {\r\n        const tabControl = this.htmlElement.children[0];\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        for (var i = 0; i < tabControl.children.length; i++) {\r\n          tabControl.children[i].addEventListener('click', (e) => {\r\n            guiEvent.Value = ((<number><any>(<Element>e.currentTarget).getAttribute('layer'))-1).toString();\r\n            this.task.insertEvent(guiEvent);\r\n          });\r\n        }\r\n    }\r\n  }\r\n\r\n  // is the div a tab control\r\n  isTabControl() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark')=== \"magicTabControl\";\r\n  }\r\n\r\n  // is the div a radio buttons wrapper\r\n  isRadio() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark') === \"magicRadio\";\r\n  }\r\n\r\n  handleCommand(command: GuiCommand) {\r\n    super.handleCommand(command);\r\n\r\n    switch (command.CommandType) {\r\n      case CommandType.SET_CLASS:\r\n        //remove the class which was replaced by this new one, as registered in the ControlMetadata\r\n        const controlMetadata:ControlMetadata = this._task.Records.list[0].getControlMetadata(this.id);\r\n        if(controlMetadata.removedClass != '') {\r\n          this.htmlElement.classList.remove(controlMetadata.removedClass);\r\n          controlMetadata.removedClass = '';\r\n        }\r\n        this.htmlElement.classList.add(command.obj1);\r\n        break;\r\n\r\n      case  CommandType.SET_VALUE:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLAnchorElement) //hyper-text button\r\n          (<HTMLAnchorElement>this.htmlElement).text = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLInputElement)\r\n        {\r\n          if((<HTMLInputElement>this.htmlElement).type === \"checkbox\") {\r\n            (<HTMLInputElement>this.htmlElement).checked = command.value;\r\n          }\r\n          else {\r\n            (<HTMLInputElement>this.htmlElement).value = command.value;\r\n          }\r\n        }\r\n\r\n        if (this.htmlElement instanceof HTMLButtonElement)\r\n        {\r\n          (<HTMLButtonElement>this.htmlElement).innerHTML = command.value;\r\n        }\r\n\r\n        break;\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_STYLE:\r\n        let value: string = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);\r\n        let attribute: string = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);\r\n        this.htmlElement.setAttribute(\"style\", attribute + \":\" + value);\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  // handle set-property commands\r\n  handleSetProperty(command: GuiCommand) {\r\n    super.handleSetProperty(command);\r\n    switch (command.Operation) {\r\n      case HtmlProperties.Text:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.obj1;\r\n\r\n        break;\r\n\r\n      case HtmlProperties.Image:\r\n        if (this.htmlElement instanceof HTMLImageElement)\r\n          (<HTMLImageElement>this.htmlElement).src = command.obj1;\r\n        else\r\n          this.htmlElement.setAttribute(\"src\", command.obj1);\r\n\r\n        break;\r\n\r\n      case HtmlProperties.ItemsList:\r\n        if (this.htmlElement instanceof HTMLSelectElement) {\r\n\r\n          // clear the list\r\n          var len = this.htmlElement.length;\r\n          for (var i = len - 1; i >= 0; i--) {\r\n            this.htmlElement.remove(i);\r\n          }\r\n\r\n          for (let s of command.obj1) {\r\n            let elem = document.createElement(\"option\");\r\n            elem.text = s.displayValue;\r\n            elem.value = s.index;\r\n            (<HTMLSelectElement>this.htmlElement).add(elem);\r\n          }\r\n        }\r\n        else if(this.isTabControl() && this.htmlElement.children.length > 0) {\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            if(tabControl.children[i] instanceof HTMLButtonElement) {\r\n              (<HTMLElement>tabControl.children[i]).innerText = command.obj1[i].displayValue;\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.Visible:\r\n        this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));\r\n        break;\r\n\r\n      case HtmlProperties.Enabled:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"disabled\", \"true\");\r\n        else\r\n          this.htmlElement.removeAttribute(\"disabled\");\r\n        break;\r\n\r\n      case HtmlProperties.TabIndex:\r\n        this.htmlElement.setAttribute(command.Operation, command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.SelectedValue:\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.obj1;\r\n        else if(this.isTabControl()  && this.htmlElement.children.length > 0){\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            let child = tabControl.children[i];\r\n            const layer = (<number><any>child.getAttribute('layer'))-1;\r\n\r\n            if(child instanceof HTMLButtonElement) {\r\n              // set button style\r\n              if ( layer == command.obj1) { // compare int to string\r\n                child.classList.add('tab_button_active');\r\n              }\r\n              else {\r\n                child.classList.remove('tab_button_active');\r\n              }\r\n            } else {\r\n              // not a buton - hide unselected tabpages\r\n              let style = (layer == command.obj1) ? 'display: inline' : 'display: none';\r\n              child.setAttribute('style',  style);\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.PlaceHolder:\r\n        this.htmlElement.setAttribute(\"placeholder\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Tooltip:\r\n        this.htmlElement.setAttribute(\"title\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Password:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"type\", \"text\");\r\n        else\r\n          this.htmlElement.setAttribute(\"type\", \"password\");\r\n        break;\r\n    }\r\n  }\r\n}\r\n"]}
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nocontrol.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/nocontrol.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional} from '@angular/core';\r\nimport {CommandType, GuiCommand} from \"@magic-xpa/gui\";\r\nimport {IGuiEvent, getGuiEventObj} from \"@magic-xpa/engine\";\r\nimport {ControlMetadata} from \"../../../controls.metadata.model\";\r\nimport {HtmlProperties} from  \"@magic-xpa/gui\";\r\nimport {MagicDirective} from \"../magic.directive\";\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {StylesMapManager} from \"../../../services/StylesMapManager\";\r\nimport {RowMagicDirective} from \"./row.magic.directive\";\r\n\r\n/**\r\n * @ignore\r\n */\r\n@Directive({\r\n  selector: '[magicnc]'\r\n})\r\n\r\nexport class NoControlMagicDirective extends MagicDirective {\r\n\r\n  @Input('magicnc') set magic(val) {this.id = val; this.selector = 'magicnc';};\r\n\r\n  constructor(\r\n    _task   : TaskMagicService,\r\n    element : ElementRef,\r\n    renderer: Renderer2,\r\n    vcRef   : ViewContainerRef,\r\n    @Optional() magicRow: RowMagicDirective) {\r\n    super(_task, element, renderer,  vcRef, magicRow);\r\n  }\r\n\r\n  regEvents() {\r\n  super.regEvents()\r\n\r\n    if (this.htmlElement instanceof HTMLSelectElement) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString()\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if (this.isRadio()) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(e.target)).value;\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if(this.isTabControl()) {\r\n        const tabControl = this.htmlElement.children[0];\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        for (var i = 0; i < tabControl.children.length; i++) {\r\n          tabControl.children[i].addEventListener('click', (e) => {\r\n            guiEvent.Value = ((<number><any>(<Element>e.currentTarget).getAttribute('layer'))-1).toString();\r\n            this.task.insertEvent(guiEvent);\r\n          });\r\n        }\r\n    }\r\n  }\r\n\r\n  // is the div a tab control\r\n  isTabControl() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark')=== \"magicTabControl\";\r\n  }\r\n\r\n  // is the div a radio buttons wrapper\r\n  isRadio() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark') === \"magicRadio\";\r\n  }\r\n\r\n  handleCommand(command: GuiCommand) {\r\n    super.handleCommand(command);\r\n\r\n    switch (command.CommandType) {\r\n      case CommandType.SET_CLASS:\r\n        //remove the class which was replaced by this new one, as registered in the ControlMetadata\r\n        const controlMetadata:ControlMetadata = this._task.Records.list[0].getControlMetadata(this.id);\r\n        if(controlMetadata.removedClass != '') {\r\n          this.htmlElement.classList.remove(controlMetadata.removedClass);\r\n          controlMetadata.removedClass = '';\r\n        }\r\n        this.htmlElement.classList.add(command.obj1);\r\n        break;\r\n\r\n      case  CommandType.SET_VALUE:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLAnchorElement) //hyper-text button\r\n          (<HTMLAnchorElement>this.htmlElement).text = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLInputElement)\r\n        {\r\n          if((<HTMLInputElement>this.htmlElement).type === \"checkbox\") {\r\n            (<HTMLInputElement>this.htmlElement).checked = command.value;\r\n          }\r\n          else {\r\n            (<HTMLInputElement>this.htmlElement).value = command.value;\r\n          }\r\n        }\r\n\r\n        if (this.htmlElement instanceof HTMLButtonElement)\r\n        {\r\n          (<HTMLButtonElement>this.htmlElement).innerHTML = command.value;\r\n        }\r\n\r\n        break;\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_STYLE:\r\n        let value: string = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);\r\n        let attribute: string = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);\r\n        this.htmlElement.setAttribute(\"style\", attribute + \":\" + value);\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  // handle set-property commands\r\n  handleSetProperty(command: GuiCommand) {\r\n    super.handleSetProperty(command);\r\n    switch (command.Operation) {\r\n      case HtmlProperties.Text:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.obj1;\r\n\r\n        break;\r\n\r\n      case HtmlProperties.Image:\r\n        if (this.htmlElement instanceof HTMLImageElement)\r\n          (<HTMLImageElement>this.htmlElement).src = command.obj1;\r\n        else\r\n          this.htmlElement.setAttribute(\"src\", command.obj1);\r\n\r\n        break;\r\n\r\n      case HtmlProperties.ItemsList:\r\n        if (this.htmlElement instanceof HTMLSelectElement) {\r\n\r\n          // clear the list\r\n          var len = this.htmlElement.length;\r\n          for (var i = len - 1; i >= 0; i--) {\r\n            this.htmlElement.remove(i);\r\n          }\r\n\r\n          for (let s of command.obj1) {\r\n            let elem = document.createElement(\"option\");\r\n            elem.text = s.displayValue;\r\n            elem.value = s.index;\r\n            (<HTMLSelectElement>this.htmlElement).add(elem);\r\n          }\r\n        }\r\n        else if(this.isTabControl() && this.htmlElement.children.length > 0) {\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            if(tabControl.children[i] instanceof HTMLButtonElement) {\r\n              (<HTMLElement>tabControl.children[i]).innerText = command.obj1[i].displayValue;\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.Visible:\r\n        this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));\r\n        break;\r\n\r\n      case HtmlProperties.Enabled:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"disabled\", \"true\");\r\n        else\r\n          this.htmlElement.removeAttribute(\"disabled\");\r\n        break;\r\n\r\n      case HtmlProperties.TabIndex:\r\n        this.htmlElement.setAttribute(command.Operation, command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.SelectedValue:\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.obj1;\r\n        else if(this.isTabControl()  && this.htmlElement.children.length > 0){\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            let child = tabControl.children[i];\r\n            const layer = (<number><any>child.getAttribute('layer'))-1;\r\n\r\n            if(child instanceof HTMLButtonElement) {\r\n              // set button style\r\n              if ( layer == command.obj1) { // compare int to string\r\n                child.classList.add('tab_button_active');\r\n              }\r\n              else {\r\n                child.classList.remove('tab_button_active');\r\n              }\r\n            } else {\r\n              // not a buton - hide unselected tabpages\r\n              let style = (layer == command.obj1) ? 'display: inline' : 'display: none';\r\n              child.setAttribute('style',  style);\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.PlaceHolder:\r\n        this.htmlElement.setAttribute(\"placeholder\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Tooltip:\r\n        this.htmlElement.setAttribute(\"title\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Password:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"type\", \"text\");\r\n        else\r\n          this.htmlElement.setAttribute(\"type\", \"password\");\r\n        break;\r\n    }\r\n  }\r\n}\r\n"]}
|