@acorex/components 7.8.1 → 7.8.3

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 (76) hide show
  1. package/common/lib/classes/datasource.class.d.ts +2 -2
  2. package/esm2022/button/lib/button.component.mjs +2 -2
  3. package/esm2022/common/lib/classes/datasource.class.mjs +13 -12
  4. package/esm2022/common/lib/components/selection-base.component.class.mjs +3 -2
  5. package/esm2022/common/lib/components/value-component.class.mjs +2 -3
  6. package/esm2022/dropdown/lib/dropdown-box.component.mjs +2 -1
  7. package/esm2022/list/lib/list.component.mjs +14 -11
  8. package/esm2022/list/lib/list.module.mjs +4 -3
  9. package/esm2022/otp/lib/otp.component.mjs +2 -2
  10. package/esm2022/popover/lib/popover.component.mjs +6 -3
  11. package/esm2022/progress-bar/lib/progress-bar.component.mjs +2 -2
  12. package/esm2022/range-slider/lib/range-slider.component.mjs +4 -4
  13. package/esm2022/select-box/lib/select-box.component.mjs +11 -8
  14. package/esm2022/tabs/lib/tabs.component.mjs +2 -2
  15. package/fesm2022/acorex-components-button.mjs +2 -2
  16. package/fesm2022/acorex-components-button.mjs.map +1 -1
  17. package/fesm2022/acorex-components-common.mjs +15 -15
  18. package/fesm2022/acorex-components-common.mjs.map +1 -1
  19. package/fesm2022/acorex-components-dropdown.mjs +1 -0
  20. package/fesm2022/acorex-components-dropdown.mjs.map +1 -1
  21. package/fesm2022/acorex-components-list.mjs +16 -12
  22. package/fesm2022/acorex-components-list.mjs.map +1 -1
  23. package/fesm2022/acorex-components-otp.mjs +2 -2
  24. package/fesm2022/acorex-components-otp.mjs.map +1 -1
  25. package/fesm2022/acorex-components-popover.mjs +5 -2
  26. package/fesm2022/acorex-components-popover.mjs.map +1 -1
  27. package/fesm2022/acorex-components-progress-bar.mjs +2 -2
  28. package/fesm2022/acorex-components-progress-bar.mjs.map +1 -1
  29. package/fesm2022/acorex-components-range-slider.mjs +3 -3
  30. package/fesm2022/acorex-components-range-slider.mjs.map +1 -1
  31. package/fesm2022/acorex-components-select-box.mjs +10 -8
  32. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  33. package/fesm2022/acorex-components-tabs.mjs +2 -2
  34. package/fesm2022/acorex-components-tabs.mjs.map +1 -1
  35. package/list/lib/list.component.d.ts +1 -2
  36. package/list/lib/list.module.d.ts +2 -1
  37. package/package.json +1 -7
  38. package/select-box/lib/select-box.component.d.ts +1 -1
  39. package/esm2022/mixin/acorex-components-mixin.mjs +0 -5
  40. package/esm2022/mixin/index.mjs +0 -17
  41. package/esm2022/mixin/lib/base-components.class.mjs +0 -110
  42. package/esm2022/mixin/lib/base-menu-mixin.class.mjs +0 -137
  43. package/esm2022/mixin/lib/button-mixin.class.mjs +0 -66
  44. package/esm2022/mixin/lib/clickable-mixin.class.mjs +0 -24
  45. package/esm2022/mixin/lib/color-look-mixing.class.mjs +0 -43
  46. package/esm2022/mixin/lib/constratctor.mjs +0 -2
  47. package/esm2022/mixin/lib/datalist-component.class.mjs +0 -155
  48. package/esm2022/mixin/lib/datalist.class.mjs +0 -46
  49. package/esm2022/mixin/lib/dropdown-mixin.class.mjs +0 -95
  50. package/esm2022/mixin/lib/interactive-mixin.class.mjs +0 -84
  51. package/esm2022/mixin/lib/mixin.class.mjs +0 -26
  52. package/esm2022/mixin/lib/page-component.class.mjs +0 -11
  53. package/esm2022/mixin/lib/selection-component.class.mjs +0 -180
  54. package/esm2022/mixin/lib/sizable-mixin.class.mjs +0 -16
  55. package/esm2022/mixin/lib/textbox-mixin.class.mjs +0 -67
  56. package/esm2022/mixin/lib/value-mixin.class.mjs +0 -227
  57. package/fesm2022/acorex-components-mixin.mjs +0 -1268
  58. package/fesm2022/acorex-components-mixin.mjs.map +0 -1
  59. package/mixin/README.md +0 -3
  60. package/mixin/index.d.ts +0 -16
  61. package/mixin/lib/base-components.class.d.ts +0 -84
  62. package/mixin/lib/base-menu-mixin.class.d.ts +0 -53
  63. package/mixin/lib/button-mixin.class.d.ts +0 -53
  64. package/mixin/lib/clickable-mixin.class.d.ts +0 -36
  65. package/mixin/lib/color-look-mixing.class.d.ts +0 -42
  66. package/mixin/lib/constratctor.d.ts +0 -4
  67. package/mixin/lib/datalist-component.class.d.ts +0 -59
  68. package/mixin/lib/datalist.class.d.ts +0 -49
  69. package/mixin/lib/dropdown-mixin.class.d.ts +0 -47
  70. package/mixin/lib/interactive-mixin.class.d.ts +0 -63
  71. package/mixin/lib/mixin.class.d.ts +0 -680
  72. package/mixin/lib/page-component.class.d.ts +0 -28
  73. package/mixin/lib/selection-component.class.d.ts +0 -61
  74. package/mixin/lib/sizable-mixin.class.d.ts +0 -34
  75. package/mixin/lib/textbox-mixin.class.d.ts +0 -66
  76. package/mixin/lib/value-mixin.class.d.ts +0 -64
@@ -1,11 +0,0 @@
1
- export function _PageComponenetMixin(Base) {
2
- return class extends Base {
3
- /**
4
- * @ignore
5
- */
6
- constructor(...args) {
7
- super(...args.slice(0, 2));
8
- }
9
- };
10
- }
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jb21wb25lbnQuY2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWl4aW4vc3JjL2xpYi9wYWdlLWNvbXBvbmVudC5jbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLFVBQVUsb0JBQW9CLENBQTZDLElBQVc7SUFDMUYsT0FBTyxLQUFNLFNBQVEsSUFBSTtRQUN2Qjs7V0FFRztRQUNILFlBQVksR0FBRyxJQUFXO1lBQ3hCLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDN0IsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhCYXNlQ29tcG9uZW50IH0gZnJvbSAnLi9iYXNlLWNvbXBvbmVudHMuY2xhc3MnO1xuaW1wb3J0IHsgQ29uc3RydWN0b3IgfSBmcm9tICcuL2NvbnN0cmF0Y3Rvcic7XG5cbmV4cG9ydCBmdW5jdGlvbiBfUGFnZUNvbXBvbmVuZXRNaXhpbjxUQmFzZSBleHRlbmRzIENvbnN0cnVjdG9yPEFYQmFzZUNvbXBvbmVudD4+KEJhc2U6IFRCYXNlKSB7XG4gIHJldHVybiBjbGFzcyBleHRlbmRzIEJhc2Uge1xuICAgIC8qKlxuICAgICAqICBAaWdub3JlXG4gICAgICovXG4gICAgY29uc3RydWN0b3IoLi4uYXJnczogYW55W10pIHtcbiAgICAgIHN1cGVyKC4uLmFyZ3Muc2xpY2UoMCwgMikpO1xuICAgIH1cbiAgfTtcbn1cbiJdfQ==
@@ -1,180 +0,0 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { EventEmitter } from '@angular/core';
3
- import { clone } from 'lodash-es';
4
- export function _SelectionComponenetMixin(Base) {
5
- return class extends Base {
6
- /**
7
- * Defines the primary text to show inside the button.
8
- */
9
- get items() {
10
- return [];
11
- }
12
- get displayItems() {
13
- return [];
14
- }
15
- get flatItems() {
16
- return [];
17
- }
18
- constructor(...args) {
19
- super(...args);
20
- this.valueField = 'id';
21
- this.textField = 'text';
22
- this.disabledField = 'disabled';
23
- this.multiple = false;
24
- this.selectionMode = 'value';
25
- this.valueChange = new EventEmitter();
26
- this.onValueChanged = new EventEmitter();
27
- }
28
- _onInternalInit() {
29
- super._onInternalInit();
30
- }
31
- get value() {
32
- return this._value;
33
- }
34
- set value(v) {
35
- v = this._internalSetValue(v);
36
- if (v !== this._value) {
37
- const oldValue = clone(this._value);
38
- if (this.multiple) {
39
- this._value = Array.isArray(v) ? v : v ? [v] : [];
40
- }
41
- else {
42
- this._value = Array.isArray(v) ? v[0] : v;
43
- }
44
- this._renderSelection();
45
- this.valueChange.emit(this._value);
46
- this.onValueChanged.emit({
47
- component: this,
48
- htmlElement: this._getHostElement(),
49
- isUserInteraction: false,
50
- oldValue,
51
- value: this._value,
52
- selectedKeys: this.selectedItems.map((c) => c[this.valueField]),
53
- selectedItems: this.selectedItems.slice(),
54
- });
55
- if (v == null || v == undefined || v == '') {
56
- this._setState('clear');
57
- }
58
- else {
59
- if (this._isInited) {
60
- this.validate();
61
- }
62
- }
63
- }
64
- }
65
- get selectedItems() {
66
- return this._selectedItems || [];
67
- }
68
- _renderSelection() {
69
- const func = () => {
70
- if (this.value == null || this.value == undefined) {
71
- return [];
72
- }
73
- const items = this.flatItems;
74
- if (items.length > 0) {
75
- return items.filter((i) => {
76
- if (Array.isArray(this.value)) {
77
- return this.value.some((ii) => {
78
- if (typeof ii === 'object') {
79
- return i[this.valueField] === ii[this.valueField];
80
- }
81
- else {
82
- return i[this.valueField] === ii;
83
- }
84
- });
85
- }
86
- else {
87
- if (typeof this.value === 'object') {
88
- return i[this.valueField] === this.value[this.valueField];
89
- }
90
- else {
91
- return i[this.valueField] === this.value;
92
- }
93
- }
94
- });
95
- }
96
- if (Array.isArray(this.value)) {
97
- return this.value.map((ii) => {
98
- if (typeof ii === 'object') {
99
- return ii;
100
- }
101
- else {
102
- const fake = {};
103
- fake[this.valueField] = this.value;
104
- fake[this.textField] = this.value;
105
- return fake;
106
- }
107
- });
108
- }
109
- else {
110
- if (typeof this.value === 'object') {
111
- return [this.value];
112
- }
113
- else {
114
- const fake = {};
115
- fake[this.valueField] = this.value;
116
- fake[this.textField] = this.value;
117
- return [fake];
118
- }
119
- }
120
- };
121
- this._selectedItems = func();
122
- }
123
- _getItemByDataMode(item) {
124
- return this.selectionMode === 'item' ? item : item[this.valueField];
125
- }
126
- _getItemValue(item) {
127
- return typeof item === 'object' ? item[this.valueField] : item;
128
- }
129
- unselectItems(...items) {
130
- if (!items || items.length === 0) {
131
- this.value = null;
132
- }
133
- else if (Array.isArray(this.value)) {
134
- this.value = this.value.filter((c) => !items.some((d) => this._getItemValue(c) === this._getItemValue(d)));
135
- }
136
- else {
137
- this.value = null;
138
- }
139
- }
140
- selectItems(...items) {
141
- if (items && items.length) {
142
- if (this.multiple) {
143
- this.value = (this.value || []).concat(items.map((c) => this._getItemByDataMode(c)));
144
- }
145
- else {
146
- this.value = this._getItemByDataMode(items[0]);
147
- }
148
- }
149
- }
150
- toggleSelect(...items) {
151
- if (items && items.length) {
152
- items.forEach((item) => {
153
- if (this.multiple) {
154
- this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);
155
- }
156
- else {
157
- this.selectItems(item);
158
- }
159
- });
160
- }
161
- }
162
- isItemSelected(item) {
163
- return this.selectedItems.some((c) => c[this.valueField] === item[this.valueField]);
164
- }
165
- isItemDisabled(item) {
166
- return (coerceBooleanProperty(item[this.disabledField]) === true ||
167
- (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false));
168
- }
169
- };
170
- }
171
- export const SELECTION_INPUTS = [
172
- 'valueField',
173
- 'textField',
174
- 'disabledField',
175
- 'disabledCallback',
176
- 'multiple',
177
- 'selectionMode',
178
- ];
179
- export const SELECTION_OUTPUT = ['onValueChanged', 'valueChanged'];
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-component.class.js","sourceRoot":"","sources":["../../../../../../libs/components/mixin/src/lib/selection-component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXSelectionValueChangedEvent } from '@acorex/components/common';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EventEmitter } from '@angular/core';\nimport { clone } from 'lodash-es';\nimport { AXBaseComponent } from './base-components.class';\nimport { Constructor } from './constratctor';\n\nexport function _SelectionComponenetMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\n  return class extends Base {\n    valueField: string = 'id';\n    textField: string = 'text';\n    disabledField: string = 'disabled';\n    disabledCallback: (e: { item: any; index: number }) => boolean;\n    multiple: boolean = false;\n    selectionMode: 'value' | 'item' = 'value';\n\n    /**\n     *  Defines the primary text to show inside the button.\n     */\n    get items(): any[] {\n      return [];\n    }\n\n    get displayItems(): any[] {\n      return [];\n    }\n\n    get flatItems(): any[] {\n      return [];\n    }\n\n    public valueChange: EventEmitter<any> = new EventEmitter<any>();\n    public onValueChanged: EventEmitter<AXSelectionValueChangedEvent> =\n      new EventEmitter<AXSelectionValueChangedEvent>();\n\n    constructor(...args: any[]) {\n      super(...args);\n    }\n\n    override _onInternalInit() {\n      super._onInternalInit();\n    }\n\n    _value: any | any[];\n    get value(): any | any[] {\n      return this._value;\n    }\n    set value(v: any | any[]) {\n      v = (this as any)._internalSetValue(v);\n      if (v !== this._value) {\n        const oldValue = clone(this._value);\n        if (this.multiple) {\n          this._value = Array.isArray(v) ? v : v ? [v] : [];\n        } else {\n          this._value = Array.isArray(v) ? v[0] : v;\n        }\n        this._renderSelection();\n        this.valueChange.emit(this._value);\n        this.onValueChanged.emit({\n          component: this,\n          htmlElement: this._getHostElement(),\n          isUserInteraction: false,\n          oldValue,\n          value: this._value,\n          selectedKeys: this.selectedItems.map((c) => c[this.valueField]),\n          selectedItems: this.selectedItems.slice(),\n        });\n        if (v == null || v == undefined || v == '') {\n          (this as any)._setState('clear');\n        } else {\n          if (this._isInited) {\n            (this as any).validate();\n          }\n        }\n      }\n    }\n\n    _selectedItems: any[];\n    get selectedItems(): any[] {\n      return this._selectedItems || [];\n    }\n\n    _renderSelection() {\n      const func = () => {\n        if (this.value == null || this.value == undefined) {\n          return [];\n        }\n        const items = this.flatItems;\n        if (items.length > 0) {\n          return items.filter((i) => {\n            if (Array.isArray(this.value)) {\n              return this.value.some((ii) => {\n                if (typeof ii === 'object') {\n                  return i[this.valueField] === ii[this.valueField];\n                } else {\n                  return i[this.valueField] === ii;\n                }\n              });\n            } else {\n              if (typeof this.value === 'object') {\n                return i[this.valueField] === this.value[this.valueField];\n              } else {\n                return i[this.valueField] === this.value;\n              }\n            }\n          });\n        }\n        if (Array.isArray(this.value)) {\n          return this.value.map((ii) => {\n            if (typeof ii === 'object') {\n              return ii;\n            } else {\n              const fake: any = {};\n              fake[this.valueField] = this.value;\n              fake[this.textField] = this.value;\n              return fake;\n            }\n          });\n        } else {\n          if (typeof this.value === 'object') {\n            return [this.value];\n          } else {\n            const fake: any = {};\n            fake[this.valueField] = this.value;\n            fake[this.textField] = this.value;\n            return [fake];\n          }\n        }\n      };\n      this._selectedItems = func();\n    }\n\n    _getItemByDataMode(item: any) {\n      return this.selectionMode === 'item' ? item : item[this.valueField];\n    }\n\n    _getItemValue(item: any) {\n      return typeof item === 'object' ? item[this.valueField] : item;\n    }\n\n    unselectItems(...items: any[]) {\n      if (!items || items.length === 0) {\n        this.value = null;\n      } else if (Array.isArray(this.value)) {\n        this.value = this.value.filter(\n          (c) => !items.some((d) => this._getItemValue(c) === this._getItemValue(d)),\n        );\n      } else {\n        this.value = null;\n      }\n    }\n\n    selectItems(...items: any[]) {\n      if (items && items.length) {\n        if (this.multiple) {\n          this.value = (this.value || []).concat(items.map((c) => this._getItemByDataMode(c)));\n        } else {\n          this.value = this._getItemByDataMode(items[0]);\n        }\n      }\n    }\n\n    toggleSelect(...items: any[]) {\n      if (items && items.length) {\n        items.forEach((item) => {\n          if (this.multiple) {\n            this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);\n          } else {\n            this.selectItems(item);\n          }\n        });\n      }\n    }\n\n    isItemSelected(item: any): boolean {\n      return this.selectedItems.some((c) => c[this.valueField] === item[this.valueField]);\n    }\n\n    isItemDisabled(item: any): boolean {\n      return (\n        coerceBooleanProperty(item[this.disabledField]) === true ||\n        (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false)\n      );\n    }\n  };\n}\n\nexport const SELECTION_INPUTS = [\n  'valueField',\n  'textField',\n  'disabledField',\n  'disabledCallback',\n  'multiple',\n  'selectionMode',\n];\nexport const SELECTION_OUTPUT = ['onValueChanged', 'valueChanged'];\n"]}
@@ -1,16 +0,0 @@
1
- export function _SizableComponenetMixin(Base) {
2
- return class extends Base {
3
- /**
4
- * @ignore
5
- */
6
- constructor(...args) {
7
- super(...args.slice(0, 2));
8
- }
9
- _onInternalInit() {
10
- super._onInternalInit();
11
- }
12
- };
13
- }
14
- export const SIZABLE_INPUTS = ['size'];
15
- export const SIZABLE_OUTPUT = [];
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2l6YWJsZS1taXhpbi5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9taXhpbi9zcmMvbGliL3NpemFibGUtbWl4aW4uY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxVQUFVLHVCQUF1QixDQUE2QyxJQUFXO0lBQzdGLE9BQU8sS0FBTSxTQUFRLElBQUk7UUFNdkI7O1dBRUc7UUFDSCxZQUFZLEdBQUcsSUFBVztZQUN4QixLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzdCLENBQUM7UUFFUSxlQUFlO1lBQ3RCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUMxQixDQUFDO0tBQ0YsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUN2QyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhCYXNlQ29tcG9uZW50LCBBWEVsZW1lbnRTaXplIH0gZnJvbSAnLi9iYXNlLWNvbXBvbmVudHMuY2xhc3MnO1xuaW1wb3J0IHsgQ29uc3RydWN0b3IgfSBmcm9tICcuL2NvbnN0cmF0Y3Rvcic7XG5cbmV4cG9ydCBmdW5jdGlvbiBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbjxUQmFzZSBleHRlbmRzIENvbnN0cnVjdG9yPEFYQmFzZUNvbXBvbmVudD4+KEJhc2U6IFRCYXNlKSB7XG4gIHJldHVybiBjbGFzcyBleHRlbmRzIEJhc2Uge1xuICAgIC8qKlxuICAgICAqICBBIHRva2VuIHRoYXQgc3BlY2lmaWVzIHRoZSBzaXplIG9mIGNvbXBvbmVudC5cbiAgICAgKi9cbiAgICBzaXplOiBBWEVsZW1lbnRTaXplO1xuXG4gICAgLyoqXG4gICAgICogIEBpZ25vcmVcbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvciguLi5hcmdzOiBhbnlbXSkge1xuICAgICAgc3VwZXIoLi4uYXJncy5zbGljZSgwLCAyKSk7XG4gICAgfVxuXG4gICAgb3ZlcnJpZGUgX29uSW50ZXJuYWxJbml0KCkge1xuICAgICAgc3VwZXIuX29uSW50ZXJuYWxJbml0KCk7XG4gICAgfVxuICB9O1xufVxuXG5leHBvcnQgY29uc3QgU0laQUJMRV9JTlBVVFMgPSBbJ3NpemUnXTtcbmV4cG9ydCBjb25zdCBTSVpBQkxFX09VVFBVVCA9IFtdO1xuIl19
@@ -1,67 +0,0 @@
1
- import { EventEmitter } from '@angular/core';
2
- export function _TextboxComponenetMixin(Base) {
3
- return class extends Base {
4
- _emitOnKeydownEvent(e) {
5
- this.onKeyDown.emit({
6
- component: this,
7
- nativeEvent: e,
8
- });
9
- this._setUserInteraction();
10
- }
11
- _emitOnKeyupEvent(e) {
12
- this.onKeyUp.emit({
13
- component: this,
14
- nativeEvent: e,
15
- });
16
- this._setUserInteraction();
17
- }
18
- _emitOnKeypressEvent(e) {
19
- this.onKeyPress.emit({
20
- component: this,
21
- nativeEvent: e,
22
- });
23
- this._setUserInteraction();
24
- }
25
- /**
26
- * @ignore
27
- */
28
- constructor(...args) {
29
- super(...args.slice(0, 2));
30
- /**
31
- * A string value that specifies the type of text box.
32
- */
33
- this.type = 'text';
34
- /**
35
- * A string value that specifies the placeholder of text box.
36
- */
37
- this.placeholder = '';
38
- /**
39
- * Fires each time the user press a key.
40
- * @event
41
- */
42
- this.onKeyDown = new EventEmitter();
43
- /**
44
- * Fires each time the user press a key.
45
- * @event
46
- */
47
- this.onKeyUp = new EventEmitter();
48
- /**
49
- * Fires each time the user press a key.
50
- * @event
51
- */
52
- this.onKeyPress = new EventEmitter();
53
- }
54
- };
55
- }
56
- export const TEXTBOX_INPUTS = [
57
- 'placeholder',
58
- 'maxLength',
59
- 'allowNull',
60
- 'type',
61
- 'autoComplete',
62
- 'readonly',
63
- 'value',
64
- 'name',
65
- ];
66
- export const TEXTBOX_OUTPUT = ['valueChange', 'onValueChanged'];
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGJveC1taXhpbi5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9taXhpbi9zcmMvbGliL3RleHRib3gtbWl4aW4uY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUk3QyxNQUFNLFVBQVUsdUJBQXVCLENBQTZDLElBQVc7SUFDN0YsT0FBTyxLQUFNLFNBQVEsSUFBSTtRQXVDdkIsbUJBQW1CLENBQUMsQ0FBZ0I7WUFDbEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ2xCLFNBQVMsRUFBRSxJQUFJO2dCQUNmLFdBQVcsRUFBRSxDQUFDO2FBQ2YsQ0FBQyxDQUFDO1lBQ0YsSUFBWSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDdEMsQ0FBQztRQUVELGlCQUFpQixDQUFDLENBQWdCO1lBQ2hDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO2dCQUNoQixTQUFTLEVBQUUsSUFBSTtnQkFDZixXQUFXLEVBQUUsQ0FBQzthQUNmLENBQUMsQ0FBQztZQUNGLElBQVksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ3RDLENBQUM7UUFFRCxvQkFBb0IsQ0FBQyxDQUFnQjtZQUNuQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztnQkFDbkIsU0FBUyxFQUFFLElBQUk7Z0JBQ2YsV0FBVyxFQUFFLENBQUM7YUFDZixDQUFDLENBQUM7WUFDRixJQUFZLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztRQUN0QyxDQUFDO1FBRUQ7O1dBRUc7UUFDSCxZQUFZLEdBQUcsSUFBVztZQUN4QixLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBbEU3Qjs7ZUFFRztZQUNILFNBQUksR0FBRyxNQUFNLENBQUM7WUFFZDs7ZUFFRztZQUNILGdCQUFXLEdBQVcsRUFBRSxDQUFDO1lBWXpCOzs7ZUFHRztZQUNILGNBQVMsR0FBNkMsSUFBSSxZQUFZLEVBQThCLENBQUM7WUFFckc7OztlQUdHO1lBQ0gsWUFBTyxHQUE2QyxJQUFJLFlBQVksRUFBOEIsQ0FBQztZQUVuRzs7O2VBR0c7WUFDSCxlQUFVLEdBQTZDLElBQUksWUFBWSxFQUE4QixDQUFDO1FBK0J0RyxDQUFDO0tBQ0YsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7SUFDNUIsYUFBYTtJQUNiLFdBQVc7SUFDWCxXQUFXO0lBQ1gsTUFBTTtJQUNOLGNBQWM7SUFDZCxVQUFVO0lBQ1YsT0FBTztJQUNQLE1BQU07Q0FDUCxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsYUFBYSxFQUFFLGdCQUFnQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEh0bWxFdmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWEJhc2VDb21wb25lbnQgfSBmcm9tICcuL2Jhc2UtY29tcG9uZW50cy5jbGFzcyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gJy4vY29uc3RyYXRjdG9yJztcblxuZXhwb3J0IGZ1bmN0aW9uIF9UZXh0Ym94Q29tcG9uZW5ldE1peGluPFRCYXNlIGV4dGVuZHMgQ29uc3RydWN0b3I8QVhCYXNlQ29tcG9uZW50Pj4oQmFzZTogVEJhc2UpIHtcbiAgcmV0dXJuIGNsYXNzIGV4dGVuZHMgQmFzZSB7XG4gICAgLyoqXG4gICAgICogIEEgc3RyaW5nIHZhbHVlIHRoYXQgc3BlY2lmaWVzIHRoZSB0eXBlIG9mIHRleHQgYm94LlxuICAgICAqL1xuICAgIHR5cGUgPSAndGV4dCc7XG5cbiAgICAvKipcbiAgICAgKiAgQSBzdHJpbmcgdmFsdWUgdGhhdCBzcGVjaWZpZXMgdGhlIHBsYWNlaG9sZGVyIG9mIHRleHQgYm94LlxuICAgICAqL1xuICAgIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSAnJztcblxuICAgIC8qKlxuICAgICAqICBBIG51bWJlciB2YWx1ZSB0aGF0IHNwZWNpZmllcyB0aGUgbWF4aW11bSBjaGFyYWN0ZXJzIG9mIHRleHQgYm94LlxuICAgICAqL1xuICAgIG1heExlbmd0aDogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogIFNwZWNpZmllcyB0aGF0IGF1dG9jb21wbGV0ZSBpcyBvbiBvciBvZmYuXG4gICAgICovXG4gICAgYXV0b0NvbXBsZXRlOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiAgRmlyZXMgZWFjaCB0aW1lIHRoZSB1c2VyIHByZXNzIGEga2V5LlxuICAgICAqICBAZXZlbnRcbiAgICAgKi9cbiAgICBvbktleURvd246IEV2ZW50RW1pdHRlcjxBWEh0bWxFdmVudDxLZXlib2FyZEV2ZW50Pj4gPSBuZXcgRXZlbnRFbWl0dGVyPEFYSHRtbEV2ZW50PEtleWJvYXJkRXZlbnQ+PigpO1xuXG4gICAgLyoqXG4gICAgICogIEZpcmVzIGVhY2ggdGltZSB0aGUgdXNlciBwcmVzcyBhIGtleS5cbiAgICAgKiAgQGV2ZW50XG4gICAgICovXG4gICAgb25LZXlVcDogRXZlbnRFbWl0dGVyPEFYSHRtbEV2ZW50PEtleWJvYXJkRXZlbnQ+PiA9IG5ldyBFdmVudEVtaXR0ZXI8QVhIdG1sRXZlbnQ8S2V5Ym9hcmRFdmVudD4+KCk7XG5cbiAgICAvKipcbiAgICAgKiAgRmlyZXMgZWFjaCB0aW1lIHRoZSB1c2VyIHByZXNzIGEga2V5LlxuICAgICAqICBAZXZlbnRcbiAgICAgKi9cbiAgICBvbktleVByZXNzOiBFdmVudEVtaXR0ZXI8QVhIdG1sRXZlbnQ8S2V5Ym9hcmRFdmVudD4+ID0gbmV3IEV2ZW50RW1pdHRlcjxBWEh0bWxFdmVudDxLZXlib2FyZEV2ZW50Pj4oKTtcblxuICAgIF9lbWl0T25LZXlkb3duRXZlbnQoZTogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgdGhpcy5vbktleURvd24uZW1pdCh7XG4gICAgICAgIGNvbXBvbmVudDogdGhpcyxcbiAgICAgICAgbmF0aXZlRXZlbnQ6IGUsXG4gICAgICB9KTtcbiAgICAgICh0aGlzIGFzIGFueSkuX3NldFVzZXJJbnRlcmFjdGlvbigpO1xuICAgIH1cblxuICAgIF9lbWl0T25LZXl1cEV2ZW50KGU6IEtleWJvYXJkRXZlbnQpIHtcbiAgICAgIHRoaXMub25LZXlVcC5lbWl0KHtcbiAgICAgICAgY29tcG9uZW50OiB0aGlzLFxuICAgICAgICBuYXRpdmVFdmVudDogZSxcbiAgICAgIH0pO1xuICAgICAgKHRoaXMgYXMgYW55KS5fc2V0VXNlckludGVyYWN0aW9uKCk7XG4gICAgfVxuXG4gICAgX2VtaXRPbktleXByZXNzRXZlbnQoZTogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgdGhpcy5vbktleVByZXNzLmVtaXQoe1xuICAgICAgICBjb21wb25lbnQ6IHRoaXMsXG4gICAgICAgIG5hdGl2ZUV2ZW50OiBlLFxuICAgICAgfSk7XG4gICAgICAodGhpcyBhcyBhbnkpLl9zZXRVc2VySW50ZXJhY3Rpb24oKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiAgQGlnbm9yZVxuICAgICAqL1xuICAgIGNvbnN0cnVjdG9yKC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgICBzdXBlciguLi5hcmdzLnNsaWNlKDAsIDIpKTtcbiAgICB9XG4gIH07XG59XG5cbmV4cG9ydCBjb25zdCBURVhUQk9YX0lOUFVUUyA9IFtcbiAgJ3BsYWNlaG9sZGVyJyxcbiAgJ21heExlbmd0aCcsXG4gICdhbGxvd051bGwnLFxuICAndHlwZScsXG4gICdhdXRvQ29tcGxldGUnLFxuICAncmVhZG9ubHknLFxuICAndmFsdWUnLFxuICAnbmFtZScsXG5dO1xuZXhwb3J0IGNvbnN0IFRFWFRCT1hfT1VUUFVUID0gWyd2YWx1ZUNoYW5nZScsICdvblZhbHVlQ2hhbmdlZCddO1xuIl19
@@ -1,227 +0,0 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { EventEmitter } from '@angular/core';
3
- import { clone } from 'lodash-es';
4
- export function _ValueComponenetMixin(Base) {
5
- return class extends Base {
6
- #readonly;
7
- /**
8
- * If set to true, user cannot change the value of component.
9
- */
10
- get readonly() {
11
- return this.#readonly;
12
- }
13
- set readonly(value) {
14
- this.#readonly = coerceBooleanProperty(value);
15
- }
16
- #allowNull;
17
- get allowNull() {
18
- return this.#allowNull;
19
- }
20
- set allowNull(value) {
21
- this.#allowNull = coerceBooleanProperty(value);
22
- }
23
- #name;
24
- get name() {
25
- return this.#name;
26
- }
27
- set name(value) {
28
- this.#name = value;
29
- }
30
- #isUserInteraction;
31
- get isUserInteraction() {
32
- return this.#isUserInteraction;
33
- }
34
- #value;
35
- get value() {
36
- return this._internalGetValue();
37
- }
38
- set value(v) {
39
- v = this._internalSetValue(v);
40
- //if (!this._isInited ) {
41
- const old = clone(this.value);
42
- // TODO: check real equality
43
- if (v != old) {
44
- this.#value = v;
45
- this._emitOnValueChangedEvent(old, this.value);
46
- this._cdr.markForCheck();
47
- if (v == null || v == undefined || v == '' || (Array.isArray(v) && v.length == 0)) {
48
- this._setState('clear');
49
- }
50
- // else {
51
- // if (this._isInited) {
52
- // this.validate();
53
- // }
54
- // }
55
- }
56
- this.#isUserInteraction = false;
57
- //}
58
- }
59
- #state;
60
- get state() {
61
- return this.#state;
62
- }
63
- set state(value) {
64
- this._setState(value);
65
- this.stateChange.emit(value);
66
- }
67
- _emitOnValueChangedEvent(oldValue, newValue) {
68
- this.valueChange.emit(newValue);
69
- this.onValueChanged.emit({
70
- component: this,
71
- value: newValue,
72
- oldValue: oldValue,
73
- name: this.name,
74
- isUserInteraction: this.isUserInteraction,
75
- });
76
- this._onValueChanged(oldValue, this.#value);
77
- this.#isUserInteraction = false;
78
- }
79
- _internalSetValue(value) {
80
- return this._setValue(value);
81
- }
82
- _internalGetValue() {
83
- return this._getValue(this.#value);
84
- }
85
- _setValue(value) {
86
- return value;
87
- }
88
- _getValue(value) {
89
- return value;
90
- }
91
- _setUserInteraction() {
92
- this.#isUserInteraction = true;
93
- }
94
- setUserInteraction() {
95
- this.#isUserInteraction = true;
96
- }
97
- _onValueChanged(oldValue, newValue) { }
98
- _onInternalInit() {
99
- this._getHostElement().setAttribute('ax-form-input', 'true');
100
- super._onInternalInit();
101
- }
102
- _onInternalViewInit() {
103
- this._checkRequired();
104
- super._onInternalViewInit();
105
- }
106
- _onInternalDestroy() {
107
- super.onDestroy();
108
- }
109
- clear() {
110
- this.value = null;
111
- }
112
- _checkRequired() {
113
- const isRequired = Array.from(this._getHostElement().querySelectorAll('ax-validation-rule')).some((c) => c.__axContext__.enabled && c.__axContext__.rule == 'required');
114
- //
115
- if (isRequired) {
116
- const container = this._getHostElement().classList.contains('ax-editor-container')
117
- ? this._getHostElement()
118
- : this._getHostElement().querySelector('.ax-editor-container');
119
- const formField = container?.closest('.ax-form-field');
120
- const label = formField?.querySelector('ax-label')?.__axContext__;
121
- if (label)
122
- label.required = true;
123
- }
124
- }
125
- validate() {
126
- const rules = Array.from(this._getHostElement().querySelectorAll('ax-validation-rule')).filter((c) => c.__axContext__.enabled);
127
- //
128
- if (!rules || rules.length === 0) {
129
- this._setState('clear');
130
- return Promise.resolve({
131
- result: true,
132
- value: this.value,
133
- name: this.name,
134
- id: this.id,
135
- });
136
- }
137
- return new Promise((resolve) => {
138
- Promise.all(rules
139
- .filter((c) => typeof c?.validate === 'function')
140
- .map((c) => {
141
- return c.validate(this.value);
142
- })).then((d) => {
143
- const error = d.find((c) => c.result === false);
144
- if (error) {
145
- this._setState('error', error.message);
146
- resolve({
147
- result: false,
148
- value: this.value,
149
- message: error.message,
150
- name: this.name,
151
- id: this.id,
152
- });
153
- }
154
- else {
155
- this._setState('success');
156
- resolve({
157
- result: true,
158
- value: this.value,
159
- name: this.name,
160
- id: this.id,
161
- });
162
- }
163
- });
164
- });
165
- }
166
- /**
167
- * @ignore
168
- */
169
- constructor(...args) {
170
- super(...args);
171
- /**
172
- * Fires each time the user press a key.
173
- * @event
174
- */
175
- this.onValueChanged = new EventEmitter();
176
- this.valueChange = new EventEmitter();
177
- this.stateChange = new EventEmitter();
178
- this.#readonly = false;
179
- this.#allowNull = true;
180
- this.#isUserInteraction = false;
181
- this.#state = 'clear';
182
- }
183
- _setState(state, ...args) {
184
- const container = this._getHostElement().classList.contains('ax-editor-container')
185
- ? this._getHostElement()
186
- : this._getHostElement().querySelector('.ax-editor-container');
187
- const formField = container?.closest('.ax-form-field');
188
- const label = formField?.querySelector('ax-label') || formField?.querySelector('label');
189
- let target = container || this._getInnerElement();
190
- if (target?.querySelector('.ax-error-container')) {
191
- target = target.querySelector('.ax-error-container');
192
- }
193
- const parent = target?.parentElement;
194
- if (!target || !parent)
195
- return;
196
- switch (state) {
197
- case 'clear':
198
- this.#state = 'clear';
199
- if (parent.querySelector('span.ax-error-message')) {
200
- parent.removeChild(parent.querySelector('span.ax-error-message'));
201
- }
202
- label?.classList.remove('ax-state-error');
203
- target.classList.remove('ax-state-error', 'ax-state-success');
204
- break;
205
- case 'success':
206
- this._setState('clear');
207
- target.classList.add('ax-state-success');
208
- this.#state = 'success';
209
- break;
210
- case 'error':
211
- this._setState('clear');
212
- if (args[0]) {
213
- const span = document.createElement('span');
214
- span.innerText = args[0];
215
- span.classList.add('ax-error-message');
216
- parent.appendChild(span);
217
- }
218
- label?.classList.add('ax-state-error');
219
- target.classList.add('ax-state-error');
220
- this.#state = 'error';
221
- break;
222
- }
223
- this._cdr.markForCheck();
224
- }
225
- };
226
- }
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-mixin.class.js","sourceRoot":"","sources":["../../../../../../libs/components/mixin/src/lib/value-mixin.class.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAIlC,MAAM,UAAU,qBAAqB,CAA6C,IAAW;IAC3F,OAAO,KAAM,SAAQ,IAAI;QAUvB,SAAS,CAAkB;QAE3B;;WAEG;QACH,IAAI,QAAQ;YACV,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QACD,IAAI,QAAQ,CAAC,KAAc;YACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC;QAED,UAAU,CAAiB;QAC3B,IAAI,SAAS;YACX,OAAO,IAAI,CAAC,UAAU,CAAC;QACzB,CAAC;QACD,IAAI,SAAS,CAAC,KAAc;YAC1B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QACjD,CAAC;QAED,KAAK,CAAS;QACd,IAAI,IAAI;YACN,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,KAAa;YACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;QAED,kBAAkB,CAAkB;QAEpC,IAAI,iBAAiB;YACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;QACjC,CAAC;QAED,MAAM,CAAM;QACZ,IAAI,KAAK;YACP,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAClC,CAAC;QACD,IAAI,KAAK,CAAC,CAAM;YACd,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC9B,yBAAyB;YACzB,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC9B,4BAA4B;YAC5B,IAAI,CAAC,IAAI,GAAG,EAAE;gBACZ,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;gBAChB,IAAI,CAAC,wBAAwB,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC/C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACzB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE;oBACjF,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;iBACzB;gBACD,SAAS;gBACT,0BAA0B;gBAC1B,uBAAuB;gBACvB,MAAM;gBACN,IAAI;aACL;YACD,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,GAAG;QACL,CAAC;QAED,MAAM,CAA6B;QAEnC,IAAI,KAAK;YACP,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,CAAC;QAED,IAAI,KAAK,CAAC,KAAuB;YAC/B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACtB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC;QAED,wBAAwB,CAAC,QAAc,EAAE,QAAc;YACrD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;gBACvB,SAAS,EAAE,IAAI;gBACf,KAAK,EAAE,QAAQ;gBACf,QAAQ,EAAE,QAAQ;gBAClB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;aAC1C,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAClC,CAAC;QAED,iBAAiB,CAAC,KAAU;YAC1B,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC;QAED,iBAAiB;YACf,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrC,CAAC;QAED,SAAS,CAAC,KAAU;YAClB,OAAO,KAAK,CAAC;QACf,CAAC;QAED,SAAS,CAAC,KAAU;YAClB,OAAO,KAAK,CAAC;QACf,CAAC;QAED,mBAAmB;YACjB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACjC,CAAC;QAED,kBAAkB;YAChB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACjC,CAAC;QAED,eAAe,CAAC,QAAa,EAAE,QAAa,IAAS,CAAC;QAE7C,eAAe;YACtB,IAAI,CAAC,eAAe,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;YAC7D,KAAK,CAAC,eAAe,EAAE,CAAC;QAC1B,CAAC;QAEQ,mBAAmB;YAC1B,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,KAAK,CAAC,mBAAmB,EAAE,CAAC;QAC9B,CAAC;QAEQ,kBAAkB;YACzB,KAAK,CAAC,SAAS,EAAE,CAAC;QACpB,CAAC;QAED,KAAK;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;QAED,cAAc;YACZ,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAC/F,CAAC,CAAC,EAAE,EAAE,CAAE,CAAS,CAAC,aAAa,CAAC,OAAO,IAAK,CAAS,CAAC,aAAa,CAAC,IAAI,IAAI,UAAU,CACvF,CAAC;YACF,EAAE;YACF,IAAI,UAAU,EAAE;gBACd,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC;oBAChF,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE;oBACxB,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;gBACjE,MAAM,SAAS,GAAG,SAAS,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;gBACvD,MAAM,KAAK,GAAI,SAAS,EAAE,aAAa,CAAC,UAAU,CAAS,EAAE,aAAa,CAAC;gBAC3E,IAAI,KAAK;oBAAE,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC;aAClC;QACH,CAAC;QAED,QAAQ;YACN,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,CAC5F,CAAC,CAAC,EAAE,EAAE,CAAE,CAAS,CAAC,aAAa,CAAC,OAAO,CACxC,CAAC;YACF,EAAE;YACF,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;gBAChC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBACxB,OAAO,OAAO,CAAC,OAAO,CAAC;oBACrB,MAAM,EAAE,IAAI;oBACZ,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,EAAE,EAAE,IAAI,CAAC,EAAE;iBACZ,CAAC,CAAC;aACJ;YAED,OAAO,IAAI,OAAO,CAAM,CAAC,OAAO,EAAE,EAAE;gBAClC,OAAO,CAAC,GAAG,CACT,KAAK;qBACF,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAQ,CAAS,EAAE,QAAQ,KAAK,UAAU,CAAC;qBACzD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;oBACT,OAAQ,CAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACzC,CAAC,CAAC,CACL,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;oBACX,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC;oBAChD,IAAI,KAAK,EAAE;wBACT,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;wBACvC,OAAO,CAAC;4BACN,MAAM,EAAE,KAAK;4BACb,KAAK,EAAE,IAAI,CAAC,KAAK;4BACjB,OAAO,EAAE,KAAK,CAAC,OAAO;4BACtB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,EAAE,EAAE,IAAI,CAAC,EAAE;yBACZ,CAAC,CAAC;qBACJ;yBAAM;wBACL,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;wBAC1B,OAAO,CAAC;4BACN,MAAM,EAAE,IAAI;4BACZ,KAAK,EAAE,IAAI,CAAC,KAAK;4BACjB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,EAAE,EAAE,IAAI,CAAC,EAAE;yBACZ,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;QAED;;WAEG;QACH,YAAY,GAAG,IAAW;YACxB,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;YA1MjB;;;eAGG;YACH,mBAAc,GAA2C,IAAI,YAAY,EAA4B,CAAC;YAEtG,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;YACzD,gBAAW,GAAmC,IAAI,YAAY,EAAoB,CAAC;YAEnF,cAAS,GAAY,KAAK,CAAC;YAY3B,eAAU,GAAY,IAAI,CAAC;YAgB3B,uBAAkB,GAAY,KAAK,CAAC;YAgCpC,WAAM,GAAqB,OAAO,CAAC;QAsInC,CAAC;QAED,SAAS,CAAC,KAAuB,EAAE,GAAG,IAAI;YACxC,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC;gBAChF,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE;gBACxB,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;YACjE,MAAM,SAAS,GAAG,SAAS,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;YACvD,MAAM,KAAK,GAAG,SAAS,EAAE,aAAa,CAAC,UAAU,CAAC,IAAI,SAAS,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;YACxF,IAAI,MAAM,GAAG,SAAS,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAClD,IAAI,MAAM,EAAE,aAAa,CAAC,qBAAqB,CAAC,EAAE;gBAChD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;aACtD;YACD,MAAM,MAAM,GAAG,MAAM,EAAE,aAAa,CAAC;YACrC,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM;gBAAE,OAAO;YAE/B,QAAQ,KAAK,EAAE;gBACb,KAAK,OAAO;oBACV,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;oBACtB,IAAI,MAAM,CAAC,aAAa,CAAC,uBAAuB,CAAC,EAAE;wBACjD,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC,uBAAuB,CAAE,CAAC,CAAC;qBACpE;oBACD,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;oBAC1C,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,EAAE,kBAAkB,CAAC,CAAC;oBAC9D,MAAM;gBACR,KAAK,SAAS;oBACZ,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;oBACxB,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;oBACzC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;oBACxB,MAAM;gBACR,KAAK,OAAO;oBACV,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;oBACxB,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE;wBACX,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;wBAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;wBACzB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;wBACvC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;qBAC1B;oBACD,KAAK,EAAE,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;oBACvC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;oBAEvC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;oBACtB,MAAM;aACT;YACD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QAC3B,CAAC;KACF,CAAC;AACJ,CAAC","sourcesContent":["import { AXValueChangedEvent } from '@acorex/components/common';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EventEmitter } from '@angular/core';\nimport { clone } from 'lodash-es';\nimport { AXBaseComponent, AXComponentState } from './base-components.class';\nimport { Constructor } from './constratctor';\n\nexport function _ValueComponenetMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\n  return class extends Base {\n    /**\n     *  Fires each time the user press a key.\n     *  @event\n     */\n    onValueChanged: EventEmitter<AXValueChangedEvent<any>> = new EventEmitter<AXValueChangedEvent<any>>();\n\n    valueChange: EventEmitter<any> = new EventEmitter<any>();\n    stateChange: EventEmitter<AXComponentState> = new EventEmitter<AXComponentState>();\n\n    #readonly: boolean = false;\n\n    /**\n     *  If set to true, user cannot change the value of component.\n     */\n    get readonly() {\n      return this.#readonly;\n    }\n    set readonly(value: boolean) {\n      this.#readonly = coerceBooleanProperty(value);\n    }\n\n    #allowNull: boolean = true;\n    get allowNull() {\n      return this.#allowNull;\n    }\n    set allowNull(value: boolean) {\n      this.#allowNull = coerceBooleanProperty(value);\n    }\n\n    #name: string;\n    get name() {\n      return this.#name;\n    }\n    set name(value: string) {\n      this.#name = value;\n    }\n\n    #isUserInteraction: boolean = false;\n\n    get isUserInteraction(): boolean {\n      return this.#isUserInteraction;\n    }\n\n    #value: any;\n    get value(): any {\n      return this._internalGetValue();\n    }\n    set value(v: any) {\n      v = this._internalSetValue(v);\n      //if (!this._isInited ) {\n      const old = clone(this.value);\n      // TODO: check real equality\n      if (v != old) {\n        this.#value = v;\n        this._emitOnValueChangedEvent(old, this.value);\n        this._cdr.markForCheck();\n        if (v == null || v == undefined || v == '' || (Array.isArray(v) && v.length == 0)) {\n          this._setState('clear');\n        }\n        // else {\n        //   if (this._isInited) {\n        //     this.validate();\n        //   }\n        // }\n      }\n      this.#isUserInteraction = false;\n      //}\n    }\n\n    #state: AXComponentState = 'clear';\n\n    get state(): AXComponentState {\n      return this.#state;\n    }\n\n    set state(value: AXComponentState) {\n      this._setState(value);\n      this.stateChange.emit(value);\n    }\n\n    _emitOnValueChangedEvent(oldValue?: any, newValue?: any) {\n      this.valueChange.emit(newValue);\n      this.onValueChanged.emit({\n        component: this,\n        value: newValue,\n        oldValue: oldValue,\n        name: this.name,\n        isUserInteraction: this.isUserInteraction,\n      });\n      this._onValueChanged(oldValue, this.#value);\n      this.#isUserInteraction = false;\n    }\n\n    _internalSetValue(value: any) {\n      return this._setValue(value);\n    }\n\n    _internalGetValue() {\n      return this._getValue(this.#value);\n    }\n\n    _setValue(value: any) {\n      return value;\n    }\n\n    _getValue(value: any) {\n      return value;\n    }\n\n    _setUserInteraction() {\n      this.#isUserInteraction = true;\n    }\n\n    setUserInteraction() {\n      this.#isUserInteraction = true;\n    }\n\n    _onValueChanged(oldValue: any, newValue: any): void {}\n\n    override _onInternalInit() {\n      this._getHostElement().setAttribute('ax-form-input', 'true');\n      super._onInternalInit();\n    }\n\n    override _onInternalViewInit(): void {\n      this._checkRequired();\n      super._onInternalViewInit();\n    }\n\n    override _onInternalDestroy() {\n      super.onDestroy();\n    }\n\n    clear() {\n      this.value = null;\n    }\n\n    _checkRequired() {\n      const isRequired = Array.from(this._getHostElement().querySelectorAll('ax-validation-rule')).some(\n        (c) => (c as any).__axContext__.enabled && (c as any).__axContext__.rule == 'required',\n      );\n      //\n      if (isRequired) {\n        const container = this._getHostElement().classList.contains('ax-editor-container')\n          ? this._getHostElement()\n          : this._getHostElement().querySelector('.ax-editor-container');\n        const formField = container?.closest('.ax-form-field');\n        const label = (formField?.querySelector('ax-label') as any)?.__axContext__;\n        if (label) label.required = true;\n      }\n    }\n\n    validate(): Promise<any> {\n      const rules = Array.from(this._getHostElement().querySelectorAll('ax-validation-rule')).filter(\n        (c) => (c as any).__axContext__.enabled,\n      );\n      //\n      if (!rules || rules.length === 0) {\n        this._setState('clear');\n        return Promise.resolve({\n          result: true,\n          value: this.value,\n          name: this.name,\n          id: this.id,\n        });\n      }\n\n      return new Promise<any>((resolve) => {\n        Promise.all(\n          rules\n            .filter((c) => typeof (c as any)?.validate === 'function')\n            .map((c) => {\n              return (c as any).validate(this.value);\n            }),\n        ).then((d) => {\n          const error = d.find((c) => c.result === false);\n          if (error) {\n            this._setState('error', error.message);\n            resolve({\n              result: false,\n              value: this.value,\n              message: error.message,\n              name: this.name,\n              id: this.id,\n            });\n          } else {\n            this._setState('success');\n            resolve({\n              result: true,\n              value: this.value,\n              name: this.name,\n              id: this.id,\n            });\n          }\n        });\n      });\n    }\n\n    /**\n     *  @ignore\n     */\n    constructor(...args: any[]) {\n      super(...args);\n    }\n\n    _setState(state: AXComponentState, ...args) {\n      const container = this._getHostElement().classList.contains('ax-editor-container')\n        ? this._getHostElement()\n        : this._getHostElement().querySelector('.ax-editor-container');\n      const formField = container?.closest('.ax-form-field');\n      const label = formField?.querySelector('ax-label') || formField?.querySelector('label');\n      let target = container || this._getInnerElement();\n      if (target?.querySelector('.ax-error-container')) {\n        target = target.querySelector('.ax-error-container');\n      }\n      const parent = target?.parentElement;\n      if (!target || !parent) return;\n\n      switch (state) {\n        case 'clear':\n          this.#state = 'clear';\n          if (parent.querySelector('span.ax-error-message')) {\n            parent.removeChild(parent.querySelector('span.ax-error-message')!);\n          }\n          label?.classList.remove('ax-state-error');\n          target.classList.remove('ax-state-error', 'ax-state-success');\n          break;\n        case 'success':\n          this._setState('clear');\n          target.classList.add('ax-state-success');\n          this.#state = 'success';\n          break;\n        case 'error':\n          this._setState('clear');\n          if (args[0]) {\n            const span = document.createElement('span');\n            span.innerText = args[0];\n            span.classList.add('ax-error-message');\n            parent.appendChild(span);\n          }\n          label?.classList.add('ax-state-error');\n          target.classList.add('ax-state-error');\n\n          this.#state = 'error';\n          break;\n      }\n      this._cdr.markForCheck();\n    }\n  };\n}\n"]}