@magic-xpa/angular 4.900.0-dev490.73 → 4.900.0-dev490.76
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/src/ui/directives/magic.directive.mjs +36 -33
- package/fesm2015/magic-xpa-angular.mjs +26 -23
- package/fesm2015/magic-xpa-angular.mjs.map +1 -1
- package/fesm2020/magic-xpa-angular.mjs +26 -23
- package/fesm2020/magic-xpa-angular.mjs.map +1 -1
- package/package.json +3 -3
- package/src/ui/directives/magic.directive.d.ts +6 -6
@@ -1,13 +1,13 @@
|
|
1
|
-
import { Directive, ElementRef, Input, Optional, Renderer2, ViewContainerRef } from
|
2
|
-
import { isNullOrUndefined } from
|
3
|
-
import { CommandType, GuiConstants, HtmlProperties, InteractiveCommandType, Modifiers } from
|
4
|
-
import { getGuiEventObj } from
|
5
|
-
import { TaskBaseMagicComponent } from
|
6
|
-
import { TaskMagicService } from
|
7
|
-
import { debounceTime, filter, map } from
|
8
|
-
import { RowMagicDirective } from
|
9
|
-
import { fromEvent } from
|
10
|
-
import { BindingLevel, StorageAttributeType } from
|
1
|
+
import { Directive, ElementRef, Input, Optional, Renderer2, ViewContainerRef } from "@angular/core";
|
2
|
+
import { isNullOrUndefined } from "@magic-xpa/mscorelib";
|
3
|
+
import { CommandType, GuiConstants, HtmlProperties, InteractiveCommandType, Modifiers } from "@magic-xpa/gui";
|
4
|
+
import { getGuiEventObj } from "@magic-xpa/engine";
|
5
|
+
import { TaskBaseMagicComponent } from "../task-base.magic.component";
|
6
|
+
import { TaskMagicService } from "../../services/task.magics.service";
|
7
|
+
import { debounceTime, filter, map } from "rxjs/operators";
|
8
|
+
import { RowMagicDirective } from "./magic/row.magic.directive";
|
9
|
+
import { fromEvent } from "rxjs";
|
10
|
+
import { BindingLevel, MgControlType, StorageAttributeType } from "@magic-xpa/utils";
|
11
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";
|
@@ -21,16 +21,16 @@ export class MagicDirective {
|
|
21
21
|
this.eventHandlers = {};
|
22
22
|
this.eventsOnlyVal = false;
|
23
23
|
this.htmlElement = this.element.nativeElement;
|
24
|
-
if (!(typeof magicRow ===
|
24
|
+
if (!(typeof magicRow === "undefined" || magicRow === null))
|
25
25
|
this.rowId = magicRow.rowId;
|
26
26
|
}
|
27
27
|
set magic(val) {
|
28
28
|
this.id = val;
|
29
|
-
this.selector =
|
29
|
+
this.selector = "magic";
|
30
30
|
}
|
31
31
|
;
|
32
32
|
set eventsOnly(val) {
|
33
|
-
console.log(
|
33
|
+
console.log("eventsOnly");
|
34
34
|
this.eventsOnlyVal = true;
|
35
35
|
}
|
36
36
|
;
|
@@ -38,11 +38,11 @@ export class MagicDirective {
|
|
38
38
|
return this._task;
|
39
39
|
}
|
40
40
|
regEvents() {
|
41
|
-
this.eventHandlers[
|
41
|
+
this.eventHandlers["focusin"] = this.OnFocus.bind(this);
|
42
42
|
Object.keys(this.eventHandlers).forEach((key) => {
|
43
43
|
this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);
|
44
44
|
});
|
45
|
-
let events = [
|
45
|
+
let events = ["click", "mousedown", "dblclick"];
|
46
46
|
events.forEach(event => {
|
47
47
|
this.renderer.listen(this.htmlElement, event, (e) => {
|
48
48
|
let fromButton = false;
|
@@ -53,15 +53,15 @@ export class MagicDirective {
|
|
53
53
|
e.cancelBubble = true;
|
54
54
|
});
|
55
55
|
});
|
56
|
-
this.renderer.listen(this.htmlElement,
|
57
|
-
let guiEvent = getGuiEventObj(
|
56
|
+
this.renderer.listen(this.htmlElement, "change", (e) => {
|
57
|
+
let guiEvent = getGuiEventObj("selectionchanged", this.id, +this.rowId);
|
58
58
|
if ((event.target).selectedIndex !== undefined) {
|
59
59
|
guiEvent.Value = (event.target).selectedIndex.toString();
|
60
60
|
e.cancelBubble = true;
|
61
61
|
this.task.insertEvent(guiEvent);
|
62
62
|
}
|
63
63
|
});
|
64
|
-
fromEvent(this.htmlElement,
|
64
|
+
fromEvent(this.htmlElement, "input").pipe(map((event) => {
|
65
65
|
return event.target.value;
|
66
66
|
}), debounceTime(200)).subscribe((x) => {
|
67
67
|
if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {
|
@@ -70,8 +70,8 @@ export class MagicDirective {
|
|
70
70
|
this.task.mgAccessorService.setValueToControl(this.id, x, true);
|
71
71
|
}
|
72
72
|
});
|
73
|
-
this.renderer.listen(this.htmlElement,
|
74
|
-
let guiEvent = getGuiEventObj(
|
73
|
+
this.renderer.listen(this.htmlElement, "keydown", (e) => {
|
74
|
+
let guiEvent = getGuiEventObj("keydown", this.id, +this.rowId);
|
75
75
|
guiEvent.modifiers = Modifiers.MODIFIER_NONE;
|
76
76
|
if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)
|
77
77
|
guiEvent.modifiers = Modifiers.MODIFIER_ALT;
|
@@ -97,7 +97,7 @@ export class MagicDirective {
|
|
97
97
|
});
|
98
98
|
}
|
99
99
|
OnFocus() {
|
100
|
-
this.task.insertEvent(getGuiEventObj(
|
100
|
+
this.task.insertEvent(getGuiEventObj("focus", this.id, +this.rowId));
|
101
101
|
event.cancelBubble = true;
|
102
102
|
}
|
103
103
|
IsSameElement(command) {
|
@@ -117,7 +117,7 @@ export class MagicDirective {
|
|
117
117
|
.subscribe(a => {
|
118
118
|
let command = a;
|
119
119
|
if (isNullOrUndefined(this.rowId))
|
120
|
-
this.rowId =
|
120
|
+
this.rowId = "0";
|
121
121
|
try {
|
122
122
|
if (!this.eventsOnlyVal)
|
123
123
|
this.handleCommand(command);
|
@@ -145,7 +145,7 @@ export class MagicDirective {
|
|
145
145
|
this.focusUnlistener();
|
146
146
|
if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))
|
147
147
|
this.htmlElement.focus();
|
148
|
-
this.focusUnlistener = this.renderer.listen(this.htmlElement,
|
148
|
+
this.focusUnlistener = this.renderer.listen(this.htmlElement, "focusin", this.eventHandlers["focusin"]);
|
149
149
|
break;
|
150
150
|
}
|
151
151
|
}
|
@@ -155,13 +155,13 @@ export class MagicDirective {
|
|
155
155
|
let methodName = command._str;
|
156
156
|
let args = command.arguments;
|
157
157
|
let magicComponent = (this.vcRef._hostLView).find(v => v instanceof TaskBaseMagicComponent);
|
158
|
-
let resultString =
|
158
|
+
let resultString = "";
|
159
159
|
try {
|
160
160
|
if (!isNullOrUndefined(magicComponent[methodName])) {
|
161
161
|
resultString = magicComponent[methodName].apply(magicComponent, args);
|
162
162
|
}
|
163
163
|
else
|
164
|
-
console.error(
|
164
|
+
console.error("Instance method " + methodName + " does not exists");
|
165
165
|
}
|
166
166
|
catch (e) {
|
167
167
|
console.error(e.message);
|
@@ -173,10 +173,13 @@ export class MagicDirective {
|
|
173
173
|
handleSetProperty(command) {
|
174
174
|
switch (command.Operation) {
|
175
175
|
case HtmlProperties.ReadOnly:
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
176
|
+
{
|
177
|
+
if (command.obj.Type == MgControlType.CTRL_TYPE_TEXT)
|
178
|
+
if (command.obj1 != true)
|
179
|
+
this.renderer.removeAttribute(this.htmlElement, command.Operation);
|
180
|
+
else
|
181
|
+
this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);
|
182
|
+
}
|
180
183
|
break;
|
181
184
|
}
|
182
185
|
}
|
@@ -191,17 +194,17 @@ MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors:
|
|
191
194
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicDirective, [{
|
192
195
|
type: Directive,
|
193
196
|
args: [{
|
194
|
-
selector:
|
197
|
+
selector: "[magic]"
|
195
198
|
}]
|
196
199
|
}], function () { return [{ type: i1.TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.RowMagicDirective, decorators: [{
|
197
200
|
type: Optional
|
198
201
|
}] }]; }, { magic: [{
|
199
202
|
type: Input,
|
200
|
-
args: [
|
203
|
+
args: ["magic"]
|
201
204
|
}], eventsOnly: [{
|
202
205
|
type: Input,
|
203
|
-
args: [
|
206
|
+
args: ["eventsOnly"]
|
204
207
|
}], rowId: [{
|
205
208
|
type: Input
|
206
209
|
}] }); })();
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, Optional, Renderer2, ViewContainerRef } from '@angular/core';\r\nimport { isNullOrUndefined } from '@magic-xpa/mscorelib';\r\n\r\nimport {\r\n  CommandType,\r\n  GuiCommand,\r\n  GuiConstants,\r\n  GuiInteractive,\r\n  HtmlProperties,\r\n  InteractiveCommandType,\r\n  Modifiers\r\n} from '@magic-xpa/gui';\r\nimport { getGuiEventObj, IGuiEvent } from '@magic-xpa/engine';\r\n\r\nimport { TaskBaseMagicComponent } from '../task-base.magic.component';\r\nimport { TaskMagicService } from '../../services/task.magics.service';\r\nimport { debounceTime, filter, map } from 'rxjs/operators';\r\nimport { RowMagicDirective } from './magic/row.magic.directive';\r\nimport { Subscription, fromEvent } from 'rxjs';\r\nimport { BindingLevel, StorageAttributeType } from '@magic-xpa/utils';\r\n\r\n\r\n/**\r\n * Connects HTML elements to the Magic Web Client engine\r\n */\r\n@Directive({\r\n  selector: '[magic]'\r\n})\r\n\r\nexport class MagicDirective implements OnInit, OnDestroy {\r\n  @Input('magic') set magic(val) {\r\n    this.id = val;\r\n    this.selector = 'magic';\r\n  };\r\n\r\n  /**\r\n   * This flag is used when we only want to register to events, but do not want to execute commands sent from server\r\n   */\r\n  @Input('eventsOnly') set eventsOnly(val) {\r\n    console.log('eventsOnly');\r\n    this.eventsOnlyVal = true;\r\n\r\n  };\r\n\r\n  /**\r\n   * Row id of the control, for when it is on a table\r\n   */\r\n  @Input() public rowId: string;\r\n  /**\r\n   *\r\n   */\r\n  //@Input() events: any[] = [];\r\n\r\n  /**\r\n   * The HTML element connected to this directive\r\n   */\r\n  protected htmlElement: HTMLElement;\r\n  /**\r\n   * Magic's component handling this control\r\n   */\r\n  public component: TaskBaseMagicComponent;\r\n  /**\r\n   * Collection of event handlers for this element\r\n   */\r\n  private eventHandlers: { [key: string]: () => void; } = {};\r\n  /**\r\n   * Id of this element\r\n   */\r\n  public id: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  protected selector: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  subscribeRefreshDom: Subscription;\r\n\r\n  private focusUnlistener: (() => void);\r\n\r\n  public eventsOnlyVal = false;\r\n\r\n  public static opened = false;\r\n\r\n  public static noOfAutoCompleteBoxesOpened =0;\r\n\r\n  subscribeInteractiveCommands: Subscription;\r\n\r\n  /**\r\n   *\r\n   * @param _task The task service\r\n   * @param element The element for which the directive is applied\r\n   * @param renderer Renderer for the element\r\n   * @param vcRef\r\n   * @param 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)._hostLView).find(v => v instanceof TaskBaseMagicComponent);\r\n        let resultString = '';\r\n\r\n        try {\r\n          if (!isNullOrUndefined(magicComponent[methodName])) {\r\n            // invoke the method on instance of magic componenet\r\n            resultString = magicComponent[methodName].apply(magicComponent, args);\r\n          }\r\n          else\r\n            console.error('Instance method ' + methodName + ' does not exists'); // when method is not found\r\n        } catch (e) {\r\n          // any other exception\r\n          console.error(e.message);\r\n        }\r\n        command.resultString = resultString; // update the return value\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle the Magic set-property command\r\n   * @param command\r\n   */\r\n  handleSetProperty(command: GuiCommand) {\r\n    switch (command.Operation) {\r\n      case HtmlProperties.ReadOnly:\r\n        if (command.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"]}
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/magic.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAqB,QAAQ,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACvH,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAEzD,OAAO,EACL,WAAW,EAEX,YAAY,EAEZ,cAAc,EACd,sBAAsB,EACtB,SAAS,EACV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,cAAc,EAAa,MAAM,mBAAmB,CAAC;AAE9D,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;;;;AAUrF,MAAM,OAAO,cAAc;IAmEzB,YACY,KAAuB,EACvB,OAAmB,EACnB,QAAmB,EACnB,KAAuB,EACX,QAA2B;QAJvC,UAAK,GAAL,KAAK,CAAkB;QACvB,YAAO,GAAP,OAAO,CAAY;QACnB,aAAQ,GAAR,QAAQ,CAAW;QACnB,UAAK,GAAL,KAAK,CAAkB;QACX,aAAQ,GAAR,QAAQ,CAAmB;QArC3C,kBAAa,GAAmC,EAAE,CAAC;QAgBpD,kBAAa,GAAG,KAAK,CAAC;QAuB3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QAM9C,IAAI,CAAC,CAAC,OAAO,QAAQ,KAAK,WAAW,IAAI,QAAQ,KAAK,IAAI,CAAC;YACzD,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;IAChC,CAAC;IAjFD,IAAoB,KAAK,CAAC,GAAG;QAC3B,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;QACd,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAC1B,CAAC;IAAA,CAAC;IAKF,IAAyB,UAAU,CAAC,GAAG;QACrC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAE5B,CAAC;IAAA,CAAC;IA2EF,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAKS,SAAS;QAEjB,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAC9C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9F,CAAC,CAAC,CAAC;QAGH,IAAI,MAAM,GAAa,CAAC,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;QAC1D,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACrB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,EAAE;gBAGlD,IAAI,UAAU,GAAG,KAAK,CAAC;gBACvB,IAAG,IAAI,CAAC,WAAW,YAAY,iBAAiB;oBAC9C,UAAU,GAAG,IAAI,CAAC;gBAEpB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC;gBAC/E,IAAI,cAAc,CAAC,2BAA2B,GAAE,CAAC;oBAC/C,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC;YAC1B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAGH,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;YACrD,IAAI,QAAQ,GAAc,cAAc,CAAC,kBAAkB,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAEnF,IAAU,CAAC,KAAK,CAAC,MAAM,CAAE,CAAC,aAAa,KAAK,SAAS,EAAE;gBACrD,QAAQ,CAAC,KAAK,GAAS,CAAC,KAAK,CAAC,MAAM,CAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;gBAChE,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC;gBACtB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;aACjC;QAEH,CAAC,CAAC,CAAC;QAGH,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,IAAI,CACvC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;YACjB,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC5B,CAAC,CAAC,EACF,YAAY,CAAC,GAAG,CAAC,CAClB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EAAE,cAAc,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,YAAY,CAAC,SAAS,EAAE;gBAEvG,IAAI,SAAS,GAA2B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC;gBACvG,IAAG,SAAS,KAAK,oBAAoB,CAAC,IAAI,IAAI,SAAS,IAAI,oBAAoB,CAAC,IAAI;oBACjF,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;aACnE;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,EAAE,CAAC,CAAgB,EAAE,EAAE;YACnE,IAAI,QAAQ,GAAc,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1E,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC,aAAa,CAAC;YAE7C,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,OAAO;gBAC9C,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC,YAAY,CAAC;iBAE3C,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,QAAQ;gBACrD,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC,aAAa,CAAC;YAEjD,IAAI,YAAY,GAAG,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,SAAS;gBACnD,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,WAAW;gBACtC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,QAAQ;gBACnC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,SAAS;gBACpC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,MAAM;gBACjC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,QAAQ;gBACnC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,OAAO;gBAClC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,QAAQ;gBACnC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,OAAO;gBAClC,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,UAAU;gBACrC,CAAC,CAAC,CAAC,OAAO,IAAI,YAAY,CAAC,MAAM,IAAI,CAAC,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,CAAC;YAE5E,IAAI,QAAQ,CAAC,SAAS,KAAK,SAAS,CAAC,aAAa,IAAI,YAAY,EAAE;gBAChE,QAAQ,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC;gBAG7B,IAAI,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,OAAO,IAAI,CAAC,CAAC,OAAO,KAAK,YAAY,CAAC,OAAO,IAAI,CAAC,CAAC,cAAc,CAAC,MAAM,IAAI,cAAc,CAAC,2BAA2B,GAAG,CAAC,CAAC;oBACtJ,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC;gBAE1B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;aACnC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAMO,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACrE,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC;IAC5B,CAAC;IAOO,aAAa,CAAC,OAAO;QAC3B,IAAI,IAAI,GAAW,OAAO,CAAC,IAAI,CAAC;QAEhC,IAAI,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC;YAC5C,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAE3C,OAAO,CAAC,OAAO,CAAC,QAAQ,KAAK,IAAI,CAAC,EAAE;YAClC,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK;gBACnB,CAAC,IAAI,KAAK,CAAC,IAAI,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC;IAOO,eAAe,CAAC,OAAuB;QAC7C,OAAO,CAAC,OAAO,CAAC,WAAW,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;IAC3C,CAAC;IAKO,YAAY;QAClB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,IAAI;aACjC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;aACnD,SAAS,CAAC,CAAC,CAAC,EAAE;YACX,IAAI,OAAO,GAAe,CAAC,CAAC;YAC5B,IAAI,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC/B,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;YACnB,IAAI;gBACF,IAAI,CAAC,IAAI,CAAC,aAAa;oBACrB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;aAC/B;YAAC,OAAO,EAAE,EAAE;gBACX,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aACjB;QACH,CAAC,CACF,CAAC;QAEJ,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC,IAAI,CAAC,mBAAmB;aAC9D,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;aAC1C,SAAS,CAAC,OAAO,CAAC,EAAE;YACnB,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACP,CAAC;IAKD,QAAQ;QACN,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAMD,aAAa,CAAC,OAAmB;QAC/B,QAAQ,OAAO,CAAC,WAAW,EAAE;YAE3B,KAAK,WAAW,CAAC,YAAY;gBAC3B,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,WAAW,CAAC,SAAS;gBACpB,IAAI,CAAC,eAAe,EAAE,CAAC;gBAE3B,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,IAAI,CAAC,WAAW,YAAY,iBAAiB,CAAC;oBAClF,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC;gBACxG,MAAM;SACP;IACL,CAAC;IAKD,yBAAyB,CAAC,OAAuB;QAC/C,QAAQ,OAAO,CAAC,YAAY,EAAE;YAC5B,KAAK,sBAAsB,CAAC,OAAO;gBACjC,IAAI,UAAU,GAAW,OAAO,CAAC,IAAI,CAAC;gBACtC,IAAI,IAAI,GAAe,OAAO,CAAC,SAAS,CAAC;gBACzC,IAAI,cAAc,GAA2B,CAAO,IAAI,CAAC,KAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,YAAY,sBAAsB,CAAC,CAAC;gBAC3H,IAAI,YAAY,GAAG,EAAE,CAAC;gBAEtB,IAAI;oBACF,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,EAAE;wBAElD,YAAY,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;qBACvE;;wBAEC,OAAO,CAAC,KAAK,CAAC,kBAAkB,GAAG,UAAU,GAAG,kBAAkB,CAAC,CAAC;iBACvE;gBAAC,OAAO,CAAC,EAAE;oBAEV,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;iBAC1B;gBACD,OAAO,CAAC,YAAY,GAAG,YAAY,CAAC;gBACpC,MAAM;SACT;IACH,CAAC;IAOD,iBAAiB,CAAC,OAAmB;QACnC,QAAQ,OAAO,CAAC,SAAS,EAAE;YACzB,KAAK,cAAc,CAAC,QAAQ;gBAAE;oBAC5B,IAAG,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,aAAa,CAAC,cAAc;wBACnD,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;4BACtB,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;;4BAEnE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;iBAChF;gBAEC,MAAM;SACT;IACH,CAAC;IAKD,WAAW;QAET,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC;;AA5Qa,qBAAM,GAAG,KAAM,CAAA;AAEf,0CAA2B,GAAE,CAAE,CAAA;4EAvDlC,cAAc;mDAAd,cAAc;uFAAd,cAAc;cAJ1B,SAAS;eAAC;gBACT,QAAQ,EAAE,SAAS;aACpB;;sBA0EI,QAAQ;wBAvES,KAAK;kBAAxB,KAAK;mBAAC,OAAO;YAQW,UAAU;kBAAlC,KAAK;mBAAC,YAAY;YASH,KAAK;kBAApB,KAAK","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, Optional, Renderer2, ViewContainerRef } from \"@angular/core\";\r\nimport { isNullOrUndefined } from \"@magic-xpa/mscorelib\";\r\n\r\nimport {\r\n  CommandType,\r\n  GuiCommand,\r\n  GuiConstants,\r\n  GuiInteractive,\r\n  HtmlProperties,\r\n  InteractiveCommandType,\r\n  Modifiers\r\n} from \"@magic-xpa/gui\";\r\nimport { getGuiEventObj, IGuiEvent } from \"@magic-xpa/engine\";\r\n\r\nimport { TaskBaseMagicComponent } from \"../task-base.magic.component\";\r\nimport { TaskMagicService } from \"../../services/task.magics.service\";\r\nimport { debounceTime, filter, map } from \"rxjs/operators\";\r\nimport { RowMagicDirective } from \"./magic/row.magic.directive\";\r\nimport { Subscription, fromEvent } from \"rxjs\";\r\nimport { BindingLevel, MgControlType, StorageAttributeType } from \"@magic-xpa/utils\";\r\n\r\n\r\n/**\r\n * Connects HTML elements to the Magic Web Client engine\r\n */\r\n@Directive({\r\n  selector: \"[magic]\"\r\n})\r\n\r\nexport class MagicDirective implements OnInit, OnDestroy {\r\n  @Input(\"magic\") set magic(val) {\r\n    this.id = val;\r\n    this.selector = \"magic\";\r\n  };\r\n\r\n  /**\r\n   * This flag is used when we only want to register to events, but do not want to execute commands sent from server\r\n   */\r\n  @Input(\"eventsOnly\") set eventsOnly(val) {\r\n    console.log(\"eventsOnly\");\r\n    this.eventsOnlyVal = true;\r\n\r\n  };\r\n\r\n  /**\r\n   * Row id of the control, for when it is on a table\r\n   */\r\n  @Input() public rowId: string;\r\n  /**\r\n   *\r\n   */\r\n  //@Input() events: any[] = [];\r\n\r\n  /**\r\n   * The HTML element connected to this directive\r\n   */\r\n  protected htmlElement: HTMLElement;\r\n  /**\r\n   * Magic's component handling this control\r\n   */\r\n  public component: TaskBaseMagicComponent;\r\n  /**\r\n   * Collection of event handlers for this element\r\n   */\r\n  private eventHandlers: { [key: string]: () => void; } = {};\r\n  /**\r\n   * Id of this element\r\n   */\r\n  public id: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  protected selector: string;\r\n  /**\r\n   * @ignore\r\n   */\r\n  subscribeRefreshDom: Subscription;\r\n\r\n  private focusUnlistener: (() => void);\r\n\r\n  public eventsOnlyVal = false;\r\n\r\n  public static opened = false;\r\n\r\n  public static noOfAutoCompleteBoxesOpened =0;\r\n\r\n  subscribeInteractiveCommands: Subscription;\r\n\r\n  /**\r\n   *\r\n   * @param _task The task service\r\n   * @param element The element for which the directive is applied\r\n   * @param renderer Renderer for the element\r\n   * @param vcRef\r\n   * @param 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)._hostLView).find(v => v instanceof TaskBaseMagicComponent);\r\n        let resultString = \"\";\r\n\r\n        try {\r\n          if (!isNullOrUndefined(magicComponent[methodName])) {\r\n            // invoke the method on instance of magic componenet\r\n            resultString = magicComponent[methodName].apply(magicComponent, args);\r\n          }\r\n          else\r\n            console.error(\"Instance method \" + methodName + \" does not exists\"); // when method is not found\r\n        } catch (e) {\r\n          // any other exception\r\n          console.error(e.message);\r\n        }\r\n        command.resultString = resultString; // update the return value\r\n        break;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Handle the Magic set-property command\r\n   * @param command\r\n   */\r\n  handleSetProperty(command: GuiCommand) {\r\n    switch (command.Operation) {\r\n      case HtmlProperties.ReadOnly: {\r\n        if(command.obj.Type == MgControlType.CTRL_TYPE_TEXT)\r\n        if (command.obj1 != true)\r\n          this.renderer.removeAttribute(this.htmlElement, command.Operation);\r\n        else\r\n          this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);\r\n      }\r\n\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n\r\n    this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n}\r\n"]}
|
@@ -10,7 +10,7 @@ import * as i3 from 'ng-dynamic-component';
|
|
10
10
|
import { DynamicModule } from 'ng-dynamic-component';
|
11
11
|
import { InteractiveCommandType, OverlayType, Styles, HtmlProperties, GuiConstants, CommandType, PIC, GuiEnvironment, Modifiers } from '@magic-xpa/gui';
|
12
12
|
import { MagicBridge, getGuiEventObj, CookieService } from '@magic-xpa/engine';
|
13
|
-
import { MagicProperties, Logger, StrUtil, StorageAttribute, BindingLevel, StorageAttributeType, PICInterface } from '@magic-xpa/utils';
|
13
|
+
import { MagicProperties, Logger, StrUtil, StorageAttribute, BindingLevel, StorageAttributeType, MgControlType, PICInterface } from '@magic-xpa/utils';
|
14
14
|
import { filter, map, debounceTime } from 'rxjs/operators';
|
15
15
|
import { Subject, fromEvent } from 'rxjs';
|
16
16
|
import { __awaiter, __decorate, __metadata } from 'tslib';
|
@@ -2858,16 +2858,16 @@ class MagicDirective {
|
|
2858
2858
|
this.eventHandlers = {};
|
2859
2859
|
this.eventsOnlyVal = false;
|
2860
2860
|
this.htmlElement = this.element.nativeElement;
|
2861
|
-
if (!(typeof magicRow ===
|
2861
|
+
if (!(typeof magicRow === "undefined" || magicRow === null))
|
2862
2862
|
this.rowId = magicRow.rowId;
|
2863
2863
|
}
|
2864
2864
|
set magic(val) {
|
2865
2865
|
this.id = val;
|
2866
|
-
this.selector =
|
2866
|
+
this.selector = "magic";
|
2867
2867
|
}
|
2868
2868
|
;
|
2869
2869
|
set eventsOnly(val) {
|
2870
|
-
console.log(
|
2870
|
+
console.log("eventsOnly");
|
2871
2871
|
this.eventsOnlyVal = true;
|
2872
2872
|
}
|
2873
2873
|
;
|
@@ -2875,11 +2875,11 @@ class MagicDirective {
|
|
2875
2875
|
return this._task;
|
2876
2876
|
}
|
2877
2877
|
regEvents() {
|
2878
|
-
this.eventHandlers[
|
2878
|
+
this.eventHandlers["focusin"] = this.OnFocus.bind(this);
|
2879
2879
|
Object.keys(this.eventHandlers).forEach((key) => {
|
2880
2880
|
this.focusUnlistener = this.renderer.listen(this.htmlElement, key, this.eventHandlers[key]);
|
2881
2881
|
});
|
2882
|
-
let events = [
|
2882
|
+
let events = ["click", "mousedown", "dblclick"];
|
2883
2883
|
events.forEach(event => {
|
2884
2884
|
this.renderer.listen(this.htmlElement, event, (e) => {
|
2885
2885
|
let fromButton = false;
|
@@ -2890,15 +2890,15 @@ class MagicDirective {
|
|
2890
2890
|
e.cancelBubble = true;
|
2891
2891
|
});
|
2892
2892
|
});
|
2893
|
-
this.renderer.listen(this.htmlElement,
|
2894
|
-
let guiEvent = getGuiEventObj(
|
2893
|
+
this.renderer.listen(this.htmlElement, "change", (e) => {
|
2894
|
+
let guiEvent = getGuiEventObj("selectionchanged", this.id, +this.rowId);
|
2895
2895
|
if ((event.target).selectedIndex !== undefined) {
|
2896
2896
|
guiEvent.Value = (event.target).selectedIndex.toString();
|
2897
2897
|
e.cancelBubble = true;
|
2898
2898
|
this.task.insertEvent(guiEvent);
|
2899
2899
|
}
|
2900
2900
|
});
|
2901
|
-
fromEvent(this.htmlElement,
|
2901
|
+
fromEvent(this.htmlElement, "input").pipe(map((event) => {
|
2902
2902
|
return event.target.value;
|
2903
2903
|
}), debounceTime(200)).subscribe((x) => {
|
2904
2904
|
if (this.task.getProperty(this.id, HtmlProperties.BindingLevel, this.rowId) === BindingLevel.Character) {
|
@@ -2907,8 +2907,8 @@ class MagicDirective {
|
|
2907
2907
|
this.task.mgAccessorService.setValueToControl(this.id, x, true);
|
2908
2908
|
}
|
2909
2909
|
});
|
2910
|
-
this.renderer.listen(this.htmlElement,
|
2911
|
-
let guiEvent = getGuiEventObj(
|
2910
|
+
this.renderer.listen(this.htmlElement, "keydown", (e) => {
|
2911
|
+
let guiEvent = getGuiEventObj("keydown", this.id, +this.rowId);
|
2912
2912
|
guiEvent.modifiers = Modifiers.MODIFIER_NONE;
|
2913
2913
|
if (e.altKey && e.keyCode !== GuiConstants.KEY_ALT)
|
2914
2914
|
guiEvent.modifiers = Modifiers.MODIFIER_ALT;
|
@@ -2934,7 +2934,7 @@ class MagicDirective {
|
|
2934
2934
|
});
|
2935
2935
|
}
|
2936
2936
|
OnFocus() {
|
2937
|
-
this.task.insertEvent(getGuiEventObj(
|
2937
|
+
this.task.insertEvent(getGuiEventObj("focus", this.id, +this.rowId));
|
2938
2938
|
event.cancelBubble = true;
|
2939
2939
|
}
|
2940
2940
|
IsSameElement(command) {
|
@@ -2954,7 +2954,7 @@ class MagicDirective {
|
|
2954
2954
|
.subscribe(a => {
|
2955
2955
|
let command = a;
|
2956
2956
|
if (isNullOrUndefined(this.rowId))
|
2957
|
-
this.rowId =
|
2957
|
+
this.rowId = "0";
|
2958
2958
|
try {
|
2959
2959
|
if (!this.eventsOnlyVal)
|
2960
2960
|
this.handleCommand(command);
|
@@ -2982,7 +2982,7 @@ class MagicDirective {
|
|
2982
2982
|
this.focusUnlistener();
|
2983
2983
|
if (!(command.obj.ConnectedControl && this.htmlElement instanceof HTMLButtonElement))
|
2984
2984
|
this.htmlElement.focus();
|
2985
|
-
this.focusUnlistener = this.renderer.listen(this.htmlElement,
|
2985
|
+
this.focusUnlistener = this.renderer.listen(this.htmlElement, "focusin", this.eventHandlers["focusin"]);
|
2986
2986
|
break;
|
2987
2987
|
}
|
2988
2988
|
}
|
@@ -2992,13 +2992,13 @@ class MagicDirective {
|
|
2992
2992
|
let methodName = command._str;
|
2993
2993
|
let args = command.arguments;
|
2994
2994
|
let magicComponent = (this.vcRef._hostLView).find(v => v instanceof TaskBaseMagicComponent);
|
2995
|
-
let resultString =
|
2995
|
+
let resultString = "";
|
2996
2996
|
try {
|
2997
2997
|
if (!isNullOrUndefined(magicComponent[methodName])) {
|
2998
2998
|
resultString = magicComponent[methodName].apply(magicComponent, args);
|
2999
2999
|
}
|
3000
3000
|
else
|
3001
|
-
console.error(
|
3001
|
+
console.error("Instance method " + methodName + " does not exists");
|
3002
3002
|
}
|
3003
3003
|
catch (e) {
|
3004
3004
|
console.error(e.message);
|
@@ -3010,10 +3010,13 @@ class MagicDirective {
|
|
3010
3010
|
handleSetProperty(command) {
|
3011
3011
|
switch (command.Operation) {
|
3012
3012
|
case HtmlProperties.ReadOnly:
|
3013
|
-
|
3014
|
-
|
3015
|
-
|
3016
|
-
|
3013
|
+
{
|
3014
|
+
if (command.obj.Type == MgControlType.CTRL_TYPE_TEXT)
|
3015
|
+
if (command.obj1 != true)
|
3016
|
+
this.renderer.removeAttribute(this.htmlElement, command.Operation);
|
3017
|
+
else
|
3018
|
+
this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);
|
3019
|
+
}
|
3017
3020
|
break;
|
3018
3021
|
}
|
3019
3022
|
}
|
@@ -3029,7 +3032,7 @@ MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors:
|
|
3029
3032
|
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicDirective, [{
|
3030
3033
|
type: Directive,
|
3031
3034
|
args: [{
|
3032
|
-
selector:
|
3035
|
+
selector: "[magic]"
|
3033
3036
|
}]
|
3034
3037
|
}], function () {
|
3035
3038
|
return [{ type: TaskMagicService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: RowMagicDirective, decorators: [{
|
@@ -3037,10 +3040,10 @@ MagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MagicDirective, selectors:
|
|
3037
3040
|
}] }];
|
3038
3041
|
}, { magic: [{
|
3039
3042
|
type: Input,
|
3040
|
-
args: [
|
3043
|
+
args: ["magic"]
|
3041
3044
|
}], eventsOnly: [{
|
3042
3045
|
type: Input,
|
3043
|
-
args: [
|
3046
|
+
args: ["eventsOnly"]
|
3044
3047
|
}], rowId: [{
|
3045
3048
|
type: Input
|
3046
3049
|
}] });
|