@acorex/components 6.1.0 → 6.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/alert/src/alert.component.d.ts +1 -1
  2. package/badge/src/badge.component.d.ts +1 -1
  3. package/breadcrumbs/src/breadcrumbs-item.component.d.ts +4 -4
  4. package/button/src/button-group.component.d.ts +4 -4
  5. package/button/src/button-item.component.d.ts +4 -4
  6. package/color-picker/src/color-picker.component.d.ts +18 -21
  7. package/common/public-api.d.ts +1 -0
  8. package/common/src/common.module.d.ts +4 -3
  9. package/common/src/debounce-time.directive.d.ts +17 -0
  10. package/common/src/events.class.d.ts +1 -1
  11. package/date-picker/src/datepicker.component.d.ts +12 -12
  12. package/esm2020/color-palette/src/color-palette-input.component.mjs +1 -1
  13. package/esm2020/color-picker/src/color-picker.component.mjs +3 -3
  14. package/esm2020/common/public-api.mjs +2 -1
  15. package/esm2020/common/src/auto-focus.directive.mjs +1 -1
  16. package/esm2020/common/src/common.module.mjs +6 -1
  17. package/esm2020/common/src/debounce-time.directive.mjs +47 -0
  18. package/esm2020/common/src/events.class.mjs +1 -1
  19. package/esm2020/data-pager/src/data-pager-input-selector.component.mjs +5 -4
  20. package/esm2020/date-picker/src/datepicker.component.mjs +2 -3
  21. package/esm2020/mixin/src/textbox-mixin.class.mjs +52 -83
  22. package/esm2020/number-box/src/number-box.component.mjs +3 -4
  23. package/esm2020/password-box/src/password-box.component.mjs +3 -3
  24. package/esm2020/search-box/src/search-box.component.mjs +4 -3
  25. package/esm2020/select-box/src/selectbox.component.mjs +5 -5
  26. package/esm2020/textarea/src/textarea.component.mjs +3 -3
  27. package/esm2020/textbox/public-api.mjs +2 -2
  28. package/esm2020/textbox/src/mask-options.directive.mjs +22 -0
  29. package/esm2020/textbox/src/textbox.component.mjs +44 -24
  30. package/esm2020/textbox/src/textbox.module.mjs +11 -7
  31. package/esm2020/time-box/src/time-box.component.mjs +4 -4
  32. package/fesm2015/acorex-components-color-palette.mjs +1 -1
  33. package/fesm2015/acorex-components-color-palette.mjs.map +1 -1
  34. package/fesm2015/acorex-components-color-picker.mjs +2 -2
  35. package/fesm2015/acorex-components-color-picker.mjs.map +1 -1
  36. package/fesm2015/acorex-components-common.mjs +61 -12
  37. package/fesm2015/acorex-components-common.mjs.map +1 -1
  38. package/fesm2015/acorex-components-data-pager.mjs +4 -3
  39. package/fesm2015/acorex-components-data-pager.mjs.map +1 -1
  40. package/fesm2015/acorex-components-date-picker.mjs +1 -2
  41. package/fesm2015/acorex-components-date-picker.mjs.map +1 -1
  42. package/fesm2015/acorex-components-mixin.mjs +3 -33
  43. package/fesm2015/acorex-components-mixin.mjs.map +1 -1
  44. package/fesm2015/acorex-components-number-box.mjs +2 -3
  45. package/fesm2015/acorex-components-number-box.mjs.map +1 -1
  46. package/fesm2015/acorex-components-password-box.mjs +2 -2
  47. package/fesm2015/acorex-components-password-box.mjs.map +1 -1
  48. package/fesm2015/acorex-components-search-box.mjs +3 -2
  49. package/fesm2015/acorex-components-search-box.mjs.map +1 -1
  50. package/fesm2015/acorex-components-select-box.mjs +4 -4
  51. package/fesm2015/acorex-components-select-box.mjs.map +1 -1
  52. package/fesm2015/acorex-components-textarea.mjs +2 -2
  53. package/fesm2015/acorex-components-textarea.mjs.map +1 -1
  54. package/fesm2015/acorex-components-textbox.mjs +60 -37
  55. package/fesm2015/acorex-components-textbox.mjs.map +1 -1
  56. package/fesm2015/acorex-components-time-box.mjs +3 -3
  57. package/fesm2015/acorex-components-time-box.mjs.map +1 -1
  58. package/fesm2020/acorex-components-color-palette.mjs +1 -1
  59. package/fesm2020/acorex-components-color-palette.mjs.map +1 -1
  60. package/fesm2020/acorex-components-color-picker.mjs +2 -2
  61. package/fesm2020/acorex-components-color-picker.mjs.map +1 -1
  62. package/fesm2020/acorex-components-common.mjs +60 -12
  63. package/fesm2020/acorex-components-common.mjs.map +1 -1
  64. package/fesm2020/acorex-components-data-pager.mjs +4 -3
  65. package/fesm2020/acorex-components-data-pager.mjs.map +1 -1
  66. package/fesm2020/acorex-components-date-picker.mjs +1 -2
  67. package/fesm2020/acorex-components-date-picker.mjs.map +1 -1
  68. package/fesm2020/acorex-components-mixin.mjs +51 -81
  69. package/fesm2020/acorex-components-mixin.mjs.map +1 -1
  70. package/fesm2020/acorex-components-number-box.mjs +2 -3
  71. package/fesm2020/acorex-components-number-box.mjs.map +1 -1
  72. package/fesm2020/acorex-components-password-box.mjs +2 -2
  73. package/fesm2020/acorex-components-password-box.mjs.map +1 -1
  74. package/fesm2020/acorex-components-search-box.mjs +3 -2
  75. package/fesm2020/acorex-components-search-box.mjs.map +1 -1
  76. package/fesm2020/acorex-components-select-box.mjs +4 -4
  77. package/fesm2020/acorex-components-select-box.mjs.map +1 -1
  78. package/fesm2020/acorex-components-textarea.mjs +2 -2
  79. package/fesm2020/acorex-components-textarea.mjs.map +1 -1
  80. package/fesm2020/acorex-components-textbox.mjs +59 -37
  81. package/fesm2020/acorex-components-textbox.mjs.map +1 -1
  82. package/fesm2020/acorex-components-time-box.mjs +3 -3
  83. package/fesm2020/acorex-components-time-box.mjs.map +1 -1
  84. package/mixin/src/base-components.class.d.ts +1 -1
  85. package/mixin/src/base-menu-mixin.class.d.ts +4 -4
  86. package/mixin/src/button-mixin.class.d.ts +1 -1
  87. package/mixin/src/clickable-mixin.class.d.ts +1 -1
  88. package/mixin/src/color-look-mixing.class.d.ts +1 -1
  89. package/mixin/src/datalist-component.class.d.ts +9 -9
  90. package/mixin/src/dropdown-mixin.class.d.ts +1 -1
  91. package/mixin/src/interactive-mixin.class.d.ts +3 -3
  92. package/mixin/src/loading-mixin.class.d.ts +1 -1
  93. package/mixin/src/mixin.class.d.ts +42 -47
  94. package/mixin/src/page-component.class.d.ts +1 -1
  95. package/mixin/src/selection-component.class.d.ts +1 -1
  96. package/mixin/src/sizable-mixin.class.d.ts +1 -1
  97. package/mixin/src/textbox-mixin.class.d.ts +4 -13
  98. package/mixin/src/value-mixin.class.d.ts +7 -7
  99. package/number-box/src/number-box.component.d.ts +1 -1
  100. package/package.json +1 -9
  101. package/password-box/src/password-box.component.d.ts +1 -1
  102. package/select-box/src/selectbox.component.d.ts +1 -1
  103. package/tabs/src/tab-item.component.d.ts +1 -1
  104. package/textarea/src/textarea.component.d.ts +1 -1
  105. package/textbox/public-api.d.ts +1 -1
  106. package/textbox/src/mask-options.directive.d.ts +13 -0
  107. package/textbox/src/textbox.component.d.ts +12 -6
  108. package/textbox/src/textbox.module.d.ts +6 -5
  109. package/time-box/src/time-box.component.d.ts +2 -2
  110. package/esm2020/input-mask/acorex-components-input-mask.mjs +0 -5
  111. package/esm2020/input-mask/public-api.mjs +0 -3
  112. package/esm2020/input-mask/src/input-mask.component.mjs +0 -58
  113. package/esm2020/input-mask/src/input-mask.module.mjs +0 -24
  114. package/esm2020/textbox/src/mask-settings.directive.mjs +0 -23
  115. package/fesm2015/acorex-components-input-mask.mjs +0 -86
  116. package/fesm2015/acorex-components-input-mask.mjs.map +0 -1
  117. package/fesm2020/acorex-components-input-mask.mjs +0 -86
  118. package/fesm2020/acorex-components-input-mask.mjs.map +0 -1
  119. package/input-mask/index.d.ts +0 -5
  120. package/input-mask/public-api.d.ts +0 -2
  121. package/input-mask/src/input-mask.component.d.ts +0 -25
  122. package/input-mask/src/input-mask.module.d.ts +0 -10
  123. package/textbox/src/mask-settings.directive.d.ts +0 -8
@@ -1,7 +1,7 @@
1
- import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, ContentChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, ContentChild, Input } from '@angular/core';
2
2
  import { AXComponent, AXFocusableComponent } from '@acorex/components/common';
3
3
  import { AXBaseTextBoxMixin } from '@acorex/components/mixin';
4
- import { AXMaskSettingsDirective } from './mask-settings.directive';
4
+ import { AXMaskOptionsDirective } from './mask-options.directive';
5
5
  import IMask from 'imask';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/forms";
@@ -11,58 +11,78 @@ import * as i1 from "@angular/forms";
11
11
  * @category Components
12
12
  */
13
13
  export class AXTextBoxComponent extends AXBaseTextBoxMixin {
14
+ /**
15
+ * @ignore
16
+ */
14
17
  constructor(elementRef, cdr) {
15
18
  super(elementRef, cdr);
19
+ this._updateOn = 'change';
20
+ this._maskOptions = { unmask: false };
16
21
  }
17
- ngAfterViewInit() {
18
- if (this.maskSettings) {
22
+ get maskOptions() {
23
+ return this._maskOptions;
24
+ }
25
+ set maskOptions(v) {
26
+ this._maskOptions = v;
27
+ }
28
+ onInit() {
29
+ if (this._maskOptionsContent) {
30
+ Object.assign(this.maskOptions, this, this._maskOptionsContent);
31
+ }
32
+ //
33
+ if (this.maskOptions.mask) {
19
34
  this._maskObj = IMask(this.input.nativeElement, {
20
- mask: this.maskSettings.mask,
21
- overwrite: true,
22
- autofix: true,
23
- eager: true
35
+ mask: this.maskOptions.mask,
24
36
  });
37
+ this._updateOn = 'submit';
38
+ this._maskObj.on("accept", this._onComplete.bind(this));
39
+ this._maskObj.on("complete", this._onComplete.bind(this));
40
+ if (this.value) {
41
+ this._maskObj.value = `${this.value}`;
42
+ this._maskObj.updateValue();
43
+ }
25
44
  }
26
45
  }
27
46
  focus() {
28
47
  this.input.nativeElement.focus();
29
48
  }
49
+ _onComplete(e) {
50
+ this.value = this._maskObj.value;
51
+ if (typeof this.maskOptions.updateValue === 'function') {
52
+ this.maskOptions?.updateValue(this._maskObj.value, this._maskObj.unmaskedValue);
53
+ }
54
+ }
30
55
  }
31
56
  AXTextBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
32
- AXTextBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXTextBoxComponent, selector: "ax-text-box", inputs: { disabled: "disabled", tabIndex: "tabIndex", readonly: "readonly", allowNull: "allowNull", value: "value", name: "name", checked: "checked", placeholder: "placeholder", maxLength: "maxLength", debounceTime: "debounceTime", type: "type", autoComplete: "autoComplete" }, outputs: { onBlur: "onBlur", onFocus: "onFocus", valueChange: "valueChange", onValueChanged: "onValueChanged" }, host: { classAttribute: "ax-editor-container" }, providers: [
57
+ AXTextBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXTextBoxComponent, selector: "ax-text-box", inputs: { disabled: "disabled", tabIndex: "tabIndex", readonly: "readonly", value: "value", name: "name", placeholder: "placeholder", maxLength: "maxLength", allowNull: "allowNull", type: "type", autoComplete: "autoComplete", maskOptions: ["mask-options", "maskOptions"] }, outputs: { onBlur: "onBlur", onFocus: "onFocus", valueChange: "valueChange", onValueChanged: "onValueChanged" }, host: { classAttribute: "ax-editor-container" }, providers: [
33
58
  { provide: AXComponent, useExisting: AXTextBoxComponent },
34
59
  { provide: AXFocusableComponent, useExisting: AXTextBoxComponent },
35
- ], queries: [{ propertyName: "maskSettings", first: true, predicate: AXMaskSettingsDirective, descendants: true }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" [attr.name]=\"name\" [attr.autocomplete]=\"autoComplete\" [attr.type]=\"type\" [attr.placeholder]=\"placeholder\" [attr.maxlength]=\"maxLength\"\r\n [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\" [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" [tabindex]=\"tabIndex\"\r\n [ngModel]=\"value\" (ngModelChange)=\"_handleModleChange($event)\"\r\n >\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-input-mask\">\r\n</ng-content>\r\n<!-- (keydown)=\"_emitOnKeydownEvent($event)\" \r\n(keyup)=\"_emitOnKeyupEvent($event)\"\r\n(keypress)=\"_emitOnKeypressEvent($event)\"\r\n(focus)=\"_emitOnFocusEvent($event)\"\r\n(blur)=\"_emitOnBlurEvent($event)\" -->", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
60
+ ], queries: [{ propertyName: "_maskOptionsContent", first: true, predicate: AXMaskOptionsDirective, descendants: true, static: true }], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n [attr.name]=\"name\" \r\n [attr.autocomplete]=\"autoComplete\"\r\n [attr.type]=\"type\"\r\n [attr.placeholder]=\"placeholder\" \r\n [attr.maxlength]=\"maxLength\" \r\n [class.ax-state-disabled]=\"disabled\"\r\n [class.ax-state-readonly]=\"readonly\" \r\n [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\"\r\n [ngModel]=\"value\" \r\n (ngModelChange)=\"value = $event\"\r\n [ngModelOptions]=\"{ updateOn:_updateOn }\" \r\n (keydown)=\"_emitOnKeydownEvent($event)\"\r\n (keyup)=\"_emitOnKeyupEvent($event)\" \r\n (keypress)=\"_emitOnKeypressEvent($event)\" \r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
36
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxComponent, decorators: [{
37
62
  type: Component,
38
63
  args: [{ selector: 'ax-text-box', inputs: [
39
64
  'disabled',
40
65
  'tabIndex',
41
66
  'readonly',
42
- 'allowNull',
43
67
  'value',
44
68
  'name',
45
- 'checked',
46
69
  'placeholder',
47
70
  'maxLength',
48
71
  'allowNull',
49
- 'debounceTime',
50
72
  'type',
51
- 'autoComplete',
52
- 'readonly',
53
- 'allowNull',
54
- 'value',
55
- 'name',
56
- 'checked',
73
+ 'autoComplete'
57
74
  ], outputs: ['onBlur', 'onFocus', 'valueChange', 'onValueChanged'], host: { class: 'ax-editor-container' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
58
75
  { provide: AXComponent, useExisting: AXTextBoxComponent },
59
76
  { provide: AXFocusableComponent, useExisting: AXTextBoxComponent },
60
- ], template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" [attr.name]=\"name\" [attr.autocomplete]=\"autoComplete\" [attr.type]=\"type\" [attr.placeholder]=\"placeholder\" [attr.maxlength]=\"maxLength\"\r\n [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\" [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" [tabindex]=\"tabIndex\"\r\n [ngModel]=\"value\" (ngModelChange)=\"_handleModleChange($event)\"\r\n >\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-input-mask\">\r\n</ng-content>\r\n<!-- (keydown)=\"_emitOnKeydownEvent($event)\" \r\n(keyup)=\"_emitOnKeyupEvent($event)\"\r\n(keypress)=\"_emitOnKeypressEvent($event)\"\r\n(focus)=\"_emitOnFocusEvent($event)\"\r\n(blur)=\"_emitOnBlurEvent($event)\" -->" }]
77
+ ], template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n [attr.name]=\"name\" \r\n [attr.autocomplete]=\"autoComplete\"\r\n [attr.type]=\"type\"\r\n [attr.placeholder]=\"placeholder\" \r\n [attr.maxlength]=\"maxLength\" \r\n [class.ax-state-disabled]=\"disabled\"\r\n [class.ax-state-readonly]=\"readonly\" \r\n [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\"\r\n [ngModel]=\"value\" \r\n (ngModelChange)=\"value = $event\"\r\n [ngModelOptions]=\"{ updateOn:_updateOn }\" \r\n (keydown)=\"_emitOnKeydownEvent($event)\"\r\n (keyup)=\"_emitOnKeyupEvent($event)\" \r\n (keypress)=\"_emitOnKeypressEvent($event)\" \r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>" }]
61
78
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { input: [{
62
79
  type: ViewChild,
63
- args: ['input']
64
- }], maskSettings: [{
80
+ args: ['input', { static: true }]
81
+ }], maskOptions: [{
82
+ type: Input,
83
+ args: ["mask-options"]
84
+ }], _maskOptionsContent: [{
65
85
  type: ContentChild,
66
- args: [AXMaskSettingsDirective]
86
+ args: [AXMaskOptionsDirective, { static: true }]
67
87
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGJveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy90ZXh0Ym94L3NyYy90ZXh0Ym94LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL3RleHRib3gvc3JjL3RleHRib3guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUV2QixTQUFTLEVBRVQsU0FBUyxFQUNULGlCQUFpQixFQUNqQixZQUFZLEVBQ2IsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzlFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BFLE9BQU8sS0FBMkIsTUFBTSxPQUFPLENBQUM7OztBQUVoRDs7OztHQUlHO0FBaUNILE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxrQkFBa0I7SUFleEQsWUFBWSxVQUFzQixFQUFFLEdBQXNCO1FBQ3hELEtBQUssQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLEVBQUU7Z0JBQzlDLElBQUksRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUk7Z0JBQzVCLFNBQVMsRUFBQyxJQUFJO2dCQUNkLE9BQU8sRUFBQyxJQUFJO2dCQUNaLEtBQUssRUFBQyxJQUFJO2FBQ1gsQ0FBQyxDQUFBO1NBQ0g7SUFDSCxDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ25DLENBQUM7OytHQWhDVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw4ZEFMbEI7UUFDVCxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFO1FBQ3pELEVBQUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLFdBQVcsRUFBRSxrQkFBa0IsRUFBRTtLQUNuRSxvRUFjYSx1QkFBdUIsdUtDL0R2Qyw4MkJBaUJxQzsyRkRrQ3hCLGtCQUFrQjtrQkFoQzlCLFNBQVM7K0JBQ0UsYUFBYSxVQUVmO3dCQUNOLFVBQVU7d0JBQ1YsVUFBVTt3QkFDVixVQUFVO3dCQUNWLFdBQVc7d0JBQ1gsT0FBTzt3QkFDUCxNQUFNO3dCQUNOLFNBQVM7d0JBQ1QsYUFBYTt3QkFDYixXQUFXO3dCQUNYLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxNQUFNO3dCQUNOLGNBQWM7d0JBQ2QsVUFBVTt3QkFDVixXQUFXO3dCQUNYLE9BQU87d0JBQ1AsTUFBTTt3QkFDTixTQUFTO3FCQUNWLFdBQ1EsQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLGFBQWEsRUFBRSxnQkFBZ0IsQ0FBQyxRQUN6RCxFQUFFLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxpQkFDdkIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDVCxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsV0FBVyxvQkFBb0IsRUFBRTt3QkFDekQsRUFBRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxvQkFBb0IsRUFBRTtxQkFDbkU7aUlBUU8sS0FBSztzQkFEWixTQUFTO3VCQUFDLE9BQU87Z0JBUVYsWUFBWTtzQkFEbkIsWUFBWTt1QkFBQyx1QkFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBFbGVtZW50UmVmLFxyXG4gIFZpZXdDaGlsZCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICBDb250ZW50Q2hpbGRcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVhDb21wb25lbnQsIEFYRm9jdXNhYmxlQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XHJcbmltcG9ydCB7IEFYQmFzZVRleHRCb3hNaXhpbiB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9taXhpbic7XHJcbmltcG9ydCB7IEFYTWFza1NldHRpbmdzRGlyZWN0aXZlIH0gZnJvbSAnLi9tYXNrLXNldHRpbmdzLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCBJTWFzaywgeyBBbnlNYXNrZWRPcHRpb25zIH0gZnJvbSAnaW1hc2snO1xyXG5cclxuLyoqXHJcbiAqIFRoZSBUZXh0Ym94IGlzIGEgY29tcG9uZW50IHdoaWNoIGRldGVjdHMgdXNlciBpbnRlcmFjdGlvbiBhbmQgdHJpZ2dlcnMgYSBjb3JyZXNwb25kaW5nIGV2ZW50XHJcbiAqXHJcbiAqIEBjYXRlZ29yeSBDb21wb25lbnRzXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F4LXRleHQtYm94JyxcclxuICB0ZW1wbGF0ZVVybDogJ3RleHRib3guY29tcG9uZW50Lmh0bWwnLFxyXG4gIGlucHV0czogW1xyXG4gICAgJ2Rpc2FibGVkJyxcclxuICAgICd0YWJJbmRleCcsXHJcbiAgICAncmVhZG9ubHknLFxyXG4gICAgJ2FsbG93TnVsbCcsXHJcbiAgICAndmFsdWUnLFxyXG4gICAgJ25hbWUnLFxyXG4gICAgJ2NoZWNrZWQnLFxyXG4gICAgJ3BsYWNlaG9sZGVyJyxcclxuICAgICdtYXhMZW5ndGgnLFxyXG4gICAgJ2FsbG93TnVsbCcsXHJcbiAgICAnZGVib3VuY2VUaW1lJyxcclxuICAgICd0eXBlJyxcclxuICAgICdhdXRvQ29tcGxldGUnLFxyXG4gICAgJ3JlYWRvbmx5JyxcclxuICAgICdhbGxvd051bGwnLFxyXG4gICAgJ3ZhbHVlJyxcclxuICAgICduYW1lJyxcclxuICAgICdjaGVja2VkJyxcclxuICBdLFxyXG4gIG91dHB1dHM6IFsnb25CbHVyJywgJ29uRm9jdXMnLCAndmFsdWVDaGFuZ2UnLCAnb25WYWx1ZUNoYW5nZWQnXSxcclxuICBob3N0OiB7IGNsYXNzOiAnYXgtZWRpdG9yLWNvbnRhaW5lcicgfSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAgeyBwcm92aWRlOiBBWENvbXBvbmVudCwgdXNlRXhpc3Rpbmc6IEFYVGV4dEJveENvbXBvbmVudCB9LFxyXG4gICAgeyBwcm92aWRlOiBBWEZvY3VzYWJsZUNvbXBvbmVudCwgdXNlRXhpc3Rpbmc6IEFYVGV4dEJveENvbXBvbmVudCB9LFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFRleHRCb3hDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VUZXh0Qm94TWl4aW4ge1xyXG4gIC8qKlxyXG4gICAqICBAaWdub3JlXHJcbiAgICovXHJcblxyXG4gIEBWaWV3Q2hpbGQoJ2lucHV0JylcclxuICBwcml2YXRlIGlucHV0OiBFbGVtZW50UmVmPEhUTUxJbnB1dEVsZW1lbnQ+O1xyXG5cclxuXHJcbiAgcHJpdmF0ZSBfbWFza09iajogSU1hc2suSW5wdXRNYXNrPEFueU1hc2tlZE9wdGlvbnM+XHJcblxyXG5cclxuICBAQ29udGVudENoaWxkKEFYTWFza1NldHRpbmdzRGlyZWN0aXZlKVxyXG4gIHByaXZhdGUgbWFza1NldHRpbmdzOiBBWE1hc2tTZXR0aW5nc0RpcmVjdGl2ZTtcclxuXHJcbiAgY29uc3RydWN0b3IoZWxlbWVudFJlZjogRWxlbWVudFJlZiwgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgc3VwZXIoZWxlbWVudFJlZiwgY2RyKTtcclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLm1hc2tTZXR0aW5ncykge1xyXG4gICAgICB0aGlzLl9tYXNrT2JqID0gSU1hc2sodGhpcy5pbnB1dC5uYXRpdmVFbGVtZW50LCB7XHJcbiAgICAgICAgbWFzazogdGhpcy5tYXNrU2V0dGluZ3MubWFzayxcclxuICAgICAgICBvdmVyd3JpdGU6dHJ1ZSxcclxuICAgICAgICBhdXRvZml4OnRydWUsXHJcbiAgICAgICAgZWFnZXI6dHJ1ZVxyXG4gICAgICB9KVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZm9jdXMoKTogdm9pZCB7XHJcbiAgICB0aGlzLmlucHV0Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcclxuICB9XHJcbn1cclxuIiwiPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtcHJlZml4XCI+XHJcbjwvbmctY29udGVudD5cclxuPGlucHV0ICNpbnB1dCBjbGFzcz1cImF4LWlucHV0XCIgW2F0dHIubmFtZV09XCJuYW1lXCIgW2F0dHIuYXV0b2NvbXBsZXRlXT1cImF1dG9Db21wbGV0ZVwiIFthdHRyLnR5cGVdPVwidHlwZVwiIFthdHRyLnBsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCIgW2F0dHIubWF4bGVuZ3RoXT1cIm1heExlbmd0aFwiXHJcbiAgICBbY2xhc3MuYXgtc3RhdGUtZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiBbY2xhc3MuYXgtc3RhdGUtcmVhZG9ubHldPVwicmVhZG9ubHlcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiBcclxuICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiIFt0YWJpbmRleF09XCJ0YWJJbmRleFwiXHJcbiAgICBbbmdNb2RlbF09XCJ2YWx1ZVwiIChuZ01vZGVsQ2hhbmdlKT1cIl9oYW5kbGVNb2RsZUNoYW5nZSgkZXZlbnQpXCJcclxuICAgPlxyXG48bmctY29udGVudCBzZWxlY3Q9XCJheC1zdWZmaXhcIj5cclxuPC9uZy1jb250ZW50PlxyXG48bmctY29udGVudCBzZWxlY3Q9XCJheC12YWxpZGF0aW9uLXJ1bGVcIj5cclxuPC9uZy1jb250ZW50PlxyXG48bmctY29udGVudCBzZWxlY3Q9XCJheC1pbnB1dC1tYXNrXCI+XHJcbjwvbmctY29udGVudD5cclxuPCEtLSAoa2V5ZG93bik9XCJfZW1pdE9uS2V5ZG93bkV2ZW50KCRldmVudClcIiBcclxuKGtleXVwKT1cIl9lbWl0T25LZXl1cEV2ZW50KCRldmVudClcIlxyXG4oa2V5cHJlc3MpPVwiX2VtaXRPbktleXByZXNzRXZlbnQoJGV2ZW50KVwiXHJcbihmb2N1cyk9XCJfZW1pdE9uRm9jdXNFdmVudCgkZXZlbnQpXCJcclxuKGJsdXIpPVwiX2VtaXRPbkJsdXJFdmVudCgkZXZlbnQpXCIgLS0+Il19
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textbox.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/textbox/src/textbox.component.ts","../../../../../../projects/acorex/components/textbox/src/textbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n  ContentChild,\r\n  Input\r\n} from '@angular/core';\r\nimport { AXComponent, AXFocusableComponent } from '@acorex/components/common';\r\nimport { AXBaseTextBoxMixin } from '@acorex/components/mixin';\r\nimport { AXMaskOptions, AXMaskOptionsDirective } from './mask-options.directive';\r\nimport IMask, { AnyMaskedOptions } from 'imask';\r\n\r\n/**\r\n * The Textbox is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-text-box',\r\n  templateUrl: 'textbox.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'tabIndex',\r\n    'readonly',\r\n    'value',\r\n    'name',\r\n    'placeholder',\r\n    'maxLength',\r\n    'allowNull',\r\n    'type',\r\n    'autoComplete'\r\n  ],\r\n  outputs: ['onBlur', 'onFocus', 'valueChange', 'onValueChanged'],\r\n  host: { class: 'ax-editor-container' },\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    { provide: AXComponent, useExisting: AXTextBoxComponent },\r\n    { provide: AXFocusableComponent, useExisting: AXTextBoxComponent },\r\n  ],\r\n})\r\nexport class AXTextBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n  protected _updateOn: 'change' | 'blur' | 'submit' = 'change';\r\n\r\n  @ViewChild('input', { static: true })\r\n  private input: ElementRef<HTMLInputElement>;\r\n\r\n\r\n  private _maskObj: IMask.InputMask<AnyMaskedOptions>\r\n\r\n\r\n  private _maskOptions: AXMaskOptions = { unmask: false };\r\n  @Input(\"mask-options\")\r\n  public get maskOptions(): AXMaskOptions {\r\n    return this._maskOptions;\r\n  }\r\n\r\n  public set maskOptions(v: AXMaskOptions) {\r\n    this._maskOptions = v;\r\n  }\r\n\r\n  @ContentChild(AXMaskOptionsDirective, { static: true })\r\n  protected _maskOptionsContent: AXMaskOptionsDirective;\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  constructor(elementRef: ElementRef, cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onInit() {\r\n    if (this._maskOptionsContent) {\r\n      Object.assign(this.maskOptions, this, this._maskOptionsContent);\r\n    }\r\n    //\r\n    if (this.maskOptions.mask) {\r\n      this._maskObj = IMask(this.input.nativeElement, {\r\n        mask: this.maskOptions.mask as string,\r\n      });\r\n      this._updateOn = 'submit';\r\n      this._maskObj.on(\"accept\", this._onComplete.bind(this));\r\n      this._maskObj.on(\"complete\", this._onComplete.bind(this));\r\n      if (this.value) {\r\n        this._maskObj.value = `${this.value}`;\r\n        this._maskObj.updateValue();\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  focus(): void {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  private _onComplete(e) {\r\n    this.value = this._maskObj.value;\r\n    if (typeof this.maskOptions.updateValue === 'function') {\r\n      this.maskOptions?.updateValue(this._maskObj.value, this._maskObj.unmaskedValue);\r\n    }\r\n  }\r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n    [attr.name]=\"name\" \r\n    [attr.autocomplete]=\"autoComplete\"\r\n    [attr.type]=\"type\"\r\n    [attr.placeholder]=\"placeholder\" \r\n    [attr.maxlength]=\"maxLength\" \r\n    [class.ax-state-disabled]=\"disabled\"\r\n    [class.ax-state-readonly]=\"readonly\" \r\n    [disabled]=\"disabled\" \r\n    [readonly]=\"readonly\" \r\n    [tabindex]=\"tabIndex\"\r\n    [ngModel]=\"value\" \r\n    (ngModelChange)=\"value = $event\"\r\n    [ngModelOptions]=\"{ updateOn:_updateOn }\" \r\n    (keydown)=\"_emitOnKeydownEvent($event)\"\r\n    (keyup)=\"_emitOnKeyupEvent($event)\" \r\n    (keypress)=\"_emitOnKeypressEvent($event)\" \r\n    (focus)=\"_emitOnFocusEvent($event)\"\r\n    (blur)=\"_emitOnBlurEvent($event)\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
@@ -1,19 +1,22 @@
1
1
  import { AXButtonModule } from '@acorex/components/button';
2
+ import { AXCommonModule } from '@acorex/components/common';
2
3
  import { AXDecoratorModule } from '@acorex/components/decorators';
3
4
  import { CommonModule } from '@angular/common';
4
5
  import { NgModule } from '@angular/core';
5
6
  import { FormsModule } from '@angular/forms';
6
- import { AXMaskSettingsDirective } from './mask-settings.directive';
7
+ import { AXMaskOptionsDirective } from './mask-options.directive';
7
8
  import { AXTextBoxComponent } from './textbox.component';
8
9
  import * as i0 from "@angular/core";
9
10
  export class AXTextBoxModule {
10
11
  }
11
12
  AXTextBoxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
- AXTextBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxModule, declarations: [AXTextBoxComponent, AXMaskSettingsDirective], imports: [CommonModule,
13
+ AXTextBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxModule, declarations: [AXTextBoxComponent, AXMaskOptionsDirective], imports: [CommonModule,
14
+ AXCommonModule,
13
15
  FormsModule,
14
16
  AXButtonModule,
15
- AXDecoratorModule], exports: [AXTextBoxComponent, AXMaskSettingsDirective] });
17
+ AXDecoratorModule], exports: [AXTextBoxComponent, AXMaskOptionsDirective] });
16
18
  AXTextBoxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTextBoxModule, imports: [CommonModule,
19
+ AXCommonModule,
17
20
  FormsModule,
18
21
  AXButtonModule,
19
22
  AXDecoratorModule] });
@@ -22,13 +25,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
22
25
  args: [{
23
26
  imports: [
24
27
  CommonModule,
28
+ AXCommonModule,
25
29
  FormsModule,
26
30
  AXButtonModule,
27
- AXDecoratorModule,
31
+ AXDecoratorModule
28
32
  ],
29
- exports: [AXTextBoxComponent, AXMaskSettingsDirective],
30
- declarations: [AXTextBoxComponent, AXMaskSettingsDirective],
33
+ exports: [AXTextBoxComponent, AXMaskOptionsDirective],
34
+ declarations: [AXTextBoxComponent, AXMaskOptionsDirective],
31
35
  providers: [],
32
36
  }]
33
37
  }] });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGJveC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy90ZXh0Ym94L3NyYy90ZXh0Ym94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQWV6RCxNQUFNLE9BQU8sZUFBZTs7NEdBQWYsZUFBZTs2R0FBZixlQUFlLGlCQUhULGtCQUFrQixFQUFFLHVCQUF1QixhQVB0RCxZQUFZO1FBQ1osV0FBVztRQUNYLGNBQWM7UUFDZCxpQkFBaUIsYUFHWCxrQkFBa0IsRUFBRSx1QkFBdUI7NkdBSTVDLGVBQWUsWUFWcEIsWUFBWTtRQUNaLFdBQVc7UUFDWCxjQUFjO1FBQ2QsaUJBQWlCOzJGQU9aLGVBQWU7a0JBWjNCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxjQUFjO3dCQUNkLGlCQUFpQjtxQkFFcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsdUJBQXVCLENBQUM7b0JBQ3RELFlBQVksRUFBRSxDQUFDLGtCQUFrQixFQUFFLHVCQUF1QixDQUFDO29CQUMzRCxTQUFTLEVBQUUsRUFBRTtpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9idXR0b24nO1xyXG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEFYTWFza1NldHRpbmdzRGlyZWN0aXZlIH0gZnJvbSAnLi9tYXNrLXNldHRpbmdzLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEFYVGV4dEJveENvbXBvbmVudCB9IGZyb20gJy4vdGV4dGJveC5jb21wb25lbnQnO1xyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEFYQnV0dG9uTW9kdWxlLFxyXG4gICAgICAgIEFYRGVjb3JhdG9yTW9kdWxlLFxyXG5cclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbQVhUZXh0Qm94Q29tcG9uZW50LCBBWE1hc2tTZXR0aW5nc0RpcmVjdGl2ZV0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtBWFRleHRCb3hDb21wb25lbnQsIEFYTWFza1NldHRpbmdzRGlyZWN0aXZlXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFRleHRCb3hNb2R1bGUgeyB9XHJcbiJdfQ==
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGJveC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy90ZXh0Ym94L3NyYy90ZXh0Ym94Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFlekQsTUFBTSxPQUFPLGVBQWU7OzRHQUFmLGVBQWU7NkdBQWYsZUFBZSxpQkFIVCxrQkFBa0IsRUFBRSxzQkFBc0IsYUFQckQsWUFBWTtRQUNaLGNBQWM7UUFDZCxXQUFXO1FBQ1gsY0FBYztRQUNkLGlCQUFpQixhQUVYLGtCQUFrQixFQUFFLHNCQUFzQjs2R0FJM0MsZUFBZSxZQVZwQixZQUFZO1FBQ1osY0FBYztRQUNkLFdBQVc7UUFDWCxjQUFjO1FBQ2QsaUJBQWlCOzJGQU1aLGVBQWU7a0JBWjNCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxXQUFXO3dCQUNYLGNBQWM7d0JBQ2QsaUJBQWlCO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxzQkFBc0IsQ0FBQztvQkFDckQsWUFBWSxFQUFFLENBQUMsa0JBQWtCLEVBQUUsc0JBQXNCLENBQUM7b0JBQzFELFNBQVMsRUFBRSxFQUFFO2lCQUNoQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYQnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2J1dHRvbic7XHJcbmltcG9ydCB7IEFYQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XHJcbmltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQVhNYXNrT3B0aW9uc0RpcmVjdGl2ZSB9IGZyb20gJy4vbWFzay1vcHRpb25zLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEFYVGV4dEJveENvbXBvbmVudCB9IGZyb20gJy4vdGV4dGJveC5jb21wb25lbnQnO1xyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEFYQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEFYQnV0dG9uTW9kdWxlLFxyXG4gICAgICAgIEFYRGVjb3JhdG9yTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW0FYVGV4dEJveENvbXBvbmVudCwgQVhNYXNrT3B0aW9uc0RpcmVjdGl2ZV0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtBWFRleHRCb3hDb21wb25lbnQsIEFYTWFza09wdGlvbnNEaXJlY3RpdmVdLFxyXG4gICAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYVGV4dEJveE1vZHVsZSB7IH1cclxuIl19
@@ -254,7 +254,7 @@ export class AXTimeBoxComponent extends AXBaseTextBoxMixin {
254
254
  }
255
255
  }
256
256
  AXTimeBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTimeBoxComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
257
- AXTimeBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXTimeBoxComponent, selector: "ax-time-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", size: "size", value: "value", placeholder: "placeholder", maxLength: "maxLength", allowNull: "allowNull", debounceTime: "debounceTime", type: "type", autoComplete: "autoComplete", name: "name", checked: "checked", minValue: "minValue", maxValue: "maxValue", format: "format", displayText: "displayText" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", formatChange: "formatChange", displayTextChange: "displayTextChange" }, host: { classAttribute: "ax-editor-container ax-drop-down" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "_maskDirective", first: true, predicate: IMaskDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" [imask]=\"_maskObj\" [unmask]=\"false\" type=\"text\" [attr.placeholder]=\"placeholder\"\r\n [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\" [disabled]=\"disabled\"\r\n [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\" \r\n (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\"\r\n (keyup)=\"_handleKeyUpEvent($event)\" \r\n (keydown)=\"_handleOnKeydownEvent($event)\" \r\n autocomplete=\"off\">\r\n\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IMaskDirective, selector: "[imask]", inputs: ["imask", "unmask", "imaskElement"], outputs: ["accept", "complete"], exportAs: ["imask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
257
+ AXTimeBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXTimeBoxComponent, selector: "ax-time-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", size: "size", value: "value", placeholder: "placeholder", maxLength: "maxLength", allowNull: "allowNull", type: "type", autoComplete: "autoComplete", name: "name", checked: "checked", minValue: "minValue", maxValue: "maxValue", format: "format", displayText: "displayText" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", formatChange: "formatChange", displayTextChange: "displayTextChange" }, host: { classAttribute: "ax-editor-container ax-drop-down" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "_maskDirective", first: true, predicate: IMaskDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n [imask]=\"_maskObj\" \r\n [unmask]=\"false\" \r\n type=\"text\" \r\n [attr.placeholder]=\"placeholder\"\r\n [class.ax-state-disabled]=\"disabled\" \r\n [class.ax-state-readonly]=\"readonly\" \r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\" \r\n [ngModel]=\"displayText\" \r\n (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\"\r\n (keyup)=\"_handleKeyUpEvent($event)\" \r\n (keydown)=\"_handleOnKeydownEvent($event)\" \r\n autocomplete=\"off\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.IMaskDirective, selector: "[imask]", inputs: ["imask", "unmask", "imaskElement"], outputs: ["accept", "complete"], exportAs: ["imask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
258
258
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXTimeBoxComponent, decorators: [{
259
259
  type: Component,
260
260
  args: [{ selector: 'ax-time-box', inputs: [
@@ -263,14 +263,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
263
263
  'tabIndex',
264
264
  'size',
265
265
  'value',
266
- 'placeholder', 'maxLength', 'allowNull', 'debounceTime', 'type', 'autoComplete', 'readonly', 'allowNull', 'value', 'name', 'checked',
266
+ 'placeholder', 'maxLength', 'allowNull', 'type', 'autoComplete', 'readonly', 'allowNull', 'value', 'name', 'checked',
267
267
  ], outputs: [
268
268
  'valueChange',
269
269
  'onValueChanged',
270
270
  'onBlur',
271
271
  'onFocus',
272
272
  'valueChange', 'onValueChanged',
273
- ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-editor-container ax-drop-down' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" [imask]=\"_maskObj\" [unmask]=\"false\" type=\"text\" [attr.placeholder]=\"placeholder\"\r\n [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\" [disabled]=\"disabled\"\r\n [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\" \r\n (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\"\r\n (keyup)=\"_handleKeyUpEvent($event)\" \r\n (keydown)=\"_handleOnKeydownEvent($event)\" \r\n autocomplete=\"off\">\r\n\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>" }]
273
+ ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-editor-container ax-drop-down' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n [imask]=\"_maskObj\" \r\n [unmask]=\"false\" \r\n type=\"text\" \r\n [attr.placeholder]=\"placeholder\"\r\n [class.ax-state-disabled]=\"disabled\" \r\n [class.ax-state-readonly]=\"readonly\" \r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\" \r\n [ngModel]=\"displayText\" \r\n (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n (focus)=\"_emitOnFocusEvent($event)\"\r\n (blur)=\"_emitOnBlurEvent($event)\"\r\n (keyup)=\"_handleKeyUpEvent($event)\" \r\n (keydown)=\"_handleOnKeydownEvent($event)\" \r\n autocomplete=\"off\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>" }]
274
274
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { input: [{
275
275
  type: ViewChild,
276
276
  args: ['input']
@@ -290,4 +290,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
290
290
  type: ViewChild,
291
291
  args: [IMaskDirective]
292
292
  }] } });
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/time-box/src/time-box.component.ts","../../../../../../projects/acorex/components/time-box/src/time-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXStringUtil } from '@acorex/core/utils';\r\nimport { AXDateTime } from '@acorex/core/dateTime';\r\nimport {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  EventEmitter,\r\n  Output,\r\n  Input,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport IMask from 'imask';\r\nimport { IMaskDirective } from 'angular-imask';\r\nimport { AXBaseTextBoxMixin, AXComponentOptionChanged } from '@acorex/components/mixin';\r\n\r\n\r\nexport type AX_TIME_FORMAT = 'HH:mm' | 'HH:mm:ss';\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-time-box',\r\n  templateUrl: './time-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    'placeholder', 'maxLength', 'allowNull', 'debounceTime', 'type', 'autoComplete', 'readonly','allowNull','value','name', 'checked',\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    'valueChange', 'onValueChanged',\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-editor-container ax-drop-down' },\r\n})\r\nexport class AXTimeBoxComponent extends AXBaseTextBoxMixin {\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n\r\n  private _minValue: Date;\r\n  @Input()\r\n  public get minValue(): Date {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: Date) {\r\n    this._minValue = v;\r\n  }\r\n\r\n  private _maxValue: Date;\r\n  @Input()\r\n  public get maxValue(): Date {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: Date) {\r\n    this._maxValue = v;\r\n  }\r\n\r\n  @Output()\r\n  formatChange = new EventEmitter<string>();\r\n\r\n  private _format: AX_TIME_FORMAT = 'HH:mm';\r\n  @Input()\r\n  public get format(): AX_TIME_FORMAT {\r\n    return this._format;\r\n  }\r\n  public set format(v: AX_TIME_FORMAT) {\r\n    this._setOption({\r\n      name: 'format',\r\n      value: v,\r\n    });\r\n  }\r\n\r\n  @Output()\r\n  public displayTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n  private _displayText: string = '';\r\n\r\n  @Input()\r\n  public get displayText(): string {\r\n    return this._displayText;\r\n  }\r\n\r\n  public set displayText(v: string) {\r\n    this._displayText = v;\r\n    this.displayTextChange.emit(v);\r\n  }\r\n\r\n  /**\r\n   *  @ignore\r\n   */\r\n  _maskObj: IMask.MaskedPattern;\r\n\r\n  @ViewChild(IMaskDirective)\r\n  private _maskDirective: IMaskDirective<IMask.MaskedNumber>;\r\n\r\n  /**\r\n   *  @ignore\r\n   */\r\n  constructor(elementRef: ElementRef, private cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onViewInit(): void {\r\n    super.onViewInit();\r\n    this._updateMask();\r\n  }\r\n\r\n  _onValueChanged(oldValue?: any, newValue?: any) {\r\n    this._updateText();\r\n    this._maskDirective?.maskRef?.updateValue();\r\n    this._maskDirective?.maskRef?.updateControl();\r\n  }\r\n\r\n  _updateText() {\r\n    this.displayText = this.value\r\n      ? AXDateTime.convert(this.value).format(this.format)\r\n      : '';\r\n  }\r\n\r\n  _onOptionChanged(option: AXComponentOptionChanged): void {\r\n    super._onOptionChanged(option);\r\n    this._updateMask();\r\n  }\r\n\r\n  focus(): void {\r\n    this.input.nativeElement.focus()\r\n  }\r\n\r\n\r\n  private _updateMask() {\r\n    if (!this._maskObj) {\r\n      this._maskObj = IMask.createMask({\r\n        mask: this.format,\r\n        lazy: false,\r\n        blocks: {\r\n          HH: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 23,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n          mm: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 59,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n          ss: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 59,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n        },\r\n      });\r\n    } else {\r\n      this._maskObj.updateOptions({\r\n        mask: this.format,\r\n      });\r\n    }\r\n    this._maskDirective?.maskRef?.updateValue();\r\n    this._maskDirective?.maskRef?.updateControl();\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n\r\n    const nums: string[] = Array(10)\r\n      .fill(0)\r\n      .map((v, i) => i.toString());\r\n    const chars: string[] = [\r\n      'Backspace',\r\n      'ArrowDown',\r\n      'ArrowUp',\r\n      'ArrowRight',\r\n      'ArrowLeft',\r\n      'Tab',\r\n      'Enter',\r\n    ];\r\n    const input = e.target as HTMLInputElement;\r\n    const key = e.key;\r\n    const valStr = input.value;\r\n    const sStart = input.selectionStart || 0;\r\n    const sEnd = input.selectionEnd || 0;\r\n    const dateVal = new AXDateTime(this.value);\r\n    //\r\n    const re = /[a-zA-Z0-9]+/gi;\r\n    const parts = Array.from(this.format.matchAll(re));\r\n    const word = valStr.substring(sStart, sEnd);\r\n    const part = parts.find((c:any) => c.index >= sStart);\r\n    const next = Array.from(valStr.substr(sEnd).matchAll(re));\r\n    const prev = Array.from(valStr.substring(0, sStart).matchAll(re));\r\n    //const part = parts[Array.from(valStr.matchAll(re)).findIndex(c => c[0] == word)];\r\n    //\r\n\r\n    const goNext = () => {\r\n      this._highlightPart(input, sEnd + (next[0]?.index || 0));\r\n    };\r\n    const goPrev = () => {\r\n      this._highlightPart(input, prev[prev.length - 1]?.index);\r\n    };\r\n\r\n    //\r\n    if (e.key === 'ArrowRight' || e.key === 'ArrowLeft') {\r\n      ignore();\r\n      e.key === 'ArrowRight' ? goNext() : goPrev();\r\n    } else if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {\r\n      if (e.ctrlKey && e.key === 'ArrowDown') {\r\n        //this.open();\r\n      } else {\r\n        const sign = e.key === 'ArrowUp' ? +1 : -1;\r\n        if (part) {\r\n          switch (part[0]) {\r\n            case 'hh':\r\n            case 'h':\r\n            case 'HH':\r\n            case 'H':\r\n              this.value = dateVal.add('hour', sign).date;\r\n              break;\r\n            case 'mm':\r\n              this.value = dateVal.add('minute', sign).date;\r\n              break;\r\n            case 'ss':\r\n            case 'SS':\r\n              this.value = dateVal.add('second', sign).date;\r\n              break;\r\n          }\r\n          setTimeout(() => {\r\n            this._highlightPart(input, sStart);\r\n          }, 10);\r\n        }\r\n      }\r\n      ignore();\r\n    } else if (e.key == 'Backspace') {\r\n      // if (this.allowNull) {\r\n      //     this.value = null;\r\n      // }\r\n      // ignore();\r\n    } else if (e.key == 'Tab') {\r\n      if (sEnd < valStr.length && !e.shiftKey) {\r\n        goNext();\r\n        ignore();\r\n      } else if (sStart != 0 && e.shiftKey) {\r\n        goPrev();\r\n        ignore();\r\n      }\r\n    } else {\r\n      // const keys = {\r\n      //     h: {\r\n      //         v: /^[0-9]$|^[1][0-2]$/,\r\n      //         p: '0'\r\n      //     },\r\n      //     H: {\r\n      //         v: /^[0-9]$|^1[0-9]$|2[0-3]$/,\r\n      //         p: '0'\r\n      //     },\r\n      //     m: {\r\n      //         v: /^[0-9]$|^[1-5][0-9]$/,\r\n      //         p: '0'\r\n      //     }\r\n      // }\r\n      // // const re = new RegExp(_.orderBy(Object.keys(keys), c => c.length, ['desc']).join(\"|\"), \"gi\");\r\n      // // return format.replace(re, function (matched) {\r\n      // //   return keys[matched]();\r\n      // // });\r\n      // const t = keys[part[0]];\r\n      // if (!t.v.test(key)) {\r\n      //     ignore();\r\n      // }\r\n      // else {\r\n      //     this._updateText()\r\n      // }\r\n    }\r\n    // super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _handleKeyUpEvent(e: KeyboardEvent) {\r\n    // const input = (e.target as HTMLInputElement);\r\n    // setTimeout(() => {\r\n    //     this._highlightPart(input);\r\n    // }, 700);\r\n  }\r\n\r\n  _emitOnFocusEvent(e: FocusEvent): void {\r\n    const input = e.target as HTMLInputElement;\r\n    this._highlightPart(input);\r\n    super._emitOnFocusEvent(e);\r\n  }\r\n\r\n  _handleOnInputClickEvent(e: MouseEvent): void {\r\n    const input = e.target as HTMLInputElement;\r\n    this._highlightPart(input);\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n  }\r\n\r\n  private _highlightPart(input: HTMLInputElement, pos?: number) {\r\n    const { start, end } = AXStringUtil.getWordBoundsAtPosition(\r\n      input.value,\r\n      pos != null ? pos : input.selectionStart || 0\r\n    );\r\n    input.setSelectionRange(start, end);\r\n  }\r\n  \r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" [imask]=\"_maskObj\" [unmask]=\"false\"  type=\"text\" [attr.placeholder]=\"placeholder\"\r\n    [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\" [disabled]=\"disabled\"\r\n    [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\" \r\n    (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n    (focus)=\"_emitOnFocusEvent($event)\"\r\n    (blur)=\"_emitOnBlurEvent($event)\"\r\n    (keyup)=\"_handleKeyUpEvent($event)\" \r\n    (keydown)=\"_handleOnKeydownEvent($event)\" \r\n    autocomplete=\"off\">\r\n\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/time-box/src/time-box.component.ts","../../../../../../projects/acorex/components/time-box/src/time-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXStringUtil } from '@acorex/core/utils';\r\nimport { AXDateTime } from '@acorex/core/dateTime';\r\nimport {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  EventEmitter,\r\n  Output,\r\n  Input,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport IMask from 'imask';\r\nimport { IMaskDirective } from 'angular-imask';\r\nimport { AXBaseTextBoxMixin, AXComponentOptionChanged } from '@acorex/components/mixin';\r\n\r\n\r\nexport type AX_TIME_FORMAT = 'HH:mm' | 'HH:mm:ss';\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-time-box',\r\n  templateUrl: './time-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    'placeholder', 'maxLength', 'allowNull', 'type', 'autoComplete', 'readonly', 'allowNull', 'value', 'name', 'checked',\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    'valueChange', 'onValueChanged',\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-editor-container ax-drop-down' },\r\n})\r\nexport class AXTimeBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n  @ViewChild('input') \r\n  input: ElementRef<HTMLInputElement>;\r\n\r\n  private _minValue: Date;\r\n  @Input()\r\n  public get minValue(): Date {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: Date) {\r\n    this._minValue = v;\r\n  }\r\n\r\n  private _maxValue: Date;\r\n  @Input()\r\n  public get maxValue(): Date {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: Date) {\r\n    this._maxValue = v;\r\n  }\r\n\r\n  @Output()\r\n  formatChange = new EventEmitter<string>();\r\n\r\n  private _format: AX_TIME_FORMAT = 'HH:mm';\r\n  @Input()\r\n  public get format(): AX_TIME_FORMAT {\r\n    return this._format;\r\n  }\r\n  public set format(v: AX_TIME_FORMAT) {\r\n    this._setOption({\r\n      name: 'format',\r\n      value: v,\r\n    });\r\n  }\r\n\r\n  @Output()\r\n  public displayTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n  private _displayText: string = '';\r\n\r\n  @Input()\r\n  public get displayText(): string {\r\n    return this._displayText;\r\n  }\r\n\r\n  public set displayText(v: string) {\r\n    this._displayText = v;\r\n    this.displayTextChange.emit(v);\r\n  }\r\n\r\n  /**\r\n   *  @ignore\r\n   */\r\n  protected _maskObj: IMask.MaskedPattern;\r\n\r\n  @ViewChild(IMaskDirective)\r\n  private _maskDirective: IMaskDirective<IMask.MaskedNumber>;\r\n\r\n  /**\r\n   *  @ignore\r\n   */\r\n  constructor(elementRef: ElementRef, private cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onViewInit(): void {\r\n    super.onViewInit();\r\n    this._updateMask();\r\n  }\r\n\r\n  _onValueChanged(oldValue?: any, newValue?: any) {\r\n    this._updateText();\r\n    this._maskDirective?.maskRef?.updateValue();\r\n    this._maskDirective?.maskRef?.updateControl();\r\n  }\r\n\r\n  _updateText() {\r\n    this.displayText = this.value\r\n      ? AXDateTime.convert(this.value).format(this.format)\r\n      : '';\r\n  }\r\n\r\n  _onOptionChanged(option: AXComponentOptionChanged): void {\r\n    super._onOptionChanged(option);\r\n    this._updateMask();\r\n  }\r\n\r\n  focus(): void {\r\n    this.input.nativeElement.focus()\r\n  }\r\n\r\n\r\n  private _updateMask() {\r\n    if (!this._maskObj) {\r\n      this._maskObj = IMask.createMask({\r\n        mask: this.format,\r\n        lazy: false,\r\n        blocks: {\r\n          HH: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 23,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n          mm: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 59,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n          ss: {\r\n            mask: IMask.MaskedRange,\r\n            from: 0,\r\n            to: 59,\r\n            maxLength: 2,\r\n            placeholderChar: '0',\r\n            autofix: 'pad',\r\n          },\r\n        },\r\n      });\r\n    } else {\r\n      this._maskObj.updateOptions({\r\n        mask: this.format,\r\n      });\r\n    }\r\n    this._maskDirective?.maskRef?.updateValue();\r\n    this._maskDirective?.maskRef?.updateControl();\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n\r\n    const nums: string[] = Array(10)\r\n      .fill(0)\r\n      .map((v, i) => i.toString());\r\n    const chars: string[] = [\r\n      'Backspace',\r\n      'ArrowDown',\r\n      'ArrowUp',\r\n      'ArrowRight',\r\n      'ArrowLeft',\r\n      'Tab',\r\n      'Enter',\r\n    ];\r\n    const input = e.target as HTMLInputElement;\r\n    const key = e.key;\r\n    const valStr = input.value;\r\n    const sStart = input.selectionStart || 0;\r\n    const sEnd = input.selectionEnd || 0;\r\n    const dateVal = new AXDateTime(this.value);\r\n    //\r\n    const re = /[a-zA-Z0-9]+/gi;\r\n    const parts = Array.from(this.format.matchAll(re));\r\n    const word = valStr.substring(sStart, sEnd);\r\n    const part = parts.find((c:any) => c.index >= sStart);\r\n    const next = Array.from(valStr.substr(sEnd).matchAll(re));\r\n    const prev = Array.from(valStr.substring(0, sStart).matchAll(re));\r\n    //const part = parts[Array.from(valStr.matchAll(re)).findIndex(c => c[0] == word)];\r\n    //\r\n\r\n    const goNext = () => {\r\n      this._highlightPart(input, sEnd + (next[0]?.index || 0));\r\n    };\r\n    const goPrev = () => {\r\n      this._highlightPart(input, prev[prev.length - 1]?.index);\r\n    };\r\n\r\n    //\r\n    if (e.key === 'ArrowRight' || e.key === 'ArrowLeft') {\r\n      ignore();\r\n      e.key === 'ArrowRight' ? goNext() : goPrev();\r\n    } else if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {\r\n      if (e.ctrlKey && e.key === 'ArrowDown') {\r\n        //this.open();\r\n      } else {\r\n        const sign = e.key === 'ArrowUp' ? +1 : -1;\r\n        if (part) {\r\n          switch (part[0]) {\r\n            case 'hh':\r\n            case 'h':\r\n            case 'HH':\r\n            case 'H':\r\n              this.value = dateVal.add('hour', sign).date;\r\n              break;\r\n            case 'mm':\r\n              this.value = dateVal.add('minute', sign).date;\r\n              break;\r\n            case 'ss':\r\n            case 'SS':\r\n              this.value = dateVal.add('second', sign).date;\r\n              break;\r\n          }\r\n          setTimeout(() => {\r\n            this._highlightPart(input, sStart);\r\n          }, 10);\r\n        }\r\n      }\r\n      ignore();\r\n    } else if (e.key == 'Backspace') {\r\n      // if (this.allowNull) {\r\n      //     this.value = null;\r\n      // }\r\n      // ignore();\r\n    } else if (e.key == 'Tab') {\r\n      if (sEnd < valStr.length && !e.shiftKey) {\r\n        goNext();\r\n        ignore();\r\n      } else if (sStart != 0 && e.shiftKey) {\r\n        goPrev();\r\n        ignore();\r\n      }\r\n    } else {\r\n      // const keys = {\r\n      //     h: {\r\n      //         v: /^[0-9]$|^[1][0-2]$/,\r\n      //         p: '0'\r\n      //     },\r\n      //     H: {\r\n      //         v: /^[0-9]$|^1[0-9]$|2[0-3]$/,\r\n      //         p: '0'\r\n      //     },\r\n      //     m: {\r\n      //         v: /^[0-9]$|^[1-5][0-9]$/,\r\n      //         p: '0'\r\n      //     }\r\n      // }\r\n      // // const re = new RegExp(_.orderBy(Object.keys(keys), c => c.length, ['desc']).join(\"|\"), \"gi\");\r\n      // // return format.replace(re, function (matched) {\r\n      // //   return keys[matched]();\r\n      // // });\r\n      // const t = keys[part[0]];\r\n      // if (!t.v.test(key)) {\r\n      //     ignore();\r\n      // }\r\n      // else {\r\n      //     this._updateText()\r\n      // }\r\n    }\r\n    // super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _handleKeyUpEvent(e: KeyboardEvent) {\r\n    // const input = (e.target as HTMLInputElement);\r\n    // setTimeout(() => {\r\n    //     this._highlightPart(input);\r\n    // }, 700);\r\n  }\r\n\r\n  _emitOnFocusEvent(e: FocusEvent): void {\r\n    const input = e.target as HTMLInputElement;\r\n    this._highlightPart(input);\r\n    super._emitOnFocusEvent(e);\r\n  }\r\n\r\n  _handleOnInputClickEvent(e: MouseEvent): void {\r\n    const input = e.target as HTMLInputElement;\r\n    this._highlightPart(input);\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n  }\r\n\r\n  private _highlightPart(input: HTMLInputElement, pos?: number) {\r\n    const { start, end } = AXStringUtil.getWordBoundsAtPosition(\r\n      input.value,\r\n      pos != null ? pos : input.selectionStart || 0\r\n    );\r\n    input.setSelectionRange(start, end);\r\n  }\r\n  \r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input #input class=\"ax-input\" \r\n    [imask]=\"_maskObj\" \r\n    [unmask]=\"false\"  \r\n    type=\"text\" \r\n    [attr.placeholder]=\"placeholder\"\r\n    [class.ax-state-disabled]=\"disabled\" \r\n    [class.ax-state-readonly]=\"readonly\" \r\n    [disabled]=\"disabled\"\r\n    [readonly]=\"readonly\" \r\n    [tabindex]=\"tabIndex\" \r\n    [ngModel]=\"displayText\" \r\n    (mouseup)=\"_handleOnInputClickEvent($event)\"\r\n    (focus)=\"_emitOnFocusEvent($event)\"\r\n    (blur)=\"_emitOnBlurEvent($event)\"\r\n    (keyup)=\"_handleKeyUpEvent($event)\" \r\n    (keydown)=\"_handleOnKeydownEvent($event)\" \r\n    autocomplete=\"off\">\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
@@ -102,7 +102,7 @@ AXColorPaletteInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14
102
102
  provide: AXColorPaletteChildComponent,
103
103
  useExisting: AXColorPaletteInputComponent,
104
104
  },
105
- ], usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"_parent.colorMode\">\r\n <div class=\"palette-inputs\">\r\n <ng-container *ngSwitchCase=\"'hex'\">\r\n <div>\r\n <ax-text-box class=\"ax-w-full\" [value]=\"_hex\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\" (onValueChanged)=\"_handleHEXAValueChanged($event)\">\r\n </ax-text-box>\r\n <label>HEX</label>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'rgba'\">\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.r\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>R</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.g\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>G</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.b\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>B</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"1\" [(value)]=\"_rgba.a\" [decimals]=\"2\" [step]=\"0.1\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n [showSpinButtons]=\"false\" (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>A</label>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <ax-button color=\"light\" class=\"ax-w-base\" (onClick)=\"_handleChangeInputMode($event)\" [disabled]=\"_parent.disabled\">\r\n <ax-icon class=\"ax-ic ax-ic-unfold\"></ax-icon>\r\n </ax-button>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "allowNull", "value", "name", "checked", "placeholder", "maxLength", "debounceTime", "type", "autoComplete"], outputs: ["onBlur", "onFocus", "valueChange", "onValueChanged"] }, { kind: "component", type: i3.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i5.AXNumberBoxComponent, selector: "ax-number-box", inputs: ["disabled", "readonly", "tabIndex", "size", "value", "placeholder", "maxLength", "allowNull", "debounceTime", "type", "autoComplete", "name", "checked", "thousandsSeparator", "padDecimalZeros", "step", "decimals", "decimalStep", "showSpinButtons", "minValue", "maxValue"], outputs: ["valueChange", "onValueChanged", "onBlur", "onFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
105
+ ], usesInheritance: true, ngImport: i0, template: "<ng-container [ngSwitch]=\"_parent.colorMode\">\r\n <div class=\"palette-inputs\">\r\n <ng-container *ngSwitchCase=\"'hex'\">\r\n <div>\r\n <ax-text-box class=\"ax-w-full\" [value]=\"_hex\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\" (onValueChanged)=\"_handleHEXAValueChanged($event)\">\r\n </ax-text-box>\r\n <label>HEX</label>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'rgba'\">\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.r\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>R</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.g\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>G</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"255\" [(value)]=\"_rgba.b\" [showSpinButtons]=\"false\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>B</label>\r\n </div>\r\n <div>\r\n <ax-number-box [minValue]=\"0\" [maxValue]=\"1\" [(value)]=\"_rgba.a\" [decimals]=\"2\" [step]=\"0.1\" [disabled]=\"_parent.disabled\" [readonly]=\"_parent.readonly\"\r\n [showSpinButtons]=\"false\" (onValueChanged)=\"_handleRGBAValueChanged($event)\">\r\n </ax-number-box>\r\n <label>A</label>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <ax-button color=\"light\" class=\"ax-w-base\" (onClick)=\"_handleChangeInputMode($event)\" [disabled]=\"_parent.disabled\">\r\n <ax-icon class=\"ax-ic ax-ic-unfold\"></ax-icon>\r\n </ax-button>\r\n</ng-container>", dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "value", "name", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "mask-options"], outputs: ["onBlur", "onFocus", "valueChange", "onValueChanged"] }, { kind: "component", type: i3.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i5.AXNumberBoxComponent, selector: "ax-number-box", inputs: ["disabled", "readonly", "tabIndex", "size", "value", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "name", "checked", "thousandsSeparator", "padDecimalZeros", "step", "decimals", "decimalStep", "showSpinButtons", "minValue", "maxValue"], outputs: ["valueChange", "onValueChanged", "onBlur", "onFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
106
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXColorPaletteInputComponent, decorators: [{
107
107
  type: Component,
108
108
  args: [{ selector: 'ax-color-palette-input', host: { class: 'ax-color-palette-input' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [