@acorex/components 16.18.49 → 16.19.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 (190) hide show
  1. package/fesm2022/acorex-components.mjs +726 -693
  2. package/fesm2022/acorex-components.mjs.map +1 -1
  3. package/index.d.ts +1 -0
  4. package/lib/base/base-page.class.d.ts +2 -2
  5. package/lib/base/element.class.d.ts +5 -5
  6. package/lib/calendar/scheduler/views/scheduler-view.component.d.ts +1 -1
  7. package/lib/data-filter/filter.class.d.ts +1 -1
  8. package/lib/data-list/core/data-list.component.d.ts +1 -1
  9. package/lib/property-editor/property-editor.class.d.ts +1 -1
  10. package/package.json +4 -6
  11. package/esm2022/acorex-components.mjs +0 -5
  12. package/esm2022/index.mjs +0 -159
  13. package/esm2022/lib/accordion/accordion.component.mjs +0 -45
  14. package/esm2022/lib/accordion/accordion.module.mjs +0 -20
  15. package/esm2022/lib/base/base-page.class.mjs +0 -97
  16. package/esm2022/lib/base/components.class.mjs +0 -17
  17. package/esm2022/lib/base/element.class.mjs +0 -307
  18. package/esm2022/lib/base/events.class.mjs +0 -17
  19. package/esm2022/lib/button/button.component.mjs +0 -74
  20. package/esm2022/lib/button/button.module.mjs +0 -21
  21. package/esm2022/lib/calendar/calendar-box/calendar-box.component.mjs +0 -472
  22. package/esm2022/lib/calendar/calendar-box/calendar-box.module.mjs +0 -22
  23. package/esm2022/lib/calendar/scheduler/scheduler-views.property.mjs +0 -59
  24. package/esm2022/lib/calendar/scheduler/scheduler.class.mjs +0 -16
  25. package/esm2022/lib/calendar/scheduler/scheduler.component.mjs +0 -226
  26. package/esm2022/lib/calendar/scheduler/scheduler.module.mjs +0 -68
  27. package/esm2022/lib/calendar/scheduler/toolbars/scheduler-toolbar-navigator.mjs +0 -136
  28. package/esm2022/lib/calendar/scheduler/toolbars/scheduler-toolbar-views.mjs +0 -37
  29. package/esm2022/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.mjs +0 -49
  30. package/esm2022/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.mjs +0 -102
  31. package/esm2022/lib/calendar/scheduler/views/month/scheduler-month-view.component.mjs +0 -214
  32. package/esm2022/lib/calendar/scheduler/views/scheduler-view.component.mjs +0 -99
  33. package/esm2022/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.mjs +0 -85
  34. package/esm2022/lib/checkbox/checkbox.component.mjs +0 -112
  35. package/esm2022/lib/checkbox/checkbox.module.mjs +0 -20
  36. package/esm2022/lib/color-picker/color-box/color-box.component.mjs +0 -423
  37. package/esm2022/lib/color-picker/color-picker.component.mjs +0 -89
  38. package/esm2022/lib/color-picker/color-picker.module.mjs +0 -24
  39. package/esm2022/lib/context-menu/context-menu.component.mjs +0 -68
  40. package/esm2022/lib/context-menu/context-menu.directive.mjs +0 -146
  41. package/esm2022/lib/context-menu/context-menu.module.mjs +0 -20
  42. package/esm2022/lib/data-filter/columns/filter-column-date.component.mjs +0 -140
  43. package/esm2022/lib/data-filter/columns/filter-column-number.component.mjs +0 -119
  44. package/esm2022/lib/data-filter/columns/filter-column-selection.component.mjs +0 -75
  45. package/esm2022/lib/data-filter/columns/filter-column-string.component.mjs +0 -119
  46. package/esm2022/lib/data-filter/filter-panel/filter-panel.component.mjs +0 -267
  47. package/esm2022/lib/data-filter/filter.class.mjs +0 -46
  48. package/esm2022/lib/data-filter/filter.module.mjs +0 -88
  49. package/esm2022/lib/data-filter/toolbar/filter-toolbar.component.mjs +0 -168
  50. package/esm2022/lib/data-list/core/data-list.component.mjs +0 -37
  51. package/esm2022/lib/data-list/list/list.component.mjs +0 -134
  52. package/esm2022/lib/data-list/list/list.module.mjs +0 -22
  53. package/esm2022/lib/data-list/list/toolbar-list-view.component.mjs +0 -84
  54. package/esm2022/lib/data-source/datasource.component.mjs +0 -47
  55. package/esm2022/lib/data-source/datasource.module.mjs +0 -18
  56. package/esm2022/lib/data-source/read-param.mjs +0 -7
  57. package/esm2022/lib/date-picker/date-picker.component.mjs +0 -1102
  58. package/esm2022/lib/date-picker/date-picker.module.mjs +0 -50
  59. package/esm2022/lib/dialog/dialog.component.mjs +0 -26
  60. package/esm2022/lib/dialog/dialog.module.mjs +0 -21
  61. package/esm2022/lib/dialog/dialog.service.mjs +0 -160
  62. package/esm2022/lib/drawer/content.component.mjs +0 -18
  63. package/esm2022/lib/drawer/drawer-container.component.mjs +0 -38
  64. package/esm2022/lib/drawer/drawer.component.mjs +0 -146
  65. package/esm2022/lib/drawer/drawer.module.mjs +0 -23
  66. package/esm2022/lib/dropdown/dropdown.component.mjs +0 -186
  67. package/esm2022/lib/dropdown/dropdown.module.mjs +0 -26
  68. package/esm2022/lib/fieldset/fieldset.component.mjs +0 -57
  69. package/esm2022/lib/fieldset/fieldset.module.mjs +0 -19
  70. package/esm2022/lib/form-group/form-group.component.mjs +0 -108
  71. package/esm2022/lib/form-group/form-group.module.mjs +0 -22
  72. package/esm2022/lib/form-group/form-lable.directive.mjs +0 -23
  73. package/esm2022/lib/label/label.component.mjs +0 -22
  74. package/esm2022/lib/label/label.module.mjs +0 -21
  75. package/esm2022/lib/loading/loading-indicator.component.mjs +0 -18
  76. package/esm2022/lib/loading/loading-panel.component.mjs +0 -45
  77. package/esm2022/lib/loading/loading.module.mjs +0 -21
  78. package/esm2022/lib/loading/loading.service.mjs +0 -47
  79. package/esm2022/lib/menu/menu-item.component.mjs +0 -50
  80. package/esm2022/lib/menu/menu.component.mjs +0 -114
  81. package/esm2022/lib/menu/menu.module.mjs +0 -22
  82. package/esm2022/lib/menu/menu2.component.mjs +0 -100
  83. package/esm2022/lib/number-box/number-box.component.mjs +0 -715
  84. package/esm2022/lib/number-box/number-box.module.mjs +0 -21
  85. package/esm2022/lib/page/content.component.mjs +0 -27
  86. package/esm2022/lib/page/footer.component.mjs +0 -19
  87. package/esm2022/lib/page/page.component.mjs +0 -57
  88. package/esm2022/lib/page/page.module.mjs +0 -22
  89. package/esm2022/lib/panel-box/panel-box.component.mjs +0 -87
  90. package/esm2022/lib/panel-box/panel-box.module.mjs +0 -19
  91. package/esm2022/lib/password-box/password-box.component.mjs +0 -36
  92. package/esm2022/lib/password-box/password-box.module.mjs +0 -23
  93. package/esm2022/lib/popover/custom-cdk-overlay.service.mjs +0 -50
  94. package/esm2022/lib/popover/overlay.service.mjs +0 -94
  95. package/esm2022/lib/popover/popover.component.mjs +0 -145
  96. package/esm2022/lib/popover/popover.module.mjs +0 -19
  97. package/esm2022/lib/popup/popup.component.mjs +0 -160
  98. package/esm2022/lib/popup/popup.module.mjs +0 -25
  99. package/esm2022/lib/popup/popup.service.mjs +0 -94
  100. package/esm2022/lib/progress-bar/progress-bar.component.mjs +0 -16
  101. package/esm2022/lib/progress-bar/progress-bar.module.mjs +0 -19
  102. package/esm2022/lib/property-editor/editors/check-editor/check-editor.mjs +0 -65
  103. package/esm2022/lib/property-editor/editors/check-editor/check.module.mjs +0 -22
  104. package/esm2022/lib/property-editor/editors/color-editor/color.editor.mjs +0 -41
  105. package/esm2022/lib/property-editor/editors/color-editor/color.module.mjs +0 -24
  106. package/esm2022/lib/property-editor/editors/column-editor/column.editor.mjs +0 -118
  107. package/esm2022/lib/property-editor/editors/column-editor/column.module.mjs +0 -32
  108. package/esm2022/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.mjs +0 -216
  109. package/esm2022/lib/property-editor/editors/conditional-color-editor/conditional-color.module.mjs +0 -76
  110. package/esm2022/lib/property-editor/editors/date-editor/date.editor.mjs +0 -87
  111. package/esm2022/lib/property-editor/editors/date-editor/date.module.mjs +0 -24
  112. package/esm2022/lib/property-editor/editors/number-editor/number.editor.mjs +0 -72
  113. package/esm2022/lib/property-editor/editors/number-editor/number.module.mjs +0 -24
  114. package/esm2022/lib/property-editor/editors/range-editor/range.editor.mjs +0 -145
  115. package/esm2022/lib/property-editor/editors/range-editor/range.module.mjs +0 -59
  116. package/esm2022/lib/property-editor/editors/searchbar-selectbox-editor/searchbar-selectbox-editor.mjs +0 -76
  117. package/esm2022/lib/property-editor/editors/selectbox-editor/selectbox.editor.mjs +0 -75
  118. package/esm2022/lib/property-editor/editors/selectbox-editor/selectbox.module.mjs +0 -25
  119. package/esm2022/lib/property-editor/editors/selection-editor/selection-editor.mjs +0 -73
  120. package/esm2022/lib/property-editor/editors/selection-editor/selection.module.mjs +0 -22
  121. package/esm2022/lib/property-editor/editors/switch-editor/number.editor.mjs +0 -30
  122. package/esm2022/lib/property-editor/editors/switch-editor/number.module.mjs +0 -25
  123. package/esm2022/lib/property-editor/editors/text-editor/text.editor.mjs +0 -36
  124. package/esm2022/lib/property-editor/editors/text-editor/text.module.mjs +0 -24
  125. package/esm2022/lib/property-editor/editors/textarea-editor/textarea.editor.mjs +0 -35
  126. package/esm2022/lib/property-editor/editors/textarea-editor/textarea.module.mjs +0 -24
  127. package/esm2022/lib/property-editor/editors/time-editor/time.editor.mjs +0 -55
  128. package/esm2022/lib/property-editor/editors/time-editor/time.module.mjs +0 -24
  129. package/esm2022/lib/property-editor/property-editor-renderer.directive.mjs +0 -167
  130. package/esm2022/lib/property-editor/property-editor.class.mjs +0 -108
  131. package/esm2022/lib/property-editor/property-editor.module.mjs +0 -194
  132. package/esm2022/lib/query-builder/query-builder-group.component.mjs +0 -129
  133. package/esm2022/lib/query-builder/query-builder-popup/query-builder-popup.component.mjs +0 -177
  134. package/esm2022/lib/query-builder/query-builder-rule.component.mjs +0 -428
  135. package/esm2022/lib/query-builder/query-builder.class.mjs +0 -42
  136. package/esm2022/lib/query-builder/query-builder.component.mjs +0 -92
  137. package/esm2022/lib/query-builder/query-builder.module.mjs +0 -62
  138. package/esm2022/lib/query-builder/query-builder.service.mjs +0 -199
  139. package/esm2022/lib/search-bar/search-bar.component.mjs +0 -293
  140. package/esm2022/lib/search-bar/search-bar.module.mjs +0 -61
  141. package/esm2022/lib/searchbox/searchbox.component.mjs +0 -138
  142. package/esm2022/lib/searchbox/searchbox.module.mjs +0 -24
  143. package/esm2022/lib/selectbox/selectbox.component.mjs +0 -1137
  144. package/esm2022/lib/selectbox/selectbox.module.mjs +0 -45
  145. package/esm2022/lib/selectbox/selectbox2.component.mjs +0 -617
  146. package/esm2022/lib/selection-list/selection-list.component.mjs +0 -120
  147. package/esm2022/lib/selection-list/selection-list.module.mjs +0 -21
  148. package/esm2022/lib/switch/switch.component.mjs +0 -55
  149. package/esm2022/lib/switch/switch.module.mjs +0 -20
  150. package/esm2022/lib/tab-page/tab-page-Renderer.component.mjs +0 -75
  151. package/esm2022/lib/tab-page/tab-page-host.component.mjs +0 -124
  152. package/esm2022/lib/tab-page/tab-page.module.mjs +0 -21
  153. package/esm2022/lib/tab-page/tab-page.service.mjs +0 -159
  154. package/esm2022/lib/tab-strip/tab-strip.component.mjs +0 -48
  155. package/esm2022/lib/tab-strip/tab-strip.module.mjs +0 -19
  156. package/esm2022/lib/tab-view/dynamic-tabs.directive.mjs +0 -25
  157. package/esm2022/lib/tab-view/tab-view.component.mjs +0 -110
  158. package/esm2022/lib/tab-view/tab-view.module.mjs +0 -21
  159. package/esm2022/lib/tab-view/tab.component.mjs +0 -33
  160. package/esm2022/lib/textarea/textarea.component.mjs +0 -44
  161. package/esm2022/lib/textarea/textarea.module.mjs +0 -21
  162. package/esm2022/lib/textbox/textbox.component.mjs +0 -46
  163. package/esm2022/lib/textbox/textbox.module.mjs +0 -36
  164. package/esm2022/lib/time-picker/time-picker.component.mjs +0 -1107
  165. package/esm2022/lib/time-picker/time-picker.module.mjs +0 -34
  166. package/esm2022/lib/toast/toast-message/toast-message.component.mjs +0 -76
  167. package/esm2022/lib/toast/toast-wrapper/toast-wrapper.component.mjs +0 -13
  168. package/esm2022/lib/toast/toast.module.mjs +0 -21
  169. package/esm2022/lib/toast/toast.service.mjs +0 -45
  170. package/esm2022/lib/toolbar/group-button/toolbar-group-button.component.mjs +0 -77
  171. package/esm2022/lib/toolbar/menu/toolbar-menu.component.mjs +0 -65
  172. package/esm2022/lib/toolbar/search/toolbar-search.component.mjs +0 -56
  173. package/esm2022/lib/toolbar/title/toolbar-title.component.mjs +0 -37
  174. package/esm2022/lib/toolbar/toolbar-item.mjs +0 -4
  175. package/esm2022/lib/toolbar/toolbar.component.mjs +0 -13
  176. package/esm2022/lib/toolbar/toolbar.module.mjs +0 -40
  177. package/esm2022/lib/tooltip/tooltip.directive.mjs +0 -115
  178. package/esm2022/lib/tooltip/tooltip.module.mjs +0 -19
  179. package/esm2022/lib/tree-side-menu/tree-side-menu.component.mjs +0 -697
  180. package/esm2022/lib/tree-side-menu/tree-side-menu.module.mjs +0 -33
  181. package/esm2022/lib/tree-view/tree-view.component.mjs +0 -854
  182. package/esm2022/lib/tree-view/tree-view.module.mjs +0 -22
  183. package/esm2022/lib/upload-file/upload-file.component.mjs +0 -299
  184. package/esm2022/lib/upload-file/upload-file.events.mjs +0 -2
  185. package/esm2022/lib/upload-file/upload-file.module.mjs +0 -24
  186. package/esm2022/lib/validation/validation-form.component.mjs +0 -68
  187. package/esm2022/lib/validation/validation-rule.widget.mjs +0 -133
  188. package/esm2022/lib/validation/validation.class.mjs +0 -2
  189. package/esm2022/lib/validation/validation.component.mjs +0 -89
  190. package/esm2022/lib/validation/validation.module.mjs +0 -34
@@ -1,1137 +0,0 @@
1
- import { AXConfig } from '@acorex/core';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, Input, NgZone, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
3
- import { differenceBy } from 'lodash';
4
- import { Observable } from 'rxjs';
5
- import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
6
- import { AXValidatableComponent, } from '../base/element.class';
7
- import { AXBaseEvent } from '../base/events.class';
8
- import { AXDataSourceComponent } from '../data-source/datasource.component';
9
- import { AXDropdownComponent } from '../dropdown/dropdown.component';
10
- import { AXSearchBoxComponent } from '../searchbox/searchbox.component';
11
- import { AXTextBoxComponent } from '../textbox/textbox.component';
12
- import { AXValidation } from '../validation/validation.component';
13
- import * as i0 from "@angular/core";
14
- import * as i1 from "@angular/common";
15
- import * as i2 from "../dropdown/dropdown.component";
16
- import * as i3 from "../textbox/textbox.component";
17
- import * as i4 from "../checkbox/checkbox.component";
18
- import * as i5 from "../searchbox/searchbox.component";
19
- import * as i6 from "@acorex/core";
20
- export class AXSelectBoxSelectionChangedEvent extends AXBaseEvent {
21
- selectedItems;
22
- selectedValues;
23
- constructor(component, selectedItems, selectedValues) {
24
- super();
25
- this.selectedItems = selectedItems;
26
- this.selectedValues = selectedValues;
27
- this.component = component;
28
- }
29
- }
30
- export class AXSelectBoxComponent extends AXValidatableComponent {
31
- cdr;
32
- ref;
33
- zone;
34
- componentName = 'selectBox';
35
- showDropDownButton = true;
36
- rowTemplate;
37
- rowInputTemplate;
38
- span;
39
- textbox;
40
- listContainer;
41
- serchBox;
42
- textBoxSelectBox;
43
- showCheckBox = true;
44
- readonly = false;
45
- rtl = AXConfig.get('layout.rtl');
46
- disabled = false;
47
- placeholder;
48
- size = 'md';
49
- allowNull = true;
50
- textAlign = null;
51
- bufferSize = 20;
52
- remoteOperation = false;
53
- fitParent = true;
54
- dropdownWidth = '300px';
55
- multiLine = false;
56
- dropdownToggle = new EventEmitter();
57
- // this input is Private and only use in LOV
58
- onDemandTranslate = false;
59
- currentfocusedIndex = -1;
60
- showLoading = false;
61
- skip = -1;
62
- searchText = '';
63
- // @Input()
64
- // chipsWidth: string = '';
65
- text = '';
66
- totalCount = 0;
67
- _contentDataSource;
68
- _dataSource;
69
- get dataSource() {
70
- return this._dataSource ? this._dataSource : this._contentDataSource;
71
- }
72
- set dataSource(v) {
73
- this._dataSource = v;
74
- }
75
- _contentValidation;
76
- _validation;
77
- get validation() {
78
- return this._validation ? this._validation : this._contentValidation;
79
- }
80
- set validation(v) {
81
- this._validation = v;
82
- }
83
- constructor(cdr, ref, zone) {
84
- super();
85
- this.cdr = cdr;
86
- this.ref = ref;
87
- this.zone = zone;
88
- }
89
- dropdown;
90
- disabledCallback;
91
- allowSearch = true;
92
- textField = 'text';
93
- valueField = 'value';
94
- disabledField = 'disabled';
95
- mode = 'single';
96
- itemRemove = false;
97
- itemsChange = new EventEmitter();
98
- onBlur = new EventEmitter();
99
- onFocus = new EventEmitter();
100
- _items = [];
101
- get items() {
102
- return this._items;
103
- }
104
- set items(v) {
105
- this._items = v;
106
- if (this.itemsChange) {
107
- this.itemsChange.emit(v);
108
- }
109
- if (this.itemsStatusObserver) {
110
- this.itemsStatusObserver.next(this.items.length);
111
- }
112
- }
113
- hasSelectedValue = false;
114
- itemsFiltered = [];
115
- // #endregion
116
- dropDownDisabled = false;
117
- selectionChanged = new EventEmitter();
118
- selectedItemsChange = new EventEmitter();
119
- _selectedItems = [];
120
- get selectedItems() {
121
- return this._selectedItems || [];
122
- }
123
- set selectedItems(v) {
124
- this.setSelectedItemsChange(v);
125
- // if (!v) {
126
- // v = [];
127
- // }
128
- // const old = this.selectedItems;
129
- // if (JSON.stringify(old) !== JSON.stringify(v)) {
130
- // this._selectedItems = this.mode == 'single' ? v.slice(0, 1) : [...new Set(v)]; //[...new Set(v[0])] : [...new Set(v)];
131
- // this._selectedItems.forEach((c) => (c.selected = true));
132
- // this.selectedItemsChange.emit(this._selectedItems);
133
- // this.selectedValuesChange.emit(this.selectedValues);
134
- // this.clearValidationStyle(this.ref.nativeElement);
135
- // this.waitForData(() => {
136
- // if (this._selectedItems) {
137
- // this.items.forEach((c) => (c.selected = this._selectedItems.some((i) => i[this.valueField] == c[this.valueField])));
138
- // }
139
- // });
140
- // }
141
- }
142
- setSelectedItemsChange(v, old = this.selectedItems) {
143
- if (!v) {
144
- v = [];
145
- }
146
- // const old = this.selectedItems;
147
- var f = differenceBy(old, v, this.valueField);
148
- var s = differenceBy(v, old, this.valueField);
149
- // if (JSON.stringify(old) !== JSON.stringify(v)) {
150
- if (f.length != 0 || s.length != 0) {
151
- this._selectedItems =
152
- this.mode == 'single' ? v.slice(0, 1) : [...new Set(v)]; //[...new Set(v[0])] : [...new Set(v)];
153
- this._selectedItems.forEach((c) => (c.selected = true));
154
- this.selectedItemsChange.emit(this._selectedItems);
155
- this.selectedValuesChange.emit(this.selectedValues);
156
- this.clearValidationStyle(this.ref.nativeElement);
157
- this.waitForData(() => {
158
- if (this._selectedItems) {
159
- this.items.forEach((c) => (c.selected = this._selectedItems.some((i) => i[this.valueField] == c[this.valueField])));
160
- }
161
- });
162
- }
163
- }
164
- ngOnInit() {
165
- if (this.rowTemplate === undefined && this.rowInputTemplate != undefined) {
166
- this.rowTemplate = this.rowInputTemplate;
167
- }
168
- if (this.rtl == null) {
169
- this.rtl =
170
- window
171
- .getComputedStyle(this.ref.nativeElement, null)
172
- .getPropertyValue('direction') === 'rtl';
173
- }
174
- }
175
- scrolled(e) {
176
- if (this.remoteOperation &&
177
- this.totalCount > this.items.length &&
178
- this.listContainer.nativeElement.scrollHeight != 0 &&
179
- this.listContainer.nativeElement.scrollHeight -
180
- this.listContainer.nativeElement.scrollTop -
181
- 300 <
182
- 50) {
183
- if (this.skip !== this.items.length) {
184
- this.showLoading = true;
185
- this.skip = this.items.length;
186
- const params = {};
187
- params.skip = this.items.length;
188
- params.take = this.bufferSize; //* (Math.floor(this.items.length / this.bufferSize) + 1);
189
- if (this.textbox) {
190
- params.searchText = this.text;
191
- }
192
- else {
193
- params.searchText = null;
194
- }
195
- this.fetch(params);
196
- }
197
- }
198
- }
199
- setSelectedItems(v, isUserInput) {
200
- let changed = false;
201
- if (isUserInput) {
202
- changed = JSON.stringify(v) !== JSON.stringify(this.selectedItems);
203
- }
204
- this.selectedItems = v;
205
- this.setSelectedIndex();
206
- if (isUserInput && changed) {
207
- this.emitSelectionChangedEvent();
208
- }
209
- }
210
- searchChangeObserver;
211
- delay = 500;
212
- textChanged(e) {
213
- if ((e.value === null || e.value === undefined || e.value === '') &&
214
- (e.oldValue === null || e.oldValue === undefined || e.oldValue === '')) {
215
- }
216
- else {
217
- this.currentfocusedIndex = -1;
218
- if (this.remoteOperation) {
219
- this.searchText = this.text;
220
- // this.searchText = e.value;
221
- // this.text = e.value;
222
- // this.items = [];
223
- if (this.items) {
224
- let t = this.items.length;
225
- for (let i = 0; i < t; i++) {
226
- this.items.pop();
227
- }
228
- }
229
- // this.items.forEach((element) => {
230
- // this.items.pop();
231
- // });
232
- const params = {};
233
- params.searchText = this.text;
234
- // params.searchText = e.value;
235
- params.skip = 0;
236
- params.take = this.bufferSize;
237
- this.fetch(params);
238
- }
239
- }
240
- }
241
- isItemDisabled(item) {
242
- if (item[this.disabledField] == true) {
243
- return true;
244
- }
245
- else if (this.disabledCallback) {
246
- return this.disabledCallback({ item, index: -1 });
247
- }
248
- else {
249
- return false;
250
- }
251
- }
252
- onButtonClick(e) { }
253
- setSelectedIndex(sign = null) {
254
- if (sign == null) {
255
- if (!this.remoteOperation && this.text && this.text !== '') {
256
- this.currentfocusedIndex = this.items
257
- .filter((c) => c[this.textField]
258
- .toLowerCase()
259
- .includes(this.text.toLowerCase()))
260
- .indexOf(this.selectedItems[this.selectedItems.length - 1]);
261
- }
262
- else {
263
- this.currentfocusedIndex = this.items.indexOf(this.selectedItems[this.selectedItems.length - 1]);
264
- }
265
- }
266
- else {
267
- sign === -1 ? this.currentfocusedIndex-- : this.currentfocusedIndex++;
268
- }
269
- if (this.remoteOperation) {
270
- this.itemsFiltered = this.items;
271
- }
272
- else {
273
- this.itemsFiltered = this.text
274
- ? this.items.filter((c) => c[this.textField]
275
- .toLowerCase()
276
- .includes(this.text.toLowerCase()))
277
- : this.items;
278
- }
279
- this.currentfocusedIndex =
280
- this.currentfocusedIndex < 0
281
- ? 0
282
- : this.currentfocusedIndex >= this.itemsFiltered.length
283
- ? this.itemsFiltered.length - 1
284
- : this.currentfocusedIndex;
285
- //
286
- // set scroll
287
- if (this.listContainer) {
288
- this.zone.runOutsideAngular(() => {
289
- const itemDiv = this.listContainer.nativeElement.querySelector(`.list-item:nth-child(${this.currentfocusedIndex})`);
290
- if (itemDiv) {
291
- itemDiv.scrollIntoView({ behavior: 'smooth' });
292
- }
293
- });
294
- }
295
- }
296
- selectedValuesChange = new EventEmitter();
297
- get selectedValues() {
298
- if (this.mode === 'single') {
299
- return this._selectedItems.map((c) => c[this.valueField])[0];
300
- }
301
- else {
302
- return this._selectedItems.map((c) => c[this.valueField]) || [];
303
- }
304
- }
305
- set selectedValues(v) {
306
- if (this.compareSelectedValues(v)) {
307
- return;
308
- }
309
- if (v == null) {
310
- this.selectedItems = [];
311
- }
312
- else {
313
- if (v !== undefined) {
314
- if (v != [] && v != '' && v != null) {
315
- this.hasSelectedValue = true;
316
- }
317
- this.waitForData(() => {
318
- if (this.mode === 'single') {
319
- if (this.items.filter((c) => v == c[this.valueField])) {
320
- this.selectedItems = this.items.filter((c) => v == c[this.valueField]);
321
- }
322
- else {
323
- this.selectedItems = [];
324
- }
325
- }
326
- else {
327
- if (Array.isArray(v)) {
328
- if (this.selectedItems.length > v.length) {
329
- this.selectedItems = this.selectedItems.filter((c) => v.includes(c[this.valueField]));
330
- }
331
- else {
332
- let addId = [];
333
- v.forEach((vId) => {
334
- addId.push({
335
- [this.valueField]: vId,
336
- });
337
- });
338
- let newId = differenceBy(addId, this.selectedItems, this.valueField);
339
- let vv = [];
340
- newId.forEach((rc) => {
341
- vv.push(rc[this.valueField]);
342
- });
343
- this.items
344
- .filter((c) => vv.includes(c[this.valueField]))
345
- .forEach((res) => {
346
- this.selectedItems.push(res);
347
- });
348
- // this.selectedItems.push(this.items.filter((c) => vv.includes(c[this.valueField])));
349
- this.setSelectedItemsChange(this.selectedItems, vv.length > 0 ? [1] : this.selectedItems);
350
- }
351
- // this.selectedItems = this.items.filter((c) => v.includes(c[this.valueField]));
352
- }
353
- else if (v) {
354
- this.selectedItems = this.items.filter((c) => v === c[this.valueField]);
355
- }
356
- else {
357
- this.selectedItems = [];
358
- }
359
- }
360
- this.selectedValuesChange.emit(this.selectedValues);
361
- this.cdr.markForCheck();
362
- this.cdr.detectChanges();
363
- });
364
- }
365
- }
366
- }
367
- compareSelectedValues(newValue) {
368
- const currentValue = this.selectedValues;
369
- return ((currentValue == null && newValue == null) ||
370
- JSON.stringify(currentValue) === JSON.stringify(newValue));
371
- }
372
- setSelectedValues(v, isUserInput) {
373
- const changed = isUserInput ? !this.compareSelectedValues(v) : false;
374
- this.selectedValues = v;
375
- if (isUserInput && changed) {
376
- this.emitSelectionChangedEvent();
377
- }
378
- }
379
- emitSelectionChangedEvent() {
380
- this.selectedValuesChange.emit(this.selectedValues);
381
- this.selectionChanged.emit(new AXSelectBoxSelectionChangedEvent(this, this.selectedItems, this.selectedValues));
382
- }
383
- ngAfterViewInit() {
384
- if (this.bufferSize < 10) {
385
- this.bufferSize = 10;
386
- }
387
- if (this.mode == 'single') {
388
- this.showCheckBox = false;
389
- }
390
- else {
391
- this.showCheckBox = true;
392
- }
393
- if (!this.remoteOperation ||
394
- (this.remoteOperation && this.hasSelectedValue)) {
395
- this.refresh();
396
- }
397
- }
398
- dropdownToggleSelecBox(e) {
399
- this.text = '';
400
- if (this.dropdown.isOpen) {
401
- this.refresh();
402
- setTimeout(() => {
403
- if (this.serchBox) {
404
- this.serchBox.focus();
405
- }
406
- }, 1);
407
- }
408
- else {
409
- // this.refresh();
410
- }
411
- this.dropdownToggle.emit(e);
412
- }
413
- ngAfterContentInit() {
414
- // if (!this.allowSearch) {
415
- // if (this.readonly == false) {
416
- // this.itemRemove = true;
417
- // this.readonly = true;
418
- // }
419
- // }
420
- this.initValidation(this.ref, 'selectedItems', this.validation);
421
- if (this.dataSource) {
422
- // if (this.allowSearch == false) {
423
- // this.fetch();
424
- // }
425
- this.dataSource.onDataReceived.subscribe((c) => {
426
- this.showLoading = false;
427
- this.dataReceived(c.data.result);
428
- });
429
- }
430
- this.cdr.markForCheck();
431
- this.cdr.detectChanges();
432
- }
433
- dataReceived(data) {
434
- if (this.remoteOperation) {
435
- if (this.searchText &&
436
- this.searchText != null &&
437
- this.searchText !== '') {
438
- if (data.totalCount) {
439
- if (this.items.length == 0) {
440
- //this.items = data.items;
441
- data.items.forEach((item) => {
442
- this.items.push(item);
443
- });
444
- }
445
- else {
446
- data.items.forEach((item) => {
447
- if (!this.items.some((x) => x[this.valueField] === item[this.valueField])) {
448
- this.items.push(item);
449
- }
450
- });
451
- // if (this.itemsStatusObserver) {
452
- // this.itemsStatusObserver.next(this.items.length);
453
- // }
454
- }
455
- this.totalCount = data.totalCount;
456
- }
457
- else {
458
- if (this.items.length == 0) {
459
- this.items = data.items;
460
- }
461
- else {
462
- data.items.forEach((item) => {
463
- this.items.push(item);
464
- });
465
- // if (this.itemsStatusObserver) {
466
- // this.itemsStatusObserver.next(this.items.length);
467
- // }
468
- }
469
- this.totalCount = data.items == undefined ? 0 : data.items.length;
470
- }
471
- }
472
- else if (data.items && data.items.length === data.totalCount) {
473
- this.items = data.items;
474
- this.totalCount = data.items.length;
475
- }
476
- else if (data.totalCount) {
477
- data.items.forEach((elm) => {
478
- this.items.push(elm);
479
- });
480
- // if (this.itemsStatusObserver) {
481
- // this.itemsStatusObserver.next(this.items.length);
482
- // }
483
- this.totalCount = data.totalCount;
484
- }
485
- else {
486
- data.forEach((elm) => {
487
- this.items.push(elm);
488
- // if (this.itemsStatusObserver) {
489
- // this.itemsStatusObserver.next(this.items.length);
490
- // }
491
- });
492
- this.totalCount = data.length;
493
- }
494
- }
495
- else {
496
- this.items = data;
497
- }
498
- this.cdr.markForCheck();
499
- this.cdr.detectChanges();
500
- this.dropdown.updatePosition();
501
- }
502
- // private params: AXDataSourceReadParams = {};
503
- fetch(params = {}) {
504
- // this.params = params;
505
- if (this.dataSource) {
506
- if (this.onDemandTranslate && params?.searchText) {
507
- params.searchText = this.translateSearch(params?.searchText);
508
- }
509
- this.showLoading = true;
510
- this.dataSource.fetch(params);
511
- }
512
- }
513
- translateSearch(searchText) {
514
- const latinPattern = /[A-Za-z;'\/\\[\],]/;
515
- const asciiToPersianMap = {
516
- 113: 'ض',
517
- 119: 'ص',
518
- 101: 'ث',
519
- 114: 'ق',
520
- 116: 'ف',
521
- 121: 'غ',
522
- 117: 'ع',
523
- 105: 'ه',
524
- 111: 'خ',
525
- 112: 'ح',
526
- 97: 'ش',
527
- 115: 'س',
528
- 100: 'ی',
529
- 102: 'ب',
530
- 103: 'ل',
531
- 104: 'ا',
532
- 106: 'ت',
533
- 107: 'ن',
534
- 108: 'م',
535
- 59: 'ک',
536
- 122: 'ظ',
537
- 120: 'ط',
538
- 99: 'ز',
539
- 118: 'ر',
540
- 98: 'ذ',
541
- 110: 'د',
542
- 44: 'و',
543
- 39: 'گ',
544
- 67: 'ژ',
545
- 93: 'چ',
546
- 91: 'ج',
547
- 92: 'پ',
548
- 109: 'ئ',
549
- };
550
- if (latinPattern.test(searchText)) {
551
- searchText = searchText
552
- .split('')
553
- .map((char) => {
554
- const asciiValue = char.charCodeAt(0);
555
- if (asciiToPersianMap[asciiValue]) {
556
- return asciiToPersianMap[asciiValue];
557
- }
558
- else {
559
- return char;
560
- }
561
- })
562
- .join('');
563
- }
564
- return searchText;
565
- }
566
- refresh() {
567
- const params = {};
568
- if (this.remoteOperation) {
569
- params.skip = 0;
570
- this.skip = 0;
571
- params.take = this.bufferSize;
572
- }
573
- if (this.dataSource != undefined) {
574
- // this.items = [];
575
- // this.items.forEach((element) => {
576
- // this.items.pop();
577
- // });
578
- if (this.items) {
579
- let t = this.items.length;
580
- for (let i = 0; i < t; i++) {
581
- this.items.pop();
582
- }
583
- }
584
- this.fetch(params);
585
- }
586
- }
587
- handleItemRemoveClick(item) {
588
- if (this.mode === 'single') {
589
- // this.selectedItems = null;
590
- this.setSelectedValues(null, true);
591
- // this.selectedItemsChange.emit(this._selectedItems);
592
- // this.clearValidationStyle(this.ref.nativeElement);
593
- }
594
- else {
595
- // this.selectedItems = this.selectedItems.filter((c) => c !== item);
596
- this.setSelectedItems(this.selectedItems.filter((c) => c[this.valueField] !== item[this.valueField]), true);
597
- // this._selectedItems = this._selectedItems.filter(c => c !== item);
598
- // this.selectedItemsChange.emit(this._selectedItems);
599
- // this.clearValidationStyle(this.ref.nativeElement);
600
- }
601
- // this.text = '';
602
- this.validate();
603
- this.cdr.markForCheck();
604
- }
605
- onFocusTextBox(e) { }
606
- onTextBoxClick(e) {
607
- if (this.disabled == false && this.readonly == false) {
608
- this.dropdown.open();
609
- }
610
- }
611
- handleItemClick(e, item) {
612
- if (this.isItemDisabled(item) == false) {
613
- const value = item[this.valueField];
614
- if (this.mode === 'single') {
615
- // this.selectedValues = value;
616
- this.setSelectedValues(value, true);
617
- }
618
- else {
619
- const exists = this.selectedValues.slice(0);
620
- if (exists.includes(value)) {
621
- if (this.allowNull == true ||
622
- (this.allowNull == false && this.selectedItems.length > 1)) {
623
- this.handleItemRemoveClick(item);
624
- }
625
- }
626
- else {
627
- exists.push(value);
628
- // this.selectedValues = exists;
629
- this.setSelectedValues(exists, true);
630
- }
631
- }
632
- if (this.mode == 'single') {
633
- this.text = '';
634
- this.dropdown.close();
635
- this.cdr.markForCheck();
636
- }
637
- // if (e.stopPropagation() == undefined) {
638
- // e.stopPropagation();
639
- // }
640
- setTimeout(() => {
641
- if (this.serchBox) {
642
- this.serchBox.focus();
643
- }
644
- }, 0);
645
- }
646
- e.stopPropagation();
647
- }
648
- handleKeyEventSearch(e) {
649
- if (this.disabled || this.readonly) {
650
- this.dropdown.close();
651
- setTimeout(() => {
652
- this.textBoxSelectBox.focus();
653
- }, 0);
654
- return false;
655
- }
656
- if (e.key === 'Escape') {
657
- this.text = null;
658
- setTimeout(() => {
659
- this.textBoxSelectBox.focus();
660
- }, 0);
661
- }
662
- if ((e.key === 'ArrowDown' || e.key === 'ArrowUp') &&
663
- this.getItems().length > 0 &&
664
- e.type === 'keydown') {
665
- if (this.mode === 'single') {
666
- this.currentfocusedIndex =
667
- this.currentfocusedIndex + (e.key === 'ArrowDown' ? 1 : -1);
668
- this.selectedItemByIndex(this.currentfocusedIndex);
669
- }
670
- else {
671
- if (this.dropdown.isOpen) {
672
- this.setSelectedIndex(e.key === 'ArrowDown' ? 1 : -1);
673
- }
674
- else {
675
- this.dropdown.open();
676
- setTimeout(() => {
677
- if (this.serchBox) {
678
- this.serchBox.focus();
679
- }
680
- }, 0);
681
- }
682
- }
683
- }
684
- // if (e.key == 'Enter' && this.dropdown.isOpen && this.mode == 'single') {
685
- // this.dropdown.close();
686
- // setTimeout(() => {
687
- // this.dropdown.focus();
688
- // }, 0);
689
- // }
690
- //e.stopPropagation();
691
- //e.preventDefault();
692
- e.stopImmediatePropagation();
693
- if (e.type === 'keydown' && e.key == 'Enter' && this.dropdown.isOpen) {
694
- if (!this.remoteOperation && this.text && this.text !== '') {
695
- this.itemsFiltered = this.items.filter((c) => c[this.textField]
696
- .toLowerCase()
697
- .includes(this.text.toLowerCase()));
698
- if (this.itemsFiltered.length === 1) {
699
- this.currentfocusedIndex = 0;
700
- }
701
- }
702
- else {
703
- this.itemsFiltered = this.items;
704
- }
705
- if (this.selectedItems.filter((c) => c[this.valueField] ===
706
- this.itemsFiltered[this.currentfocusedIndex][this.valueField]).length > 0 &&
707
- this.mode == 'multiple') {
708
- if (this.allowNull == true ||
709
- (this.allowNull == false && this.selectedItems.length > 1)) {
710
- if (!this.remoteOperation && this.text && this.text !== '') {
711
- this.selectedItems = this.selectedItems.filter((c) => c !==
712
- this.items.filter((c) => c[this.textField]
713
- .toLowerCase()
714
- .includes(this.text.toLowerCase()))[this.currentfocusedIndex]);
715
- }
716
- else {
717
- this.selectedItems = this.selectedItems.filter((c) => c[this.valueField] !==
718
- this.items[this.currentfocusedIndex][this.valueField]);
719
- }
720
- this.emitSelectionChangedEvent();
721
- }
722
- }
723
- else {
724
- if (this.mode == 'multiple') {
725
- if (this.currentfocusedIndex != -1) {
726
- if (!this.remoteOperation && this.text && this.text !== '') {
727
- if (this.itemsFiltered.length === 1) {
728
- this.selectedItems.push(this.itemsFiltered[0]);
729
- }
730
- else {
731
- this.selectedItems.push(this.itemsFiltered[this.currentfocusedIndex]);
732
- }
733
- }
734
- else {
735
- this.selectedItems.push(this.items[this.currentfocusedIndex]);
736
- }
737
- this.emitSelectionChangedEvent();
738
- }
739
- }
740
- else {
741
- if (this.text && this.itemsFiltered?.length === 1) {
742
- this.setSelectedItems(this.itemsFiltered, true);
743
- }
744
- if (this.mode == 'single') {
745
- this.dropdown.close();
746
- setTimeout(() => {
747
- this.textBoxSelectBox.focus();
748
- }, 0);
749
- }
750
- }
751
- }
752
- e.stopPropagation();
753
- e.preventDefault();
754
- e.stopImmediatePropagation();
755
- }
756
- this.cdr.markForCheck();
757
- }
758
- isChar(str) {
759
- if (str.includes('Shift') ||
760
- str.includes('Tab') ||
761
- str.includes('Control') ||
762
- str.includes('Alt') ||
763
- str.includes('CapsLock') ||
764
- str.includes('Meta') ||
765
- str.includes('ContextMenu') ||
766
- str.includes('Enter') ||
767
- str.includes('Backspace') ||
768
- str.includes('PrintScreen') ||
769
- str.includes('ScrollLock') ||
770
- str.includes('Pause') ||
771
- str.includes('Home') ||
772
- str.includes('End') ||
773
- str.includes('Insert') ||
774
- str.includes('PageUp') ||
775
- str.includes('Delete') ||
776
- str.includes('PageDown') ||
777
- str.includes('NumLock') ||
778
- str.includes('Escape') ||
779
- str.includes('Arrow') ||
780
- str.includes('ّF1') ||
781
- str.includes('F2') ||
782
- str.includes('F3') ||
783
- str.includes('F4') ||
784
- str.includes('F5') ||
785
- str.includes('F6') ||
786
- str.includes('F7') ||
787
- str.includes('F8') ||
788
- str.includes('F9') ||
789
- str.includes('F10') ||
790
- str.includes('F11') ||
791
- str.includes('F12')) {
792
- return false;
793
- }
794
- else {
795
- return true;
796
- }
797
- }
798
- handleKeyEvent(e) {
799
- // const NumberMinusPattern = /[a-zA-Z0-9\-]/g;
800
- // const Farsi = /[پچجحخهعغفقثصضشسیبلاتنمکگوئدذرزطظژؤإأءًٌٍَُِّ\s]+$/;
801
- // const inputChar = String.fromCharCode(e.charCode);
802
- // const patternEn = /^[a-zA-Z0-9]*$/;
803
- // const pattern = /^[\u0600-\u06FF\s]+$/;
804
- const inputChar = e.key;
805
- if ((inputChar != 'Backspace' &&
806
- inputChar != 'Backspace' &&
807
- inputChar != 'Tab' &&
808
- inputChar != 'Enter' &&
809
- inputChar != 'Escape' &&
810
- inputChar != 'ArrowDown' &&
811
- inputChar != 'ArrowUp') ||
812
- e.code === 'Space' ||
813
- e.ctrlKey == true) {
814
- e.preventDefault();
815
- }
816
- if (e.key === 'Backspace' &&
817
- e.type === 'keydown' &&
818
- ((this.allowNull === true && this.selectedItems.length > 0) ||
819
- (this.allowNull === false && this.selectedItems.length > 1))) {
820
- this.selectedItems.pop();
821
- this.emitSelectionChangedEvent();
822
- }
823
- if (this.disabled || this.readonly) {
824
- this.dropdown.close();
825
- setTimeout(() => {
826
- this.textBoxSelectBox.focus();
827
- }, 0);
828
- return false;
829
- }
830
- const INPUT = String.fromCharCode(e.keyCode);
831
- if (this.isChar(e.key) && this.allowSearch && e.ctrlKey == false) {
832
- this.dropdown.open();
833
- setTimeout(() => {
834
- if (this.serchBox) {
835
- this.serchBox.focus();
836
- }
837
- }, 0);
838
- this.text = e.key;
839
- }
840
- if (e.key === 'Escape') {
841
- this.text = null;
842
- this.dropdown.close();
843
- setTimeout(() => {
844
- this.textBoxSelectBox.focus();
845
- }, 0);
846
- }
847
- if ((e.key === 'ArrowDown' || e.key === 'ArrowUp') &&
848
- this.getItems().length > 0 &&
849
- e.type === 'keydown') {
850
- if (this.mode === 'single') {
851
- this.selectedItemByIndex(this.currentfocusedIndex + (e.key === 'ArrowDown' ? 1 : -1));
852
- }
853
- else {
854
- if (this.dropdown.isOpen) {
855
- // this.setSelectedIndex((e.key === 'ArrowDown' ? 1 : -1));
856
- if (this.allowSearch == false) {
857
- this.setSelectedIndex(e.key === 'ArrowDown' ? 1 : -1);
858
- }
859
- else {
860
- setTimeout(() => {
861
- if (this.serchBox) {
862
- this.serchBox.focus();
863
- }
864
- }, 0);
865
- }
866
- }
867
- else {
868
- this.dropdown.open();
869
- if (this.allowSearch == true) {
870
- setTimeout(() => {
871
- if (this.serchBox) {
872
- this.serchBox.focus();
873
- }
874
- }, 0);
875
- }
876
- }
877
- }
878
- }
879
- if (this.allowSearch === false) {
880
- if (e.type === 'keydown' && e.key == 'Enter' && this.dropdown.isOpen) {
881
- e.stopImmediatePropagation();
882
- if (this.selectedItems.filter((c) => c[this.valueField] ===
883
- this.itemsFiltered[this.currentfocusedIndex][this.valueField]).length > 0 &&
884
- this.mode == 'multiple') {
885
- if (this.allowNull == true ||
886
- (this.allowNull == false && this.selectedItems.length > 1)) {
887
- if (!this.remoteOperation && this.text && this.text !== '') {
888
- this.selectedItems = this.selectedItems.filter((c) => c !==
889
- this.items.filter((c) => c[this.textField]
890
- .toLowerCase()
891
- .includes(this.text.toLowerCase()))[this.currentfocusedIndex]);
892
- }
893
- else {
894
- this.selectedItems = this.selectedItems.filter((c) => c[this.valueField] !==
895
- this.items[this.currentfocusedIndex][this.valueField]);
896
- }
897
- this.emitSelectionChangedEvent();
898
- }
899
- }
900
- else {
901
- if (this.mode == 'multiple') {
902
- if (this.currentfocusedIndex != -1) {
903
- if (!this.remoteOperation && this.text && this.text !== '') {
904
- if (this.itemsFiltered.length === 1) {
905
- this.selectedItems.push(this.itemsFiltered[0]);
906
- }
907
- else {
908
- this.selectedItems.push(this.itemsFiltered[this.currentfocusedIndex]);
909
- }
910
- }
911
- else {
912
- this.selectedItems.push(this.items[this.currentfocusedIndex]);
913
- }
914
- this.emitSelectionChangedEvent();
915
- }
916
- }
917
- else {
918
- if (this.text && this.itemsFiltered.length === 1) {
919
- this.setSelectedItems(this.itemsFiltered, true);
920
- }
921
- if (this.mode == 'single') {
922
- this.dropdown.close();
923
- setTimeout(() => {
924
- this.textBoxSelectBox.focus();
925
- }, 0);
926
- }
927
- }
928
- }
929
- }
930
- }
931
- this.cdr.markForCheck();
932
- }
933
- focus() {
934
- this.textbox.focus();
935
- }
936
- selectedItemByIndex(index) {
937
- let item = [];
938
- if (!this.remoteOperation && this.text && this.text !== '') {
939
- this.itemsFiltered = this.items.filter((c) => c[this.textField]
940
- .toLowerCase()
941
- .includes(this.text.toLowerCase()));
942
- item = this.itemsFiltered[index];
943
- }
944
- else {
945
- item = this.items[index];
946
- }
947
- //
948
- // const item = this.text ? this.items.filter((c) => (c[this.textField] as string).toLowerCase().includes(this.text.toLowerCase()))[index] : this.items[index];
949
- if (item) {
950
- this.setSelectedItems([item], true);
951
- }
952
- this.setSelectedIndex();
953
- }
954
- noAccentOrigin = {
955
- ك: 'ک',
956
- ﻷ: 'لا',
957
- ؤ: 'و',
958
- ى: 'ی',
959
- ي: 'ی',
960
- ئ: 'ی',
961
- أ: 'ا',
962
- إ: 'ا',
963
- آ: 'ا',
964
- ٱ: 'ا',
965
- ٳ: 'ا',
966
- ة: 'ه',
967
- ء: '',
968
- 'ِ': '',
969
- 'ْ': '',
970
- 'ُ': '',
971
- 'َ': '',
972
- 'ّ': '',
973
- 'ٍ': '',
974
- 'ً': '',
975
- 'ٌ': '',
976
- 'ٓ': '',
977
- 'ٰ': '',
978
- 'ٔ': '',
979
- '�': '',
980
- };
981
- getItems() {
982
- if (this.items == null) {
983
- return [];
984
- }
985
- if (!this.remoteOperation && this.text && this.text !== '') {
986
- return this.items.filter((c) => {
987
- const convertedTextField = this.convertArabicToPersian(c[this.textField], this.noAccentOrigin);
988
- const convertedText = this.convertArabicToPersian(this.text, this.noAccentOrigin);
989
- return convertedTextField
990
- .toLowerCase()
991
- .includes(convertedText.toLowerCase());
992
- });
993
- }
994
- else {
995
- return this.items;
996
- }
997
- }
998
- convertArabicToPersian(inputString, conversionMap) {
999
- let textConvert = '';
1000
- for (let i = 0; i < inputString.length; i++) {
1001
- const currentChar = inputString[i];
1002
- if (conversionMap[currentChar]) {
1003
- textConvert += conversionMap[currentChar];
1004
- }
1005
- else {
1006
- textConvert += currentChar;
1007
- }
1008
- }
1009
- return textConvert;
1010
- }
1011
- isItemSelected(item) {
1012
- return (this.selectedItems &&
1013
- this.selectedItems.filter((c) => c[this.valueField] === item[this.valueField]).length > 0);
1014
- }
1015
- itemsStatusObserver;
1016
- waitForData(callbackfn) {
1017
- if (this.items && this.items.length) {
1018
- callbackfn();
1019
- }
1020
- else if (!this.itemsStatusObserver) {
1021
- Observable.create((observer) => {
1022
- this.itemsStatusObserver = observer;
1023
- })
1024
- .pipe(debounceTime(100))
1025
- .pipe(distinctUntilChanged())
1026
- .subscribe((c) => {
1027
- callbackfn();
1028
- });
1029
- }
1030
- }
1031
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: AXSelectBoxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
1032
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.7", type: AXSelectBoxComponent, selector: "ax-select-box", inputs: { showDropDownButton: "showDropDownButton", rowInputTemplate: "rowInputTemplate", showCheckBox: "showCheckBox", readonly: "readonly", rtl: "rtl", disabled: "disabled", placeholder: "placeholder", size: "size", allowNull: "allowNull", textAlign: "textAlign", bufferSize: "bufferSize", remoteOperation: "remoteOperation", fitParent: "fitParent", dropdownWidth: "dropdownWidth", multiLine: "multiLine", onDemandTranslate: "onDemandTranslate", dataSource: "dataSource", validation: "validation", disabledCallback: "disabledCallback", allowSearch: "allowSearch", textField: "textField", valueField: "valueField", disabledField: "disabledField", mode: "mode", items: "items", selectedItems: "selectedItems", selectedValues: "selectedValues" }, outputs: { dropdownToggle: "dropdownToggle", itemsChange: "itemsChange", onBlur: "onBlur", onFocus: "onFocus", selectionChanged: "selectionChanged", selectedItemsChange: "selectedItemsChange", selectedValuesChange: "selectedValuesChange" }, host: { styleAttribute: "width: 100%" }, providers: [
1033
- { provide: AXValidatableComponent, useExisting: AXSelectBoxComponent },
1034
- ], queries: [{ propertyName: "rowTemplate", first: true, predicate: TemplateRef, descendants: true, static: true }, { propertyName: "_contentDataSource", first: true, predicate: AXDataSourceComponent, descendants: true, static: true }, { propertyName: "_contentValidation", first: true, predicate: AXValidation, descendants: true, static: true }], viewQueries: [{ propertyName: "span", first: true, predicate: AXTextBoxComponent, descendants: true, static: true }, { propertyName: "textbox", first: true, predicate: AXTextBoxComponent, descendants: true, static: true }, { propertyName: "listContainer", first: true, predicate: ["listContainer"], descendants: true, static: true }, { propertyName: "serchBox", first: true, predicate: ["serchBox"], descendants: true }, { propertyName: "textBoxSelectBox", first: true, predicate: ["textBoxSelectBox"], descendants: true, static: true }, { propertyName: "dropdown", first: true, predicate: ["d"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ax-drop-down\n #d\n [size]=\"size\"\n [fitParent]=\"fitParent\"\n [dropdownWidth]=\"dropdownWidth\"\n [rtl]=\"rtl\"\n [showDropDownButton]=\"showDropDownButton\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n (dropdownToggle)=\"dropdownToggleSelecBox($event)\"\n>\n <ng-container start>\n <ng-content select=\"[start]\"> </ng-content>\n </ng-container>\n <ng-container header>\n <div\n class=\"ax chips-container\"\n [class.multiline]=\"multiLine\"\n [style.padding]=\"selectedItems.length && multiLine ? '0.25rem' : ''\"\n >\n <div\n class=\"chips\"\n [class.chips-blank]=\"mode === 'single'\"\n [title]=\"item[textField]\"\n *ngFor=\"let item of selectedItems\"\n >\n <span\n class=\"chips-text\"\n [ngStyle]=\"{\n width:\n item[textField].length > 15 &&\n this.mode === 'multiple' &&\n !multiLine\n ? '110px'\n : 'auto'\n }\"\n >\n {{ item[textField] }}\n </span>\n <span\n class=\"close-icon\"\n (click)=\"handleItemRemoveClick(item)\"\n *ngIf=\"\n (readonly != true || itemRemove == true) &&\n disabled != true &&\n (allowNull == true || selectedItems.length > 1)\n \"\n >\n <i class=\"far fa-times close\"></i>\n </span>\n </div>\n <div class=\"search-wrapper\" (click)=\"onTextBoxClick($event)\">\n <ax-text-box\n #textBoxSelectBox\n [textAlign]=\"textAlign\"\n [placeholder]=\"selectedItems.length == 0 ? placeholder : ''\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n (onkey)=\"handleKeyEvent($event)\"\n [size]=\"size\"\n (onFocus)=\"onFocusTextBox($event)\"\n >\n </ax-text-box>\n </div>\n </div>\n </ng-container>\n <ng-container end>\n <ng-content select=\"[end]\"> </ng-content>\n </ng-container>\n\n <ng-container panel>\n <div *ngIf=\"allowSearch\" class=\"search-wrapper\" style=\"padding: 0.7em\">\n <ax-search-box\n #serchBox\n [onDemandTranslate]=\"onDemandTranslate\"\n [(value)]=\"text\"\n (onkey)=\"handleKeyEventSearch($event)\"\n (textChanged)=\"textChanged($event)\"\n (onButtonClick)=\"textChanged($event)\"\n >\n </ax-search-box>\n </div>\n <div class=\"ax list-container\">\n <div\n #listContainer\n class=\"list-container-items\"\n (scroll)=\"scrolled($event)\"\n >\n <ng-container\n *ngIf=\"getItems().length > 0; then thenTemplate; else elseTemplate\"\n ></ng-container>\n <ng-template #thenTemplate>\n <div\n [class.ax-state-disabled]=\"isItemDisabled(item)\"\n class=\"list-item\"\n *ngFor=\"let item of getItems(); let i = index\"\n [class.focused]=\"i == currentfocusedIndex\"\n [class.selected]=\"isItemSelected(item)\"\n (click)=\"handleItemClick($event, item)\"\n >\n <div style=\"display: flex\">\n <ax-check-box\n *ngIf=\"showCheckBox\"\n [size]=\"size\"\n [value]=\"isItemSelected(item)\"\n [disabled]=\"\n (!allowNull &&\n selectedItems.length === 1 &&\n isItemSelected(item)) ||\n isItemDisabled(item)\n \"\n (onClick)=\"handleItemClick($event, item)\"\n >\n </ax-check-box>\n <ng-container *ngIf=\"rowTemplate; else elseTemplate\">\n <div\n style=\"\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n flex: 1;\n \"\n [title]=\"item[textField]\"\n [ngStyle]=\"\n showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n rowTemplate;\n context: { $implicit: item }\n \"\n >\n </ng-container>\n </div>\n </ng-container>\n <ng-template #elseTemplate>\n <div\n style=\"\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n flex: 1;\n \"\n [title]=\"item[textField]\"\n [ngStyle]=\"\n showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n \"\n >\n {{ item[textField] }}\n </div>\n </ng-template>\n </div>\n </div>\n </ng-template>\n <div *ngIf=\"showLoading\" class=\"ax-pad-sm\" style=\"text-align: center\">\n <i\n class=\"far fa-spinner-third fa-pulse fa-2x\"\n style=\"color: var(--ax-primary-color)\"\n ></i>\n </div>\n <!-- <ax-loading-indicator ></ax-loading-indicator> -->\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"\n showLoading == true;\n then searchTemplate;\n else noDataTemplate\n \"\n ></ng-container>\n <ng-template #searchTemplate>\n <div class=\"list-item\">\n {{ 'common.search' | trans }}\n </div>\n </ng-template>\n <ng-template #noDataTemplate>\n <div class=\"list-item\">\n {{ 'common.noDataFound' | trans }}\n </div>\n </ng-template>\n </ng-template>\n </div>\n </div>\n </ng-container>\n</ax-drop-down>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.AXDropdownComponent, selector: "ax-drop-down", inputs: ["rtl", "readonly", "loading", "dropdownWidth"], outputs: ["dropdownToggle", "onButtonClick"] }, { kind: "component", type: i3.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "showMask", "type", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { kind: "component", type: i4.AXCheckBoxComponent, selector: "ax-check-box", inputs: ["readonly", "disabled", "size", "label", "tabIndex", "indeterminate", "useTreeView", "value"], outputs: ["onValueChanged", "valueChange", "onClick"] }, { kind: "component", type: i5.AXSearchBoxComponent, selector: "ax-search-box", inputs: ["placeholder", "onDemandTranslate", "text", "delay"], outputs: ["textChanged", "onButtonClick"] }, { kind: "pipe", type: i6.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1035
- }
1036
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: AXSelectBoxComponent, decorators: [{
1037
- type: Component,
1038
- args: [{ selector: 'ax-select-box', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: { style: 'width: 100%' }, providers: [
1039
- { provide: AXValidatableComponent, useExisting: AXSelectBoxComponent },
1040
- ], template: "<ax-drop-down\n #d\n [size]=\"size\"\n [fitParent]=\"fitParent\"\n [dropdownWidth]=\"dropdownWidth\"\n [rtl]=\"rtl\"\n [showDropDownButton]=\"showDropDownButton\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n (dropdownToggle)=\"dropdownToggleSelecBox($event)\"\n>\n <ng-container start>\n <ng-content select=\"[start]\"> </ng-content>\n </ng-container>\n <ng-container header>\n <div\n class=\"ax chips-container\"\n [class.multiline]=\"multiLine\"\n [style.padding]=\"selectedItems.length && multiLine ? '0.25rem' : ''\"\n >\n <div\n class=\"chips\"\n [class.chips-blank]=\"mode === 'single'\"\n [title]=\"item[textField]\"\n *ngFor=\"let item of selectedItems\"\n >\n <span\n class=\"chips-text\"\n [ngStyle]=\"{\n width:\n item[textField].length > 15 &&\n this.mode === 'multiple' &&\n !multiLine\n ? '110px'\n : 'auto'\n }\"\n >\n {{ item[textField] }}\n </span>\n <span\n class=\"close-icon\"\n (click)=\"handleItemRemoveClick(item)\"\n *ngIf=\"\n (readonly != true || itemRemove == true) &&\n disabled != true &&\n (allowNull == true || selectedItems.length > 1)\n \"\n >\n <i class=\"far fa-times close\"></i>\n </span>\n </div>\n <div class=\"search-wrapper\" (click)=\"onTextBoxClick($event)\">\n <ax-text-box\n #textBoxSelectBox\n [textAlign]=\"textAlign\"\n [placeholder]=\"selectedItems.length == 0 ? placeholder : ''\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n (onkey)=\"handleKeyEvent($event)\"\n [size]=\"size\"\n (onFocus)=\"onFocusTextBox($event)\"\n >\n </ax-text-box>\n </div>\n </div>\n </ng-container>\n <ng-container end>\n <ng-content select=\"[end]\"> </ng-content>\n </ng-container>\n\n <ng-container panel>\n <div *ngIf=\"allowSearch\" class=\"search-wrapper\" style=\"padding: 0.7em\">\n <ax-search-box\n #serchBox\n [onDemandTranslate]=\"onDemandTranslate\"\n [(value)]=\"text\"\n (onkey)=\"handleKeyEventSearch($event)\"\n (textChanged)=\"textChanged($event)\"\n (onButtonClick)=\"textChanged($event)\"\n >\n </ax-search-box>\n </div>\n <div class=\"ax list-container\">\n <div\n #listContainer\n class=\"list-container-items\"\n (scroll)=\"scrolled($event)\"\n >\n <ng-container\n *ngIf=\"getItems().length > 0; then thenTemplate; else elseTemplate\"\n ></ng-container>\n <ng-template #thenTemplate>\n <div\n [class.ax-state-disabled]=\"isItemDisabled(item)\"\n class=\"list-item\"\n *ngFor=\"let item of getItems(); let i = index\"\n [class.focused]=\"i == currentfocusedIndex\"\n [class.selected]=\"isItemSelected(item)\"\n (click)=\"handleItemClick($event, item)\"\n >\n <div style=\"display: flex\">\n <ax-check-box\n *ngIf=\"showCheckBox\"\n [size]=\"size\"\n [value]=\"isItemSelected(item)\"\n [disabled]=\"\n (!allowNull &&\n selectedItems.length === 1 &&\n isItemSelected(item)) ||\n isItemDisabled(item)\n \"\n (onClick)=\"handleItemClick($event, item)\"\n >\n </ax-check-box>\n <ng-container *ngIf=\"rowTemplate; else elseTemplate\">\n <div\n style=\"\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n flex: 1;\n \"\n [title]=\"item[textField]\"\n [ngStyle]=\"\n showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"\n rowTemplate;\n context: { $implicit: item }\n \"\n >\n </ng-container>\n </div>\n </ng-container>\n <ng-template #elseTemplate>\n <div\n style=\"\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n flex: 1;\n \"\n [title]=\"item[textField]\"\n [ngStyle]=\"\n showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n \"\n >\n {{ item[textField] }}\n </div>\n </ng-template>\n </div>\n </div>\n </ng-template>\n <div *ngIf=\"showLoading\" class=\"ax-pad-sm\" style=\"text-align: center\">\n <i\n class=\"far fa-spinner-third fa-pulse fa-2x\"\n style=\"color: var(--ax-primary-color)\"\n ></i>\n </div>\n <!-- <ax-loading-indicator ></ax-loading-indicator> -->\n <ng-template #elseTemplate>\n <ng-container\n *ngIf=\"\n showLoading == true;\n then searchTemplate;\n else noDataTemplate\n \"\n ></ng-container>\n <ng-template #searchTemplate>\n <div class=\"list-item\">\n {{ 'common.search' | trans }}\n </div>\n </ng-template>\n <ng-template #noDataTemplate>\n <div class=\"list-item\">\n {{ 'common.noDataFound' | trans }}\n </div>\n </ng-template>\n </ng-template>\n </div>\n </div>\n </ng-container>\n</ax-drop-down>\n" }]
1041
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }], propDecorators: { showDropDownButton: [{
1042
- type: Input
1043
- }], rowTemplate: [{
1044
- type: ContentChild,
1045
- args: [TemplateRef, { static: true }]
1046
- }], rowInputTemplate: [{
1047
- type: Input
1048
- }], span: [{
1049
- type: ViewChild,
1050
- args: [AXTextBoxComponent, { static: true }]
1051
- }], textbox: [{
1052
- type: ViewChild,
1053
- args: [AXTextBoxComponent, { static: true }]
1054
- }], listContainer: [{
1055
- type: ViewChild,
1056
- args: ['listContainer', { static: true }]
1057
- }], serchBox: [{
1058
- type: ViewChild,
1059
- args: ['serchBox', { static: false }]
1060
- }], textBoxSelectBox: [{
1061
- type: ViewChild,
1062
- args: ['textBoxSelectBox', { static: true }]
1063
- }], showCheckBox: [{
1064
- type: Input
1065
- }], readonly: [{
1066
- type: Input
1067
- }], rtl: [{
1068
- type: Input
1069
- }], disabled: [{
1070
- type: Input
1071
- }], placeholder: [{
1072
- type: Input
1073
- }], size: [{
1074
- type: Input
1075
- }], allowNull: [{
1076
- type: Input
1077
- }], textAlign: [{
1078
- type: Input
1079
- }], bufferSize: [{
1080
- type: Input
1081
- }], remoteOperation: [{
1082
- type: Input
1083
- }], fitParent: [{
1084
- type: Input
1085
- }], dropdownWidth: [{
1086
- type: Input
1087
- }], multiLine: [{
1088
- type: Input
1089
- }], dropdownToggle: [{
1090
- type: Output
1091
- }], onDemandTranslate: [{
1092
- type: Input
1093
- }], _contentDataSource: [{
1094
- type: ContentChild,
1095
- args: [AXDataSourceComponent, { static: true }]
1096
- }], dataSource: [{
1097
- type: Input
1098
- }], _contentValidation: [{
1099
- type: ContentChild,
1100
- args: [AXValidation, { static: true }]
1101
- }], validation: [{
1102
- type: Input
1103
- }], dropdown: [{
1104
- type: ViewChild,
1105
- args: ['d', { static: true }]
1106
- }], disabledCallback: [{
1107
- type: Input
1108
- }], allowSearch: [{
1109
- type: Input
1110
- }], textField: [{
1111
- type: Input
1112
- }], valueField: [{
1113
- type: Input
1114
- }], disabledField: [{
1115
- type: Input
1116
- }], mode: [{
1117
- type: Input
1118
- }], itemsChange: [{
1119
- type: Output
1120
- }], onBlur: [{
1121
- type: Output
1122
- }], onFocus: [{
1123
- type: Output
1124
- }], items: [{
1125
- type: Input
1126
- }], selectionChanged: [{
1127
- type: Output
1128
- }], selectedItemsChange: [{
1129
- type: Output
1130
- }], selectedItems: [{
1131
- type: Input
1132
- }], selectedValuesChange: [{
1133
- type: Output
1134
- }], selectedValues: [{
1135
- type: Input
1136
- }] } });
1137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectbox.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/selectbox/selectbox.component.ts","../../../../../../libs/components/src/lib/selectbox/selectbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from '@acorex/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { differenceBy } from 'lodash';\nimport { Observable } from 'rxjs';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport {\n  AXBaseInputComponent,\n  AXBaseSizableComponent,\n  AXElementSize,\n  AXValidatableComponent,\n} from '../base/element.class';\nimport { AXBaseEvent } from '../base/events.class';\nimport { AXDataSourceComponent } from '../data-source/datasource.component';\nimport { AXDataSourceReadParams } from '../data-source/read-param';\nimport { AXDropdownComponent } from '../dropdown/dropdown.component';\nimport { AXSearchBoxComponent } from '../searchbox/searchbox.component';\nimport { AXTextBoxComponent } from '../textbox/textbox.component';\nimport { AXValidation } from '../validation/validation.component';\nexport class AXSelectBoxSelectionChangedEvent extends AXBaseEvent {\n  constructor(\n    component: any,\n    public selectedItems: any[],\n    public selectedValues: any[] | any\n  ) {\n    super();\n    this.component = component;\n  }\n}\n\n@Component({\n  selector: 'ax-select-box',\n  templateUrl: './selectbox.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { style: 'width: 100%' },\n  providers: [\n    { provide: AXValidatableComponent, useExisting: AXSelectBoxComponent },\n  ],\n})\nexport class AXSelectBoxComponent\n  extends AXValidatableComponent\n  implements AXBaseSizableComponent, AXBaseInputComponent\n{\n  componentName = 'selectBox';\n\n  @Input() showDropDownButton: boolean = true;\n\n  @ContentChild(TemplateRef, { static: true })\n  rowTemplate: TemplateRef<any>;\n\n  @Input()\n  rowInputTemplate: TemplateRef<any>;\n  @ViewChild(AXTextBoxComponent, { static: true })\n  span: ElementRef<HTMLElement>;\n\n  @ViewChild(AXTextBoxComponent, { static: true })\n  textbox: AXTextBoxComponent;\n\n  @ViewChild('listContainer', { static: true })\n  listContainer: ElementRef<HTMLDivElement>;\n\n  @ViewChild('serchBox', { static: false })\n  serchBox: AXSearchBoxComponent;\n\n  @ViewChild('textBoxSelectBox', { static: true })\n  textBoxSelectBox: AXTextBoxComponent;\n\n  @Input() showCheckBox: boolean = true;\n\n  @Input() readonly: boolean = false;\n\n  @Input() rtl: boolean = AXConfig.get('layout.rtl');\n\n  @Input() disabled: boolean = false;\n\n  @Input() placeholder: string;\n\n  @Input() size: AXElementSize = 'md';\n\n  @Input() allowNull: boolean = true;\n\n  @Input() textAlign: 'right' | 'left' | null = null;\n\n  @Input() bufferSize: number = 20;\n\n  @Input() remoteOperation: boolean = false;\n\n  @Input() fitParent: boolean = true;\n\n  @Input() dropdownWidth: string = '300px';\n\n  @Input() multiLine = false;\n\n  @Output()\n  dropdownToggle: EventEmitter<any> = new EventEmitter<any>();\n  // this input is Private and only use in LOV\n\n  @Input() onDemandTranslate: boolean = false;\n\n  currentfocusedIndex: number = -1;\n  showLoading: boolean = false;\n\n  skip: number = -1;\n  searchText: string = '';\n  // @Input()\n  // chipsWidth: string = '';\n\n  text: string = '';\n  totalCount: number = 0;\n\n  @ContentChild(AXDataSourceComponent, { static: true })\n  private _contentDataSource: AXDataSourceComponent;\n\n  private _dataSource: AXDataSourceComponent;\n\n  @Input()\n  public get dataSource(): AXDataSourceComponent {\n    return this._dataSource ? this._dataSource : this._contentDataSource;\n  }\n\n  public set dataSource(v: AXDataSourceComponent) {\n    this._dataSource = v;\n  }\n\n  @ContentChild(AXValidation, { static: true })\n  private _contentValidation: AXValidation;\n\n  private _validation: AXValidation;\n\n  @Input()\n  public get validation(): AXValidation {\n    return this._validation ? this._validation : this._contentValidation;\n  }\n\n  public set validation(v: AXValidation) {\n    this._validation = v;\n  }\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private ref: ElementRef,\n    private zone: NgZone\n  ) {\n    super();\n  }\n\n  @ViewChild('d', { static: true })\n  dropdown: AXDropdownComponent;\n\n  @Input() disabledCallback: (e: { item: any; index: number }) => boolean;\n\n  @Input() allowSearch: boolean = true;\n  @Input() textField: string = 'text';\n  @Input() valueField: string = 'value';\n  @Input() disabledField: string = 'disabled';\n  @Input() mode: 'single' | 'multiple' = 'single';\n  itemRemove: boolean = false;\n  @Output() itemsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  @Output() onBlur: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output() onFocus: EventEmitter<any> = new EventEmitter<any>();\n\n  private _items: any[] = [];\n  @Input()\n  public get items(): any[] {\n    return this._items;\n  }\n  public set items(v: any[]) {\n    this._items = v;\n    if (this.itemsChange) {\n      this.itemsChange.emit(v);\n    }\n    if (this.itemsStatusObserver) {\n      this.itemsStatusObserver.next(this.items.length);\n    }\n  }\n\n  hasSelectedValue: boolean = false;\n  itemsFiltered: any[] = [];\n\n  // #endregion\n\n  dropDownDisabled: boolean = false;\n\n  @Output()\n  selectionChanged: EventEmitter<AXSelectBoxSelectionChangedEvent> =\n    new EventEmitter<AXSelectBoxSelectionChangedEvent>();\n\n  @Output()\n  selectedItemsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  private _selectedItems: any[] = [];\n  @Input()\n  public get selectedItems(): any[] {\n    return this._selectedItems || [];\n  }\n  public set selectedItems(v: any[]) {\n    this.setSelectedItemsChange(v);\n    // if (!v) {\n    //   v = [];\n    // }\n\n    // const old = this.selectedItems;\n    // if (JSON.stringify(old) !== JSON.stringify(v)) {\n    //   this._selectedItems = this.mode == 'single' ? v.slice(0, 1) : [...new Set(v)]; //[...new Set(v[0])] : [...new Set(v)];\n    //   this._selectedItems.forEach((c) => (c.selected = true));\n    //   this.selectedItemsChange.emit(this._selectedItems);\n    //   this.selectedValuesChange.emit(this.selectedValues);\n    //   this.clearValidationStyle(this.ref.nativeElement);\n    //   this.waitForData(() => {\n    //     if (this._selectedItems) {\n    //       this.items.forEach((c) => (c.selected = this._selectedItems.some((i) => i[this.valueField] == c[this.valueField])));\n    //     }\n    //   });\n    // }\n  }\n\n  setSelectedItemsChange(v: any[], old: any[] = this.selectedItems) {\n    if (!v) {\n      v = [];\n    }\n    // const old = this.selectedItems;\n    var f = differenceBy(old, v, this.valueField);\n    var s = differenceBy(v, old, this.valueField);\n    // if (JSON.stringify(old) !== JSON.stringify(v)) {\n    if (f.length != 0 || s.length != 0) {\n      this._selectedItems =\n        this.mode == 'single' ? v.slice(0, 1) : [...new Set(v)]; //[...new Set(v[0])] : [...new Set(v)];\n      this._selectedItems.forEach((c) => (c.selected = true));\n      this.selectedItemsChange.emit(this._selectedItems);\n      this.selectedValuesChange.emit(this.selectedValues);\n      this.clearValidationStyle(this.ref.nativeElement);\n      this.waitForData(() => {\n        if (this._selectedItems) {\n          this.items.forEach(\n            (c) =>\n              (c.selected = this._selectedItems.some(\n                (i) => i[this.valueField] == c[this.valueField]\n              ))\n          );\n        }\n      });\n    }\n  }\n\n  ngOnInit() {\n    if (this.rowTemplate === undefined && this.rowInputTemplate != undefined) {\n      this.rowTemplate = this.rowInputTemplate;\n    }\n    if (this.rtl == null) {\n      this.rtl =\n        window\n          .getComputedStyle(this.ref.nativeElement, null)\n          .getPropertyValue('direction') === 'rtl';\n    }\n  }\n\n  scrolled(e) {\n    if (\n      this.remoteOperation &&\n      this.totalCount > this.items.length &&\n      this.listContainer.nativeElement.scrollHeight != 0 &&\n      this.listContainer.nativeElement.scrollHeight -\n        this.listContainer.nativeElement.scrollTop -\n        300 <\n        50\n    ) {\n      if (this.skip !== this.items.length) {\n        this.showLoading = true;\n        this.skip = this.items.length;\n        const params: AXDataSourceReadParams = {};\n        params.skip = this.items.length;\n        params.take = this.bufferSize; //* (Math.floor(this.items.length / this.bufferSize) + 1);\n        if (this.textbox) {\n          params.searchText = this.text;\n        } else {\n          params.searchText = null;\n        }\n        this.fetch(params);\n      }\n    }\n  }\n  private setSelectedItems(v: any[], isUserInput: boolean) {\n    let changed = false;\n    if (isUserInput) {\n      changed = JSON.stringify(v) !== JSON.stringify(this.selectedItems);\n    }\n    this.selectedItems = v;\n    this.setSelectedIndex();\n    if (isUserInput && changed) {\n      this.emitSelectionChangedEvent();\n    }\n  }\n\n  private searchChangeObserver: any;\n\n  delay: number = 500;\n\n  textChanged(e) {\n    if (\n      (e.value === null || e.value === undefined || e.value === '') &&\n      (e.oldValue === null || e.oldValue === undefined || e.oldValue === '')\n    ) {\n    } else {\n      this.currentfocusedIndex = -1;\n      if (this.remoteOperation) {\n        this.searchText = this.text;\n        //  this.searchText = e.value;\n        // this.text = e.value;\n        // this.items = [];\n        if (this.items) {\n          let t = this.items.length;\n          for (let i = 0; i < t; i++) {\n            this.items.pop();\n          }\n        }\n\n        // this.items.forEach((element) => {\n        //   this.items.pop();\n        // });\n        const params: AXDataSourceReadParams = {};\n        params.searchText = this.text;\n        // params.searchText = e.value;\n        params.skip = 0;\n        params.take = this.bufferSize;\n        this.fetch(params);\n      }\n    }\n  }\n\n  isItemDisabled(item: any): boolean {\n    if (item[this.disabledField] == true) {\n      return true;\n    } else if (this.disabledCallback) {\n      return this.disabledCallback({ item, index: -1 });\n    } else {\n      return false;\n    }\n  }\n\n  onButtonClick(e) {}\n\n  private setSelectedIndex(sign: -1 | 1 | null = null): void {\n    if (sign == null) {\n      if (!this.remoteOperation && this.text && this.text !== '') {\n        this.currentfocusedIndex = this.items\n          .filter((c) =>\n            (c[this.textField] as string)\n              .toLowerCase()\n              .includes(this.text.toLowerCase())\n          )\n          .indexOf(this.selectedItems[this.selectedItems.length - 1]);\n      } else {\n        this.currentfocusedIndex = this.items.indexOf(\n          this.selectedItems[this.selectedItems.length - 1]\n        );\n      }\n    } else {\n      sign === -1 ? this.currentfocusedIndex-- : this.currentfocusedIndex++;\n    }\n\n    if (this.remoteOperation) {\n      this.itemsFiltered = this.items;\n    } else {\n      this.itemsFiltered = this.text\n        ? this.items.filter((c) =>\n            (c[this.textField] as string)\n              .toLowerCase()\n              .includes(this.text.toLowerCase())\n          )\n        : this.items;\n    }\n\n    this.currentfocusedIndex =\n      this.currentfocusedIndex < 0\n        ? 0\n        : this.currentfocusedIndex >= this.itemsFiltered.length\n        ? this.itemsFiltered.length - 1\n        : this.currentfocusedIndex;\n    //\n    // set scroll\n    if (this.listContainer) {\n      this.zone.runOutsideAngular(() => {\n        const itemDiv = this.listContainer.nativeElement.querySelector(\n          `.list-item:nth-child(${this.currentfocusedIndex})`\n        );\n        if (itemDiv) {\n          itemDiv.scrollIntoView({ behavior: 'smooth' });\n        }\n      });\n    }\n  }\n\n  @Output()\n  selectedValuesChange: EventEmitter<any[] | any> = new EventEmitter<\n    any[] | any\n  >();\n\n  @Input()\n  public get selectedValues(): any[] | any {\n    if (this.mode === 'single') {\n      return this._selectedItems.map((c) => c[this.valueField])[0];\n    } else {\n      return this._selectedItems.map((c) => c[this.valueField]) || [];\n    }\n  }\n\n  public set selectedValues(v: any[] | any) {\n    if (this.compareSelectedValues(v)) {\n      return;\n    }\n    if (v == null) {\n      this.selectedItems = [];\n    } else {\n      if (v !== undefined) {\n        if (v != []! && v != '' && v != null) {\n          this.hasSelectedValue = true;\n        }\n\n        this.waitForData(() => {\n          if (this.mode === 'single') {\n            if (this.items.filter((c) => v == c[this.valueField])) {\n              this.selectedItems = this.items.filter(\n                (c) => v == c[this.valueField]\n              );\n            } else {\n              this.selectedItems = [];\n            }\n          } else {\n            if (Array.isArray(v)) {\n              if (this.selectedItems.length > v.length) {\n                this.selectedItems = this.selectedItems.filter((c) =>\n                  v.includes(c[this.valueField])\n                );\n              } else {\n                let addId = [];\n                v.forEach((vId) => {\n                  addId.push({\n                    [this.valueField]: vId,\n                  });\n                });\n\n                let newId = differenceBy(\n                  addId,\n                  this.selectedItems,\n                  this.valueField\n                );\n                let vv = [];\n                newId.forEach((rc) => {\n                  vv.push(rc[this.valueField]);\n                });\n                this.items\n                  .filter((c) => vv.includes(c[this.valueField]))\n                  .forEach((res) => {\n                    this.selectedItems.push(res);\n                  });\n                //  this.selectedItems.push(this.items.filter((c) => vv.includes(c[this.valueField])));\n                this.setSelectedItemsChange(\n                  this.selectedItems,\n                  vv.length > 0 ? [1] : this.selectedItems\n                );\n              }\n\n              //  this.selectedItems = this.items.filter((c) => v.includes(c[this.valueField]));\n            } else if (v) {\n              this.selectedItems = this.items.filter(\n                (c) => v === c[this.valueField]\n              );\n            } else {\n              this.selectedItems = [];\n            }\n          }\n          this.selectedValuesChange.emit(this.selectedValues);\n          this.cdr.markForCheck();\n          this.cdr.detectChanges();\n        });\n      }\n    }\n  }\n\n  private compareSelectedValues(newValue: any[] | any) {\n    const currentValue = this.selectedValues;\n    return (\n      (currentValue == null && newValue == null) ||\n      JSON.stringify(currentValue) === JSON.stringify(newValue)\n    );\n  }\n\n  private setSelectedValues(v: any[] | any, isUserInput: boolean) {\n    const changed = isUserInput ? !this.compareSelectedValues(v) : false;\n    this.selectedValues = v;\n    if (isUserInput && changed) {\n      this.emitSelectionChangedEvent();\n    }\n  }\n\n  private emitSelectionChangedEvent() {\n    this.selectedValuesChange.emit(this.selectedValues);\n    this.selectionChanged.emit(\n      new AXSelectBoxSelectionChangedEvent(\n        this,\n        this.selectedItems,\n        this.selectedValues\n      )\n    );\n  }\n\n  ngAfterViewInit(): void {\n    if (this.bufferSize < 10) {\n      this.bufferSize = 10;\n    }\n    if (this.mode == 'single') {\n      this.showCheckBox = false;\n    } else {\n      this.showCheckBox = true;\n    }\n    if (\n      !this.remoteOperation ||\n      (this.remoteOperation && this.hasSelectedValue)\n    ) {\n      this.refresh();\n    }\n  }\n  dropdownToggleSelecBox(e) {\n    this.text = '';\n    if (this.dropdown.isOpen) {\n      this.refresh();\n      setTimeout(() => {\n        if (this.serchBox) {\n          this.serchBox.focus();\n        }\n      }, 1);\n    } else {\n      //  this.refresh();\n    }\n    this.dropdownToggle.emit(e);\n  }\n\n  ngAfterContentInit() {\n    // if (!this.allowSearch) {\n    //     if (this.readonly == false) {\n    //         this.itemRemove = true;\n    //         this.readonly = true;\n    //     }\n    // }\n    this.initValidation(this.ref, 'selectedItems', this.validation);\n    if (this.dataSource) {\n      // if (this.allowSearch == false) {\n      //   this.fetch();\n      // }\n      this.dataSource.onDataReceived.subscribe((c) => {\n        this.showLoading = false;\n        this.dataReceived(c.data.result);\n      });\n    }\n    this.cdr.markForCheck();\n    this.cdr.detectChanges();\n  }\n\n  private dataReceived(data: any) {\n    if (this.remoteOperation) {\n      if (\n        this.searchText &&\n        this.searchText != null &&\n        this.searchText !== ''\n      ) {\n        if (data.totalCount) {\n          if (this.items.length == 0) {\n            //this.items = data.items;\n            data.items.forEach((item) => {\n              this.items.push(item);\n            });\n          } else {\n            data.items.forEach((item) => {\n              if (\n                !this.items.some(\n                  (x) => x[this.valueField] === item[this.valueField]\n                )\n              ) {\n                this.items.push(item);\n              }\n            });\n            // if (this.itemsStatusObserver) {\n            //   this.itemsStatusObserver.next(this.items.length);\n            // }\n          }\n\n          this.totalCount = data.totalCount;\n        } else {\n          if (this.items.length == 0) {\n            this.items = data.items;\n          } else {\n            data.items.forEach((item) => {\n              this.items.push(item);\n            });\n            // if (this.itemsStatusObserver) {\n            //   this.itemsStatusObserver.next(this.items.length);\n            // }\n          }\n          this.totalCount = data.items == undefined ? 0 : data.items.length;\n        }\n      } else if (data.items && data.items.length === data.totalCount) {\n        this.items = data.items;\n        this.totalCount = data.items.length;\n      } else if (data.totalCount) {\n        data.items.forEach((elm) => {\n          this.items.push(elm);\n        });\n        // if (this.itemsStatusObserver) {\n        //   this.itemsStatusObserver.next(this.items.length);\n        // }\n        this.totalCount = data.totalCount;\n      } else {\n        data.forEach((elm) => {\n          this.items.push(elm);\n          // if (this.itemsStatusObserver) {\n          //   this.itemsStatusObserver.next(this.items.length);\n          // }\n        });\n        this.totalCount = data.length;\n      }\n    } else {\n      this.items = data;\n    }\n\n    this.cdr.markForCheck();\n    this.cdr.detectChanges();\n\n    this.dropdown.updatePosition();\n  }\n\n  // private params: AXDataSourceReadParams = {};\n\n  fetch(params: AXDataSourceReadParams = {}) {\n    //  this.params = params;\n    if (this.dataSource) {\n      if (this.onDemandTranslate && params?.searchText) {\n        params.searchText = this.translateSearch(params?.searchText);\n      }\n      this.showLoading = true;\n      this.dataSource.fetch(params);\n    }\n  }\n\n  translateSearch(searchText: string): string {\n    const latinPattern = /[A-Za-z;'\\/\\\\[\\],]/;\n    const asciiToPersianMap = {\n      113: 'ض',\n      119: 'ص',\n      101: 'ث',\n      114: 'ق',\n      116: 'ف',\n      121: 'غ',\n      117: 'ع',\n      105: 'ه',\n      111: 'خ',\n      112: 'ح',\n      97: 'ش',\n      115: 'س',\n      100: 'ی',\n      102: 'ب',\n      103: 'ل',\n      104: 'ا',\n      106: 'ت',\n      107: 'ن',\n      108: 'م',\n      59: 'ک',\n      122: 'ظ',\n      120: 'ط',\n      99: 'ز',\n      118: 'ر',\n      98: 'ذ',\n      110: 'د',\n      44: 'و',\n      39: 'گ',\n      67: 'ژ',\n      93: 'چ',\n      91: 'ج',\n      92: 'پ',\n      109: 'ئ',\n    };\n    if (latinPattern.test(searchText)) {\n      searchText = searchText\n        .split('')\n        .map((char) => {\n          const asciiValue = char.charCodeAt(0);\n          if (asciiToPersianMap[asciiValue]) {\n            return asciiToPersianMap[asciiValue];\n          } else {\n            return char;\n          }\n        })\n        .join('');\n    }\n    return searchText;\n  }\n\n  refresh() {\n    const params: AXDataSourceReadParams = {};\n    if (this.remoteOperation) {\n      params.skip = 0;\n      this.skip = 0;\n      params.take = this.bufferSize;\n    }\n    if (this.dataSource != undefined) {\n      // this.items = [];\n      // this.items.forEach((element) => {\n      //   this.items.pop();\n      // });\n\n      if (this.items) {\n        let t = this.items.length;\n        for (let i = 0; i < t; i++) {\n          this.items.pop();\n        }\n      }\n\n      this.fetch(params);\n    }\n  }\n\n  handleItemRemoveClick(item) {\n    if (this.mode === 'single') {\n      // this.selectedItems = null;\n      this.setSelectedValues(null, true);\n      // this.selectedItemsChange.emit(this._selectedItems);\n      // this.clearValidationStyle(this.ref.nativeElement);\n    } else {\n      // this.selectedItems = this.selectedItems.filter((c) => c !== item);\n      this.setSelectedItems(\n        this.selectedItems.filter(\n          (c) => c[this.valueField] !== item[this.valueField]\n        ),\n        true\n      );\n      // this._selectedItems = this._selectedItems.filter(c => c !== item);\n      // this.selectedItemsChange.emit(this._selectedItems);\n      // this.clearValidationStyle(this.ref.nativeElement);\n    }\n    // this.text = '';\n    this.validate();\n    this.cdr.markForCheck();\n  }\n\n  onFocusTextBox(e) {}\n\n  onTextBoxClick(e) {\n    if (this.disabled == false && this.readonly == false) {\n      this.dropdown.open();\n    }\n  }\n\n  handleItemClick(e: MouseEvent, item: any) {\n    if (this.isItemDisabled(item) == false) {\n      const value = item[this.valueField];\n\n      if (this.mode === 'single') {\n        // this.selectedValues = value;\n        this.setSelectedValues(value, true);\n      } else {\n        const exists = this.selectedValues.slice(0);\n        if (exists.includes(value)) {\n          if (\n            this.allowNull == true ||\n            (this.allowNull == false && this.selectedItems.length > 1)\n          ) {\n            this.handleItemRemoveClick(item);\n          }\n        } else {\n          exists.push(value);\n          // this.selectedValues = exists;\n          this.setSelectedValues(exists, true);\n        }\n      }\n\n      if (this.mode == 'single') {\n        this.text = '';\n        this.dropdown.close();\n        this.cdr.markForCheck();\n      }\n      // if (e.stopPropagation() == undefined) {\n      //     e.stopPropagation();\n      // }\n      setTimeout(() => {\n        if (this.serchBox) {\n          this.serchBox.focus();\n        }\n      }, 0);\n    }\n\n    e.stopPropagation();\n  }\n\n  handleKeyEventSearch(e: KeyboardEvent) {\n    if (this.disabled || this.readonly) {\n      this.dropdown.close();\n      setTimeout(() => {\n        this.textBoxSelectBox.focus();\n      }, 0);\n      return false;\n    }\n    if (e.key === 'Escape') {\n      this.text = null;\n      setTimeout(() => {\n        this.textBoxSelectBox.focus();\n      }, 0);\n    }\n    if (\n      (e.key === 'ArrowDown' || e.key === 'ArrowUp') &&\n      this.getItems().length > 0 &&\n      e.type === 'keydown'\n    ) {\n      if (this.mode === 'single') {\n        this.currentfocusedIndex =\n          this.currentfocusedIndex + (e.key === 'ArrowDown' ? 1 : -1);\n        this.selectedItemByIndex(this.currentfocusedIndex);\n      } else {\n        if (this.dropdown.isOpen) {\n          this.setSelectedIndex(e.key === 'ArrowDown' ? 1 : -1);\n        } else {\n          this.dropdown.open();\n          setTimeout(() => {\n            if (this.serchBox) {\n              this.serchBox.focus();\n            }\n          }, 0);\n        }\n      }\n    }\n    // if (e.key == 'Enter' && this.dropdown.isOpen && this.mode == 'single') {\n    //     this.dropdown.close();\n    //     setTimeout(() => {\n    //         this.dropdown.focus();\n    //     }, 0);\n    // }\n    //e.stopPropagation();\n    //e.preventDefault();\n    e.stopImmediatePropagation();\n    if (e.type === 'keydown' && e.key == 'Enter' && this.dropdown.isOpen) {\n      if (!this.remoteOperation && this.text && this.text !== '') {\n        this.itemsFiltered = this.items.filter((c) =>\n          (c[this.textField] as string)\n            .toLowerCase()\n            .includes(this.text.toLowerCase())\n        );\n        if (this.itemsFiltered.length === 1) {\n          this.currentfocusedIndex = 0;\n        }\n      } else {\n        this.itemsFiltered = this.items;\n      }\n\n      if (\n        this.selectedItems.filter(\n          (c) =>\n            c[this.valueField] ===\n            this.itemsFiltered[this.currentfocusedIndex][this.valueField]\n        ).length > 0 &&\n        this.mode == 'multiple'\n      ) {\n        if (\n          this.allowNull == true ||\n          (this.allowNull == false && this.selectedItems.length > 1)\n        ) {\n          if (!this.remoteOperation && this.text && this.text !== '') {\n            this.selectedItems = this.selectedItems.filter(\n              (c) =>\n                c !==\n                this.items.filter((c) =>\n                  (c[this.textField] as string)\n                    .toLowerCase()\n                    .includes(this.text.toLowerCase())\n                )[this.currentfocusedIndex]\n            );\n          } else {\n            this.selectedItems = this.selectedItems.filter(\n              (c) =>\n                c[this.valueField] !==\n                this.items[this.currentfocusedIndex][this.valueField]\n            );\n          }\n          this.emitSelectionChangedEvent();\n        }\n      } else {\n        if (this.mode == 'multiple') {\n          if (this.currentfocusedIndex != -1) {\n            if (!this.remoteOperation && this.text && this.text !== '') {\n              if (this.itemsFiltered.length === 1) {\n                this.selectedItems.push(this.itemsFiltered[0]);\n              } else {\n                this.selectedItems.push(\n                  this.itemsFiltered[this.currentfocusedIndex]\n                );\n              }\n            } else {\n              this.selectedItems.push(this.items[this.currentfocusedIndex]);\n            }\n            this.emitSelectionChangedEvent();\n          }\n        } else {\n          if (this.text && this.itemsFiltered?.length === 1) {\n            this.setSelectedItems(this.itemsFiltered, true);\n          }\n          if (this.mode == 'single') {\n            this.dropdown.close();\n            setTimeout(() => {\n              this.textBoxSelectBox.focus();\n            }, 0);\n          }\n        }\n      }\n      e.stopPropagation();\n      e.preventDefault();\n      e.stopImmediatePropagation();\n    }\n    this.cdr.markForCheck();\n  }\n\n  isChar(str: string) {\n    if (\n      str.includes('Shift') ||\n      str.includes('Tab') ||\n      str.includes('Control') ||\n      str.includes('Alt') ||\n      str.includes('CapsLock') ||\n      str.includes('Meta') ||\n      str.includes('ContextMenu') ||\n      str.includes('Enter') ||\n      str.includes('Backspace') ||\n      str.includes('PrintScreen') ||\n      str.includes('ScrollLock') ||\n      str.includes('Pause') ||\n      str.includes('Home') ||\n      str.includes('End') ||\n      str.includes('Insert') ||\n      str.includes('PageUp') ||\n      str.includes('Delete') ||\n      str.includes('PageDown') ||\n      str.includes('NumLock') ||\n      str.includes('Escape') ||\n      str.includes('Arrow') ||\n      str.includes('ّF1') ||\n      str.includes('F2') ||\n      str.includes('F3') ||\n      str.includes('F4') ||\n      str.includes('F5') ||\n      str.includes('F6') ||\n      str.includes('F7') ||\n      str.includes('F8') ||\n      str.includes('F9') ||\n      str.includes('F10') ||\n      str.includes('F11') ||\n      str.includes('F12')\n    ) {\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  handleKeyEvent(e: any) {\n    // const NumberMinusPattern = /[a-zA-Z0-9\\-]/g;\n    // const Farsi = /[پچجحخهعغفقثصضشسیبلاتنمکگوئدذرزطظژؤإأءًٌٍَُِّ\\s]+$/;\n    //  const inputChar = String.fromCharCode(e.charCode);\n    // const patternEn = /^[a-zA-Z0-9]*$/;\n    // const pattern = /^[\\u0600-\\u06FF\\s]+$/;\n    const inputChar = e.key;\n    if (\n      (inputChar != 'Backspace' &&\n        inputChar != 'Backspace' &&\n        inputChar != 'Tab' &&\n        inputChar != 'Enter' &&\n        inputChar != 'Escape' &&\n        inputChar != 'ArrowDown' &&\n        inputChar != 'ArrowUp') ||\n      e.code === 'Space' ||\n      e.ctrlKey == true\n    ) {\n      e.preventDefault();\n    }\n    if (\n      e.key === 'Backspace' &&\n      e.type === 'keydown' &&\n      ((this.allowNull === true && this.selectedItems.length > 0) ||\n        (this.allowNull === false && this.selectedItems.length > 1))\n    ) {\n      this.selectedItems.pop();\n      this.emitSelectionChangedEvent();\n    }\n    if (this.disabled || this.readonly) {\n      this.dropdown.close();\n      setTimeout(() => {\n        this.textBoxSelectBox.focus();\n      }, 0);\n      return false;\n    }\n    const INPUT = String.fromCharCode(e.keyCode);\n    if (this.isChar(e.key) && this.allowSearch && e.ctrlKey == false) {\n      this.dropdown.open();\n      setTimeout(() => {\n        if (this.serchBox) {\n          this.serchBox.focus();\n        }\n      }, 0);\n      this.text = e.key;\n    }\n\n    if (e.key === 'Escape') {\n      this.text = null;\n      this.dropdown.close();\n      setTimeout(() => {\n        this.textBoxSelectBox.focus();\n      }, 0);\n    }\n    if (\n      (e.key === 'ArrowDown' || e.key === 'ArrowUp') &&\n      this.getItems().length > 0 &&\n      e.type === 'keydown'\n    ) {\n      if (this.mode === 'single') {\n        this.selectedItemByIndex(\n          this.currentfocusedIndex + (e.key === 'ArrowDown' ? 1 : -1)\n        );\n      } else {\n        if (this.dropdown.isOpen) {\n          //  this.setSelectedIndex((e.key === 'ArrowDown' ? 1 : -1));\n          if (this.allowSearch == false) {\n            this.setSelectedIndex(e.key === 'ArrowDown' ? 1 : -1);\n          } else {\n            setTimeout(() => {\n              if (this.serchBox) {\n                this.serchBox.focus();\n              }\n            }, 0);\n          }\n        } else {\n          this.dropdown.open();\n          if (this.allowSearch == true) {\n            setTimeout(() => {\n              if (this.serchBox) {\n                this.serchBox.focus();\n              }\n            }, 0);\n          }\n        }\n      }\n    }\n\n    if (this.allowSearch === false) {\n      if (e.type === 'keydown' && e.key == 'Enter' && this.dropdown.isOpen) {\n        e.stopImmediatePropagation();\n        if (\n          this.selectedItems.filter(\n            (c) =>\n              c[this.valueField] ===\n              this.itemsFiltered[this.currentfocusedIndex][this.valueField]\n          ).length > 0 &&\n          this.mode == 'multiple'\n        ) {\n          if (\n            this.allowNull == true ||\n            (this.allowNull == false && this.selectedItems.length > 1)\n          ) {\n            if (!this.remoteOperation && this.text && this.text !== '') {\n              this.selectedItems = this.selectedItems.filter(\n                (c) =>\n                  c !==\n                  this.items.filter((c) =>\n                    (c[this.textField] as string)\n                      .toLowerCase()\n                      .includes(this.text.toLowerCase())\n                  )[this.currentfocusedIndex]\n              );\n            } else {\n              this.selectedItems = this.selectedItems.filter(\n                (c) =>\n                  c[this.valueField] !==\n                  this.items[this.currentfocusedIndex][this.valueField]\n              );\n            }\n            this.emitSelectionChangedEvent();\n          }\n        } else {\n          if (this.mode == 'multiple') {\n            if (this.currentfocusedIndex != -1) {\n              if (!this.remoteOperation && this.text && this.text !== '') {\n                if (this.itemsFiltered.length === 1) {\n                  this.selectedItems.push(this.itemsFiltered[0]);\n                } else {\n                  this.selectedItems.push(\n                    this.itemsFiltered[this.currentfocusedIndex]\n                  );\n                }\n              } else {\n                this.selectedItems.push(this.items[this.currentfocusedIndex]);\n              }\n              this.emitSelectionChangedEvent();\n            }\n          } else {\n            if (this.text && this.itemsFiltered.length === 1) {\n              this.setSelectedItems(this.itemsFiltered, true);\n            }\n            if (this.mode == 'single') {\n              this.dropdown.close();\n              setTimeout(() => {\n                this.textBoxSelectBox.focus();\n              }, 0);\n            }\n          }\n        }\n      }\n    }\n\n    this.cdr.markForCheck();\n  }\n\n  focus(): void {\n    this.textbox.focus();\n  }\n\n  selectedItemByIndex(index: number) {\n    let item = [];\n    if (!this.remoteOperation && this.text && this.text !== '') {\n      this.itemsFiltered = this.items.filter((c) =>\n        (c[this.textField] as string)\n          .toLowerCase()\n          .includes(this.text.toLowerCase())\n      );\n\n      item = this.itemsFiltered[index];\n    } else {\n      item = this.items[index];\n    }\n    //\n    //  const item = this.text ? this.items.filter((c) => (c[this.textField] as string).toLowerCase().includes(this.text.toLowerCase()))[index] : this.items[index];\n    if (item) {\n      this.setSelectedItems([item], true);\n    }\n\n    this.setSelectedIndex();\n  }\n\n  noAccentOrigin = {\n    ك: 'ک',\n    ﻷ: 'لا',\n    ؤ: 'و',\n    ى: 'ی',\n    ي: 'ی',\n    ئ: 'ی',\n    أ: 'ا',\n    إ: 'ا',\n    آ: 'ا',\n    ٱ: 'ا',\n    ٳ: 'ا',\n    ة: 'ه',\n    ء: '',\n    'ِ': '',\n    'ْ': '',\n    'ُ': '',\n    'َ': '',\n    'ّ': '',\n    'ٍ': '',\n    'ً': '',\n    'ٌ': '',\n    'ٓ': '',\n    'ٰ': '',\n    'ٔ': '',\n    '�': '',\n  };\n\n  getItems(): any[] {\n    if (this.items == null) {\n      return [];\n    }\n    if (!this.remoteOperation && this.text && this.text !== '') {\n      return this.items.filter((c) => {\n        const convertedTextField = this.convertArabicToPersian(\n          c[this.textField],\n          this.noAccentOrigin\n        );\n        const convertedText = this.convertArabicToPersian(\n          this.text,\n          this.noAccentOrigin\n        );\n        return convertedTextField\n          .toLowerCase()\n          .includes(convertedText.toLowerCase());\n      });\n    } else {\n      return this.items;\n    }\n  }\n\n  convertArabicToPersian(inputString, conversionMap) {\n    let textConvert = '';\n    for (let i = 0; i < inputString.length; i++) {\n      const currentChar = inputString[i];\n      if (conversionMap[currentChar]) {\n        textConvert += conversionMap[currentChar];\n      } else {\n        textConvert += currentChar;\n      }\n    }\n    return textConvert;\n  }\n\n  isItemSelected(item: any): boolean {\n    return (\n      this.selectedItems &&\n      this.selectedItems.filter(\n        (c) => c[this.valueField] === item[this.valueField]\n      ).length > 0\n    );\n  }\n\n  private itemsStatusObserver: any;\n  private waitForData(callbackfn: () => void) {\n    if (this.items && this.items.length) {\n      callbackfn();\n    } else if (!this.itemsStatusObserver) {\n      Observable.create((observer) => {\n        this.itemsStatusObserver = observer;\n      })\n        .pipe(debounceTime(100))\n        .pipe(distinctUntilChanged())\n        .subscribe((c) => {\n          callbackfn();\n        });\n    }\n  }\n}\n","<ax-drop-down\n  #d\n  [size]=\"size\"\n  [fitParent]=\"fitParent\"\n  [dropdownWidth]=\"dropdownWidth\"\n  [rtl]=\"rtl\"\n  [showDropDownButton]=\"showDropDownButton\"\n  [disabled]=\"disabled\"\n  [readonly]=\"readonly\"\n  (dropdownToggle)=\"dropdownToggleSelecBox($event)\"\n>\n  <ng-container start>\n    <ng-content select=\"[start]\"> </ng-content>\n  </ng-container>\n  <ng-container header>\n    <div\n      class=\"ax chips-container\"\n      [class.multiline]=\"multiLine\"\n      [style.padding]=\"selectedItems.length && multiLine ? '0.25rem' : ''\"\n    >\n      <div\n        class=\"chips\"\n        [class.chips-blank]=\"mode === 'single'\"\n        [title]=\"item[textField]\"\n        *ngFor=\"let item of selectedItems\"\n      >\n        <span\n          class=\"chips-text\"\n          [ngStyle]=\"{\n            width:\n              item[textField].length > 15 &&\n              this.mode === 'multiple' &&\n              !multiLine\n                ? '110px'\n                : 'auto'\n          }\"\n        >\n          {{ item[textField] }}\n        </span>\n        <span\n          class=\"close-icon\"\n          (click)=\"handleItemRemoveClick(item)\"\n          *ngIf=\"\n            (readonly != true || itemRemove == true) &&\n            disabled != true &&\n            (allowNull == true || selectedItems.length > 1)\n          \"\n        >\n          <i class=\"far fa-times close\"></i>\n        </span>\n      </div>\n      <div class=\"search-wrapper\" (click)=\"onTextBoxClick($event)\">\n        <ax-text-box\n          #textBoxSelectBox\n          [textAlign]=\"textAlign\"\n          [placeholder]=\"selectedItems.length == 0 ? placeholder : ''\"\n          [readonly]=\"readonly\"\n          [disabled]=\"disabled\"\n          (onkey)=\"handleKeyEvent($event)\"\n          [size]=\"size\"\n          (onFocus)=\"onFocusTextBox($event)\"\n        >\n        </ax-text-box>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container end>\n    <ng-content select=\"[end]\"> </ng-content>\n  </ng-container>\n\n  <ng-container panel>\n    <div *ngIf=\"allowSearch\" class=\"search-wrapper\" style=\"padding: 0.7em\">\n      <ax-search-box\n        #serchBox\n        [onDemandTranslate]=\"onDemandTranslate\"\n        [(value)]=\"text\"\n        (onkey)=\"handleKeyEventSearch($event)\"\n        (textChanged)=\"textChanged($event)\"\n        (onButtonClick)=\"textChanged($event)\"\n      >\n      </ax-search-box>\n    </div>\n    <div class=\"ax list-container\">\n      <div\n        #listContainer\n        class=\"list-container-items\"\n        (scroll)=\"scrolled($event)\"\n      >\n        <ng-container\n          *ngIf=\"getItems().length > 0; then thenTemplate; else elseTemplate\"\n        ></ng-container>\n        <ng-template #thenTemplate>\n          <div\n            [class.ax-state-disabled]=\"isItemDisabled(item)\"\n            class=\"list-item\"\n            *ngFor=\"let item of getItems(); let i = index\"\n            [class.focused]=\"i == currentfocusedIndex\"\n            [class.selected]=\"isItemSelected(item)\"\n            (click)=\"handleItemClick($event, item)\"\n          >\n            <div style=\"display: flex\">\n              <ax-check-box\n                *ngIf=\"showCheckBox\"\n                [size]=\"size\"\n                [value]=\"isItemSelected(item)\"\n                [disabled]=\"\n                  (!allowNull &&\n                    selectedItems.length === 1 &&\n                    isItemSelected(item)) ||\n                  isItemDisabled(item)\n                \"\n                (onClick)=\"handleItemClick($event, item)\"\n              >\n              </ax-check-box>\n              <ng-container *ngIf=\"rowTemplate; else elseTemplate\">\n                <div\n                  style=\"\n                    white-space: nowrap;\n                    text-overflow: ellipsis;\n                    overflow: hidden;\n                    flex: 1;\n                  \"\n                  [title]=\"item[textField]\"\n                  [ngStyle]=\"\n                    showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n                  \"\n                >\n                  <ng-container\n                    *ngTemplateOutlet=\"\n                      rowTemplate;\n                      context: { $implicit: item }\n                    \"\n                  >\n                  </ng-container>\n                </div>\n              </ng-container>\n              <ng-template #elseTemplate>\n                <div\n                  style=\"\n                    white-space: nowrap;\n                    text-overflow: ellipsis;\n                    overflow: hidden;\n                    flex: 1;\n                  \"\n                  [title]=\"item[textField]\"\n                  [ngStyle]=\"\n                    showCheckBox ? { 'padding-inline-start': '0.5rem' } : ''\n                  \"\n                >\n                  {{ item[textField] }}\n                </div>\n              </ng-template>\n            </div>\n          </div>\n        </ng-template>\n        <div *ngIf=\"showLoading\" class=\"ax-pad-sm\" style=\"text-align: center\">\n          <i\n            class=\"far fa-spinner-third fa-pulse fa-2x\"\n            style=\"color: var(--ax-primary-color)\"\n          ></i>\n        </div>\n        <!-- <ax-loading-indicator ></ax-loading-indicator> -->\n        <ng-template #elseTemplate>\n          <ng-container\n            *ngIf=\"\n              showLoading == true;\n              then searchTemplate;\n              else noDataTemplate\n            \"\n          ></ng-container>\n          <ng-template #searchTemplate>\n            <div class=\"list-item\">\n              {{ 'common.search' | trans }}\n            </div>\n          </ng-template>\n          <ng-template #noDataTemplate>\n            <div class=\"list-item\">\n              {{ 'common.noDataFound' | trans }}\n            </div>\n          </ng-template>\n        </ng-template>\n      </div>\n    </div>\n  </ng-container>\n</ax-drop-down>\n"]}