@acorex/components 7.8.0 → 7.8.2

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 (53) hide show
  1. package/esm2022/button/lib/button.component.mjs +2 -2
  2. package/esm2022/list/lib/list.component.mjs +10 -8
  3. package/esm2022/otp/lib/otp.component.mjs +2 -2
  4. package/esm2022/select-box/lib/select-box.component.mjs +7 -6
  5. package/fesm2022/acorex-components-button.mjs +2 -2
  6. package/fesm2022/acorex-components-button.mjs.map +1 -1
  7. package/fesm2022/acorex-components-list.mjs +9 -7
  8. package/fesm2022/acorex-components-list.mjs.map +1 -1
  9. package/fesm2022/acorex-components-otp.mjs +2 -2
  10. package/fesm2022/acorex-components-otp.mjs.map +1 -1
  11. package/fesm2022/acorex-components-select-box.mjs +6 -5
  12. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  13. package/list/lib/list.component.d.ts +1 -2
  14. package/package.json +1 -7
  15. package/select-box/lib/select-box.component.d.ts +0 -1
  16. package/esm2022/mixin/acorex-components-mixin.mjs +0 -5
  17. package/esm2022/mixin/index.mjs +0 -17
  18. package/esm2022/mixin/lib/base-components.class.mjs +0 -110
  19. package/esm2022/mixin/lib/base-menu-mixin.class.mjs +0 -137
  20. package/esm2022/mixin/lib/button-mixin.class.mjs +0 -66
  21. package/esm2022/mixin/lib/clickable-mixin.class.mjs +0 -24
  22. package/esm2022/mixin/lib/color-look-mixing.class.mjs +0 -43
  23. package/esm2022/mixin/lib/constratctor.mjs +0 -2
  24. package/esm2022/mixin/lib/datalist-component.class.mjs +0 -155
  25. package/esm2022/mixin/lib/datalist.class.mjs +0 -46
  26. package/esm2022/mixin/lib/dropdown-mixin.class.mjs +0 -95
  27. package/esm2022/mixin/lib/interactive-mixin.class.mjs +0 -84
  28. package/esm2022/mixin/lib/mixin.class.mjs +0 -26
  29. package/esm2022/mixin/lib/page-component.class.mjs +0 -11
  30. package/esm2022/mixin/lib/selection-component.class.mjs +0 -180
  31. package/esm2022/mixin/lib/sizable-mixin.class.mjs +0 -16
  32. package/esm2022/mixin/lib/textbox-mixin.class.mjs +0 -67
  33. package/esm2022/mixin/lib/value-mixin.class.mjs +0 -227
  34. package/fesm2022/acorex-components-mixin.mjs +0 -1268
  35. package/fesm2022/acorex-components-mixin.mjs.map +0 -1
  36. package/mixin/README.md +0 -3
  37. package/mixin/index.d.ts +0 -16
  38. package/mixin/lib/base-components.class.d.ts +0 -84
  39. package/mixin/lib/base-menu-mixin.class.d.ts +0 -53
  40. package/mixin/lib/button-mixin.class.d.ts +0 -53
  41. package/mixin/lib/clickable-mixin.class.d.ts +0 -36
  42. package/mixin/lib/color-look-mixing.class.d.ts +0 -42
  43. package/mixin/lib/constratctor.d.ts +0 -4
  44. package/mixin/lib/datalist-component.class.d.ts +0 -59
  45. package/mixin/lib/datalist.class.d.ts +0 -49
  46. package/mixin/lib/dropdown-mixin.class.d.ts +0 -47
  47. package/mixin/lib/interactive-mixin.class.d.ts +0 -63
  48. package/mixin/lib/mixin.class.d.ts +0 -680
  49. package/mixin/lib/page-component.class.d.ts +0 -28
  50. package/mixin/lib/selection-component.class.d.ts +0 -61
  51. package/mixin/lib/sizable-mixin.class.d.ts +0 -34
  52. package/mixin/lib/textbox-mixin.class.d.ts +0 -66
  53. package/mixin/lib/value-mixin.class.d.ts +0 -64
@@ -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":"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","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"]}