@ng-nest/ui 14.0.7 → 14.0.8

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 (197) hide show
  1. package/avatar/avatar-group.component.d.ts +8 -0
  2. package/avatar/avatar.component.d.ts +15 -4
  3. package/avatar/avatar.module.d.ts +5 -4
  4. package/avatar/avatar.property.d.ts +31 -3
  5. package/avatar/examples/en_US/default/badge/README.md +6 -0
  6. package/avatar/examples/en_US/default/group/README.md +6 -0
  7. package/avatar/examples/en_US/default/label/README.md +6 -0
  8. package/avatar/examples/en_US/default/response/README.md +6 -0
  9. package/avatar/examples/zh_CN/default/badge/README.md +6 -0
  10. package/avatar/examples/zh_CN/default/group/README.md +6 -0
  11. package/avatar/examples/zh_CN/default/label/README.md +6 -0
  12. package/avatar/examples/zh_CN/default/response/README.md +6 -0
  13. package/avatar/public-api.d.ts +1 -0
  14. package/badge/badge.component.d.ts +4 -1
  15. package/badge/badge.property.d.ts +6 -1
  16. package/badge/examples/en_US/default/animation/README.md +4 -0
  17. package/badge/examples/en_US/default/standalone/README.md +6 -0
  18. package/badge/examples/zh_CN/default/animation/README.md +4 -0
  19. package/badge/examples/zh_CN/default/standalone/README.md +6 -0
  20. package/calendar/calendar.property.d.ts +2 -1
  21. package/core/animation/badge.d.ts +1 -0
  22. package/core/config/config.d.ts +26 -0
  23. package/core/interfaces/identify.type.d.ts +2 -0
  24. package/core/interfaces/layout.type.d.ts +15 -0
  25. package/esm2020/avatar/avatar-group.component.mjs +19 -0
  26. package/esm2020/avatar/avatar.component.mjs +91 -11
  27. package/esm2020/avatar/avatar.module.mjs +6 -5
  28. package/esm2020/avatar/avatar.property.mjs +31 -3
  29. package/esm2020/avatar/public-api.mjs +2 -1
  30. package/esm2020/badge/badge.component.mjs +24 -8
  31. package/esm2020/badge/badge.property.mjs +7 -2
  32. package/esm2020/calendar/calendar.property.mjs +1 -1
  33. package/esm2020/core/animation/badge.mjs +17 -1
  34. package/esm2020/core/config/config.mjs +1 -1
  35. package/esm2020/core/interfaces/identify.type.mjs +1 -1
  36. package/esm2020/core/interfaces/layout.type.mjs +1 -1
  37. package/esm2020/form/form.component.mjs +3 -3
  38. package/esm2020/i18n/i18n.property.mjs +1 -1
  39. package/esm2020/i18n/languages/en_US.mjs +5 -1
  40. package/esm2020/i18n/languages/zh_CN.mjs +5 -1
  41. package/esm2020/i18n/languages/zh_TW.mjs +5 -1
  42. package/esm2020/image/image-group.component.mjs +2 -2
  43. package/esm2020/image/image.component.mjs +13 -5
  44. package/esm2020/image/image.module.mjs +5 -4
  45. package/esm2020/image/image.property.mjs +22 -3
  46. package/esm2020/index.mjs +3 -1
  47. package/esm2020/keyword/keyword.directive.mjs +66 -0
  48. package/esm2020/keyword/keyword.module.mjs +19 -0
  49. package/esm2020/keyword/keyword.property.mjs +41 -0
  50. package/esm2020/keyword/ng-nest-ui-keyword.mjs +5 -0
  51. package/esm2020/keyword/public-api.mjs +4 -0
  52. package/esm2020/list/list-option.component.mjs +4 -4
  53. package/esm2020/list/list.component.mjs +4 -4
  54. package/esm2020/list/list.module.mjs +8 -4
  55. package/esm2020/list/list.property.mjs +19 -3
  56. package/esm2020/select/select-portal.component.mjs +6 -3
  57. package/esm2020/select/select.component.mjs +31 -23
  58. package/esm2020/select/select.property.mjs +8 -2
  59. package/esm2020/table/table.component.mjs +4 -4
  60. package/esm2020/tree/tree-node.component.mjs +52 -27
  61. package/esm2020/tree/tree.component.mjs +173 -58
  62. package/esm2020/tree/tree.module.mjs +5 -4
  63. package/esm2020/tree/tree.property.mjs +38 -2
  64. package/esm2020/tree-select/ng-nest-ui-tree-select.mjs +5 -0
  65. package/esm2020/tree-select/public-api.mjs +5 -0
  66. package/esm2020/tree-select/tree-select-portal.component.mjs +110 -0
  67. package/esm2020/tree-select/tree-select.component.mjs +632 -0
  68. package/esm2020/tree-select/tree-select.module.mjs +65 -0
  69. package/esm2020/tree-select/tree-select.property.mjs +153 -0
  70. package/esm2020/upload/upload.component.mjs +9 -6
  71. package/esm2020/upload/upload.module.mjs +12 -4
  72. package/esm2020/upload/upload.property.mjs +10 -3
  73. package/fesm2015/ng-nest-ui-avatar.mjs +143 -17
  74. package/fesm2015/ng-nest-ui-avatar.mjs.map +1 -1
  75. package/fesm2015/ng-nest-ui-badge.mjs +29 -8
  76. package/fesm2015/ng-nest-ui-badge.mjs.map +1 -1
  77. package/fesm2015/ng-nest-ui-calendar.mjs.map +1 -1
  78. package/fesm2015/ng-nest-ui-core.mjs +17 -1
  79. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  80. package/fesm2015/ng-nest-ui-form.mjs +2 -2
  81. package/fesm2015/ng-nest-ui-form.mjs.map +1 -1
  82. package/fesm2015/ng-nest-ui-i18n.mjs +12 -0
  83. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  84. package/fesm2015/ng-nest-ui-image.mjs +39 -11
  85. package/fesm2015/ng-nest-ui-image.mjs.map +1 -1
  86. package/fesm2015/ng-nest-ui-keyword.mjs +125 -0
  87. package/fesm2015/ng-nest-ui-keyword.mjs.map +1 -0
  88. package/fesm2015/ng-nest-ui-list.mjs +32 -12
  89. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  90. package/fesm2015/ng-nest-ui-select.mjs +42 -25
  91. package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
  92. package/fesm2015/ng-nest-ui-table.mjs +3 -3
  93. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  94. package/fesm2015/ng-nest-ui-tree-select.mjs +951 -0
  95. package/fesm2015/ng-nest-ui-tree-select.mjs.map +1 -0
  96. package/fesm2015/ng-nest-ui-tree.mjs +271 -94
  97. package/fesm2015/ng-nest-ui-tree.mjs.map +1 -1
  98. package/fesm2015/ng-nest-ui-upload.mjs +28 -10
  99. package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
  100. package/fesm2015/ng-nest-ui.mjs +2 -0
  101. package/fesm2015/ng-nest-ui.mjs.map +1 -1
  102. package/fesm2020/ng-nest-ui-avatar.mjs +140 -17
  103. package/fesm2020/ng-nest-ui-avatar.mjs.map +1 -1
  104. package/fesm2020/ng-nest-ui-badge.mjs +29 -8
  105. package/fesm2020/ng-nest-ui-badge.mjs.map +1 -1
  106. package/fesm2020/ng-nest-ui-calendar.mjs.map +1 -1
  107. package/fesm2020/ng-nest-ui-core.mjs +17 -1
  108. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  109. package/fesm2020/ng-nest-ui-form.mjs +2 -2
  110. package/fesm2020/ng-nest-ui-form.mjs.map +1 -1
  111. package/fesm2020/ng-nest-ui-i18n.mjs +12 -0
  112. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  113. package/fesm2020/ng-nest-ui-image.mjs +39 -11
  114. package/fesm2020/ng-nest-ui-image.mjs.map +1 -1
  115. package/fesm2020/ng-nest-ui-keyword.mjs +125 -0
  116. package/fesm2020/ng-nest-ui-keyword.mjs.map +1 -0
  117. package/fesm2020/ng-nest-ui-list.mjs +32 -12
  118. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  119. package/fesm2020/ng-nest-ui-select.mjs +42 -25
  120. package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
  121. package/fesm2020/ng-nest-ui-table.mjs +3 -3
  122. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  123. package/fesm2020/ng-nest-ui-tree-select.mjs +946 -0
  124. package/fesm2020/ng-nest-ui-tree-select.mjs.map +1 -0
  125. package/fesm2020/ng-nest-ui-tree.mjs +267 -91
  126. package/fesm2020/ng-nest-ui-tree.mjs.map +1 -1
  127. package/fesm2020/ng-nest-ui-upload.mjs +28 -10
  128. package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
  129. package/fesm2020/ng-nest-ui.mjs +2 -0
  130. package/fesm2020/ng-nest-ui.mjs.map +1 -1
  131. package/i18n/i18n.property.d.ts +5 -0
  132. package/i18n/languages/en_US.d.ts +4 -0
  133. package/i18n/languages/zh_CN.d.ts +4 -0
  134. package/i18n/languages/zh_TW.d.ts +4 -0
  135. package/image/image.component.d.ts +2 -2
  136. package/image/image.module.d.ts +3 -2
  137. package/image/image.property.d.ts +23 -7
  138. package/index.d.ts +2 -0
  139. package/keyword/index.d.ts +5 -0
  140. package/keyword/keyword.directive.d.ts +19 -0
  141. package/keyword/keyword.module.d.ts +9 -0
  142. package/keyword/keyword.property.d.ts +40 -0
  143. package/keyword/public-api.d.ts +3 -0
  144. package/list/list-option.component.d.ts +0 -1
  145. package/list/list.module.d.ts +2 -1
  146. package/list/list.property.d.ts +22 -2
  147. package/package.json +17 -1
  148. package/select/examples/en_US/default/default/README.md +1 -2
  149. package/select/examples/zh_CN/default/default/README.md +1 -2
  150. package/select/select-portal.component.d.ts +5 -1
  151. package/select/select.component.d.ts +2 -2
  152. package/select/select.property.d.ts +6 -1
  153. package/style/core/index.css +29 -0
  154. package/style/core/index.css.map +1 -1
  155. package/style/directives/index.scss +1 -0
  156. package/style/directives/keyword/index.scss +6 -0
  157. package/style/directives/keyword/mixin.scss +24 -0
  158. package/style/directives/keyword/param.scss +3 -0
  159. package/tree/tree-node.component.d.ts +4 -4
  160. package/tree/tree.component.d.ts +13 -1
  161. package/tree/tree.module.d.ts +2 -1
  162. package/tree/tree.property.d.ts +44 -14
  163. package/tree-select/examples/en_US/default/README.md +4 -0
  164. package/tree-select/examples/en_US/default/async/README.md +6 -0
  165. package/tree-select/examples/en_US/default/bordered/README.md +6 -0
  166. package/tree-select/examples/en_US/default/custom/README.md +6 -0
  167. package/tree-select/examples/en_US/default/default/README.md +6 -0
  168. package/tree-select/examples/en_US/default/disabled/README.md +6 -0
  169. package/tree-select/examples/en_US/default/label/README.md +6 -0
  170. package/tree-select/examples/en_US/default/multiple/README.md +6 -0
  171. package/tree-select/examples/en_US/default/path/README.md +6 -0
  172. package/tree-select/examples/en_US/default/required/README.md +6 -0
  173. package/tree-select/examples/en_US/default/scroll/README.md +6 -0
  174. package/tree-select/examples/en_US/default/search/README.md +7 -0
  175. package/tree-select/examples/en_US/default/size/README.md +6 -0
  176. package/tree-select/examples/zh_CN/default/README.md +4 -0
  177. package/tree-select/examples/zh_CN/default/async/README.md +6 -0
  178. package/tree-select/examples/zh_CN/default/bordered/README.md +6 -0
  179. package/tree-select/examples/zh_CN/default/custom/README.md +6 -0
  180. package/tree-select/examples/zh_CN/default/default/README.md +6 -0
  181. package/tree-select/examples/zh_CN/default/disabled/README.md +6 -0
  182. package/tree-select/examples/zh_CN/default/label/README.md +6 -0
  183. package/tree-select/examples/zh_CN/default/multiple/README.md +6 -0
  184. package/tree-select/examples/zh_CN/default/path/README.md +6 -0
  185. package/tree-select/examples/zh_CN/default/required/README.md +6 -0
  186. package/tree-select/examples/zh_CN/default/scroll/README.md +6 -0
  187. package/tree-select/examples/zh_CN/default/search/README.md +7 -0
  188. package/tree-select/examples/zh_CN/default/size/README.md +6 -0
  189. package/tree-select/index.d.ts +5 -0
  190. package/tree-select/public-api.d.ts +4 -0
  191. package/tree-select/tree-select-portal.component.d.ts +62 -0
  192. package/tree-select/tree-select.component.d.ts +101 -0
  193. package/tree-select/tree-select.module.d.ts +20 -0
  194. package/tree-select/tree-select.property.d.ts +202 -0
  195. package/upload/upload.component.d.ts +1 -1
  196. package/upload/upload.module.d.ts +3 -1
  197. package/upload/upload.property.d.ts +13 -3
@@ -0,0 +1,632 @@
1
+ import { BehaviorSubject, Subject } from 'rxjs';
2
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild } from '@angular/core';
3
+ import { XTreeSelectProperty, XTreeSelectPrefix } from './tree-select.property';
4
+ import { XIsEmpty, XIsObservable, XIsChange, XSetData, XClearClass, XIsObjectArray, XIsFunction, XIsArray, XIsString, XRemove, XResize } from '@ng-nest/ui/core';
5
+ import { XPortalConnectedPosition } from '@ng-nest/ui/portal';
6
+ import { XTreeSelectPortalComponent } from './tree-select-portal.component';
7
+ import { takeUntil, throttleTime, debounceTime, distinctUntilChanged, map } from 'rxjs/operators';
8
+ import { DOWN_ARROW, UP_ARROW, ENTER, MAC_ENTER, LEFT_ARROW, RIGHT_ARROW, TAB, BACKSPACE } from '@angular/cdk/keycodes';
9
+ import { XValueAccessor } from '@ng-nest/ui/base-form';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@ng-nest/ui/portal";
12
+ import * as i2 from "@angular/cdk/overlay";
13
+ import * as i3 from "@ng-nest/ui/i18n";
14
+ import * as i4 from "@ng-nest/ui/core";
15
+ import * as i5 from "@angular/common";
16
+ import * as i6 from "@angular/forms";
17
+ import * as i7 from "@ng-nest/ui/input";
18
+ import * as i8 from "@ng-nest/ui/tag";
19
+ import * as i9 from "@ng-nest/ui/outlet";
20
+ export class XTreeSelectComponent extends XTreeSelectProperty {
21
+ constructor(renderer, cdr, portalService, viewContainerRef, overlay, i18n, configService) {
22
+ super();
23
+ this.renderer = renderer;
24
+ this.cdr = cdr;
25
+ this.portalService = portalService;
26
+ this.viewContainerRef = viewContainerRef;
27
+ this.overlay = overlay;
28
+ this.i18n = i18n;
29
+ this.configService = configService;
30
+ this.readonly = true;
31
+ this.enter = false;
32
+ this.showClearable = false;
33
+ this.displayValue = '';
34
+ this.multipleSearchValue = '';
35
+ this.nodes = [];
36
+ this.selectedNodes = [];
37
+ this.displayNodes = [];
38
+ this.displayMore = '';
39
+ this.showDisplayMore = false;
40
+ this.searchNodes = [];
41
+ this.icon = 'fto-chevron-down';
42
+ this.iconSpin = false;
43
+ this.maxNodes = 6;
44
+ this.inputPadding = 0.4;
45
+ this.protalTobottom = true;
46
+ this.asyncLoading = false;
47
+ this.animating = false;
48
+ this.objectArray = false;
49
+ this.selectedSurplus = 0;
50
+ this.selectedTotal = 0;
51
+ this.locale = {};
52
+ this.valueTplContext = { $node: null, $isValue: true };
53
+ this.valueChange = new Subject();
54
+ this.positionChange = new Subject();
55
+ this.closeSubject = new Subject();
56
+ this.dataChange = new BehaviorSubject([]);
57
+ this.keydownSubject = new Subject();
58
+ this.inputChange = new Subject();
59
+ this.composition = false;
60
+ this.multipleInputSizeChange = new Subject();
61
+ this._unSubject = new Subject();
62
+ }
63
+ get getReadonly() {
64
+ return (this.readonly && !this.search) || (Boolean(this.search) && Boolean(this.multiple));
65
+ }
66
+ get getMaxTagContent() {
67
+ return this.maxTagContent || this.locale.maxTagContent;
68
+ }
69
+ writeValue(value) {
70
+ if (this.multiple) {
71
+ if (XIsEmpty(value)) {
72
+ value = [];
73
+ }
74
+ if (!XIsArray(value)) {
75
+ value = [value];
76
+ }
77
+ this.objectArray = XIsObjectArray(value);
78
+ }
79
+ this.value = value;
80
+ this.setDisplayValue();
81
+ this.valueChange.next(this.value);
82
+ this.cdr.detectChanges();
83
+ }
84
+ ngOnInit() {
85
+ this.setFlex(this.treeSelect.nativeElement, this.renderer, this.justify, this.align, this.direction);
86
+ this.setClassMap();
87
+ this.setSubject();
88
+ if (this.multiple) {
89
+ this.valueTpl = this.multipleValueTpl;
90
+ this.inputPadding = 0.125;
91
+ }
92
+ this.i18n.localeChange
93
+ .pipe(map((x) => x.treeSelect), takeUntil(this._unSubject))
94
+ .subscribe((x) => {
95
+ this.locale = x;
96
+ this.cdr.markForCheck();
97
+ });
98
+ }
99
+ ngOnChanges(changes) {
100
+ const { data } = changes;
101
+ XIsChange(data) && this.setData();
102
+ }
103
+ ngAfterViewInit() {
104
+ this.setPortal();
105
+ if (this.multiple && this.inputCom.inputValueRef) {
106
+ XResize(this.inputCom.inputValueRef.nativeElement)
107
+ .pipe(debounceTime(30), takeUntil(this._unSubject))
108
+ .subscribe((x) => {
109
+ this._resizeObserver = x.resizeObserver;
110
+ this.setMutipleInputSize();
111
+ });
112
+ }
113
+ }
114
+ ngOnDestroy() {
115
+ this._unSubject.next();
116
+ this._unSubject.unsubscribe();
117
+ this._resizeObserver?.disconnect();
118
+ }
119
+ setClassMap() {
120
+ XClearClass(this.labelMap);
121
+ this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;
122
+ }
123
+ setData() {
124
+ if (this.async)
125
+ return;
126
+ XSetData(this.data, this._unSubject).subscribe((x) => {
127
+ this.nodes = x;
128
+ this.dataChange.next(this.nodes);
129
+ this.setDisplayValue();
130
+ this.setPortal();
131
+ this.cdr.detectChanges();
132
+ });
133
+ }
134
+ setSubject() {
135
+ this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {
136
+ this.closePortal();
137
+ });
138
+ this.inputChange.pipe(debounceTime(this.debounceTime), distinctUntilChanged(), takeUntil(this._unSubject)).subscribe((x) => {
139
+ this.modelChange(x);
140
+ });
141
+ this.keydownSubject.pipe(throttleTime(10), takeUntil(this._unSubject)).subscribe((x) => {
142
+ const keyCode = x.keyCode;
143
+ if (!this.portalAttached() && [DOWN_ARROW, UP_ARROW, LEFT_ARROW, RIGHT_ARROW, ENTER, MAC_ENTER, BACKSPACE].includes(keyCode)) {
144
+ this.inputChange.next(this.displayValue);
145
+ }
146
+ // if (this.portalAttached() && [ESCAPE].includes(keyCode)) {
147
+ // this.closeSubject.next();
148
+ // }
149
+ });
150
+ this.multipleInputSizeChange.pipe(distinctUntilChanged(), takeUntil(this._unSubject)).subscribe((x) => {
151
+ if (this.multipleInput) {
152
+ const input = this.multipleInput?.elementRef.nativeElement;
153
+ this.renderer.setStyle(input, 'width', `${x}px`);
154
+ }
155
+ });
156
+ }
157
+ setMutipleInputSize() {
158
+ const ivf = this.inputCom.inputValueRef.nativeElement;
159
+ let { clientWidth, scrollHeight } = ivf;
160
+ const len = ivf.children.length;
161
+ let lastRowTagTop = -1;
162
+ let lines = 1;
163
+ let rowTagTop = -1;
164
+ let lastRowTagsWidth = 0;
165
+ let marginLeft = 0;
166
+ let marginTop = 0;
167
+ for (let i = len - 1; i >= 0; i--) {
168
+ const ele = ivf.children[i];
169
+ if (ele.tagName === 'X-TAG') {
170
+ const { offsetTop, offsetWidth } = ele;
171
+ const style = getComputedStyle(ele);
172
+ marginLeft = Number(style.marginLeft.replace('px', ''));
173
+ marginTop = Number(style.marginTop.replace('px', ''));
174
+ if (rowTagTop === -1) {
175
+ rowTagTop = offsetTop;
176
+ }
177
+ else if (rowTagTop !== offsetTop) {
178
+ lines++;
179
+ rowTagTop = offsetTop;
180
+ }
181
+ if (lastRowTagTop === -1) {
182
+ lastRowTagTop = offsetTop;
183
+ }
184
+ if (lastRowTagTop === offsetTop) {
185
+ lastRowTagsWidth += offsetWidth + marginLeft;
186
+ }
187
+ }
188
+ }
189
+ const height = scrollHeight + (lines > 1 ? marginTop : 0);
190
+ this.renderer.setStyle(this.inputCom.inputRef.nativeElement, 'height', `${height}px`);
191
+ if (this.multipleInput) {
192
+ this.multipleInputSizeChange.next(clientWidth - lastRowTagsWidth - marginLeft);
193
+ }
194
+ this.portal?.overlayRef?.updatePosition();
195
+ }
196
+ menter() {
197
+ this.enter = true;
198
+ if (this.disabled || !this.clearable || this.iconSpin)
199
+ return;
200
+ if (!XIsEmpty(this.displayValue)) {
201
+ this.icon = '';
202
+ this.showClearable = true;
203
+ this.cdr.detectChanges();
204
+ }
205
+ }
206
+ mleave() {
207
+ this.enter = false;
208
+ if (this.disabled || !this.clearable || this.iconSpin)
209
+ return;
210
+ if (this.clearable) {
211
+ this.icon = 'fto-chevron-down';
212
+ this.showClearable = false;
213
+ this.cdr.detectChanges();
214
+ }
215
+ }
216
+ modelChange(value) {
217
+ if (XIsFunction(this.data)) {
218
+ if (!this.portalAttached()) {
219
+ this.showPortal();
220
+ }
221
+ this.icon = 'fto-loader';
222
+ this.iconSpin = true;
223
+ this.cdr.detectChanges();
224
+ XSetData(this.data, this._unSubject, true, value).subscribe((x) => {
225
+ this.icon = '';
226
+ this.iconSpin = false;
227
+ if (!this.enter && this.clearable) {
228
+ this.showClearable = false;
229
+ }
230
+ this.nodes = x;
231
+ this.dataChange.next(this.nodes);
232
+ this.cdr.detectChanges();
233
+ });
234
+ return;
235
+ }
236
+ if (this.nodes) {
237
+ if (!this.portalAttached()) {
238
+ this.showPortal();
239
+ }
240
+ if (XIsEmpty(value)) {
241
+ this.searchNodes = [
242
+ ...this.nodes.map((x) => {
243
+ let res = { ...x };
244
+ delete res.children;
245
+ delete res.childrenLoaded;
246
+ delete res.leaf;
247
+ return res;
248
+ })
249
+ ];
250
+ }
251
+ else {
252
+ this.setSearchNodes(value);
253
+ }
254
+ this.dataChange.next(this.searchNodes);
255
+ }
256
+ }
257
+ setSearchNodes(value) {
258
+ let nodes = [];
259
+ const getParent = (node) => {
260
+ if (XIsEmpty(node.pid))
261
+ return;
262
+ const parent = this.nodes.find((x) => x.id === node.pid);
263
+ parent.open = true;
264
+ if (!XIsEmpty(parent)) {
265
+ if (nodes.every((x) => x.id !== parent.id)) {
266
+ nodes.push(parent);
267
+ }
268
+ }
269
+ };
270
+ if (this.caseSensitive) {
271
+ nodes = this.nodes.filter((x) => x.label.indexOf(value) >= 0);
272
+ }
273
+ else {
274
+ nodes = this.nodes.filter((x) => x.label.toLowerCase().indexOf(value.toLowerCase()) >= 0);
275
+ }
276
+ for (let node of nodes) {
277
+ getParent(node);
278
+ }
279
+ this.searchNodes = nodes.map((x) => {
280
+ let res = { ...x };
281
+ delete res.children;
282
+ delete res.childrenLoaded;
283
+ delete res.leaf;
284
+ return res;
285
+ });
286
+ }
287
+ clearEmit() {
288
+ this.value = this.multiple ? [] : '';
289
+ this.displayValue = '';
290
+ this.multipleSearchValue = '';
291
+ this.selectedNodes = [];
292
+ this.setDisplayNodes();
293
+ this.valueTplContext.$node = null;
294
+ this.mleave();
295
+ this.valueChange.next(this.value);
296
+ this.inputChange.next('');
297
+ if (this.onChange)
298
+ this.onChange(this.value);
299
+ }
300
+ setDisplayValue(clickNode) {
301
+ if (this.nodes.length > 0) {
302
+ if (this.multiple) {
303
+ if (XIsEmpty(this.value)) {
304
+ this.value = [];
305
+ this.displayValue = '';
306
+ this.selectedNodes = [];
307
+ this.displayNodes = [];
308
+ this.displayMore = '';
309
+ this.valueTplContext.$node = null;
310
+ this.setDisplayNodes();
311
+ }
312
+ else {
313
+ let ids = [];
314
+ let selected = [];
315
+ if (this.objectArray) {
316
+ ids = this.value.map((x) => x.id);
317
+ }
318
+ else {
319
+ ids = this.value;
320
+ }
321
+ if (clickNode) {
322
+ let inx = this.selectedNodes.findIndex((x) => x.id === clickNode.id);
323
+ if (inx >= 0) {
324
+ XRemove(this.selectedNodes, (x) => x.id === clickNode.id);
325
+ }
326
+ else {
327
+ this.selectedNodes.push(clickNode);
328
+ }
329
+ }
330
+ else {
331
+ for (let id of ids) {
332
+ let node = this.nodes.find((x) => x.id === id);
333
+ if (node)
334
+ selected.push(node);
335
+ }
336
+ this.selectedNodes = selected;
337
+ }
338
+ if (this.showPath) {
339
+ for (let node of this.selectedNodes) {
340
+ const parents = this.getParentPath(node);
341
+ node.path = parents.map((x) => x.label).join(this.separator);
342
+ }
343
+ }
344
+ this.setDisplayNodes();
345
+ this.displayValue = this.selectedNodes.map((x) => x.label).join(this.separator);
346
+ this.valueTplContext.$node = [...this.selectedNodes];
347
+ }
348
+ }
349
+ else {
350
+ let node = this.nodes.find((x) => x.id === this.value);
351
+ if (node) {
352
+ if (this.showPath) {
353
+ const parents = this.getParentPath(node);
354
+ this.displayValue = parents.map((x) => x.label).join(this.separator);
355
+ }
356
+ else {
357
+ this.displayValue = node.label;
358
+ }
359
+ this.valueTplContext.$node = node;
360
+ }
361
+ else {
362
+ this.displayValue = '';
363
+ this.valueTplContext.$node = null;
364
+ }
365
+ }
366
+ this.cdr.detectChanges();
367
+ }
368
+ }
369
+ getParentPath(node) {
370
+ let res = [node];
371
+ const getParent = (nd) => {
372
+ let parent = this.nodes.find((x) => nd.pid && x.id === nd.pid);
373
+ if (parent) {
374
+ res = [parent, ...res];
375
+ getParent(parent);
376
+ }
377
+ };
378
+ getParent(node);
379
+ return res;
380
+ }
381
+ closeNode(event, node, index) {
382
+ let inx = -1;
383
+ if (this.objectArray) {
384
+ inx = this.value.findIndex((y) => y.id === node.id);
385
+ }
386
+ else {
387
+ inx = this.value.findIndex((y) => y === node.id);
388
+ }
389
+ if (inx >= 0) {
390
+ this.value.splice(inx, 1);
391
+ this.valueChange.next(this.value);
392
+ if (this.onChange)
393
+ this.onChange(this.value);
394
+ this.selectedNodes.splice(index, 1);
395
+ this.setDisplayNodes();
396
+ }
397
+ event.stopPropagation();
398
+ }
399
+ setDisplayNodes() {
400
+ if (!this.multiple)
401
+ return;
402
+ const maxlen = this.selectedNodes.length;
403
+ let len = 0;
404
+ if (!this.maxTagCount) {
405
+ len = maxlen;
406
+ }
407
+ else {
408
+ len = maxlen > Number(this.maxTagCount) ? Number(this.maxTagCount) : maxlen;
409
+ }
410
+ let more = maxlen - len;
411
+ more = more < 0 ? 0 : more;
412
+ this.displayNodes = this.selectedNodes.slice(0, len);
413
+ this.showDisplayMore = more > 0;
414
+ if (XIsString(this.getMaxTagContent)) {
415
+ this.displayMore = more > 0 ? this.getMaxTagContent.replace(/\{\{surplus\}\}/g, `${more}`) : '';
416
+ }
417
+ else {
418
+ this.selectedSurplus = more;
419
+ this.selectedTotal = maxlen;
420
+ }
421
+ setTimeout(() => this.setMutipleInputSize());
422
+ }
423
+ portalAttached() {
424
+ return this.portal?.overlayRef?.hasAttached();
425
+ }
426
+ closePortal() {
427
+ if (this.portalAttached()) {
428
+ this.portal?.overlayRef?.detach();
429
+ this.active = false;
430
+ this.multipleSearchValue = '';
431
+ this.cdr.detectChanges();
432
+ return true;
433
+ }
434
+ return false;
435
+ }
436
+ destroyPortal() {
437
+ this.portal?.overlayRef?.dispose();
438
+ }
439
+ showPortal(click = false) {
440
+ if (this.disabled || this.iconSpin || this.animating)
441
+ return;
442
+ this.active = true;
443
+ if ((this.async && XIsObservable(this.data) && this.nodes.length === 0) || XIsFunction(this.data)) {
444
+ this.icon = 'fto-loader';
445
+ this.iconSpin = true;
446
+ this.inputCom.cdr.detectChanges();
447
+ XSetData(this.data, this._unSubject, true, click ? '' : this.displayValue).subscribe((x) => {
448
+ this.icon = 'fto-chevron-down';
449
+ this.iconSpin = false;
450
+ if (!this.enter && this.clearable) {
451
+ this.showClearable = false;
452
+ }
453
+ this.inputCom.cdr.detectChanges();
454
+ this.nodes = x;
455
+ this.dataChange.next(this.nodes);
456
+ if (!this.search)
457
+ this.setDisplayValue();
458
+ this.createPortal();
459
+ this.cdr.detectChanges();
460
+ });
461
+ }
462
+ else {
463
+ this.dataChange.next(this.nodes);
464
+ this.createPortal();
465
+ }
466
+ if (this.search && this.multiple) {
467
+ this.multipleInput.inputFocus();
468
+ }
469
+ else {
470
+ this.inputCom.inputFocus();
471
+ }
472
+ }
473
+ createPortal() {
474
+ this.box = this.inputCom.inputRef.nativeElement.getBoundingClientRect();
475
+ const config = {
476
+ backdropClass: '',
477
+ width: this.box.width,
478
+ positionStrategy: this.setPlacement(),
479
+ scrollStrategy: this.overlay.scrollStrategies.reposition()
480
+ };
481
+ this.setPosition(config);
482
+ this.portal = this.portalService.attach({
483
+ content: XTreeSelectPortalComponent,
484
+ viewContainerRef: this.viewContainerRef,
485
+ overlayConfig: config
486
+ });
487
+ this.portal.overlayRef
488
+ ?.outsidePointerEvents()
489
+ .pipe(takeUntil(this._unSubject))
490
+ .subscribe(() => {
491
+ this.setDisplayValue();
492
+ this.closeSubject.next();
493
+ });
494
+ this.setInstance();
495
+ }
496
+ setPosition(config) {
497
+ let position = config.positionStrategy;
498
+ position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos) => {
499
+ const place = XPortalConnectedPosition.get(pos.connectionPair);
500
+ place !== this.placement && this.positionChange.next(place);
501
+ });
502
+ }
503
+ setInstance() {
504
+ let componentRef = this.portal.componentRef;
505
+ if (!componentRef)
506
+ return;
507
+ Object.assign(componentRef.instance, {
508
+ data: this.nodes,
509
+ value: this.value,
510
+ placement: this.placement,
511
+ multiple: this.multiple,
512
+ selectAll: this.selectAll,
513
+ nodeTpl: this.nodeTpl,
514
+ valueChange: this.valueChange,
515
+ positionChange: this.positionChange,
516
+ closeSubject: this.closeSubject,
517
+ keydownSubject: this.keydownSubject,
518
+ dataChange: this.dataChange,
519
+ inputCom: this.inputCom,
520
+ portalMaxHeight: this.portalMaxHeight,
521
+ objectArray: this.objectArray,
522
+ selectAllText: this.selectAllText,
523
+ caseSensitive: this.caseSensitive,
524
+ search: this.search,
525
+ virtualScroll: this.virtualScroll,
526
+ size: this.size,
527
+ expandedLevel: this.expandedLevel,
528
+ inputChange: this.inputChange,
529
+ destroyPortal: () => this.destroyPortal(),
530
+ nodeEmit: (node, value) => this.nodeClick(node, value),
531
+ animating: (ing) => (this.animating = ing)
532
+ });
533
+ componentRef.changeDetectorRef.detectChanges();
534
+ }
535
+ nodeClick(node, value) {
536
+ if (this.multiple) {
537
+ if (this.value.length === 0) {
538
+ this.value = value;
539
+ }
540
+ if (this.multipleInput) {
541
+ const input = this.multipleInput.elementRef.nativeElement;
542
+ this.renderer.setStyle(input, 'width', '2rem');
543
+ }
544
+ if (this.search && this.multipleSearchValue !== '') {
545
+ this.multipleSearchValue = '';
546
+ this.inputChange.next('');
547
+ this.valueChange.next([...this.value]);
548
+ }
549
+ this.setDisplayValue(node);
550
+ }
551
+ else {
552
+ node = node;
553
+ if (this.showPath) {
554
+ const parents = this.getParentPath(node);
555
+ this.displayValue = parents.map((x) => x.label).join(this.separator);
556
+ }
557
+ else {
558
+ this.displayValue = node.label;
559
+ }
560
+ this.valueTplContext.$node = node;
561
+ this.value = node.id;
562
+ this.closeSubject.next();
563
+ }
564
+ if (this.search && this.multiple) {
565
+ this.multipleInput.inputFocus();
566
+ }
567
+ else {
568
+ this.inputCom.inputFocus();
569
+ }
570
+ if (this.onChange)
571
+ this.onChange(this.value);
572
+ this.formControlValidator();
573
+ this.cdr.detectChanges();
574
+ }
575
+ selectAllNodes(value) {
576
+ this.value = value;
577
+ }
578
+ setPlacement() {
579
+ return this.portalService.setPlacement({
580
+ elementRef: this.inputCom.inputRef,
581
+ placement: [this.placement, 'bottom', 'top'],
582
+ transformOriginOn: 'x-tree-select-portal'
583
+ });
584
+ }
585
+ setPortal() {
586
+ this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());
587
+ }
588
+ formControlChanges() {
589
+ this.setData();
590
+ this.ngOnInit();
591
+ this.writeValue(this.value);
592
+ this.ngAfterViewInit();
593
+ this.cdr.detectChanges();
594
+ }
595
+ onKeydown($event) {
596
+ this.keydownSubject.next($event);
597
+ if ($event.keyCode !== TAB && !this.search) {
598
+ $event.preventDefault();
599
+ }
600
+ }
601
+ onFocus(_event) {
602
+ if (this.search && this.multiple) {
603
+ this.multipleInput.inputFocus();
604
+ }
605
+ else {
606
+ this.inputCom.inputFocus();
607
+ }
608
+ }
609
+ onInput(_event) {
610
+ this.formControlValidator();
611
+ setTimeout(() => this.inputChange.next(this.multiple ? this.multipleSearchValue : this.displayValue));
612
+ }
613
+ }
614
+ /** @nocollapse */ XTreeSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XTreeSelectComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i1.XPortalService }, { token: i0.ViewContainerRef }, { token: i2.Overlay }, { token: i3.XI18nService }, { token: i4.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
615
+ /** @nocollapse */ XTreeSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XTreeSelectComponent, selector: "x-tree-select", providers: [XValueAccessor(XTreeSelectComponent)], viewQueries: [{ propertyName: "inputCom", first: true, predicate: ["inputCom"], descendants: true, static: true }, { propertyName: "treeSelect", first: true, predicate: ["treeSelect"], descendants: true, static: true }, { propertyName: "multipleValueTpl", first: true, predicate: ["multipleValueTpl"], descendants: true, static: true }, { propertyName: "multipleInput", first: true, predicate: ["multipleInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #treeSelect class=\"x-tree-select\" [class.x-tree-select-multiple]=\"multiple\">\r\n <div class=\"x-tree-select-row\">\r\n <x-input\r\n #inputCom\r\n type=\"text\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [required]=\"required\"\r\n [disabled]=\"disabled\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"getReadonly\"\r\n [clearable]=\"showClearable\"\r\n [(ngModel)]=\"displayValue\"\r\n [valueTpl]=\"valueTpl ? valueTpl : nodeTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"before\"\r\n [after]=\"after\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n [pointer]=\"true\"\r\n [inputPadding]=\"inputPadding\"\r\n [(active)]=\"active\"\r\n (clearEmit)=\"clearEmit()\"\r\n (xKeydown)=\"onKeydown($event)\"\r\n (xInput)=\"onInput($event)\"\r\n (xFocus)=\"onFocus($event)\"\r\n (xClick)=\"showPortal(true)\"\r\n (xMouseenter)=\"menter()\"\r\n (xMouseleave)=\"mleave()\"\r\n (xComposition)=\"composition = $event\"\r\n ></x-input>\r\n </div>\r\n</div>\r\n\r\n<ng-template #multipleValueTpl>\r\n <x-tag\r\n [@.disabled]=\"true\"\r\n *ngFor=\"let node of displayNodes; index as i\"\r\n [closable]=\"!disabled\"\r\n (close)=\"closeNode($event, node, i)\"\r\n [size]=\"size\"\r\n >{{ showPath ? node.path : node.label }}</x-tag\r\n >\r\n <x-tag [@.disabled]=\"true\" *ngIf=\"showDisplayMore\" [size]=\"size\">\r\n <ng-container *xOutlet=\"getMaxTagContent; context: { $surplus: selectedSurplus, $total: selectedTotal }\">{{\r\n displayMore\r\n }}</ng-container>\r\n </x-tag>\r\n <x-input\r\n #multipleInput\r\n *ngIf=\"search\"\r\n bordered=\"false\"\r\n [size]=\"size\"\r\n inputPadding=\"0.275\"\r\n [(ngModel)]=\"multipleSearchValue\"\r\n (xInput)=\"onInput($event)\"\r\n (xKeydown)=\"onKeydown($event)\"\r\n ></x-input>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";x-tree-select{display:inline-block;width:12rem}.x-tree-select{margin:0;padding:0;width:100%}.x-tree-select x-input{width:100%}.x-tree-select-multiple .x-input-value-template-value{display:flex;align-items:center;margin-bottom:.125rem;flex-wrap:wrap;width:initial;height:initial!important}.x-tree-select-multiple .x-input-value-template-value>x-tag{display:inline-flex;margin-left:.0625rem;margin-top:.125rem}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-big{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-big>.x-icon{right:calc(-var(--x-padding-large)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-large{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-large>.x-icon{right:calc(-var(--x-padding-medium)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-medium{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-medium>.x-icon{right:calc(-var(--x-padding-small)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-small{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-small>.x-icon{right:calc(-var(--x-padding-mini)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-mini{height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-mini>.x-icon{right:-.0625rem}.x-tree-select-multiple .x-input-value-template-value>x-input{margin-top:.125rem;width:5rem;min-width:3rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-large);line-height:var(--x-height-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>label{height:var(--x-height-large);line-height:var(--x-height-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-medium);line-height:var(--x-height-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>label{height:var(--x-height-medium);line-height:var(--x-height-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-small);line-height:var(--x-height-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>label{height:var(--x-height-small);line-height:var(--x-height-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-mini);line-height:var(--x-height-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>label{height:var(--x-height-mini);line-height:var(--x-height-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-value-template-value{height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-max-length{height:1.125rem;line-height:1.125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>label{height:1.125rem;line-height:1.125rem}.x-tree-select-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);width:100%;border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);position:relative;display:flex;flex-direction:column;background-color:var(--x-background);overflow:hidden auto;max-height:calc((calc(var(--x-font-size) + .875rem) * 6) + (var(--x-border-width) * 7))}.x-tree-select-portal x-tree{width:100%}.x-tree-select-portal x-empty{margin:1rem;display:block}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.XInputComponent, selector: "x-input" }, { kind: "component", type: i8.XTagComponent, selector: "x-tag" }, { kind: "directive", type: i9.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
616
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XTreeSelectComponent, decorators: [{
617
+ type: Component,
618
+ args: [{ selector: `${XTreeSelectPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XTreeSelectComponent)], template: "<div #treeSelect class=\"x-tree-select\" [class.x-tree-select-multiple]=\"multiple\">\r\n <div class=\"x-tree-select-row\">\r\n <x-input\r\n #inputCom\r\n type=\"text\"\r\n [label]=\"label\"\r\n [labelWidth]=\"labelWidth\"\r\n [labelAlign]=\"labelAlign\"\r\n [justify]=\"justify\"\r\n [align]=\"align\"\r\n [direction]=\"direction\"\r\n [required]=\"required\"\r\n [disabled]=\"disabled\"\r\n [validator]=\"validator\"\r\n [icon]=\"icon\"\r\n [iconSpin]=\"iconSpin\"\r\n [placeholder]=\"placeholder\"\r\n [readonly]=\"getReadonly\"\r\n [clearable]=\"showClearable\"\r\n [(ngModel)]=\"displayValue\"\r\n [valueTpl]=\"valueTpl ? valueTpl : nodeTpl\"\r\n [valueTplContext]=\"valueTplContext\"\r\n [size]=\"size\"\r\n [bordered]=\"bordered\"\r\n [before]=\"before\"\r\n [after]=\"after\"\r\n [pattern]=\"pattern\"\r\n [message]=\"message\"\r\n [pointer]=\"true\"\r\n [inputPadding]=\"inputPadding\"\r\n [(active)]=\"active\"\r\n (clearEmit)=\"clearEmit()\"\r\n (xKeydown)=\"onKeydown($event)\"\r\n (xInput)=\"onInput($event)\"\r\n (xFocus)=\"onFocus($event)\"\r\n (xClick)=\"showPortal(true)\"\r\n (xMouseenter)=\"menter()\"\r\n (xMouseleave)=\"mleave()\"\r\n (xComposition)=\"composition = $event\"\r\n ></x-input>\r\n </div>\r\n</div>\r\n\r\n<ng-template #multipleValueTpl>\r\n <x-tag\r\n [@.disabled]=\"true\"\r\n *ngFor=\"let node of displayNodes; index as i\"\r\n [closable]=\"!disabled\"\r\n (close)=\"closeNode($event, node, i)\"\r\n [size]=\"size\"\r\n >{{ showPath ? node.path : node.label }}</x-tag\r\n >\r\n <x-tag [@.disabled]=\"true\" *ngIf=\"showDisplayMore\" [size]=\"size\">\r\n <ng-container *xOutlet=\"getMaxTagContent; context: { $surplus: selectedSurplus, $total: selectedTotal }\">{{\r\n displayMore\r\n }}</ng-container>\r\n </x-tag>\r\n <x-input\r\n #multipleInput\r\n *ngIf=\"search\"\r\n bordered=\"false\"\r\n [size]=\"size\"\r\n inputPadding=\"0.275\"\r\n [(ngModel)]=\"multipleSearchValue\"\r\n (xInput)=\"onInput($event)\"\r\n (xKeydown)=\"onKeydown($event)\"\r\n ></x-input>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";x-tree-select{display:inline-block;width:12rem}.x-tree-select{margin:0;padding:0;width:100%}.x-tree-select x-input{width:100%}.x-tree-select-multiple .x-input-value-template-value{display:flex;align-items:center;margin-bottom:.125rem;flex-wrap:wrap;width:initial;height:initial!important}.x-tree-select-multiple .x-input-value-template-value>x-tag{display:inline-flex;margin-left:.0625rem;margin-top:.125rem}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-big{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-big>.x-icon{right:calc(-var(--x-padding-large)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-large{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-large>.x-icon{right:calc(-var(--x-padding-medium)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-medium{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-medium>.x-icon{right:calc(-var(--x-padding-small)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-small{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-small>.x-icon{right:calc(-var(--x-padding-mini)/2)}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-mini{height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-tag .x-tag-mini>.x-icon{right:-.0625rem}.x-tree-select-multiple .x-input-value-template-value>x-input{margin-top:.125rem;width:5rem;min-width:3rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-large);line-height:var(--x-height-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-big>label{height:var(--x-height-large);line-height:var(--x-height-large)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-medium);line-height:var(--x-height-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-large>label{height:var(--x-height-medium);line-height:var(--x-height-medium)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-small);line-height:var(--x-height-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-medium>label{height:var(--x-height-small);line-height:var(--x-height-small)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-value-template-value{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-input>.x-input-max-length{height:var(--x-height-mini);line-height:var(--x-height-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-small>label{height:var(--x-height-mini);line-height:var(--x-height-mini)}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>input,.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-row-after:not(.x-input-row-after-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-value-template-value{height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-input>.x-input-max-length{height:1.125rem;line-height:1.125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-row-before:not(.x-input-row-before-template),.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>.x-input-row>.x-input-row-after:not(.x-input-row-after-template){height:1.125rem;line-height:1.125rem;padding:0 .125rem}.x-tree-select-multiple .x-input-value-template-value>x-input .x-input-mini>label{height:1.125rem;line-height:1.125rem}.x-tree-select-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);width:100%;border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);position:relative;display:flex;flex-direction:column;background-color:var(--x-background);overflow:hidden auto;max-height:calc((calc(var(--x-font-size) + .875rem) * 6) + (var(--x-border-width) * 7))}.x-tree-select-portal x-tree{width:100%}.x-tree-select-portal x-empty{margin:1rem;display:block}\n"] }]
619
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i1.XPortalService }, { type: i0.ViewContainerRef }, { type: i2.Overlay }, { type: i3.XI18nService }, { type: i4.XConfigService }]; }, propDecorators: { inputCom: [{
620
+ type: ViewChild,
621
+ args: ['inputCom', { static: true }]
622
+ }], treeSelect: [{
623
+ type: ViewChild,
624
+ args: ['treeSelect', { static: true }]
625
+ }], multipleValueTpl: [{
626
+ type: ViewChild,
627
+ args: ['multipleValueTpl', { static: true }]
628
+ }], multipleInput: [{
629
+ type: ViewChild,
630
+ args: ['multipleInput']
631
+ }] } });
632
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-select.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/tree-select/tree-select.component.ts","../../../../../lib/ng-nest/ui/tree-select/tree-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Subject } from 'rxjs';\r\nimport {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Renderer2,\r\n  ElementRef,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { XTreeSelectNode, XTreeSelectProperty, XTreeSelectPrefix } from './tree-select.property';\r\nimport {\r\n  XIsEmpty,\r\n  XIsObservable,\r\n  XIsChange,\r\n  XSetData,\r\n  XClearClass,\r\n  XConfigService,\r\n  XPositionTopBottom,\r\n  XIsObjectArray,\r\n  XIsFunction,\r\n  XIsArray,\r\n  XIsString,\r\n  XRemove,\r\n  XResize\r\n} from '@ng-nest/ui/core';\r\nimport { XPortalService, XPortalOverlayRef, XPortalConnectedPosition } from '@ng-nest/ui/portal';\r\nimport { XInputComponent } from '@ng-nest/ui/input';\r\nimport { XTreeSelectPortalComponent } from './tree-select-portal.component';\r\nimport { Overlay, FlexibleConnectedPositionStrategy, ConnectedOverlayPositionChange, OverlayConfig } from '@angular/cdk/overlay';\r\nimport { takeUntil, throttleTime, debounceTime, distinctUntilChanged, map } from 'rxjs/operators';\r\nimport { DOWN_ARROW, UP_ARROW, ENTER, MAC_ENTER, LEFT_ARROW, RIGHT_ARROW, TAB, BACKSPACE } from '@angular/cdk/keycodes';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XI18nTreeSelect, XI18nService } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XTreeSelectPrefix}`,\r\n  templateUrl: './tree-select.component.html',\r\n  styleUrls: ['./tree-select.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XTreeSelectComponent)]\r\n})\r\nexport class XTreeSelectComponent extends XTreeSelectProperty implements OnInit, OnChanges {\r\n  @ViewChild('inputCom', { static: true }) inputCom!: XInputComponent;\r\n  @ViewChild('treeSelect', { static: true }) treeSelect!: ElementRef;\r\n  @ViewChild('multipleValueTpl', { static: true }) multipleValueTpl!: TemplateRef<void>;\r\n  @ViewChild('multipleInput') multipleInput!: XInputComponent;\r\n\r\n  get getReadonly() {\r\n    return (this.readonly && !this.search) || (Boolean(this.search) && Boolean(this.multiple));\r\n  }\r\n\r\n  get getMaxTagContent() {\r\n    return this.maxTagContent || this.locale.maxTagContent;\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (this.multiple) {\r\n      if (XIsEmpty(value)) {\r\n        value = [];\r\n      }\r\n      if (!XIsArray(value)) {\r\n        value = [value];\r\n      }\r\n      this.objectArray = XIsObjectArray(value);\r\n    }\r\n    this.value = value;\r\n    this.setDisplayValue();\r\n    this.valueChange.next(this.value);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  override readonly = true;\r\n  enter: boolean = false;\r\n  showClearable: boolean = false;\r\n  displayValue: any = '';\r\n  multipleSearchValue = '';\r\n  nodes: XTreeSelectNode[] = [];\r\n  selectedNodes: XTreeSelectNode[] = [];\r\n  displayNodes: XTreeSelectNode[] = [];\r\n  displayMore = '';\r\n  showDisplayMore = false;\r\n  searchNodes: XTreeSelectNode[] = [];\r\n  cloneNodes!: XTreeSelectNode[];\r\n  portal!: XPortalOverlayRef<XTreeSelectPortalComponent>;\r\n  icon: string = 'fto-chevron-down';\r\n  iconSpin: boolean = false;\r\n  box!: DOMRect;\r\n  protalHeight!: number;\r\n  maxNodes: number = 6;\r\n  inputPadding = 0.4;\r\n  protalTobottom: boolean = true;\r\n  asyncLoading = false;\r\n  animating = false;\r\n  objectArray = false;\r\n  selectedSurplus = 0;\r\n  selectedTotal = 0;\r\n  locale: XI18nTreeSelect = {};\r\n  override valueTplContext: { $node: any; $isValue: boolean } = { $node: null, $isValue: true };\r\n  valueChange: Subject<any> = new Subject();\r\n  positionChange: Subject<any> = new Subject();\r\n  closeSubject: Subject<void> = new Subject();\r\n  dataChange = new BehaviorSubject<XTreeSelectNode[]>([]);\r\n  keydownSubject: Subject<KeyboardEvent> = new Subject();\r\n  inputChange: Subject<any> = new Subject();\r\n  composition: boolean = false;\r\n  multipleInputSizeChange = new Subject<number>();\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public override cdr: ChangeDetectorRef,\r\n    private portalService: XPortalService,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private overlay: Overlay,\r\n    public i18n: XI18nService,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.treeSelect.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setClassMap();\r\n    this.setSubject();\r\n    if (this.multiple) {\r\n      this.valueTpl = this.multipleValueTpl;\r\n      this.inputPadding = 0.125;\r\n    }\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.treeSelect as XI18nTreeSelect),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { data } = changes;\r\n    XIsChange(data) && this.setData();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPortal();\r\n    if (this.multiple && this.inputCom.inputValueRef) {\r\n      XResize(this.inputCom.inputValueRef.nativeElement)\r\n        .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n        .subscribe((x) => {\r\n          this._resizeObserver = x.resizeObserver;\r\n          this.setMutipleInputSize();\r\n        });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  setData() {\r\n    if (this.async) return;\r\n    XSetData<XTreeSelectNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.dataChange.next(this.nodes);\r\n      this.setDisplayValue();\r\n      this.setPortal();\r\n      this.cdr.detectChanges();\r\n    });\r\n  }\r\n\r\n  setSubject() {\r\n    this.closeSubject.pipe(takeUntil(this._unSubject)).subscribe(() => {\r\n      this.closePortal();\r\n    });\r\n    this.inputChange.pipe(debounceTime(this.debounceTime as number), distinctUntilChanged(), takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.modelChange(x);\r\n    });\r\n    this.keydownSubject.pipe(throttleTime(10), takeUntil(this._unSubject)).subscribe((x) => {\r\n      const keyCode = x.keyCode;\r\n      if (!this.portalAttached() && [DOWN_ARROW, UP_ARROW, LEFT_ARROW, RIGHT_ARROW, ENTER, MAC_ENTER, BACKSPACE].includes(keyCode)) {\r\n        this.inputChange.next(this.displayValue);\r\n      }\r\n      // if (this.portalAttached() && [ESCAPE].includes(keyCode)) {\r\n      //   this.closeSubject.next();\r\n      // }\r\n    });\r\n    this.multipleInputSizeChange.pipe(distinctUntilChanged(), takeUntil(this._unSubject)).subscribe((x) => {\r\n      if (this.multipleInput) {\r\n        const input = this.multipleInput?.elementRef.nativeElement;\r\n        this.renderer.setStyle(input, 'width', `${x}px`);\r\n      }\r\n    });\r\n  }\r\n\r\n  setMutipleInputSize() {\r\n    const ivf = this.inputCom.inputValueRef.nativeElement as HTMLDivElement;\r\n    let { clientWidth, scrollHeight } = ivf;\r\n    const len = ivf.children.length;\r\n    let lastRowTagTop = -1;\r\n    let lines = 1;\r\n    let rowTagTop = -1;\r\n    let lastRowTagsWidth = 0;\r\n    let marginLeft = 0;\r\n    let marginTop = 0;\r\n    for (let i = len - 1; i >= 0; i--) {\r\n      const ele = ivf.children[i] as HTMLElement;\r\n      if (ele.tagName === 'X-TAG') {\r\n        const { offsetTop, offsetWidth } = ele;\r\n        const style = getComputedStyle(ele);\r\n        marginLeft = Number(style.marginLeft.replace('px', ''));\r\n        marginTop = Number(style.marginTop.replace('px', ''));\r\n        if (rowTagTop === -1) {\r\n          rowTagTop = offsetTop;\r\n        } else if (rowTagTop !== offsetTop) {\r\n          lines++;\r\n          rowTagTop = offsetTop;\r\n        }\r\n        if (lastRowTagTop === -1) {\r\n          lastRowTagTop = offsetTop;\r\n        }\r\n        if (lastRowTagTop === offsetTop) {\r\n          lastRowTagsWidth += offsetWidth + marginLeft;\r\n        }\r\n      }\r\n    }\r\n    const height = scrollHeight + (lines > 1 ? marginTop : 0);\r\n    this.renderer.setStyle(this.inputCom.inputRef.nativeElement, 'height', `${height}px`);\r\n    if (this.multipleInput) {\r\n      this.multipleInputSizeChange.next(clientWidth - lastRowTagsWidth - marginLeft);\r\n    }\r\n    this.portal?.overlayRef?.updatePosition();\r\n  }\r\n\r\n  menter() {\r\n    this.enter = true;\r\n    if (this.disabled || !this.clearable || this.iconSpin) return;\r\n    if (!XIsEmpty(this.displayValue)) {\r\n      this.icon = '';\r\n      this.showClearable = true;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  mleave() {\r\n    this.enter = false;\r\n    if (this.disabled || !this.clearable || this.iconSpin) return;\r\n    if (this.clearable) {\r\n      this.icon = 'fto-chevron-down';\r\n      this.showClearable = false;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  modelChange(value: string | number) {\r\n    if (XIsFunction(this.data)) {\r\n      if (!this.portalAttached()) {\r\n        this.showPortal();\r\n      }\r\n      this.icon = 'fto-loader';\r\n      this.iconSpin = true;\r\n      this.cdr.detectChanges();\r\n      XSetData<XTreeSelectNode>(this.data, this._unSubject, true, value as any).subscribe((x) => {\r\n        this.icon = '';\r\n        this.iconSpin = false;\r\n        if (!this.enter && this.clearable) {\r\n          this.showClearable = false;\r\n        }\r\n        this.nodes = x;\r\n        this.dataChange.next(this.nodes);\r\n        this.cdr.detectChanges();\r\n      });\r\n      return;\r\n    }\r\n    if (this.nodes) {\r\n      if (!this.portalAttached()) {\r\n        this.showPortal();\r\n      }\r\n      if (XIsEmpty(value)) {\r\n        this.searchNodes = [\r\n          ...this.nodes.map((x) => {\r\n            let res = { ...x };\r\n            delete res.children;\r\n            delete res.childrenLoaded;\r\n            delete res.leaf;\r\n            return res;\r\n          })\r\n        ];\r\n      } else {\r\n        this.setSearchNodes(value);\r\n      }\r\n      this.dataChange.next(this.searchNodes);\r\n    }\r\n  }\r\n\r\n  setSearchNodes(value: string | number) {\r\n    let nodes: XTreeSelectNode[] = [];\r\n    const getParent = (node: XTreeSelectNode) => {\r\n      if (XIsEmpty(node.pid)) return;\r\n      const parent = this.nodes.find((x) => x.id === node.pid) as XTreeSelectNode;\r\n      parent.open = true;\r\n      if (!XIsEmpty(parent)) {\r\n        if (nodes.every((x) => x.id !== parent.id)) {\r\n          nodes.push(parent);\r\n        }\r\n      }\r\n    };\r\n    if (this.caseSensitive) {\r\n      nodes = this.nodes.filter((x) => x.label.indexOf(value) >= 0);\r\n    } else {\r\n      nodes = this.nodes.filter((x) => (x.label as string).toLowerCase().indexOf((value as string).toLowerCase()) >= 0);\r\n    }\r\n    for (let node of nodes) {\r\n      getParent(node);\r\n    }\r\n    this.searchNodes = nodes.map((x) => {\r\n      let res = { ...x };\r\n      delete res.children;\r\n      delete res.childrenLoaded;\r\n      delete res.leaf;\r\n      return res;\r\n    });\r\n  }\r\n\r\n  clearEmit() {\r\n    this.value = this.multiple ? [] : '';\r\n    this.displayValue = '';\r\n    this.multipleSearchValue = '';\r\n    this.selectedNodes = [];\r\n    this.setDisplayNodes();\r\n    this.valueTplContext.$node = null;\r\n    this.mleave();\r\n    this.valueChange.next(this.value);\r\n    this.inputChange.next('');\r\n    if (this.onChange) this.onChange(this.value);\r\n  }\r\n\r\n  setDisplayValue(clickNode?: XTreeSelectNode) {\r\n    if (this.nodes.length > 0) {\r\n      if (this.multiple) {\r\n        if (XIsEmpty(this.value)) {\r\n          this.value = [];\r\n          this.displayValue = '';\r\n          this.selectedNodes = [];\r\n          this.displayNodes = [];\r\n          this.displayMore = '';\r\n          this.valueTplContext.$node = null;\r\n          this.setDisplayNodes();\r\n        } else {\r\n          let ids = [];\r\n          let selected = [];\r\n          if (this.objectArray) {\r\n            ids = this.value.map((x: XTreeSelectNode) => x.id);\r\n          } else {\r\n            ids = this.value;\r\n          }\r\n          if (clickNode) {\r\n            let inx = this.selectedNodes.findIndex((x: XTreeSelectNode) => x.id === clickNode.id);\r\n            if (inx >= 0) {\r\n              XRemove(this.selectedNodes, (x) => x.id === clickNode.id);\r\n            } else {\r\n              this.selectedNodes.push(clickNode);\r\n            }\r\n          } else {\r\n            for (let id of ids) {\r\n              let node = this.nodes.find((x) => x.id === id);\r\n              if (node) selected.push(node);\r\n            }\r\n            this.selectedNodes = selected;\r\n          }\r\n          if (this.showPath) {\r\n            for (let node of this.selectedNodes) {\r\n              const parents = this.getParentPath(node);\r\n              node.path = parents.map((x) => x.label).join(this.separator);\r\n            }\r\n          }\r\n          this.setDisplayNodes();\r\n          this.displayValue = this.selectedNodes.map((x) => x.label).join(this.separator);\r\n          this.valueTplContext.$node = [...this.selectedNodes];\r\n        }\r\n      } else {\r\n        let node = this.nodes.find((x) => x.id === this.value);\r\n        if (node) {\r\n          if (this.showPath) {\r\n            const parents = this.getParentPath(node);\r\n            this.displayValue = parents.map((x) => x.label).join(this.separator);\r\n          } else {\r\n            this.displayValue = node.label;\r\n          }\r\n          this.valueTplContext.$node = node;\r\n        } else {\r\n          this.displayValue = '';\r\n          this.valueTplContext.$node = null;\r\n        }\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  getParentPath(node: XTreeSelectNode) {\r\n    let res: XTreeSelectNode[] = [node];\r\n    const getParent = (nd: XTreeSelectNode) => {\r\n      let parent = this.nodes.find((x) => nd.pid && x.id === nd.pid);\r\n      if (parent) {\r\n        res = [parent, ...res];\r\n        getParent(parent);\r\n      }\r\n    };\r\n    getParent(node);\r\n\r\n    return res;\r\n  }\r\n\r\n  closeNode(event: Event, node: XTreeSelectNode, index: number) {\r\n    let inx = -1;\r\n    if (this.objectArray) {\r\n      inx = this.value.findIndex((y: XTreeSelectNode) => y.id === node.id);\r\n    } else {\r\n      inx = this.value.findIndex((y: number | string) => y === node.id);\r\n    }\r\n    if (inx >= 0) {\r\n      this.value.splice(inx, 1);\r\n      this.valueChange.next(this.value);\r\n      if (this.onChange) this.onChange(this.value);\r\n      this.selectedNodes.splice(index, 1);\r\n      this.setDisplayNodes();\r\n    }\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDisplayNodes() {\r\n    if (!this.multiple) return;\r\n    const maxlen = this.selectedNodes.length;\r\n    let len = 0;\r\n    if (!this.maxTagCount) {\r\n      len = maxlen;\r\n    } else {\r\n      len = maxlen > Number(this.maxTagCount) ? Number(this.maxTagCount) : maxlen;\r\n    }\r\n    let more = maxlen - len;\r\n    more = more < 0 ? 0 : more;\r\n    this.displayNodes = this.selectedNodes.slice(0, len);\r\n    this.showDisplayMore = more > 0;\r\n    if (XIsString(this.getMaxTagContent)) {\r\n      this.displayMore = more > 0 ? (this.getMaxTagContent as string).replace(/\\{\\{surplus\\}\\}/g, `${more}`) : '';\r\n    } else {\r\n      this.selectedSurplus = more;\r\n      this.selectedTotal = maxlen;\r\n    }\r\n    setTimeout(() => this.setMutipleInputSize());\r\n  }\r\n\r\n  portalAttached() {\r\n    return this.portal?.overlayRef?.hasAttached();\r\n  }\r\n\r\n  closePortal() {\r\n    if (this.portalAttached()) {\r\n      this.portal?.overlayRef?.detach();\r\n      this.active = false;\r\n      this.multipleSearchValue = '';\r\n      this.cdr.detectChanges();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  destroyPortal() {\r\n    this.portal?.overlayRef?.dispose();\r\n  }\r\n\r\n  showPortal(click = false) {\r\n    if (this.disabled || this.iconSpin || this.animating) return;\r\n    this.active = true;\r\n    if ((this.async && XIsObservable(this.data) && this.nodes.length === 0) || XIsFunction(this.data)) {\r\n      this.icon = 'fto-loader';\r\n      this.iconSpin = true;\r\n      this.inputCom.cdr.detectChanges();\r\n      XSetData<XTreeSelectNode>(this.data, this._unSubject, true, click ? '' : this.displayValue).subscribe((x) => {\r\n        this.icon = 'fto-chevron-down';\r\n        this.iconSpin = false;\r\n        if (!this.enter && this.clearable) {\r\n          this.showClearable = false;\r\n        }\r\n        this.inputCom.cdr.detectChanges();\r\n        this.nodes = x;\r\n        this.dataChange.next(this.nodes);\r\n        if (!this.search) this.setDisplayValue();\r\n        this.createPortal();\r\n        this.cdr.detectChanges();\r\n      });\r\n    } else {\r\n      this.dataChange.next(this.nodes);\r\n      this.createPortal();\r\n    }\r\n    if (this.search && this.multiple) {\r\n      this.multipleInput.inputFocus();\r\n    } else {\r\n      this.inputCom.inputFocus();\r\n    }\r\n  }\r\n\r\n  createPortal() {\r\n    this.box = this.inputCom.inputRef.nativeElement.getBoundingClientRect();\r\n    const config: OverlayConfig = {\r\n      backdropClass: '',\r\n      width: this.box.width,\r\n      positionStrategy: this.setPlacement(),\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\r\n    };\r\n    this.setPosition(config);\r\n    this.portal = this.portalService.attach({\r\n      content: XTreeSelectPortalComponent,\r\n      viewContainerRef: this.viewContainerRef,\r\n      overlayConfig: config\r\n    });\r\n    this.portal.overlayRef\r\n      ?.outsidePointerEvents()\r\n      .pipe(takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        this.setDisplayValue();\r\n        this.closeSubject.next();\r\n      });\r\n    this.setInstance();\r\n  }\r\n\r\n  setPosition(config: OverlayConfig) {\r\n    let position = config.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._unSubject)).subscribe((pos: ConnectedOverlayPositionChange) => {\r\n      const place = XPortalConnectedPosition.get(pos.connectionPair) as XPositionTopBottom;\r\n      place !== this.placement && this.positionChange.next(place);\r\n    });\r\n  }\r\n\r\n  setInstance() {\r\n    let componentRef = this.portal.componentRef;\r\n    if (!componentRef) return;\r\n    Object.assign(componentRef.instance, {\r\n      data: this.nodes,\r\n      value: this.value,\r\n      placement: this.placement,\r\n      multiple: this.multiple,\r\n      selectAll: this.selectAll,\r\n      nodeTpl: this.nodeTpl,\r\n      valueChange: this.valueChange,\r\n      positionChange: this.positionChange,\r\n      closeSubject: this.closeSubject,\r\n      keydownSubject: this.keydownSubject,\r\n      dataChange: this.dataChange,\r\n      inputCom: this.inputCom,\r\n      portalMaxHeight: this.portalMaxHeight,\r\n      objectArray: this.objectArray,\r\n      selectAllText: this.selectAllText,\r\n      caseSensitive: this.caseSensitive,\r\n      search: this.search,\r\n      virtualScroll: this.virtualScroll,\r\n      size: this.size,\r\n      expandedLevel: this.expandedLevel,\r\n      inputChange: this.inputChange,\r\n      destroyPortal: () => this.destroyPortal(),\r\n      nodeEmit: (node: XTreeSelectNode, value: XTreeSelectNode[] | (string | number)[]) => this.nodeClick(node, value),\r\n      animating: (ing: boolean) => (this.animating = ing)\r\n    });\r\n    componentRef.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  nodeClick(node: XTreeSelectNode, value?: XTreeSelectNode[] | (string | number)[]) {\r\n    if (this.multiple) {\r\n      if (this.value.length === 0) {\r\n        this.value = value;\r\n      }\r\n      if (this.multipleInput) {\r\n        const input = this.multipleInput.elementRef.nativeElement;\r\n        this.renderer.setStyle(input, 'width', '2rem');\r\n      }\r\n      if (this.search && this.multipleSearchValue !== '') {\r\n        this.multipleSearchValue = '';\r\n        this.inputChange.next('');\r\n        this.valueChange.next([...this.value]);\r\n      }\r\n      this.setDisplayValue(node);\r\n    } else {\r\n      node = node as XTreeSelectNode;\r\n      if (this.showPath) {\r\n        const parents = this.getParentPath(node);\r\n        this.displayValue = parents.map((x) => x.label).join(this.separator);\r\n      } else {\r\n        this.displayValue = node.label;\r\n      }\r\n      this.valueTplContext.$node = node;\r\n      this.value = node.id;\r\n      this.closeSubject.next();\r\n    }\r\n    if (this.search && this.multiple) {\r\n      this.multipleInput.inputFocus();\r\n    } else {\r\n      this.inputCom.inputFocus();\r\n    }\r\n    if (this.onChange) this.onChange(this.value);\r\n    this.formControlValidator();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  selectAllNodes(value: XTreeSelectNode[] | (string | number)[]) {\r\n    this.value = value;\r\n  }\r\n\r\n  setPlacement() {\r\n    return this.portalService.setPlacement({\r\n      elementRef: this.inputCom.inputRef,\r\n      placement: [this.placement as XPositionTopBottom, 'bottom', 'top'],\r\n      transformOriginOn: 'x-tree-select-portal'\r\n    });\r\n  }\r\n\r\n  setPortal() {\r\n    this.portalAttached() && this.portal?.overlayRef?.updatePositionStrategy(this.setPlacement());\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.setData();\r\n    this.ngOnInit();\r\n    this.writeValue(this.value);\r\n    this.ngAfterViewInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onKeydown($event: KeyboardEvent) {\r\n    this.keydownSubject.next($event);\r\n    if ($event.keyCode !== TAB && !this.search) {\r\n      $event.preventDefault();\r\n    }\r\n  }\r\n\r\n  onFocus(_event: Event) {\r\n    if (this.search && this.multiple) {\r\n      this.multipleInput.inputFocus();\r\n    } else {\r\n      this.inputCom.inputFocus();\r\n    }\r\n  }\r\n\r\n  onInput(_event: InputEvent) {\r\n    this.formControlValidator();\r\n    setTimeout(() => this.inputChange.next(this.multiple ? this.multipleSearchValue : this.displayValue));\r\n  }\r\n}\r\n","<div #treeSelect class=\"x-tree-select\" [class.x-tree-select-multiple]=\"multiple\">\r\n  <div class=\"x-tree-select-row\">\r\n    <x-input\r\n      #inputCom\r\n      type=\"text\"\r\n      [label]=\"label\"\r\n      [labelWidth]=\"labelWidth\"\r\n      [labelAlign]=\"labelAlign\"\r\n      [justify]=\"justify\"\r\n      [align]=\"align\"\r\n      [direction]=\"direction\"\r\n      [required]=\"required\"\r\n      [disabled]=\"disabled\"\r\n      [validator]=\"validator\"\r\n      [icon]=\"icon\"\r\n      [iconSpin]=\"iconSpin\"\r\n      [placeholder]=\"placeholder\"\r\n      [readonly]=\"getReadonly\"\r\n      [clearable]=\"showClearable\"\r\n      [(ngModel)]=\"displayValue\"\r\n      [valueTpl]=\"valueTpl ? valueTpl : nodeTpl\"\r\n      [valueTplContext]=\"valueTplContext\"\r\n      [size]=\"size\"\r\n      [bordered]=\"bordered\"\r\n      [before]=\"before\"\r\n      [after]=\"after\"\r\n      [pattern]=\"pattern\"\r\n      [message]=\"message\"\r\n      [pointer]=\"true\"\r\n      [inputPadding]=\"inputPadding\"\r\n      [(active)]=\"active\"\r\n      (clearEmit)=\"clearEmit()\"\r\n      (xKeydown)=\"onKeydown($event)\"\r\n      (xInput)=\"onInput($event)\"\r\n      (xFocus)=\"onFocus($event)\"\r\n      (xClick)=\"showPortal(true)\"\r\n      (xMouseenter)=\"menter()\"\r\n      (xMouseleave)=\"mleave()\"\r\n      (xComposition)=\"composition = $event\"\r\n    ></x-input>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #multipleValueTpl>\r\n  <x-tag\r\n    [@.disabled]=\"true\"\r\n    *ngFor=\"let node of displayNodes; index as i\"\r\n    [closable]=\"!disabled\"\r\n    (close)=\"closeNode($event, node, i)\"\r\n    [size]=\"size\"\r\n    >{{ showPath ? node.path : node.label }}</x-tag\r\n  >\r\n  <x-tag [@.disabled]=\"true\" *ngIf=\"showDisplayMore\" [size]=\"size\">\r\n    <ng-container *xOutlet=\"getMaxTagContent; context: { $surplus: selectedSurplus, $total: selectedTotal }\">{{\r\n      displayMore\r\n    }}</ng-container>\r\n  </x-tag>\r\n  <x-input\r\n    #multipleInput\r\n    *ngIf=\"search\"\r\n    bordered=\"false\"\r\n    [size]=\"size\"\r\n    inputPadding=\"0.275\"\r\n    [(ngModel)]=\"multipleSearchValue\"\r\n    (xInput)=\"onInput($event)\"\r\n    (xKeydown)=\"onKeydown($event)\"\r\n  ></x-input>\r\n</ng-template>\r\n"]}