@magic-xpa/angular 4.801.7 → 4.900.0-dev4100.11
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/services/accessor.magic.service.mjs +29 -6
- package/esm2020/src/services/mg-date-adapter.mjs +13 -8
- package/esm2020/src/services/task.magics.service.mjs +2 -2
- package/esm2020/src/ui/directives/magic.directive.mjs +9 -9
- package/esm2020/src/ui/directives/mgformat.magic.directive.mjs +36 -17
- package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +1 -1
- package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +2 -2
- package/esm2020/src/ui/magic-root.component.mjs +1 -1
- package/fesm2015/magic-xpa-angular.mjs +86 -38
- package/fesm2015/magic-xpa-angular.mjs.map +1 -1
- package/fesm2020/magic-xpa-angular.mjs +84 -38
- package/fesm2020/magic-xpa-angular.mjs.map +1 -1
- package/package.json +3 -3
- package/src/services/accessor.magic.service.d.ts +1 -0
- package/src/services/mg-date-adapter.d.ts +2 -1
- package/src/ui/directives/mgformat.magic.directive.d.ts +2 -0
@@ -5,6 +5,7 @@ import { PICInterface, StorageAttribute } from '@magic-xpa/utils';
|
|
5
5
|
import { MagicDirective } from './magic.directive';
|
6
6
|
import { Validators } from '@angular/forms';
|
7
7
|
import { MgDateFormatter } from '../pipes/date.magic.pipe';
|
8
|
+
import { isUndefined } from '@magic-xpa/mscorelib';
|
8
9
|
import * as i0 from "@angular/core";
|
9
10
|
import * as i1 from "./magic.directive";
|
10
11
|
import * as i2 from "../../services/task.magics.service";
|
@@ -23,6 +24,25 @@ export class MgformatMagicDirective {
|
|
23
24
|
}
|
24
25
|
}
|
25
26
|
onFocusEvent($event) {
|
27
|
+
this.calculatePattern();
|
28
|
+
}
|
29
|
+
onInputEvent($event) {
|
30
|
+
this.calculatePattern();
|
31
|
+
}
|
32
|
+
onChangeEvent($event) {
|
33
|
+
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
34
|
+
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
35
|
+
switch (attr) {
|
36
|
+
case StorageAttribute.ALPHA:
|
37
|
+
case StorageAttribute.UNICODE:
|
38
|
+
this.formatAlphaUnicode(control);
|
39
|
+
break;
|
40
|
+
case StorageAttribute.BOOLEAN:
|
41
|
+
this.formatBoolean(control);
|
42
|
+
break;
|
43
|
+
}
|
44
|
+
}
|
45
|
+
calculatePattern() {
|
26
46
|
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
27
47
|
if (control != null) {
|
28
48
|
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
@@ -39,26 +59,22 @@ export class MgformatMagicDirective {
|
|
39
59
|
if (attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {
|
40
60
|
if (control.validator == null)
|
41
61
|
control.setValidators(Validators.maxLength(pic.getMaskLength()));
|
42
|
-
else
|
43
|
-
|
62
|
+
else {
|
63
|
+
if (pic.isFormatExp()) {
|
64
|
+
control.setValidators(Validators.maxLength(pic.getMaskLength()));
|
65
|
+
if (isUndefined(this.magicDir.rowId))
|
66
|
+
this.magicDir.rowId = '0';
|
67
|
+
control.setValidators([control.validator, this._task.customValidator(this.magicDir.rowId, this.magicDir.id)]);
|
68
|
+
}
|
69
|
+
else
|
70
|
+
control.setValidators([control.validator, Validators.maxLength(pic.getMaskLength())]);
|
71
|
+
}
|
72
|
+
control.updateValueAndValidity();
|
44
73
|
}
|
45
74
|
}
|
46
75
|
}
|
47
76
|
}
|
48
77
|
}
|
49
|
-
onChangeEvent($event) {
|
50
|
-
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
51
|
-
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
52
|
-
switch (attr) {
|
53
|
-
case StorageAttribute.ALPHA:
|
54
|
-
case StorageAttribute.UNICODE:
|
55
|
-
this.formatAlphaUnicode(control);
|
56
|
-
break;
|
57
|
-
case StorageAttribute.BOOLEAN:
|
58
|
-
this.formatBoolean(control);
|
59
|
-
break;
|
60
|
-
}
|
61
|
-
}
|
62
78
|
formatDate(pic) {
|
63
79
|
let mgDateFormatter = new MgDateFormatter();
|
64
80
|
this._task.mgInputDateFormat = mgDateFormatter.ConvertMgDateFormatToAngular(pic.getMask());
|
@@ -207,7 +223,7 @@ export class MgformatMagicDirective {
|
|
207
223
|
}
|
208
224
|
MgformatMagicDirective.ɵfac = function MgformatMagicDirective_Factory(t) { return new (t || MgformatMagicDirective)(i0.ɵɵdirectiveInject(i1.MagicDirective), i0.ɵɵdirectiveInject(i2.TaskMagicService)); };
|
209
225
|
MgformatMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MgformatMagicDirective, selectors: [["", "mgFormat", ""]], hostBindings: function MgformatMagicDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
210
|
-
i0.ɵɵlistener("focus", function MgformatMagicDirective_focus_HostBindingHandler($event) { return ctx.onFocusEvent($event); })("change", function MgformatMagicDirective_change_HostBindingHandler($event) { return ctx.onChangeEvent($event); });
|
226
|
+
i0.ɵɵlistener("focus", function MgformatMagicDirective_focus_HostBindingHandler($event) { return ctx.onFocusEvent($event); })("input", function MgformatMagicDirective_input_HostBindingHandler($event) { return ctx.onInputEvent($event); })("change", function MgformatMagicDirective_change_HostBindingHandler($event) { return ctx.onChangeEvent($event); });
|
211
227
|
} } });
|
212
228
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MgformatMagicDirective, [{
|
213
229
|
type: Directive,
|
@@ -217,8 +233,11 @@ MgformatMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MgformatMagicDirec
|
|
217
233
|
}], function () { return [{ type: i1.MagicDirective }, { type: i2.TaskMagicService }]; }, { onFocusEvent: [{
|
218
234
|
type: HostListener,
|
219
235
|
args: ['focus', ['$event']]
|
236
|
+
}], onInputEvent: [{
|
237
|
+
type: HostListener,
|
238
|
+
args: ['input', ['$event']]
|
220
239
|
}], onChangeEvent: [{
|
221
240
|
type: HostListener,
|
222
241
|
args: ['change', ['$event']]
|
223
242
|
}] }); })();
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mgformat.magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/mgformat.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, HostListener} from '@angular/core';\r\nimport {TaskMagicService} from '../../services/task.magics.service';\r\nimport {StringBuilder, RefParam} from '@magic-xpa/mscorelib';\r\nimport {PICInterface, StorageAttribute} from '@magic-xpa/utils';\r\nimport {MagicDirective} from './magic.directive';\r\nimport {AbstractControl, Validators} from '@angular/forms';\r\nimport {PIC} from '@magic-xpa/gui';\r\nimport {MgDateFormatter} from '../pipes/date.magic.pipe';\r\n\r\n/**\r\n * Perform Magic validation on input controls which hold alphanumeric strings\r\n */\r\n@Directive({\r\n  selector: '[mgFormat]'\r\n})\r\n\r\n\r\nexport class MgformatMagicDirective {\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor(\r\n    protected magicDir: MagicDirective ,\r\n    protected _task: TaskMagicService\r\n\r\n  ) { }\r\n\r\n  ngAfterViewInit() {\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n\r\n    if(control != null && this._task.mgInputDateFormat == null) {\r\n      // get the first date control's format.\r\n      let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n      if (pic.getAttr() == StorageAttribute.DATE ) {\r\n        this.formatDate(pic);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /**\r\n   * This can be used to set pattern\r\n   * On input, verifies the input matches the required mask\r\n   */\r\n  @HostListener('focus', ['$event'])\r\n  public onFocusEvent($event){\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n\r\n    if(control != null ) {\r\n      let attr: StorageAttribute = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;\r\n      if (attr == StorageAttribute.NUMERIC || attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {\r\n        let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n\r\n        if (this.isPatternGenerationNeeded(attr, pic)) {\r\n          let pattern: string = this.generatePattern(attr, pic);\r\n          if (control.validator == null)\r\n            control.setValidators(Validators.pattern(pattern));\r\n          else\r\n            control.setValidators([control.validator, Validators.pattern(pattern)]);\r\n        }\r\n        else {\r\n          if (attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {\r\n               if (control.validator == null)\r\n                  control.setValidators(Validators.maxLength(pic.getMaskLength()));\r\n               else\r\n                  control.setValidators([control.validator, Validators.maxLength(pic.getMaskLength())]);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n  */\r\n  // This can be used to implement uppercase/lower case\r\n  @HostListener('change', ['$event'])\r\n  public onChangeEvent($event){\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n    let attr: StorageAttribute = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;\r\n\r\n    switch  (attr)\r\n    {\r\n      case StorageAttribute.ALPHA:\r\n      case StorageAttribute.UNICODE:\r\n        this.formatAlphaUnicode (control);\r\n        break;\r\n      case StorageAttribute.BOOLEAN:\r\n        this.formatBoolean(control);\r\n        break;\r\n    }\r\n  }\r\n\r\n  formatDate(pic: PIC): void {\r\n     let mgDateFormatter = new MgDateFormatter();\r\n      this._task.mgInputDateFormat = mgDateFormatter.ConvertMgDateFormatToAngular(pic.getMask());\r\n  }\r\n  /**\r\n   * @ignore\r\n   */\r\n  formatAlphaUnicode(control: AbstractControl): void {\r\n    let value: string = control.value;\r\n\r\n    if (value !== null && value.length > 0) {\r\n      const newValue: string = this._task.GetRangedValue(this.magicDir.id, value);\r\n      if (newValue != null)\r\n        value = newValue;\r\n\r\n      let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n      let mask: string = pic.getMask();\r\n      let valueStr: StringBuilder = new StringBuilder();\r\n\r\n      for (let i: number = 0; i < value.length; i++) {\r\n        switch (mask.charCodeAt(i)) {\r\n          case PICInterface.PIC_U:\r\n            valueStr.Append(value.charAt(i).toUpperCase());\r\n            break;\r\n          case PICInterface.PIC_L:\r\n            valueStr.Append(value.charAt(i).toLowerCase());\r\n            break;\r\n          default:\r\n            valueStr.Append(value.charAt(i));\r\n            break;\r\n        }\r\n      }\r\n\r\n      control.setValue(valueStr.ToString());\r\n\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  formatBoolean (control: AbstractControl): void  {\r\n    let value: string = control.value;\r\n    if (value !== null && value.length > 0) {\r\n      let newValue: string = this._task.GetRangedValue (this.magicDir.id , value);\r\n      if (newValue.toUpperCase().startsWith(value.toUpperCase())) {\r\n        control.setValue(newValue);\r\n      } else {\r\n        control.setValue(value);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern from  fld's  format\r\n  /// </summary>\r\n   generatePattern (attribute: StorageAttribute, pic: PIC): string {\r\n    let pattern: string = '';\r\n\r\n    switch (attribute)\r\n    {\r\n    case StorageAttribute.NUMERIC:\r\n      pattern = this.generatePatternForNumber(pic);\r\n      break;\r\n    case StorageAttribute.ALPHA:\r\n    case StorageAttribute.UNICODE:\r\n      pattern = this.generatePatternForAlpha(pic);\r\n    break;\r\n    }\r\n\r\n    return pattern;\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern for Alpha\r\n  /// </summary>\r\n generatePatternForNumber(pic: PIC): string {\r\n    let patternStr: StringBuilder = new StringBuilder ();\r\n\r\n    patternStr.Append('^');\r\n    if (pic.isNegative())\r\n      patternStr.Append('-?');\r\n    if (pic.getWholes())\r\n      patternStr.AppendFormat('\\\\d{{0},{1}}', 0, pic.getWholes());\r\n    if (pic.getDec())\r\n      patternStr.AppendFormat('(\\\\.\\\\d{1,{0}})?', pic.getDec());\r\n    patternStr.Append('$');\r\n\r\n    return patternStr.ToString();\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n isPatternGenerationNeeded (attr : StorageAttribute, pic : PIC): boolean {\r\n\r\n   switch (attr) {\r\n     case StorageAttribute.NUMERIC:\r\n       return true;\r\n\r\n     case StorageAttribute.ALPHA:\r\n     case StorageAttribute.UNICODE:\r\n       return (pic.getMaskChars() > 0) ? true : false;\r\n   }\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern for Alpha\r\n  /// </summary>\r\n generatePatternForAlpha(pic : PIC): string {\r\n  let cnt: number = 0;\r\n  let inputAllChars: boolean = false;\r\n  let closeSet: boolean = false;\r\n  let  mask: string = pic.getMask();\r\n  let  pattern: StringBuilder = new StringBuilder();\r\n\r\n  pattern.Append('^');\r\n  for (let i: number = 0; i < mask.length;)\r\n  {\r\n    //start new subset , if mask[i] is one of these.\r\n    if (inputAllChars && (mask.charCodeAt(i) == PICInterface.PIC_N || mask.charCodeAt(i) == PICInterface.PIC_U || mask.charCodeAt(i) == PICInterface.PIC_L\r\n        || mask.charCodeAt(i) == PICInterface.PIC_X))\r\n    {\r\n      pattern.Append('(');\r\n      closeSet = true;\r\n      inputAllChars = false;\r\n    }\r\n\r\n    cnt = 0;\r\n    switch (mask.charCodeAt(i))\r\n    {\r\n      case PICInterface.PIC_U:\r\n      case PICInterface.PIC_X:\r\n      case PICInterface.PIC_L:\r\n      {\r\n        pattern.Append('.');\r\n        let inputAllCharsRef: RefParam<boolean> = new RefParam<boolean>(false);\r\n        let dirs: string =  PICInterface.PIC_U.toString();\r\n        dirs += PICInterface.PIC_L.toString();\r\n        dirs += PICInterface.PIC_X.toString();\r\n        cnt = this.getDirectiveCount(mask, i, dirs, inputAllCharsRef);\r\n        inputAllChars = inputAllCharsRef.value;\r\n        i += cnt;\r\n\r\n      }\r\n        break;\r\n      case PICInterface.PIC_N:\r\n      {\r\n        pattern.Append('\\\\d');\r\n        let inputAllCharsRef: RefParam<boolean> = new RefParam<boolean>(false);\r\n        cnt = this.getDirectiveCount(mask, i, PICInterface.PIC_L.toString(), inputAllCharsRef);\r\n        inputAllChars = inputAllCharsRef.value;\r\n        i += cnt;\r\n      }\r\n        break;\r\n\r\n      default:\r\n        pattern.Append(mask[i]);\r\n        i++;\r\n        break;\r\n    }\r\n    if (cnt > 0)\r\n      pattern.AppendFormat('{{0},{1}}', inputAllChars ? cnt : 0, cnt);\r\n    if (closeSet)\r\n      pattern.Append(')');\r\n    closeSet = false;\r\n\r\n  }\r\n   pattern.Append('$');\r\n   return pattern.ToString();\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  getDirectiveCount(mask: string, idx: number, pattern: string, changeInPattern: RefParam<boolean> ): number  {\r\n\r\n    changeInPattern.value = false;\r\n    let patternCount: number = 0;\r\n\r\n    // find max chars\r\n    while (idx < mask.length && this.IsPatternMatches(mask.charCodeAt(idx).toString(), pattern))\r\n    { patternCount++; idx++; }\r\n\r\n\r\n    if (idx < mask.length)\r\n      changeInPattern.value = true;\r\n\r\n    return patternCount;\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  IsPatternMatches(mask: string, pattern: string): boolean {\r\n\r\n    for (let i:number = 0; i < pattern.length; i++)\r\n    if (mask == pattern[i])\r\n      return true;\r\n    return false;\r\n  }\r\n}\r\n"]}
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mgformat.magic.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/directives/mgformat.magic.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, HostListener} from '@angular/core';\r\nimport {TaskMagicService} from '../../services/task.magics.service';\r\nimport {StringBuilder, RefParam} from '@magic-xpa/mscorelib';\r\nimport {PICInterface, StorageAttribute} from '@magic-xpa/utils';\r\nimport {MagicDirective} from './magic.directive';\r\nimport {AbstractControl, Validators} from '@angular/forms';\r\nimport {PIC} from '@magic-xpa/gui';\r\nimport {MgDateFormatter} from '../pipes/date.magic.pipe';\r\nimport {isUndefined} from '@magic-xpa/mscorelib';\r\n\r\n/**\r\n * Perform Magic validation on input controls which hold alphanumeric strings\r\n */\r\n@Directive({\r\n  selector: '[mgFormat]'\r\n})\r\n\r\n\r\nexport class MgformatMagicDirective {\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor(\r\n    protected magicDir: MagicDirective ,\r\n    protected _task: TaskMagicService\r\n\r\n  ) { }\r\n\r\n  ngAfterViewInit() {\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n\r\n    if(control != null && this._task.mgInputDateFormat == null) {\r\n      // get the first date control's format.\r\n      let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n      if (pic.getAttr() == StorageAttribute.DATE ) {\r\n        this.formatDate(pic);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /**\r\n   * This can be used to set pattern\r\n   * On input, verifies the input matches the required mask\r\n   */\r\n  @HostListener('focus', ['$event'])\r\n  public onFocusEvent($event){\r\n    this.calculatePattern();\r\n  }\r\n\r\n  @HostListener('input', ['$event'])\r\n  public onInputEvent($event){\r\n    this.calculatePattern();\r\n   }\r\n\r\n  /**\r\n   * @ignore\r\n  */\r\n  // This can be used to implement uppercase/lower case\r\n  @HostListener('change', ['$event'])\r\n  public onChangeEvent($event){\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n    let attr: StorageAttribute = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;\r\n\r\n    switch  (attr)\r\n    {\r\n      case StorageAttribute.ALPHA:\r\n      case StorageAttribute.UNICODE:\r\n        this.formatAlphaUnicode (control);\r\n        break;\r\n      case StorageAttribute.BOOLEAN:\r\n        this.formatBoolean(control);\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n  */\r\n  calculatePattern ()\r\n  {\r\n    let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id );\r\n\r\n    if(control != null ) {\r\n      let attr: StorageAttribute = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;\r\n      if (attr == StorageAttribute.NUMERIC || attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {\r\n        let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n\r\n        if (this.isPatternGenerationNeeded(attr, pic)) {\r\n          let pattern: string = this.generatePattern(attr, pic);\r\n          if (control.validator == null)\r\n            control.setValidators(Validators.pattern(pattern));\r\n          else\r\n            control.setValidators([control.validator, Validators.pattern(pattern)]);\r\n        }\r\n        else {\r\n          if (attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {\r\n            if (control.validator == null)\r\n              control.setValidators(Validators.maxLength(pic.getMaskLength()));\r\n            else {\r\n              // re-set all validators again\r\n              if (pic.isFormatExp()) {\r\n                control.setValidators(Validators.maxLength(pic.getMaskLength()));\r\n                if (isUndefined(this.magicDir.rowId))\r\n                  this.magicDir.rowId = '0';\r\n                control.setValidators([control.validator, this._task.customValidator(this.magicDir.rowId, this.magicDir.id)]);\r\n              }\r\n              else\r\n                control.setValidators([control.validator, Validators.maxLength(pic.getMaskLength())]);\r\n            }\r\n\r\n          //  control.setValidators(Validators.maxLength(pic.getMaskLength()));\r\n            control.updateValueAndValidity();\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  formatDate(pic: PIC): void {\r\n     let mgDateFormatter = new MgDateFormatter();\r\n      this._task.mgInputDateFormat = mgDateFormatter.ConvertMgDateFormatToAngular(pic.getMask());\r\n  }\r\n  /**\r\n   * @ignore\r\n   */\r\n  formatAlphaUnicode(control: AbstractControl): void {\r\n    let value: string = control.value;\r\n\r\n    if (value !== null && value.length > 0) {\r\n      const newValue: string = this._task.GetRangedValue(this.magicDir.id, value);\r\n      if (newValue != null)\r\n        value = newValue;\r\n\r\n      let pic: PIC = this._task.GetControlPictureMask(this.magicDir.id);\r\n      let mask: string = pic.getMask();\r\n      let valueStr: StringBuilder = new StringBuilder();\r\n\r\n      for (let i: number = 0; i < value.length; i++) {\r\n        switch (mask.charCodeAt(i)) {\r\n          case PICInterface.PIC_U:\r\n            valueStr.Append(value.charAt(i).toUpperCase());\r\n            break;\r\n          case PICInterface.PIC_L:\r\n            valueStr.Append(value.charAt(i).toLowerCase());\r\n            break;\r\n          default:\r\n            valueStr.Append(value.charAt(i));\r\n            break;\r\n        }\r\n      }\r\n\r\n      control.setValue(valueStr.ToString());\r\n\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  formatBoolean (control: AbstractControl): void  {\r\n    let value: string = control.value;\r\n    if (value !== null && value.length > 0) {\r\n      let newValue: string = this._task.GetRangedValue (this.magicDir.id , value);\r\n      if (newValue.toUpperCase().startsWith(value.toUpperCase())) {\r\n        control.setValue(newValue);\r\n      } else {\r\n        control.setValue(value);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern from  fld's  format\r\n  /// </summary>\r\n   generatePattern (attribute: StorageAttribute, pic: PIC): string {\r\n    let pattern: string = '';\r\n\r\n    switch (attribute)\r\n    {\r\n    case StorageAttribute.NUMERIC:\r\n      pattern = this.generatePatternForNumber(pic);\r\n      break;\r\n    case StorageAttribute.ALPHA:\r\n    case StorageAttribute.UNICODE:\r\n      pattern = this.generatePatternForAlpha(pic);\r\n    break;\r\n    }\r\n\r\n    return pattern;\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern for Alpha\r\n  /// </summary>\r\n generatePatternForNumber(pic: PIC): string {\r\n    let patternStr: StringBuilder = new StringBuilder ();\r\n\r\n    patternStr.Append('^');\r\n    if (pic.isNegative())\r\n      patternStr.Append('-?');\r\n    if (pic.getWholes())\r\n      patternStr.AppendFormat('\\\\d{{0},{1}}', 0, pic.getWholes());\r\n    if (pic.getDec())\r\n      patternStr.AppendFormat('(\\\\.\\\\d{1,{0}})?', pic.getDec());\r\n    patternStr.Append('$');\r\n\r\n    return patternStr.ToString();\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n isPatternGenerationNeeded (attr : StorageAttribute, pic : PIC): boolean {\r\n\r\n   switch (attr) {\r\n     case StorageAttribute.NUMERIC:\r\n       return true;\r\n\r\n     case StorageAttribute.ALPHA:\r\n     case StorageAttribute.UNICODE:\r\n       return (pic.getMaskChars() > 0) ? true : false;\r\n   }\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  /// <summary>\r\n  /// generate pattern for Alpha\r\n  /// </summary>\r\n generatePatternForAlpha(pic : PIC): string {\r\n  let cnt: number = 0;\r\n  let inputAllChars: boolean = false;\r\n  let closeSet: boolean = false;\r\n  let  mask: string = pic.getMask();\r\n  let  pattern: StringBuilder = new StringBuilder();\r\n\r\n  pattern.Append('^');\r\n  for (let i: number = 0; i < mask.length;)\r\n  {\r\n    //start new subset , if mask[i] is one of these.\r\n    if (inputAllChars && (mask.charCodeAt(i) == PICInterface.PIC_N || mask.charCodeAt(i) == PICInterface.PIC_U || mask.charCodeAt(i) == PICInterface.PIC_L\r\n        || mask.charCodeAt(i) == PICInterface.PIC_X))\r\n    {\r\n      pattern.Append('(');\r\n      closeSet = true;\r\n      inputAllChars = false;\r\n    }\r\n\r\n    cnt = 0;\r\n    switch (mask.charCodeAt(i))\r\n    {\r\n      case PICInterface.PIC_U:\r\n      case PICInterface.PIC_X:\r\n      case PICInterface.PIC_L:\r\n      {\r\n        pattern.Append('.');\r\n        let inputAllCharsRef: RefParam<boolean> = new RefParam<boolean>(false);\r\n        let dirs: string =  PICInterface.PIC_U.toString();\r\n        dirs += PICInterface.PIC_L.toString();\r\n        dirs += PICInterface.PIC_X.toString();\r\n        cnt = this.getDirectiveCount(mask, i, dirs, inputAllCharsRef);\r\n        inputAllChars = inputAllCharsRef.value;\r\n        i += cnt;\r\n\r\n      }\r\n        break;\r\n      case PICInterface.PIC_N:\r\n      {\r\n        pattern.Append('\\\\d');\r\n        let inputAllCharsRef: RefParam<boolean> = new RefParam<boolean>(false);\r\n        cnt = this.getDirectiveCount(mask, i, PICInterface.PIC_L.toString(), inputAllCharsRef);\r\n        inputAllChars = inputAllCharsRef.value;\r\n        i += cnt;\r\n      }\r\n        break;\r\n\r\n      default:\r\n        pattern.Append(mask[i]);\r\n        i++;\r\n        break;\r\n    }\r\n    if (cnt > 0)\r\n      pattern.AppendFormat('{{0},{1}}', inputAllChars ? cnt : 0, cnt);\r\n    if (closeSet)\r\n      pattern.Append(')');\r\n    closeSet = false;\r\n\r\n  }\r\n   pattern.Append('$');\r\n   return pattern.ToString();\r\n }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  getDirectiveCount(mask: string, idx: number, pattern: string, changeInPattern: RefParam<boolean> ): number  {\r\n\r\n    changeInPattern.value = false;\r\n    let patternCount: number = 0;\r\n\r\n    // find max chars\r\n    while (idx < mask.length && this.IsPatternMatches(mask.charCodeAt(idx).toString(), pattern))\r\n    { patternCount++; idx++; }\r\n\r\n\r\n    if (idx < mask.length)\r\n      changeInPattern.value = true;\r\n\r\n    return patternCount;\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  IsPatternMatches(mask: string, pattern: string): boolean {\r\n\r\n    for (let i:number = 0; i < pattern.length; i++)\r\n    if (mask == pattern[i])\r\n      return true;\r\n    return false;\r\n  }\r\n}\r\n"]}
|
@@ -93,7 +93,7 @@ MagicOverlayContainerWrapper.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlay
|
|
93
93
|
i0.ɵɵelementEnd();
|
94
94
|
i0.ɵɵelement(6, "div", 5);
|
95
95
|
i0.ɵɵelementEnd();
|
96
|
-
} }, directives: [i3.MagicFocusDirective, i4.MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;
|
96
|
+
} }, directives: [i3.MagicFocusDirective, i4.MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;z-index:999;inset:0}"] });
|
97
97
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainerWrapper, [{
|
98
98
|
type: Component,
|
99
99
|
args: [{
|
@@ -123,7 +123,7 @@ MagicOverlayContainer.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContain
|
|
123
123
|
i0.ɵɵproperty("ngIf", ctx.getShowTitleBar());
|
124
124
|
i0.ɵɵadvance(1);
|
125
125
|
i0.ɵɵproperty("ngStyle", ctx.getClientAreaStyles());
|
126
|
-
} }, directives: [i1.NgIf, i1.NgStyle, i2.MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;
|
126
|
+
} }, directives: [i1.NgIf, i1.NgStyle, i2.MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#fff}.modal-background[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header[_ngcontent-%COMP%]{background-color:beige;border-bottom:2px solid red}"] });
|
127
127
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainer, [{
|
128
128
|
type: Component,
|
129
129
|
args: [{ selector: 'app-magic-overlay-container', template: `
|
@@ -142,7 +142,7 @@ MagicOverlayContainer.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContain
|
|
142
142
|
</div>
|
143
143
|
</div>
|
144
144
|
</div>
|
145
|
-
`, styles: [".modal-foreground{position:fixed;
|
145
|
+
`, styles: [".modal-foreground{position:fixed;inset:0;background-color:#fff}.modal-background{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header{background-color:beige;border-bottom:2px solid red}\n"] }]
|
146
146
|
}], function () { return [{ type: i0.ComponentFactoryResolver }]; }, { headerElementRef: [{
|
147
147
|
type: ViewChild,
|
148
148
|
args: ['modalheader', { static: false }]
|
@@ -163,7 +163,7 @@ MagicShellComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicShellComponent,
|
|
163
163
|
i0.ɵɵproperty("ngIf", ctx.RootComponent !== null);
|
164
164
|
i0.ɵɵadvance(3);
|
165
165
|
i0.ɵɵproperty("ngIf", ctx.showSpinner);
|
166
|
-
} }, directives: [i8.NgIf, i9.DynamicComponent, i9.DynamicIoDirective, i10.MagicViewContainerRef, i8.NgTemplateOutlet], styles: [".mgSpinnerClass[_ngcontent-%COMP%]{border:10px solid #cccccc;border-top:10px solid black;border-radius:50%;position:fixed;margin:auto;
|
166
|
+
} }, directives: [i8.NgIf, i9.DynamicComponent, i9.DynamicIoDirective, i10.MagicViewContainerRef, i8.NgTemplateOutlet], styles: [".mgSpinnerClass[_ngcontent-%COMP%]{border:10px solid #cccccc;border-top:10px solid black;border-radius:50%;position:fixed;margin:auto;inset:0;width:100px;height:100px;animation:spin 2s linear infinite}.spinner-background[_ngcontent-%COMP%]{position:fixed;z-index:1000;inset:0;opacity:.5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}"] });
|
167
167
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicShellComponent, [{
|
168
168
|
type: Component,
|
169
169
|
args: [{
|
@@ -10,14 +10,14 @@ 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, MgControlType
|
13
|
+
import { MagicProperties, Logger, StrUtil, StorageAttribute, PICInterface, BindingLevel, StorageAttributeType, MgControlType } 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';
|
17
17
|
import * as i1$1 from '@angular/platform-browser';
|
18
18
|
import * as i1$2 from '@angular/common/http';
|
19
19
|
import { HttpClientModule } from '@angular/common/http';
|
20
|
-
import { NativeDateAdapter, DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
20
|
+
import { NativeDateAdapter, MAT_DATE_LOCALE, DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
21
21
|
import * as i1$3 from '@angular/cdk/platform';
|
22
22
|
|
23
23
|
class ControlMetadata {
|
@@ -993,7 +993,7 @@ MagicOverlayContainerWrapper.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlay
|
|
993
993
|
i0.ɵɵelement(6, "div", 5);
|
994
994
|
i0.ɵɵelementEnd();
|
995
995
|
}
|
996
|
-
}, directives: [MagicFocusDirective, MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;
|
996
|
+
}, directives: [MagicFocusDirective, MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;z-index:999;inset:0}"] });
|
997
997
|
(function () {
|
998
998
|
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainerWrapper, [{
|
999
999
|
type: Component,
|
@@ -1206,7 +1206,7 @@ MagicOverlayContainer.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContain
|
|
1206
1206
|
i0.ɵɵadvance(1);
|
1207
1207
|
i0.ɵɵproperty("ngStyle", ctx.getClientAreaStyles());
|
1208
1208
|
}
|
1209
|
-
}, directives: [i1.NgIf, i1.NgStyle, MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;
|
1209
|
+
}, directives: [i1.NgIf, i1.NgStyle, MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#fff}.modal-background[_ngcontent-%COMP%]{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header[_ngcontent-%COMP%]{background-color:beige;border-bottom:2px solid red}"] });
|
1210
1210
|
(function () {
|
1211
1211
|
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainer, [{
|
1212
1212
|
type: Component,
|
@@ -1226,7 +1226,7 @@ MagicOverlayContainer.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContain
|
|
1226
1226
|
</div>
|
1227
1227
|
</div>
|
1228
1228
|
</div>
|
1229
|
-
`, styles: [".modal-foreground{position:fixed;
|
1229
|
+
`, styles: [".modal-foreground{position:fixed;inset:0;background-color:#fff}.modal-background{position:fixed;inset:0;background-color:#000;opacity:.75}.modal-header{background-color:beige;border-bottom:2px solid red}\n"] }]
|
1230
1230
|
}], function () { return [{ type: i0.ComponentFactoryResolver }]; }, { headerElementRef: [{
|
1231
1231
|
type: ViewChild,
|
1232
1232
|
args: ['modalheader', { static: false }]
|
@@ -2021,7 +2021,7 @@ class TaskMagicService {
|
|
2021
2021
|
return val;
|
2022
2022
|
}
|
2023
2023
|
case StorageAttribute.NUMERIC:
|
2024
|
-
return val;
|
2024
|
+
return +val;
|
2025
2025
|
default:
|
2026
2026
|
return val;
|
2027
2027
|
}
|
@@ -2409,9 +2409,9 @@ class AccessorMagicService {
|
|
2409
2409
|
let properties;
|
2410
2410
|
properties = this.task.Records.list[0].getControlMetadata(controlId);
|
2411
2411
|
if (properties.properties.get(HtmlProperties.ReadOnly) !== null && properties.properties.get(HtmlProperties.ReadOnly) === true)
|
2412
|
-
return false;
|
2413
|
-
else
|
2414
2412
|
return true;
|
2413
|
+
else
|
2414
|
+
return false;
|
2415
2415
|
}
|
2416
2416
|
getText(controlId, rowId) {
|
2417
2417
|
return this.task.getProperty(controlId, HtmlProperties.Text, rowId);
|
@@ -2441,6 +2441,29 @@ class AccessorMagicService {
|
|
2441
2441
|
let vis = this.getProperty(controlId, HtmlProperties.Visible, rowId);
|
2442
2442
|
return vis ? 'visible' : 'hidden';
|
2443
2443
|
}
|
2444
|
+
getAlphaMask(controlId, rowId) {
|
2445
|
+
if (isNullOrUndefined(controlId))
|
2446
|
+
return null;
|
2447
|
+
let pic = this.task.GetControlPictureMask(controlId);
|
2448
|
+
let mask = pic.getMask();
|
2449
|
+
let valueStr = new StringBuilder();
|
2450
|
+
for (let i = 0; i < mask.length; i++) {
|
2451
|
+
switch (mask.charCodeAt(i)) {
|
2452
|
+
case PICInterface.PIC_N:
|
2453
|
+
valueStr.Append("0");
|
2454
|
+
break;
|
2455
|
+
case PICInterface.PIC_U:
|
2456
|
+
case PICInterface.PIC_L:
|
2457
|
+
case PICInterface.PIC_X:
|
2458
|
+
valueStr.Append("A");
|
2459
|
+
break;
|
2460
|
+
default:
|
2461
|
+
valueStr.Append(mask.charAt(i));
|
2462
|
+
break;
|
2463
|
+
}
|
2464
|
+
}
|
2465
|
+
return (pic != null) ? valueStr.toString() : null;
|
2466
|
+
}
|
2444
2467
|
getNumericPicture(picture) {
|
2445
2468
|
var obj = {};
|
2446
2469
|
if (isNullOrUndefined(picture))
|
@@ -2622,7 +2645,7 @@ class AccessorMagicService {
|
|
2622
2645
|
if (c.hasError('maxlength'))
|
2623
2646
|
return 'Max length allowed is : ' + c.errors.maxlength.requiredLength;
|
2624
2647
|
if (c.hasError('max'))
|
2625
|
-
return 'Max value
|
2648
|
+
return 'Max value allowed is : ' + c.errors.max.max;
|
2626
2649
|
let controlMetadata = this.task.Records.list[rowId].getControlMetadata(id);
|
2627
2650
|
for (let key of controlMetadata.customValidators.keys()) {
|
2628
2651
|
if (c.hasError(key)) {
|
@@ -3009,15 +3032,15 @@ class MagicDirective {
|
|
3009
3032
|
}
|
3010
3033
|
handleSetProperty(command) {
|
3011
3034
|
switch (command.Operation) {
|
3012
|
-
case HtmlProperties.ReadOnly:
|
3013
|
-
|
3014
|
-
if (command.
|
3015
|
-
|
3016
|
-
|
3017
|
-
|
3035
|
+
case HtmlProperties.ReadOnly:
|
3036
|
+
{
|
3037
|
+
if (command.obj.Type == MgControlType.CTRL_TYPE_TEXT)
|
3038
|
+
if (command.obj1 != true)
|
3039
|
+
this.renderer.removeAttribute(this.htmlElement, command.Operation);
|
3040
|
+
else
|
3041
|
+
this.renderer.setAttribute(this.htmlElement, command.Operation, command.str);
|
3018
3042
|
}
|
3019
3043
|
break;
|
3020
|
-
}
|
3021
3044
|
}
|
3022
3045
|
}
|
3023
3046
|
ngOnDestroy() {
|
@@ -3348,6 +3371,25 @@ class MgformatMagicDirective {
|
|
3348
3371
|
}
|
3349
3372
|
}
|
3350
3373
|
onFocusEvent($event) {
|
3374
|
+
this.calculatePattern();
|
3375
|
+
}
|
3376
|
+
onInputEvent($event) {
|
3377
|
+
this.calculatePattern();
|
3378
|
+
}
|
3379
|
+
onChangeEvent($event) {
|
3380
|
+
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
3381
|
+
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
3382
|
+
switch (attr) {
|
3383
|
+
case StorageAttribute.ALPHA:
|
3384
|
+
case StorageAttribute.UNICODE:
|
3385
|
+
this.formatAlphaUnicode(control);
|
3386
|
+
break;
|
3387
|
+
case StorageAttribute.BOOLEAN:
|
3388
|
+
this.formatBoolean(control);
|
3389
|
+
break;
|
3390
|
+
}
|
3391
|
+
}
|
3392
|
+
calculatePattern() {
|
3351
3393
|
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
3352
3394
|
if (control != null) {
|
3353
3395
|
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
@@ -3364,26 +3406,22 @@ class MgformatMagicDirective {
|
|
3364
3406
|
if (attr == StorageAttribute.ALPHA || attr == StorageAttribute.UNICODE) {
|
3365
3407
|
if (control.validator == null)
|
3366
3408
|
control.setValidators(Validators.maxLength(pic.getMaskLength()));
|
3367
|
-
else
|
3368
|
-
|
3409
|
+
else {
|
3410
|
+
if (pic.isFormatExp()) {
|
3411
|
+
control.setValidators(Validators.maxLength(pic.getMaskLength()));
|
3412
|
+
if (isUndefined(this.magicDir.rowId))
|
3413
|
+
this.magicDir.rowId = '0';
|
3414
|
+
control.setValidators([control.validator, this._task.customValidator(this.magicDir.rowId, this.magicDir.id)]);
|
3415
|
+
}
|
3416
|
+
else
|
3417
|
+
control.setValidators([control.validator, Validators.maxLength(pic.getMaskLength())]);
|
3418
|
+
}
|
3419
|
+
control.updateValueAndValidity();
|
3369
3420
|
}
|
3370
3421
|
}
|
3371
3422
|
}
|
3372
3423
|
}
|
3373
3424
|
}
|
3374
|
-
onChangeEvent($event) {
|
3375
|
-
let control = this._task.getFormControl(this.magicDir.rowId, this.magicDir.id);
|
3376
|
-
let attr = this._task.Records.list[0].getControlMetadata(this.magicDir.id).dataType;
|
3377
|
-
switch (attr) {
|
3378
|
-
case StorageAttribute.ALPHA:
|
3379
|
-
case StorageAttribute.UNICODE:
|
3380
|
-
this.formatAlphaUnicode(control);
|
3381
|
-
break;
|
3382
|
-
case StorageAttribute.BOOLEAN:
|
3383
|
-
this.formatBoolean(control);
|
3384
|
-
break;
|
3385
|
-
}
|
3386
|
-
}
|
3387
3425
|
formatDate(pic) {
|
3388
3426
|
let mgDateFormatter = new MgDateFormatter();
|
3389
3427
|
this._task.mgInputDateFormat = mgDateFormatter.ConvertMgDateFormatToAngular(pic.getMask());
|
@@ -3533,7 +3571,7 @@ class MgformatMagicDirective {
|
|
3533
3571
|
MgformatMagicDirective.ɵfac = function MgformatMagicDirective_Factory(t) { return new (t || MgformatMagicDirective)(i0.ɵɵdirectiveInject(MagicDirective), i0.ɵɵdirectiveInject(TaskMagicService)); };
|
3534
3572
|
MgformatMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MgformatMagicDirective, selectors: [["", "mgFormat", ""]], hostBindings: function MgformatMagicDirective_HostBindings(rf, ctx) {
|
3535
3573
|
if (rf & 1) {
|
3536
|
-
i0.ɵɵlistener("focus", function MgformatMagicDirective_focus_HostBindingHandler($event) { return ctx.onFocusEvent($event); })("change", function MgformatMagicDirective_change_HostBindingHandler($event) { return ctx.onChangeEvent($event); });
|
3574
|
+
i0.ɵɵlistener("focus", function MgformatMagicDirective_focus_HostBindingHandler($event) { return ctx.onFocusEvent($event); })("input", function MgformatMagicDirective_input_HostBindingHandler($event) { return ctx.onInputEvent($event); })("change", function MgformatMagicDirective_change_HostBindingHandler($event) { return ctx.onChangeEvent($event); });
|
3537
3575
|
}
|
3538
3576
|
} });
|
3539
3577
|
(function () {
|
@@ -3545,6 +3583,9 @@ MgformatMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: MgformatMagicDirec
|
|
3545
3583
|
}], function () { return [{ type: MagicDirective }, { type: TaskMagicService }]; }, { onFocusEvent: [{
|
3546
3584
|
type: HostListener,
|
3547
3585
|
args: ['focus', ['$event']]
|
3586
|
+
}], onInputEvent: [{
|
3587
|
+
type: HostListener,
|
3588
|
+
args: ['input', ['$event']]
|
3548
3589
|
}], onChangeEvent: [{
|
3549
3590
|
type: HostListener,
|
3550
3591
|
args: ['change', ['$event']]
|
@@ -4056,7 +4097,7 @@ MagicShellComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicShellComponent,
|
|
4056
4097
|
i0.ɵɵadvance(3);
|
4057
4098
|
i0.ɵɵproperty("ngIf", ctx.showSpinner);
|
4058
4099
|
}
|
4059
|
-
}, directives: [i1.NgIf, i3.DynamicComponent, i3.DynamicIoDirective, MagicViewContainerRef, i1.NgTemplateOutlet], styles: [".mgSpinnerClass[_ngcontent-%COMP%]{border:10px solid #cccccc;border-top:10px solid black;border-radius:50%;position:fixed;margin:auto;
|
4100
|
+
}, directives: [i1.NgIf, i3.DynamicComponent, i3.DynamicIoDirective, MagicViewContainerRef, i1.NgTemplateOutlet], styles: [".mgSpinnerClass[_ngcontent-%COMP%]{border:10px solid #cccccc;border-top:10px solid black;border-radius:50%;position:fixed;margin:auto;inset:0;width:100px;height:100px;animation:spin 2s linear infinite}.spinner-background[_ngcontent-%COMP%]{position:fixed;z-index:1000;inset:0;opacity:.5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}"] });
|
4060
4101
|
(function () {
|
4061
4102
|
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicShellComponent, [{
|
4062
4103
|
type: Component,
|
@@ -4481,11 +4522,13 @@ const MG_FORMATS = {
|
|
4481
4522
|
}
|
4482
4523
|
};
|
4483
4524
|
class MgDateAdapter extends NativeDateAdapter {
|
4484
|
-
constructor(platform, task) {
|
4485
|
-
super(
|
4525
|
+
constructor(platform, task, localeId) {
|
4526
|
+
super(localeId, platform);
|
4486
4527
|
this.platform = platform;
|
4487
4528
|
this.task = task;
|
4529
|
+
this.localeId = localeId;
|
4488
4530
|
this.mgdtfmt = null;
|
4531
|
+
this.setLocale(localeId);
|
4489
4532
|
}
|
4490
4533
|
parse(value) {
|
4491
4534
|
let valueStr = value;
|
@@ -4545,7 +4588,7 @@ class MgDateAdapter extends NativeDateAdapter {
|
|
4545
4588
|
}
|
4546
4589
|
if (month == 0 && year == 0 && date == 0)
|
4547
4590
|
return null;
|
4548
|
-
return new Date(
|
4591
|
+
return new Date(year, month, date);
|
4549
4592
|
}
|
4550
4593
|
}
|
4551
4594
|
format(date, displayFormat) {
|
@@ -4561,12 +4604,17 @@ class MgDateAdapter extends NativeDateAdapter {
|
|
4561
4604
|
}
|
4562
4605
|
}
|
4563
4606
|
}
|
4564
|
-
MgDateAdapter.ɵfac = function MgDateAdapter_Factory(t) { return new (t || MgDateAdapter)(i0.ɵɵinject(i1$3.Platform), i0.ɵɵinject(TaskMagicService)); };
|
4607
|
+
MgDateAdapter.ɵfac = function MgDateAdapter_Factory(t) { return new (t || MgDateAdapter)(i0.ɵɵinject(i1$3.Platform), i0.ɵɵinject(TaskMagicService), i0.ɵɵinject(MAT_DATE_LOCALE)); };
|
4565
4608
|
MgDateAdapter.ɵprov = i0.ɵɵdefineInjectable({ token: MgDateAdapter, factory: MgDateAdapter.ɵfac });
|
4566
4609
|
(function () {
|
4567
4610
|
(typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MgDateAdapter, [{
|
4568
4611
|
type: Injectable
|
4569
|
-
}], function () {
|
4612
|
+
}], function () {
|
4613
|
+
return [{ type: i1$3.Platform }, { type: TaskMagicService }, { type: undefined, decorators: [{
|
4614
|
+
type: Inject,
|
4615
|
+
args: [MAT_DATE_LOCALE]
|
4616
|
+
}] }];
|
4617
|
+
}, null);
|
4570
4618
|
})();
|
4571
4619
|
|
4572
4620
|
const matDateProviders = [
|