@magic-xpa/angular 4.800.0-dev480.22 → 4.800.0-dev480.220

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 (117) hide show
  1. package/bundles/magic-xpa-angular.umd.js +1382 -2648
  2. package/bundles/magic-xpa-angular.umd.js.map +1 -1
  3. package/bundles/magic-xpa-angular.umd.min.js +2 -2
  4. package/bundles/magic-xpa-angular.umd.min.js.map +1 -1
  5. package/esm2015/index.js +1 -1
  6. package/esm2015/magic-xpa-angular.js +1 -4
  7. package/esm2015/src/controls.metadata.model.js +3 -36
  8. package/esm2015/src/interfaces/sub-form-definition.iterface.js +1 -1
  9. package/esm2015/src/magic.core.module.js +4 -14
  10. package/esm2015/src/services/ISubformMagicService.js +1 -1
  11. package/esm2015/src/services/OverlayWindowService.js +4 -29
  12. package/esm2015/src/services/StylesMapManager.js +1 -4
  13. package/esm2015/src/services/accessor.magic.service.js +41 -249
  14. package/esm2015/src/services/commands-collector.magic.service.js +4 -7
  15. package/esm2015/src/services/component-list.magic.service.js +1 -25
  16. package/esm2015/src/services/confirmation.components.magic.provider.js +4 -24
  17. package/esm2015/src/services/engine.magic.service.js +7 -10
  18. package/esm2015/src/services/exit.magic.service.js +4 -10
  19. package/esm2015/src/services/magic.providers.js +1 -4
  20. package/esm2015/src/services/magic.services.js +4 -10
  21. package/esm2015/src/services/mg-date-adapter.js +5 -5
  22. package/esm2015/src/services/overlay.conainer.magic.provider.js +4 -8
  23. package/esm2015/src/services/router-commands.magic.service.js +4 -10
  24. package/esm2015/src/services/subform.magic.service.js +37 -56
  25. package/esm2015/src/services/table.magic.service.js +5 -61
  26. package/esm2015/src/services/task.magics.service.js +15 -282
  27. package/esm2015/src/services/title.magic.service.js +4 -15
  28. package/esm2015/src/ui/GuiInteractiveExecutor.js +8 -6
  29. package/esm2015/src/ui/components/base-magic-alert.component.js +4 -14
  30. package/esm2015/src/ui/components/base-magic-confirm.component.js +4 -16
  31. package/esm2015/src/ui/components/magic-alert.component.js +5 -8
  32. package/esm2015/src/ui/components/magic-confirmation-box.component.js +5 -8
  33. package/esm2015/src/ui/directives/NonMagicControlDirective.js +4 -31
  34. package/esm2015/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.js +4 -10
  35. package/esm2015/src/ui/directives/magic/checkbox.magic.directive.js +4 -13
  36. package/esm2015/src/ui/directives/magic/combobox.magic.directive.js +4 -10
  37. package/esm2015/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.js +5 -11
  38. package/esm2015/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.js +4 -16
  39. package/esm2015/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.js +5 -11
  40. package/esm2015/src/ui/directives/magic/input.noformcontrol.magic.directive.js +4 -10
  41. package/esm2015/src/ui/directives/magic/nocontrol.magic.directive.js +6 -16
  42. package/esm2015/src/ui/directives/magic/row.magic.directive.js +7 -23
  43. package/esm2015/src/ui/directives/magic-focus.directive.js +4 -7
  44. package/esm2015/src/ui/directives/magic.directive.js +12 -82
  45. package/esm2015/src/ui/directives/magicViewContainerRef.directive.js +4 -8
  46. package/esm2015/src/ui/directives/mgformat.magic.directive.js +4 -57
  47. package/esm2015/src/ui/directives/range-validator.magic.directive.js +4 -20
  48. package/esm2015/src/ui/magic-confirmationBox.js +1 -25
  49. package/esm2015/src/ui/magic-modal/base-magic-overlay-container.js +1 -1
  50. package/esm2015/src/ui/magic-modal/magic-modal-form.js +1 -4
  51. package/esm2015/src/ui/magic-modal/magic-modal-interface.js +1 -1
  52. package/esm2015/src/ui/magic-modal/magic-overlay-container-wrapper.js +4 -21
  53. package/esm2015/src/ui/magic-modal/magic-overlay-container.js +4 -46
  54. package/esm2015/src/ui/magic-root.component.js +10 -53
  55. package/esm2015/src/ui/mgerror.magic.component.js +4 -21
  56. package/esm2015/src/ui/pipes/date.magic.pipe.js +5 -12
  57. package/esm2015/src/ui/pipes/time.magic.pipe.js +4 -7
  58. package/esm2015/src/ui/router-container.magic.component.js +14 -35
  59. package/esm2015/src/ui/subform.magic.component.js +4 -23
  60. package/esm2015/src/ui/task-base.magic.component.js +4 -74
  61. package/esm2015/src/ui/utils.js +1 -20
  62. package/fesm2015/magic-xpa-angular.js +608 -1882
  63. package/fesm2015/magic-xpa-angular.js.map +1 -1
  64. package/magic-xpa-angular.d.ts +0 -3
  65. package/package.json +3 -3
  66. package/src/controls.metadata.model.d.ts +0 -16
  67. package/src/interfaces/sub-form-definition.iterface.d.ts +0 -6
  68. package/src/magic.core.module.d.ts +0 -3
  69. package/src/services/OverlayWindowService.d.ts +0 -19
  70. package/src/services/StylesMapManager.d.ts +0 -3
  71. package/src/services/accessor.magic.service.d.ts +15 -208
  72. package/src/services/commands-collector.magic.service.d.ts +0 -3
  73. package/src/services/component-list.magic.service.d.ts +0 -27
  74. package/src/services/confirmation.components.magic.provider.d.ts +0 -16
  75. package/src/services/engine.magic.service.d.ts +1 -3
  76. package/src/services/exit.magic.service.d.ts +0 -6
  77. package/src/services/magic.providers.d.ts +0 -3
  78. package/src/services/magic.services.d.ts +0 -6
  79. package/src/services/router-commands.magic.service.d.ts +0 -6
  80. package/src/services/subform.magic.service.d.ts +5 -30
  81. package/src/services/table.magic.service.d.ts +0 -55
  82. package/src/services/task.magics.service.d.ts +1 -294
  83. package/src/services/title.magic.service.d.ts +0 -11
  84. package/src/ui/GuiInteractiveExecutor.d.ts +1 -3
  85. package/src/ui/components/base-magic-alert.component.d.ts +0 -16
  86. package/src/ui/components/base-magic-confirm.component.d.ts +0 -18
  87. package/src/ui/components/magic-alert.component.d.ts +0 -3
  88. package/src/ui/components/magic-confirmation-box.component.d.ts +0 -3
  89. package/src/ui/directives/NonMagicControlDirective.d.ts +0 -41
  90. package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +0 -6
  91. package/src/ui/directives/magic/checkbox.magic.directive.d.ts +0 -9
  92. package/src/ui/directives/magic/combobox.magic.directive.d.ts +0 -6
  93. package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +0 -6
  94. package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +0 -12
  95. package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +0 -6
  96. package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +0 -6
  97. package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +0 -3
  98. package/src/ui/directives/magic/row.magic.directive.d.ts +0 -15
  99. package/src/ui/directives/magic-focus.directive.d.ts +0 -3
  100. package/src/ui/directives/magic.directive.d.ts +1 -78
  101. package/src/ui/directives/magicViewContainerRef.directive.d.ts +0 -3
  102. package/src/ui/directives/mgformat.magic.directive.d.ts +0 -40
  103. package/src/ui/directives/range-validator.magic.directive.d.ts +0 -16
  104. package/src/ui/magic-confirmationBox.d.ts +0 -19
  105. package/src/ui/magic-modal/base-magic-overlay-container.d.ts +0 -9
  106. package/src/ui/magic-modal/magic-modal-form.d.ts +0 -3
  107. package/src/ui/magic-modal/magic-modal-interface.d.ts +0 -27
  108. package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +0 -20
  109. package/src/ui/magic-modal/magic-overlay-container.d.ts +0 -51
  110. package/src/ui/magic-root.component.d.ts +0 -42
  111. package/src/ui/mgerror.magic.component.d.ts +0 -19
  112. package/src/ui/pipes/date.magic.pipe.d.ts +0 -6
  113. package/src/ui/pipes/time.magic.pipe.d.ts +0 -3
  114. package/src/ui/router-container.magic.component.d.ts +5 -21
  115. package/src/ui/subform.magic.component.d.ts +0 -21
  116. package/src/ui/task-base.magic.component.d.ts +0 -72
  117. package/src/ui/utils.d.ts +0 -3
@@ -11,35 +11,16 @@ import { fromEvent } from 'rxjs/internal/observable/fromEvent';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "../../services/task.magics.service";
13
13
  import * as i2 from "./magic/row.magic.directive";
14
- /**
15
- * Connects HTML elements to the Magic Web Client engine
16
- */
17
14
  export class MagicDirective {
18
- /**
19
- *
20
- * @param _task The task service
21
- * @param element The element for which the directive is applied
22
- * @param renderer Renderer for the element
23
- * @param vcRef
24
- * @param magicRow
25
- */
26
15
  constructor(_task, element, renderer, vcRef, magicRow) {
27
16
  this._task = _task;
28
17
  this.element = element;
29
18
  this.renderer = renderer;
30
19
  this.vcRef = vcRef;
31
20
  this.magicRow = magicRow;
32
- /**
33
- * Collection of event handlers for this element
34
- */
35
21
  this.eventHandlers = {};
36
22
  this.eventsOnlyVal = false;
37
23
  this.htmlElement = this.element.nativeElement;
38
- //let c = (<any>this.vcRef)._view;
39
- //while (!(c instanceof TaskBaseMagicComponent)) {
40
- // c = c.component;
41
- //}
42
- //this.component = c;
43
24
  if (!(typeof magicRow === 'undefined' || magicRow === null))
44
25
  this.rowId = magicRow.rowId;
45
26
  }
@@ -48,40 +29,28 @@ export class MagicDirective {
48
29
  this.selector = 'magic';
49
30
  }
50
31
  ;
51
- /**
52
- * This flag is used when we only want to register to events, but do not want to execute commands sent from server
53
- */
54
32
  set eventsOnly(val) {
55
33
  console.log('eventsOnly');
56
34
  this.eventsOnlyVal = true;
57
35
  }
58
36
  ;
59
- /**
60
- * Get the task service
61
- * @returns
62
- */
63
37
  get task() {
64
38
  return this._task;
65
39
  }
66
- /**
67
- * Register to the events this element may need to handle
68
- */
69
40
  regEvents() {
70
- // Handle events for which event handler may be removed and restored
71
41
  this.eventHandlers['focusin'] = this.OnFocus.bind(this);
72
42
  Object.keys(this.eventHandlers).forEach((key) => {
73
43
  this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);
74
44
  });
75
- // Handle events with anonymous event handlers
76
- let events = ['click', 'mousedown', 'dblclick']; // ,'resize', 'load', 'unload'
45
+ let events = ['click', 'mousedown', 'dblclick'];
77
46
  events.forEach(event => {
78
47
  this.renderer.listen(this.htmlElement, event, (e) => {
79
- // check if the event is fired from zoom button ( to identify the connected zoom button in engine)
80
48
  let fromButton = false;
81
49
  if (this.htmlElement instanceof HTMLButtonElement)
82
50
  fromButton = true;
83
51
  this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));
84
- e.cancelBubble = true;
52
+ if (MagicDirective.noOfAutoCompleteBoxesOpened < 1)
53
+ e.cancelBubble = true;
85
54
  });
86
55
  });
87
56
  this.renderer.listen(this.htmlElement, 'change', (e) => {
@@ -92,13 +61,10 @@ export class MagicDirective {
92
61
  this.task.insertEvent(guiEvent);
93
62
  }
94
63
  });
95
- // handle the input event
96
64
  fromEvent(this.htmlElement, 'input').pipe(map((event) => {
97
65
  return event.target.value;
98
- }), debounceTime(200) // time after which value will be sent to magic
99
- ).subscribe((x) => {
66
+ }), debounceTime(200)).subscribe((x) => {
100
67
  if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {
101
- // Don't support character binding for date/time values
102
68
  let attribute = this.task.Records.list[0].getControlMetadata(this.id).dataType;
103
69
  if (attribute !== StorageAttributeType.Date && attribute != StorageAttributeType.Time)
104
70
  this.task.mgAccessorService.setValueToControl(this.id, x, true);
@@ -124,25 +90,16 @@ export class MagicDirective {
124
90
  (e.keyCode >= GuiConstants.KEY_F1 && e.keyCode <= GuiConstants.KEY_F12);
125
91
  if (guiEvent.modifiers !== Modifiers.MODIFIER_NONE || supportedKey) {
126
92
  guiEvent.keyCode = e.keyCode;
127
- // Defect 160021 fixed - don't set e.cancelBubble when combobox is opened and esc key is pressed
128
- if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && !MagicDirective.opened)
93
+ if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && (!MagicDirective.opened && MagicDirective.noOfAutoCompleteBoxesOpened < 1))
129
94
  e.cancelBubble = true;
130
95
  this.task.insertEvent(guiEvent);
131
96
  }
132
97
  });
133
98
  }
134
- /**
135
- * Handle focus event
136
- */
137
99
  OnFocus() {
138
100
  this.task.insertEvent(getGuiEventObj('focus', this.id, +this.rowId));
139
101
  event.cancelBubble = true;
140
102
  }
141
- /**
142
- * Is the command's element the same as this directive's element
143
- * @param command
144
- * @returns true/false
145
- */
146
103
  IsSameElement(command) {
147
104
  let line = command.line;
148
105
  if (this.task.isTableControl(command.CtrlName))
@@ -151,17 +108,9 @@ export class MagicDirective {
151
108
  (line === +this.rowId ||
152
109
  (line === 0 && isNullOrUndefined(this.rowId))));
153
110
  }
154
- /**
155
- * Is the command's element the same as this directive's component
156
- * @param command
157
- * @returns true/false
158
- */
159
111
  IsSameComponent(command) {
160
112
  return (command.controlName === this.id);
161
113
  }
162
- /**
163
- * @ignore
164
- */
165
114
  regUpdatesUI() {
166
115
  this.subscribeRefreshDom = this.task
167
116
  .refreshDom.pipe(filter(c => this.IsSameElement(c)))
@@ -183,17 +132,10 @@ export class MagicDirective {
183
132
  this.handleInteractiveCommands(command);
184
133
  });
185
134
  }
186
- /**
187
- * Initializes this object
188
- */
189
135
  ngOnInit() {
190
136
  this.regEvents();
191
137
  this.regUpdatesUI();
192
138
  }
193
- /**
194
- * Handles the commands received from the Magic WebClient engine
195
- * @param command
196
- */
197
139
  handleCommand(command) {
198
140
  switch (command.CommandType) {
199
141
  case CommandType.SET_PROPERTY:
@@ -201,16 +143,12 @@ export class MagicDirective {
201
143
  break;
202
144
  case CommandType.SET_FOCUS:
203
145
  this.focusUnlistener();
204
- // Do not set focus on connected zoom button
205
146
  if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))
206
147
  this.htmlElement.focus();
207
148
  this.focusUnlistener = this.renderer.listen(this.htmlElement, 'focusin', this.eventHandlers['focusin']);
208
149
  break;
209
150
  }
210
151
  }
211
- /**
212
- * handle the interactive commands like CallJS
213
- */
214
152
  handleInteractiveCommands(command) {
215
153
  switch (command._commandType) {
216
154
  case InteractiveCommandType.CALL_JS:
@@ -220,24 +158,18 @@ export class MagicDirective {
220
158
  let resultString = '';
221
159
  try {
222
160
  if (!isNullOrUndefined(magicComponent[methodName])) {
223
- // invoke the method on instance of magic componenet
224
161
  resultString = magicComponent[methodName].apply(magicComponent, args);
225
162
  }
226
163
  else
227
- console.error('Instance method ' + methodName + ' does not exists'); // when method is not found
164
+ console.error('Instance method ' + methodName + ' does not exists');
228
165
  }
229
166
  catch (e) {
230
- // any other exception
231
167
  console.error(e.message);
232
168
  }
233
- command.resultString = resultString; // update the return value
169
+ command.resultString = resultString;
234
170
  break;
235
171
  }
236
172
  }
237
- /**
238
- * Handle the Magic set-property command
239
- * @param command
240
- */
241
173
  handleSetProperty(command) {
242
174
  switch (command.Operation) {
243
175
  case HtmlProperties.ReadOnly:
@@ -248,17 +180,15 @@ export class MagicDirective {
248
180
  break;
249
181
  }
250
182
  }
251
- /**
252
- * Cleanup
253
- */
254
183
  ngOnDestroy() {
255
184
  this.subscribeRefreshDom.unsubscribe();
256
185
  }
257
186
  }
258
187
  MagicDirective.opened = false;
259
- /** @nocollapse */ MagicDirective.ɵfac = function MagicDirective_Factory(t) { return new (t || MagicDirective)(i0.ɵɵdirectiveInject(i1.TaskMagicService), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i2.RowMagicDirective, 8)); };
260
- /** @nocollapse */ MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors: [["", "magic", ""]], inputs: { magic: "magic", eventsOnly: "eventsOnly", rowId: "rowId" } });
261
- /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(MagicDirective, [{
188
+ MagicDirective.noOfAutoCompleteBoxesOpened = 0;
189
+ MagicDirective.ɵfac = function MagicDirective_Factory(t) { return new (t || MagicDirective)(i0.ɵɵdirectiveInject(i1.TaskMagicService), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i2.RowMagicDirective, 8)); };
190
+ MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors: [["", "magic", ""]], inputs: { magic: "magic", eventsOnly: "eventsOnly", rowId: "rowId" } });
191
+ (function () { i0.ɵsetClassMetadata(MagicDirective, [{
262
192
  type: Directive,
263
193
  args: [{
264
194
  selector: '[magic]'
@@ -274,4 +204,4 @@ MagicDirective.opened = false;
274
204
  }], rowId: [{
275
205
  type: Input
276
206
  }] }); })();
277
- //# 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 'util';\r\n\r\nimport {\r\n  CommandType,\r\n  GuiCommand,\r\n  GuiConstants,\r\n  GuiInteractive,\r\n  HtmlProperties,\r\n  InteractiveCommandType,\r\n  Modifiers\r\n} from '@magic-xpa/gui';\r\nimport { getGuiEventObj, IGuiEvent } from '@magic-xpa/engine';\r\n\r\nimport { TaskBaseMagicComponent } from '../task-base.magic.component';\r\nimport { TaskMagicService } from '../../services/task.magics.service';\r\nimport { debounceTime, filter, map } from 'rxjs/operators';\r\nimport { RowMagicDirective } from './magic/row.magic.directive';\r\nimport { Subscription } from 'rxjs';\r\nimport { BindingLevel, StorageAttributeType } from '@magic-xpa/utils';\r\nimport { fromEvent } from 'rxjs/internal/observable/fromEvent';\r\n\r\n/**\r\n * Connects HTML elements to the Magic Web Client engine\r\n */\r\n@Directive({\r\n  selector: '[magic]'\r\n})\r\n\r\nexport class MagicDirective implements OnInit, OnDestroy {\r\n  @Input('magic') set magic(val) {\r\n    this.id = val;\r\n    this.selector = 'magic';\r\n  };\r\n\r\n  /**\r\n   * This flag is used when we only want to register to events, but do not want to execute commands sent from server\r\n   */\r\n  @Input('eventsOnly') set eventsOnly(val) {\r\n    console.log('eventsOnly');\r\n    this.eventsOnlyVal = true;\r\n\r\n  };\r\n\r\n  /**\r\n   * Row id of the control, for when it is on a table\r\n   */\r\n  @Input() public rowId: string;\r\n  /**\r\n   *\r\n   */\r\n  //@Input() events: any[] = [];\r\n\r\n  /**\r\n   * The HTML element connected to this directive\r\n   */\r\n  protected htmlElement: HTMLElement;\r\n  /**\r\n   * Magic's component handling this control\r\n   */\r\n  public component: TaskBaseMagicComponent;\r\n  /**\r\n   * Collection of event handlers for this element\r\n   */\r\n  private eventHandlers: { [key: string]: () => void; } = {};\r\n  /**\r\n   * Id of this element\r\n   */\r\n  public id: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  protected selector: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  subscribeRefreshDom: Subscription;\r\n\r\n  private focusUnlistener: (() => void);\r\n\r\n  public eventsOnlyVal = false;\r\n\r\n  public static opened = false;\r\n\r\n  subscribeInteractiveCommands: Subscription;\r\n\r\n  /**\r\n   *\r\n   * @param _task The task service\r\n   * @param element The element for which the directive is applied\r\n   * @param renderer Renderer for the element\r\n   * @param vcRef\r\n   * @param magicRow\r\n   */\r\n  constructor(\r\n    protected _task: TaskMagicService,\r\n    protected element: ElementRef,\r\n    protected renderer: Renderer2,\r\n    protected vcRef: ViewContainerRef,\r\n    @Optional() protected magicRow: RowMagicDirective) {\r\n\r\n    this.htmlElement = this.element.nativeElement;\r\n    //let c = (<any>this.vcRef)._view;\r\n    //while (!(c instanceof TaskBaseMagicComponent)) {\r\n    //  c = c.component;\r\n    //}\r\n    //this.component = c;\r\n    if (!(typeof magicRow === 'undefined' || magicRow === null))\r\n      this.rowId = magicRow.rowId;\r\n  }\r\n\r\n  /**\r\n   * Get the task service\r\n   * @returns\r\n   */\r\n  get task(): TaskMagicService {\r\n    return this._task;\r\n  }\r\n\r\n  /**\r\n   * Register to the events this element may need to handle\r\n   */\r\n  protected regEvents() {\r\n    // Handle events for which event handler may be removed and restored\r\n    this.eventHandlers['focusin'] = this.OnFocus.bind(this);\r\n\r\n    Object.keys(this.eventHandlers).forEach((key) => {\r\n      this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);\r\n    });\r\n\r\n    // Handle events with anonymous  event handlers\r\n    let events: string[] = ['click', 'mousedown', 'dblclick'];// ,'resize', 'load', 'unload'\r\n    events.forEach(event => {\r\n      this.renderer.listen(this.htmlElement, event, (e) => {\r\n        \r\n          // check if the event is fired from zoom button ( to identify the connected zoom button in engine)\r\n        let fromButton = false; \r\n        if(this.htmlElement instanceof HTMLButtonElement)\r\n          fromButton = true;\r\n\r\n        this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));\r\n        e.cancelBubble = true;\r\n\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)\r\n                e.cancelBubble = true;\r\n\r\n            this.task.insertEvent(guiEvent);\r\n        }\r\n    });\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle focus event\r\n   */\r\n  private OnFocus() {\r\n    this.task.insertEvent(getGuiEventObj('focus', this.id, +this.rowId));\r\n    event.cancelBubble = true;\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's element\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameElement(command) {\r\n    let line: number = command.line;\r\n\r\n    if (this.task.isTableControl(command.CtrlName))\r\n      line = this.task.getGuiRowId(line, true);\r\n\r\n    return (command.CtrlName === this.id &&\r\n      (line === +this.rowId ||\r\n        (line === 0 && isNullOrUndefined(this.rowId))));\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's component\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameComponent(command: GuiInteractive) {\r\n    return (command.controlName === this.id);\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  private regUpdatesUI() {\r\n    this.subscribeRefreshDom = this.task\r\n      .refreshDom.pipe(filter(c => this.IsSameElement(c)))\r\n      .subscribe(a => {\r\n          let command: GuiCommand = a;\r\n          if (isNullOrUndefined(this.rowId))\r\n            this.rowId = '0';\r\n          try {\r\n            if (!this.eventsOnlyVal)\r\n              this.handleCommand(command);\r\n          } catch (ex) {\r\n            console.dir(ex);\r\n          }\r\n        }\r\n      );\r\n\r\n    this.subscribeInteractiveCommands = this.task.interactiveCommands\r\n      .pipe(filter(c => this.IsSameComponent(c)))\r\n      .subscribe(command => {\r\n        this.handleInteractiveCommands(command);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Initializes this object\r\n   */\r\n  ngOnInit(): void {\r\n    this.regEvents();\r\n    this.regUpdatesUI();\r\n  }\r\n\r\n  /**\r\n   * Handles the commands received from the Magic WebClient engine\r\n   * @param command\r\n   */\r\n  handleCommand(command: GuiCommand) {\r\n    switch (command.CommandType) {\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_FOCUS:\r\n            this.focusUnlistener();\r\n       // Do not set focus on connected zoom  button\r\n        if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))\r\n          this.htmlElement.focus();\r\n        this.focusUnlistener = this.renderer.listen(this.htmlElement, 'focusin', this.eventHandlers['focusin']);\r\n        break;\r\n      }\r\n  }\r\n\r\n  /**\r\n   * handle the interactive commands like CallJS\r\n   */\r\n  handleInteractiveCommands(command: GuiInteractive) {\r\n    switch (command._commandType) {\r\n      case InteractiveCommandType.CALL_JS:\r\n        let methodName: string = command._str;\r\n        let args: Array<any> = command.arguments;\r\n        let magicComponent: TaskBaseMagicComponent = ((<any>this.vcRef)._hostView).find(v => v instanceof TaskBaseMagicComponent);\r\n        let resultString = '';\r\n\r\n        try {\r\n          if (!isNullOrUndefined(magicComponent[methodName])) {\r\n            // invoke the method on instance of magic componenet\r\n            resultString = magicComponent[methodName].apply(magicComponent, args);\r\n          }\r\n          else\r\n            console.error('Instance method ' + methodName + ' does not exists'); // when method is not found\r\n        } catch (e) {\r\n          // any other exception\r\n          console.error(e.message);\r\n        }\r\n        command.resultString = resultString; // update the return value\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle the Magic set-property command\r\n   * @param command\r\n   */\r\n  handleSetProperty(command: GuiCommand) {\r\n    switch (command.Operation) {\r\n      case HtmlProperties.ReadOnly:\r\n        if (command.obj1 != true)\r\n          this.renderer.removeAttribute(this.htmlElement, command.Operation);\r\n        else\r\n          this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);\r\n\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n\r\n    this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n}\r\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, Optional, Renderer2, ViewContainerRef } from '@angular/core';\r\nimport { isNullOrUndefined } from 'util';\r\n\r\nimport {\r\n  CommandType,\r\n  GuiCommand,\r\n  GuiConstants,\r\n  GuiInteractive,\r\n  HtmlProperties,\r\n  InteractiveCommandType,\r\n  Modifiers\r\n} from '@magic-xpa/gui';\r\nimport { getGuiEventObj, IGuiEvent } from '@magic-xpa/engine';\r\n\r\nimport { TaskBaseMagicComponent } from '../task-base.magic.component';\r\nimport { TaskMagicService } from '../../services/task.magics.service';\r\nimport { debounceTime, filter, map } from 'rxjs/operators';\r\nimport { RowMagicDirective } from './magic/row.magic.directive';\r\nimport { Subscription } from 'rxjs';\r\nimport { BindingLevel, StorageAttributeType } from '@magic-xpa/utils';\r\nimport { fromEvent } from 'rxjs/internal/observable/fromEvent';\r\n\r\n/**\r\n * Connects HTML elements to the Magic Web Client engine\r\n */\r\n@Directive({\r\n  selector: '[magic]'\r\n})\r\n\r\nexport class MagicDirective implements OnInit, OnDestroy {\r\n  @Input('magic') set magic(val) {\r\n    this.id = val;\r\n    this.selector = 'magic';\r\n  };\r\n\r\n  /**\r\n   * This flag is used when we only want to register to events, but do not want to execute commands sent from server\r\n   */\r\n  @Input('eventsOnly') set eventsOnly(val) {\r\n    console.log('eventsOnly');\r\n    this.eventsOnlyVal = true;\r\n\r\n  };\r\n\r\n  /**\r\n   * Row id of the control, for when it is on a table\r\n   */\r\n  @Input() public rowId: string;\r\n  /**\r\n   *\r\n   */\r\n  //@Input() events: any[] = [];\r\n\r\n  /**\r\n   * The HTML element connected to this directive\r\n   */\r\n  protected htmlElement: HTMLElement;\r\n  /**\r\n   * Magic's component handling this control\r\n   */\r\n  public component: TaskBaseMagicComponent;\r\n  /**\r\n   * Collection of event handlers for this element\r\n   */\r\n  private eventHandlers: { [key: string]: () => void; } = {};\r\n  /**\r\n   * Id of this element\r\n   */\r\n  public id: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  protected selector: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  subscribeRefreshDom: Subscription;\r\n\r\n  private focusUnlistener: (() => void);\r\n\r\n  public eventsOnlyVal = false;\r\n\r\n  public static opened = false;\r\n\r\n  public static noOfAutoCompleteBoxesOpened =0;\r\n\r\n  subscribeInteractiveCommands: Subscription;\r\n\r\n  /**\r\n   *\r\n   * @param _task The task service\r\n   * @param element The element for which the directive is applied\r\n   * @param renderer Renderer for the element\r\n   * @param vcRef\r\n   * @param magicRow\r\n   */\r\n  constructor(\r\n    protected _task: TaskMagicService,\r\n    protected element: ElementRef,\r\n    protected renderer: Renderer2,\r\n    protected vcRef: ViewContainerRef,\r\n    @Optional() protected magicRow: RowMagicDirective) {\r\n\r\n    this.htmlElement = this.element.nativeElement;\r\n    //let c = (<any>this.vcRef)._view;\r\n    //while (!(c instanceof TaskBaseMagicComponent)) {\r\n    //  c = c.component;\r\n    //}\r\n    //this.component = c;\r\n    if (!(typeof magicRow === 'undefined' || magicRow === null))\r\n      this.rowId = magicRow.rowId;\r\n  }\r\n\r\n  /**\r\n   * Get the task service\r\n   * @returns\r\n   */\r\n  get task(): TaskMagicService {\r\n    return this._task;\r\n  }\r\n\r\n  /**\r\n   * Register to the events this element may need to handle\r\n   */\r\n  protected regEvents() {\r\n    // Handle events for which event handler may be removed and restored\r\n    this.eventHandlers['focusin'] = this.OnFocus.bind(this);\r\n\r\n    Object.keys(this.eventHandlers).forEach((key) => {\r\n      this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);\r\n    });\r\n\r\n    // Handle events with anonymous  event handlers\r\n    let events: string[] = ['click', 'mousedown', 'dblclick'];// ,'resize', 'load', 'unload'\r\n    events.forEach(event => {\r\n      this.renderer.listen(this.htmlElement, event, (e) => {\r\n        \r\n          // check if the event is fired from zoom button ( to identify the connected zoom button in engine)\r\n        let fromButton = false; \r\n        if(this.htmlElement instanceof HTMLButtonElement)\r\n          fromButton = true;\r\n\r\n        this.task.insertEvent(getGuiEventObj(event, this.id, +this.rowId, fromButton));\r\n        if (MagicDirective.noOfAutoCompleteBoxesOpened< 1)\r\n          e.cancelBubble = true;\r\n      });\r\n    });\r\n\r\n\r\n    this.renderer.listen(this.htmlElement, 'change', (e) => {\r\n      let guiEvent: IGuiEvent = getGuiEventObj('selectionchanged', this.id, +this.rowId);\r\n\r\n      if ((<any>(event.target)).selectedIndex !== undefined) {\r\n        guiEvent.Value = (<any>(event.target)).selectedIndex.toString();\r\n        e.cancelBubble = true;\r\n        this.task.insertEvent(guiEvent);\r\n      }\r\n \r\n    });\r\n\r\n    // handle the input event\r\n    fromEvent(this.htmlElement, 'input').pipe(\r\n      map((event: any) => {\r\n        return event.target.value;\r\n      }),\r\n      debounceTime(200) // time after which value will be sent to magic\r\n    ).subscribe((x) => {\r\n        if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {\r\n          // Don't support character binding for date/time values\r\n         let attribute : StorageAttributeType =  this.task.Records.list[0].getControlMetadata(this.id).dataType;\r\n         if(attribute !== StorageAttributeType.Date && attribute != StorageAttributeType.Time)\r\n            this.task.mgAccessorService.setValueToControl(this.id, x, true);\r\n        }\r\n    });\r\n\r\n    this.renderer.listen(this.htmlElement, 'keydown', (e: KeyboardEvent) => {\r\n        let guiEvent: IGuiEvent = getGuiEventObj('keydown', this.id, +this.rowId);\r\n        guiEvent.modifiers = Modifiers.MODIFIER_NONE;\r\n\r\n        if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)\r\n            guiEvent.modifiers = Modifiers.MODIFIER_ALT;\r\n\r\n        else if (e.ctrlKey && e.keyCode !== GuiConstants.KEY_CTRL)\r\n            guiEvent.modifiers = Modifiers.MODIFIER_CTRL;\r\n\r\n        let supportedKey = e.keyCode === GuiConstants.KEY_PG_UP ||\r\n            e.keyCode === GuiConstants.KEY_PG_DOWN ||\r\n            e.keyCode === GuiConstants.KEY_LEFT ||\r\n            e.keyCode === GuiConstants.KEY_RIGHT ||\r\n            e.keyCode === GuiConstants.KEY_UP ||\r\n            e.keyCode === GuiConstants.KEY_DOWN ||\r\n            e.keyCode === GuiConstants.KEY_ESC ||\r\n            e.keyCode === GuiConstants.KEY_HOME ||\r\n            e.keyCode === GuiConstants.KEY_END ||\r\n            e.keyCode === GuiConstants.KEY_RETURN ||\r\n            (e.keyCode >= GuiConstants.KEY_F1 && e.keyCode <= GuiConstants.KEY_F12);\r\n\r\n        if (guiEvent.modifiers !== Modifiers.MODIFIER_NONE || supportedKey) {\r\n            guiEvent.keyCode = e.keyCode;\r\n\r\n            // Defect 160021 fixed - don't set e.cancelBubble when combobox is opened and esc key is pressed\r\n            if (e.keyCode !== GuiConstants.KEY_ESC || e.keyCode === GuiConstants.KEY_ESC && (!MagicDirective.opened && MagicDirective.noOfAutoCompleteBoxesOpened < 1))\r\n                e.cancelBubble = true;\r\n\r\n            this.task.insertEvent(guiEvent);\r\n        }\r\n    });\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle focus event\r\n   */\r\n  private OnFocus() {\r\n    this.task.insertEvent(getGuiEventObj('focus', this.id, +this.rowId));\r\n    event.cancelBubble = true;\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's element\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameElement(command) {\r\n    let line: number = command.line;\r\n\r\n    if (this.task.isTableControl(command.CtrlName))\r\n      line = this.task.getGuiRowId(line, true);\r\n\r\n    return (command.CtrlName === this.id &&\r\n      (line === +this.rowId ||\r\n        (line === 0 && isNullOrUndefined(this.rowId))));\r\n  }\r\n\r\n  /**\r\n   * Is the command's element the same as this directive's component\r\n   * @param command\r\n   * @returns true/false\r\n   */\r\n  private IsSameComponent(command: GuiInteractive) {\r\n    return (command.controlName === this.id);\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  private regUpdatesUI() {\r\n    this.subscribeRefreshDom = this.task\r\n      .refreshDom.pipe(filter(c => this.IsSameElement(c)))\r\n      .subscribe(a => {\r\n          let command: GuiCommand = a;\r\n          if (isNullOrUndefined(this.rowId))\r\n            this.rowId = '0';\r\n          try {\r\n            if (!this.eventsOnlyVal)\r\n              this.handleCommand(command);\r\n          } catch (ex) {\r\n            console.dir(ex);\r\n          }\r\n        }\r\n      );\r\n\r\n    this.subscribeInteractiveCommands = this.task.interactiveCommands\r\n      .pipe(filter(c => this.IsSameComponent(c)))\r\n      .subscribe(command => {\r\n        this.handleInteractiveCommands(command);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Initializes this object\r\n   */\r\n  ngOnInit(): void {\r\n    this.regEvents();\r\n    this.regUpdatesUI();\r\n  }\r\n\r\n  /**\r\n   * Handles the commands received from the Magic WebClient engine\r\n   * @param command\r\n   */\r\n  handleCommand(command: GuiCommand) {\r\n    switch (command.CommandType) {\r\n\r\n      case CommandType.SET_PROPERTY:\r\n        this.handleSetProperty(command);\r\n        break;\r\n\r\n      case CommandType.SET_FOCUS:\r\n            this.focusUnlistener();\r\n       // Do not set focus on connected zoom  button\r\n        if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))\r\n          this.htmlElement.focus();\r\n        this.focusUnlistener = this.renderer.listen(this.htmlElement, 'focusin', this.eventHandlers['focusin']);\r\n        break;\r\n      }\r\n  }\r\n\r\n  /**\r\n   * handle the interactive commands like CallJS\r\n   */\r\n  handleInteractiveCommands(command: GuiInteractive) {\r\n    switch (command._commandType) {\r\n      case InteractiveCommandType.CALL_JS:\r\n        let methodName: string = command._str;\r\n        let args: Array<any> = command.arguments;\r\n        let magicComponent: TaskBaseMagicComponent = ((<any>this.vcRef)._hostView).find(v => v instanceof TaskBaseMagicComponent);\r\n        let resultString = '';\r\n\r\n        try {\r\n          if (!isNullOrUndefined(magicComponent[methodName])) {\r\n            // invoke the method on instance of magic componenet\r\n            resultString = magicComponent[methodName].apply(magicComponent, args);\r\n          }\r\n          else\r\n            console.error('Instance method ' + methodName + ' does not exists'); // when method is not found\r\n        } catch (e) {\r\n          // any other exception\r\n          console.error(e.message);\r\n        }\r\n        command.resultString = resultString; // update the return value\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle the Magic set-property command\r\n   * @param command\r\n   */\r\n  handleSetProperty(command: GuiCommand) {\r\n    switch (command.Operation) {\r\n      case HtmlProperties.ReadOnly:\r\n        if (command.obj1 != true)\r\n          this.renderer.removeAttribute(this.htmlElement, command.Operation);\r\n        else\r\n          this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);\r\n\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n\r\n    this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n}\r\n"]}
@@ -1,24 +1,20 @@
1
1
  import { ComponentFactoryResolver, Directive, ViewContainerRef } from "@angular/core";
2
2
  import { isNullOrUndefined } from "util";
3
3
  import * as i0 from "@angular/core";
4
- /**
5
- * Directive for setting ViewContainerRef on element
6
- */
7
4
  export class MagicViewContainerRef {
8
5
  constructor(vcRef, resolver) {
9
6
  this.vcRef = vcRef;
10
7
  this.resolver = resolver;
11
- // For angular 10 - find the component from the views
12
8
  let comp = (this.vcRef._hostView).find(v => v != null && !isNullOrUndefined(v.setViewContainerRef));
13
9
  comp.setViewContainerRef(vcRef);
14
10
  }
15
11
  }
16
- /** @nocollapse */ MagicViewContainerRef.ɵfac = function MagicViewContainerRef_Factory(t) { return new (t || MagicViewContainerRef)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver)); };
17
- /** @nocollapse */ MagicViewContainerRef.ɵdir = i0.ɵɵdefineDirective({ type: MagicViewContainerRef, selectors: [["", "magicViewContainerRef", ""]] });
18
- /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(MagicViewContainerRef, [{
12
+ MagicViewContainerRef.ɵfac = function MagicViewContainerRef_Factory(t) { return new (t || MagicViewContainerRef)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver)); };
13
+ MagicViewContainerRef.ɵdir = i0.ɵɵdefineDirective({ type: MagicViewContainerRef, selectors: [["", "magicViewContainerRef", ""]] });
14
+ (function () { i0.ɵsetClassMetadata(MagicViewContainerRef, [{
19
15
  type: Directive,
20
16
  args: [{
21
17
  selector: '[magicViewContainerRef]',
22
18
  }]
23
19
  }], function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, null); })();
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvbWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXRGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFFekM7O0dBRUc7QUFJSCxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLFlBQW9CLEtBQXVCLEVBQVUsUUFBa0M7UUFBbkUsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUEwQjtRQUNyRixzREFBc0Q7UUFDdkQsSUFBSSxJQUFJLEdBQUcsQ0FBTyxJQUFJLENBQUMsS0FBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQTJCLElBQUksSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUUsQ0FBNEIsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7UUFDakssSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7OzZHQUxVLHFCQUFxQjs2RUFBckIscUJBQXFCO2tEQUFyQixxQkFBcUI7Y0FIakMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSx5QkFBeUI7YUFDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIERpcmVjdGl2ZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBJTWFnaWNWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXMvc3ViLWZvcm0tZGVmaW5pdGlvbi5pdGVyZmFjZVwiO1xuaW1wb3J0IHsgaXNOdWxsT3JVbmRlZmluZWQgfSBmcm9tIFwidXRpbFwiO1xuXG4vKipcbiAqIERpcmVjdGl2ZSBmb3Igc2V0dGluZyAgVmlld0NvbnRhaW5lclJlZiBvbiBlbGVtZW50XG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1ttYWdpY1ZpZXdDb250YWluZXJSZWZdJyxcbn0pXG5leHBvcnQgY2xhc3MgTWFnaWNWaWV3Q29udGFpbmVyUmVmIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSB2Y1JlZjogVmlld0NvbnRhaW5lclJlZiwgcHJpdmF0ZSByZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyKSB7XG4gICAgLy8gRm9yIGFuZ3VsYXIgMTAgLSAgZmluZCB0aGUgY29tcG9uZW50IGZyb20gdGhlIHZpZXdzXG4gICBsZXQgY29tcCA9ICgoPGFueT50aGlzLnZjUmVmKS5faG9zdFZpZXcpLmZpbmQodiA9PiB2IGFzIElNYWdpY1ZpZXdDb250YWluZXJSZWYgIT0gbnVsbCAmJiAhaXNOdWxsT3JVbmRlZmluZWQoKHYgYXMgSU1hZ2ljVmlld0NvbnRhaW5lclJlZikuc2V0Vmlld0NvbnRhaW5lclJlZikpO1xuICAgY29tcC5zZXRWaWV3Q29udGFpbmVyUmVmKHZjUmVmKTtcbiAgfVxufVxuXG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvbWFnaWNWaWV3Q29udGFpbmVyUmVmLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXRGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFRekMsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxZQUFvQixLQUF1QixFQUFVLFFBQWtDO1FBQW5FLFVBQUssR0FBTCxLQUFLLENBQWtCO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBMEI7UUFFdEYsSUFBSSxJQUFJLEdBQUcsQ0FBTyxJQUFJLENBQUMsS0FBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQTJCLElBQUksSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUUsQ0FBNEIsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7UUFDakssSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7OzBGQUxVLHFCQUFxQjswREFBckIscUJBQXFCO29DQUFyQixxQkFBcUI7Y0FIakMsU0FBUztlQUFDO2dCQUNULFFBQVEsRUFBRSx5QkFBeUI7YUFDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIERpcmVjdGl2ZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBJTWFnaWNWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXMvc3ViLWZvcm0tZGVmaW5pdGlvbi5pdGVyZmFjZVwiO1xuaW1wb3J0IHsgaXNOdWxsT3JVbmRlZmluZWQgfSBmcm9tIFwidXRpbFwiO1xuXG4vKipcbiAqIERpcmVjdGl2ZSBmb3Igc2V0dGluZyAgVmlld0NvbnRhaW5lclJlZiBvbiBlbGVtZW50XG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1ttYWdpY1ZpZXdDb250YWluZXJSZWZdJyxcbn0pXG5leHBvcnQgY2xhc3MgTWFnaWNWaWV3Q29udGFpbmVyUmVmIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSB2Y1JlZjogVmlld0NvbnRhaW5lclJlZiwgcHJpdmF0ZSByZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyKSB7XG4gICAgLy8gRm9yIGFuZ3VsYXIgMTAgLSAgZmluZCB0aGUgY29tcG9uZW50IGZyb20gdGhlIHZpZXdzXG4gICBsZXQgY29tcCA9ICgoPGFueT50aGlzLnZjUmVmKS5faG9zdFZpZXcpLmZpbmQodiA9PiB2IGFzIElNYWdpY1ZpZXdDb250YWluZXJSZWYgIT0gbnVsbCAmJiAhaXNOdWxsT3JVbmRlZmluZWQoKHYgYXMgSU1hZ2ljVmlld0NvbnRhaW5lclJlZikuc2V0Vmlld0NvbnRhaW5lclJlZikpO1xuICAgY29tcC5zZXRWaWV3Q29udGFpbmVyUmVmKHZjUmVmKTtcbiAgfVxufVxuXG4iXX0=