@magic-xpa/angular 4.801.0-dev481.243 → 4.801.0-dev481.249
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 +57 -0
- package/{esm2015/magic-xpa-angular.js → esm2020/magic-xpa-angular.mjs} +0 -0
- package/{esm2015/src/controls.metadata.model.js → esm2020/src/controls.metadata.model.mjs} +0 -0
- package/{esm2015/src/interfaces/sub-form-definition.iterface.js → esm2020/src/interfaces/sub-form-definition.iterface.mjs} +1 -0
- package/esm2020/src/magic.core.module.mjs +157 -0
- package/{esm2015/src/services/ISubformMagicService.js → esm2020/src/services/ISubformMagicService.mjs} +1 -0
- package/esm2020/src/services/OverlayWindowService.mjs +208 -0
- package/{esm2015/src/services/StylesMapManager.js → esm2020/src/services/StylesMapManager.mjs} +0 -0
- package/{esm2015/src/services/accessor.magic.service.js → esm2020/src/services/accessor.magic.service.mjs} +2 -2
- package/{esm2015/src/services/commands-collector.magic.service.js → esm2020/src/services/commands-collector.magic.service.mjs} +7 -4
- package/esm2020/src/services/component-list.magic.service.mjs +46 -0
- package/{esm2015/src/services/confirmation.components.magic.provider.js → esm2020/src/services/confirmation.components.magic.provider.mjs} +2 -2
- package/esm2020/src/services/engine.magic.service.mjs +82 -0
- package/{esm2015/src/services/exit.magic.service.js → esm2020/src/services/exit.magic.service.mjs} +2 -2
- package/esm2020/src/services/magic.lazy.loader.service.mjs +16 -0
- package/{esm2015/src/services/magic.providers.js → esm2020/src/services/magic.providers.mjs} +0 -0
- package/{esm2015/src/services/magic.services.js → esm2020/src/services/magic.services.mjs} +2 -2
- package/{esm2015/src/services/mg-date-adapter.js → esm2020/src/services/mg-date-adapter.mjs} +2 -2
- package/{esm2015/src/services/overlay.conainer.magic.provider.js → esm2020/src/services/overlay.conainer.magic.provider.mjs} +2 -2
- package/esm2020/src/services/router-commands.magic.service.mjs +28 -0
- package/{esm2015/src/services/subform.magic.service.js → esm2020/src/services/subform.magic.service.mjs} +14 -10
- package/{esm2015/src/services/table.magic.service.js → esm2020/src/services/table.magic.service.mjs} +2 -2
- package/{esm2015/src/services/task.magics.service.js → esm2020/src/services/task.magics.service.mjs} +2 -2
- package/{esm2015/src/services/title.magic.service.js → esm2020/src/services/title.magic.service.mjs} +2 -2
- package/{esm2015/src/ui/GuiInteractiveExecutor.js → esm2020/src/ui/GuiInteractiveExecutor.mjs} +0 -0
- package/{esm2015/src/ui/components/base-magic-alert.component.js → esm2020/src/ui/components/base-magic-alert.component.mjs} +2 -2
- package/{esm2015/src/ui/components/base-magic-confirm.component.js → esm2020/src/ui/components/base-magic-confirm.component.mjs} +2 -2
- package/esm2020/src/ui/components/magic-alert.component.mjs +71 -0
- package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +82 -0
- package/{esm2015/src/ui/directives/NonMagicControlDirective.js → esm2020/src/ui/directives/NonMagicControlDirective.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/checkbox.magic.directive.js → esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/combobox.magic.directive.js → esm2020/src/ui/directives/magic/combobox.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs} +3 -4
- package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs} +3 -4
- package/{esm2015/src/ui/directives/magic/input.noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/nocontrol.magic.directive.js → esm2020/src/ui/directives/magic/nocontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/row.magic.directive.js → esm2020/src/ui/directives/magic/row.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic-focus.directive.js → esm2020/src/ui/directives/magic-focus.directive.mjs} +2 -2
- package/esm2020/src/ui/directives/magic.directive.mjs +207 -0
- package/{esm2015/src/ui/directives/magicViewContainerRef.directive.js → esm2020/src/ui/directives/magicViewContainerRef.directive.mjs} +3 -3
- package/{esm2015/src/ui/directives/mgformat.magic.directive.js → esm2020/src/ui/directives/mgformat.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/range-validator.magic.directive.js → esm2020/src/ui/directives/range-validator.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/magic-confirmationBox.js → esm2020/src/ui/magic-confirmationBox.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/base-magic-overlay-container.js → esm2020/src/ui/magic-modal/base-magic-overlay-container.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/magic-modal-form.js → esm2020/src/ui/magic-modal/magic-modal-form.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/magic-modal-interface.js → esm2020/src/ui/magic-modal/magic-modal-interface.mjs} +1 -0
- package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +135 -0
- package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +165 -0
- package/esm2020/src/ui/magic-root.component.mjs +237 -0
- package/esm2020/src/ui/mgerror.magic.component.mjs +120 -0
- package/{esm2015/src/ui/pipes/date.magic.pipe.js → esm2020/src/ui/pipes/date.magic.pipe.mjs} +3 -3
- package/{esm2015/src/ui/pipes/time.magic.pipe.js → esm2020/src/ui/pipes/time.magic.pipe.mjs} +3 -3
- package/{esm2015/src/ui/router-container.magic.component.js → esm2020/src/ui/router-container.magic.component.mjs} +2 -2
- package/{esm2015/src/ui/subform.magic.component.js → esm2020/src/ui/subform.magic.component.mjs} +3 -3
- package/{esm2015/src/ui/task-base.magic.component.js → esm2020/src/ui/task-base.magic.component.mjs} +2 -2
- package/{esm2015/src/ui/utils.js → esm2020/src/ui/utils.mjs} +0 -0
- package/fesm2015/magic-xpa-angular.mjs +4578 -0
- package/fesm2015/magic-xpa-angular.mjs.map +1 -0
- package/{fesm2015/magic-xpa-angular.js → fesm2020/magic-xpa-angular.mjs} +433 -412
- package/fesm2020/magic-xpa-angular.mjs.map +1 -0
- package/index.d.ts +1 -0
- package/package.json +28 -15
- package/src/magic.core.module.d.ts +3 -8
- package/src/services/OverlayWindowService.d.ts +2 -2
- package/src/services/accessor.magic.service.d.ts +2 -2
- package/src/services/commands-collector.magic.service.d.ts +2 -2
- package/src/services/component-list.magic.service.d.ts +3 -0
- package/src/services/confirmation.components.magic.provider.d.ts +2 -2
- package/src/services/engine.magic.service.d.ts +2 -2
- package/src/services/exit.magic.service.d.ts +2 -2
- package/src/services/magic.lazy.loader.service.d.ts +6 -0
- package/src/services/magic.services.d.ts +2 -2
- package/src/services/mg-date-adapter.d.ts +2 -2
- package/src/services/overlay.conainer.magic.provider.d.ts +2 -2
- package/src/services/router-commands.magic.service.d.ts +2 -2
- package/src/services/subform.magic.service.d.ts +6 -4
- package/src/services/table.magic.service.d.ts +2 -2
- package/src/services/task.magics.service.d.ts +2 -2
- package/src/services/title.magic.service.d.ts +2 -2
- package/src/ui/components/base-magic-alert.component.d.ts +2 -2
- package/src/ui/components/base-magic-confirm.component.d.ts +2 -2
- package/src/ui/components/magic-alert.component.d.ts +2 -2
- package/src/ui/components/magic-confirmation-box.component.d.ts +2 -2
- package/src/ui/directives/NonMagicControlDirective.d.ts +2 -2
- package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/checkbox.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/combobox.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/row.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic-focus.directive.d.ts +2 -2
- package/src/ui/directives/magic.directive.d.ts +2 -2
- package/src/ui/directives/magicViewContainerRef.directive.d.ts +2 -2
- package/src/ui/directives/mgformat.magic.directive.d.ts +2 -2
- package/src/ui/directives/range-validator.magic.directive.d.ts +2 -2
- package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +7 -5
- package/src/ui/magic-modal/magic-overlay-container.d.ts +2 -2
- package/src/ui/magic-root.component.d.ts +2 -2
- package/src/ui/mgerror.magic.component.d.ts +2 -2
- package/src/ui/pipes/date.magic.pipe.d.ts +2 -2
- package/src/ui/pipes/time.magic.pipe.d.ts +2 -2
- package/src/ui/router-container.magic.component.d.ts +2 -2
- package/src/ui/subform.magic.component.d.ts +2 -2
- package/src/ui/task-base.magic.component.d.ts +2 -2
- package/bundles/magic-xpa-angular.umd.js +0 -5028
- package/bundles/magic-xpa-angular.umd.js.map +0 -1
- package/bundles/magic-xpa-angular.umd.min.js +0 -16
- package/bundles/magic-xpa-angular.umd.min.js.map +0 -1
- package/esm2015/index.js +0 -56
- package/esm2015/src/magic.core.module.js +0 -173
- package/esm2015/src/services/OverlayWindowService.js +0 -205
- package/esm2015/src/services/component-list.magic.service.js +0 -36
- package/esm2015/src/services/engine.magic.service.js +0 -82
- package/esm2015/src/services/router-commands.magic.service.js +0 -25
- package/esm2015/src/ui/components/magic-alert.component.js +0 -72
- package/esm2015/src/ui/components/magic-confirmation-box.component.js +0 -83
- package/esm2015/src/ui/directives/magic.directive.js +0 -207
- package/esm2015/src/ui/magic-modal/magic-overlay-container-wrapper.js +0 -131
- package/esm2015/src/ui/magic-modal/magic-overlay-container.js +0 -169
- package/esm2015/src/ui/magic-root.component.js +0 -237
- package/esm2015/src/ui/mgerror.magic.component.js +0 -120
- package/fesm2015/magic-xpa-angular.js.map +0 -1
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Injectable } from "@angular/core";
|
|
3
|
-
import { Subject } from "rxjs";
|
|
4
|
-
import { MagicBridge } from "@magic-xpa/engine";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class EngineMagicService {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.magicBridge = MagicBridge;
|
|
9
|
-
this.isStub = false;
|
|
10
|
-
this.isLoggedIn = false;
|
|
11
|
-
this.refreshDom = new Subject();
|
|
12
|
-
this.interactiveCommands = new Subject();
|
|
13
|
-
}
|
|
14
|
-
startMagicEngine(httpClient) {
|
|
15
|
-
this.magicBridge.registerExecuteCommandsCallback(data => {
|
|
16
|
-
if (!this.isStub) {
|
|
17
|
-
try {
|
|
18
|
-
const list = data;
|
|
19
|
-
for (let c of list) {
|
|
20
|
-
this.refreshDom.next(c);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
catch (e) {
|
|
24
|
-
console.dir(e);
|
|
25
|
-
console.log('magic engine not found');
|
|
26
|
-
console.log('moving to stub mode');
|
|
27
|
-
this.isStub = true;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
this.magicBridge.registerInteractiveCallback(data => {
|
|
32
|
-
if (!this.isStub) {
|
|
33
|
-
this.interactiveCommands.next(data);
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
this.magicBridge.Initialize(httpClient);
|
|
37
|
-
}
|
|
38
|
-
terminateMagic() {
|
|
39
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
yield this.magicBridge.TerminateMagic();
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
insertEvent(guiEvent) {
|
|
44
|
-
if (!this.isStub)
|
|
45
|
-
this.magicBridge.insertEvent(guiEvent);
|
|
46
|
-
}
|
|
47
|
-
GetRangedValue(taskId, controlName, value) {
|
|
48
|
-
return this.magicBridge.GetRangedValue(taskId, controlName, value);
|
|
49
|
-
}
|
|
50
|
-
GetControlPictureMask(taskId, controlName) {
|
|
51
|
-
return this.magicBridge.GetControlPictureMask(taskId, controlName);
|
|
52
|
-
}
|
|
53
|
-
GetFormattedValue(taskId, controlName, value) {
|
|
54
|
-
return this.magicBridge.GetFormattedValue(taskId, controlName, value);
|
|
55
|
-
}
|
|
56
|
-
ValidateControlValue(taskId, controlName, value) {
|
|
57
|
-
return this.magicBridge.ValidateControlValue(taskId, controlName, value);
|
|
58
|
-
}
|
|
59
|
-
GetFldRanges(taskId, controlName) {
|
|
60
|
-
return this.magicBridge.GetFldRanges(taskId, controlName);
|
|
61
|
-
}
|
|
62
|
-
saveData(data) {
|
|
63
|
-
}
|
|
64
|
-
getIsLoggedIn() {
|
|
65
|
-
return this.isLoggedIn;
|
|
66
|
-
}
|
|
67
|
-
setIsLoggedIn(setIsLoggedIn) {
|
|
68
|
-
this.isLoggedIn = setIsLoggedIn;
|
|
69
|
-
}
|
|
70
|
-
TransCacheExists() {
|
|
71
|
-
return this.magicBridge.TransCacheExists();
|
|
72
|
-
}
|
|
73
|
-
TerminateContextUsingFetchAPI() {
|
|
74
|
-
this.magicBridge.TerminateContextUsingFetchAPI();
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
EngineMagicService.ɵfac = function EngineMagicService_Factory(t) { return new (t || EngineMagicService)(); };
|
|
78
|
-
EngineMagicService.ɵprov = i0.ɵɵdefineInjectable({ token: EngineMagicService, factory: EngineMagicService.ɵfac });
|
|
79
|
-
(function () { i0.ɵsetClassMetadata(EngineMagicService, [{
|
|
80
|
-
type: Injectable
|
|
81
|
-
}], null, null); })();
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLm1hZ2ljLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy9zZXJ2aWNlcy9lbmdpbmUubWFnaWMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBWSxXQUFXLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQzs7QUFRekQsTUFBTSxPQUFPLGtCQUFrQjtJQUQvQjtRQUVFLGdCQUFXLEdBQUcsV0FBVyxDQUFDO1FBQzFCLFdBQU0sR0FBRyxLQUFLLENBQUM7UUFFZixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBRW5CLGVBQVUsR0FBd0IsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUNoRCx3QkFBbUIsR0FBNEIsSUFBSSxPQUFPLEVBQUUsQ0FBQztLQThFOUQ7SUE1RUMsZ0JBQWdCLENBQUMsVUFBc0I7UUFDckMsSUFBSSxDQUFDLFdBQVcsQ0FBQywrQkFBK0IsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN0RCxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRTtnQkFDaEIsSUFBSTtvQkFDRixNQUFNLElBQUksR0FBRyxJQUFvQixDQUFDO29CQUNsQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRTt3QkFDbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7cUJBQ3pCO2lCQUNGO2dCQUNELE9BQU8sQ0FBQyxFQUFFO29CQUNSLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ2YsT0FBTyxDQUFDLEdBQUcsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO29CQUN0QyxPQUFPLENBQUMsR0FBRyxDQUFDLHFCQUFxQixDQUFDLENBQUM7b0JBQ25DLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO2lCQUNwQjthQUNGO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsV0FBVyxDQUFDLDJCQUEyQixDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2xELElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO2dCQUNkLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDckM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFSyxjQUFjOztZQUNsQixNQUFNLElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDMUMsQ0FBQztLQUFBO0lBRUQsV0FBVyxDQUFDLFFBQW1CO1FBQzdCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUNkLElBQUksQ0FBQyxXQUFXLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxjQUFjLENBQUMsTUFBYyxFQUFFLFdBQW1CLEVBQUUsS0FBYTtRQUMvRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDckUsQ0FBQztJQUVELHFCQUFxQixDQUFDLE1BQWMsRUFBRSxXQUFtQjtRQUN2RCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMscUJBQXFCLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUFjLEVBQUcsV0FBbUIsRUFBRSxLQUFVO1FBQ2hFLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hFLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxNQUFjLEVBQUUsV0FBbUIsRUFBRSxLQUFVO1FBQ2xFLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzNFLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBYyxFQUFFLFdBQW1CO1FBQzlDLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxRQUFRLENBQUMsSUFBVztJQUdwQixDQUFDO0lBRUQsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN6QixDQUFDO0lBRUQsYUFBYSxDQUFDLGFBQXNCO1FBQ2xDLElBQUksQ0FBQyxVQUFVLEdBQUcsYUFBYSxDQUFDO0lBQ2xDLENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUM3QyxDQUFDO0lBRUQsNkJBQTZCO1FBQzNCLElBQUksQ0FBQyxXQUFXLENBQUMsNkJBQTZCLEVBQUUsQ0FBQztJQUNuRCxDQUFDOztvRkFwRlUsa0JBQWtCOzBEQUFsQixrQkFBa0IsV0FBbEIsa0JBQWtCO29DQUFsQixrQkFBa0I7Y0FEOUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtTdWJqZWN0fSBmcm9tIFwicnhqc1wiO1xyXG5cclxuaW1wb3J0IHtJR3VpRXZlbnQsIE1hZ2ljQnJpZGdlfSBmcm9tIFwiQG1hZ2ljLXhwYS9lbmdpbmVcIjtcclxuaW1wb3J0IHtHdWlDb21tYW5kLCBHdWlJbnRlcmFjdGl2ZX0gZnJvbSBcIkBtYWdpYy14cGEvZ3VpXCI7XHJcbmltcG9ydCB7SHR0cENsaWVudH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcblxyXG4vKipcclxuICogQGlnbm9yZVxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRW5naW5lTWFnaWNTZXJ2aWNlIHtcclxuICBtYWdpY0JyaWRnZSA9IE1hZ2ljQnJpZGdlO1xyXG4gIGlzU3R1YiA9IGZhbHNlO1xyXG4gIC8vIHRydWUgd2hlbiB1c2VyIGlzIGxvZ2dlZCBpbiBtYWdpY1xyXG4gIGlzTG9nZ2VkSW4gPSBmYWxzZTtcclxuICAvL1RPRE8gLSB1bnJlZ2lzdGVyXHJcbiAgcmVmcmVzaERvbTogU3ViamVjdDxHdWlDb21tYW5kPiA9IG5ldyBTdWJqZWN0KCk7XHJcbiAgaW50ZXJhY3RpdmVDb21tYW5kczogU3ViamVjdDxHdWlJbnRlcmFjdGl2ZT4gPSBuZXcgU3ViamVjdCgpO1xyXG5cclxuICBzdGFydE1hZ2ljRW5naW5lKGh0dHBDbGllbnQ6IEh0dHBDbGllbnQpIHtcclxuICAgIHRoaXMubWFnaWNCcmlkZ2UucmVnaXN0ZXJFeGVjdXRlQ29tbWFuZHNDYWxsYmFjayhkYXRhID0+IHtcclxuICAgICAgaWYgKCF0aGlzLmlzU3R1Yikge1xyXG4gICAgICAgIHRyeSB7XHJcbiAgICAgICAgICBjb25zdCBsaXN0ID0gZGF0YSBhcyBHdWlDb21tYW5kW107XHJcbiAgICAgICAgICBmb3IgKGxldCBjIG9mIGxpc3QpIHtcclxuICAgICAgICAgICAgdGhpcy5yZWZyZXNoRG9tLm5leHQoYyk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNhdGNoIChlKSB7XHJcbiAgICAgICAgICBjb25zb2xlLmRpcihlKTtcclxuICAgICAgICAgIGNvbnNvbGUubG9nKCdtYWdpYyBlbmdpbmUgbm90IGZvdW5kJyk7XHJcbiAgICAgICAgICBjb25zb2xlLmxvZygnbW92aW5nIHRvIHN0dWIgbW9kZScpO1xyXG4gICAgICAgICAgdGhpcy5pc1N0dWIgPSB0cnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfSk7XHJcblxyXG4gICAgdGhpcy5tYWdpY0JyaWRnZS5yZWdpc3RlckludGVyYWN0aXZlQ2FsbGJhY2soZGF0YSA9PiB7XHJcbiAgICAgIGlmICghdGhpcy5pc1N0dWIpIHtcclxuICAgICAgICAgIHRoaXMuaW50ZXJhY3RpdmVDb21tYW5kcy5uZXh0KGRhdGEpO1xyXG4gICAgICAgIH1cclxuICAgIH0pO1xyXG5cclxuICAgIHRoaXMubWFnaWNCcmlkZ2UuSW5pdGlhbGl6ZShodHRwQ2xpZW50KTtcclxuICB9XHJcblxyXG4gIGFzeW5jIHRlcm1pbmF0ZU1hZ2ljKCk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgYXdhaXQgdGhpcy5tYWdpY0JyaWRnZS5UZXJtaW5hdGVNYWdpYygpO1xyXG4gIH1cclxuXHJcbiAgaW5zZXJ0RXZlbnQoZ3VpRXZlbnQ6IElHdWlFdmVudCk6IHZvaWQge1xyXG4gICAgaWYgKCF0aGlzLmlzU3R1YilcclxuICAgICAgdGhpcy5tYWdpY0JyaWRnZS5pbnNlcnRFdmVudChndWlFdmVudCk7XHJcbiAgfVxyXG5cclxuICBHZXRSYW5nZWRWYWx1ZSh0YXNrSWQ6IHN0cmluZywgY29udHJvbE5hbWU6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5tYWdpY0JyaWRnZS5HZXRSYW5nZWRWYWx1ZSh0YXNrSWQsIGNvbnRyb2xOYW1lLCB2YWx1ZSk7XHJcbiAgfVxyXG5cclxuICBHZXRDb250cm9sUGljdHVyZU1hc2sodGFza0lkOiBzdHJpbmcsIGNvbnRyb2xOYW1lOiBzdHJpbmcpOiBhbnkge1xyXG4gICAgcmV0dXJuIHRoaXMubWFnaWNCcmlkZ2UuR2V0Q29udHJvbFBpY3R1cmVNYXNrKHRhc2tJZCwgY29udHJvbE5hbWUpO1xyXG4gIH1cclxuXHJcbiAgR2V0Rm9ybWF0dGVkVmFsdWUodGFza0lkOiBzdHJpbmcsICBjb250cm9sTmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KTogYW55IHtcclxuICAgIHJldHVybiB0aGlzLm1hZ2ljQnJpZGdlLkdldEZvcm1hdHRlZFZhbHVlKHRhc2tJZCwgY29udHJvbE5hbWUsIHZhbHVlKTtcclxuICB9XHJcblxyXG4gIFZhbGlkYXRlQ29udHJvbFZhbHVlKHRhc2tJZDogc3RyaW5nLCBjb250cm9sTmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLm1hZ2ljQnJpZGdlLlZhbGlkYXRlQ29udHJvbFZhbHVlKHRhc2tJZCwgY29udHJvbE5hbWUsIHZhbHVlKTtcclxuICB9XHJcblxyXG4gIEdldEZsZFJhbmdlcyh0YXNrSWQ6IHN0cmluZywgY29udHJvbE5hbWU6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5tYWdpY0JyaWRnZS5HZXRGbGRSYW5nZXModGFza0lkLCBjb250cm9sTmFtZSk7XHJcbiAgfVxyXG5cclxuICBzYXZlRGF0YShkYXRhOnN0cmluZylcclxuICB7XHJcbiAgICAvL3RoaXMubWFnaWNCcmlkZ2Uuc2F2ZURhdGEoZGF0YSk7XHJcbiAgfVxyXG5cclxuICBnZXRJc0xvZ2dlZEluKCk6Ym9vbGVhbntcclxuICAgIHJldHVybiB0aGlzLmlzTG9nZ2VkSW47XHJcbiAgfVxyXG5cclxuICBzZXRJc0xvZ2dlZEluKHNldElzTG9nZ2VkSW46IGJvb2xlYW4pe1xyXG4gICAgdGhpcy5pc0xvZ2dlZEluID0gc2V0SXNMb2dnZWRJbjtcclxuICB9XHJcblxyXG4gIFRyYW5zQ2FjaGVFeGlzdHMoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5tYWdpY0JyaWRnZS5UcmFuc0NhY2hlRXhpc3RzKCk7XHJcbiAgfVxyXG5cclxuICBUZXJtaW5hdGVDb250ZXh0VXNpbmdGZXRjaEFQSSgpOiB2b2lkIHtcclxuICAgIHRoaXMubWFnaWNCcmlkZ2UuVGVybWluYXRlQ29udGV4dFVzaW5nRmV0Y2hBUEkoKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { isNullOrUndefined } from '@magic-xpa/mscorelib';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class RouteCommand {
|
|
5
|
-
}
|
|
6
|
-
export class RouterCommandsMagicService {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.pendingRouteCommands = [];
|
|
9
|
-
}
|
|
10
|
-
AddRouteCommand(routeCommand) {
|
|
11
|
-
this.pendingRouteCommands.push(routeCommand);
|
|
12
|
-
}
|
|
13
|
-
ExecuteNextCommand() {
|
|
14
|
-
let pendingRouteCommand = this.pendingRouteCommands.shift();
|
|
15
|
-
if (!isNullOrUndefined(pendingRouteCommand)) {
|
|
16
|
-
pendingRouteCommand.callerMgSubformServiceRef.ExecuteRouteCommand(pendingRouteCommand);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
RouterCommandsMagicService.ɵfac = function RouterCommandsMagicService_Factory(t) { return new (t || RouterCommandsMagicService)(); };
|
|
21
|
-
RouterCommandsMagicService.ɵprov = i0.ɵɵdefineInjectable({ token: RouterCommandsMagicService, factory: RouterCommandsMagicService.ɵfac });
|
|
22
|
-
(function () { i0.ɵsetClassMetadata(RouterCommandsMagicService, [{
|
|
23
|
-
type: Injectable
|
|
24
|
-
}], null, null); })();
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyLWNvbW1hbmRzLm1hZ2ljLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy9zZXJ2aWNlcy9yb3V0ZXItY29tbWFuZHMubWFnaWMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBTyxpQkFBaUIsRUFBQyxNQUFNLHNCQUFzQixDQUFDOztBQU03RCxNQUFNLE9BQU8sWUFBWTtDQU14QjtBQUtELE1BQU0sT0FBTywwQkFBMEI7SUFEdkM7UUFFVSx5QkFBb0IsR0FBbUIsRUFBRSxDQUFDO0tBYW5EO0lBWEMsZUFBZSxDQUFFLFlBQTBCO1FBQ3pDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELGtCQUFrQjtRQUNoQixJQUFJLG1CQUFtQixHQUFpQixJQUFJLENBQUMsb0JBQW9CLENBQUMsS0FBSyxFQUFFLENBQUM7UUFFMUUsSUFBSSxDQUFDLGlCQUFpQixDQUFDLG1CQUFtQixDQUFDLEVBQUU7WUFDM0MsbUJBQW1CLENBQUMseUJBQXlCLENBQUMsbUJBQW1CLENBQUMsbUJBQW1CLENBQUMsQ0FBQztTQUN4RjtJQUNILENBQUM7O29HQWJVLDBCQUEwQjtrRUFBMUIsMEJBQTBCLFdBQTFCLDBCQUEwQjtvQ0FBMUIsMEJBQTBCO2NBRHRDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IExpc3QsaXNOdWxsT3JVbmRlZmluZWR9IGZyb20gJ0BtYWdpYy14cGEvbXNjb3JlbGliJztcclxuaW1wb3J0IHsgSVN1YmZvcm1NYWdpY1NlcnZpY2UgfSBmcm9tICcuL0lTdWJmb3JtTWFnaWNTZXJ2aWNlJztcclxuXHJcbi8qKlxyXG4gKiBAaWdub3JlXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgUm91dGVDb21tYW5kIHtcclxuICBjYWxsZXJNZ1N1YmZvcm1TZXJ2aWNlUmVmOiBJU3ViZm9ybU1hZ2ljU2VydmljZTtcclxuICByb3V0ZXJPdXRsZXROYW1lOiBzdHJpbmc7XHJcbiAgZm9ybU5hbWU6IHN0cmluZztcclxuICBwYXJhbWV0ZXJzOiBhbnk7XHJcbiAgcm91dGVQYXJhbXM6IExpc3Q8YW55PjtcclxufVxyXG4vKipcclxuICogQGlnbm9yZVxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgUm91dGVyQ29tbWFuZHNNYWdpY1NlcnZpY2Uge1xyXG4gIHByaXZhdGUgcGVuZGluZ1JvdXRlQ29tbWFuZHM6IFJvdXRlQ29tbWFuZFtdID0gW107XHJcblxyXG4gIEFkZFJvdXRlQ29tbWFuZCAocm91dGVDb21tYW5kOiBSb3V0ZUNvbW1hbmQpIHtcclxuICAgIHRoaXMucGVuZGluZ1JvdXRlQ29tbWFuZHMucHVzaChyb3V0ZUNvbW1hbmQpO1xyXG4gIH1cclxuXHJcbiAgRXhlY3V0ZU5leHRDb21tYW5kKCkge1xyXG4gICAgbGV0IHBlbmRpbmdSb3V0ZUNvbW1hbmQ6IFJvdXRlQ29tbWFuZCA9IHRoaXMucGVuZGluZ1JvdXRlQ29tbWFuZHMuc2hpZnQoKTtcclxuXHJcbiAgICBpZiAoIWlzTnVsbE9yVW5kZWZpbmVkKHBlbmRpbmdSb3V0ZUNvbW1hbmQpKSB7XHJcbiAgICAgIHBlbmRpbmdSb3V0ZUNvbW1hbmQuY2FsbGVyTWdTdWJmb3JtU2VydmljZVJlZi5FeGVjdXRlUm91dGVDb21tYW5kKHBlbmRpbmdSb3V0ZUNvbW1hbmQpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import { BaseMagicAlertComponent } from './base-magic-alert.component';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class MagicAlertComponent extends BaseMagicAlertComponent {
|
|
5
|
-
}
|
|
6
|
-
MagicAlertComponent.ɵfac = function MagicAlertComponent_Factory(t) { return ɵMagicAlertComponent_BaseFactory(t || MagicAlertComponent); };
|
|
7
|
-
MagicAlertComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicAlertComponent, selectors: [["sample-magic-alert-component"]], features: [i0.ɵɵInheritDefinitionFeature], decls: 8, vars: 2, consts: [[1, "mg-message-background"], [3, "click"]], template: function MagicAlertComponent_Template(rf, ctx) { if (rf & 1) {
|
|
8
|
-
i0.ɵɵelementStart(0, "div");
|
|
9
|
-
i0.ɵɵelementStart(1, "div", 0);
|
|
10
|
-
i0.ɵɵelementStart(2, "h2");
|
|
11
|
-
i0.ɵɵtext(3);
|
|
12
|
-
i0.ɵɵelementEnd();
|
|
13
|
-
i0.ɵɵelementStart(4, "p");
|
|
14
|
-
i0.ɵɵtext(5);
|
|
15
|
-
i0.ɵɵelementEnd();
|
|
16
|
-
i0.ɵɵelementStart(6, "button", 1);
|
|
17
|
-
i0.ɵɵlistener("click", function MagicAlertComponent_Template_button_click_6_listener() { return ctx.OnClose(); });
|
|
18
|
-
i0.ɵɵtext(7, "OK");
|
|
19
|
-
i0.ɵɵelementEnd();
|
|
20
|
-
i0.ɵɵelementEnd();
|
|
21
|
-
i0.ɵɵelementEnd();
|
|
22
|
-
} if (rf & 2) {
|
|
23
|
-
i0.ɵɵadvance(3);
|
|
24
|
-
i0.ɵɵtextInterpolate1(" ", ctx.title, "");
|
|
25
|
-
i0.ɵɵadvance(2);
|
|
26
|
-
i0.ɵɵtextInterpolate1("", ctx.message, " ");
|
|
27
|
-
} }, styles: [".mg-message-background[_ngcontent-%COMP%] {\n background-color: #F5F5F5;\n text-align: center;\n width: 40%;\n font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n padding: 17px;\n border-radius: 5px;\n text-align: center;\n margin-top: 10% ;\n margin-left: auto;\n margin-right: auto;\n border: 1px solid gray;\n }\n\n button[_ngcontent-%COMP%] {\n background-color: #8CD4F5;\n color: white;\n border: none;\n box-shadow: none;\n font-size: 17px;\n font-weight: 500;\n -webkit-border-radius: 4px;\n border-radius: 5px;\n padding: 10px 32px;\n margin: 26px 5px 0 5px;\n cursor: pointer;\n }"] });
|
|
28
|
-
const ɵMagicAlertComponent_BaseFactory = i0.ɵɵgetInheritedFactory(MagicAlertComponent);
|
|
29
|
-
(function () { i0.ɵsetClassMetadata(MagicAlertComponent, [{
|
|
30
|
-
type: Component,
|
|
31
|
-
args: [{
|
|
32
|
-
selector: 'sample-magic-alert-component',
|
|
33
|
-
template: `<div>
|
|
34
|
-
<div class="mg-message-background">
|
|
35
|
-
<h2> {{title}}</h2>
|
|
36
|
-
<p>{{message}} </p>
|
|
37
|
-
|
|
38
|
-
<button (click)="OnClose()">OK</button>
|
|
39
|
-
</div>
|
|
40
|
-
</div>`,
|
|
41
|
-
styles: [`
|
|
42
|
-
.mg-message-background {
|
|
43
|
-
background-color: #F5F5F5;
|
|
44
|
-
text-align: center;
|
|
45
|
-
width: 40%;
|
|
46
|
-
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
|
47
|
-
padding: 17px;
|
|
48
|
-
border-radius: 5px;
|
|
49
|
-
text-align: center;
|
|
50
|
-
margin-top: 10% ;
|
|
51
|
-
margin-left: auto;
|
|
52
|
-
margin-right: auto;
|
|
53
|
-
border: 1px solid gray;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
button {
|
|
57
|
-
background-color: #8CD4F5;
|
|
58
|
-
color: white;
|
|
59
|
-
border: none;
|
|
60
|
-
box-shadow: none;
|
|
61
|
-
font-size: 17px;
|
|
62
|
-
font-weight: 500;
|
|
63
|
-
-webkit-border-radius: 4px;
|
|
64
|
-
border-radius: 5px;
|
|
65
|
-
padding: 10px 32px;
|
|
66
|
-
margin: 26px 5px 0 5px;
|
|
67
|
-
cursor: pointer;
|
|
68
|
-
}
|
|
69
|
-
`]
|
|
70
|
-
}]
|
|
71
|
-
}], null, null); })();
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvY29tcG9uZW50cy9tYWdpYy1hbGVydC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUE4Q3ZFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUyx1QkFBdUI7O2tIQUFwRCxtQkFBbUI7d0RBQW5CLG1CQUFtQjtRQXRDbkIsMkJBQ1Q7UUFBQSw4QkFDRTtRQUFBLDBCQUFLO1FBQUEsWUFBUztRQUFBLGlCQUFLO1FBQ25CLHlCQUFHO1FBQUEsWUFBWTtRQUFBLGlCQUFJO1FBRW5CLGlDQUE0QjtRQUFwQixnR0FBUyxhQUFTLElBQUM7UUFBQyxrQkFBRTtRQUFBLGlCQUFTO1FBQ3pDLGlCQUFNO1FBQ1IsaUJBQU07O1FBTEcsZUFBUztRQUFULHlDQUFTO1FBQ1gsZUFBWTtRQUFaLDJDQUFZOztrRUFtQ1IsbUJBQW1CO29DQUFuQixtQkFBbUI7Y0F4Qy9CLFNBQVM7ZUFBQztnQkFDVCxRQUFRLEVBQUUsOEJBQThCO2dCQUN4QyxRQUFRLEVBQUU7Ozs7Ozs7U0FPSDtnQkFDUCxNQUFNLEVBQUUsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTRCUixDQUFDO2FBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VNYWdpY0FsZXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLW1hZ2ljLWFsZXJ0LmNvbXBvbmVudCc7XG5cblxuLyoqKlxuICogVGhpcyBpcyBzYW1wbGUgY29tcG9uZW50IGZvciB0aGUgYWxlcnQgbWVzc2FnZVxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYW1wbGUtbWFnaWMtYWxlcnQtY29tcG9uZW50JyxcbiAgdGVtcGxhdGU6IGA8ZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJtZy1tZXNzYWdlLWJhY2tncm91bmRcIj5cbiAgICAgIDxoMj4ge3t0aXRsZX19PC9oMj5cbiAgICAgIDxwPnt7bWVzc2FnZX19IDwvcD5cblxuICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiT25DbG9zZSgpXCI+T0s8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+YCxcbiAgc3R5bGVzOiBbYFxuICAgIC5tZy1tZXNzYWdlLWJhY2tncm91bmQge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjRjVGNUY1O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHdpZHRoOiA0MCU7XG4gIGZvbnQtZmFtaWx5OiAnT3BlbiBTYW5zJywgJ0hlbHZldGljYSBOZXVlJywgSGVsdmV0aWNhLCBBcmlhbCwgc2Fucy1zZXJpZjtcbiAgcGFkZGluZzogMTdweDtcbiAgYm9yZGVyLXJhZGl1czogNXB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIG1hcmdpbi10b3A6IDEwJSA7XG4gIG1hcmdpbi1sZWZ0OiBhdXRvO1xuICBtYXJnaW4tcmlnaHQ6IGF1dG87XG4gIGJvcmRlcjogMXB4IHNvbGlkICBncmF5O1xuICB9XG5cbiAgYnV0dG9uIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogIzhDRDRGNTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXI6IG5vbmU7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGZvbnQtc2l6ZTogMTdweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgLXdlYmtpdC1ib3JkZXItcmFkaXVzOiA0cHg7XG4gIGJvcmRlci1yYWRpdXM6IDVweDtcbiAgcGFkZGluZzogMTBweCAzMnB4O1xuICBtYXJnaW46IDI2cHggNXB4IDAgNXB4O1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIH1cbiAgYF1cbn0pXG5leHBvcnQgY2xhc3MgTWFnaWNBbGVydENvbXBvbmVudCBleHRlbmRzICBCYXNlTWFnaWNBbGVydENvbXBvbmVudHtcblxufVxuIl19
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import { BaseMagicConfirmComponent } from './base-magic-confirm.component';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class MagicConfirmationBoxComponent extends BaseMagicConfirmComponent {
|
|
5
|
-
}
|
|
6
|
-
MagicConfirmationBoxComponent.ɵfac = function MagicConfirmationBoxComponent_Factory(t) { return ɵMagicConfirmationBoxComponent_BaseFactory(t || MagicConfirmationBoxComponent); };
|
|
7
|
-
MagicConfirmationBoxComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicConfirmationBoxComponent, selectors: [["sample-magic-confirmation-box"]], features: [i0.ɵɵInheritDefinitionFeature], decls: 11, vars: 2, consts: [[1, "mg-message-background"], [3, "click"], [1, "cancel", 3, "click"]], template: function MagicConfirmationBoxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
8
|
-
i0.ɵɵelementStart(0, "div");
|
|
9
|
-
i0.ɵɵelementStart(1, "div", 0);
|
|
10
|
-
i0.ɵɵelementStart(2, "h2");
|
|
11
|
-
i0.ɵɵtext(3);
|
|
12
|
-
i0.ɵɵelementEnd();
|
|
13
|
-
i0.ɵɵtext(4);
|
|
14
|
-
i0.ɵɵelement(5, "br");
|
|
15
|
-
i0.ɵɵelement(6, "br");
|
|
16
|
-
i0.ɵɵelementStart(7, "button", 1);
|
|
17
|
-
i0.ɵɵlistener("click", function MagicConfirmationBoxComponent_Template_button_click_7_listener() { return ctx.OnClose(true); });
|
|
18
|
-
i0.ɵɵtext(8, "OK");
|
|
19
|
-
i0.ɵɵelementEnd();
|
|
20
|
-
i0.ɵɵelementStart(9, "button", 2);
|
|
21
|
-
i0.ɵɵlistener("click", function MagicConfirmationBoxComponent_Template_button_click_9_listener() { return ctx.OnClose(false); });
|
|
22
|
-
i0.ɵɵtext(10, "Cancel");
|
|
23
|
-
i0.ɵɵelementEnd();
|
|
24
|
-
i0.ɵɵelementEnd();
|
|
25
|
-
i0.ɵɵelementEnd();
|
|
26
|
-
} if (rf & 2) {
|
|
27
|
-
i0.ɵɵadvance(3);
|
|
28
|
-
i0.ɵɵtextInterpolate1(" ", ctx.title, "");
|
|
29
|
-
i0.ɵɵadvance(1);
|
|
30
|
-
i0.ɵɵtextInterpolate1(" ", ctx.message, " ");
|
|
31
|
-
} }, styles: [".mg-message-background[_ngcontent-%COMP%] {\n background-color: #F5F5F5;\n text-align: center;\n width: 40%;\n font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n padding: 17px;\n border-radius: 5px;\n text-align: center;\n margin-top: 10% ;\n margin-left: auto;\n margin-right: auto;\n border: 1px solid gray;\n }\n\n button[_ngcontent-%COMP%] {\n background-color: #8CD4F5;\n color: white;\n border: none;\n box-shadow: none;\n font-size: 17px;\n font-weight: 500;\n -webkit-border-radius: 4px;\n border-radius: 5px;\n padding: 10px 32px;\n margin: 26px 5px 0 5px;\n cursor: pointer;\n }\n \n button.cancel[_ngcontent-%COMP%] {\n background-color: #C1C1C1;\n }"] });
|
|
32
|
-
const ɵMagicConfirmationBoxComponent_BaseFactory = i0.ɵɵgetInheritedFactory(MagicConfirmationBoxComponent);
|
|
33
|
-
(function () { i0.ɵsetClassMetadata(MagicConfirmationBoxComponent, [{
|
|
34
|
-
type: Component,
|
|
35
|
-
args: [{
|
|
36
|
-
selector: 'sample-magic-confirmation-box',
|
|
37
|
-
template: `<div>
|
|
38
|
-
<div class="mg-message-background">
|
|
39
|
-
<h2> {{title}}</h2>
|
|
40
|
-
{{message}}
|
|
41
|
-
<br>
|
|
42
|
-
<br>
|
|
43
|
-
|
|
44
|
-
<button (click)="OnClose(true)">OK</button>
|
|
45
|
-
<button class="cancel" (click)="OnClose(false)">Cancel</button>
|
|
46
|
-
</div>
|
|
47
|
-
</div>`,
|
|
48
|
-
styles: [`
|
|
49
|
-
.mg-message-background {
|
|
50
|
-
background-color: #F5F5F5;
|
|
51
|
-
text-align: center;
|
|
52
|
-
width: 40%;
|
|
53
|
-
font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
|
54
|
-
padding: 17px;
|
|
55
|
-
border-radius: 5px;
|
|
56
|
-
text-align: center;
|
|
57
|
-
margin-top: 10% ;
|
|
58
|
-
margin-left: auto;
|
|
59
|
-
margin-right: auto;
|
|
60
|
-
border: 1px solid gray;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
button {
|
|
64
|
-
background-color: #8CD4F5;
|
|
65
|
-
color: white;
|
|
66
|
-
border: none;
|
|
67
|
-
box-shadow: none;
|
|
68
|
-
font-size: 17px;
|
|
69
|
-
font-weight: 500;
|
|
70
|
-
-webkit-border-radius: 4px;
|
|
71
|
-
border-radius: 5px;
|
|
72
|
-
padding: 10px 32px;
|
|
73
|
-
margin: 26px 5px 0 5px;
|
|
74
|
-
cursor: pointer;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
button.cancel {
|
|
78
|
-
background-color: #C1C1C1;
|
|
79
|
-
}
|
|
80
|
-
`]
|
|
81
|
-
}]
|
|
82
|
-
}], null, null); })();
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtY29uZmlybWF0aW9uLWJveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy91aS9jb21wb25lbnRzL21hZ2ljLWNvbmZpcm1hdGlvbi1ib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0FBb0QzRSxNQUFNLE9BQU8sNkJBQThCLFNBQVEseUJBQXlCOztnSkFBL0QsNkJBQTZCO2tFQUE3Qiw2QkFBNkI7UUE3QzdCLDJCQUNUO1FBQUEsOEJBQ0U7UUFBQSwwQkFBSztRQUFBLFlBQVM7UUFBQSxpQkFBSztRQUNuQixZQUNBO1FBQUEscUJBQ0E7UUFBQSxxQkFFQTtRQUFBLGlDQUFnQztRQUF4QiwwR0FBUyxZQUFRLElBQUksQ0FBQyxJQUFDO1FBQUMsa0JBQUU7UUFBQSxpQkFBUztRQUMzQyxpQ0FBZ0Q7UUFBekIsMEdBQVMsWUFBUSxLQUFLLENBQUMsSUFBQztRQUFDLHVCQUFNO1FBQUEsaUJBQVM7UUFDakUsaUJBQU07UUFDUixpQkFBTTs7UUFSRyxlQUFTO1FBQVQseUNBQVM7UUFDZCxlQUNBO1FBREEsNENBQ0E7OzRFQXlDTyw2QkFBNkI7b0NBQTdCLDZCQUE2QjtjQS9DekMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSwrQkFBK0I7Z0JBQ3pDLFFBQVEsRUFBRTs7Ozs7Ozs7OztTQVVIO2dCQUNQLE1BQU0sRUFBRSxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWdDUixDQUFDO2FBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VNYWdpY0NvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL2Jhc2UtbWFnaWMtY29uZmlybS5jb21wb25lbnQnO1xuXG4vKioqXG4gKiBUaGlzIGlzIHNhbXBsZSBjb21wb25lbnQgZm9yIHRoZSBjb25maXJtYXRpb24gYm94XG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NhbXBsZS1tYWdpYy1jb25maXJtYXRpb24tYm94JyxcbiAgdGVtcGxhdGU6IGA8ZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJtZy1tZXNzYWdlLWJhY2tncm91bmRcIj5cbiAgICAgIDxoMj4ge3t0aXRsZX19PC9oMj5cbiAgICAgIHt7bWVzc2FnZX19XG4gICAgICA8YnI+XG4gICAgICA8YnI+XG5cbiAgICAgIDxidXR0b24gKGNsaWNrKT1cIk9uQ2xvc2UodHJ1ZSlcIj5PSzwvYnV0dG9uPlxuICAgICAgPGJ1dHRvbiBjbGFzcz1cImNhbmNlbFwiIChjbGljayk9XCJPbkNsb3NlKGZhbHNlKVwiPkNhbmNlbDwvYnV0dG9uPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5gLFxuICBzdHlsZXM6IFtgXG4gICAgLm1nLW1lc3NhZ2UtYmFja2dyb3VuZCB7XG4gIGJhY2tncm91bmQtY29sb3I6ICNGNUY1RjU7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgd2lkdGg6IDQwJTtcbiAgZm9udC1mYW1pbHk6ICdPcGVuIFNhbnMnLCAnSGVsdmV0aWNhIE5ldWUnLCBIZWx2ZXRpY2EsIEFyaWFsLCBzYW5zLXNlcmlmO1xuICBwYWRkaW5nOiAxN3B4O1xuICBib3JkZXItcmFkaXVzOiA1cHg7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgbWFyZ2luLXRvcDogMTAlIDtcbiAgbWFyZ2luLWxlZnQ6IGF1dG87XG4gIG1hcmdpbi1yaWdodDogYXV0bztcbiAgYm9yZGVyOiAxcHggc29saWQgIGdyYXk7XG4gIH1cblxuICBidXR0b24ge1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjOENENEY1O1xuICBjb2xvcjogd2hpdGU7XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgZm9udC1zaXplOiAxN3B4O1xuICBmb250LXdlaWdodDogNTAwO1xuICAtd2Via2l0LWJvcmRlci1yYWRpdXM6IDRweDtcbiAgYm9yZGVyLXJhZGl1czogNXB4O1xuICBwYWRkaW5nOiAxMHB4IDMycHg7XG4gIG1hcmdpbjogMjZweCA1cHggMCA1cHg7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgfVxuICAgIFxuICAgIGJ1dHRvbi5jYW5jZWwge1xuICAgICAgYmFja2dyb3VuZC1jb2xvcjogI0MxQzFDMTtcbiAgICB9XG4gIGBdXG59KVxuZXhwb3J0IGNsYXNzIE1hZ2ljQ29uZmlybWF0aW9uQm94Q29tcG9uZW50IGV4dGVuZHMgQmFzZU1hZ2ljQ29uZmlybUNvbXBvbmVudCB7XG5cbn1cbiJdfQ==
|
|
@@ -1,207 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, Input, Optional, Renderer2, ViewContainerRef } from '@angular/core';
|
|
2
|
-
import { isNullOrUndefined } from '@magic-xpa/mscorelib';
|
|
3
|
-
import { CommandType, GuiConstants, HtmlProperties, InteractiveCommandType, Modifiers } from '@magic-xpa/gui';
|
|
4
|
-
import { getGuiEventObj } from '@magic-xpa/engine';
|
|
5
|
-
import { TaskBaseMagicComponent } from '../task-base.magic.component';
|
|
6
|
-
import { TaskMagicService } from '../../services/task.magics.service';
|
|
7
|
-
import { debounceTime, filter, map } from 'rxjs/operators';
|
|
8
|
-
import { RowMagicDirective } from './magic/row.magic.directive';
|
|
9
|
-
import { BindingLevel, StorageAttributeType } from '@magic-xpa/utils';
|
|
10
|
-
import { fromEvent } from 'rxjs/internal/observable/fromEvent';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../../services/task.magics.service";
|
|
13
|
-
import * as i2 from "./magic/row.magic.directive";
|
|
14
|
-
export class MagicDirective {
|
|
15
|
-
constructor(_task, element, renderer, vcRef, magicRow) {
|
|
16
|
-
this._task = _task;
|
|
17
|
-
this.element = element;
|
|
18
|
-
this.renderer = renderer;
|
|
19
|
-
this.vcRef = vcRef;
|
|
20
|
-
this.magicRow = magicRow;
|
|
21
|
-
this.eventHandlers = {};
|
|
22
|
-
this.eventsOnlyVal = false;
|
|
23
|
-
this.htmlElement = this.element.nativeElement;
|
|
24
|
-
if (!(typeof magicRow === 'undefined' || magicRow === null))
|
|
25
|
-
this.rowId = magicRow.rowId;
|
|
26
|
-
}
|
|
27
|
-
set magic(val) {
|
|
28
|
-
this.id = val;
|
|
29
|
-
this.selector = 'magic';
|
|
30
|
-
}
|
|
31
|
-
;
|
|
32
|
-
set eventsOnly(val) {
|
|
33
|
-
console.log('eventsOnly');
|
|
34
|
-
this.eventsOnlyVal = true;
|
|
35
|
-
}
|
|
36
|
-
;
|
|
37
|
-
get task() {
|
|
38
|
-
return this._task;
|
|
39
|
-
}
|
|
40
|
-
regEvents() {
|
|
41
|
-
this.eventHandlers['focusin'] = this.OnFocus.bind(this);
|
|
42
|
-
Object.keys(this.eventHandlers).forEach((key) => {
|
|
43
|
-
this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);
|
|
44
|
-
});
|
|
45
|
-
let events = ['click', 'mousedown', 'dblclick'];
|
|
46
|
-
events.forEach(event => {
|
|
47
|
-
this.renderer.listen(this.htmlElement, event, (e) => {
|
|
48
|
-
let fromButton = false;
|
|
49
|
-
if (this.htmlElement instanceof HTMLButtonElement)
|
|
50
|
-
fromButton = true;
|
|
51
|
-
this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));
|
|
52
|
-
if (MagicDirective.noOfAutoCompleteBoxesOpened < 1)
|
|
53
|
-
e.cancelBubble = true;
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
this.renderer.listen(this.htmlElement, 'change', (e) => {
|
|
57
|
-
let guiEvent = getGuiEventObj('selectionchanged', this.id, +this.rowId);
|
|
58
|
-
if ((event.target).selectedIndex !== undefined) {
|
|
59
|
-
guiEvent.Value = (event.target).selectedIndex.toString();
|
|
60
|
-
e.cancelBubble = true;
|
|
61
|
-
this.task.insertEvent(guiEvent);
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
fromEvent(this.htmlElement, 'input').pipe(map((event) => {
|
|
65
|
-
return event.target.value;
|
|
66
|
-
}), debounceTime(200)).subscribe((x) => {
|
|
67
|
-
if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {
|
|
68
|
-
let attribute = this.task.Records.list[0].getControlMetadata(this.id).dataType;
|
|
69
|
-
if (attribute !== StorageAttributeType.Date && attribute != StorageAttributeType.Time)
|
|
70
|
-
this.task.mgAccessorService.setValueToControl(this.id, x, true);
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
this.renderer.listen(this.htmlElement, 'keydown', (e) => {
|
|
74
|
-
let guiEvent = getGuiEventObj('keydown', this.id, +this.rowId);
|
|
75
|
-
guiEvent.modifiers = Modifiers.MODIFIER_NONE;
|
|
76
|
-
if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)
|
|
77
|
-
guiEvent.modifiers = Modifiers.MODIFIER_ALT;
|
|
78
|
-
else if (e.ctrlKey && e.keyCode !== GuiConstants.KEY_CTRL)
|
|
79
|
-
guiEvent.modifiers = Modifiers.MODIFIER_CTRL;
|
|
80
|
-
let supportedKey = e.keyCode === GuiConstants.KEY_PG_UP ||
|
|
81
|
-
e.keyCode === GuiConstants.KEY_PG_DOWN ||
|
|
82
|
-
e.keyCode === GuiConstants.KEY_LEFT ||
|
|
83
|
-
e.keyCode === GuiConstants.KEY_RIGHT ||
|
|
84
|
-
e.keyCode === GuiConstants.KEY_UP ||
|
|
85
|
-
e.keyCode === GuiConstants.KEY_DOWN ||
|
|
86
|
-
e.keyCode === GuiConstants.KEY_ESC ||
|
|
87
|
-
e.keyCode === GuiConstants.KEY_HOME ||
|
|
88
|
-
e.keyCode === GuiConstants.KEY_END ||
|
|
89
|
-
e.keyCode === GuiConstants.KEY_RETURN ||
|
|
90
|
-
(e.keyCode >= GuiConstants.KEY_F1 && e.keyCode <= GuiConstants.KEY_F12);
|
|
91
|
-
if (guiEvent.modifiers !== Modifiers.MODIFIER_NONE || supportedKey) {
|
|
92
|
-
guiEvent.keyCode = e.keyCode;
|
|
93
|
-
if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && (!MagicDirective.opened && MagicDirective.noOfAutoCompleteBoxesOpened < 1))
|
|
94
|
-
e.cancelBubble = true;
|
|
95
|
-
this.task.insertEvent(guiEvent);
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
OnFocus() {
|
|
100
|
-
this.task.insertEvent(getGuiEventObj('focus', this.id, +this.rowId));
|
|
101
|
-
event.cancelBubble = true;
|
|
102
|
-
}
|
|
103
|
-
IsSameElement(command) {
|
|
104
|
-
let line = command.line;
|
|
105
|
-
if (this.task.isTableControl(command.CtrlName))
|
|
106
|
-
line = this.task.getGuiRowId(line, true);
|
|
107
|
-
return (command.CtrlName === this.id &&
|
|
108
|
-
(line === +this.rowId ||
|
|
109
|
-
(line === 0 && isNullOrUndefined(this.rowId))));
|
|
110
|
-
}
|
|
111
|
-
IsSameComponent(command) {
|
|
112
|
-
return (command.controlName === this.id);
|
|
113
|
-
}
|
|
114
|
-
regUpdatesUI() {
|
|
115
|
-
this.subscribeRefreshDom = this.task
|
|
116
|
-
.refreshDom.pipe(filter(c => this.IsSameElement(c)))
|
|
117
|
-
.subscribe(a => {
|
|
118
|
-
let command = a;
|
|
119
|
-
if (isNullOrUndefined(this.rowId))
|
|
120
|
-
this.rowId = '0';
|
|
121
|
-
try {
|
|
122
|
-
if (!this.eventsOnlyVal)
|
|
123
|
-
this.handleCommand(command);
|
|
124
|
-
}
|
|
125
|
-
catch (ex) {
|
|
126
|
-
console.dir(ex);
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
this.subscribeInteractiveCommands = this.task.interactiveCommands
|
|
130
|
-
.pipe(filter(c => this.IsSameComponent(c)))
|
|
131
|
-
.subscribe(command => {
|
|
132
|
-
this.handleInteractiveCommands(command);
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
ngOnInit() {
|
|
136
|
-
this.regEvents();
|
|
137
|
-
this.regUpdatesUI();
|
|
138
|
-
}
|
|
139
|
-
handleCommand(command) {
|
|
140
|
-
switch (command.CommandType) {
|
|
141
|
-
case CommandType.SET_PROPERTY:
|
|
142
|
-
this.handleSetProperty(command);
|
|
143
|
-
break;
|
|
144
|
-
case CommandType.SET_FOCUS:
|
|
145
|
-
this.focusUnlistener();
|
|
146
|
-
if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))
|
|
147
|
-
this.htmlElement.focus();
|
|
148
|
-
this.focusUnlistener = this.renderer.listen(this.htmlElement, 'focusin', this.eventHandlers['focusin']);
|
|
149
|
-
break;
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
handleInteractiveCommands(command) {
|
|
153
|
-
switch (command._commandType) {
|
|
154
|
-
case InteractiveCommandType.CALL_JS:
|
|
155
|
-
let methodName = command._str;
|
|
156
|
-
let args = command.arguments;
|
|
157
|
-
let magicComponent = (this.vcRef._hostView).find(v => v instanceof TaskBaseMagicComponent);
|
|
158
|
-
let resultString = '';
|
|
159
|
-
try {
|
|
160
|
-
if (!isNullOrUndefined(magicComponent[methodName])) {
|
|
161
|
-
resultString = magicComponent[methodName].apply(magicComponent, args);
|
|
162
|
-
}
|
|
163
|
-
else
|
|
164
|
-
console.error('Instance method ' + methodName + ' does not exists');
|
|
165
|
-
}
|
|
166
|
-
catch (e) {
|
|
167
|
-
console.error(e.message);
|
|
168
|
-
}
|
|
169
|
-
command.resultString = resultString;
|
|
170
|
-
break;
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
handleSetProperty(command) {
|
|
174
|
-
switch (command.Operation) {
|
|
175
|
-
case HtmlProperties.ReadOnly:
|
|
176
|
-
if (command.obj1 != true)
|
|
177
|
-
this.renderer.removeAttribute(this.htmlElement, command.Operation);
|
|
178
|
-
else
|
|
179
|
-
this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);
|
|
180
|
-
break;
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
ngOnDestroy() {
|
|
184
|
-
this.subscribeRefreshDom.unsubscribe();
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
MagicDirective.opened = false;
|
|
188
|
-
MagicDirective.noOfAutoCompleteBoxesOpened = 0;
|
|
189
|
-
MagicDirective.ɵfac = function MagicDirective_Factory(t) { return new (t || MagicDirective)(i0.ɵɵdirectiveInject(i1.TaskMagicService), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i2.RowMagicDirective, 8)); };
|
|
190
|
-
MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors: [["", "magic", ""]], inputs: { magic: "magic", eventsOnly: "eventsOnly", rowId: "rowId" } });
|
|
191
|
-
(function () { i0.ɵsetClassMetadata(MagicDirective, [{
|
|
192
|
-
type: Directive,
|
|
193
|
-
args: [{
|
|
194
|
-
selector: '[magic]'
|
|
195
|
-
}]
|
|
196
|
-
}], function () { return [{ type: i1.TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.RowMagicDirective, decorators: [{
|
|
197
|
-
type: Optional
|
|
198
|
-
}] }]; }, { magic: [{
|
|
199
|
-
type: Input,
|
|
200
|
-
args: ['magic']
|
|
201
|
-
}], eventsOnly: [{
|
|
202
|
-
type: Input,
|
|
203
|
-
args: ['eventsOnly']
|
|
204
|
-
}], rowId: [{
|
|
205
|
-
type: Input
|
|
206
|
-
}] }); })();
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, Optional, Renderer2, ViewContainerRef } from '@angular/core';\r\nimport { isNullOrUndefined } from '@magic-xpa/mscorelib';\r\n\r\nimport {\r\n  CommandType,\r\n  GuiCommand,\r\n  GuiConstants,\r\n  GuiInteractive,\r\n  HtmlProperties,\r\n  InteractiveCommandType,\r\n  Modifiers\r\n} from '@magic-xpa/gui';\r\nimport { getGuiEventObj, IGuiEvent } from '@magic-xpa/engine';\r\n\r\nimport { TaskBaseMagicComponent } from '../task-base.magic.component';\r\nimport { TaskMagicService } from '../../services/task.magics.service';\r\nimport { debounceTime, filter, map } from 'rxjs/operators';\r\nimport { RowMagicDirective } from './magic/row.magic.directive';\r\nimport { Subscription } from 'rxjs';\r\nimport { BindingLevel, StorageAttributeType } from '@magic-xpa/utils';\r\nimport { fromEvent } from 'rxjs/internal/observable/fromEvent';\r\n\r\n/**\r\n * Connects HTML elements to the Magic Web Client engine\r\n */\r\n@Directive({\r\n  selector: '[magic]'\r\n})\r\n\r\nexport class MagicDirective implements OnInit, OnDestroy {\r\n  @Input('magic') set magic(val) {\r\n    this.id = val;\r\n    this.selector = 'magic';\r\n  };\r\n\r\n  /**\r\n   * This flag is used when we only want to register to events, but do not want to execute commands sent from server\r\n   */\r\n  @Input('eventsOnly') set eventsOnly(val) {\r\n    console.log('eventsOnly');\r\n    this.eventsOnlyVal = true;\r\n\r\n  };\r\n\r\n  /**\r\n   * Row id of the control, for when it is on a table\r\n   */\r\n  @Input() public rowId: string;\r\n  /**\r\n   *\r\n   */\r\n  //@Input() events: any[] = [];\r\n\r\n  /**\r\n   * The HTML element connected to this directive\r\n   */\r\n  protected htmlElement: HTMLElement;\r\n  /**\r\n   * Magic's component handling this control\r\n   */\r\n  public component: TaskBaseMagicComponent;\r\n  /**\r\n   * Collection of event handlers for this element\r\n   */\r\n  private eventHandlers: { [key: string]: () => void; } = {};\r\n  /**\r\n   * Id of this element\r\n   */\r\n  public id: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  protected selector: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  subscribeRefreshDom: Subscription;\r\n\r\n  private focusUnlistener: (() => void);\r\n\r\n  public eventsOnlyVal = false;\r\n\r\n  public static opened = false;\r\n\r\n  public static noOfAutoCompleteBoxesOpened =0;\r\n\r\n  subscribeInteractiveCommands: Subscription;\r\n\r\n  /**\r\n   *\r\n   * @param _task The task service\r\n   * @param element The element for which the directive is applied\r\n   * @param renderer Renderer for the element\r\n   * @param vcRef\r\n   * @param magicRow\r\n   */\r\n  constructor(\r\n    protected _task: TaskMagicService,\r\n    protected element: ElementRef,\r\n    protected renderer: Renderer2,\r\n    protected vcRef: ViewContainerRef,\r\n    @Optional() protected magicRow: RowMagicDirective) {\r\n\r\n    this.htmlElement = this.element.nativeElement;\r\n    //let c = (<any>this.vcRef)._view;\r\n    //while (!(c instanceof TaskBaseMagicComponent)) {\r\n    //  c = c.component;\r\n    //}\r\n    //this.component = c;\r\n    if (!(typeof magicRow === 'undefined' || magicRow === null))\r\n      this.rowId = magicRow.rowId;\r\n  }\r\n\r\n  /**\r\n   * Get the task service\r\n   * @returns\r\n   */\r\n  get task(): TaskMagicService {\r\n    return this._task;\r\n  }\r\n\r\n  /**\r\n   * Register to the events this element may need to handle\r\n   */\r\n  protected regEvents() {\r\n    // Handle events for which event handler may be removed and restored\r\n    this.eventHandlers['focusin'] = this.OnFocus.bind(this);\r\n\r\n    Object.keys(this.eventHandlers).forEach((key) => {\r\n      this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);\r\n    });\r\n\r\n    // Handle events with anonymous  event handlers\r\n    let events: string[] = ['click', 'mousedown', 'dblclick'];// ,'resize', 'load', 'unload'\r\n    events.forEach(event => {\r\n      this.renderer.listen(this.htmlElement, event, (e) => {\r\n        \r\n          // check if the event is fired from zoom button ( to identify the connected zoom button in engine)\r\n        let fromButton = false; \r\n        if(this.htmlElement instanceof HTMLButtonElement)\r\n          fromButton = true;\r\n\r\n        this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));\r\n        if (MagicDirective.noOfAutoCompleteBoxesOpened< 1)\r\n          e.cancelBubble = true;\r\n      });\r\n    });\r\n\r\n\r\n    this.renderer.listen(this.htmlElement, 'change', (e) => {\r\n      let guiEvent: IGuiEvent = getGuiEventObj('selectionchanged', this.id, +this.rowId);\r\n\r\n      if ((<any>(event.target)).selectedIndex !== undefined) {\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString();\r\n        e.cancelBubble = true;\r\n        this.task.insertEvent(guiEvent);\r\n      }\r\n \r\n    });\r\n\r\n    // handle the input event\r\n    fromEvent(this.htmlElement, 'input').pipe(\r\n      map((event: any) => {\r\n        return event.target.value;\r\n      }),\r\n      debounceTime(200) // time after which value will be sent to magic\r\n    ).subscribe((x) => {\r\n        if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {\r\n          // Don't support character binding for date/time values\r\n         let attribute : StorageAttributeType =  this.task.Records.list[0].getControlMetadata(this.id).dataType;\r\n         if(attribute !== StorageAttributeType.Date && attribute != StorageAttributeType.Time)\r\n            this.task.mgAccessorService.setValueToControl(this.id, x, true);\r\n        }\r\n    });\r\n\r\n    this.renderer.listen(this.htmlElement, 'keydown', (e: KeyboardEvent) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj('keydown', this.id, +this.rowId);\r\n        guiEvent.modifiers = Modifiers.MODIFIER_NONE;\r\n\r\n        if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)\r\n            guiEvent.modifiers = Modifiers.MODIFIER_ALT;\r\n\r\n        else if (e.ctrlKey && e.keyCode !== GuiConstants.KEY_CTRL)\r\n            guiEvent.modifiers = Modifiers.MODIFIER_CTRL;\r\n\r\n        let supportedKey = e.keyCode === GuiConstants.KEY_PG_UP ||\r\n            e.keyCode === GuiConstants.KEY_PG_DOWN ||\r\n            e.keyCode === GuiConstants.KEY_LEFT ||\r\n            e.keyCode === GuiConstants.KEY_RIGHT ||\r\n            e.keyCode === GuiConstants.KEY_UP ||\r\n            e.keyCode === GuiConstants.KEY_DOWN ||\r\n            e.keyCode === GuiConstants.KEY_ESC ||\r\n            e.keyCode === GuiConstants.KEY_HOME ||\r\n            e.keyCode === GuiConstants.KEY_END ||\r\n            e.keyCode === GuiConstants.KEY_RETURN ||\r\n            (e.keyCode >= GuiConstants.KEY_F1 && e.keyCode <= GuiConstants.KEY_F12);\r\n\r\n        if (guiEvent.modifiers !== Modifiers.MODIFIER_NONE || supportedKey) {\r\n            guiEvent.keyCode = e.keyCode;\r\n\r\n            // Defect 160021 fixed - don't set e.cancelBubble when combobox is opened and esc key is pressed\r\n            if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && (!MagicDirective.opened && MagicDirective.noOfAutoCompleteBoxesOpened < 1))\r\n                e.cancelBubble = true;\r\n\r\n            this.task.insertEvent(guiEvent);\r\n        }\r\n    });\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle focus event\r\n   */\r\n  private OnFocus() {\r\n    this.task.insertEvent(getGuiEventObj('focus', this.id, +this.rowId));\r\n    event.cancelBubble = true;\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's element\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameElement(command) {\r\n    let line: number = command.line;\r\n\r\n    if (this.task.isTableControl(command.CtrlName))\r\n      line = this.task.getGuiRowId(line, true);\r\n\r\n    return (command.CtrlName === this.id &&\r\n      (line === +this.rowId ||\r\n        (line === 0 && isNullOrUndefined(this.rowId))));\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's component\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameComponent(command: GuiInteractive) {\r\n    return (command.controlName === this.id);\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  private regUpdatesUI() {\r\n    this.subscribeRefreshDom = this.task\r\n      .refreshDom.pipe(filter(c => this.IsSameElement(c)))\r\n      .subscribe(a => {\r\n          let command: GuiCommand = a;\r\n          if (isNullOrUndefined(this.rowId))\r\n            this.rowId = '0';\r\n          try {\r\n            if (!this.eventsOnlyVal)\r\n              this.handleCommand(command);\r\n          } catch (ex) {\r\n            console.dir(ex);\r\n          }\r\n        }\r\n      );\r\n\r\n    this.subscribeInteractiveCommands = this.task.interactiveCommands\r\n      .pipe(filter(c => this.IsSameComponent(c)))\r\n      .subscribe(command => {\r\n        this.handleInteractiveCommands(command);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Initializes this object\r\n   */\r\n  ngOnInit(): void {\r\n    this.regEvents();\r\n    this.regUpdatesUI();\r\n  }\r\n\r\n  /**\r\n   * Handles the commands received from the Magic WebClient engine\r\n   * @param command\r\n   */\r\n  handleCommand(command: GuiCommand) {\r\n    switch (command.CommandType) {\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_FOCUS:\r\n            this.focusUnlistener();\r\n       // Do not set focus on connected zoom  button\r\n        if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))\r\n          this.htmlElement.focus();\r\n        this.focusUnlistener = this.renderer.listen(this.htmlElement, 'focusin', this.eventHandlers['focusin']);\r\n        break;\r\n      }\r\n  }\r\n\r\n  /**\r\n   * handle the interactive commands like CallJS\r\n   */\r\n  handleInteractiveCommands(command: GuiInteractive) {\r\n    switch (command._commandType) {\r\n      case InteractiveCommandType.CALL_JS:\r\n        let methodName: string = command._str;\r\n        let args: Array<any> = command.arguments;\r\n        let magicComponent: TaskBaseMagicComponent = ((<any>this.vcRef)._hostView).find(v => v instanceof TaskBaseMagicComponent);\r\n        let resultString = '';\r\n\r\n        try {\r\n          if (!isNullOrUndefined(magicComponent[methodName])) {\r\n            // invoke the method on instance of magic componenet\r\n            resultString = magicComponent[methodName].apply(magicComponent, args);\r\n          }\r\n          else\r\n            console.error('Instance method ' + methodName + ' does not exists'); // when method is not found\r\n        } catch (e) {\r\n          // any other exception\r\n          console.error(e.message);\r\n        }\r\n        command.resultString = resultString; // update the return value\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle the Magic set-property command\r\n   * @param command\r\n   */\r\n  handleSetProperty(command: GuiCommand) {\r\n    switch (command.Operation) {\r\n      case HtmlProperties.ReadOnly:\r\n        if (command.obj1 != true)\r\n          this.renderer.removeAttribute(this.htmlElement, command.Operation);\r\n        else\r\n          this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);\r\n\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n\r\n    this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n}\r\n"]}
|