@magic-xpa/angular 4.1000.0 → 4.1000.410-0.428
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/index.mjs +1 -1
- package/esm2020/src/services/task.magics.service.mjs +13 -2
- package/esm2020/src/ui/GuiInteractiveExecutor.mjs +7 -2
- package/esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs +76 -7
- package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs +34 -5
- package/esm2020/src/ui/directives/mgformat.magic.directive.mjs +170 -2
- package/fesm2015/magic-xpa-angular.mjs +284 -13
- package/fesm2015/magic-xpa-angular.mjs.map +1 -1
- package/fesm2020/magic-xpa-angular.mjs +284 -13
- package/fesm2020/magic-xpa-angular.mjs.map +1 -1
- package/package.json +3 -3
- package/src/ui/directives/magic/checkbox.magic.directive.d.ts +15 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +8 -2
- package/src/ui/directives/mgformat.magic.directive.d.ts +7 -0
@@ -1,19 +1,86 @@
|
|
1
|
-
import { Directive, HostListener } from '@angular/core';
|
1
|
+
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
|
2
2
|
import { MagicDirective } from '../magic.directive';
|
3
|
+
import { TaskMagicService } from "../../../services/task.magics.service";
|
4
|
+
import { getGuiEventObj } from "@magic-xpa/engine";
|
5
|
+
import { filter } from "rxjs/operators";
|
6
|
+
import { CommandType, HtmlProperties } from "@magic-xpa/gui";
|
3
7
|
import * as i0 from "@angular/core";
|
4
8
|
import * as i1 from "../magic.directive";
|
9
|
+
import * as i2 from "../../../services/task.magics.service";
|
5
10
|
export class CheckboxMagicDirective {
|
6
|
-
constructor(magicDirective) {
|
11
|
+
constructor(magicDirective, el, task) {
|
7
12
|
this.magicDirective = magicDirective;
|
13
|
+
this.el = el;
|
14
|
+
this.task = task;
|
15
|
+
this.threeState = false;
|
16
|
+
this.subscribeRefreshDom = null;
|
17
|
+
this.isIndeterminate = false;
|
8
18
|
}
|
9
19
|
onChange($event) {
|
10
|
-
|
20
|
+
if (this.threeState) {
|
21
|
+
this.handleThreeState();
|
22
|
+
}
|
23
|
+
else {
|
24
|
+
this.magicDirective.task.onCheckChanged($event, this.magicDirective.id, +this.magicDirective.rowId);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
ngOnInit() {
|
28
|
+
if (this.threeState) {
|
29
|
+
let guiEvent = getGuiEventObj("setAsThreeState", this.magicDirective.id, +this.magicDirective.rowId);
|
30
|
+
this.task.insertEvent(guiEvent);
|
31
|
+
this.el.nativeElement.indeterminate = this.isIndeterminate = this.task.getProperty(this.magicDirective.id, HtmlProperties.CheckBoxIndeterminate, this.magicDirective.rowId);
|
32
|
+
this.regUpdatesUI();
|
33
|
+
}
|
34
|
+
}
|
35
|
+
regUpdatesUI() {
|
36
|
+
this.subscribeRefreshDom = this.task
|
37
|
+
.refreshDom.pipe(filter(c => this.magicDirective.IsSameElement(c)))
|
38
|
+
.subscribe(a => {
|
39
|
+
let command = a;
|
40
|
+
try {
|
41
|
+
this.handleCommand(command);
|
42
|
+
}
|
43
|
+
catch (ex) {
|
44
|
+
console.dir(ex);
|
45
|
+
}
|
46
|
+
});
|
47
|
+
}
|
48
|
+
handleCommand(command) {
|
49
|
+
if (command.CommandType == CommandType.SET_PROPERTY &&
|
50
|
+
command.Operation == HtmlProperties.CheckBoxIndeterminate) {
|
51
|
+
this.isIndeterminate = this.el.nativeElement.indeterminate = command.obj1;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
handleThreeState() {
|
55
|
+
let value = '';
|
56
|
+
let prevCheckedValue = this.task.getValue(this.magicDirective.id, this.magicDirective.rowId);
|
57
|
+
const checkbox = this.el.nativeElement;
|
58
|
+
if (this.isIndeterminate) {
|
59
|
+
checkbox.checked = false;
|
60
|
+
checkbox.indeterminate = false;
|
61
|
+
value = 'unchecked';
|
62
|
+
}
|
63
|
+
else if (prevCheckedValue) {
|
64
|
+
checkbox.checked = false;
|
65
|
+
checkbox.indeterminate = true;
|
66
|
+
value = 'indeterminate';
|
67
|
+
}
|
68
|
+
else if (!prevCheckedValue) {
|
69
|
+
checkbox.checked = true;
|
70
|
+
checkbox.indeterminate = false;
|
71
|
+
value = 'checked';
|
72
|
+
}
|
73
|
+
this.magicDirective.task.onCheckChanged(value, this.magicDirective.id, +this.magicDirective.rowId);
|
74
|
+
}
|
75
|
+
ngOnDestroy() {
|
76
|
+
if (this.subscribeRefreshDom !== null)
|
77
|
+
this.subscribeRefreshDom.unsubscribe();
|
11
78
|
}
|
12
79
|
}
|
13
|
-
CheckboxMagicDirective.ɵfac = function CheckboxMagicDirective_Factory(t) { return new (t || CheckboxMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective)); };
|
80
|
+
CheckboxMagicDirective.ɵfac = function CheckboxMagicDirective_Factory(t) { return new (t || CheckboxMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i2.TaskMagicService)); };
|
14
81
|
CheckboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: CheckboxMagicDirective, selectors: [["input", "type", "checkbox", "magic", "", 3, "noFormControl", ""]], hostBindings: function CheckboxMagicDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
15
82
|
i0.ɵɵlistener("change", function CheckboxMagicDirective_change_HostBindingHandler($event) { return ctx.onChange($event); });
|
16
|
-
} } });
|
83
|
+
} }, inputs: { threeState: "threeState" } });
|
17
84
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CheckboxMagicDirective, [{
|
18
85
|
type: Directive,
|
19
86
|
args: [{
|
@@ -21,8 +88,10 @@ CheckboxMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: CheckboxMagicDirec
|
|
21
88
|
input[type=checkbox][magic]:not([noFormControl])
|
22
89
|
`,
|
23
90
|
}]
|
24
|
-
}], function () { return [{ type: i1.MagicDirective }]; }, {
|
91
|
+
}], function () { return [{ type: i1.MagicDirective }, { type: i0.ElementRef }, { type: i2.TaskMagicService }]; }, { threeState: [{
|
92
|
+
type: Input
|
93
|
+
}], onChange: [{
|
25
94
|
type: HostListener,
|
26
95
|
args: ['change', ['$event']]
|
27
96
|
}] }); })();
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.magic.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/angular/src/ui/directives/magic/checkbox.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, HostListener, Input} from '@angular/core';\r\nimport { MagicDirective } from '../magic.directive';\r\nimport {TaskMagicService} from \"../../../services/task.magics.service\";\r\nimport {getGuiEventObj, IGuiEvent} from \"@magic-xpa/engine\";\r\nimport {filter} from \"rxjs/operators\";\r\nimport {CommandType, GuiCommand, HtmlProperties} from \"@magic-xpa/gui\";\r\n\r\n\r\n/**\r\n * Directive for checkboxes, to handle the 'change' event\r\n */\r\n@Directive({\r\n  selector:\r\n    `\r\n    input[type=checkbox][magic]:not([noFormControl])\r\n`,\r\n})\r\nexport class CheckboxMagicDirective {\r\n\r\n  @Input() threeState: boolean = false;\r\n  private subscribeRefreshDom: any = null;\r\n  private isIndeterminate: boolean = false;\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor(    protected magicDirective: MagicDirective,\r\n                  private el: ElementRef,\r\n                  protected task: TaskMagicService,) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Handles the Checkbox 'change' event - pass it to the Magic engine\r\n   */\r\n  @HostListener('change', ['$event'])\r\n  onChange($event) {\r\n    if(this.threeState) {\r\n      this.handleThreeState();\r\n    }\r\n    else {\r\n      this.magicDirective.task.onCheckChanged($event, this.magicDirective.id, +this.magicDirective.rowId);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    if(this.threeState){\r\n      let guiEvent: IGuiEvent = getGuiEventObj(\"setAsThreeState\", this.magicDirective.id, +this.magicDirective.rowId);\r\n      this.task.insertEvent(guiEvent);\r\n      this.el.nativeElement.indeterminate = this.isIndeterminate = this.task.getProperty(this.magicDirective.id, HtmlProperties.CheckBoxIndeterminate, this.magicDirective.rowId);\r\n\r\n      this.regUpdatesUI();\r\n    }\r\n  }\r\n\r\n  private regUpdatesUI() {\r\n    this.subscribeRefreshDom = this.task\r\n      .refreshDom.pipe(filter(c => this.magicDirective.IsSameElement(c)))\r\n      .subscribe(a => {\r\n          let command: GuiCommand = a;\r\n          try {\r\n            this.handleCommand(command);\r\n          } catch (ex) {\r\n            console.dir(ex);\r\n          }\r\n        }\r\n      );\r\n  }\r\n\r\n  handleCommand(command: GuiCommand){\r\n    if (command.CommandType == CommandType.SET_PROPERTY &&\r\n      command.Operation == HtmlProperties.CheckBoxIndeterminate) {\r\n      this.isIndeterminate = this.el.nativeElement.indeterminate = command.obj1;\r\n    }\r\n  }\r\n\r\n  private handleThreeState() {\r\n\r\n    let value : string = '';\r\n    let prevCheckedValue = this.task.getValue(this.magicDirective.id, this.magicDirective.rowId);\r\n\r\n    const checkbox = this.el.nativeElement;\r\n\r\n    if (this.isIndeterminate) {\r\n      checkbox.checked = false;\r\n      checkbox.indeterminate = false;\r\n      value = 'unchecked';\r\n    } else if (prevCheckedValue) {\r\n      checkbox.checked = false;\r\n      checkbox.indeterminate = true;\r\n      value = 'indeterminate';\r\n    } else if (!prevCheckedValue) {\r\n      checkbox.checked = true;\r\n      checkbox.indeterminate = false;\r\n      value = 'checked';\r\n    }\r\n\r\n    // @ts-ignore\r\n    this.magicDirective.task.onCheckChanged(value, this.magicDirective.id, +this.magicDirective.rowId);\r\n\r\n  }\r\n\r\n  /**\r\n   * Cleanup\r\n   */\r\n  ngOnDestroy(): void {\r\n    if(this.subscribeRefreshDom !== null)\r\n      this.subscribeRefreshDom.unsubscribe();\r\n  }\r\n\r\n}\r\n\r\n\r\n"]}
|
package/esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs
CHANGED
@@ -1,18 +1,44 @@
|
|
1
1
|
import { Directive, ElementRef, forwardRef, HostListener, Renderer2 } from "@angular/core";
|
2
2
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
3
|
+
import { MagicDirective } from "../../../magic.directive";
|
4
|
+
import { TaskMagicService } from "../../../../../services/task.magics.service";
|
5
|
+
import { Environment, LastFocusedManager } from "@magic-xpa/engine";
|
3
6
|
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../../../magic.directive";
|
8
|
+
import * as i2 from "../../../../../services/task.magics.service";
|
4
9
|
export const DATE_VALUE_ACCESSOR = {
|
5
10
|
provide: NG_VALUE_ACCESSOR,
|
6
11
|
useExisting: forwardRef(() => DateValueAccessor),
|
7
12
|
multi: true
|
8
13
|
};
|
9
14
|
export class DateValueAccessor {
|
10
|
-
|
15
|
+
onBlurEvent(event) {
|
16
|
+
const century = Environment.Instance.GetCentury(LastFocusedManager.Instance.getCurrTask().getCompIdx());
|
17
|
+
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
18
|
+
this.formatDateWithCentury(event.target.value, century, control);
|
19
|
+
}
|
20
|
+
constructor(renderer, elementRef, magicDir, _task) {
|
11
21
|
this.renderer = renderer;
|
12
22
|
this.elementRef = elementRef;
|
23
|
+
this.magicDir = magicDir;
|
24
|
+
this._task = _task;
|
13
25
|
this.onChange = (_) => { };
|
14
26
|
this.onTouched = () => { };
|
15
27
|
}
|
28
|
+
formatDateWithCentury(userInput, century, control) {
|
29
|
+
const separator = userInput.includes('/') ? '/' : "-";
|
30
|
+
let centuryVal = parseInt(century.toString().slice(0, 2));
|
31
|
+
if (userInput.length == 0)
|
32
|
+
return;
|
33
|
+
const dateArray = userInput.split(separator);
|
34
|
+
const day = Number(dateArray[2]);
|
35
|
+
const month = Number(dateArray[1]);
|
36
|
+
const year = Number(dateArray[0]);
|
37
|
+
let updatedYear = year.toString().length === 2 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '' + year :
|
38
|
+
year.toString().length === 1 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '0' + year :
|
39
|
+
year;
|
40
|
+
control.setValue(new Date(`${updatedYear}${separator}${month}${separator}${day}`));
|
41
|
+
}
|
16
42
|
writeValue(value) {
|
17
43
|
if (!value) {
|
18
44
|
this.renderer.setProperty(this.elementRef.nativeElement, "value", null);
|
@@ -32,9 +58,9 @@ export class DateValueAccessor {
|
|
32
58
|
this.renderer.setProperty(this.elementRef.nativeElement, "disabled", isDisabled);
|
33
59
|
}
|
34
60
|
}
|
35
|
-
DateValueAccessor.ɵfac = function DateValueAccessor_Factory(t) { return new (t || DateValueAccessor)(i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ElementRef)); };
|
61
|
+
DateValueAccessor.ɵfac = function DateValueAccessor_Factory(t) { return new (t || DateValueAccessor)(i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.MagicDirective), i0.ɵɵdirectiveInject(i2.TaskMagicService)); };
|
36
62
|
DateValueAccessor.ɵdir = i0.ɵɵdefineDirective({ type: DateValueAccessor, selectors: [["", "dateInput", ""]], hostBindings: function DateValueAccessor_HostBindings(rf, ctx) { if (rf & 1) {
|
37
|
-
i0.ɵɵlistener("input", function DateValueAccessor_input_HostBindingHandler($event) { return ctx.onChange($event.target.valueAsDate); })("blur", function DateValueAccessor_blur_HostBindingHandler() { return ctx.
|
63
|
+
i0.ɵɵlistener("input", function DateValueAccessor_input_HostBindingHandler($event) { return ctx.onChange($event.target.valueAsDate); })("blur", function DateValueAccessor_blur_HostBindingHandler($event) { return ctx.onBlurEvent($event); });
|
38
64
|
} }, features: [i0.ɵɵProvidersFeature([DATE_VALUE_ACCESSOR])] });
|
39
65
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DateValueAccessor, [{
|
40
66
|
type: Directive,
|
@@ -42,11 +68,14 @@ DateValueAccessor.ɵdir = i0.ɵɵdefineDirective({ type: DateValueAccessor, sele
|
|
42
68
|
selector: "[dateInput]",
|
43
69
|
providers: [DATE_VALUE_ACCESSOR]
|
44
70
|
}]
|
45
|
-
}], function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, { onChange: [{
|
71
|
+
}], function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.MagicDirective }, { type: i2.TaskMagicService }]; }, { onChange: [{
|
46
72
|
type: HostListener,
|
47
73
|
args: ["input", ["$event.target.valueAsDate"]]
|
48
74
|
}], onTouched: [{
|
49
75
|
type: HostListener,
|
50
76
|
args: ["blur", []]
|
77
|
+
}], onBlurEvent: [{
|
78
|
+
type: HostListener,
|
79
|
+
args: ['blur', ['$event']]
|
51
80
|
}] }); })();
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.cva.directive.js","sourceRoot":"","sources":["../../../../../../../../../../projects/angular/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  forwardRef,\r\n  HostListener,\r\n  Renderer2\r\n} from \"@angular/core\";\r\nimport {AbstractControl, ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {MagicDirective} from \"../../../magic.directive\";\r\nimport {TaskMagicService} from \"../../../../../services/task.magics.service\";\r\nimport {Environment, LastFocusedManager} from \"@magic-xpa/engine\";\r\n\r\nexport const DATE_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => DateValueAccessor),\r\n  multi: true\r\n};\r\n\r\n/**\r\n * The accessor for writing a value and listening to changes on a date input element\r\n *\r\n *  ### Example\r\n *  `<input type=\"date\" name=\"birthday\" ngModel dateInput>`\r\n *  OR\r\n *  `<input type=\"date\" formControlName=\"birthday\" dateInput>`\r\n */\r\n@Directive({\r\n  selector: \"[dateInput]\",\r\n  providers: [DATE_VALUE_ACCESSOR]\r\n})\r\nexport class DateValueAccessor implements ControlValueAccessor {\r\n  @HostListener(\"input\", [\"$event.target.valueAsDate\"])\r\n  onChange = (_: any) => {};\r\n  @HostListener(\"blur\", [])\r\n  onTouched = () => {};\r\n\r\n  @HostListener('blur', ['$event'])\r\n  public onBlurEvent(event) {\r\n    const century = Environment.Instance.GetCentury(LastFocusedManager.Instance.getCurrTask().getCompIdx());\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);\r\n\r\n    this.formatDateWithCentury(event.target.value, century, control);\r\n  }\r\n\r\n  constructor(private renderer: Renderer2, private elementRef: ElementRef,\r\n              protected magicDir: MagicDirective ,\r\n              protected _task: TaskMagicService) {}\r\n\r\n\r\n  /** Format year, if user enters 2 digits instead of 4 digits as per the century given in Magic.ini file */\r\n  formatDateWithCentury(userInput:string, century:number, control: AbstractControl){\r\n    const separator = userInput.includes('/')?'/':\"-\";\r\n    let centuryVal = parseInt(century.toString().slice(0, 2));\r\n    if(userInput.length == 0)\r\n      return ;\r\n\r\n    const dateArray: string[] = userInput.split(separator);\r\n    const day = Number(dateArray[2]);\r\n    const month = Number(dateArray[1]);\r\n    const year = Number(dateArray[0]);\r\n\r\n    let updatedYear = year.toString().length === 2 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '' + year :\r\n      year.toString().length === 1 ? (year < century % 100 ? centuryVal + 1 : centuryVal) + '0' + year :\r\n        year;\r\n\r\n    control.setValue(new Date(`${updatedYear}${separator}${month}${separator}${day}`))\r\n  }\r\n\r\n  /** Writes a new value to the element (model -> view) */\r\n  writeValue(value: Date): void {\r\n    if (!value) {\r\n      this.renderer.setProperty(this.elementRef.nativeElement, \"value\", null);\r\n      return;\r\n    }\r\n\r\n    this.renderer.setProperty(\r\n      this.elementRef.nativeElement,\r\n      \"valueAsDate\",\r\n      new Date(Date.UTC(value.getFullYear(), value.getMonth(), value.getDate()))\r\n    );\r\n  }\r\n\r\n  /** Registers a callback function, called when value changes (view -> model) */\r\n  registerOnChange(fn: (_: any) => void): void {\r\n    this.onChange = v =>\r\n      fn(\r\n        v instanceof Date\r\n          ? new Date(v.getUTCFullYear(), v.getUTCMonth(), v.getUTCDate())\r\n          : v\r\n      );\r\n  }\r\n\r\n  /** Registers a callback function, called when the control is blurred */\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  /** Enables or disables the element when the control status changes */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.renderer.setProperty(\r\n      this.elementRef.nativeElement,\r\n      \"disabled\",\r\n      isDisabled\r\n    );\r\n  }\r\n}\r\n"]}
|