@magic-xpa/angular 4.1100.0-dev4110.99 → 4.1101.0-dev4111.271

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.
Files changed (170) hide show
  1. package/README.md +5 -5
  2. package/{esm2020 → esm2022}/index.mjs +59 -59
  3. package/{esm2020 → esm2022}/magic-xpa-angular.mjs +1 -1
  4. package/esm2022/src/controls.metadata.model.mjs +183 -0
  5. package/{esm2020 → esm2022}/src/interfaces/sub-form-definition.iterface.mjs +1 -1
  6. package/{esm2020 → esm2022}/src/magic.core.module.mjs +159 -160
  7. package/{esm2020 → esm2022}/src/services/ISubformMagicService.mjs +1 -1
  8. package/esm2022/src/services/OverlayWindowService.mjs +245 -0
  9. package/esm2022/src/services/StylesMapManager.mjs +28 -0
  10. package/esm2022/src/services/accessor.magic.service.mjs +358 -0
  11. package/esm2022/src/services/commands-collector.magic.service.mjs +47 -0
  12. package/esm2022/src/services/component-list.magic.service.mjs +45 -0
  13. package/{esm2020 → esm2022}/src/services/confirmation.components.magic.provider.mjs +21 -21
  14. package/esm2022/src/services/engine.magic.service.mjs +80 -0
  15. package/{esm2020 → esm2022}/src/services/exit.magic.service.mjs +13 -13
  16. package/esm2022/src/services/magic-color.service.mjs +101 -0
  17. package/{esm2020 → esm2022}/src/services/magic.lazy.loader.service.mjs +16 -16
  18. package/{esm2020 → esm2022}/src/services/magic.providers.mjs +24 -24
  19. package/esm2022/src/services/magic.services.mjs +36 -0
  20. package/esm2022/src/services/mg-date-adapter.mjs +108 -0
  21. package/{esm2020 → esm2022}/src/services/overlay.conainer.magic.provider.mjs +14 -14
  22. package/esm2022/src/services/router-commands.magic.service.mjs +31 -0
  23. package/esm2022/src/services/subform.magic.service.mjs +195 -0
  24. package/esm2022/src/services/table.magic.service.mjs +81 -0
  25. package/esm2022/src/services/task.magics.service.mjs +648 -0
  26. package/esm2022/src/services/title.magic.service.mjs +19 -0
  27. package/esm2022/src/ui/GuiInteractiveExecutor.mjs +114 -0
  28. package/esm2022/src/ui/components/base-magic-alert.component.mjs +24 -0
  29. package/esm2022/src/ui/components/base-magic-confirm.component.mjs +24 -0
  30. package/esm2022/src/ui/components/magic-alert.component.mjs +36 -0
  31. package/esm2022/src/ui/components/magic-confirmation-box.component.mjs +42 -0
  32. package/esm2022/src/ui/directives/NonMagicControlDirective.mjs +58 -0
  33. package/esm2022/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs +29 -0
  34. package/esm2022/src/ui/directives/magic/checkbox.magic.directive.mjs +100 -0
  35. package/esm2022/src/ui/directives/magic/combobox.magic.directive.mjs +37 -0
  36. package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs +27 -0
  37. package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +85 -0
  38. package/esm2022/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs +32 -0
  39. package/esm2022/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs +28 -0
  40. package/{esm2020 → esm2022}/src/ui/directives/magic/nocontrol.magic.directive.mjs +193 -193
  41. package/esm2022/src/ui/directives/magic/row.magic.directive.mjs +62 -0
  42. package/esm2022/src/ui/directives/magic-focus.directive.mjs +20 -0
  43. package/esm2022/src/ui/directives/magic.directive.mjs +232 -0
  44. package/esm2022/src/ui/directives/magicViewContainerRef.directive.mjs +20 -0
  45. package/esm2022/src/ui/directives/mgformat.magic.directive.mjs +579 -0
  46. package/esm2022/src/ui/directives/range-validator.magic.directive.mjs +60 -0
  47. package/{esm2020 → esm2022}/src/ui/magic-confirmationBox.mjs +41 -41
  48. package/{esm2020 → esm2022}/src/ui/magic-modal/base-magic-overlay-container.mjs +22 -22
  49. package/esm2022/src/ui/magic-modal/magic-modal-form.mjs +6 -0
  50. package/{esm2020 → esm2022}/src/ui/magic-modal/magic-modal-interface.mjs +1 -1
  51. package/esm2022/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +125 -0
  52. package/esm2022/src/ui/magic-modal/magic-overlay-container.mjs +162 -0
  53. package/esm2022/src/ui/magic-root.component.mjs +236 -0
  54. package/esm2022/src/ui/mgerror.magic.component.mjs +125 -0
  55. package/esm2022/src/ui/pipes/date.magic.pipe.mjs +106 -0
  56. package/esm2022/src/ui/pipes/time.magic.pipe.mjs +52 -0
  57. package/esm2022/src/ui/pipes/time24.magic.pipe.mjs +35 -0
  58. package/esm2022/src/ui/router-container.magic.component.mjs +115 -0
  59. package/{esm2020 → esm2022}/src/ui/subform.magic.component.mjs +50 -46
  60. package/esm2022/src/ui/task-base.magic.component.mjs +91 -0
  61. package/{esm2020 → esm2022}/src/ui/utils.mjs +53 -53
  62. package/{fesm2020 → fesm2022}/magic-xpa-angular.mjs +4933 -4495
  63. package/fesm2022/magic-xpa-angular.mjs.map +1 -0
  64. package/index.d.ts +58 -58
  65. package/package.json +10 -16
  66. package/src/controls.metadata.model.d.ts +62 -62
  67. package/src/interfaces/sub-form-definition.iterface.d.ts +12 -12
  68. package/src/magic.core.module.d.ts +41 -41
  69. package/src/services/ISubformMagicService.d.ts +4 -4
  70. package/src/services/OverlayWindowService.d.ts +30 -31
  71. package/src/services/StylesMapManager.d.ts +5 -5
  72. package/src/services/accessor.magic.service.d.ts +69 -69
  73. package/src/services/commands-collector.magic.service.d.ts +15 -15
  74. package/src/services/component-list.magic.service.d.ts +23 -23
  75. package/src/services/confirmation.components.magic.provider.d.ts +8 -8
  76. package/src/services/engine.magic.service.d.ts +27 -27
  77. package/src/services/exit.magic.service.d.ts +6 -6
  78. package/src/services/magic-color.service.d.ts +19 -19
  79. package/src/services/magic.lazy.loader.service.d.ts +6 -6
  80. package/src/services/magic.providers.d.ts +107 -107
  81. package/src/services/magic.services.d.ts +16 -16
  82. package/src/services/mg-date-adapter.d.ts +38 -40
  83. package/src/services/overlay.conainer.magic.provider.d.ts +7 -7
  84. package/src/services/router-commands.magic.service.d.ts +17 -17
  85. package/src/services/subform.magic.service.d.ts +43 -43
  86. package/src/services/table.magic.service.d.ts +30 -30
  87. package/src/services/task.magics.service.d.ts +100 -100
  88. package/src/services/title.magic.service.d.ts +9 -9
  89. package/src/ui/GuiInteractiveExecutor.d.ts +22 -22
  90. package/src/ui/components/base-magic-alert.component.d.ts +10 -10
  91. package/src/ui/components/base-magic-confirm.component.d.ts +10 -10
  92. package/src/ui/components/magic-alert.component.d.ts +6 -6
  93. package/src/ui/components/magic-confirmation-box.component.d.ts +6 -6
  94. package/src/ui/directives/NonMagicControlDirective.d.ts +26 -26
  95. package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +9 -9
  96. package/src/ui/directives/magic/checkbox.magic.directive.d.ts +22 -9
  97. package/src/ui/directives/magic/combobox.magic.directive.d.ts +10 -10
  98. package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +7 -7
  99. package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +23 -17
  100. package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +7 -7
  101. package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +9 -9
  102. package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +18 -18
  103. package/src/ui/directives/magic/row.magic.directive.d.ts +17 -17
  104. package/src/ui/directives/magic-focus.directive.d.ts +9 -9
  105. package/src/ui/directives/magic.directive.d.ts +45 -44
  106. package/src/ui/directives/magicViewContainerRef.directive.d.ts +8 -8
  107. package/src/ui/directives/mgformat.magic.directive.d.ts +38 -31
  108. package/src/ui/directives/range-validator.magic.directive.d.ts +17 -17
  109. package/src/ui/magic-confirmationBox.d.ts +6 -6
  110. package/src/ui/magic-modal/base-magic-overlay-container.d.ts +5 -5
  111. package/src/ui/magic-modal/magic-modal-form.d.ts +5 -5
  112. package/src/ui/magic-modal/magic-modal-interface.d.ts +10 -10
  113. package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +30 -31
  114. package/src/ui/magic-modal/magic-overlay-container.d.ts +24 -25
  115. package/src/ui/magic-root.component.d.ts +43 -40
  116. package/src/ui/mgerror.magic.component.d.ts +20 -20
  117. package/src/ui/pipes/date.magic.pipe.d.ts +17 -17
  118. package/src/ui/pipes/time.magic.pipe.d.ts +11 -11
  119. package/src/ui/pipes/time24.magic.pipe.d.ts +10 -10
  120. package/src/ui/router-container.magic.component.d.ts +29 -30
  121. package/src/ui/subform.magic.component.d.ts +16 -16
  122. package/src/ui/task-base.magic.component.d.ts +34 -34
  123. package/src/ui/utils.d.ts +9 -9
  124. package/esm2020/src/controls.metadata.model.mjs +0 -180
  125. package/esm2020/src/services/OverlayWindowService.mjs +0 -236
  126. package/esm2020/src/services/StylesMapManager.mjs +0 -28
  127. package/esm2020/src/services/accessor.magic.service.mjs +0 -356
  128. package/esm2020/src/services/commands-collector.magic.service.mjs +0 -46
  129. package/esm2020/src/services/component-list.magic.service.mjs +0 -46
  130. package/esm2020/src/services/engine.magic.service.mjs +0 -82
  131. package/esm2020/src/services/magic-color.service.mjs +0 -99
  132. package/esm2020/src/services/magic.services.mjs +0 -31
  133. package/esm2020/src/services/mg-date-adapter.mjs +0 -109
  134. package/esm2020/src/services/router-commands.magic.service.mjs +0 -28
  135. package/esm2020/src/services/subform.magic.service.mjs +0 -184
  136. package/esm2020/src/services/table.magic.service.mjs +0 -77
  137. package/esm2020/src/services/task.magics.service.mjs +0 -624
  138. package/esm2020/src/services/title.magic.service.mjs +0 -18
  139. package/esm2020/src/ui/GuiInteractiveExecutor.mjs +0 -105
  140. package/esm2020/src/ui/components/base-magic-alert.component.mjs +0 -23
  141. package/esm2020/src/ui/components/base-magic-confirm.component.mjs +0 -23
  142. package/esm2020/src/ui/components/magic-alert.component.mjs +0 -35
  143. package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +0 -41
  144. package/esm2020/src/ui/directives/NonMagicControlDirective.mjs +0 -49
  145. package/esm2020/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs +0 -28
  146. package/esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs +0 -28
  147. package/esm2020/src/ui/directives/magic/combobox.magic.directive.mjs +0 -36
  148. package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs +0 -27
  149. package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +0 -52
  150. package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs +0 -32
  151. package/esm2020/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs +0 -27
  152. package/esm2020/src/ui/directives/magic/row.magic.directive.mjs +0 -58
  153. package/esm2020/src/ui/directives/magic-focus.directive.mjs +0 -19
  154. package/esm2020/src/ui/directives/magic.directive.mjs +0 -215
  155. package/esm2020/src/ui/directives/magicViewContainerRef.directive.mjs +0 -19
  156. package/esm2020/src/ui/directives/mgformat.magic.directive.mjs +0 -408
  157. package/esm2020/src/ui/directives/range-validator.magic.directive.mjs +0 -58
  158. package/esm2020/src/ui/magic-modal/magic-modal-form.mjs +0 -8
  159. package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +0 -121
  160. package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +0 -159
  161. package/esm2020/src/ui/magic-root.component.mjs +0 -203
  162. package/esm2020/src/ui/mgerror.magic.component.mjs +0 -119
  163. package/esm2020/src/ui/pipes/date.magic.pipe.mjs +0 -105
  164. package/esm2020/src/ui/pipes/time.magic.pipe.mjs +0 -51
  165. package/esm2020/src/ui/pipes/time24.magic.pipe.mjs +0 -34
  166. package/esm2020/src/ui/router-container.magic.component.mjs +0 -108
  167. package/esm2020/src/ui/task-base.magic.component.mjs +0 -86
  168. package/fesm2015/magic-xpa-angular.mjs +0 -4865
  169. package/fesm2015/magic-xpa-angular.mjs.map +0 -1
  170. package/fesm2020/magic-xpa-angular.mjs.map +0 -1
@@ -1,193 +1,193 @@
1
- import { Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional } from '@angular/core';
2
- import { CommandType } from "@magic-xpa/gui";
3
- import { getGuiEventObj } from "@magic-xpa/engine";
4
- import { HtmlProperties } from "@magic-xpa/gui";
5
- import { MagicDirective } from "../magic.directive";
6
- import { TaskMagicService } from "../../../services/task.magics.service";
7
- import { StylesMapManager } from "../../../services/StylesMapManager";
8
- import { RowMagicDirective } from "./row.magic.directive";
9
- import { Platform } from "@angular/cdk/platform";
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "../../../services/task.magics.service";
12
- import * as i2 from "@angular/cdk/platform";
13
- import * as i3 from "./row.magic.directive";
14
- export class NoControlMagicDirective extends MagicDirective {
15
- set magic(val) { this.id = val; this.selector = 'magicnc'; }
16
- ;
17
- constructor(_task, element, renderer, vcRef, platform, magicRow) {
18
- super(_task, element, renderer, vcRef, platform, magicRow);
19
- }
20
- regEvents() {
21
- super.regEvents();
22
- if (this.htmlElement instanceof HTMLSelectElement) {
23
- this.htmlElement.addEventListener('change', (e) => {
24
- let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
25
- guiEvent.Value = (event.target).selectedIndex.toString();
26
- this.task.insertEvent(guiEvent);
27
- });
28
- }
29
- if (this.isRadio()) {
30
- this.htmlElement.addEventListener('change', (e) => {
31
- let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
32
- guiEvent.Value = (e.target).value;
33
- this.task.insertEvent(guiEvent);
34
- });
35
- }
36
- if (this.isTabControl()) {
37
- const tabControl = this.htmlElement.children[0];
38
- let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
39
- for (var i = 0; i < tabControl.children.length; i++) {
40
- tabControl.children[i].addEventListener('click', (e) => {
41
- guiEvent.Value = (e.currentTarget.getAttribute('layer') - 1).toString();
42
- this.task.insertEvent(guiEvent);
43
- });
44
- }
45
- }
46
- }
47
- isTabControl() {
48
- return this.htmlElement instanceof HTMLDivElement &&
49
- this.htmlElement.children[0].getAttribute('magicMark') === "magicTabControl";
50
- }
51
- isRadio() {
52
- return this.htmlElement instanceof HTMLDivElement &&
53
- this.htmlElement.children[0].getAttribute('magicMark') === "magicRadio";
54
- }
55
- handleCommand(command) {
56
- super.handleCommand(command);
57
- switch (command.CommandType) {
58
- case CommandType.SET_CLASS:
59
- const controlMetadata = this._task.Records.list[0].getControlMetadata(this.id);
60
- if (controlMetadata.removedClass != '') {
61
- this.htmlElement.classList.remove(controlMetadata.removedClass);
62
- controlMetadata.removedClass = '';
63
- }
64
- this.htmlElement.classList.add(command.obj1);
65
- break;
66
- case CommandType.SET_VALUE:
67
- if (this.htmlElement instanceof HTMLLabelElement)
68
- this.htmlElement.innerText = command.value;
69
- if (this.htmlElement instanceof HTMLSelectElement)
70
- this.htmlElement.value = command.value;
71
- if (this.htmlElement instanceof HTMLAnchorElement)
72
- this.htmlElement.text = command.value;
73
- if (this.htmlElement instanceof HTMLInputElement) {
74
- if (this.htmlElement.type === "checkbox") {
75
- this.htmlElement.checked = command.value;
76
- }
77
- else {
78
- this.htmlElement.value = command.value;
79
- }
80
- }
81
- if (this.htmlElement instanceof HTMLButtonElement) {
82
- this.htmlElement.innerHTML = command.value;
83
- }
84
- break;
85
- case CommandType.SET_PROPERTY:
86
- this.handleSetProperty(command);
87
- break;
88
- case CommandType.SET_STYLE:
89
- let value = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);
90
- let attribute = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);
91
- this.htmlElement.setAttribute("style", attribute + ":" + value);
92
- break;
93
- }
94
- }
95
- handleSetProperty(command) {
96
- super.handleSetProperty(command);
97
- switch (command.Operation) {
98
- case HtmlProperties.Text:
99
- if (this.htmlElement instanceof HTMLLabelElement)
100
- this.htmlElement.innerText = command.obj1;
101
- break;
102
- case HtmlProperties.Image:
103
- if (this.htmlElement instanceof HTMLImageElement)
104
- this.htmlElement.src = command.obj1;
105
- else
106
- this.htmlElement.setAttribute("src", command.obj1);
107
- break;
108
- case HtmlProperties.ItemsList:
109
- if (this.htmlElement instanceof HTMLSelectElement) {
110
- var len = this.htmlElement.length;
111
- for (var i = len - 1; i >= 0; i--) {
112
- this.htmlElement.remove(i);
113
- }
114
- for (let s of command.obj1) {
115
- let elem = document.createElement("option");
116
- elem.text = s.displayValue;
117
- elem.value = s.index;
118
- this.htmlElement.add(elem);
119
- }
120
- }
121
- else if (this.isTabControl() && this.htmlElement.children.length > 0) {
122
- const tabControl = this.htmlElement.children[0];
123
- for (var i = 0; i < tabControl.children.length; i++) {
124
- if (tabControl.children[i] instanceof HTMLButtonElement) {
125
- tabControl.children[i].innerText = command.obj1[i].displayValue;
126
- }
127
- }
128
- }
129
- break;
130
- case HtmlProperties.Visible:
131
- this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));
132
- break;
133
- case HtmlProperties.Enabled:
134
- if (command.obj1 === false)
135
- this.htmlElement.setAttribute("disabled", "true");
136
- else
137
- this.htmlElement.removeAttribute("disabled");
138
- break;
139
- case HtmlProperties.TabIndex:
140
- this.htmlElement.setAttribute(command.Operation, command.obj1);
141
- break;
142
- case HtmlProperties.SelectedValue:
143
- if (this.htmlElement instanceof HTMLSelectElement)
144
- this.htmlElement.value = command.obj1;
145
- else if (this.isTabControl() && this.htmlElement.children.length > 0) {
146
- const tabControl = this.htmlElement.children[0];
147
- for (var i = 0; i < tabControl.children.length; i++) {
148
- let child = tabControl.children[i];
149
- const layer = child.getAttribute('layer') - 1;
150
- if (child instanceof HTMLButtonElement) {
151
- if (layer == command.obj1) {
152
- child.classList.add('tab_button_active');
153
- }
154
- else {
155
- child.classList.remove('tab_button_active');
156
- }
157
- }
158
- else {
159
- let style = (layer == command.obj1) ? 'display: inline' : 'display: none';
160
- child.setAttribute('style', style);
161
- }
162
- }
163
- }
164
- break;
165
- case HtmlProperties.PlaceHolder:
166
- this.htmlElement.setAttribute("placeholder", command.obj1);
167
- break;
168
- case HtmlProperties.Tooltip:
169
- this.htmlElement.setAttribute("title", command.obj1);
170
- break;
171
- case HtmlProperties.Password:
172
- if (command.obj1 === false)
173
- this.htmlElement.setAttribute("type", "text");
174
- else
175
- this.htmlElement.setAttribute("type", "password");
176
- break;
177
- }
178
- }
179
- }
180
- NoControlMagicDirective.ɵfac = function NoControlMagicDirective_Factory(t) { return new (t || NoControlMagicDirective)(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)); };
181
- NoControlMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: NoControlMagicDirective, selectors: [["", "magicnc", ""]], inputs: { magic: ["magicnc", "magic"] }, features: [i0.ɵɵInheritDefinitionFeature] });
182
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NoControlMagicDirective, [{
183
- type: Directive,
184
- args: [{
185
- selector: '[magicnc]'
186
- }]
187
- }], function () { return [{ type: i1.TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.Platform }, { type: i3.RowMagicDirective, decorators: [{
188
- type: Optional
189
- }] }]; }, { magic: [{
190
- type: Input,
191
- args: ['magicnc']
192
- }] }); })();
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nocontrol.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/nocontrol.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional} from '@angular/core';\r\nimport {CommandType, GuiCommand} from \"@magic-xpa/gui\";\r\nimport {IGuiEvent, getGuiEventObj} from \"@magic-xpa/engine\";\r\nimport {ControlMetadata} from \"../../../controls.metadata.model\";\r\nimport {HtmlProperties} from  \"@magic-xpa/gui\";\r\nimport {MagicDirective} from \"../magic.directive\";\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {StylesMapManager} from \"../../../services/StylesMapManager\";\r\nimport {RowMagicDirective} from \"./row.magic.directive\";\r\nimport {Platform} from \"@angular/cdk/platform\";\r\n\r\n/**\r\n * @ignore\r\n */\r\n@Directive({\r\n  selector: '[magicnc]'\r\n})\r\n\r\nexport class NoControlMagicDirective extends MagicDirective {\r\n\r\n  @Input('magicnc') set magic(val) {this.id = val; this.selector = 'magicnc';};\r\n\r\n  constructor(\r\n    _task   : TaskMagicService,\r\n    element : ElementRef,\r\n    renderer: Renderer2,\r\n    vcRef   : ViewContainerRef,\r\n    platform: Platform,\r\n    @Optional() magicRow: RowMagicDirective) {\r\n    super(_task, element, renderer,  vcRef, platform, magicRow);\r\n  }\r\n\r\n  regEvents() {\r\n  super.regEvents()\r\n\r\n    if (this.htmlElement instanceof HTMLSelectElement) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString()\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if (this.isRadio()) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(e.target)).value;\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if(this.isTabControl()) {\r\n        const tabControl = this.htmlElement.children[0];\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        for (var i = 0; i < tabControl.children.length; i++) {\r\n          tabControl.children[i].addEventListener('click', (e) => {\r\n            guiEvent.Value = ((<number><any>(<Element>e.currentTarget).getAttribute('layer'))-1).toString();\r\n            this.task.insertEvent(guiEvent);\r\n          });\r\n        }\r\n    }\r\n  }\r\n\r\n  // is the div a tab control\r\n  isTabControl() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark')=== \"magicTabControl\";\r\n  }\r\n\r\n  // is the div a radio buttons wrapper\r\n  isRadio() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark') === \"magicRadio\";\r\n  }\r\n\r\n  handleCommand(command: GuiCommand) {\r\n    super.handleCommand(command);\r\n\r\n    switch (command.CommandType) {\r\n      case CommandType.SET_CLASS:\r\n        //remove the class which was replaced by this new one, as registered in the ControlMetadata\r\n        const controlMetadata:ControlMetadata = this._task.Records.list[0].getControlMetadata(this.id);\r\n        if(controlMetadata.removedClass != '') {\r\n          this.htmlElement.classList.remove(controlMetadata.removedClass);\r\n          controlMetadata.removedClass = '';\r\n        }\r\n        this.htmlElement.classList.add(command.obj1);\r\n        break;\r\n\r\n      case  CommandType.SET_VALUE:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLAnchorElement) //hyper-text button\r\n          (<HTMLAnchorElement>this.htmlElement).text = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLInputElement)\r\n        {\r\n          if((<HTMLInputElement>this.htmlElement).type === \"checkbox\") {\r\n            (<HTMLInputElement>this.htmlElement).checked = command.value;\r\n          }\r\n          else {\r\n            (<HTMLInputElement>this.htmlElement).value = command.value;\r\n          }\r\n        }\r\n\r\n        if (this.htmlElement instanceof HTMLButtonElement)\r\n        {\r\n          (<HTMLButtonElement>this.htmlElement).innerHTML = command.value;\r\n        }\r\n\r\n        break;\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_STYLE:\r\n        let value: string = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);\r\n        let attribute: string = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);\r\n        this.htmlElement.setAttribute(\"style\", attribute + \":\" + value);\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  // handle set-property commands\r\n  handleSetProperty(command: GuiCommand) {\r\n    super.handleSetProperty(command);\r\n    switch (command.Operation) {\r\n      case HtmlProperties.Text:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.obj1;\r\n\r\n        break;\r\n\r\n      case HtmlProperties.Image:\r\n        if (this.htmlElement instanceof HTMLImageElement)\r\n          (<HTMLImageElement>this.htmlElement).src = command.obj1;\r\n        else\r\n          this.htmlElement.setAttribute(\"src\", command.obj1);\r\n\r\n        break;\r\n\r\n      case HtmlProperties.ItemsList:\r\n        if (this.htmlElement instanceof HTMLSelectElement) {\r\n\r\n          // clear the list\r\n          var len = this.htmlElement.length;\r\n          for (var i = len - 1; i >= 0; i--) {\r\n            this.htmlElement.remove(i);\r\n          }\r\n\r\n          for (let s of command.obj1) {\r\n            let elem = document.createElement(\"option\");\r\n            elem.text = s.displayValue;\r\n            elem.value = s.index;\r\n            (<HTMLSelectElement>this.htmlElement).add(elem);\r\n          }\r\n        }\r\n        else if(this.isTabControl() && this.htmlElement.children.length > 0) {\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            if(tabControl.children[i] instanceof HTMLButtonElement) {\r\n              (<HTMLElement>tabControl.children[i]).innerText = command.obj1[i].displayValue;\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.Visible:\r\n        this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));\r\n        break;\r\n\r\n      case HtmlProperties.Enabled:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"disabled\", \"true\");\r\n        else\r\n          this.htmlElement.removeAttribute(\"disabled\");\r\n        break;\r\n\r\n      case HtmlProperties.TabIndex:\r\n        this.htmlElement.setAttribute(command.Operation, command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.SelectedValue:\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.obj1;\r\n        else if(this.isTabControl()  && this.htmlElement.children.length > 0){\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            let child = tabControl.children[i];\r\n            const layer = (<number><any>child.getAttribute('layer'))-1;\r\n\r\n            if(child instanceof HTMLButtonElement) {\r\n              // set button style\r\n              if ( layer == command.obj1) { // compare int to string\r\n                child.classList.add('tab_button_active');\r\n              }\r\n              else {\r\n                child.classList.remove('tab_button_active');\r\n              }\r\n            } else {\r\n              // not a buton - hide unselected tabpages\r\n              let style = (layer == command.obj1) ? 'display: inline' : 'display: none';\r\n              child.setAttribute('style',  style);\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.PlaceHolder:\r\n        this.htmlElement.setAttribute(\"placeholder\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Tooltip:\r\n        this.htmlElement.setAttribute(\"title\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Password:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"type\", \"text\");\r\n        else\r\n          this.htmlElement.setAttribute(\"type\", \"password\");\r\n        break;\r\n    }\r\n  }\r\n}\r\n"]}
1
+ import { Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional } from '@angular/core';
2
+ import { CommandType } from "@magic-xpa/gui";
3
+ import { getGuiEventObj } from "@magic-xpa/engine";
4
+ import { HtmlProperties } from "@magic-xpa/gui";
5
+ import { MagicDirective } from "../magic.directive";
6
+ import { TaskMagicService } from "../../../services/task.magics.service";
7
+ import { StylesMapManager } from "../../../services/StylesMapManager";
8
+ import { RowMagicDirective } from "./row.magic.directive";
9
+ import { Platform } from "@angular/cdk/platform";
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../../services/task.magics.service";
12
+ import * as i2 from "@angular/cdk/platform";
13
+ import * as i3 from "./row.magic.directive";
14
+ export class NoControlMagicDirective extends MagicDirective {
15
+ set magic(val) { this.id = val; this.selector = 'magicnc'; }
16
+ ;
17
+ constructor(_task, element, renderer, vcRef, platform, magicRow) {
18
+ super(_task, element, renderer, vcRef, platform, magicRow);
19
+ }
20
+ regEvents() {
21
+ super.regEvents();
22
+ if (this.htmlElement instanceof HTMLSelectElement) {
23
+ this.htmlElement.addEventListener('change', (e) => {
24
+ let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
25
+ guiEvent.Value = (event.target).selectedIndex.toString();
26
+ this.task.insertEvent(guiEvent);
27
+ });
28
+ }
29
+ if (this.isRadio()) {
30
+ this.htmlElement.addEventListener('change', (e) => {
31
+ let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
32
+ guiEvent.Value = (e.target).value;
33
+ this.task.insertEvent(guiEvent);
34
+ });
35
+ }
36
+ if (this.isTabControl()) {
37
+ const tabControl = this.htmlElement.children[0];
38
+ let guiEvent = getGuiEventObj("selectionchanged", this.id, 0);
39
+ for (var i = 0; i < tabControl.children.length; i++) {
40
+ tabControl.children[i].addEventListener('click', (e) => {
41
+ guiEvent.Value = (e.currentTarget.getAttribute('layer') - 1).toString();
42
+ this.task.insertEvent(guiEvent);
43
+ });
44
+ }
45
+ }
46
+ }
47
+ isTabControl() {
48
+ return this.htmlElement instanceof HTMLDivElement &&
49
+ this.htmlElement.children[0].getAttribute('magicMark') === "magicTabControl";
50
+ }
51
+ isRadio() {
52
+ return this.htmlElement instanceof HTMLDivElement &&
53
+ this.htmlElement.children[0].getAttribute('magicMark') === "magicRadio";
54
+ }
55
+ handleCommand(command) {
56
+ super.handleCommand(command);
57
+ switch (command.CommandType) {
58
+ case CommandType.SET_CLASS:
59
+ const controlMetadata = this._task.Records.list[0].getControlMetadata(this.id);
60
+ if (controlMetadata.removedClass != '') {
61
+ this.htmlElement.classList.remove(controlMetadata.removedClass);
62
+ controlMetadata.removedClass = '';
63
+ }
64
+ this.htmlElement.classList.add(command.obj1);
65
+ break;
66
+ case CommandType.SET_VALUE:
67
+ if (this.htmlElement instanceof HTMLLabelElement)
68
+ this.htmlElement.innerText = command.value;
69
+ if (this.htmlElement instanceof HTMLSelectElement)
70
+ this.htmlElement.value = command.value;
71
+ if (this.htmlElement instanceof HTMLAnchorElement)
72
+ this.htmlElement.text = command.value;
73
+ if (this.htmlElement instanceof HTMLInputElement) {
74
+ if (this.htmlElement.type === "checkbox") {
75
+ this.htmlElement.checked = command.value;
76
+ }
77
+ else {
78
+ this.htmlElement.value = command.value;
79
+ }
80
+ }
81
+ if (this.htmlElement instanceof HTMLButtonElement) {
82
+ this.htmlElement.innerHTML = command.value;
83
+ }
84
+ break;
85
+ case CommandType.SET_PROPERTY:
86
+ this.handleSetProperty(command);
87
+ break;
88
+ case CommandType.SET_STYLE:
89
+ let value = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);
90
+ let attribute = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);
91
+ this.htmlElement.setAttribute("style", attribute + ":" + value);
92
+ break;
93
+ }
94
+ }
95
+ handleSetProperty(command) {
96
+ super.handleSetProperty(command);
97
+ switch (command.Operation) {
98
+ case HtmlProperties.Text:
99
+ if (this.htmlElement instanceof HTMLLabelElement)
100
+ this.htmlElement.innerText = command.obj1;
101
+ break;
102
+ case HtmlProperties.Image:
103
+ if (this.htmlElement instanceof HTMLImageElement)
104
+ this.htmlElement.src = command.obj1;
105
+ else
106
+ this.htmlElement.setAttribute("src", command.obj1);
107
+ break;
108
+ case HtmlProperties.ItemsList:
109
+ if (this.htmlElement instanceof HTMLSelectElement) {
110
+ var len = this.htmlElement.length;
111
+ for (var i = len - 1; i >= 0; i--) {
112
+ this.htmlElement.remove(i);
113
+ }
114
+ for (let s of command.obj1) {
115
+ let elem = document.createElement("option");
116
+ elem.text = s.displayValue;
117
+ elem.value = s.index;
118
+ this.htmlElement.add(elem);
119
+ }
120
+ }
121
+ else if (this.isTabControl() && this.htmlElement.children.length > 0) {
122
+ const tabControl = this.htmlElement.children[0];
123
+ for (var i = 0; i < tabControl.children.length; i++) {
124
+ if (tabControl.children[i] instanceof HTMLButtonElement) {
125
+ tabControl.children[i].innerText = command.obj1[i].displayValue;
126
+ }
127
+ }
128
+ }
129
+ break;
130
+ case HtmlProperties.Visible:
131
+ this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));
132
+ break;
133
+ case HtmlProperties.Enabled:
134
+ if (command.obj1 === false)
135
+ this.htmlElement.setAttribute("disabled", "true");
136
+ else
137
+ this.htmlElement.removeAttribute("disabled");
138
+ break;
139
+ case HtmlProperties.TabIndex:
140
+ this.htmlElement.setAttribute(command.Operation, command.obj1);
141
+ break;
142
+ case HtmlProperties.SelectedValue:
143
+ if (this.htmlElement instanceof HTMLSelectElement)
144
+ this.htmlElement.value = command.obj1;
145
+ else if (this.isTabControl() && this.htmlElement.children.length > 0) {
146
+ const tabControl = this.htmlElement.children[0];
147
+ for (var i = 0; i < tabControl.children.length; i++) {
148
+ let child = tabControl.children[i];
149
+ const layer = child.getAttribute('layer') - 1;
150
+ if (child instanceof HTMLButtonElement) {
151
+ if (layer == command.obj1) {
152
+ child.classList.add('tab_button_active');
153
+ }
154
+ else {
155
+ child.classList.remove('tab_button_active');
156
+ }
157
+ }
158
+ else {
159
+ let style = (layer == command.obj1) ? 'display: inline' : 'display: none';
160
+ child.setAttribute('style', style);
161
+ }
162
+ }
163
+ }
164
+ break;
165
+ case HtmlProperties.PlaceHolder:
166
+ this.htmlElement.setAttribute("placeholder", command.obj1);
167
+ break;
168
+ case HtmlProperties.Tooltip:
169
+ this.htmlElement.setAttribute("title", command.obj1);
170
+ break;
171
+ case HtmlProperties.Password:
172
+ if (command.obj1 === false)
173
+ this.htmlElement.setAttribute("type", "text");
174
+ else
175
+ this.htmlElement.setAttribute("type", "password");
176
+ break;
177
+ }
178
+ }
179
+ static ɵfac = function NoControlMagicDirective_Factory(t) { return new (t || NoControlMagicDirective)(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)); };
180
+ static ɵdir = i0.ɵɵdefineDirective({ type: NoControlMagicDirective, selectors: [["", "magicnc", ""]], inputs: { magic: [i0.ɵɵInputFlags.None, "magicnc", "magic"] }, features: [i0.ɵɵInheritDefinitionFeature] });
181
+ }
182
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NoControlMagicDirective, [{
183
+ type: Directive,
184
+ args: [{
185
+ selector: '[magicnc]'
186
+ }]
187
+ }], () => [{ type: i1.TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.Platform }, { type: i3.RowMagicDirective, decorators: [{
188
+ type: Optional
189
+ }] }], { magic: [{
190
+ type: Input,
191
+ args: ['magicnc']
192
+ }] }); })();
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nocontrol.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/nocontrol.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, Renderer2, ViewContainerRef, Optional} from '@angular/core';\r\nimport {CommandType, GuiCommand} from \"@magic-xpa/gui\";\r\nimport {IGuiEvent, getGuiEventObj} from \"@magic-xpa/engine\";\r\nimport {ControlMetadata} from \"../../../controls.metadata.model\";\r\nimport {HtmlProperties} from  \"@magic-xpa/gui\";\r\nimport {MagicDirective} from \"../magic.directive\";\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {StylesMapManager} from \"../../../services/StylesMapManager\";\r\nimport {RowMagicDirective} from \"./row.magic.directive\";\r\nimport {Platform} from \"@angular/cdk/platform\";\r\n\r\n/**\r\n * @ignore\r\n */\r\n@Directive({\r\n  selector: '[magicnc]'\r\n})\r\n\r\nexport class NoControlMagicDirective extends MagicDirective {\r\n\r\n  @Input('magicnc') set magic(val) {this.id = val; this.selector = 'magicnc';};\r\n\r\n  constructor(\r\n    _task   : TaskMagicService,\r\n    element : ElementRef,\r\n    renderer: Renderer2,\r\n    vcRef   : ViewContainerRef,\r\n    platform: Platform,\r\n    @Optional() magicRow: RowMagicDirective) {\r\n    super(_task, element, renderer,  vcRef, platform, magicRow);\r\n  }\r\n\r\n  regEvents() {\r\n  super.regEvents()\r\n\r\n    if (this.htmlElement instanceof HTMLSelectElement) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString()\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if (this.isRadio()) {\r\n      this.htmlElement.addEventListener('change', (e) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        guiEvent.Value = (<any>(e.target)).value;\r\n        this.task.insertEvent(guiEvent);\r\n      });\r\n    }\r\n\r\n    if(this.isTabControl()) {\r\n        const tabControl = this.htmlElement.children[0];\r\n        let guiEvent: IGuiEvent = getGuiEventObj(\"selectionchanged\", this.id, 0);\r\n        for (var i = 0; i < tabControl.children.length; i++) {\r\n          tabControl.children[i].addEventListener('click', (e) => {\r\n            guiEvent.Value = ((<number><any>(<Element>e.currentTarget).getAttribute('layer'))-1).toString();\r\n            this.task.insertEvent(guiEvent);\r\n          });\r\n        }\r\n    }\r\n  }\r\n\r\n  // is the div a tab control\r\n  isTabControl() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark')=== \"magicTabControl\";\r\n  }\r\n\r\n  // is the div a radio buttons wrapper\r\n  isRadio() {\r\n    return this.htmlElement instanceof HTMLDivElement &&\r\n      this.htmlElement.children[0].getAttribute('magicMark') === \"magicRadio\";\r\n  }\r\n\r\n  handleCommand(command: GuiCommand) {\r\n    super.handleCommand(command);\r\n\r\n    switch (command.CommandType) {\r\n      case CommandType.SET_CLASS:\r\n        //remove the class which was replaced by this new one, as registered in the ControlMetadata\r\n        const controlMetadata:ControlMetadata = this._task.Records.list[0].getControlMetadata(this.id);\r\n        if(controlMetadata.removedClass != '') {\r\n          this.htmlElement.classList.remove(controlMetadata.removedClass);\r\n          controlMetadata.removedClass = '';\r\n        }\r\n        this.htmlElement.classList.add(command.obj1);\r\n        break;\r\n\r\n      case  CommandType.SET_VALUE:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLAnchorElement) //hyper-text button\r\n          (<HTMLAnchorElement>this.htmlElement).text = command.value;\r\n\r\n        if (this.htmlElement instanceof HTMLInputElement)\r\n        {\r\n          if((<HTMLInputElement>this.htmlElement).type === \"checkbox\") {\r\n            (<HTMLInputElement>this.htmlElement).checked = command.value;\r\n          }\r\n          else {\r\n            (<HTMLInputElement>this.htmlElement).value = command.value;\r\n          }\r\n        }\r\n\r\n        if (this.htmlElement instanceof HTMLButtonElement)\r\n        {\r\n          (<HTMLButtonElement>this.htmlElement).innerHTML = command.value;\r\n        }\r\n\r\n        break;\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_STYLE:\r\n        let value: string = StylesMapManager.magicValueGetStyle(command.Operation, command.obj1);\r\n        let attribute: string = StylesMapManager.MagicPropertyToHtmlAttributeMap.get(command.Operation);\r\n        this.htmlElement.setAttribute(\"style\", attribute + \":\" + value);\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  // handle set-property commands\r\n  handleSetProperty(command: GuiCommand) {\r\n    super.handleSetProperty(command);\r\n    switch (command.Operation) {\r\n      case HtmlProperties.Text:\r\n        if (this.htmlElement instanceof HTMLLabelElement)\r\n          (<HTMLLabelElement>this.htmlElement).innerText = command.obj1;\r\n\r\n        break;\r\n\r\n      case HtmlProperties.Image:\r\n        if (this.htmlElement instanceof HTMLImageElement)\r\n          (<HTMLImageElement>this.htmlElement).src = command.obj1;\r\n        else\r\n          this.htmlElement.setAttribute(\"src\", command.obj1);\r\n\r\n        break;\r\n\r\n      case HtmlProperties.ItemsList:\r\n        if (this.htmlElement instanceof HTMLSelectElement) {\r\n\r\n          // clear the list\r\n          var len = this.htmlElement.length;\r\n          for (var i = len - 1; i >= 0; i--) {\r\n            this.htmlElement.remove(i);\r\n          }\r\n\r\n          for (let s of command.obj1) {\r\n            let elem = document.createElement(\"option\");\r\n            elem.text = s.displayValue;\r\n            elem.value = s.index;\r\n            (<HTMLSelectElement>this.htmlElement).add(elem);\r\n          }\r\n        }\r\n        else if(this.isTabControl() && this.htmlElement.children.length > 0) {\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            if(tabControl.children[i] instanceof HTMLButtonElement) {\r\n              (<HTMLElement>tabControl.children[i]).innerText = command.obj1[i].displayValue;\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.Visible:\r\n        this.htmlElement.setAttribute('style', 'visibility:' + (command.obj1 ? 'visible' : 'hidden'));\r\n        break;\r\n\r\n      case HtmlProperties.Enabled:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"disabled\", \"true\");\r\n        else\r\n          this.htmlElement.removeAttribute(\"disabled\");\r\n        break;\r\n\r\n      case HtmlProperties.TabIndex:\r\n        this.htmlElement.setAttribute(command.Operation, command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.SelectedValue:\r\n        if (this.htmlElement instanceof HTMLSelectElement)\r\n          (<HTMLSelectElement>this.htmlElement).value = command.obj1;\r\n        else if(this.isTabControl()  && this.htmlElement.children.length > 0){\r\n          const tabControl = this.htmlElement.children[0];\r\n\r\n          for (var i = 0; i < tabControl.children.length; i++) {\r\n            let child = tabControl.children[i];\r\n            const layer = (<number><any>child.getAttribute('layer'))-1;\r\n\r\n            if(child instanceof HTMLButtonElement) {\r\n              // set button style\r\n              if ( layer == command.obj1) { // compare int to string\r\n                child.classList.add('tab_button_active');\r\n              }\r\n              else {\r\n                child.classList.remove('tab_button_active');\r\n              }\r\n            } else {\r\n              // not a buton - hide unselected tabpages\r\n              let style = (layer == command.obj1) ? 'display: inline' : 'display: none';\r\n              child.setAttribute('style',  style);\r\n            }\r\n          }\r\n        }\r\n        break;\r\n\r\n      case HtmlProperties.PlaceHolder:\r\n        this.htmlElement.setAttribute(\"placeholder\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Tooltip:\r\n        this.htmlElement.setAttribute(\"title\", command.obj1);\r\n        break;\r\n\r\n      case HtmlProperties.Password:\r\n        if (command.obj1 === false)\r\n          this.htmlElement.setAttribute(\"type\", \"text\");\r\n        else\r\n          this.htmlElement.setAttribute(\"type\", \"password\");\r\n        break;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,62 @@
1
+ import { Directive, ElementRef, HostListener, Input } from "@angular/core";
2
+ import { TaskMagicService } from "../../../services/task.magics.service";
3
+ import { getGuiEventObj } from "@magic-xpa/engine";
4
+ import { filter } from "rxjs/operators";
5
+ import { MagicDirective } from "../../directives/magic.directive";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../services/task.magics.service";
8
+ export class RowMagicDirective {
9
+ _task;
10
+ element;
11
+ rowId;
12
+ htmlElement;
13
+ rowChangedSubscriber = null;
14
+ constructor(_task, element) {
15
+ this._task = _task;
16
+ this.element = element;
17
+ this.htmlElement = this.element.nativeElement;
18
+ }
19
+ ngOnInit() {
20
+ this.rowChangedSubscriber = this._task
21
+ .OnSelectedRowChanged.pipe(filter(rowId => rowId === this.rowId))
22
+ .subscribe(rowId => {
23
+ if (!this.isInView(this.htmlElement))
24
+ this.htmlElement.scrollIntoView();
25
+ });
26
+ }
27
+ isInView(element) {
28
+ const rect = element.getBoundingClientRect();
29
+ const parentRect = element.parentElement.getBoundingClientRect();
30
+ return (rect.top >= parentRect.top &&
31
+ rect.bottom <= parentRect.bottom);
32
+ }
33
+ ngOnDestroy() {
34
+ if (this.rowChangedSubscriber !== null) {
35
+ this.rowChangedSubscriber.unsubscribe();
36
+ }
37
+ }
38
+ onClick($event) {
39
+ if (this.rowId != '') {
40
+ this._task.insertEvent(getGuiEventObj('click', "magicRow", +this.rowId));
41
+ if (MagicDirective.noOfAutoCompleteBoxesOpened < 1)
42
+ event.cancelBubble = true;
43
+ }
44
+ }
45
+ static ɵfac = function RowMagicDirective_Factory(t) { return new (t || RowMagicDirective)(i0.ɵɵdirectiveInject(i1.TaskMagicService), i0.ɵɵdirectiveInject(i0.ElementRef)); };
46
+ static ɵdir = i0.ɵɵdefineDirective({ type: RowMagicDirective, selectors: [["", "magicRow", ""]], hostBindings: function RowMagicDirective_HostBindings(rf, ctx) { if (rf & 1) {
47
+ i0.ɵɵlistener("click", function RowMagicDirective_click_HostBindingHandler($event) { return ctx.onClick($event); });
48
+ } }, inputs: { rowId: [i0.ɵɵInputFlags.None, "magicRow", "rowId"] } });
49
+ }
50
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RowMagicDirective, [{
51
+ type: Directive,
52
+ args: [{
53
+ selector: '[magicRow]'
54
+ }]
55
+ }], () => [{ type: i1.TaskMagicService }, { type: i0.ElementRef }], { rowId: [{
56
+ type: Input,
57
+ args: ['magicRow']
58
+ }], onClick: [{
59
+ type: HostListener,
60
+ args: ['click', ['$event']]
61
+ }] }); })();
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93Lm1hZ2ljLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvbWFnaWMvcm93Lm1hZ2ljLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUM5RixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUN2RSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXhDLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQTs7O0FBVS9ELE1BQU0sT0FBTyxpQkFBaUI7SUFjaEI7SUFDQTtJQWRPLEtBQUssQ0FBUztJQUt2QixXQUFXLENBQWM7SUFLM0Isb0JBQW9CLEdBQWlCLElBQUksQ0FBQztJQUVsRCxZQUNZLEtBQXdCLEVBQ3hCLE9BQW1CO1FBRG5CLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3hCLFlBQU8sR0FBUCxPQUFPLENBQVk7UUFHN0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQztJQUNoRCxDQUFDO0lBS0QsUUFBUTtRQUNOLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUMsS0FBSzthQUNuQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNoRSxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDZixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO2dCQUNsQyxJQUFJLENBQUMsV0FBVyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3RDLENBQUMsQ0FDRixDQUFDO0lBQ04sQ0FBQztJQUVPLFFBQVEsQ0FBQyxPQUFPO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQzdDLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUNqRSxPQUFPLENBQ0wsSUFBSSxDQUFDLEdBQUcsSUFBSSxVQUFVLENBQUMsR0FBRztZQUMxQixJQUFJLENBQUMsTUFBTSxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQ2pDLENBQUM7SUFDSixDQUFDO0lBS0QsV0FBVztRQU9ULElBQUksSUFBSSxDQUFDLG9CQUFvQixLQUFLLElBQUksRUFBRTtZQUN0QyxJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDekM7SUFDSCxDQUFDO0lBR0QsT0FBTyxDQUFDLE1BQU07UUFDWixJQUFHLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxFQUFFO1lBQ25CLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDekUsSUFBSSxjQUFjLENBQUMsMkJBQTJCLEdBQUcsQ0FBQztnQkFDaEQsS0FBSyxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7U0FDN0I7SUFDSCxDQUFDOzJFQWpFVSxpQkFBaUI7K0NBQWpCLGlCQUFpQjtZQUFqQiw0RkFBQSxtQkFBZSxJQUFFOzs7aUZBQWpCLGlCQUFpQjtjQUw1QixTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLFlBQVk7YUFDdkI7MEVBSW1CLEtBQUs7a0JBQXZCLEtBQUs7bUJBQUMsVUFBVTtZQTBEakIsT0FBTztrQkFETixZQUFZO21CQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5pbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtUYXNrTWFnaWNTZXJ2aWNlfSBmcm9tIFwiLi4vLi4vLi4vc2VydmljZXMvdGFzay5tYWdpY3Muc2VydmljZVwiO1xyXG5pbXBvcnQge2dldEd1aUV2ZW50T2JqfSBmcm9tIFwiQG1hZ2ljLXhwYS9lbmdpbmVcIjtcclxuaW1wb3J0IHsgZmlsdGVyIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gXCJyeGpzL1J4XCI7XHJcbmltcG9ydCB7TWFnaWNEaXJlY3RpdmV9IGZyb20gXCIuLi8uLi9kaXJlY3RpdmVzL21hZ2ljLmRpcmVjdGl2ZVwiXHJcblxyXG4vKipcclxuICogQGlnbm9yZVxyXG4gKi9cclxuIEBEaXJlY3RpdmUoe1xyXG4gICBzZWxlY3RvcjogJ1ttYWdpY1Jvd10nXHJcbiB9KVxyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBSb3dNYWdpY0RpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95e1xyXG4gIEBJbnB1dCgnbWFnaWNSb3cnKSByb3dJZDogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgSFRNTCBlbGVtZW50IGNvbm5lY3RlZCB0byB0aGlzIGRpcmVjdGl2ZVxyXG4gICAqL1xyXG4gIHByb3RlY3RlZCBodG1sRWxlbWVudDogSFRNTEVsZW1lbnQ7XHJcblxyXG4gIC8qKlxyXG4gICAqIEBpZ25vcmVcclxuICAgKi9cclxuICBwcml2YXRlIHJvd0NoYW5nZWRTdWJzY3JpYmVyOiBTdWJzY3JpcHRpb24gPSBudWxsO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByb3RlY3RlZCBfdGFzayA6IFRhc2tNYWdpY1NlcnZpY2UsXHJcbiAgICBwcm90ZWN0ZWQgZWxlbWVudDogRWxlbWVudFJlZlxyXG4gIClcclxuICB7XHJcbiAgICB0aGlzLmh0bWxFbGVtZW50ID0gdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQ7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBJbml0aWFsaXplcyB0aGlzIG9iamVjdFxyXG4gICAqL1xyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5yb3dDaGFuZ2VkU3Vic2NyaWJlciA9IHRoaXMuX3Rhc2tcclxuICAgICAgLk9uU2VsZWN0ZWRSb3dDaGFuZ2VkLnBpcGUoZmlsdGVyKHJvd0lkID0+IHJvd0lkID09PSB0aGlzLnJvd0lkKSlcclxuICAgICAgLnN1YnNjcmliZShyb3dJZCA9PiB7XHJcbiAgICAgICAgICBpZiAoIXRoaXMuaXNJblZpZXcodGhpcy5odG1sRWxlbWVudCkpXHJcbiAgICAgICAgICAgIHRoaXMuaHRtbEVsZW1lbnQuc2Nyb2xsSW50b1ZpZXcoKTtcclxuICAgICAgICB9XHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGlzSW5WaWV3KGVsZW1lbnQpOiBib29sZWFuIHtcclxuICAgIGNvbnN0IHJlY3QgPSBlbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xyXG4gICAgY29uc3QgcGFyZW50UmVjdCA9IGVsZW1lbnQucGFyZW50RWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcclxuICAgIHJldHVybiAoXHJcbiAgICAgIHJlY3QudG9wID49IHBhcmVudFJlY3QudG9wICYmXHJcbiAgICAgIHJlY3QuYm90dG9tIDw9IHBhcmVudFJlY3QuYm90dG9tXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQ2xlYW51cFxyXG4gICAqL1xyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgLy8gRG9uJ3Qga25vdyB3aHksIGJ1dCB3aGVuIHRoZSB0YWJsZSBpcyBsb2FkZWQgZm9yIHRoZSBmaXJzdCB0aW1lLCB3ZVxyXG4gICAgLy8gZ2V0IG5nT25Jbml0KCkgZm9yIHRoZSAxc3Qgcm93IChyb3dJZCA9IFwiMFwiKSBhbmQgdGhlbiBuZ09uRGVzdHJveSgpXHJcbiAgICAvLyBmb3IgbnVtYmVyIG9mIHJvd3MgaW4gdGhlIHBhZ2UgYnV0IGhlcmUgdGhpcy5yb3dJZCBpcyB1bmRlZmluZWQuXHJcbiAgICAvLyBTaW5jZSBuZ09uSW5pdCgpIHdhcyBub3QgY2FsbGVkIGZvciBhbGwgdGhlc2Ugcm93cywgdGhpcy5yb3dDaGFuZ2VkU3Vic2NyaWJlclxyXG4gICAgLy8gaXMgbnVsbCBhbmQgaGVuY2UgY3Jhc2hlcy5cclxuICAgIC8vIFNvLCB0aGUgY29uZGl0aW9uIHRvIGNoZWNrIG51bGl0eSBpcyBhZGRlZC5cclxuICAgIGlmICh0aGlzLnJvd0NoYW5nZWRTdWJzY3JpYmVyICE9PSBudWxsKSB7XHJcbiAgICAgIHRoaXMucm93Q2hhbmdlZFN1YnNjcmliZXIudW5zdWJzY3JpYmUoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcclxuICBvbkNsaWNrKCRldmVudCkge1xyXG4gICAgaWYodGhpcy5yb3dJZCAhPSAnJykge1xyXG4gICAgICB0aGlzLl90YXNrLmluc2VydEV2ZW50KGdldEd1aUV2ZW50T2JqKCdjbGljaycsIFwibWFnaWNSb3dcIiwgK3RoaXMucm93SWQpKTtcclxuICAgICAgaWYgKE1hZ2ljRGlyZWN0aXZlLm5vT2ZBdXRvQ29tcGxldGVCb3hlc09wZW5lZCA8IDEpXHJcbiAgICAgICAgZXZlbnQuY2FuY2VsQnViYmxlID0gdHJ1ZTtcclxuICAgIH1cclxuICB9XHJcbiB9XHJcbiJdfQ==
@@ -0,0 +1,20 @@
1
+ import { Directive, ElementRef } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class MagicFocusDirective {
4
+ hostElement;
5
+ constructor(hostElement) {
6
+ this.hostElement = hostElement;
7
+ }
8
+ ngAfterViewInit() {
9
+ this.hostElement.nativeElement.focus();
10
+ }
11
+ static ɵfac = function MagicFocusDirective_Factory(t) { return new (t || MagicFocusDirective)(i0.ɵɵdirectiveInject(i0.ElementRef)); };
12
+ static ɵdir = i0.ɵɵdefineDirective({ type: MagicFocusDirective, selectors: [["", "magicFocus", ""]] });
13
+ }
14
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicFocusDirective, [{
15
+ type: Directive,
16
+ args: [{
17
+ selector: '[magicFocus]'
18
+ }]
19
+ }], () => [{ type: i0.ElementRef }], null); })();
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtZm9jdXMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvZGlyZWN0aXZlcy9tYWdpYy1mb2N1cy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUXRELE1BQU0sT0FBTyxtQkFBbUI7SUFFVjtJQUFwQixZQUFvQixXQUF1QjtRQUF2QixnQkFBVyxHQUFYLFdBQVcsQ0FBWTtJQUFHLENBQUM7SUFDL0MsZUFBZTtRQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pDLENBQUM7NkVBTFUsbUJBQW1COytDQUFuQixtQkFBbUI7O2lGQUFuQixtQkFBbUI7Y0FIL0IsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSxjQUFjO2FBQ3pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuLyoqXG4gKiBEaXJlY3RpdmUgZm9yIHNldHRpbmcgZm9jdXMgb24gZWxlbWVudFxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbbWFnaWNGb2N1c10nXG59KVxuZXhwb3J0IGNsYXNzIE1hZ2ljRm9jdXNEaXJlY3RpdmUgIHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGhvc3RFbGVtZW50OiBFbGVtZW50UmVmKSB7fVxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5ob3N0RWxlbWVudC5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gIH1cblxufVxuIl19