@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,229 @@
|
|
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 { fromEvent } from "rxjs";
|
10
|
+
import { BindingLevel, MgControlType, StorageAttributeType } from "@magic-xpa/utils";
|
11
|
+
import { Platform } from "@angular/cdk/platform";
|
12
|
+
import * as i0 from "@angular/core";
|
13
|
+
import * as i1 from "../../services/task.magics.service";
|
14
|
+
import * as i2 from "@angular/cdk/platform";
|
15
|
+
import * as i3 from "./magic/row.magic.directive";
|
16
|
+
export class MagicDirective {
|
17
|
+
_task;
|
18
|
+
element;
|
19
|
+
renderer;
|
20
|
+
vcRef;
|
21
|
+
platform;
|
22
|
+
magicRow;
|
23
|
+
set magic(val) {
|
24
|
+
this.id = val;
|
25
|
+
this.selector = "magic";
|
26
|
+
}
|
27
|
+
;
|
28
|
+
set eventsOnly(val) {
|
29
|
+
console.log("eventsOnly");
|
30
|
+
this.eventsOnlyVal = true;
|
31
|
+
}
|
32
|
+
;
|
33
|
+
rowId;
|
34
|
+
htmlElement;
|
35
|
+
component;
|
36
|
+
eventHandlers = {};
|
37
|
+
id;
|
38
|
+
selector;
|
39
|
+
subscribeRefreshDom;
|
40
|
+
focusUnlistener;
|
41
|
+
eventsOnlyVal = false;
|
42
|
+
static opened = false;
|
43
|
+
static noOfAutoCompleteBoxesOpened = 0;
|
44
|
+
subscribeInteractiveCommands;
|
45
|
+
constructor(_task, element, renderer, vcRef, platform, magicRow) {
|
46
|
+
this._task = _task;
|
47
|
+
this.element = element;
|
48
|
+
this.renderer = renderer;
|
49
|
+
this.vcRef = vcRef;
|
50
|
+
this.platform = platform;
|
51
|
+
this.magicRow = magicRow;
|
52
|
+
this.htmlElement = this.element.nativeElement;
|
53
|
+
if (!(typeof magicRow === "undefined" || magicRow === null))
|
54
|
+
this.rowId = magicRow.rowId;
|
55
|
+
}
|
56
|
+
get task() {
|
57
|
+
return this._task;
|
58
|
+
}
|
59
|
+
regEvents() {
|
60
|
+
this.eventHandlers["focusin"] = this.OnFocus.bind(this);
|
61
|
+
Object.keys(this.eventHandlers).forEach((key) => {
|
62
|
+
this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);
|
63
|
+
});
|
64
|
+
let events = ["click", "mousedown", "dblclick"];
|
65
|
+
events.forEach(event => {
|
66
|
+
this.renderer.listen(this.htmlElement, event, (e) => {
|
67
|
+
let fromButton = false;
|
68
|
+
if (this.htmlElement instanceof HTMLButtonElement)
|
69
|
+
fromButton = true;
|
70
|
+
if (fromButton && (this.platform.IOS || this.platform.SAFARI))
|
71
|
+
this.task.insertEvent(getGuiEventObj("focus", this.id, +this.rowId));
|
72
|
+
this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));
|
73
|
+
if (MagicDirective.noOfAutoCompleteBoxesOpened < 1)
|
74
|
+
e.cancelBubble = true;
|
75
|
+
});
|
76
|
+
});
|
77
|
+
this.renderer.listen(this.htmlElement, "change", (e) => {
|
78
|
+
let guiEvent = getGuiEventObj("selectionchanged", this.id, +this.rowId);
|
79
|
+
if ((event.target).selectedIndex !== undefined) {
|
80
|
+
guiEvent.Value = (event.target).selectedIndex.toString();
|
81
|
+
e.cancelBubble = true;
|
82
|
+
this.task.insertEvent(guiEvent);
|
83
|
+
}
|
84
|
+
});
|
85
|
+
fromEvent(this.htmlElement, "input").pipe(map((event) => {
|
86
|
+
return event.target.value;
|
87
|
+
}), debounceTime(200)).subscribe((x) => {
|
88
|
+
if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {
|
89
|
+
let attribute = this.task.Records.list[0].getControlMetadata(this.id).dataType;
|
90
|
+
if (attribute !== StorageAttributeType.Date && attribute != StorageAttributeType.Time)
|
91
|
+
this.task.mgAccessorService.setValueToControl(this.id, x, true);
|
92
|
+
}
|
93
|
+
});
|
94
|
+
this.renderer.listen(this.htmlElement, "keydown", (e) => {
|
95
|
+
let guiEvent = getGuiEventObj("keydown", this.id, +this.rowId);
|
96
|
+
guiEvent.modifiers = Modifiers.MODIFIER_NONE;
|
97
|
+
if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)
|
98
|
+
guiEvent.modifiers = Modifiers.MODIFIER_ALT;
|
99
|
+
else if (e.ctrlKey && e.keyCode !== GuiConstants.KEY_CTRL)
|
100
|
+
guiEvent.modifiers = Modifiers.MODIFIER_CTRL;
|
101
|
+
let supportedKey = e.keyCode === GuiConstants.KEY_PG_UP ||
|
102
|
+
e.keyCode === GuiConstants.KEY_PG_DOWN ||
|
103
|
+
e.keyCode === GuiConstants.KEY_LEFT ||
|
104
|
+
e.keyCode === GuiConstants.KEY_RIGHT ||
|
105
|
+
e.keyCode === GuiConstants.KEY_UP ||
|
106
|
+
e.keyCode === GuiConstants.KEY_DOWN ||
|
107
|
+
e.keyCode === GuiConstants.KEY_ESC ||
|
108
|
+
e.keyCode === GuiConstants.KEY_HOME ||
|
109
|
+
e.keyCode === GuiConstants.KEY_END ||
|
110
|
+
e.keyCode === GuiConstants.KEY_RETURN ||
|
111
|
+
(e.keyCode >= GuiConstants.KEY_F1 && e.keyCode <= GuiConstants.KEY_F12);
|
112
|
+
if (guiEvent.modifiers !== Modifiers.MODIFIER_NONE || supportedKey) {
|
113
|
+
guiEvent.keyCode = e.keyCode;
|
114
|
+
if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && (!MagicDirective.opened && MagicDirective.noOfAutoCompleteBoxesOpened < 1))
|
115
|
+
e.cancelBubble = true;
|
116
|
+
this.task.insertEvent(guiEvent);
|
117
|
+
}
|
118
|
+
});
|
119
|
+
}
|
120
|
+
OnFocus() {
|
121
|
+
this.task.insertEvent(getGuiEventObj("focus", this.id, +this.rowId));
|
122
|
+
event.cancelBubble = true;
|
123
|
+
}
|
124
|
+
IsSameElement(command) {
|
125
|
+
let line = command.line;
|
126
|
+
if (this.task.isTableControl(command.CtrlName))
|
127
|
+
line = this.task.getGuiRowId(line, true);
|
128
|
+
return (command.CtrlName === this.id &&
|
129
|
+
(line === +this.rowId ||
|
130
|
+
(line === 0 && isNullOrUndefined(this.rowId))));
|
131
|
+
}
|
132
|
+
IsSameComponent(command) {
|
133
|
+
return (command.controlName === this.id);
|
134
|
+
}
|
135
|
+
regUpdatesUI() {
|
136
|
+
this.subscribeRefreshDom = this.task
|
137
|
+
.refreshDom.pipe(filter(c => this.IsSameElement(c)))
|
138
|
+
.subscribe(a => {
|
139
|
+
let command = a;
|
140
|
+
if (isNullOrUndefined(this.rowId))
|
141
|
+
this.rowId = "0";
|
142
|
+
try {
|
143
|
+
if (!this.eventsOnlyVal)
|
144
|
+
this.handleCommand(command);
|
145
|
+
}
|
146
|
+
catch (ex) {
|
147
|
+
console.dir(ex);
|
148
|
+
}
|
149
|
+
});
|
150
|
+
this.subscribeInteractiveCommands = this.task.interactiveCommands
|
151
|
+
.pipe(filter(c => this.IsSameComponent(c)))
|
152
|
+
.subscribe(command => {
|
153
|
+
this.handleInteractiveCommands(command);
|
154
|
+
});
|
155
|
+
}
|
156
|
+
ngOnInit() {
|
157
|
+
this.regEvents();
|
158
|
+
this.regUpdatesUI();
|
159
|
+
}
|
160
|
+
handleCommand(command) {
|
161
|
+
switch (command.CommandType) {
|
162
|
+
case CommandType.SET_PROPERTY:
|
163
|
+
this.handleSetProperty(command);
|
164
|
+
break;
|
165
|
+
case CommandType.SET_FOCUS:
|
166
|
+
this.focusUnlistener();
|
167
|
+
if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))
|
168
|
+
this.htmlElement.focus();
|
169
|
+
this.focusUnlistener = this.renderer.listen(this.htmlElement, "focusin", this.eventHandlers["focusin"]);
|
170
|
+
break;
|
171
|
+
}
|
172
|
+
}
|
173
|
+
handleInteractiveCommands(command) {
|
174
|
+
switch (command._commandType) {
|
175
|
+
case InteractiveCommandType.CALL_JS:
|
176
|
+
let methodName = command._str;
|
177
|
+
let args = command.arguments;
|
178
|
+
let magicComponent = (this.vcRef._hostLView).find(v => v instanceof TaskBaseMagicComponent);
|
179
|
+
let resultString = "";
|
180
|
+
try {
|
181
|
+
if (!isNullOrUndefined(magicComponent[methodName])) {
|
182
|
+
resultString = magicComponent[methodName].apply(magicComponent, args);
|
183
|
+
}
|
184
|
+
else
|
185
|
+
console.error("Instance method " + methodName + " does not exists");
|
186
|
+
}
|
187
|
+
catch (e) {
|
188
|
+
console.error(e.message);
|
189
|
+
}
|
190
|
+
command.resultString = resultString;
|
191
|
+
break;
|
192
|
+
}
|
193
|
+
}
|
194
|
+
handleSetProperty(command) {
|
195
|
+
switch (command.Operation) {
|
196
|
+
case HtmlProperties.ReadOnly:
|
197
|
+
{
|
198
|
+
if (command.obj.Type == MgControlType.CTRL_TYPE_TEXT)
|
199
|
+
if (command.obj1 != true)
|
200
|
+
this.renderer.removeAttribute(this.htmlElement, command.Operation);
|
201
|
+
else
|
202
|
+
this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);
|
203
|
+
}
|
204
|
+
break;
|
205
|
+
}
|
206
|
+
}
|
207
|
+
ngOnDestroy() {
|
208
|
+
this.subscribeRefreshDom.unsubscribe();
|
209
|
+
}
|
210
|
+
static ɵ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.Platform), i0.ɵɵdirectiveInject(i3.RowMagicDirective, 8)); };
|
211
|
+
static ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors: [["", "magic", ""]], inputs: { magic: "magic", eventsOnly: "eventsOnly", rowId: "rowId" } });
|
212
|
+
}
|
213
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicDirective, [{
|
214
|
+
type: Directive,
|
215
|
+
args: [{
|
216
|
+
selector: "[magic]"
|
217
|
+
}]
|
218
|
+
}], () => [{ type: i1.TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.Platform }, { type: i3.RowMagicDirective, decorators: [{
|
219
|
+
type: Optional
|
220
|
+
}] }], { magic: [{
|
221
|
+
type: Input,
|
222
|
+
args: ["magic"]
|
223
|
+
}], eventsOnly: [{
|
224
|
+
type: Input,
|
225
|
+
args: ["eventsOnly"]
|
226
|
+
}], rowId: [{
|
227
|
+
type: Input
|
228
|
+
}] }); })();
|
229
|
+
//# 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, fromEvent } from \"rxjs\";\r\nimport { BindingLevel, MgControlType, StorageAttributeType } from \"@magic-xpa/utils\";\r\nimport { Platform } from \"@angular/cdk/platform\";\r\n\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 platform\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    public platform: Platform,\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        /**\r\n         * In the case of Safari or Chrome browser on IOS, when a button is clicked, the browser does not receive\r\n         * focus event hence the zoom action is not executed. So in order to receive focus event, enabling it exclusively\r\n         * in the case of Safari or Chrome browser on IOS and Safari browser on Mac.\r\n         */\r\n        if (fromButton && (this.platform.IOS || this.platform.SAFARI))\r\n          this.task.insertEvent(getGuiEventObj(\"focus\", this.id, +this.rowId));\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  public 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)._hostLView).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.obj.Type == MgControlType.CTRL_TYPE_TEXT)\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\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"]}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { Directive, ViewContainerRef } from "@angular/core";
|
2
|
+
import { isNullOrUndefined } from "@magic-xpa/mscorelib";
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class MagicViewContainerRef {
|
5
|
+
vcRef;
|
6
|
+
constructor(vcRef) {
|
7
|
+
this.vcRef = vcRef;
|
8
|
+
let comp = (this.vcRef._hostLView).find(v => v != null && !isNullOrUndefined(v.setViewContainerRef));
|
9
|
+
comp.setViewContainerRef(vcRef);
|
10
|
+
}
|
11
|
+
static ɵfac = function MagicViewContainerRef_Factory(t) { return new (t || MagicViewContainerRef)(i0.ɵɵdirectiveInject(i0.ViewContainerRef)); };
|
12
|
+
static ɵdir = i0.ɵɵdefineDirective({ type: MagicViewContainerRef, selectors: [["", "magicViewContainerRef", ""]] });
|
13
|
+
}
|
14
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicViewContainerRef, [{
|
15
|
+
type: Directive,
|
16
|
+
args: [{
|
17
|
+
selector: '[magicViewContainerRef]',
|
18
|
+
}]
|
19
|
+
}], () => [{ type: i0.ViewContainerRef }], null); })();
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvbWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQVF6RCxNQUFNLE9BQU8scUJBQXFCO0lBQ1o7SUFBcEIsWUFBb0IsS0FBdUI7UUFBdkIsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFFMUMsSUFBSSxJQUFJLEdBQUcsQ0FBTyxJQUFJLENBQUMsS0FBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQTJCLElBQUksSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUUsQ0FBNEIsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7UUFDbEssSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7K0VBTFUscUJBQXFCOytDQUFyQixxQkFBcUI7O2lGQUFyQixxQkFBcUI7Y0FIakMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSx5QkFBeUI7YUFDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgSU1hZ2ljVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzL3N1Yi1mb3JtLWRlZmluaXRpb24uaXRlcmZhY2VcIjtcbmltcG9ydCB7IGlzTnVsbE9yVW5kZWZpbmVkIH0gZnJvbSBcIkBtYWdpYy14cGEvbXNjb3JlbGliXCI7XG5cbi8qKlxuICogRGlyZWN0aXZlIGZvciBzZXR0aW5nICBWaWV3Q29udGFpbmVyUmVmIG9uIGVsZW1lbnRcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW21hZ2ljVmlld0NvbnRhaW5lclJlZl0nLFxufSlcbmV4cG9ydCBjbGFzcyBNYWdpY1ZpZXdDb250YWluZXJSZWYge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHZjUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7XG4gICAgLy8gRm9yIGFuZ3VsYXIgMTAgLSAgZmluZCB0aGUgY29tcG9uZW50IGZyb20gdGhlIHZpZXdzXG4gICBsZXQgY29tcCA9ICgoPGFueT50aGlzLnZjUmVmKS5faG9zdExWaWV3KS5maW5kKHYgPT4gdiBhcyBJTWFnaWNWaWV3Q29udGFpbmVyUmVmICE9IG51bGwgJiYgIWlzTnVsbE9yVW5kZWZpbmVkKCh2IGFzIElNYWdpY1ZpZXdDb250YWluZXJSZWYpLnNldFZpZXdDb250YWluZXJSZWYpKTtcbiAgIGNvbXAuc2V0Vmlld0NvbnRhaW5lclJlZih2Y1JlZik7XG4gIH1cbn1cblxuIl19
|