@magic-xpa/angular 4.1100.0-dev4110.25 → 4.1100.0-dev4110.252
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 → esm2022}/index.mjs +59 -59
- package/{esm2020 → esm2022}/magic-xpa-angular.mjs +1 -1
- package/esm2022/src/controls.metadata.model.mjs +183 -0
- package/{esm2020 → esm2022}/src/interfaces/sub-form-definition.iterface.mjs +1 -1
- package/{esm2020 → esm2022}/src/magic.core.module.mjs +159 -160
- package/{esm2020 → esm2022}/src/services/ISubformMagicService.mjs +1 -1
- package/esm2022/src/services/OverlayWindowService.mjs +244 -0
- package/esm2022/src/services/StylesMapManager.mjs +28 -0
- package/esm2022/src/services/accessor.magic.service.mjs +358 -0
- package/esm2022/src/services/commands-collector.magic.service.mjs +47 -0
- package/esm2022/src/services/component-list.magic.service.mjs +45 -0
- package/{esm2020 → esm2022}/src/services/confirmation.components.magic.provider.mjs +21 -21
- package/esm2022/src/services/engine.magic.service.mjs +80 -0
- package/{esm2020 → esm2022}/src/services/exit.magic.service.mjs +13 -13
- package/esm2022/src/services/magic-color.service.mjs +101 -0
- package/{esm2020 → esm2022}/src/services/magic.lazy.loader.service.mjs +16 -16
- package/{esm2020 → esm2022}/src/services/magic.providers.mjs +24 -24
- package/esm2022/src/services/magic.services.mjs +36 -0
- package/esm2022/src/services/mg-date-adapter.mjs +108 -0
- package/{esm2020 → esm2022}/src/services/overlay.conainer.magic.provider.mjs +14 -14
- package/esm2022/src/services/router-commands.magic.service.mjs +31 -0
- package/esm2022/src/services/subform.magic.service.mjs +194 -0
- package/esm2022/src/services/table.magic.service.mjs +81 -0
- package/esm2022/src/services/task.magics.service.mjs +637 -0
- package/esm2022/src/services/title.magic.service.mjs +19 -0
- package/esm2022/src/ui/GuiInteractiveExecutor.mjs +109 -0
- package/esm2022/src/ui/components/base-magic-alert.component.mjs +24 -0
- package/esm2022/src/ui/components/base-magic-confirm.component.mjs +24 -0
- package/esm2022/src/ui/components/magic-alert.component.mjs +36 -0
- package/esm2022/src/ui/components/magic-confirmation-box.component.mjs +42 -0
- package/esm2022/src/ui/directives/NonMagicControlDirective.mjs +58 -0
- package/esm2022/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs +29 -0
- package/esm2022/src/ui/directives/magic/checkbox.magic.directive.mjs +29 -0
- package/esm2022/src/ui/directives/magic/combobox.magic.directive.mjs +37 -0
- package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs +27 -0
- package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +85 -0
- package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs +32 -0
- package/esm2022/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs +28 -0
- package/esm2022/src/ui/directives/magic/nocontrol.magic.directive.mjs +193 -0
- package/esm2022/src/ui/directives/magic/row.magic.directive.mjs +62 -0
- package/esm2022/src/ui/directives/magic-focus.directive.mjs +20 -0
- package/esm2022/src/ui/directives/magic.directive.mjs +229 -0
- package/esm2022/src/ui/directives/magicViewContainerRef.directive.mjs +20 -0
- package/esm2022/src/ui/directives/mgformat.magic.directive.mjs +579 -0
- package/esm2022/src/ui/directives/range-validator.magic.directive.mjs +60 -0
- package/{esm2020 → esm2022}/src/ui/magic-confirmationBox.mjs +42 -42
- package/{esm2020 → esm2022}/src/ui/magic-modal/base-magic-overlay-container.mjs +22 -22
- package/esm2022/src/ui/magic-modal/magic-modal-form.mjs +6 -0
- package/{esm2020 → esm2022}/src/ui/magic-modal/magic-modal-interface.mjs +1 -1
- package/esm2022/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +124 -0
- package/esm2022/src/ui/magic-modal/magic-overlay-container.mjs +162 -0
- package/esm2022/src/ui/magic-root.component.mjs +236 -0
- package/esm2022/src/ui/mgerror.magic.component.mjs +125 -0
- package/esm2022/src/ui/pipes/date.magic.pipe.mjs +106 -0
- package/esm2022/src/ui/pipes/time.magic.pipe.mjs +52 -0
- package/esm2022/src/ui/pipes/time24.magic.pipe.mjs +35 -0
- package/esm2022/src/ui/router-container.magic.component.mjs +115 -0
- package/{esm2020 → esm2022}/src/ui/subform.magic.component.mjs +50 -46
- package/esm2022/src/ui/task-base.magic.component.mjs +91 -0
- package/esm2022/src/ui/utils.mjs +54 -0
- package/{fesm2020 → fesm2022}/magic-xpa-angular.mjs +4827 -4444
- package/fesm2022/magic-xpa-angular.mjs.map +1 -0
- package/index.d.ts +58 -58
- package/package.json +10 -16
- package/src/controls.metadata.model.d.ts +62 -62
- package/src/interfaces/sub-form-definition.iterface.d.ts +12 -12
- package/src/magic.core.module.d.ts +41 -41
- package/src/services/ISubformMagicService.d.ts +4 -4
- package/src/services/OverlayWindowService.d.ts +30 -25
- package/src/services/StylesMapManager.d.ts +5 -5
- package/src/services/accessor.magic.service.d.ts +69 -69
- package/src/services/commands-collector.magic.service.d.ts +15 -15
- package/src/services/component-list.magic.service.d.ts +23 -23
- package/src/services/confirmation.components.magic.provider.d.ts +8 -8
- package/src/services/engine.magic.service.d.ts +27 -27
- package/src/services/exit.magic.service.d.ts +6 -6
- package/src/services/magic-color.service.d.ts +19 -19
- package/src/services/magic.lazy.loader.service.d.ts +6 -6
- package/src/services/magic.providers.d.ts +107 -107
- package/src/services/magic.services.d.ts +16 -16
- package/src/services/mg-date-adapter.d.ts +38 -40
- package/src/services/overlay.conainer.magic.provider.d.ts +7 -7
- package/src/services/router-commands.magic.service.d.ts +17 -17
- package/src/services/subform.magic.service.d.ts +43 -43
- package/src/services/table.magic.service.d.ts +30 -30
- package/src/services/task.magics.service.d.ts +100 -100
- package/src/services/title.magic.service.d.ts +9 -9
- package/src/ui/GuiInteractiveExecutor.d.ts +22 -21
- package/src/ui/components/base-magic-alert.component.d.ts +10 -10
- package/src/ui/components/base-magic-confirm.component.d.ts +10 -10
- package/src/ui/components/magic-alert.component.d.ts +6 -6
- package/src/ui/components/magic-confirmation-box.component.d.ts +6 -6
- package/src/ui/directives/NonMagicControlDirective.d.ts +26 -26
- package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +9 -9
- package/src/ui/directives/magic/checkbox.magic.directive.d.ts +9 -9
- package/src/ui/directives/magic/combobox.magic.directive.d.ts +10 -10
- package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +7 -7
- package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +23 -17
- package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +7 -7
- package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +9 -9
- package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +18 -18
- package/src/ui/directives/magic/row.magic.directive.d.ts +17 -17
- package/src/ui/directives/magic-focus.directive.d.ts +9 -9
- package/src/ui/directives/magic.directive.d.ts +44 -44
- package/src/ui/directives/magicViewContainerRef.directive.d.ts +8 -8
- package/src/ui/directives/mgformat.magic.directive.d.ts +38 -31
- package/src/ui/directives/range-validator.magic.directive.d.ts +17 -17
- package/src/ui/magic-confirmationBox.d.ts +6 -6
- package/src/ui/magic-modal/base-magic-overlay-container.d.ts +5 -5
- package/src/ui/magic-modal/magic-modal-form.d.ts +5 -5
- package/src/ui/magic-modal/magic-modal-interface.d.ts +10 -10
- package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +30 -31
- package/src/ui/magic-modal/magic-overlay-container.d.ts +24 -25
- package/src/ui/magic-root.component.d.ts +43 -40
- package/src/ui/mgerror.magic.component.d.ts +20 -20
- package/src/ui/pipes/date.magic.pipe.d.ts +17 -17
- package/src/ui/pipes/time.magic.pipe.d.ts +11 -11
- package/src/ui/pipes/time24.magic.pipe.d.ts +10 -10
- package/src/ui/router-container.magic.component.d.ts +29 -30
- package/src/ui/subform.magic.component.d.ts +16 -16
- package/src/ui/task-base.magic.component.d.ts +34 -34
- package/src/ui/utils.d.ts +9 -9
- package/esm2020/src/controls.metadata.model.mjs +0 -180
- package/esm2020/src/services/OverlayWindowService.mjs +0 -208
- package/esm2020/src/services/StylesMapManager.mjs +0 -28
- package/esm2020/src/services/accessor.magic.service.mjs +0 -356
- package/esm2020/src/services/commands-collector.magic.service.mjs +0 -46
- package/esm2020/src/services/component-list.magic.service.mjs +0 -46
- package/esm2020/src/services/engine.magic.service.mjs +0 -82
- package/esm2020/src/services/magic-color.service.mjs +0 -99
- package/esm2020/src/services/magic.services.mjs +0 -31
- package/esm2020/src/services/mg-date-adapter.mjs +0 -109
- package/esm2020/src/services/router-commands.magic.service.mjs +0 -28
- package/esm2020/src/services/subform.magic.service.mjs +0 -184
- package/esm2020/src/services/table.magic.service.mjs +0 -77
- package/esm2020/src/services/task.magics.service.mjs +0 -624
- package/esm2020/src/services/title.magic.service.mjs +0 -18
- package/esm2020/src/ui/GuiInteractiveExecutor.mjs +0 -98
- package/esm2020/src/ui/components/base-magic-alert.component.mjs +0 -23
- package/esm2020/src/ui/components/base-magic-confirm.component.mjs +0 -23
- package/esm2020/src/ui/components/magic-alert.component.mjs +0 -35
- package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +0 -41
- package/esm2020/src/ui/directives/NonMagicControlDirective.mjs +0 -49
- package/esm2020/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs +0 -28
- package/esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs +0 -28
- package/esm2020/src/ui/directives/magic/combobox.magic.directive.mjs +0 -36
- package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs +0 -27
- package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +0 -52
- package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs +0 -32
- package/esm2020/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs +0 -27
- package/esm2020/src/ui/directives/magic/nocontrol.magic.directive.mjs +0 -193
- package/esm2020/src/ui/directives/magic/row.magic.directive.mjs +0 -58
- package/esm2020/src/ui/directives/magic-focus.directive.mjs +0 -19
- package/esm2020/src/ui/directives/magic.directive.mjs +0 -215
- package/esm2020/src/ui/directives/magicViewContainerRef.directive.mjs +0 -19
- package/esm2020/src/ui/directives/mgformat.magic.directive.mjs +0 -408
- package/esm2020/src/ui/directives/range-validator.magic.directive.mjs +0 -58
- package/esm2020/src/ui/magic-modal/magic-modal-form.mjs +0 -8
- package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +0 -121
- package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +0 -159
- package/esm2020/src/ui/magic-root.component.mjs +0 -203
- package/esm2020/src/ui/mgerror.magic.component.mjs +0 -119
- package/esm2020/src/ui/pipes/date.magic.pipe.mjs +0 -105
- package/esm2020/src/ui/pipes/time.magic.pipe.mjs +0 -51
- package/esm2020/src/ui/pipes/time24.magic.pipe.mjs +0 -34
- package/esm2020/src/ui/router-container.magic.component.mjs +0 -108
- package/esm2020/src/ui/task-base.magic.component.mjs +0 -86
- package/esm2020/src/ui/utils.mjs +0 -54
- package/fesm2015/magic-xpa-angular.mjs +0 -4832
- package/fesm2015/magic-xpa-angular.mjs.map +0 -1
- package/fesm2020/magic-xpa-angular.mjs.map +0 -1
@@ -0,0 +1,60 @@
|
|
1
|
+
import { Directive, ViewContainerRef } from '@angular/core';
|
2
|
+
import { NG_VALIDATORS } from '@angular/forms';
|
3
|
+
import { TaskMagicService } from '../../services/task.magics.service';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "../../services/task.magics.service";
|
6
|
+
export class RangeValidatorMagicDirective {
|
7
|
+
_task;
|
8
|
+
vcRef;
|
9
|
+
constructor(_task, vcRef) {
|
10
|
+
this._task = _task;
|
11
|
+
this.vcRef = vcRef;
|
12
|
+
}
|
13
|
+
validate(c) {
|
14
|
+
let controlName;
|
15
|
+
controlName = this.getControlName(c);
|
16
|
+
let properties;
|
17
|
+
properties = this._task.Records.list["0"].getControlMetadata(controlName);
|
18
|
+
properties.rangeValidator = true;
|
19
|
+
let errMsg = null;
|
20
|
+
if (c.dirty)
|
21
|
+
errMsg = this._task.ValidateControlValue(controlName, this._task.ConvertValToNative(controlName, 0, c.value));
|
22
|
+
let isValid = (errMsg == null) ? true : false;
|
23
|
+
if (isValid) {
|
24
|
+
return null;
|
25
|
+
}
|
26
|
+
else {
|
27
|
+
return {
|
28
|
+
rangevalidator: {
|
29
|
+
errorMsg: errMsg
|
30
|
+
}
|
31
|
+
};
|
32
|
+
}
|
33
|
+
}
|
34
|
+
getControlName(c) {
|
35
|
+
const formGroup = c.parent.controls;
|
36
|
+
return Object.keys(formGroup).find(name => c === formGroup[name]) || null;
|
37
|
+
}
|
38
|
+
static ɵfac = function RangeValidatorMagicDirective_Factory(t) { return new (t || RangeValidatorMagicDirective)(i0.ɵɵdirectiveInject(i1.TaskMagicService), i0.ɵɵdirectiveInject(i0.ViewContainerRef)); };
|
39
|
+
static ɵdir = i0.ɵɵdefineDirective({ type: RangeValidatorMagicDirective, selectors: [["", "rangevalidator", ""]], features: [i0.ɵɵProvidersFeature([
|
40
|
+
{
|
41
|
+
provide: NG_VALIDATORS,
|
42
|
+
useExisting: RangeValidatorMagicDirective,
|
43
|
+
multi: true,
|
44
|
+
}
|
45
|
+
])] });
|
46
|
+
}
|
47
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeValidatorMagicDirective, [{
|
48
|
+
type: Directive,
|
49
|
+
args: [{
|
50
|
+
selector: '[rangevalidator] ',
|
51
|
+
providers: [
|
52
|
+
{
|
53
|
+
provide: NG_VALIDATORS,
|
54
|
+
useExisting: RangeValidatorMagicDirective,
|
55
|
+
multi: true,
|
56
|
+
}
|
57
|
+
]
|
58
|
+
}]
|
59
|
+
}], () => [{ type: i1.TaskMagicService }, { type: i0.ViewContainerRef }], null); })();
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvcmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBZSxhQUFhLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7O0FBbUJ0RSxNQUFNLE9BQU8sNEJBQTRCO0lBT2pCO0lBQW9DO0lBQTFELFlBQXNCLEtBQXVCLEVBQWEsS0FBdUI7UUFBM0QsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFBYSxVQUFLLEdBQUwsS0FBSyxDQUFrQjtJQUNqRixDQUFDO0lBT0EsUUFBUSxDQUFDLENBQWM7UUFDbkIsSUFBSSxXQUFtQixDQUFDO1FBQ3hCLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksVUFBMkIsQ0FBQztRQUNoQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzFFLFVBQVUsQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQ2pDLElBQUksTUFBTSxHQUFXLElBQUksQ0FBQztRQUMxQixJQUFJLENBQUMsQ0FBQyxLQUFLO1lBQ1YsTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUUsV0FBVyxFQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUNsSCxJQUFJLE9BQU8sR0FBWSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDdkQsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNaLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQzthQUNJLENBQUM7WUFDSixPQUFPO2dCQUNMLGNBQWMsRUFBRTtvQkFDZCxRQUFRLEVBQUcsTUFBTTtpQkFDbEI7YUFDRixDQUFDO1FBQ0osQ0FBQztJQUNMLENBQUM7SUFLRixjQUFjLENBQUMsQ0FBYztRQUMzQixNQUFNLFNBQVMsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNwQyxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQztJQUM1RSxDQUFDO3NGQTNDVSw0QkFBNEI7K0NBQTVCLDRCQUE0Qiw0RUFYNUI7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLGFBQWE7b0JBQ3RCLFdBQVcsRUFBRSw0QkFBNEI7b0JBRXpDLEtBQUssRUFBRSxJQUFJO2lCQUVaO2FBQ0Y7O2lGQUdVLDRCQUE0QjtjQWJ4QyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtnQkFDN0IsU0FBUyxFQUFFO29CQUNUO3dCQUNFLE9BQU8sRUFBRSxhQUFhO3dCQUN0QixXQUFXLDhCQUE4Qjt3QkFFekMsS0FBSyxFQUFFLElBQUk7cUJBRVo7aUJBQ0Y7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgTkdfVkFMSURBVE9SUywgVmFsaWRhdG9yIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBUYXNrTWFnaWNTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdGFzay5tYWdpY3Muc2VydmljZSc7XHJcbmltcG9ydCB7IENvbnRyb2xNZXRhZGF0YSB9IGZyb20gJy4uLy4uL2NvbnRyb2xzLm1ldGFkYXRhLm1vZGVsJztcclxuXHJcbi8qKlxyXG4gKiBWYWxpZGF0ZXMgdGhlIGZpZWxkIHJhbmdlLlxyXG4gKi9cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbcmFuZ2V2YWxpZGF0b3JdICcsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTElEQVRPUlMsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBSYW5nZVZhbGlkYXRvck1hZ2ljRGlyZWN0aXZlLFxyXG5cclxuICAgICAgbXVsdGk6IHRydWUsXHJcblxyXG4gICAgfVxyXG4gIF1cclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBSYW5nZVZhbGlkYXRvck1hZ2ljRGlyZWN0aXZlIGltcGxlbWVudHMgVmFsaWRhdG9yIHtcclxuXHJcbiAgLyoqXHJcbiAgICpcclxuICAgKiBAcGFyYW0gX3Rhc2sgVGhlIHRhc2sgc2VydmljZVxyXG4gICAqIEBwYXJhbSB2Y1JlZlxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBfdGFzazogVGFza01hZ2ljU2VydmljZSwgIHByb3RlY3RlZCB2Y1JlZjogVmlld0NvbnRhaW5lclJlZikge1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogVmFsaWRhdGlvbiBtZXRob2RcclxuICAgKiBAcGFyYW0gYyBGb3JtQ29udHJvbCB0byB2YWxpZGF0ZVxyXG4gICAqIEByZXR1cm5zIElmIHZhbGlkYXRpb24gZmFpbHMsIHJldHVybiBlcnJvciBtZXNzYWdlLCBlbHNlIHJldHVybnMgbnVsbFxyXG4gICAqL1xyXG4gICB2YWxpZGF0ZShjOiBGb3JtQ29udHJvbCkge1xyXG4gICAgICAgbGV0IGNvbnRyb2xOYW1lOiBzdHJpbmc7XHJcbiAgICAgICBjb250cm9sTmFtZSA9IHRoaXMuZ2V0Q29udHJvbE5hbWUgKGMpO1xyXG4gICAgICAgbGV0IHByb3BlcnRpZXM6IENvbnRyb2xNZXRhZGF0YTtcclxuICAgICAgIHByb3BlcnRpZXMgPSB0aGlzLl90YXNrLlJlY29yZHMubGlzdFtcIjBcIl0uZ2V0Q29udHJvbE1ldGFkYXRhKGNvbnRyb2xOYW1lKTtcclxuICAgICAgIHByb3BlcnRpZXMucmFuZ2VWYWxpZGF0b3IgPSB0cnVlO1xyXG4gICAgICAgbGV0IGVyck1zZzogc3RyaW5nID0gbnVsbDtcclxuICAgICAgIGlmIChjLmRpcnR5KVxyXG4gICAgICAgIGVyck1zZyA9IHRoaXMuX3Rhc2suVmFsaWRhdGVDb250cm9sVmFsdWUgKGNvbnRyb2xOYW1lLCAgdGhpcy5fdGFzay5Db252ZXJ0VmFsVG9OYXRpdmUoY29udHJvbE5hbWUsICAwLCBjLnZhbHVlKSk7XHJcbiAgICAgICBsZXQgaXNWYWxpZDogYm9vbGVhbiA9IChlcnJNc2cgPT0gbnVsbCkgPyB0cnVlIDogZmFsc2U7XHJcbiAgICAgICBpZiAoaXNWYWxpZCkge1xyXG4gICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgICAgIH1cclxuICAgICAgIGVsc2Uge1xyXG4gICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgIHJhbmdldmFsaWRhdG9yOiB7XHJcbiAgICAgICAgICAgICBlcnJvck1zZyA6IGVyck1zZ1xyXG4gICAgICAgICAgIH1cclxuICAgICAgICAgfTtcclxuICAgICAgIH1cclxuICAgfVxyXG5cclxuICAvKipcclxuICAgKiBAaWdub3JlXHJcbiAgICovXHJcbiAgZ2V0Q29udHJvbE5hbWUoYzogRm9ybUNvbnRyb2wpOiBzdHJpbmcgfCBudWxsIHtcclxuICAgIGNvbnN0IGZvcm1Hcm91cCA9IGMucGFyZW50LmNvbnRyb2xzO1xyXG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGZvcm1Hcm91cCkuZmluZChuYW1lID0+IGMgPT09IGZvcm1Hcm91cFtuYW1lXSkgfHwgbnVsbDtcclxuICB9XHJcbn1cclxuIl19
|
@@ -1,42 +1,42 @@
|
|
1
|
-
import { Styles } from "@magic-xpa/gui";
|
2
|
-
export class confirmationBox {
|
3
|
-
static isConfirmBox(style) {
|
4
|
-
let buttonMode = style & 0x0F;
|
5
|
-
var isConfirm = (buttonMode === Styles.MSGBOX_BUTTON_OK_CANCEL) ||
|
6
|
-
(buttonMode === Styles.MSGBOX_BUTTON_ABORT_RETRY_IGNORE) ||
|
7
|
-
(buttonMode === Styles.MSGBOX_BUTTON_YES_NO_CANCEL) ||
|
8
|
-
(buttonMode === Styles.MSGBOX_BUTTON_YES_NO) ||
|
9
|
-
(buttonMode === Styles.MSGBOX_BUTTON_RETRY_CANCEL);
|
10
|
-
return (isConfirm);
|
11
|
-
}
|
12
|
-
static convertToExcpectedResultBox(style, okWasPressed) {
|
13
|
-
let buttonMode = style & 0x0F;
|
14
|
-
let retValue = Styles.MSGBOX_RESULT_OK;
|
15
|
-
if (buttonMode === Styles.MSGBOX_BUTTON_OK)
|
16
|
-
retValue = Styles.MSGBOX_RESULT_OK;
|
17
|
-
else if (buttonMode === Styles.MSGBOX_BUTTON_OK_CANCEL)
|
18
|
-
retValue = okWasPressed ? Styles.MSGBOX_RESULT_OK : Styles.MSGBOX_RESULT_CANCEL;
|
19
|
-
else if (buttonMode === Styles.MSGBOX_BUTTON_ABORT_RETRY_IGNORE)
|
20
|
-
retValue = okWasPressed ? Styles.MSGBOX_RESULT_ABORT : Styles.MSGBOX_RESULT_RETRY;
|
21
|
-
else if (buttonMode === Styles.MSGBOX_BUTTON_YES_NO_CANCEL)
|
22
|
-
retValue = okWasPressed ? Styles.MSGBOX_RESULT_YES : Styles.MSGBOX_RESULT_NO;
|
23
|
-
else if (buttonMode === Styles.MSGBOX_BUTTON_YES_NO)
|
24
|
-
retValue = okWasPressed ? Styles.MSGBOX_RESULT_YES : Styles.MSGBOX_RESULT_NO;
|
25
|
-
else if (buttonMode === Styles.MSGBOX_BUTTON_RETRY_CANCEL)
|
26
|
-
retValue = okWasPressed ? Styles.MSGBOX_RESULT_RETRY : Styles.MSGBOX_RESULT_CANCEL;
|
27
|
-
return retValue;
|
28
|
-
}
|
29
|
-
static showConfirmationBox(title, message, style) {
|
30
|
-
let okWasPressed = false;
|
31
|
-
let isConfirm = this.isConfirmBox(style);
|
32
|
-
let titleAndString = title + '\n' + '\n' + message;
|
33
|
-
if (isConfirm)
|
34
|
-
okWasPressed = confirm(titleAndString);
|
35
|
-
else {
|
36
|
-
alert(titleAndString);
|
37
|
-
okWasPressed = true;
|
38
|
-
}
|
39
|
-
return okWasPressed;
|
40
|
-
}
|
41
|
-
}
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
1
|
+
import { Styles } from "@magic-xpa/gui";
|
2
|
+
export class confirmationBox {
|
3
|
+
static isConfirmBox(style) {
|
4
|
+
let buttonMode = style & 0x0F;
|
5
|
+
var isConfirm = (buttonMode === Styles.MSGBOX_BUTTON_OK_CANCEL) ||
|
6
|
+
(buttonMode === Styles.MSGBOX_BUTTON_ABORT_RETRY_IGNORE) ||
|
7
|
+
(buttonMode === Styles.MSGBOX_BUTTON_YES_NO_CANCEL) ||
|
8
|
+
(buttonMode === Styles.MSGBOX_BUTTON_YES_NO) ||
|
9
|
+
(buttonMode === Styles.MSGBOX_BUTTON_RETRY_CANCEL);
|
10
|
+
return (isConfirm);
|
11
|
+
}
|
12
|
+
static convertToExcpectedResultBox(style, okWasPressed) {
|
13
|
+
let buttonMode = style & 0x0F;
|
14
|
+
let retValue = Styles.MSGBOX_RESULT_OK;
|
15
|
+
if (buttonMode === Styles.MSGBOX_BUTTON_OK)
|
16
|
+
retValue = Styles.MSGBOX_RESULT_OK;
|
17
|
+
else if (buttonMode === Styles.MSGBOX_BUTTON_OK_CANCEL)
|
18
|
+
retValue = okWasPressed ? Styles.MSGBOX_RESULT_OK : Styles.MSGBOX_RESULT_CANCEL;
|
19
|
+
else if (buttonMode === Styles.MSGBOX_BUTTON_ABORT_RETRY_IGNORE)
|
20
|
+
retValue = okWasPressed ? Styles.MSGBOX_RESULT_ABORT : Styles.MSGBOX_RESULT_RETRY;
|
21
|
+
else if (buttonMode === Styles.MSGBOX_BUTTON_YES_NO_CANCEL)
|
22
|
+
retValue = okWasPressed ? Styles.MSGBOX_RESULT_YES : Styles.MSGBOX_RESULT_NO;
|
23
|
+
else if (buttonMode === Styles.MSGBOX_BUTTON_YES_NO)
|
24
|
+
retValue = okWasPressed ? Styles.MSGBOX_RESULT_YES : Styles.MSGBOX_RESULT_NO;
|
25
|
+
else if (buttonMode === Styles.MSGBOX_BUTTON_RETRY_CANCEL)
|
26
|
+
retValue = okWasPressed ? Styles.MSGBOX_RESULT_RETRY : Styles.MSGBOX_RESULT_CANCEL;
|
27
|
+
return retValue;
|
28
|
+
}
|
29
|
+
static showConfirmationBox(title, message, style) {
|
30
|
+
let okWasPressed = false;
|
31
|
+
let isConfirm = this.isConfirmBox(style);
|
32
|
+
let titleAndString = title + '\n' + '\n' + message;
|
33
|
+
if (isConfirm)
|
34
|
+
okWasPressed = confirm(titleAndString);
|
35
|
+
else {
|
36
|
+
alert(titleAndString);
|
37
|
+
okWasPressed = true;
|
38
|
+
}
|
39
|
+
return okWasPressed;
|
40
|
+
}
|
41
|
+
}
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtY29uZmlybWF0aW9uQm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvbWFnaWMtY29uZmlybWF0aW9uQm94LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxNQUFNLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUt0QyxNQUFNLE9BQU8sZUFBZTtJQUtuQixNQUFNLENBQUUsWUFBWSxDQUFDLEtBQWM7UUFHeEMsSUFBSSxVQUFVLEdBQVcsS0FBSyxHQUFHLElBQUksQ0FBQztRQUV0QyxJQUFJLFNBQVMsR0FBRyxDQUFDLFVBQVUsS0FBSyxNQUFNLENBQUMsdUJBQXVCLENBQUM7WUFDN0QsQ0FBQyxVQUFVLEtBQUssTUFBTSxDQUFDLGdDQUFnQyxDQUFDO1lBQ3hELENBQUMsVUFBVSxLQUFLLE1BQU0sQ0FBQywyQkFBMkIsQ0FBQztZQUNuRCxDQUFDLFVBQVUsS0FBSyxNQUFNLENBQUMsb0JBQW9CLENBQUM7WUFDNUMsQ0FBQyxVQUFVLEtBQUssTUFBTSxDQUFDLDBCQUEwQixDQUFDLENBQUM7UUFFckQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFRTSxNQUFNLENBQUMsMkJBQTJCLENBQUUsS0FBYSxFQUFFLFlBQXFCO1FBRzdFLElBQUksVUFBVSxHQUFXLEtBQUssR0FBRyxJQUFJLENBQUM7UUFFdEMsSUFBSSxRQUFRLEdBQUksTUFBTSxDQUFDLGdCQUFnQixDQUFDO1FBRXhDLElBQUksVUFBVSxLQUFNLE1BQU0sQ0FBQyxnQkFBZ0I7WUFDekMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQzthQUNoQyxJQUFJLFVBQVUsS0FBSyxNQUFNLENBQUMsdUJBQXVCO1lBQ3BELFFBQVEsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLG9CQUFvQixDQUFDO2FBQzdFLElBQUksVUFBVSxLQUFLLE1BQU0sQ0FBQyxnQ0FBZ0M7WUFDN0QsUUFBUSxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUM7YUFDL0UsSUFBSSxVQUFVLEtBQU0sTUFBTSxDQUFDLDJCQUEyQjtZQUN6RCxRQUFRLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQzthQUMxRSxJQUFJLFVBQVUsS0FBSyxNQUFNLENBQUMsb0JBQW9CO1lBQ2pELFFBQVEsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDO2FBQzFFLElBQUksVUFBVSxLQUFLLE1BQU0sQ0FBQywwQkFBMEI7WUFDdkQsUUFBUSxHQUFHLFlBQVksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsb0JBQW9CLENBQUM7UUFFckYsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQVNNLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxLQUFhLEVBQUUsT0FBZSxFQUFFLEtBQWE7UUFFN0UsSUFBSSxZQUFZLEdBQUssS0FBSyxDQUFDO1FBRTNCLElBQUksU0FBUyxHQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUM7UUFHMUMsSUFBSSxjQUFjLEdBQUcsS0FBSyxHQUFHLElBQUksR0FBRSxJQUFJLEdBQUcsT0FBTyxDQUFDO1FBRWxELElBQUksU0FBUztZQUNYLFlBQVksR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7YUFDcEMsQ0FBQztZQUNKLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQztZQUN0QixZQUFZLEdBQUcsSUFBSSxDQUFDO1FBQ3RCLENBQUM7UUFHRCxPQUFPLFlBQVksQ0FBQztJQUN0QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1N0eWxlc30gZnJvbSBcIkBtYWdpYy14cGEvZ3VpXCI7XHJcblxyXG4vKipcclxuICogRGlzcGxheXMgYSBtZXNzYWdlLWJveFxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIGNvbmZpcm1hdGlvbkJveCB7XHJcblxyXG4gIC8qKlxyXG4gICAqIEBpZ25vcmVcclxuICAgKi9cclxuICBwdWJsaWMgc3RhdGljICBpc0NvbmZpcm1Cb3goc3R5bGUgOiBTdHlsZXMpOiBCb29sZWFue1xyXG5cclxuICAgIC8vIGJ1dHRvbiBmb3JtYXQgbWFzayBpcyBpbiBmaXJzdCBuaWJibGUgZnJvbSByaWdodFxyXG4gICAgbGV0IGJ1dHRvbk1vZGUgPSA8bnVtYmVyPnN0eWxlICYgMHgwRjtcclxuXHJcbiAgICB2YXIgaXNDb25maXJtID0gKGJ1dHRvbk1vZGUgPT09IFN0eWxlcy5NU0dCT1hfQlVUVE9OX09LX0NBTkNFTCkgfHxcclxuICAgICAgKGJ1dHRvbk1vZGUgPT09IFN0eWxlcy5NU0dCT1hfQlVUVE9OX0FCT1JUX1JFVFJZX0lHTk9SRSkgfHxcclxuICAgICAgKGJ1dHRvbk1vZGUgPT09IFN0eWxlcy5NU0dCT1hfQlVUVE9OX1lFU19OT19DQU5DRUwpIHx8XHJcbiAgICAgIChidXR0b25Nb2RlID09PSBTdHlsZXMuTVNHQk9YX0JVVFRPTl9ZRVNfTk8pIHx8XHJcbiAgICAgIChidXR0b25Nb2RlID09PSBTdHlsZXMuTVNHQk9YX0JVVFRPTl9SRVRSWV9DQU5DRUwpO1xyXG5cclxuICAgIHJldHVybiAoaXNDb25maXJtKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIENvbnZlcnRzIHRoZSByZXN1bHQgZnJvbSB0aGUgSFRNTCB3aW5kb3cgdG8gdGhlIGV4cGVjdGVkIHJlc3VsdCB0eXBlXHJcbiAgICogQHBhcmFtIHN0eWxlIFJlc3VsdCByZWNlaXZlZCBmcm9tIEhUTUwgd2luZG93XHJcbiAgICogQHBhcmFtIG9rV2FzUHJlc3NlZCBXYXMgdGhlIFwiT0tcIiBwcmVzc2VkXHJcbiAgICogQHJldHVybnMgIE1lc3NhZ2VCb3ggcmVzdWx0IHR5cGVcclxuICAgKi9cclxuICBwdWJsaWMgc3RhdGljIGNvbnZlcnRUb0V4Y3BlY3RlZFJlc3VsdEJveCAoc3R5bGU6IFN0eWxlcywgb2tXYXNQcmVzc2VkOiBCb29sZWFuICk6IFN0eWxlc3tcclxuXHJcbiAgICAvLyBidXR0b24gZm9ybWF0IG1hc2sgaXMgaW4gZmlyc3QgbmliYmxlIGZyb20gcmlnaHRcclxuICAgIGxldCBidXR0b25Nb2RlID0gPG51bWJlcj5zdHlsZSAmIDB4MEY7XHJcblxyXG4gICAgbGV0IHJldFZhbHVlID0gIFN0eWxlcy5NU0dCT1hfUkVTVUxUX09LO1xyXG5cclxuICAgIGlmIChidXR0b25Nb2RlID09PSAgU3R5bGVzLk1TR0JPWF9CVVRUT05fT0spXHJcbiAgICAgIHJldFZhbHVlID0gU3R5bGVzLk1TR0JPWF9SRVNVTFRfT0s7XHJcbiAgICBlbHNlIGlmIChidXR0b25Nb2RlID09PSBTdHlsZXMuTVNHQk9YX0JVVFRPTl9PS19DQU5DRUwpXHJcbiAgICAgIHJldFZhbHVlID0gb2tXYXNQcmVzc2VkID8gU3R5bGVzLk1TR0JPWF9SRVNVTFRfT0sgOiBTdHlsZXMuTVNHQk9YX1JFU1VMVF9DQU5DRUw7XHJcbiAgICBlbHNlIGlmIChidXR0b25Nb2RlID09PSBTdHlsZXMuTVNHQk9YX0JVVFRPTl9BQk9SVF9SRVRSWV9JR05PUkUpXHJcbiAgICAgIHJldFZhbHVlID0gb2tXYXNQcmVzc2VkID8gU3R5bGVzLk1TR0JPWF9SRVNVTFRfQUJPUlQgOiBTdHlsZXMuTVNHQk9YX1JFU1VMVF9SRVRSWTtcclxuICAgIGVsc2UgaWYgKGJ1dHRvbk1vZGUgPT09ICBTdHlsZXMuTVNHQk9YX0JVVFRPTl9ZRVNfTk9fQ0FOQ0VMKVxyXG4gICAgICByZXRWYWx1ZSA9IG9rV2FzUHJlc3NlZCA/IFN0eWxlcy5NU0dCT1hfUkVTVUxUX1lFUyA6IFN0eWxlcy5NU0dCT1hfUkVTVUxUX05PO1xyXG4gICAgZWxzZSBpZiAoYnV0dG9uTW9kZSA9PT0gU3R5bGVzLk1TR0JPWF9CVVRUT05fWUVTX05PKVxyXG4gICAgICByZXRWYWx1ZSA9IG9rV2FzUHJlc3NlZCA/IFN0eWxlcy5NU0dCT1hfUkVTVUxUX1lFUyA6IFN0eWxlcy5NU0dCT1hfUkVTVUxUX05PO1xyXG4gICAgZWxzZSBpZiAoYnV0dG9uTW9kZSA9PT0gU3R5bGVzLk1TR0JPWF9CVVRUT05fUkVUUllfQ0FOQ0VMKVxyXG4gICAgICByZXRWYWx1ZSA9IG9rV2FzUHJlc3NlZCA/IFN0eWxlcy5NU0dCT1hfUkVTVUxUX1JFVFJZIDogU3R5bGVzLk1TR0JPWF9SRVNVTFRfQ0FOQ0VMO1xyXG5cclxuICAgIHJldHVybiByZXRWYWx1ZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNob3cgYSBtZXNzYWdlIGJveCBhcyBhbiBIVE1MIHdpbmRvd1xyXG4gICAqIEBwYXJhbSB0aXRsZSBUaXRsZSBvZiB0aGUgbWVzc2FnZSBib3hcclxuICAgKiBAcGFyYW0gbWVzc2FnZSBNZXNzYWdlIHRoYXQgd2lsbCBiZSBkaXNwbGF5IGluIHRoZSBtZXNzYWdlIGJveFxyXG4gICAqIEBwYXJhbSBzdHlsZSBTdHlsZSB0aGF0IGluY2x1ZGUgYnV0dG9ucyBcXCBJY29uc1xyXG4gICAqIEByZXR1cm5zIE1lc3NhZ2VCb3ggcmVzdWx0XHJcbiAgICovXHJcbiAgcHVibGljIHN0YXRpYyBzaG93Q29uZmlybWF0aW9uQm94KHRpdGxlOiBzdHJpbmcsIG1lc3NhZ2U6IHN0cmluZywgc3R5bGU6IFN0eWxlcyk6IGJvb2xlYW4ge1xyXG5cclxuICAgIGxldCBva1dhc1ByZXNzZWQgICA9IGZhbHNlO1xyXG4vLyBjaGVjayBpZiBpdCBpcyBjb25maXJtYXRpb24gYm94XHJcbiAgICBsZXQgaXNDb25maXJtICA9IHRoaXMuaXNDb25maXJtQm94KHN0eWxlKTtcclxuXHJcbiAgICAvLyB0aGUgdGl0bGUgd2lsbCBiZSBhZGRlZCB0byB0aGUgc3RyaW5nIGFuZCB3ZSB3aWxsIGFkZCBuZXcgbGluZSBhZnRlciB0aGUgdGl0bGVcclxuICAgIGxldCB0aXRsZUFuZFN0cmluZyA9IHRpdGxlICsgJ1xcbicrICdcXG4nICsgbWVzc2FnZTtcclxuXHJcbiAgICBpZiAoaXNDb25maXJtKVxyXG4gICAgICBva1dhc1ByZXNzZWQgPSBjb25maXJtKHRpdGxlQW5kU3RyaW5nKTtcclxuICAgIGVsc2Uge1xyXG4gICAgICBhbGVydCh0aXRsZUFuZFN0cmluZyk7XHJcbiAgICAgIG9rV2FzUHJlc3NlZCA9IHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgLy8gcmV0dXJuIHRoZSByZXN1bHQgZnJvbSB0aGUgdXNlclxyXG4gICAgcmV0dXJuIG9rV2FzUHJlc3NlZDsgXHJcbiAgfVxyXG59XHJcbiJdfQ==
|
@@ -1,22 +1,22 @@
|
|
1
|
-
import { __decorate, __metadata } from "tslib";
|
2
|
-
import { Input, Output } from "@angular/core";
|
3
|
-
let BaseMagicOverlayContainer = class BaseMagicOverlayContainer {
|
4
|
-
};
|
5
|
-
__decorate([
|
6
|
-
Input(),
|
7
|
-
__metadata("design:type", Object)
|
8
|
-
], BaseMagicOverlayContainer.prototype, "ModalComp", void 0);
|
9
|
-
__decorate([
|
10
|
-
Input(),
|
11
|
-
__metadata("design:type", Object)
|
12
|
-
], BaseMagicOverlayContainer.prototype, "ModalCompParameters", void 0);
|
13
|
-
__decorate([
|
14
|
-
Output(),
|
15
|
-
__metadata("design:type", Object)
|
16
|
-
], BaseMagicOverlayContainer.prototype, "onClose", void 0);
|
17
|
-
BaseMagicOverlayContainer = __decorate([
|
18
|
-
Input(),
|
19
|
-
Output()
|
20
|
-
], BaseMagicOverlayContainer);
|
21
|
-
export { BaseMagicOverlayContainer };
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
2
|
+
import { Input, Output } from "@angular/core";
|
3
|
+
let BaseMagicOverlayContainer = class BaseMagicOverlayContainer {
|
4
|
+
};
|
5
|
+
__decorate([
|
6
|
+
Input(),
|
7
|
+
__metadata("design:type", Object)
|
8
|
+
], BaseMagicOverlayContainer.prototype, "ModalComp", void 0);
|
9
|
+
__decorate([
|
10
|
+
Input(),
|
11
|
+
__metadata("design:type", Object)
|
12
|
+
], BaseMagicOverlayContainer.prototype, "ModalCompParameters", void 0);
|
13
|
+
__decorate([
|
14
|
+
Output(),
|
15
|
+
__metadata("design:type", Object)
|
16
|
+
], BaseMagicOverlayContainer.prototype, "onClose", void 0);
|
17
|
+
BaseMagicOverlayContainer = __decorate([
|
18
|
+
Input(),
|
19
|
+
Output()
|
20
|
+
], BaseMagicOverlayContainer);
|
21
|
+
export { BaseMagicOverlayContainer };
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1tYWdpYy1vdmVybGF5LWNvbnRhaW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL21hZ2ljLW1vZGFsL2Jhc2UtbWFnaWMtb3ZlcmxheS1jb250YWluZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3ZDLElBQWUseUJBQXlCLEdBQXhDLE1BQWUseUJBQXlCO0NBZTlDLENBQUE7QUFYbUI7SUFBakIsS0FBSyxFQUFFOzs0REFBb0I7QUFLVjtJQUFqQixLQUFLLEVBQUU7O3NFQUFtQztBQUt4QjtJQUFsQixNQUFNLEVBQUU7OzBEQUFrQjtBQWRQLHlCQUF5QjtJQUY5QyxLQUFLLEVBQUU7SUFDUCxNQUFNLEVBQUU7R0FDYSx5QkFBeUIsQ0FlOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnB1dCwgT3V0cHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuQElucHV0KClcclxuQE91dHB1dCgpXHJcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlTWFnaWNPdmVybGF5Q29udGFpbmVyIHtcclxuICAvKipcclxuICAgKlxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGFic3RyYWN0IE1vZGFsQ29tcDtcclxuXHJcbiAgLyoqXHJcbiAgICpcclxuICAgKi9cclxuICBASW5wdXQoKSBhYnN0cmFjdCBNb2RhbENvbXBQYXJhbWV0ZXJzOiBhbnk7XHJcblxyXG4gIC8qKlxyXG4gICAqXHJcbiAgICovXHJcbiAgQE91dHB1dCgpIGFic3RyYWN0IG9uQ2xvc2U7XHJcbn1cclxuIl19
|
@@ -0,0 +1,6 @@
|
|
1
|
+
export class ModalFormDefinition {
|
2
|
+
taskId = "";
|
3
|
+
comp = null;
|
4
|
+
parameters = {};
|
5
|
+
}
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtbW9kYWwtZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL21hZ2ljLW1vZGFsL21hZ2ljLW1vZGFsLWZvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixNQUFNLEdBQVcsRUFBRSxDQUFDO0lBQ3BCLElBQUksR0FBUSxJQUFJLENBQUM7SUFDakIsVUFBVSxHQUFRLEVBQUUsQ0FBQztDQUN0QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAaWdub3JlXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgTW9kYWxGb3JtRGVmaW5pdGlvbiB7XHJcbiAgdGFza0lkOiBzdHJpbmcgPSBcIlwiO1xyXG4gIGNvbXA6IGFueSA9IG51bGw7XHJcbiAgcGFyYW1ldGVyczogYW55ID0ge307XHJcbn1cclxuIl19
|
@@ -1,2 +1,2 @@
|
|
1
|
-
export {};
|
1
|
+
export {};
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtbW9kYWwtaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvbWFnaWMtbW9kYWwvbWFnaWMtbW9kYWwtaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogRGVzY3JpYmVzIHRoZSBiZWhhdmlvciBvZiBhIG1vZGFsIHdpbmRvd1xyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBNYWdpY01vZGFsSW50ZXJmYWNlIHtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSBYIGNvb3JkaW5hdGUgb2YgdGhlIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIFgoKTtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSBZIGNvb3JkaW5hdGUgb2YgdGhlIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIFkoKTtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSB3aWR0aCBvZiBtb2RhbCB3aW5kb3dcclxuICAgKi9cclxuICBXaWR0aCgpOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgaGVpZ2h0IG9mIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIEhlaWdodCgpOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogSXMgdGhlIG1vZGFsIHdpbmRvdyBjZW50ZXJlZCByZWxhdGl2ZWx5IHRvIHRoZSBtYWluIHdpbmRvd1xyXG4gICAqL1xyXG4gIElzQ2VudGVyZWRUb1dpbmRvdygpO1xyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIG5hbWUgb2YgdGhlIGZvcm0gLSB0aXRsZSBvZiB0aGUgbW9kYWwgd2luZG93XHJcbiAgICovXHJcbiAgRm9ybU5hbWUoKTtcclxuICAvKipcclxuICAgKiBTaG91bGQgdGhlIHRpdGxlIGJhciBiZSBkaXNwbGF5ZWRcclxuICAgKi9cclxuICBTaG93VGl0bGVCYXIoKTtcclxuICAvKipcclxuICAgKiBTaG91bGQgdGhlIG1vZGFsIHdpbmRvdyBjbG9zZSB3aGVuIHRoZSB1c2VyIGNsaWNrcyBvbiB0aGUgYmFja2dyb3VuZFxyXG4gICAqL1xyXG4gIFNob3VsZENsb3NlT25CYWNrZ3JvdW5kQ2xpY2soKTtcclxufVxyXG4iXX0=
|
@@ -0,0 +1,124 @@
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ViewChild, ElementRef, Injector, ChangeDetectorRef, Compiler } from '@angular/core';
|
2
|
+
import { BaseMagicOverlayContainer } from "./base-magic-overlay-container";
|
3
|
+
import { BaseMagicConfirmComponent } from "../components/base-magic-confirm.component";
|
4
|
+
import { BaseMagicAlertComponent } from "../components/base-magic-alert.component";
|
5
|
+
import { OverlayType } from "@magic-xpa/gui";
|
6
|
+
import { ComponentListMagicService } from "../../services/component-list.magic.service";
|
7
|
+
import { isNullOrUndefined } from '@magic-xpa/mscorelib';
|
8
|
+
import { MagicLazyLoaderService } from '../../services/magic.lazy.loader.service';
|
9
|
+
import * as i0 from "@angular/core";
|
10
|
+
import * as i1 from "../../services/component-list.magic.service";
|
11
|
+
import * as i2 from "../../services/magic.lazy.loader.service";
|
12
|
+
import * as i3 from "../directives/magic-focus.directive";
|
13
|
+
import * as i4 from "../directives/magicViewContainerRef.directive";
|
14
|
+
const _c0 = ["overlayContainerWrapper"];
|
15
|
+
export class MagicOverlayContainerWrapper {
|
16
|
+
componentListMagicService;
|
17
|
+
magicLazyModuleLoader;
|
18
|
+
injector;
|
19
|
+
changeDetectorRef;
|
20
|
+
compiler;
|
21
|
+
Component = null;
|
22
|
+
Parameters = {};
|
23
|
+
OverlayTypeParam;
|
24
|
+
onClose = new EventEmitter();
|
25
|
+
overlayContentViewContainerRef;
|
26
|
+
overlayContainerWrapperElementRef;
|
27
|
+
static allowedBaseComps = new Map([
|
28
|
+
[OverlayType.Overlay, { comp: BaseMagicOverlayContainer, error: 'BaseMagicOverlayContainer . Overlay ' }],
|
29
|
+
[OverlayType.Alert, { comp: BaseMagicAlertComponent, error: 'BaseMagicAlertComponent. Alert ' }],
|
30
|
+
[OverlayType.ConfirmationBox, { comp: BaseMagicConfirmComponent, error: 'BaseMagicConfirmComponent. Confirmation ' }]
|
31
|
+
]);
|
32
|
+
constructor(componentListMagicService, magicLazyModuleLoader, injector, changeDetectorRef, compiler) {
|
33
|
+
this.componentListMagicService = componentListMagicService;
|
34
|
+
this.magicLazyModuleLoader = magicLazyModuleLoader;
|
35
|
+
this.injector = injector;
|
36
|
+
this.changeDetectorRef = changeDetectorRef;
|
37
|
+
this.compiler = compiler;
|
38
|
+
}
|
39
|
+
ngOnInit() {
|
40
|
+
let moduleRef = this.componentListMagicService.getModuleRef(this.Parameters.MagicFormName);
|
41
|
+
if (moduleRef == null) {
|
42
|
+
let lazyLoadModule = this.componentListMagicService.getLazyLoadModuleData(this.Parameters.MagicFormName);
|
43
|
+
if (lazyLoadModule != null) {
|
44
|
+
let moduleName = lazyLoadModule.moduleName.replace("Magic", "");
|
45
|
+
moduleName = moduleName.replace("Module", "");
|
46
|
+
this.magicLazyModuleLoader.Load(moduleName).then(m => {
|
47
|
+
const compiled = this.compiler.compileModuleAndAllComponentsSync(m[lazyLoadModule.moduleName]);
|
48
|
+
moduleRef = compiled.ngModuleFactory.create(this.injector);
|
49
|
+
this.loadComponent(moduleRef);
|
50
|
+
});
|
51
|
+
}
|
52
|
+
else {
|
53
|
+
this.loadComponent(null);
|
54
|
+
}
|
55
|
+
}
|
56
|
+
else
|
57
|
+
this.loadComponent(moduleRef);
|
58
|
+
}
|
59
|
+
loadComponent(moduleRef) {
|
60
|
+
this.Parameters.ModalComp = this.componentListMagicService.getComponent(this.Parameters.MagicFormName, !isNullOrUndefined(this.Parameters.MagicFormName));
|
61
|
+
let componentRef = this.overlayContentViewContainerRef.createComponent(this.Component);
|
62
|
+
let allowedBaseComp = MagicOverlayContainerWrapper.allowedBaseComps.get(this.OverlayTypeParam);
|
63
|
+
if (componentRef.instance instanceof allowedBaseComp.comp) {
|
64
|
+
Object.assign(componentRef.instance, this.Parameters);
|
65
|
+
componentRef.instance.onClose.subscribe((res) => {
|
66
|
+
this.onClose.emit(res);
|
67
|
+
});
|
68
|
+
}
|
69
|
+
else {
|
70
|
+
let msg = "Provided window container should subclass of : " + allowedBaseComp.error + "window will not work properly.";
|
71
|
+
alert(msg);
|
72
|
+
}
|
73
|
+
}
|
74
|
+
setViewContainerRef(vcRef) {
|
75
|
+
this.overlayContentViewContainerRef = vcRef;
|
76
|
+
}
|
77
|
+
GetRootElement() {
|
78
|
+
return this.overlayContainerWrapperElementRef.nativeElement;
|
79
|
+
}
|
80
|
+
DetectChanges() {
|
81
|
+
this.changeDetectorRef.detectChanges();
|
82
|
+
}
|
83
|
+
static ɵfac = function MagicOverlayContainerWrapper_Factory(t) { return new (t || MagicOverlayContainerWrapper)(i0.ɵɵdirectiveInject(i1.ComponentListMagicService), i0.ɵɵdirectiveInject(i2.MagicLazyLoaderService), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.Compiler)); };
|
84
|
+
static ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContainerWrapper, selectors: [["app-magic-overlay-container-wrapper"]], viewQuery: function MagicOverlayContainerWrapper_Query(rf, ctx) { if (rf & 1) {
|
85
|
+
i0.ɵɵviewQuery(_c0, 7);
|
86
|
+
} if (rf & 2) {
|
87
|
+
let _t;
|
88
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.overlayContainerWrapperElementRef = _t.first);
|
89
|
+
} }, inputs: { Component: "Component", Parameters: "Parameters", OverlayTypeParam: "OverlayTypeParam" }, outputs: { onClose: "onClose" }, decls: 7, vars: 0, consts: [["overlayContainerWrapper", ""], ["overlayContent", ""], ["tabIndex", "0", "magicFocus", "", 1, "overlay-container-wrapper-background", 2, "width", "0px", "height", "0px"], [1, "overlay-container-wrapper-background"], ["magicViewContainerRef", ""], ["tabIndex", "0", 1, "overlay-container-wrapper-background", 2, "width", "0px", "height", "0px"]], template: function MagicOverlayContainerWrapper_Template(rf, ctx) { if (rf & 1) {
|
90
|
+
i0.ɵɵelementStart(0, "div");
|
91
|
+
i0.ɵɵelement(1, "div", 2);
|
92
|
+
i0.ɵɵelementStart(2, "div", 3, 0);
|
93
|
+
i0.ɵɵelement(4, "div", 4, 1);
|
94
|
+
i0.ɵɵelementEnd();
|
95
|
+
i0.ɵɵelement(6, "div", 5);
|
96
|
+
i0.ɵɵelementEnd();
|
97
|
+
} }, dependencies: [i3.MagicFocusDirective, i4.MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;z-index:999;inset:0}"] });
|
98
|
+
}
|
99
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainerWrapper, [{
|
100
|
+
type: Component,
|
101
|
+
args: [{ selector: 'app-magic-overlay-container-wrapper', template: `
|
102
|
+
<div>
|
103
|
+
<div class="overlay-container-wrapper-background" tabIndex="0" style="width: 0px; height: 0px;" magicFocus></div>
|
104
|
+
<div class="overlay-container-wrapper-background" #overlayContainerWrapper>
|
105
|
+
<div #overlayContent magicViewContainerRef>
|
106
|
+
</div>
|
107
|
+
</div>
|
108
|
+
<div class="overlay-container-wrapper-background" tabIndex="0" style="width: 0px; height: 0px;" ></div>
|
109
|
+
</div>
|
110
|
+
`, styles: [".overlay-container-wrapper-background{position:fixed;z-index:999;inset:0}\n"] }]
|
111
|
+
}], () => [{ type: i1.ComponentListMagicService }, { type: i2.MagicLazyLoaderService }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }, { type: i0.Compiler }], { Component: [{
|
112
|
+
type: Input
|
113
|
+
}], Parameters: [{
|
114
|
+
type: Input
|
115
|
+
}], OverlayTypeParam: [{
|
116
|
+
type: Input
|
117
|
+
}], onClose: [{
|
118
|
+
type: Output
|
119
|
+
}], overlayContainerWrapperElementRef: [{
|
120
|
+
type: ViewChild,
|
121
|
+
args: ['overlayContainerWrapper', { static: true }]
|
122
|
+
}] }); })();
|
123
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MagicOverlayContainerWrapper, { className: "MagicOverlayContainerWrapper", filePath: "src\\ui\\magic-modal\\magic-overlay-container-wrapper.ts", lineNumber: 45 }); })();
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic-overlay-container-wrapper.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/magic-modal/magic-overlay-container-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ElementRef, NgModuleRef,\r\n  Injector, ChangeDetectorRef, Compiler\r\n} from '@angular/core';\r\nimport { BaseMagicOverlayContainer } from \"./base-magic-overlay-container\";\r\nimport { BaseMagicConfirmComponent } from \"../components/base-magic-confirm.component\";\r\nimport { BaseMagicAlertComponent } from \"../components/base-magic-alert.component\";\r\nimport { OverlayType } from \"@magic-xpa/gui\";\r\nimport { ComponentListMagicService, ModuleData } from \"../../services/component-list.magic.service\";\r\nimport { IMagicViewContainerRef } from \"../../..\";\r\nimport {isNullOrUndefined} from '@magic-xpa/mscorelib';\r\nimport { MagicLazyLoaderService } from '../../services/magic.lazy.loader.service';\r\n\r\n\r\n@Component({\r\n  selector: 'app-magic-overlay-container-wrapper',\r\n  template: `\r\n    <div>\r\n      <div class=\"overlay-container-wrapper-background\" tabIndex=\"0\" style=\"width: 0px; height: 0px;\" magicFocus></div>\r\n      <div class=\"overlay-container-wrapper-background\" #overlayContainerWrapper>\r\n        <div #overlayContent magicViewContainerRef>\r\n        </div>\r\n      </div>\r\n      <div class=\"overlay-container-wrapper-background\" tabIndex=\"0\" style=\"width: 0px; height: 0px;\" ></div>\r\n    </div>\r\n  `,\r\n  styles: [`\r\n    .overlay-container-wrapper-background {\r\n      /* modal background fixed across whole screen */\r\n      position: fixed;\r\n      top: 0;\r\n      z-index: 999;\r\n      right: 0;\r\n      bottom: 0;\r\n      left: 0;\r\n    }\r\n  `]\r\n})\r\nexport class MagicOverlayContainerWrapper  implements IMagicViewContainerRef {\r\n  /**\r\n   *\r\n   */\r\n  @Input() public Component = null;\r\n  /**\r\n   *\r\n   */\r\n  @Input() public Parameters: any = {};\r\n\r\n  @Input() private OverlayTypeParam: OverlayType;\r\n\r\n  @Output() private onClose = new EventEmitter<void>();\r\n\r\n  /**\r\n   * HTML to be displayed in the modal window\r\n   */\r\n  overlayContentViewContainerRef: ViewContainerRef;\r\n\r\n  @ViewChild('overlayContainerWrapper', { static: true }) overlayContainerWrapperElementRef: ElementRef;\r\n\r\n  /**\r\n   * @ignore\r\n   * contais data of allowed base components to use\r\n   */\r\n  static allowedBaseComps = new Map<number, {comp: any, error: string}>([\r\n    [OverlayType.Overlay, {comp: BaseMagicOverlayContainer, error:'BaseMagicOverlayContainer . Overlay '}],\r\n    [OverlayType.Alert, {comp: BaseMagicAlertComponent, error:'BaseMagicAlertComponent. Alert '}],\r\n    [OverlayType.ConfirmationBox,  {comp: BaseMagicConfirmComponent, error :'BaseMagicConfirmComponent. Confirmation '}]\r\n  ]);\r\n  /**\r\n   *\r\n   * @param componentFactoryResolver\r\n   */\r\n  constructor(private componentListMagicService: ComponentListMagicService,\r\n              private magicLazyModuleLoader: MagicLazyLoaderService,\r\n              private injector: Injector,\r\n              private changeDetectorRef:ChangeDetectorRef,\r\n              private compiler: Compiler) {\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    let moduleRef: NgModuleRef<any> = this.componentListMagicService.getModuleRef(this.Parameters.MagicFormName);\r\n\r\n    if (moduleRef == null) {\r\n      let lazyLoadModule: ModuleData = this.componentListMagicService.getLazyLoadModuleData(this.Parameters.MagicFormName);\r\n\r\n      if (lazyLoadModule != null) {\r\n        let moduleName = lazyLoadModule.moduleName.replace(\"Magic\", \"\");\r\n        moduleName = moduleName.replace(\"Module\", \"\");\r\n        this.magicLazyModuleLoader.Load(moduleName).then(m => {\r\n          const compiled = this.compiler.compileModuleAndAllComponentsSync(<any>m[lazyLoadModule.moduleName]);\r\n          moduleRef = compiled.ngModuleFactory.create(this.injector);\r\n          this.loadComponent(moduleRef);\r\n        });\r\n      }\r\n      else {\r\n        this.loadComponent(null);\r\n      }\r\n    } else\r\n      this.loadComponent(moduleRef);\r\n  }\r\n\r\n  private loadComponent(moduleRef: NgModuleRef<any>) {\r\n    this.Parameters.ModalComp = this.componentListMagicService.getComponent(this.Parameters.MagicFormName, !isNullOrUndefined(this.Parameters.MagicFormName));\r\n\r\n\r\n    let componentRef = this.overlayContentViewContainerRef.createComponent(this.Component);\r\n    let allowedBaseComp = MagicOverlayContainerWrapper.allowedBaseComps.get(this.OverlayTypeParam);\r\n\r\n\r\n    if (componentRef.instance instanceof allowedBaseComp.comp) {\r\n      Object.assign(componentRef.instance, this.Parameters);\r\n      (<any>componentRef.instance).onClose.subscribe((res) => {\r\n        this.onClose.emit(res);\r\n      });\r\n    } else {\r\n      let msg = \"Provided  window container should subclass of : \" + allowedBaseComp.error + \"window will not work properly.\";\r\n      alert(msg);\r\n    }\r\n  }\r\n\r\n  setViewContainerRef(vcRef: ViewContainerRef){\r\n    this.overlayContentViewContainerRef = vcRef;\r\n  }\r\n\r\n  GetRootElement(): HTMLElement {\r\n    return this.overlayContainerWrapperElementRef.nativeElement;\r\n  }\r\n\r\n  DetectChanges()\r\n  {\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n}\r\n"]}
|
@@ -0,0 +1,162 @@
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
2
|
+
import { isNullOrUndefined } from '@magic-xpa/mscorelib';
|
3
|
+
import { BaseMagicOverlayContainer } from './base-magic-overlay-container';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@angular/common";
|
6
|
+
import * as i2 from "../directives/magicViewContainerRef.directive";
|
7
|
+
const _c0 = ["modalheader"];
|
8
|
+
const _c1 = ["modalForeground"];
|
9
|
+
function MagicOverlayContainer_button_2_Template(rf, ctx) { if (rf & 1) {
|
10
|
+
const _r2 = i0.ɵɵgetCurrentView();
|
11
|
+
i0.ɵɵelementStart(0, "button", 9);
|
12
|
+
i0.ɵɵlistener("click", function MagicOverlayContainer_button_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.OnClose()); });
|
13
|
+
i0.ɵɵtext(1, "X");
|
14
|
+
i0.ɵɵelementEnd();
|
15
|
+
} }
|
16
|
+
function MagicOverlayContainer_div_5_Template(rf, ctx) { if (rf & 1) {
|
17
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
18
|
+
i0.ɵɵelementStart(0, "div", 10, 2);
|
19
|
+
i0.ɵɵtext(2);
|
20
|
+
i0.ɵɵelementStart(3, "button", 11);
|
21
|
+
i0.ɵɵlistener("click", function MagicOverlayContainer_div_5_Template_button_click_3_listener() { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.OnClose()); });
|
22
|
+
i0.ɵɵtext(4, "X");
|
23
|
+
i0.ɵɵelementEnd()();
|
24
|
+
} if (rf & 2) {
|
25
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
26
|
+
i0.ɵɵadvance(2);
|
27
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r2.getText(), " ");
|
28
|
+
} }
|
29
|
+
export class MagicOverlayContainer extends BaseMagicOverlayContainer {
|
30
|
+
modalbodyViewContainerRef;
|
31
|
+
headerElementRef;
|
32
|
+
foregroundElementRef;
|
33
|
+
ModalComp = null;
|
34
|
+
ModalCompParameters = {};
|
35
|
+
onClose = new EventEmitter();
|
36
|
+
componentRef = null;
|
37
|
+
constructor() {
|
38
|
+
super();
|
39
|
+
}
|
40
|
+
ngOnInit() {
|
41
|
+
this.componentRef = this.modalbodyViewContainerRef.createComponent(this.ModalComp);
|
42
|
+
Object.assign(this.componentRef.instance, this.ModalCompParameters);
|
43
|
+
}
|
44
|
+
setViewContainerRef(vcRef) {
|
45
|
+
this.modalbodyViewContainerRef = vcRef;
|
46
|
+
}
|
47
|
+
getText() {
|
48
|
+
if (this.componentRef !== null) {
|
49
|
+
let comp = this.componentRef.instance;
|
50
|
+
return comp.FormName();
|
51
|
+
}
|
52
|
+
else
|
53
|
+
return '';
|
54
|
+
}
|
55
|
+
getStyle() {
|
56
|
+
let styles = {};
|
57
|
+
if (this.componentRef != undefined) {
|
58
|
+
let comp = this.componentRef.instance;
|
59
|
+
styles['width'] = comp.Width();
|
60
|
+
styles['height'] = comp.Height();
|
61
|
+
if (comp.IsCenteredToWindow()) {
|
62
|
+
styles['margin'] = 'auto';
|
63
|
+
}
|
64
|
+
else {
|
65
|
+
styles['margin-left'] = comp.X() + 'px';
|
66
|
+
styles['margin-top'] = comp.Y() + 'px';
|
67
|
+
}
|
68
|
+
}
|
69
|
+
return styles;
|
70
|
+
}
|
71
|
+
getClientAreaStyles() {
|
72
|
+
let styles = {};
|
73
|
+
if (this.componentRef != undefined) {
|
74
|
+
const headerHeight = this.getShowTitleBar() && !isNullOrUndefined(this.headerElementRef) ? (this.headerElementRef.nativeElement.offsetHeight + 1) : 0;
|
75
|
+
if (!isNullOrUndefined(this.foregroundElementRef)) {
|
76
|
+
const foregroundHeight = this.foregroundElementRef.nativeElement.offsetHeight;
|
77
|
+
styles['height'] = (foregroundHeight - headerHeight) + 'px';
|
78
|
+
const foregroundWidth = this.foregroundElementRef.nativeElement.offsetWidth;
|
79
|
+
styles['width'] = (foregroundWidth) + 'px';
|
80
|
+
}
|
81
|
+
styles['overflow'] = 'auto';
|
82
|
+
}
|
83
|
+
return styles;
|
84
|
+
}
|
85
|
+
getShowTitleBar() {
|
86
|
+
if (this.componentRef != undefined) {
|
87
|
+
let comp = this.componentRef.instance;
|
88
|
+
return comp.ShowTitleBar();
|
89
|
+
}
|
90
|
+
}
|
91
|
+
OnClose() {
|
92
|
+
this.onClose.emit();
|
93
|
+
}
|
94
|
+
OnBackgroundClick() {
|
95
|
+
let comp = this.componentRef.instance;
|
96
|
+
if (comp.ShouldCloseOnBackgroundClick())
|
97
|
+
this.OnClose();
|
98
|
+
}
|
99
|
+
static ɵfac = function MagicOverlayContainer_Factory(t) { return new (t || MagicOverlayContainer)(); };
|
100
|
+
static ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContainer, selectors: [["app-magic-overlay-container"]], viewQuery: function MagicOverlayContainer_Query(rf, ctx) { if (rf & 1) {
|
101
|
+
i0.ɵɵviewQuery(_c0, 5);
|
102
|
+
i0.ɵɵviewQuery(_c1, 5);
|
103
|
+
} if (rf & 2) {
|
104
|
+
let _t;
|
105
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.headerElementRef = _t.first);
|
106
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.foregroundElementRef = _t.first);
|
107
|
+
} }, inputs: { ModalComp: "ModalComp", ModalCompParameters: "ModalCompParameters" }, outputs: { onClose: "onClose" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 4, consts: [["modalForeground", ""], ["modalbody", ""], ["modalheader", ""], [1, "modal-background", 3, "click"], ["tabindex", "-1", "style", "float:right; border: none; background-color: transparent; outline: none; color: white", 3, "click", 4, "ngIf"], [1, "modal-foreground", 3, "ngStyle"], ["class", "modal-header", 4, "ngIf"], [3, "ngStyle"], ["magicViewContainerRef", ""], ["tabindex", "-1", 2, "float", "right", "border", "none", "background-color", "transparent", "outline", "none", "color", "white", 3, "click"], [1, "modal-header"], ["tabindex", "-1", 2, "float", "right", 3, "click"]], template: function MagicOverlayContainer_Template(rf, ctx) { if (rf & 1) {
|
108
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
109
|
+
i0.ɵɵelementStart(0, "div")(1, "div", 3);
|
110
|
+
i0.ɵɵlistener("click", function MagicOverlayContainer_Template_div_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.OnBackgroundClick()); });
|
111
|
+
i0.ɵɵtemplate(2, MagicOverlayContainer_button_2_Template, 2, 0, "button", 4);
|
112
|
+
i0.ɵɵelementEnd();
|
113
|
+
i0.ɵɵelementStart(3, "div", 5, 0);
|
114
|
+
i0.ɵɵtemplate(5, MagicOverlayContainer_div_5_Template, 5, 1, "div", 6);
|
115
|
+
i0.ɵɵelementStart(6, "div", 7);
|
116
|
+
i0.ɵɵelement(7, "div", 8, 1);
|
117
|
+
i0.ɵɵelementEnd()()();
|
118
|
+
} if (rf & 2) {
|
119
|
+
i0.ɵɵadvance(2);
|
120
|
+
i0.ɵɵproperty("ngIf", !ctx.getShowTitleBar());
|
121
|
+
i0.ɵɵadvance();
|
122
|
+
i0.ɵɵproperty("ngStyle", ctx.getStyle());
|
123
|
+
i0.ɵɵadvance(2);
|
124
|
+
i0.ɵɵproperty("ngIf", ctx.getShowTitleBar());
|
125
|
+
i0.ɵɵadvance();
|
126
|
+
i0.ɵɵproperty("ngStyle", ctx.getClientAreaStyles());
|
127
|
+
} }, dependencies: [i1.NgIf, i1.NgStyle, i2.MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#fff}.modal-background[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header[_ngcontent-%COMP%]{background-color:beige;border-bottom:2px solid red}"] });
|
128
|
+
}
|
129
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainer, [{
|
130
|
+
type: Component,
|
131
|
+
args: [{ selector: 'app-magic-overlay-container', template: `
|
132
|
+
<div>
|
133
|
+
<div class="modal-background" (click)="OnBackgroundClick()">
|
134
|
+
<button (click)="OnClose()" tabindex="-1" style="float:right; border: none; background-color: transparent; outline: none; color: white" *ngIf="!getShowTitleBar()">X</button>
|
135
|
+
</div>
|
136
|
+
<div #modalForeground class="modal-foreground" [ngStyle]="getStyle()">
|
137
|
+
<div #modalheader class="modal-header" *ngIf="getShowTitleBar()">
|
138
|
+
{{getText()}}
|
139
|
+
<button (click)="OnClose()" style="float:right" tabindex="-1">X</button>
|
140
|
+
</div>
|
141
|
+
<div [ngStyle]="getClientAreaStyles()">
|
142
|
+
<div #modalbody magicViewContainerRef>
|
143
|
+
</div>
|
144
|
+
</div>
|
145
|
+
</div>
|
146
|
+
</div>
|
147
|
+
`, styles: [".modal-foreground{position:fixed;inset:0;background-color:#fff}.modal-background{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header{background-color:beige;border-bottom:2px solid red}\n"] }]
|
148
|
+
}], () => [], { headerElementRef: [{
|
149
|
+
type: ViewChild,
|
150
|
+
args: ['modalheader', { static: false }]
|
151
|
+
}], foregroundElementRef: [{
|
152
|
+
type: ViewChild,
|
153
|
+
args: ['modalForeground', { static: false }]
|
154
|
+
}], ModalComp: [{
|
155
|
+
type: Input
|
156
|
+
}], ModalCompParameters: [{
|
157
|
+
type: Input
|
158
|
+
}], onClose: [{
|
159
|
+
type: Output
|
160
|
+
}] }); })();
|
161
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MagicOverlayContainer, { className: "MagicOverlayContainer", filePath: "src\\ui\\magic-modal\\magic-overlay-container.ts", lineNumber: 40 }); })();
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic-overlay-container.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/magic-modal/magic-overlay-container.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { MagicModalInterface } from './magic-modal-interface';\r\nimport { isNullOrUndefined } from '@magic-xpa/mscorelib';\r\nimport { BaseMagicOverlayContainer } from './base-magic-overlay-container';\r\nimport { IMagicViewContainerRef } from '../../..';\r\n\r\n/**\r\n * Creates a modal window for Magic modal window components\r\n */\r\n@Component({\r\n  selector: 'app-magic-overlay-container',\r\n  template: `\r\n    <div>\r\n      <div class=\"modal-background\" (click)=\"OnBackgroundClick()\">\r\n        <button (click)=\"OnClose()\" tabindex=\"-1\" style=\"float:right; border: none; background-color: transparent; outline: none; color: white\" *ngIf=\"!getShowTitleBar()\">X</button>\r\n      </div>\r\n      <div #modalForeground class=\"modal-foreground\" [ngStyle]=\"getStyle()\">\r\n        <div #modalheader class=\"modal-header\" *ngIf=\"getShowTitleBar()\">\r\n          {{getText()}}\r\n          <button (click)=\"OnClose()\" style=\"float:right\" tabindex=\"-1\">X</button>\r\n        </div>\r\n        <div [ngStyle]=\"getClientAreaStyles()\">\r\n          <div #modalbody magicViewContainerRef>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  styleUrls: ['./magic-overlay-container.css']\r\n})\r\nexport class MagicOverlayContainer extends BaseMagicOverlayContainer implements OnInit , IMagicViewContainerRef{\r\n  /**\r\n   * HTML to be displayed in the modal window\r\n   */\r\n  modalbodyViewContainerRef : ViewContainerRef;\r\n\r\n  /**\r\n   * Header of the modal window\r\n   */\r\n  @ViewChild('modalheader', { static: false }) headerElementRef: ElementRef;\r\n  /**\r\n   * Foreground of the modal window\r\n   */\r\n  @ViewChild('modalForeground', { static: false }) foregroundElementRef: ElementRef;\r\n\r\n  /**\r\n   *\r\n   */\r\n  @Input() ModalComp = null;\r\n  /**\r\n   *\r\n   */\r\n  @Input() ModalCompParameters: any = {};\r\n\r\n  @Output() onClose = new EventEmitter<void>();\r\n\r\n  /**\r\n   *\r\n   */\r\n  private componentRef = null;\r\n\r\n  /**\r\n   *\r\n   * @param injector\r\n   * @param componentFactoryResolver\r\n   */\r\n  constructor(\r\n\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    this.componentRef = this.modalbodyViewContainerRef.createComponent(this.ModalComp);\r\n    Object.assign(this.componentRef.instance, this.ModalCompParameters);\r\n  }\r\n\r\n\r\n  setViewContainerRef(vcRef: ViewContainerRef){\r\n    this.modalbodyViewContainerRef = vcRef;\r\n  }\r\n\r\n\r\n  /**\r\n   * Returns the form name\r\n   * @returns\r\n   */\r\n  getText() {\r\n    if (this.componentRef !== null) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n      return comp.FormName();\r\n    }\r\n    else\r\n      return '';\r\n  }\r\n\r\n  /**\r\n   * Returns CSS styles for the window\r\n   * @returns\r\n   */\r\n  getStyle() {\r\n    let styles = {};\r\n    if (this.componentRef != undefined) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n\r\n      styles['width'] = comp.Width();\r\n      styles['height'] = comp.Height();\r\n\r\n      if (comp.IsCenteredToWindow()) {\r\n        styles['margin'] = 'auto';\r\n      }\r\n      else {\r\n        styles['margin-left'] = comp.X() + 'px';\r\n        styles['margin-top'] = comp.Y() + 'px';\r\n      }\r\n    }\r\n    return styles;\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS styles for the client area\r\n   * @returns\r\n   */\r\n  getClientAreaStyles() {\r\n    let styles = {};\r\n    if (this.componentRef != undefined) {\r\n      const headerHeight = this.getShowTitleBar() && !isNullOrUndefined(this.headerElementRef) ? (this.headerElementRef.nativeElement.offsetHeight + 1) : 0;\r\n      if (!isNullOrUndefined(this.foregroundElementRef)) {\r\n        const foregroundHeight = this.foregroundElementRef.nativeElement.offsetHeight;\r\n        styles['height'] = (foregroundHeight - headerHeight) + 'px';\r\n\r\n        const foregroundWidth = this.foregroundElementRef.nativeElement.offsetWidth;\r\n        styles['width'] = (foregroundWidth) + 'px';\r\n      }\r\n      styles['overflow'] = 'auto';\r\n    }\r\n    return styles;\r\n  }\r\n\r\n  /**\r\n   * Should the title bar be displayed\r\n   * @returns\r\n   */\r\n  getShowTitleBar() {\r\n    if (this.componentRef != undefined) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n      return comp.ShowTitleBar();\r\n    }\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  OnClose() {\r\n    this.onClose.emit();\r\n  }\r\n\r\n  /**\r\n   * Handles click in the background window\r\n   */\r\n  OnBackgroundClick() {\r\n    let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n\r\n    if (comp.ShouldCloseOnBackgroundClick())\r\n      this.OnClose();\r\n  }\r\n}\r\n"]}
|