@ng-nest/ui 14.0.2 → 14.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (180) hide show
  1. package/auto-complete/auto-complete.component.d.ts +1 -1
  2. package/base-form/base-form.component.d.ts +6 -3
  3. package/button/button.property.d.ts +11 -1
  4. package/cascade/cascade.component.d.ts +1 -1
  5. package/color-picker/color-picker.component.d.ts +1 -1
  6. package/core/config/config.d.ts +3 -0
  7. package/date-picker/date-picker.component.d.ts +1 -1
  8. package/date-picker/date-range.component.d.ts +1 -1
  9. package/dialog/dialog.module.d.ts +2 -1
  10. package/dialog/dialog.property.d.ts +2 -0
  11. package/esm2020/auto-complete/auto-complete.component.mjs +1 -1
  12. package/esm2020/base-form/base-form.component.mjs +11 -3
  13. package/esm2020/button/button.component.mjs +3 -3
  14. package/esm2020/button/button.property.mjs +7 -2
  15. package/esm2020/cascade/cascade.component.mjs +4 -3
  16. package/esm2020/checkbox/checkbox.component.mjs +6 -4
  17. package/esm2020/color-picker/color-picker-portal.component.mjs +3 -3
  18. package/esm2020/color-picker/color-picker.component.mjs +4 -3
  19. package/esm2020/core/config/config.mjs +1 -1
  20. package/esm2020/date-picker/date-picker.component.mjs +4 -3
  21. package/esm2020/date-picker/date-range.component.mjs +1 -1
  22. package/esm2020/dialog/dialog.module.mjs +8 -4
  23. package/esm2020/dialog/dialog.property.mjs +1 -1
  24. package/esm2020/find/find.component.mjs +5 -3
  25. package/esm2020/form/control.component.mjs +37 -25
  26. package/esm2020/form/form.component.mjs +15 -3
  27. package/esm2020/form/form.module.mjs +6 -3
  28. package/esm2020/form/form.property.mjs +10 -3
  29. package/esm2020/i18n/i18n.property.mjs +1 -1
  30. package/esm2020/i18n/languages/en_US.mjs +6 -2
  31. package/esm2020/i18n/languages/zh_CN.mjs +6 -2
  32. package/esm2020/i18n/languages/zh_TW.mjs +6 -2
  33. package/esm2020/input/input.component.mjs +21 -9
  34. package/esm2020/input/input.property.mjs +24 -2
  35. package/esm2020/input-number/input-number.component.mjs +3 -3
  36. package/esm2020/list/list.component.mjs +13 -13
  37. package/esm2020/radio/radio.component.mjs +4 -3
  38. package/esm2020/rate/rate.component.mjs +8 -3
  39. package/esm2020/select/select-portal.component.mjs +6 -4
  40. package/esm2020/select/select.component.mjs +225 -31
  41. package/esm2020/select/select.module.mjs +35 -4
  42. package/esm2020/select/select.property.mjs +14 -3
  43. package/esm2020/slider-select/slider-select.component.mjs +6 -5
  44. package/esm2020/switch/switch.component.mjs +1 -1
  45. package/esm2020/table/table-body.component.mjs +9 -4
  46. package/esm2020/table/table-head.component.mjs +4 -4
  47. package/esm2020/table/table.component.mjs +23 -5
  48. package/esm2020/table/table.property.mjs +10 -3
  49. package/esm2020/tag/tag.component.mjs +5 -5
  50. package/esm2020/tag/tag.property.mjs +1 -1
  51. package/esm2020/textarea/textarea.component.mjs +3 -3
  52. package/esm2020/textarea/textarea.property.mjs +1 -6
  53. package/esm2020/theme/theme.component.mjs +1 -1
  54. package/esm2020/time-picker/time-picker.component.mjs +4 -3
  55. package/esm2020/transfer/transfer.component.mjs +1 -1
  56. package/esm2020/upload/upload.component.mjs +1 -1
  57. package/fesm2015/ng-nest-ui-auto-complete.mjs.map +1 -1
  58. package/fesm2015/ng-nest-ui-base-form.mjs +10 -2
  59. package/fesm2015/ng-nest-ui-base-form.mjs.map +1 -1
  60. package/fesm2015/ng-nest-ui-button.mjs +8 -3
  61. package/fesm2015/ng-nest-ui-button.mjs.map +1 -1
  62. package/fesm2015/ng-nest-ui-cascade.mjs +3 -2
  63. package/fesm2015/ng-nest-ui-cascade.mjs.map +1 -1
  64. package/fesm2015/ng-nest-ui-checkbox.mjs +5 -3
  65. package/fesm2015/ng-nest-ui-checkbox.mjs.map +1 -1
  66. package/fesm2015/ng-nest-ui-color-picker.mjs +5 -4
  67. package/fesm2015/ng-nest-ui-color-picker.mjs.map +1 -1
  68. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  69. package/fesm2015/ng-nest-ui-date-picker.mjs +3 -2
  70. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  71. package/fesm2015/ng-nest-ui-dialog.mjs +7 -3
  72. package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
  73. package/fesm2015/ng-nest-ui-find.mjs +4 -2
  74. package/fesm2015/ng-nest-ui-find.mjs.map +1 -1
  75. package/fesm2015/ng-nest-ui-form.mjs +65 -30
  76. package/fesm2015/ng-nest-ui-form.mjs.map +1 -1
  77. package/fesm2015/ng-nest-ui-i18n.mjs +15 -3
  78. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  79. package/fesm2015/ng-nest-ui-input-number.mjs +2 -2
  80. package/fesm2015/ng-nest-ui-input-number.mjs.map +1 -1
  81. package/fesm2015/ng-nest-ui-input.mjs +43 -9
  82. package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
  83. package/fesm2015/ng-nest-ui-list.mjs +12 -12
  84. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  85. package/fesm2015/ng-nest-ui-radio.mjs +3 -2
  86. package/fesm2015/ng-nest-ui-radio.mjs.map +1 -1
  87. package/fesm2015/ng-nest-ui-rate.mjs +7 -2
  88. package/fesm2015/ng-nest-ui-rate.mjs.map +1 -1
  89. package/fesm2015/ng-nest-ui-select.mjs +278 -38
  90. package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
  91. package/fesm2015/ng-nest-ui-slider-select.mjs +5 -4
  92. package/fesm2015/ng-nest-ui-slider-select.mjs.map +1 -1
  93. package/fesm2015/ng-nest-ui-switch.mjs.map +1 -1
  94. package/fesm2015/ng-nest-ui-table.mjs +46 -15
  95. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  96. package/fesm2015/ng-nest-ui-tag.mjs +4 -4
  97. package/fesm2015/ng-nest-ui-tag.mjs.map +1 -1
  98. package/fesm2015/ng-nest-ui-textarea.mjs +2 -7
  99. package/fesm2015/ng-nest-ui-textarea.mjs.map +1 -1
  100. package/fesm2015/ng-nest-ui-theme.mjs.map +1 -1
  101. package/fesm2015/ng-nest-ui-time-picker.mjs +3 -2
  102. package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
  103. package/fesm2015/ng-nest-ui-transfer.mjs.map +1 -1
  104. package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
  105. package/fesm2020/ng-nest-ui-auto-complete.mjs.map +1 -1
  106. package/fesm2020/ng-nest-ui-base-form.mjs +10 -2
  107. package/fesm2020/ng-nest-ui-base-form.mjs.map +1 -1
  108. package/fesm2020/ng-nest-ui-button.mjs +8 -3
  109. package/fesm2020/ng-nest-ui-button.mjs.map +1 -1
  110. package/fesm2020/ng-nest-ui-cascade.mjs +3 -2
  111. package/fesm2020/ng-nest-ui-cascade.mjs.map +1 -1
  112. package/fesm2020/ng-nest-ui-checkbox.mjs +5 -3
  113. package/fesm2020/ng-nest-ui-checkbox.mjs.map +1 -1
  114. package/fesm2020/ng-nest-ui-color-picker.mjs +5 -4
  115. package/fesm2020/ng-nest-ui-color-picker.mjs.map +1 -1
  116. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  117. package/fesm2020/ng-nest-ui-date-picker.mjs +3 -2
  118. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  119. package/fesm2020/ng-nest-ui-dialog.mjs +7 -3
  120. package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
  121. package/fesm2020/ng-nest-ui-find.mjs +4 -2
  122. package/fesm2020/ng-nest-ui-find.mjs.map +1 -1
  123. package/fesm2020/ng-nest-ui-form.mjs +64 -30
  124. package/fesm2020/ng-nest-ui-form.mjs.map +1 -1
  125. package/fesm2020/ng-nest-ui-i18n.mjs +15 -3
  126. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  127. package/fesm2020/ng-nest-ui-input-number.mjs +2 -2
  128. package/fesm2020/ng-nest-ui-input-number.mjs.map +1 -1
  129. package/fesm2020/ng-nest-ui-input.mjs +43 -9
  130. package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
  131. package/fesm2020/ng-nest-ui-list.mjs +12 -12
  132. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  133. package/fesm2020/ng-nest-ui-radio.mjs +3 -2
  134. package/fesm2020/ng-nest-ui-radio.mjs.map +1 -1
  135. package/fesm2020/ng-nest-ui-rate.mjs +7 -2
  136. package/fesm2020/ng-nest-ui-rate.mjs.map +1 -1
  137. package/fesm2020/ng-nest-ui-select.mjs +275 -38
  138. package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
  139. package/fesm2020/ng-nest-ui-slider-select.mjs +5 -4
  140. package/fesm2020/ng-nest-ui-slider-select.mjs.map +1 -1
  141. package/fesm2020/ng-nest-ui-switch.mjs.map +1 -1
  142. package/fesm2020/ng-nest-ui-table.mjs +42 -12
  143. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  144. package/fesm2020/ng-nest-ui-tag.mjs +4 -4
  145. package/fesm2020/ng-nest-ui-tag.mjs.map +1 -1
  146. package/fesm2020/ng-nest-ui-textarea.mjs +2 -7
  147. package/fesm2020/ng-nest-ui-textarea.mjs.map +1 -1
  148. package/fesm2020/ng-nest-ui-theme.mjs.map +1 -1
  149. package/fesm2020/ng-nest-ui-time-picker.mjs +3 -2
  150. package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
  151. package/fesm2020/ng-nest-ui-transfer.mjs.map +1 -1
  152. package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
  153. package/find/find.component.d.ts +1 -1
  154. package/form/control.component.d.ts +6 -3
  155. package/form/examples/en_US/default/form-vaild/README.md +8 -0
  156. package/form/examples/zh_CN/default/form-vaild/README.md +8 -0
  157. package/form/form.component.d.ts +3 -1
  158. package/form/form.module.d.ts +2 -1
  159. package/form/form.property.d.ts +7 -2
  160. package/i18n/i18n.property.d.ts +6 -0
  161. package/i18n/languages/en_US.d.ts +4 -0
  162. package/i18n/languages/zh_CN.d.ts +4 -0
  163. package/i18n/languages/zh_TW.d.ts +4 -0
  164. package/input/input.component.d.ts +3 -0
  165. package/input/input.property.d.ts +26 -1
  166. package/input-number/input-number.component.d.ts +1 -1
  167. package/package.json +1 -1
  168. package/rate/rate.component.d.ts +1 -0
  169. package/select/select.component.d.ts +25 -5
  170. package/select/select.module.d.ts +4 -2
  171. package/select/select.property.d.ts +13 -2
  172. package/slider-select/slider-select.component.d.ts +1 -1
  173. package/switch/switch.component.d.ts +1 -1
  174. package/table/examples/en_US/default/head/README.md +6 -0
  175. package/table/examples/zh_CN/default/head/README.md +6 -0
  176. package/table/table.component.d.ts +5 -2
  177. package/table/table.property.d.ts +17 -2
  178. package/tag/tag.component.d.ts +1 -1
  179. package/tag/tag.property.d.ts +1 -1
  180. package/time-picker/time-picker.component.d.ts +1 -1
@@ -9,18 +9,49 @@ import { XSelectPortalComponent } from './select-portal.component';
9
9
  import { XSelectProperty } from './select.property';
10
10
  import { XBaseFormModule } from '@ng-nest/ui/base-form';
11
11
  import { XI18nModule } from '@ng-nest/ui/i18n';
12
+ import { XTagModule } from '@ng-nest/ui/tag';
13
+ import { XOutletModule } from '@ng-nest/ui/outlet';
12
14
  import * as i0 from "@angular/core";
13
15
  export class XSelectModule {
14
16
  }
15
17
  /** @nocollapse */ XSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
16
- /** @nocollapse */ XSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, declarations: [XSelectComponent, XSelectPortalComponent, XSelectProperty], imports: [CommonModule, FormsModule, ReactiveFormsModule, XPortalModule, XInputModule, XListModule, XBaseFormModule, XI18nModule], exports: [XSelectComponent, XSelectPortalComponent] });
17
- /** @nocollapse */ XSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, imports: [CommonModule, FormsModule, ReactiveFormsModule, XPortalModule, XInputModule, XListModule, XBaseFormModule, XI18nModule] });
18
+ /** @nocollapse */ XSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, declarations: [XSelectComponent, XSelectPortalComponent, XSelectProperty], imports: [CommonModule,
19
+ FormsModule,
20
+ ReactiveFormsModule,
21
+ XPortalModule,
22
+ XInputModule,
23
+ XListModule,
24
+ XBaseFormModule,
25
+ XTagModule,
26
+ XI18nModule,
27
+ XOutletModule], exports: [XSelectComponent, XSelectPortalComponent] });
28
+ /** @nocollapse */ XSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, imports: [CommonModule,
29
+ FormsModule,
30
+ ReactiveFormsModule,
31
+ XPortalModule,
32
+ XInputModule,
33
+ XListModule,
34
+ XBaseFormModule,
35
+ XTagModule,
36
+ XI18nModule,
37
+ XOutletModule] });
18
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectModule, decorators: [{
19
39
  type: NgModule,
20
40
  args: [{
21
41
  declarations: [XSelectComponent, XSelectPortalComponent, XSelectProperty],
22
42
  exports: [XSelectComponent, XSelectPortalComponent],
23
- imports: [CommonModule, FormsModule, ReactiveFormsModule, XPortalModule, XInputModule, XListModule, XBaseFormModule, XI18nModule]
43
+ imports: [
44
+ CommonModule,
45
+ FormsModule,
46
+ ReactiveFormsModule,
47
+ XPortalModule,
48
+ XInputModule,
49
+ XListModule,
50
+ XBaseFormModule,
51
+ XTagModule,
52
+ XI18nModule,
53
+ XOutletModule
54
+ ]
24
55
  }]
25
56
  }] });
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3NlbGVjdC9zZWxlY3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPL0MsTUFBTSxPQUFPLGFBQWE7OzZIQUFiLGFBQWE7OEhBQWIsYUFBYSxpQkFKVCxnQkFBZ0IsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLGFBRTlELFlBQVksRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLFdBQVcsYUFEdEgsZ0JBQWdCLEVBQUUsc0JBQXNCOzhIQUd2QyxhQUFhLFlBRmQsWUFBWSxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxlQUFlLEVBQUUsV0FBVzsyRkFFckgsYUFBYTtrQkFMekIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLENBQUM7b0JBQ3pFLE9BQU8sRUFBRSxDQUFDLGdCQUFnQixFQUFFLHNCQUFzQixDQUFDO29CQUNuRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUM7aUJBQ2xJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFhTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBYSW5wdXRNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9pbnB1dCc7XHJcbmltcG9ydCB7IFhQb3J0YWxNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9wb3J0YWwnO1xyXG5pbXBvcnQgeyBYTGlzdE1vZHVsZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2xpc3QnO1xyXG5pbXBvcnQgeyBYU2VsZWN0UG9ydGFsQ29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QtcG9ydGFsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFhTZWxlY3RQcm9wZXJ0eSB9IGZyb20gJy4vc2VsZWN0LnByb3BlcnR5JztcclxuaW1wb3J0IHsgWEJhc2VGb3JtTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvYmFzZS1mb3JtJztcclxuaW1wb3J0IHsgWEkxOG5Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9pMThuJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbWFNlbGVjdENvbXBvbmVudCwgWFNlbGVjdFBvcnRhbENvbXBvbmVudCwgWFNlbGVjdFByb3BlcnR5XSxcclxuICBleHBvcnRzOiBbWFNlbGVjdENvbXBvbmVudCwgWFNlbGVjdFBvcnRhbENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUsIFhQb3J0YWxNb2R1bGUsIFhJbnB1dE1vZHVsZSwgWExpc3RNb2R1bGUsIFhCYXNlRm9ybU1vZHVsZSwgWEkxOG5Nb2R1bGVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBYU2VsZWN0TW9kdWxlIHt9XHJcbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3NlbGVjdC9zZWxlY3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQWtCbkQsTUFBTSxPQUFPLGFBQWE7OzZIQUFiLGFBQWE7OEhBQWIsYUFBYSxpQkFmVCxnQkFBZ0IsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLGFBR3RFLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixZQUFZO1FBQ1osV0FBVztRQUNYLGVBQWU7UUFDZixVQUFVO1FBQ1YsV0FBVztRQUNYLGFBQWEsYUFYTCxnQkFBZ0IsRUFBRSxzQkFBc0I7OEhBY3ZDLGFBQWEsWUFadEIsWUFBWTtRQUNaLFdBQVc7UUFDWCxtQkFBbUI7UUFDbkIsYUFBYTtRQUNiLFlBQVk7UUFDWixXQUFXO1FBQ1gsZUFBZTtRQUNmLFVBQVU7UUFDVixXQUFXO1FBQ1gsYUFBYTsyRkFHSixhQUFhO2tCQWhCekIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLENBQUM7b0JBQ3pFLE9BQU8sRUFBRSxDQUFDLGdCQUFnQixFQUFFLHNCQUFzQixDQUFDO29CQUNuRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsYUFBYTt3QkFDYixZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixVQUFVO3dCQUNWLFdBQVc7d0JBQ1gsYUFBYTtxQkFDZDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBYU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgWElucHV0TW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvaW5wdXQnO1xyXG5pbXBvcnQgeyBYUG9ydGFsTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvcG9ydGFsJztcclxuaW1wb3J0IHsgWExpc3RNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9saXN0JztcclxuaW1wb3J0IHsgWFNlbGVjdFBvcnRhbENvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LXBvcnRhbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBYU2VsZWN0UHJvcGVydHkgfSBmcm9tICcuL3NlbGVjdC5wcm9wZXJ0eSc7XHJcbmltcG9ydCB7IFhCYXNlRm9ybU1vZHVsZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2Jhc2UtZm9ybSc7XHJcbmltcG9ydCB7IFhJMThuTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvaTE4bic7XHJcbmltcG9ydCB7IFhUYWdNb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS90YWcnO1xyXG5pbXBvcnQgeyBYT3V0bGV0TW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvb3V0bGV0JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbWFNlbGVjdENvbXBvbmVudCwgWFNlbGVjdFBvcnRhbENvbXBvbmVudCwgWFNlbGVjdFByb3BlcnR5XSxcclxuICBleHBvcnRzOiBbWFNlbGVjdENvbXBvbmVudCwgWFNlbGVjdFBvcnRhbENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgWFBvcnRhbE1vZHVsZSxcclxuICAgIFhJbnB1dE1vZHVsZSxcclxuICAgIFhMaXN0TW9kdWxlLFxyXG4gICAgWEJhc2VGb3JtTW9kdWxlLFxyXG4gICAgWFRhZ01vZHVsZSxcclxuICAgIFhJMThuTW9kdWxlLFxyXG4gICAgWE91dGxldE1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFhTZWxlY3RNb2R1bGUge31cclxuIl19
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { XDataConvert, XInputBoolean, XWithConfig } from '@ng-nest/ui/core';
2
+ import { XDataConvert, XInputBoolean, XWithConfig, XInputNumber } from '@ng-nest/ui/core';
3
3
  import { Input, Component } from '@angular/core';
4
4
  import { XControlValueAccessor } from '@ng-nest/ui/base-form';
5
5
  import * as i0 from "@angular/core";
@@ -24,7 +24,7 @@ export class XSelectProperty extends XControlValueAccessor {
24
24
  }
25
25
  }
26
26
  /** @nocollapse */ XSelectProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
27
- /** @nocollapse */ XSelectProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSelectProperty, selector: "ng-component", inputs: { data: "data", clearable: "clearable", async: "async", placement: "placement", multiple: "multiple", selectAll: "selectAll", selectAllText: "selectAllText", nodeTpl: "nodeTpl", size: "size", bordered: "bordered", portalMaxHeight: "portalMaxHeight", search: "search", caseSensitive: "caseSensitive", debounceTime: "debounceTime" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
27
+ /** @nocollapse */ XSelectProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSelectProperty, selector: "ng-component", inputs: { data: "data", clearable: "clearable", async: "async", placement: "placement", multiple: "multiple", selectAll: "selectAll", selectAllText: "selectAllText", nodeTpl: "nodeTpl", size: "size", bordered: "bordered", portalMaxHeight: "portalMaxHeight", search: "search", caseSensitive: "caseSensitive", debounceTime: "debounceTime", maxTagCount: "maxTagCount", maxTagContent: "maxTagContent" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
28
28
  __decorate([
29
29
  XDataConvert()
30
30
  ], XSelectProperty.prototype, "data", void 0);
@@ -68,6 +68,13 @@ __decorate([
68
68
  __decorate([
69
69
  XWithConfig(X_CONFIG_NAME, 200)
70
70
  ], XSelectProperty.prototype, "debounceTime", void 0);
71
+ __decorate([
72
+ XInputNumber(),
73
+ XWithConfig(X_CONFIG_NAME)
74
+ ], XSelectProperty.prototype, "maxTagCount", void 0);
75
+ __decorate([
76
+ XWithConfig(X_CONFIG_NAME)
77
+ ], XSelectProperty.prototype, "maxTagContent", void 0);
71
78
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSelectProperty, decorators: [{
72
79
  type: Component,
73
80
  args: [{ template: '' }]
@@ -99,6 +106,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
99
106
  type: Input
100
107
  }], debounceTime: [{
101
108
  type: Input
109
+ }], maxTagCount: [{
110
+ type: Input
111
+ }], maxTagContent: [{
112
+ type: Input
102
113
  }] } });
103
114
  /**
104
115
  * Select Portal
@@ -106,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
106
117
  * @decorator component
107
118
  */
108
119
  export const XSelectPortalPrefix = 'x-select-portal';
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/select/select.property.ts"],"names":[],"mappings":";AAAA,OAAO,EAEL,YAAY,EACZ,aAAa,EAGb,WAAW,EAGZ,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,EAAE,SAAS,EAAe,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAe,MAAM,uBAAuB,CAAC;;AAE3E;;;;GAIG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,UAAU,CAAC;AACxC,MAAM,aAAa,GAAG,QAAQ,CAAC;AAE/B;;GAEG;AAEH,MAAM,OAAO,eAAgB,SAAQ,qBAA0B;IAD/D;;QAEE;;;WAGG;QACsB,SAAI,GAAuB,EAAE,CAAC;KAkExD;;+HAvEY,eAAe;mHAAf,eAAe,+ZADL,EAAE;AAME;IAAf,YAAY,EAAE;6CAA+B;AAKe;IAA5D,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;IAAE,aAAa,EAAE;kDAAsB;AAKjE;IAAhB,aAAa,EAAE;8CAAkB;AAKwB;IAAzD,WAAW,CAAqB,aAAa,EAAE,QAAQ,CAAC;kDAAgC;AAKxE;IAAhB,aAAa,EAAE;iDAAqB;AAKpB;IAAhB,aAAa,EAAE;kDAAsB;AAKF;IAAnC,WAAW,CAAS,aAAa,CAAC;sDAAwB;AAUd;IAA5C,WAAW,CAAQ,aAAa,EAAE,QAAQ,CAAC;6CAAuB;AAKN;IAA5D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;iDAAqB;AAKpC;IAA5C,WAAW,CAAS,aAAa,EAAE,OAAO,CAAC;wDAA0B;AAKR;IAA7D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,KAAK,CAAC;+CAAmB;AAKnB;IAA5D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;sDAA0B;AAK7C;IAAxC,WAAW,CAAS,aAAa,EAAE,GAAG,CAAC;qDAAuB;2FAtE7D,eAAe;kBAD3B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMA,IAAI;sBAA5B,KAAK;gBAKgE,SAAS;sBAA9E,KAAK;gBAKoB,KAAK;sBAA9B,KAAK;gBAK6D,SAAS;sBAA3E,KAAK;gBAKoB,QAAQ;sBAAjC,KAAK;gBAKoB,SAAS;sBAAlC,KAAK;gBAKuC,aAAa;sBAAzD,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKyD,IAAI;sBAAlE,KAAK;gBAKgE,QAAQ;sBAA7E,KAAK;gBAKgD,eAAe;sBAApE,KAAK;gBAKiE,MAAM;sBAA5E,KAAK;gBAKgE,aAAa;sBAAlF,KAAK;gBAK4C,YAAY;sBAA7D,KAAK;;AAuER;;;;GAIG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAG,iBAAiB,CAAC","sourcesContent":["import {\r\n  XParentIdentityProperty,\r\n  XDataConvert,\r\n  XInputBoolean,\r\n  XData,\r\n  XBoolean,\r\n  XWithConfig,\r\n  XPositionTopBottom,\r\n  XSize\r\n} from '@ng-nest/ui/core';\r\nimport { Input, Component, TemplateRef } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * Select\r\n * @selector x-select\r\n * @decorator component\r\n */\r\nexport const XSelectPrefix = 'x-select';\r\nconst X_CONFIG_NAME = 'select';\r\n\r\n/**\r\n * Select Property\r\n */\r\n@Component({ template: '' })\r\nexport class XSelectProperty extends XControlValueAccessor<any> {\r\n  /**\r\n   * @zh_CN 节点数据\r\n   * @en_US Node data\r\n   */\r\n  @Input() @XDataConvert() data: XData<XSelectNode> = [];\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 异步加载\r\n   * @en_US Asynchronous loading\r\n   */\r\n  @Input() @XInputBoolean() async?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XPositionTopBottom>(X_CONFIG_NAME, 'bottom') placement?: XPositionTopBottom;\r\n  /**\r\n   * @zh_CN 多选功能\r\n   * @en_US Multiple choice\r\n   */\r\n  @Input() @XInputBoolean() multiple?: XBoolean;\r\n  /**\r\n   * @zh_CN 多选添加全选功能\r\n   * @en_US Multi choice to add full selection function\r\n   */\r\n  @Input() @XInputBoolean() selectAll?: XBoolean;\r\n  /**\r\n   * @zh_CN 全选的文字\r\n   * @en_US Selected all text\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME) selectAllText?: string;\r\n  /**\r\n   * @zh_CN 节点模板\r\n   * @en_US Node template\r\n   */\r\n  @Input() nodeTpl?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 下拉框的最大高度\r\n   * @en_US The biggest height of the drop-down box\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, '12rem') portalMaxHeight!: string;\r\n  /**\r\n   * @zh_CN 输入搜索\r\n   * @en_US Input search\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, false) search!: XBoolean;\r\n  /**\r\n   * @zh_CN 匹配区分大小写\r\n   * @en_US Case-sensitive\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) caseSensitive!: XBoolean;\r\n  /**\r\n   * @zh_CN 输入延迟执行时间，ms\r\n   * @en_US Enter a delay execution time, ms\r\n   */\r\n  @Input() @XWithConfig<number>(X_CONFIG_NAME, 200) debounceTime?: number;\r\n}\r\n\r\n/**\r\n * Select Option\r\n * @undocument true\r\n */\r\nexport interface XSelectOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 节点数据\r\n   * @en_US Node data\r\n   */\r\n  data?: XData<XSelectNode>;\r\n  /**\r\n   * @zh_CN 异步加载\r\n   * @en_US Asynchronous loading\r\n   */\r\n  async?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XPositionTopBottom;\r\n  /**\r\n   * @zh_CN 多选功能\r\n   * @en_US Multiple choice\r\n   */\r\n  multiple?: XBoolean;\r\n  /**\r\n   * @zh_CN 多选添加全选功能\r\n   * @en_US Multi choice to add full selection function\r\n   */\r\n  selectAll?: XBoolean;\r\n  /**\r\n   * @zh_CN 全选的文字\r\n   * @en_US Selected all text\r\n   */\r\n  selectAllText?: string;\r\n  /**\r\n   * @zh_CN 节点模板\r\n   * @en_US Node template\r\n   */\r\n  nodeTpl?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 下拉框的最大高度\r\n   * @en_US The biggest height of the drop-down box\r\n   */\r\n  portalMaxHeight?: string;\r\n  /**\r\n   * @zh_CN 输入搜索\r\n   * @en_US Input search\r\n   */\r\n  search?: XBoolean;\r\n}\r\n\r\n/**\r\n * @zh_CN Select 数据对象\r\n * @en_US Select data object\r\n */\r\nexport interface XSelectNode extends XParentIdentityProperty<XSelectNode> {}\r\n\r\n/**\r\n * Select Portal\r\n * @selector x-select-portal\r\n * @decorator component\r\n */\r\nexport const XSelectPortalPrefix = 'x-select-portal';\r\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/select/select.property.ts"],"names":[],"mappings":";AAAA,OAAO,EAEL,YAAY,EACZ,aAAa,EAGb,WAAW,EAGX,YAAY,EAGb,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,EAAE,SAAS,EAAe,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAe,MAAM,uBAAuB,CAAC;;AAE3E;;;;GAIG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,UAAU,CAAC;AACxC,MAAM,aAAa,GAAG,QAAQ,CAAC;AAE/B;;GAEG;AAEH,MAAM,OAAO,eAAgB,SAAQ,qBAA0B;IAD/D;;QAEE;;;WAGG;QACsB,SAAI,GAAuB,EAAE,CAAC;KA6ExD;;+HAlFY,eAAe;mHAAf,eAAe,2dADL,EAAE;AAME;IAAf,YAAY,EAAE;6CAA+B;AAKe;IAA5D,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;IAAE,aAAa,EAAE;kDAAsB;AAKjE;IAAhB,aAAa,EAAE;8CAAkB;AAKwB;IAAzD,WAAW,CAAqB,aAAa,EAAE,QAAQ,CAAC;kDAAgC;AAKxE;IAAhB,aAAa,EAAE;iDAAqB;AAKpB;IAAhB,aAAa,EAAE;kDAAsB;AAKF;IAAnC,WAAW,CAAS,aAAa,CAAC;sDAAwB;AAUd;IAA5C,WAAW,CAAQ,aAAa,EAAE,QAAQ,CAAC;6CAAuB;AAKN;IAA5D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;iDAAqB;AAKpC;IAA5C,WAAW,CAAS,aAAa,EAAE,OAAO,CAAC;wDAA0B;AAKR;IAA7D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,KAAK,CAAC;+CAAmB;AAKnB;IAA5D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;sDAA0B;AAK7C;IAAxC,WAAW,CAAS,aAAa,EAAE,GAAG,CAAC;qDAAuB;AAKV;IAApD,YAAY,EAAE;IAAE,WAAW,CAAU,aAAa,CAAC;oDAAuB;AAMpC;IAAtC,WAAW,CAAY,aAAa,CAAC;sDAA2B;2FAjF/D,eAAe;kBAD3B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMA,IAAI;sBAA5B,KAAK;gBAKgE,SAAS;sBAA9E,KAAK;gBAKoB,KAAK;sBAA9B,KAAK;gBAK6D,SAAS;sBAA3E,KAAK;gBAKoB,QAAQ;sBAAjC,KAAK;gBAKoB,SAAS;sBAAlC,KAAK;gBAKuC,aAAa;sBAAzD,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKyD,IAAI;sBAAlE,KAAK;gBAKgE,QAAQ;sBAA7E,KAAK;gBAKgD,eAAe;sBAApE,KAAK;gBAKiE,MAAM;sBAA5E,KAAK;gBAKgE,aAAa;sBAAlF,KAAK;gBAK4C,YAAY;sBAA7D,KAAK;gBAKwD,WAAW;sBAAxE,KAAK;gBAM0C,aAAa;sBAA5D,KAAK;;AAuER;;;;GAIG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAG,iBAAiB,CAAC","sourcesContent":["import {\r\n  XParentIdentityProperty,\r\n  XDataConvert,\r\n  XInputBoolean,\r\n  XData,\r\n  XBoolean,\r\n  XWithConfig,\r\n  XPositionTopBottom,\r\n  XSize,\r\n  XInputNumber,\r\n  XNumber,\r\n  XTemplate\r\n} from '@ng-nest/ui/core';\r\nimport { Input, Component, TemplateRef } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * Select\r\n * @selector x-select\r\n * @decorator component\r\n */\r\nexport const XSelectPrefix = 'x-select';\r\nconst X_CONFIG_NAME = 'select';\r\n\r\n/**\r\n * Select Property\r\n */\r\n@Component({ template: '' })\r\nexport class XSelectProperty extends XControlValueAccessor<any> {\r\n  /**\r\n   * @zh_CN 节点数据\r\n   * @en_US Node data\r\n   */\r\n  @Input() @XDataConvert() data: XData<XSelectNode> = [];\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 异步加载\r\n   * @en_US Asynchronous loading\r\n   */\r\n  @Input() @XInputBoolean() async?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XPositionTopBottom>(X_CONFIG_NAME, 'bottom') placement?: XPositionTopBottom;\r\n  /**\r\n   * @zh_CN 多选功能\r\n   * @en_US Multiple choice\r\n   */\r\n  @Input() @XInputBoolean() multiple?: XBoolean;\r\n  /**\r\n   * @zh_CN 多选添加全选功能\r\n   * @en_US Multi choice to add full selection function\r\n   */\r\n  @Input() @XInputBoolean() selectAll?: XBoolean;\r\n  /**\r\n   * @zh_CN 全选的文字\r\n   * @en_US Selected all text\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME) selectAllText?: string;\r\n  /**\r\n   * @zh_CN 节点模板\r\n   * @en_US Node template\r\n   */\r\n  @Input() nodeTpl?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 下拉框的最大高度\r\n   * @en_US The biggest height of the drop-down box\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, '12rem') portalMaxHeight!: string;\r\n  /**\r\n   * @zh_CN 输入搜索\r\n   * @en_US Input search\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, false) search!: XBoolean;\r\n  /**\r\n   * @zh_CN 匹配区分大小写\r\n   * @en_US Case-sensitive\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) caseSensitive!: XBoolean;\r\n  /**\r\n   * @zh_CN 输入延迟执行时间，ms\r\n   * @en_US Enter a delay execution time, ms\r\n   */\r\n  @Input() @XWithConfig<number>(X_CONFIG_NAME, 200) debounceTime?: number;\r\n  /**\r\n   * @zh_CN 多选时显示的选中数据个数，其它的在更多中显示，默认全部显示\r\n   * @en_US Display the number of data in the maximum election, and the others are displayed in more of them\r\n   */\r\n  @Input() @XInputNumber() @XWithConfig<XNumber>(X_CONFIG_NAME) maxTagCount?: XNumber;\r\n  /**\r\n   * @zh_CN 多选时显示的个数超过指定个数，显示的文字模版\r\n   * @en_US The number displayed when multiple choices exceeds the specified number, the displayed text template displayed\r\n   * @default '更多{{surplus}}个选中'\r\n   */\r\n  @Input() @XWithConfig<XTemplate>(X_CONFIG_NAME) maxTagContent?: XTemplate;\r\n}\r\n\r\n/**\r\n * Select Option\r\n * @undocument true\r\n */\r\nexport interface XSelectOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 节点数据\r\n   * @en_US Node data\r\n   */\r\n  data?: XData<XSelectNode>;\r\n  /**\r\n   * @zh_CN 异步加载\r\n   * @en_US Asynchronous loading\r\n   */\r\n  async?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XPositionTopBottom;\r\n  /**\r\n   * @zh_CN 多选功能\r\n   * @en_US Multiple choice\r\n   */\r\n  multiple?: XBoolean;\r\n  /**\r\n   * @zh_CN 多选添加全选功能\r\n   * @en_US Multi choice to add full selection function\r\n   */\r\n  selectAll?: XBoolean;\r\n  /**\r\n   * @zh_CN 全选的文字\r\n   * @en_US Selected all text\r\n   */\r\n  selectAllText?: string;\r\n  /**\r\n   * @zh_CN 节点模板\r\n   * @en_US Node template\r\n   */\r\n  nodeTpl?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 下拉框的最大高度\r\n   * @en_US The biggest height of the drop-down box\r\n   */\r\n  portalMaxHeight?: string;\r\n  /**\r\n   * @zh_CN 输入搜索\r\n   * @en_US Input search\r\n   */\r\n  search?: XBoolean;\r\n}\r\n\r\n/**\r\n * @zh_CN Select 数据对象\r\n * @en_US Select data object\r\n */\r\nexport interface XSelectNode extends XParentIdentityProperty<XSelectNode> {}\r\n\r\n/**\r\n * Select Portal\r\n * @selector x-select-portal\r\n * @decorator component\r\n */\r\nexport const XSelectPortalPrefix = 'x-select-portal';\r\n"]}
@@ -24,8 +24,8 @@ export class XSliderSelectComponent extends XSliderSelectProperty {
24
24
  this.displayValue = '0';
25
25
  this._unSubject = new Subject();
26
26
  }
27
- get getRequired() {
28
- return this.required && XIsEmpty(this.value);
27
+ get requiredIsEmpty() {
28
+ return this.validator && this.required && (XIsEmpty(this.value) || this.value === 0);
29
29
  }
30
30
  writeValue(value) {
31
31
  if (value === null)
@@ -96,6 +96,7 @@ export class XSliderSelectComponent extends XSliderSelectProperty {
96
96
  this.visible = true;
97
97
  }
98
98
  this.cdr.detectChanges();
99
+ this.formControlValidator();
99
100
  this.dragStartEmit.emit(drag);
100
101
  }
101
102
  moved(drag) {
@@ -139,10 +140,10 @@ export class XSliderSelectComponent extends XSliderSelectProperty {
139
140
  }
140
141
  }
141
142
  /** @nocollapse */ XSliderSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderSelectComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
142
- /** @nocollapse */ XSliderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderSelectComponent, selector: "x-slider-select", providers: [XValueAccessor(XSliderSelectComponent)], viewQueries: [{ propertyName: "sliderSelect", first: true, predicate: ["sliderSelect"], descendants: true, static: true }, { propertyName: "dragRef", first: true, predicate: ["dragRef"], descendants: true, static: true }, { propertyName: "railRef", first: true, predicate: ["railRef"], descendants: true, static: true }, { propertyName: "processRef", first: true, predicate: ["processRef"], descendants: true, static: true }, { propertyName: "tooltip", first: true, predicate: XTooltipDirective, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #sliderSelect\r\n class=\"x-slider-select\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-slider-select-inner\" #innerRef>\r\n <div class=\"x-slider-select-rail\" #railRef>\r\n <div></div>\r\n </div>\r\n <div class=\"x-slider-select-track\" #trackRef>\r\n <div class=\"x-slider-select-process\" #processRef></div>\r\n </div>\r\n <div class=\"x-slider-select-drags\">\r\n <div\r\n #dragRef\r\n class=\"x-slider-select-drag\"\r\n cdkDrag\r\n cdkDragLockAxis=\"x\"\r\n [cdkDragDisabled]=\"disabled\"\r\n [cdkDragBoundary]=\"innerRef\"\r\n (cdkDragStarted)=\"started($event)\"\r\n (cdkDragEnded)=\"ended($event)\"\r\n (cdkDragMoved)=\"moved($event)\"\r\n >\r\n <div\r\n #tooltip\r\n x-tooltip\r\n class=\"x-slider-select-button\"\r\n placement=\"top\"\r\n [disabled]=\"!showTooltip\"\r\n [content]=\"displayValue\"\r\n [visible]=\"visible\"\r\n [manual]=\"manual\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-slider-select{display:inline-block;width:12rem}.x-slider-select{margin:0;padding:0;width:100%}.x-slider-select.x-flex{display:flex}.x-slider-select.x-justify-start{justify-content:flex-start}.x-slider-select.x-justify-center{justify-content:center}.x-slider-select.x-justify-end{justify-content:flex-end}.x-slider-select.x-justify-space-between{justify-content:space-between}.x-slider-select.x-justify-space-around{justify-content:space-around}.x-slider-select.x-align-start{align-items:flex-start}.x-slider-select.x-align-center{align-items:center}.x-slider-select.x-align-end{align-items:flex-end}.x-slider-select.x-direction-column{flex-direction:column}.x-slider-select.x-direction-column-reverse{flex-direction:column-reverse}.x-slider-select.x-direction-row{flex-direction:row}.x-slider-select.x-direction-row-reverse{flex-direction:row-reverse}.x-slider-select>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);color:var(--x-text-300);font-weight:600}.x-slider-select>label.x-text-align-start{text-align:start}.x-slider-select>label.x-text-align-center{text-align:center}.x-slider-select>label.x-text-align-end{text-align:end}.x-slider-select>.x-slider-select-inner{flex:1;position:relative;display:flex;align-items:center;padding-right:1rem}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail{position:absolute;margin-left:.5rem;width:calc(100% - 1rem);background-color:var(--x-border-100);height:calc(calc(var(--x-font-size) + .875rem) / 4);border-radius:var(--x-border-radius)}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail>div{width:100%;height:100%}.x-slider-select>.x-slider-select-inner>.x-slider-select-track{margin-left:.5rem;width:calc(100% - 1rem);position:absolute}.x-slider-select>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{height:calc(calc(var(--x-font-size) + .875rem) / 4);background-color:var(--x-primary);border-radius:var(--x-border-radius);width:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags{position:relative;width:100%;height:calc(var(--x-font-size) + .875rem);display:flex;align-items:center}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{position:absolute;cursor:pointer;left:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{width:1rem;height:1rem;border-radius:1rem;border:calc(var(--x-border-width) * 2) solid var(--x-primary);background-color:var(--x-background-a100)}.x-slider-select.x-invalid>label,.x-slider-select.x-required>label{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row>x-icon,.x-slider-select.x-required>.x-slider-select-row>x-icon{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row:before,.x-slider-select.x-required>.x-slider-select-row:before{content:\" \";z-index:2;position:absolute;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);border-top-left-radius:var(--x-border-radius);border-bottom-left-radius:var(--x-border-radius);width:.125rem;background-color:var(--x-danger)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-rail{background-color:var(--x-border-300)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{background-color:var(--x-primary-400)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{cursor:not-allowed}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{border-color:var(--x-primary-400)}.x-slider-select.x-flex.x-direction-row>label{padding:0 .5rem 0 0}.x-slider-select.x-flex.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-slider-select.x-flex.x-direction-column,.x-slider-select.x-flex.x-direction-column-reverse{align-items:inherit}.x-slider-select-max-length{position:absolute;font-size:var(--x-font-size-small);color:var(--x-text-500);padding:0 var(--x-padding-medium);right:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.XTooltipDirective, selector: "[x-tooltip], x-tooltip" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
143
+ /** @nocollapse */ XSliderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XSliderSelectComponent, selector: "x-slider-select", providers: [XValueAccessor(XSliderSelectComponent)], viewQueries: [{ propertyName: "sliderSelect", first: true, predicate: ["sliderSelect"], descendants: true, static: true }, { propertyName: "dragRef", first: true, predicate: ["dragRef"], descendants: true, static: true }, { propertyName: "railRef", first: true, predicate: ["railRef"], descendants: true, static: true }, { propertyName: "processRef", first: true, predicate: ["processRef"], descendants: true, static: true }, { propertyName: "tooltip", first: true, predicate: XTooltipDirective, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #sliderSelect\r\n class=\"x-slider-select\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [class.x-slider-select-label-required]=\"required\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-slider-select-inner\" #innerRef>\r\n <div class=\"x-slider-select-rail\" #railRef>\r\n <div></div>\r\n </div>\r\n <div class=\"x-slider-select-track\" #trackRef>\r\n <div class=\"x-slider-select-process\" #processRef></div>\r\n </div>\r\n <div class=\"x-slider-select-drags\">\r\n <div\r\n #dragRef\r\n class=\"x-slider-select-drag\"\r\n cdkDrag\r\n cdkDragLockAxis=\"x\"\r\n [cdkDragDisabled]=\"disabled\"\r\n [cdkDragBoundary]=\"innerRef\"\r\n (cdkDragStarted)=\"started($event)\"\r\n (cdkDragEnded)=\"ended($event)\"\r\n (cdkDragMoved)=\"moved($event)\"\r\n >\r\n <div\r\n #tooltip\r\n x-tooltip\r\n class=\"x-slider-select-button\"\r\n placement=\"top\"\r\n [disabled]=\"!showTooltip\"\r\n [content]=\"displayValue\"\r\n [visible]=\"visible\"\r\n [manual]=\"manual\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-slider-select{display:inline-block;width:12rem}.x-slider-select{margin:0;padding:0;width:100%}.x-slider-select.x-flex{display:flex}.x-slider-select.x-justify-start{justify-content:flex-start}.x-slider-select.x-justify-center{justify-content:center}.x-slider-select.x-justify-end{justify-content:flex-end}.x-slider-select.x-justify-space-between{justify-content:space-between}.x-slider-select.x-justify-space-around{justify-content:space-around}.x-slider-select.x-align-start{align-items:flex-start}.x-slider-select.x-align-center{align-items:center}.x-slider-select.x-align-end{align-items:flex-end}.x-slider-select.x-direction-column{flex-direction:column}.x-slider-select.x-direction-column-reverse{flex-direction:column-reverse}.x-slider-select.x-direction-row{flex-direction:row}.x-slider-select.x-direction-row-reverse{flex-direction:row-reverse}.x-slider-select>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);color:var(--x-text-300);font-weight:600}.x-slider-select>label.x-text-align-start{text-align:start}.x-slider-select>label.x-text-align-center{text-align:center}.x-slider-select>label.x-text-align-end{text-align:end}.x-slider-select-label-required:before{display:inline-block;margin-right:.25rem;color:var(--x-danger);line-height:1;font-size:var(--x-font-size-small);content:\"*\"}.x-slider-select>.x-slider-select-inner{flex:1;position:relative;display:flex;align-items:center;padding-right:1rem}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail{position:absolute;margin-left:.5rem;width:calc(100% - 1rem);background-color:var(--x-border-100);height:calc(calc(var(--x-font-size) + .875rem) / 4);border-radius:var(--x-border-radius)}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail>div{width:100%;height:100%}.x-slider-select>.x-slider-select-inner>.x-slider-select-track{margin-left:.5rem;width:calc(100% - 1rem);position:absolute}.x-slider-select>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{height:calc(calc(var(--x-font-size) + .875rem) / 4);background-color:var(--x-primary);border-radius:var(--x-border-radius);width:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags{position:relative;width:100%;height:calc(var(--x-font-size) + .875rem);display:flex;align-items:center}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{position:absolute;cursor:pointer;left:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{width:1rem;height:1rem;border-radius:1rem;border:calc(var(--x-border-width) * 2) solid var(--x-primary);background-color:var(--x-background-a100)}.x-slider-select.x-invalid>label,.x-slider-select.x-required>label{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row>x-icon,.x-slider-select.x-required>.x-slider-select-row>x-icon{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row:before,.x-slider-select.x-required>.x-slider-select-row:before{content:\" \";z-index:2;position:absolute;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);border-top-left-radius:var(--x-border-radius);border-bottom-left-radius:var(--x-border-radius);width:.125rem;background-color:var(--x-danger)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-rail{background-color:var(--x-border-300)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{background-color:var(--x-primary-400)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{cursor:not-allowed}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{border-color:var(--x-primary-400)}.x-slider-select.x-flex.x-direction-row>label{padding:0 .5rem 0 0}.x-slider-select.x-flex.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-slider-select.x-flex.x-direction-column,.x-slider-select.x-flex.x-direction-column-reverse{align-items:inherit}.x-slider-select-max-length{position:absolute;font-size:var(--x-font-size-small);color:var(--x-text-500);padding:0 var(--x-padding-medium);right:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.XTooltipDirective, selector: "[x-tooltip], x-tooltip" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
143
144
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XSliderSelectComponent, decorators: [{
144
145
  type: Component,
145
- args: [{ selector: `${XSliderSelectPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XSliderSelectComponent)], template: "<div\r\n #sliderSelect\r\n class=\"x-slider-select\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-slider-select-inner\" #innerRef>\r\n <div class=\"x-slider-select-rail\" #railRef>\r\n <div></div>\r\n </div>\r\n <div class=\"x-slider-select-track\" #trackRef>\r\n <div class=\"x-slider-select-process\" #processRef></div>\r\n </div>\r\n <div class=\"x-slider-select-drags\">\r\n <div\r\n #dragRef\r\n class=\"x-slider-select-drag\"\r\n cdkDrag\r\n cdkDragLockAxis=\"x\"\r\n [cdkDragDisabled]=\"disabled\"\r\n [cdkDragBoundary]=\"innerRef\"\r\n (cdkDragStarted)=\"started($event)\"\r\n (cdkDragEnded)=\"ended($event)\"\r\n (cdkDragMoved)=\"moved($event)\"\r\n >\r\n <div\r\n #tooltip\r\n x-tooltip\r\n class=\"x-slider-select-button\"\r\n placement=\"top\"\r\n [disabled]=\"!showTooltip\"\r\n [content]=\"displayValue\"\r\n [visible]=\"visible\"\r\n [manual]=\"manual\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-slider-select{display:inline-block;width:12rem}.x-slider-select{margin:0;padding:0;width:100%}.x-slider-select.x-flex{display:flex}.x-slider-select.x-justify-start{justify-content:flex-start}.x-slider-select.x-justify-center{justify-content:center}.x-slider-select.x-justify-end{justify-content:flex-end}.x-slider-select.x-justify-space-between{justify-content:space-between}.x-slider-select.x-justify-space-around{justify-content:space-around}.x-slider-select.x-align-start{align-items:flex-start}.x-slider-select.x-align-center{align-items:center}.x-slider-select.x-align-end{align-items:flex-end}.x-slider-select.x-direction-column{flex-direction:column}.x-slider-select.x-direction-column-reverse{flex-direction:column-reverse}.x-slider-select.x-direction-row{flex-direction:row}.x-slider-select.x-direction-row-reverse{flex-direction:row-reverse}.x-slider-select>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);color:var(--x-text-300);font-weight:600}.x-slider-select>label.x-text-align-start{text-align:start}.x-slider-select>label.x-text-align-center{text-align:center}.x-slider-select>label.x-text-align-end{text-align:end}.x-slider-select>.x-slider-select-inner{flex:1;position:relative;display:flex;align-items:center;padding-right:1rem}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail{position:absolute;margin-left:.5rem;width:calc(100% - 1rem);background-color:var(--x-border-100);height:calc(calc(var(--x-font-size) + .875rem) / 4);border-radius:var(--x-border-radius)}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail>div{width:100%;height:100%}.x-slider-select>.x-slider-select-inner>.x-slider-select-track{margin-left:.5rem;width:calc(100% - 1rem);position:absolute}.x-slider-select>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{height:calc(calc(var(--x-font-size) + .875rem) / 4);background-color:var(--x-primary);border-radius:var(--x-border-radius);width:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags{position:relative;width:100%;height:calc(var(--x-font-size) + .875rem);display:flex;align-items:center}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{position:absolute;cursor:pointer;left:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{width:1rem;height:1rem;border-radius:1rem;border:calc(var(--x-border-width) * 2) solid var(--x-primary);background-color:var(--x-background-a100)}.x-slider-select.x-invalid>label,.x-slider-select.x-required>label{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row>x-icon,.x-slider-select.x-required>.x-slider-select-row>x-icon{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row:before,.x-slider-select.x-required>.x-slider-select-row:before{content:\" \";z-index:2;position:absolute;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);border-top-left-radius:var(--x-border-radius);border-bottom-left-radius:var(--x-border-radius);width:.125rem;background-color:var(--x-danger)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-rail{background-color:var(--x-border-300)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{background-color:var(--x-primary-400)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{cursor:not-allowed}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{border-color:var(--x-primary-400)}.x-slider-select.x-flex.x-direction-row>label{padding:0 .5rem 0 0}.x-slider-select.x-flex.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-slider-select.x-flex.x-direction-column,.x-slider-select.x-flex.x-direction-column-reverse{align-items:inherit}.x-slider-select-max-length{position:absolute;font-size:var(--x-font-size-small);color:var(--x-text-500);padding:0 var(--x-padding-medium);right:0}\n"] }]
146
+ args: [{ selector: `${XSliderSelectPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XSliderSelectComponent)], template: "<div\r\n #sliderSelect\r\n class=\"x-slider-select\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [class.x-slider-select-label-required]=\"required\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-slider-select-inner\" #innerRef>\r\n <div class=\"x-slider-select-rail\" #railRef>\r\n <div></div>\r\n </div>\r\n <div class=\"x-slider-select-track\" #trackRef>\r\n <div class=\"x-slider-select-process\" #processRef></div>\r\n </div>\r\n <div class=\"x-slider-select-drags\">\r\n <div\r\n #dragRef\r\n class=\"x-slider-select-drag\"\r\n cdkDrag\r\n cdkDragLockAxis=\"x\"\r\n [cdkDragDisabled]=\"disabled\"\r\n [cdkDragBoundary]=\"innerRef\"\r\n (cdkDragStarted)=\"started($event)\"\r\n (cdkDragEnded)=\"ended($event)\"\r\n (cdkDragMoved)=\"moved($event)\"\r\n >\r\n <div\r\n #tooltip\r\n x-tooltip\r\n class=\"x-slider-select-button\"\r\n placement=\"top\"\r\n [disabled]=\"!showTooltip\"\r\n [content]=\"displayValue\"\r\n [visible]=\"visible\"\r\n [manual]=\"manual\"\r\n ></div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";x-slider-select{display:inline-block;width:12rem}.x-slider-select{margin:0;padding:0;width:100%}.x-slider-select.x-flex{display:flex}.x-slider-select.x-justify-start{justify-content:flex-start}.x-slider-select.x-justify-center{justify-content:center}.x-slider-select.x-justify-end{justify-content:flex-end}.x-slider-select.x-justify-space-between{justify-content:space-between}.x-slider-select.x-justify-space-around{justify-content:space-around}.x-slider-select.x-align-start{align-items:flex-start}.x-slider-select.x-align-center{align-items:center}.x-slider-select.x-align-end{align-items:flex-end}.x-slider-select.x-direction-column{flex-direction:column}.x-slider-select.x-direction-column-reverse{flex-direction:column-reverse}.x-slider-select.x-direction-row{flex-direction:row}.x-slider-select.x-direction-row-reverse{flex-direction:row-reverse}.x-slider-select>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);color:var(--x-text-300);font-weight:600}.x-slider-select>label.x-text-align-start{text-align:start}.x-slider-select>label.x-text-align-center{text-align:center}.x-slider-select>label.x-text-align-end{text-align:end}.x-slider-select-label-required:before{display:inline-block;margin-right:.25rem;color:var(--x-danger);line-height:1;font-size:var(--x-font-size-small);content:\"*\"}.x-slider-select>.x-slider-select-inner{flex:1;position:relative;display:flex;align-items:center;padding-right:1rem}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail{position:absolute;margin-left:.5rem;width:calc(100% - 1rem);background-color:var(--x-border-100);height:calc(calc(var(--x-font-size) + .875rem) / 4);border-radius:var(--x-border-radius)}.x-slider-select>.x-slider-select-inner>.x-slider-select-rail>div{width:100%;height:100%}.x-slider-select>.x-slider-select-inner>.x-slider-select-track{margin-left:.5rem;width:calc(100% - 1rem);position:absolute}.x-slider-select>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{height:calc(calc(var(--x-font-size) + .875rem) / 4);background-color:var(--x-primary);border-radius:var(--x-border-radius);width:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags{position:relative;width:100%;height:calc(var(--x-font-size) + .875rem);display:flex;align-items:center}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{position:absolute;cursor:pointer;left:0%}.x-slider-select>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{width:1rem;height:1rem;border-radius:1rem;border:calc(var(--x-border-width) * 2) solid var(--x-primary);background-color:var(--x-background-a100)}.x-slider-select.x-invalid>label,.x-slider-select.x-required>label{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row>x-icon,.x-slider-select.x-required>.x-slider-select-row>x-icon{color:var(--x-danger)}.x-slider-select.x-invalid>.x-slider-select-row:before,.x-slider-select.x-required>.x-slider-select-row:before{content:\" \";z-index:2;position:absolute;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);border-top-left-radius:var(--x-border-radius);border-bottom-left-radius:var(--x-border-radius);width:.125rem;background-color:var(--x-danger)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-rail{background-color:var(--x-border-300)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-track>.x-slider-select-process{background-color:var(--x-primary-400)}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag{cursor:not-allowed}.x-slider-select.x-disabled>.x-slider-select-inner>.x-slider-select-drags>.x-slider-select-drag>.x-slider-select-button{border-color:var(--x-primary-400)}.x-slider-select.x-flex.x-direction-row>label{padding:0 .5rem 0 0}.x-slider-select.x-flex.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-slider-select.x-flex.x-direction-column,.x-slider-select.x-flex.x-direction-column-reverse{align-items:inherit}.x-slider-select-max-length{position:absolute;font-size:var(--x-font-size-small);color:var(--x-text-500);padding:0 var(--x-padding-medium);right:0}\n"] }]
146
147
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { sliderSelect: [{
147
148
  type: ViewChild,
148
149
  args: ['sliderSelect', { static: true }]
@@ -159,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
159
160
  type: ViewChild,
160
161
  args: [XTooltipDirective, { static: true }]
161
162
  }] } });
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-select.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider-select/slider-select.component.ts","../../../../../lib/ng-nest/ui/slider-select/slider-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XTooltipDirective } from '@ng-nest/ui/tooltip';\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  ViewChild,\r\n  OnDestroy,\r\n  AfterViewInit\r\n} from '@angular/core';\r\nimport { XSliderSelectProperty, XSliderSelectPrefix } from './slider-select.property';\r\nimport { XIsEmpty, XIsUndefined, XResize, XClearClass, XConfigService } from '@ng-nest/ui/core';\r\nimport { CdkDragMove, CdkDragStart, CdkDragEnd } from '@angular/cdk/drag-drop';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: `${XSliderSelectPrefix}`,\r\n  templateUrl: './slider-select.component.html',\r\n  styleUrls: ['./slider-select.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XSliderSelectComponent)]\r\n})\r\nexport class XSliderSelectComponent extends XSliderSelectProperty implements OnInit, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderSelect', { static: true }) sliderSelect!: ElementRef;\r\n  @ViewChild('dragRef', { static: true }) dragRef!: ElementRef;\r\n  @ViewChild('railRef', { static: true }) railRef!: ElementRef;\r\n  @ViewChild('processRef', { static: true }) processRef!: ElementRef;\r\n  @ViewChild(XTooltipDirective, { static: true }) tooltip!: XTooltipDirective;\r\n  left: number = 0;\r\n  visible: boolean = false;\r\n  manual: boolean = false;\r\n  start!: number;\r\n  override value = 0;\r\n  displayValue = '0';\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  get getRequired() {\r\n    return this.required && XIsEmpty(this.value);\r\n  }\r\n\r\n  override writeValue(value: number) {\r\n    if (value === null) value = 0;\r\n    this.value = value;\r\n    this.setLeft();\r\n    this.setDisplayValue();\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.sliderSelect.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setPrecision();\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    XResize(this.sliderSelect.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.setLeft();\r\n        this.setDisplayValue();\r\n        this.cdr.detectChanges();\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  change() {\r\n    const val = Number(((Number(this.max) - Number(this.min)) * Number(this.left)) / 100 + Number(this.min)).toFixed(\r\n      Number(this.precision)\r\n    );\r\n    this.value = parseFloat(val);\r\n    this.setDisplayValue();\r\n    if (this.onChange) this.onChange(this.value);\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  setLeft() {\r\n    this.left = Math.round(((this.value - Number(this.min)) * 100) / (Number(this.max) - Number(this.min)));\r\n    const start = this.left;\r\n    this.start = start;\r\n    this.setDrag();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setDisplayValue() {\r\n    this.displayValue = Number(this.value).toFixed(Number(this.precision));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setPrecision() {\r\n    if (XIsUndefined(this.precision) || !XIsEmpty(this.step)) {\r\n      let stepStr = String(this.step);\r\n      let indexpoint = stepStr.indexOf('.');\r\n      if (indexpoint === -1) {\r\n        this.precision = 0;\r\n      } else {\r\n        this.precision = stepStr.length - (indexpoint + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  started(drag: CdkDragStart) {\r\n    const start = this.left;\r\n    this.start = start;\r\n    if (this.showTooltip) {\r\n      this.manual = true;\r\n      this.visible = true;\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.dragStartEmit.emit(drag);\r\n  }\r\n\r\n  moved(drag: CdkDragMove) {\r\n    let transform = drag.source.getFreeDragPosition();\r\n    this.setDrag(transform.x);\r\n    drag.source.reset();\r\n    if (this.showTooltip) {\r\n      this.tooltip.updatePortal();\r\n    }\r\n    this.change();\r\n    this.dragMoveEmit.emit(drag);\r\n  }\r\n\r\n  ended(drag: CdkDragEnd) {\r\n    if (this.showTooltip) {\r\n      this.manual = false;\r\n      this.visible = false;\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.dragEndEmit.emit(drag);\r\n  }\r\n\r\n  setDrag(distance: number = 0) {\r\n    let railBox = this.railRef.nativeElement.getBoundingClientRect();\r\n    let stepWidth = railBox.width / ((Number(this.max) - Number(this.min)) / Number(this.step));\r\n    let offset = Math.abs(distance % stepWidth);\r\n    let dis =\r\n      offset < stepWidth / 2\r\n        ? distance > 0\r\n          ? distance - offset\r\n          : distance + offset\r\n        : distance > 0\r\n        ? distance + stepWidth - offset\r\n        : distance - stepWidth + offset;\r\n    let x = (this.start / 100) * railBox.width + dis;\r\n    this.left = Math.round((x / railBox.width) * 100);\r\n    this.renderer.setStyle(this.dragRef.nativeElement, 'left', `${this.left}%`);\r\n    this.renderer.setStyle(this.processRef.nativeElement, 'width', `${this.left}%`);\r\n    this.renderer.removeStyle(this.dragRef.nativeElement, 'transform');\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #sliderSelect\r\n  class=\"x-slider-select\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n>\r\n  <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-slider-select-inner\" #innerRef>\r\n    <div class=\"x-slider-select-rail\" #railRef>\r\n      <div></div>\r\n    </div>\r\n    <div class=\"x-slider-select-track\" #trackRef>\r\n      <div class=\"x-slider-select-process\" #processRef></div>\r\n    </div>\r\n    <div class=\"x-slider-select-drags\">\r\n      <div\r\n        #dragRef\r\n        class=\"x-slider-select-drag\"\r\n        cdkDrag\r\n        cdkDragLockAxis=\"x\"\r\n        [cdkDragDisabled]=\"disabled\"\r\n        [cdkDragBoundary]=\"innerRef\"\r\n        (cdkDragStarted)=\"started($event)\"\r\n        (cdkDragEnded)=\"ended($event)\"\r\n        (cdkDragMoved)=\"moved($event)\"\r\n      >\r\n        <div\r\n          #tooltip\r\n          x-tooltip\r\n          class=\"x-slider-select-button\"\r\n          placement=\"top\"\r\n          [disabled]=\"!showTooltip\"\r\n          [content]=\"displayValue\"\r\n          [visible]=\"visible\"\r\n          [manual]=\"manual\"\r\n        ></div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-select.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider-select/slider-select.component.ts","../../../../../lib/ng-nest/ui/slider-select/slider-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { XTooltipDirective } from '@ng-nest/ui/tooltip';\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  ViewChild,\r\n  OnDestroy,\r\n  AfterViewInit\r\n} from '@angular/core';\r\nimport { XSliderSelectProperty, XSliderSelectPrefix } from './slider-select.property';\r\nimport { XIsEmpty, XIsUndefined, XResize, XClearClass, XConfigService } from '@ng-nest/ui/core';\r\nimport { CdkDragMove, CdkDragStart, CdkDragEnd } from '@angular/cdk/drag-drop';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: `${XSliderSelectPrefix}`,\r\n  templateUrl: './slider-select.component.html',\r\n  styleUrls: ['./slider-select.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XSliderSelectComponent)]\r\n})\r\nexport class XSliderSelectComponent extends XSliderSelectProperty implements OnInit, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderSelect', { static: true }) sliderSelect!: ElementRef;\r\n  @ViewChild('dragRef', { static: true }) dragRef!: ElementRef;\r\n  @ViewChild('railRef', { static: true }) railRef!: ElementRef;\r\n  @ViewChild('processRef', { static: true }) processRef!: ElementRef;\r\n  @ViewChild(XTooltipDirective, { static: true }) tooltip!: XTooltipDirective;\r\n  left: number = 0;\r\n  visible: boolean = false;\r\n  manual: boolean = false;\r\n  start!: number;\r\n  override value = 0;\r\n  displayValue = '0';\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  override get requiredIsEmpty() {\r\n    return this.validator && this.required && (XIsEmpty(this.value) || this.value === 0);\r\n  }\r\n\r\n  override writeValue(value: number) {\r\n    if (value === null) value = 0;\r\n    this.value = value;\r\n    this.setLeft();\r\n    this.setDisplayValue();\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public override cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setFlex(this.sliderSelect.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setPrecision();\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    XResize(this.sliderSelect.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.setLeft();\r\n        this.setDisplayValue();\r\n        this.cdr.detectChanges();\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  change() {\r\n    const val = Number(((Number(this.max) - Number(this.min)) * Number(this.left)) / 100 + Number(this.min)).toFixed(\r\n      Number(this.precision)\r\n    );\r\n    this.value = parseFloat(val);\r\n    this.setDisplayValue();\r\n    if (this.onChange) this.onChange(this.value);\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  setLeft() {\r\n    this.left = Math.round(((this.value - Number(this.min)) * 100) / (Number(this.max) - Number(this.min)));\r\n    const start = this.left;\r\n    this.start = start;\r\n    this.setDrag();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setDisplayValue() {\r\n    this.displayValue = Number(this.value).toFixed(Number(this.precision));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setPrecision() {\r\n    if (XIsUndefined(this.precision) || !XIsEmpty(this.step)) {\r\n      let stepStr = String(this.step);\r\n      let indexpoint = stepStr.indexOf('.');\r\n      if (indexpoint === -1) {\r\n        this.precision = 0;\r\n      } else {\r\n        this.precision = stepStr.length - (indexpoint + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  started(drag: CdkDragStart) {\r\n    const start = this.left;\r\n    this.start = start;\r\n    if (this.showTooltip) {\r\n      this.manual = true;\r\n      this.visible = true;\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.formControlValidator();\r\n    this.dragStartEmit.emit(drag);\r\n  }\r\n\r\n  moved(drag: CdkDragMove) {\r\n    let transform = drag.source.getFreeDragPosition();\r\n    this.setDrag(transform.x);\r\n    drag.source.reset();\r\n    if (this.showTooltip) {\r\n      this.tooltip.updatePortal();\r\n    }\r\n    this.change();\r\n    this.dragMoveEmit.emit(drag);\r\n  }\r\n\r\n  ended(drag: CdkDragEnd) {\r\n    if (this.showTooltip) {\r\n      this.manual = false;\r\n      this.visible = false;\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.dragEndEmit.emit(drag);\r\n  }\r\n\r\n  setDrag(distance: number = 0) {\r\n    let railBox = this.railRef.nativeElement.getBoundingClientRect();\r\n    let stepWidth = railBox.width / ((Number(this.max) - Number(this.min)) / Number(this.step));\r\n    let offset = Math.abs(distance % stepWidth);\r\n    let dis =\r\n      offset < stepWidth / 2\r\n        ? distance > 0\r\n          ? distance - offset\r\n          : distance + offset\r\n        : distance > 0\r\n        ? distance + stepWidth - offset\r\n        : distance - stepWidth + offset;\r\n    let x = (this.start / 100) * railBox.width + dis;\r\n    this.left = Math.round((x / railBox.width) * 100);\r\n    this.renderer.setStyle(this.dragRef.nativeElement, 'left', `${this.left}%`);\r\n    this.renderer.setStyle(this.processRef.nativeElement, 'width', `${this.left}%`);\r\n    this.renderer.removeStyle(this.dragRef.nativeElement, 'transform');\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #sliderSelect\r\n  class=\"x-slider-select\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n>\r\n  <label *ngIf=\"label\" [class.x-slider-select-label-required]=\"required\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-slider-select-inner\" #innerRef>\r\n    <div class=\"x-slider-select-rail\" #railRef>\r\n      <div></div>\r\n    </div>\r\n    <div class=\"x-slider-select-track\" #trackRef>\r\n      <div class=\"x-slider-select-process\" #processRef></div>\r\n    </div>\r\n    <div class=\"x-slider-select-drags\">\r\n      <div\r\n        #dragRef\r\n        class=\"x-slider-select-drag\"\r\n        cdkDrag\r\n        cdkDragLockAxis=\"x\"\r\n        [cdkDragDisabled]=\"disabled\"\r\n        [cdkDragBoundary]=\"innerRef\"\r\n        (cdkDragStarted)=\"started($event)\"\r\n        (cdkDragEnded)=\"ended($event)\"\r\n        (cdkDragMoved)=\"moved($event)\"\r\n      >\r\n        <div\r\n          #tooltip\r\n          x-tooltip\r\n          class=\"x-slider-select-button\"\r\n          placement=\"top\"\r\n          [disabled]=\"!showTooltip\"\r\n          [content]=\"displayValue\"\r\n          [visible]=\"visible\"\r\n          [manual]=\"manual\"\r\n        ></div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
46
46
  type: ViewChild,
47
47
  args: ['switch', { static: true }]
48
48
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUVULGlCQUFpQixFQUNqQix1QkFBdUIsRUFJdkIsU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkUsT0FBTyxFQUFFLFdBQVcsRUFBa0IsTUFBTSxrQkFBa0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7QUFVdkQsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGVBQWU7SUFRbkQsWUFBbUIsUUFBbUIsRUFBVSxHQUFzQixFQUFTLGFBQTZCO1FBQzFHLEtBQUssRUFBRSxDQUFDO1FBRFMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFVLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBQVMsa0JBQWEsR0FBYixhQUFhLENBQWdCO0lBRTVHLENBQUM7SUFQUSxVQUFVLENBQUMsS0FBVTtRQUM1QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFNRCxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDakcsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxXQUFXO1FBQ1QsV0FBVyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMzQixJQUFJLENBQUMsUUFBUSxDQUFDLGdCQUFnQixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUNwRixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBQzFCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQ3pCLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QyxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2hCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7Z0lBaENVLGdCQUFnQjtvSEFBaEIsZ0JBQWdCLG1DQUZoQixDQUFDLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLGlLQ3BCL0Msc1hBTUE7MkZEZ0JhLGdCQUFnQjtrQkFSNUIsU0FBUzsrQkFDRSxHQUFHLGFBQWEsRUFBRSxpQkFHYixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsY0FBYyxrQkFBa0IsQ0FBQzs2SkFHTixNQUFNO3NCQUE1QyxTQUFTO3VCQUFDLFFBQVEsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBPbkluaXQsXHJcbiAgVmlld0VuY2Fwc3VsYXRpb24sXHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgUmVuZGVyZXIyLFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgVmlld0NoaWxkXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFhTd2l0Y2hQcm9wZXJ0eSwgWFN3aXRjaFByZWZpeCB9IGZyb20gJy4vc3dpdGNoLnByb3BlcnR5JztcclxuaW1wb3J0IHsgWENsZWFyQ2xhc3MsIFhDb25maWdTZXJ2aWNlIH0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcbmltcG9ydCB7IFhWYWx1ZUFjY2Vzc29yIH0gZnJvbSAnQG5nLW5lc3QvdWkvYmFzZS1mb3JtJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBgJHtYU3dpdGNoUHJlZml4fWAsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3N3aXRjaC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vc3dpdGNoLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBwcm92aWRlcnM6IFtYVmFsdWVBY2Nlc3NvcihYU3dpdGNoQ29tcG9uZW50KV1cclxufSlcclxuZXhwb3J0IGNsYXNzIFhTd2l0Y2hDb21wb25lbnQgZXh0ZW5kcyBYU3dpdGNoUHJvcGVydHkgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBWaWV3Q2hpbGQoJ3N3aXRjaCcsIHsgc3RhdGljOiB0cnVlIH0pIHN3aXRjaCE6IEVsZW1lbnRSZWY7XHJcblxyXG4gIG92ZXJyaWRlIHdyaXRlVmFsdWUodmFsdWU6IGFueSkge1xyXG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xyXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHVibGljIHJlbmRlcmVyOiBSZW5kZXJlcjIsIHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZiwgcHVibGljIGNvbmZpZ1NlcnZpY2U6IFhDb25maWdTZXJ2aWNlKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnNldEZsZXgodGhpcy5zd2l0Y2gubmF0aXZlRWxlbWVudCwgdGhpcy5yZW5kZXJlciwgdGhpcy5qdXN0aWZ5LCB0aGlzLmFsaWduLCB0aGlzLmRpcmVjdGlvbik7XHJcbiAgICB0aGlzLnNldENsYXNzTWFwKCk7XHJcbiAgfVxyXG5cclxuICBzZXRDbGFzc01hcCgpIHtcclxuICAgIFhDbGVhckNsYXNzKHRoaXMubGFiZWxNYXApO1xyXG4gICAgdGhpcy5sYWJlbE1hcFtgeC10ZXh0LWFsaWduLSR7dGhpcy5sYWJlbEFsaWdufWBdID0gdGhpcy5sYWJlbEFsaWduID8gdHJ1ZSA6IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgc3dpdGNoQ2xpY2soKSB7XHJcbiAgICBpZiAodGhpcy5kaXNhYmxlZCkgcmV0dXJuO1xyXG4gICAgdGhpcy52YWx1ZSA9ICF0aGlzLnZhbHVlO1xyXG4gICAgaWYgKHRoaXMub25DaGFuZ2UpIHRoaXMub25DaGFuZ2UodGhpcy52YWx1ZSk7XHJcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgfVxyXG5cclxuICBmb3JtQ29udHJvbENoYW5nZXMoKSB7XHJcbiAgICB0aGlzLm5nT25Jbml0KCk7XHJcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgI3N3aXRjaCBjbGFzcz1cIngtc3dpdGNoXCIgW2NsYXNzLngtZmxleF09XCJqdXN0aWZ5IHx8IGFsaWduIHx8IGRpcmVjdGlvblwiIFtjbGFzcy54LWNoZWNrZWRdPVwidmFsdWVcIiBbY2xhc3MueC1kaXNhYmxlZF09XCJkaXNhYmxlZFwiPlxyXG4gIDxsYWJlbCAqbmdJZj1cImxhYmVsXCIgW3N0eWxlLndpZHRoXT1cImxhYmVsV2lkdGhcIiBbbmdDbGFzc109XCJsYWJlbE1hcFwiPnt7IGxhYmVsIH19PC9sYWJlbD5cclxuICA8ZGl2IGNsYXNzPVwieC1zd2l0Y2gtcm93XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwieC1zd2l0Y2gtc2xpZGVyXCIgKGNsaWNrKT1cInN3aXRjaENsaWNrKClcIj48L2Rpdj5cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUVULGlCQUFpQixFQUNqQix1QkFBdUIsRUFJdkIsU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkUsT0FBTyxFQUFFLFdBQVcsRUFBa0IsTUFBTSxrQkFBa0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7QUFVdkQsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGVBQWU7SUFRbkQsWUFBbUIsUUFBbUIsRUFBa0IsR0FBc0IsRUFBUyxhQUE2QjtRQUNsSCxLQUFLLEVBQUUsQ0FBQztRQURTLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBa0IsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFBUyxrQkFBYSxHQUFiLGFBQWEsQ0FBZ0I7SUFFcEgsQ0FBQztJQVBRLFVBQVUsQ0FBQyxLQUFVO1FBQzVCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQU1ELFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNqRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELFdBQVc7UUFDVCxXQUFXLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzNCLElBQUksQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQ3BGLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUFFLE9BQU87UUFDMUIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDekIsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELGtCQUFrQjtRQUNoQixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDaEIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDOztnSUFoQ1UsZ0JBQWdCO29IQUFoQixnQkFBZ0IsbUNBRmhCLENBQUMsY0FBYyxDQUFDLGdCQUFnQixDQUFDLENBQUMsaUtDcEIvQyxzWEFNQTsyRkRnQmEsZ0JBQWdCO2tCQVI1QixTQUFTOytCQUNFLEdBQUcsYUFBYSxFQUFFLGlCQUdiLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sYUFDcEMsQ0FBQyxjQUFjLGtCQUFrQixDQUFDOzZKQUdOLE1BQU07c0JBQTVDLFNBQVM7dUJBQUMsUUFBUSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIE9uSW5pdCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICBSZW5kZXJlcjIsXHJcbiAgRWxlbWVudFJlZixcclxuICBWaWV3Q2hpbGRcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgWFN3aXRjaFByb3BlcnR5LCBYU3dpdGNoUHJlZml4IH0gZnJvbSAnLi9zd2l0Y2gucHJvcGVydHknO1xyXG5pbXBvcnQgeyBYQ2xlYXJDbGFzcywgWENvbmZpZ1NlcnZpY2UgfSBmcm9tICdAbmctbmVzdC91aS9jb3JlJztcclxuaW1wb3J0IHsgWFZhbHVlQWNjZXNzb3IgfSBmcm9tICdAbmctbmVzdC91aS9iYXNlLWZvcm0nO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IGAke1hTd2l0Y2hQcmVmaXh9YCxcclxuICB0ZW1wbGF0ZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zd2l0Y2guY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIHByb3ZpZGVyczogW1hWYWx1ZUFjY2Vzc29yKFhTd2l0Y2hDb21wb25lbnQpXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgWFN3aXRjaENvbXBvbmVudCBleHRlbmRzIFhTd2l0Y2hQcm9wZXJ0eSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQFZpZXdDaGlsZCgnc3dpdGNoJywgeyBzdGF0aWM6IHRydWUgfSkgc3dpdGNoITogRWxlbWVudFJlZjtcclxuXHJcbiAgb3ZlcnJpZGUgd3JpdGVWYWx1ZSh2YWx1ZTogYW55KSB7XHJcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHVibGljIG92ZXJyaWRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsIHB1YmxpYyBjb25maWdTZXJ2aWNlOiBYQ29uZmlnU2VydmljZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5zZXRGbGV4KHRoaXMuc3dpdGNoLm5hdGl2ZUVsZW1lbnQsIHRoaXMucmVuZGVyZXIsIHRoaXMuanVzdGlmeSwgdGhpcy5hbGlnbiwgdGhpcy5kaXJlY3Rpb24pO1xyXG4gICAgdGhpcy5zZXRDbGFzc01hcCgpO1xyXG4gIH1cclxuXHJcbiAgc2V0Q2xhc3NNYXAoKSB7XHJcbiAgICBYQ2xlYXJDbGFzcyh0aGlzLmxhYmVsTWFwKTtcclxuICAgIHRoaXMubGFiZWxNYXBbYHgtdGV4dC1hbGlnbi0ke3RoaXMubGFiZWxBbGlnbn1gXSA9IHRoaXMubGFiZWxBbGlnbiA/IHRydWUgOiBmYWxzZTtcclxuICB9XHJcblxyXG4gIHN3aXRjaENsaWNrKCkge1xyXG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHJldHVybjtcclxuICAgIHRoaXMudmFsdWUgPSAhdGhpcy52YWx1ZTtcclxuICAgIGlmICh0aGlzLm9uQ2hhbmdlKSB0aGlzLm9uQ2hhbmdlKHRoaXMudmFsdWUpO1xyXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxuXHJcbiAgZm9ybUNvbnRyb2xDaGFuZ2VzKCkge1xyXG4gICAgdGhpcy5uZ09uSW5pdCgpO1xyXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2ICNzd2l0Y2ggY2xhc3M9XCJ4LXN3aXRjaFwiIFtjbGFzcy54LWZsZXhdPVwianVzdGlmeSB8fCBhbGlnbiB8fCBkaXJlY3Rpb25cIiBbY2xhc3MueC1jaGVja2VkXT1cInZhbHVlXCIgW2NsYXNzLngtZGlzYWJsZWRdPVwiZGlzYWJsZWRcIj5cclxuICA8bGFiZWwgKm5nSWY9XCJsYWJlbFwiIFtzdHlsZS53aWR0aF09XCJsYWJlbFdpZHRoXCIgW25nQ2xhc3NdPVwibGFiZWxNYXBcIj57eyBsYWJlbCB9fTwvbGFiZWw+XHJcbiAgPGRpdiBjbGFzcz1cIngtc3dpdGNoLXJvd1wiPlxyXG4gICAgPGRpdiBjbGFzcz1cIngtc3dpdGNoLXNsaWRlclwiIChjbGljayk9XCJzd2l0Y2hDbGljaygpXCI+PC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -84,8 +84,10 @@ export class XTableBodyComponent extends XTableBodyProperty {
84
84
  const ele = x.srcElement;
85
85
  this.table.scrollTop = ele.scrollTop;
86
86
  this.table.scrollLeft = ele.scrollLeft;
87
- if (ele.scrollLeft >= 0 && this.table.thead) {
88
- this.table.thead.nativeElement.scrollLeft = this.table.scrollLeft;
87
+ if (ele.scrollLeft >= 0 && this.table.thead.length > 0) {
88
+ for (let thead of this.table.thead) {
89
+ thead.nativeElement.scrollLeft = this.table.scrollLeft;
90
+ }
89
91
  }
90
92
  this.table.scrollLeftMax = ele.scrollLeft + ele.clientWidth === ele.scrollWidth;
91
93
  this.table.cdr.detectChanges();
@@ -152,7 +154,10 @@ export class XTableBodyComponent extends XTableBodyProperty {
152
154
  setAdaptionHeight() {
153
155
  if (this.adaptionHeight > 0) {
154
156
  const captionHeight = this.table.tcaption?.nativeElement.clientHeight || 0;
155
- const headHeight = this.table.thead?.nativeElement.clientHeight || 0;
157
+ let headHeight = 0;
158
+ for (let thead of this.table.thead) {
159
+ headHeight += thead.nativeElement.clientHeight;
160
+ }
156
161
  const footHeight = this.table.tfoot?.nativeElement.clientHeight || 0;
157
162
  console.log(captionHeight, footHeight);
158
163
  const paginationHeight = this.table.pagination?.elementRef.nativeElement.clientHeight || 0;
@@ -208,4 +213,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
208
213
  }], table: [{
209
214
  type: Input
210
215
  }] } });
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-body.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/table/table-body.component.ts","../../../../../lib/ng-nest/ui/table/table-body.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  Inject,\r\n  ViewChild,\r\n  Input\r\n} from '@angular/core';\r\nimport { XTableBodyPrefix, XTableBodyProperty, XTableRow, XTableColumn, XTableCell } from './table.property';\r\nimport { removeNgTag, XIsChange, XResize, XConfigService, XNumber, stripTags } from '@ng-nest/ui/core';\r\nimport { Subject, fromEvent } from 'rxjs';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XTableBodyPrefix}`,\r\n  templateUrl: './table-body.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XTableBodyComponent extends XTableBodyProperty implements OnInit, OnChanges {\r\n  tbodyStyle: { [property: string]: any } = {};\r\n  get isEmpty() {\r\n    return this.data?.length === 0;\r\n  }\r\n  get getRowHeight() {\r\n    return this.rowHeight == 0 ? '' : this.rowHeight;\r\n  }\r\n  get getItemSize() {\r\n    return this.rowHeight !== 0 && this.itemSize > this.rowHeight ? this.rowHeight : this.itemSize;\r\n  }\r\n\r\n  @ViewChild('tbody') tbody!: ElementRef;\r\n  @ViewChild('virtualBody') virtualBody!: CdkVirtualScrollViewport;\r\n  @Input() table: any;\r\n\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    // @Optional() @Host() public table: XTableComponent,\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    @Inject(DOCUMENT) public doc: any,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n  ngOnChanges(simples: SimpleChanges) {\r\n    const { data, columns, activatedRow, mergeRule, expandedAll } = simples;\r\n    XIsChange(data, columns, activatedRow, mergeRule, expandedAll) && this.cdr.detectChanges();\r\n  }\r\n\r\n  ngOnInit() {\r\n    removeNgTag(this.elementRef.nativeElement);\r\n    if (this.level > 0) removeNgTag(this.tbody.nativeElement);\r\n    if (this.scroll?.y && !this.bodyHeight) {\r\n      this.bodyHeight = this.scroll.y;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.table.virtualBody = this.virtualBody;\r\n    this.table.bodyChange = () => this.cdr.detectChanges();\r\n    this.setSubject();\r\n    this.setScroll();\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  setSubject() {\r\n    if (this.virtualBody) {\r\n      this.table.scrollContentEle = this.virtualBody?.elementRef?.nativeElement.querySelector(\r\n        '.cdk-virtual-scroll-content-wrapper'\r\n      ) as HTMLElement;\r\n      if (this.scroll?.x) {\r\n        this.renderer.setStyle(this.table.scrollContentEle, 'width', `${this.scroll.x}px`);\r\n      }\r\n      XResize(this.table.table.nativeElement, this.table.scrollContentEle)\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe((x) => {\r\n          this._resizeObserver = x.resizeObserver;\r\n          this.setAdaptionHeight();\r\n          this.setScroll();\r\n        });\r\n      fromEvent(window, 'resize')\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe(() => {\r\n          this.setAdaptionHeight();\r\n        });\r\n    }\r\n    if (this.table.scrollContentEle) {\r\n      fromEvent(this.virtualBody.elementRef.nativeElement, 'scroll')\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe((x) => {\r\n          const ele = x.srcElement as HTMLElement;\r\n          this.table.scrollTop = ele.scrollTop;\r\n          this.table.scrollLeft = ele.scrollLeft;\r\n          if (ele.scrollLeft >= 0 && this.table.thead) {\r\n            this.table.thead.nativeElement.scrollLeft = this.table.scrollLeft;\r\n          }\r\n          this.table.scrollLeftMax = ele.scrollLeft + ele.clientWidth === ele.scrollWidth;\r\n          this.table.cdr.detectChanges();\r\n        });\r\n    }\r\n  }\r\n\r\n  setScroll() {\r\n    if (!this.virtualBody) return;\r\n    const ele = this.virtualBody.elementRef.nativeElement;\r\n    const hasY = ele.scrollHeight > (this.bodyHeight as number);\r\n    const hasX = this.table.scrollContentEle.clientWidth > ele.clientWidth;\r\n\r\n    if (!this.table.hasScrollY && hasY) {\r\n      this.table.hasScrollY = true;\r\n      this.table.scrollYWidth = ele.offsetWidth - ele.clientWidth;\r\n    } else if (this.table.hasScrollY && !hasY) {\r\n      this.table.hasScrollY = false;\r\n      this.table.scrollYWidth = 0;\r\n    }\r\n\r\n    if (!this.table.hasScrollX && hasX) {\r\n      this.table.hasScrollX = true;\r\n      this.table.scrollXHeight = ele.offsetHeight - ele.clientHeight;\r\n    } else if (this.table.hasScrollX && !hasX) {\r\n      this.table.hasScrollX = false;\r\n      this.table.scrollXHeight = 0;\r\n      this.table.scrollXWidth = null;\r\n    }\r\n    if (hasX) {\r\n      this.table.scrollXWidth = ele.offsetWidth + ele.scrollWidth - ele.clientWidth;\r\n    }\r\n\r\n    this.table.cdr.detectChanges();\r\n  }\r\n\r\n  setStyle() {\r\n    let height = this.rowHeight == 0 ? '' : this.rowHeight;\r\n    if (this.cellConfig && this.cellConfig.cells) {\r\n      const spt = this.cellConfig.cells.map((x) => {\r\n        const gridAreaSpt = x.gridArea?.split('/');\r\n        return gridAreaSpt && gridAreaSpt.length > 3 ? Number(gridAreaSpt[2]) : 2;\r\n      });\r\n      height = ((Math.max(...spt) - 1) * (height as number)) as XNumber;\r\n    }\r\n    this.tbodyStyle = {\r\n      height: `${height}px`\r\n    };\r\n  }\r\n\r\n  getIndex(index: number, item: XTableRow) {\r\n    if (!isNaN(index)) return index;\r\n    return this.data.indexOf(item);\r\n  }\r\n\r\n  getFlex(column: XTableColumn) {\r\n    if (column.width) return 'none';\r\n    if (!column.flex) return 1;\r\n    return column.flex;\r\n  }\r\n\r\n  getTitle(row: XTableRow, column: XTableCell | any) {\r\n    let it = row[column.id as string];\r\n    return it ? stripTags(it) : '';\r\n  }\r\n\r\n  setAdaptionHeight() {\r\n    if ((this.adaptionHeight as number) > 0) {\r\n      const captionHeight = this.table.tcaption?.nativeElement.clientHeight || 0;\r\n      const headHeight = this.table.thead?.nativeElement.clientHeight || 0;\r\n\r\n      const footHeight = this.table.tfoot?.nativeElement.clientHeight || 0;\r\n      console.log(captionHeight, footHeight);\r\n      const paginationHeight = this.table.pagination?.elementRef.nativeElement.clientHeight || 0;\r\n      this.bodyHeight =\r\n        Number(this.docPercent) * this.doc.documentElement.clientHeight -\r\n        captionHeight -\r\n        headHeight -\r\n        footHeight -\r\n        paginationHeight -\r\n        Number(this.adaptionHeight);\r\n      if (this.bodyHeight < 0) this.bodyHeight = 0;\r\n      this.minBufferPx = this.bodyHeight;\r\n      this.maxBufferPx = this.bodyHeight * 1.2;\r\n      this.virtualBody['_scrollStrategy']['_minBufferPx'] = this.minBufferPx;\r\n      this.virtualBody['_scrollStrategy']['_maxBufferPx'] = this.maxBufferPx;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  rowClick(row: XTableRow) {\r\n    this.activatedRow = row;\r\n    if (this.allowSelectRow && this.table.rowChecked) {\r\n      if (!Array.from((event as any).path).find((x: any) => x.localName == 'x-checkbox')) {\r\n        row[this.table.rowChecked.id] = !row[this.table.rowChecked.id];\r\n        this.table.bodyChecked(row[this.table.rowChecked.id], this.table.rowChecked);\r\n      }\r\n    }\r\n    this.activatedRowChange.emit(row);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onExpanded(_event: Event, node: XTableRow) {\r\n    node.expanded = !node.expanded;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  trackByItem(_index: number, item: XTableRow | XTableColumn) {\r\n    return item.id;\r\n  }\r\n}\r\n","<tbody #tbody>\r\n  <ng-container *ngIf=\"cellConfig; else virtualScrollTpl\">\r\n    <tr *ngFor=\"let row of data; index as i; trackBy: trackByItem\" [style.gridTemplateColumns]=\"cellConfig.gridTemplateColumns\">\r\n      <td\r\n        *ngFor=\"let column of cellConfig.cells; index as j\"\r\n        [title]=\"getTitle(row, column)\"\r\n        [class.x-table-sticky]=\"table.getStickyLeft(column) || table.getStickyRight(column)\"\r\n        [class.x-table-sticky-left]=\"table.getStickyLeft(column)\"\r\n        [class.x-table-sticky-right]=\"table.getStickyRight(column)\"\r\n        [class.x-table-sticky-left-last]=\"table.getStickyLeftLast(column)\"\r\n        [class.x-table-sticky-right-first]=\"table.getStickyRightFirst(column)\"\r\n        [style.left.px]=\"column.left\"\r\n        [style.right.px]=\"column.right\"\r\n        [style.grid-area]=\"column.gridArea\"\r\n      >\r\n        <ng-container *ngTemplateOutlet=\"cellTpl; context: { column: column, row: row, i: i }\"></ng-container>\r\n      </td>\r\n    </tr>\r\n  </ng-container>\r\n  <x-empty *ngIf=\"isEmpty && level === 0\"></x-empty>\r\n</tbody>\r\n\r\n<ng-template #virtualScrollTpl>\r\n  <cdk-virtual-scroll-viewport\r\n    #virtualBody\r\n    *ngIf=\"virtualScroll; else bodyTpl\"\r\n    [itemSize]=\"getItemSize\"\r\n    [minBufferPx]=\"minBufferPx\"\r\n    [maxBufferPx]=\"maxBufferPx\"\r\n    [style.height.px]=\"bodyHeight\"\r\n  >\r\n    <tr\r\n      *cdkVirtualFor=\"let row of data; let index = index; trackBy: trackByItem\"\r\n      [class.x-table-activated]=\"allowSelectRow && activatedRow?.id === row.id\"\r\n      [style.height.px]=\"getRowHeight\"\r\n      [style.min-height.px]=\"getRowHeight\"\r\n      (click)=\"rowClick(row)\"\r\n    >\r\n      <!-- rowHeight 为 0 的时候，index 下标获取不到 -->\r\n      <ng-container *ngTemplateOutlet=\"rowTpl; context: { row: row, i: getIndex(index, row) }\"></ng-container>\r\n    </tr>\r\n  </cdk-virtual-scroll-viewport>\r\n</ng-template>\r\n\r\n<ng-template #bodyTpl>\r\n  <ng-container *ngFor=\"let row of data; index as i; trackBy: trackByItem\">\r\n    <tr\r\n      [class.x-table-activated]=\"allowSelectRow && activatedRow?.id === row.id\"\r\n      [style.height.px]=\"getRowHeight\"\r\n      [style.min-height.px]=\"getRowHeight\"\r\n      (click)=\"rowClick(row)\"\r\n    >\r\n      <ng-container *ngTemplateOutlet=\"rowTpl; context: { row: row, i: i }\"></ng-container>\r\n    </tr>\r\n    <div class=\"x-table-children\" [class.x-table-expandTpl]=\"expandTpl\" *ngIf=\"table.treeTable && row.children && row.expanded\">\r\n      <x-table-body\r\n        [data]=\"row.children\"\r\n        [columns]=\"table.columns\"\r\n        [itemSize]=\"table.itemSize\"\r\n        [rowHeight]=\"table.rowHeight\"\r\n        [columnTpl]=\"table.bodyColumnTpl\"\r\n        [allowSelectRow]=\"table.allowSelectRow\"\r\n        [rowClass]=\"table.rowClass\"\r\n        [cellConfig]=\"table.cellConfig?.tbody\"\r\n        [(activatedRow)]=\"table.activatedRow\"\r\n        [expandedAll]=\"expandedAll\"\r\n        [expandTpl]=\"expandTpl\"\r\n        (activatedRowChange)=\"table.activatedRowChange.emit($event)\"\r\n        [level]=\"row.level! + 1\"\r\n        [table]=\"table\"\r\n      ></x-table-body>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #rowTpl let-row=\"row\" let-i=\"i\">\r\n  <ng-container *ngIf=\"level > 0 && expandTpl\">\r\n    <ng-container *xOutlet=\"expandTpl; context: { $row: row, $index: i, $level: level }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"level === 0 || !expandTpl\">\r\n    <ng-container *xOutlet=\"rowDefault; context: { row: row, i: i, level: level }\"></ng-container>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #rowDefault let-row=\"row\" let-i=\"i\">\r\n  <ng-container *ngFor=\"let column of columns; index as j; trackBy: trackByItem\">\r\n    <td\r\n      [style.width.px]=\"column.width\"\r\n      [style.flex]=\"getFlex(column)\"\r\n      [title]=\"getTitle(row, column)\"\r\n      [class.x-table-sticky]=\"table.getStickyLeft(column) || table.getStickyRight(column)\"\r\n      [class.x-table-sticky-left]=\"table.getStickyLeft(column)\"\r\n      [class.x-table-sticky-right]=\"table.getStickyRight(column)\"\r\n      [class.x-table-sticky-left-last]=\"table.getStickyLeftLast(column)\"\r\n      [class.x-table-sticky-right-first]=\"table.getStickyRightFirst(column)\"\r\n      [style.left.px]=\"column.left\"\r\n      [style.right.px]=\"column.right\"\r\n      [ngClass]=\"!rowClass ? {} : rowClass(row, i)\"\r\n    >\r\n      <ng-template *ngTemplateOutlet=\"cellTpl; context: { column: column, row: row, i: i }\"></ng-template>\r\n    </td>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #cellTpl let-column=\"column\" let-row=\"row\" let-i=\"i\">\r\n  <ng-container [ngSwitch]=\"column.type\">\r\n    <ng-container *ngSwitchCase=\"'checkbox'\">\r\n      <x-checkbox\r\n        [data]=\"[{ id: true, label: '' }]\"\r\n        [(ngModel)]=\"row[column.id]\"\r\n        (ngModelChange)=\"table.bodyChecked($event, column)\"\r\n      ></x-checkbox>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'index'\">\r\n      <div>{{ table.getIndex(i) }}</div>\r\n    </ng-container>\r\n    <ng-container *ngSwitchDefault>\r\n      <ng-container *ngIf=\"table.isExpandColumn(column)\">\r\n        <x-button\r\n          [class.is-leaf]=\"!row.leaf\"\r\n          [class.is-expanded]=\"row.expanded\"\r\n          (click)=\"onExpanded($event, row)\"\r\n          icon=\"fto-chevron-right\"\r\n          size=\"mini\"\r\n          onlyIcon\r\n          class=\"x-table-expand\"\r\n          [style.margin-left.rem]=\"row.level - 0.5\"\r\n        ></x-button>\r\n      </ng-container>\r\n      <ng-container *xOutlet=\"columnTpl[column.id]; context: { $column: column, $row: row, $index: table.getIndex(i) }\">\r\n        <div [innerHTML]=\"row[column.id]\" [style.text-align]=\"column.textAlign\"></div>\r\n        {{ table.rowExpandNext && table.rowExpandNext.id === column.id ? 'x-table-body-level-' + row.level : '' }}\r\n      </ng-container>\r\n    </ng-container>\r\n  </ng-container>\r\n</ng-template>\r\n"]}
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-body.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/table/table-body.component.ts","../../../../../lib/ng-nest/ui/table/table-body.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  Inject,\r\n  ViewChild,\r\n  Input\r\n} from '@angular/core';\r\nimport { XTableBodyPrefix, XTableBodyProperty, XTableRow, XTableColumn, XTableCell } from './table.property';\r\nimport { removeNgTag, XIsChange, XResize, XConfigService, XNumber, stripTags } from '@ng-nest/ui/core';\r\nimport { Subject, fromEvent } from 'rxjs';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XTableBodyPrefix}`,\r\n  templateUrl: './table-body.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XTableBodyComponent extends XTableBodyProperty implements OnInit, OnChanges {\r\n  tbodyStyle: { [property: string]: any } = {};\r\n  get isEmpty() {\r\n    return this.data?.length === 0;\r\n  }\r\n  get getRowHeight() {\r\n    return this.rowHeight == 0 ? '' : this.rowHeight;\r\n  }\r\n  get getItemSize() {\r\n    return this.rowHeight !== 0 && this.itemSize > this.rowHeight ? this.rowHeight : this.itemSize;\r\n  }\r\n\r\n  @ViewChild('tbody') tbody!: ElementRef;\r\n  @ViewChild('virtualBody') virtualBody!: CdkVirtualScrollViewport;\r\n  @Input() table: any;\r\n\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    // @Optional() @Host() public table: XTableComponent,\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    @Inject(DOCUMENT) public doc: any,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n  ngOnChanges(simples: SimpleChanges) {\r\n    const { data, columns, activatedRow, mergeRule, expandedAll } = simples;\r\n    XIsChange(data, columns, activatedRow, mergeRule, expandedAll) && this.cdr.detectChanges();\r\n  }\r\n\r\n  ngOnInit() {\r\n    removeNgTag(this.elementRef.nativeElement);\r\n    if (this.level > 0) removeNgTag(this.tbody.nativeElement);\r\n    if (this.scroll?.y && !this.bodyHeight) {\r\n      this.bodyHeight = this.scroll.y;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.table.virtualBody = this.virtualBody;\r\n    this.table.bodyChange = () => this.cdr.detectChanges();\r\n    this.setSubject();\r\n    this.setScroll();\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  setSubject() {\r\n    if (this.virtualBody) {\r\n      this.table.scrollContentEle = this.virtualBody?.elementRef?.nativeElement.querySelector(\r\n        '.cdk-virtual-scroll-content-wrapper'\r\n      ) as HTMLElement;\r\n      if (this.scroll?.x) {\r\n        this.renderer.setStyle(this.table.scrollContentEle, 'width', `${this.scroll.x}px`);\r\n      }\r\n      XResize(this.table.table.nativeElement, this.table.scrollContentEle)\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe((x) => {\r\n          this._resizeObserver = x.resizeObserver;\r\n          this.setAdaptionHeight();\r\n          this.setScroll();\r\n        });\r\n      fromEvent(window, 'resize')\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe(() => {\r\n          this.setAdaptionHeight();\r\n        });\r\n    }\r\n    if (this.table.scrollContentEle) {\r\n      fromEvent(this.virtualBody.elementRef.nativeElement, 'scroll')\r\n        .pipe(takeUntil(this._unSubject))\r\n        .subscribe((x) => {\r\n          const ele = x.srcElement as HTMLElement;\r\n          this.table.scrollTop = ele.scrollTop;\r\n          this.table.scrollLeft = ele.scrollLeft;\r\n          if (ele.scrollLeft >= 0 && this.table.thead.length > 0) {\r\n            for (let thead of this.table.thead) {\r\n              thead.nativeElement.scrollLeft = this.table.scrollLeft;\r\n            }\r\n          }\r\n          this.table.scrollLeftMax = ele.scrollLeft + ele.clientWidth === ele.scrollWidth;\r\n          this.table.cdr.detectChanges();\r\n        });\r\n    }\r\n  }\r\n\r\n  setScroll() {\r\n    if (!this.virtualBody) return;\r\n    const ele = this.virtualBody.elementRef.nativeElement;\r\n    const hasY = ele.scrollHeight > (this.bodyHeight as number);\r\n    const hasX = this.table.scrollContentEle.clientWidth > ele.clientWidth;\r\n\r\n    if (!this.table.hasScrollY && hasY) {\r\n      this.table.hasScrollY = true;\r\n      this.table.scrollYWidth = ele.offsetWidth - ele.clientWidth;\r\n    } else if (this.table.hasScrollY && !hasY) {\r\n      this.table.hasScrollY = false;\r\n      this.table.scrollYWidth = 0;\r\n    }\r\n\r\n    if (!this.table.hasScrollX && hasX) {\r\n      this.table.hasScrollX = true;\r\n      this.table.scrollXHeight = ele.offsetHeight - ele.clientHeight;\r\n    } else if (this.table.hasScrollX && !hasX) {\r\n      this.table.hasScrollX = false;\r\n      this.table.scrollXHeight = 0;\r\n      this.table.scrollXWidth = null;\r\n    }\r\n    if (hasX) {\r\n      this.table.scrollXWidth = ele.offsetWidth + ele.scrollWidth - ele.clientWidth;\r\n    }\r\n\r\n    this.table.cdr.detectChanges();\r\n  }\r\n\r\n  setStyle() {\r\n    let height = this.rowHeight == 0 ? '' : this.rowHeight;\r\n    if (this.cellConfig && this.cellConfig.cells) {\r\n      const spt = this.cellConfig.cells.map((x) => {\r\n        const gridAreaSpt = x.gridArea?.split('/');\r\n        return gridAreaSpt && gridAreaSpt.length > 3 ? Number(gridAreaSpt[2]) : 2;\r\n      });\r\n      height = ((Math.max(...spt) - 1) * (height as number)) as XNumber;\r\n    }\r\n    this.tbodyStyle = {\r\n      height: `${height}px`\r\n    };\r\n  }\r\n\r\n  getIndex(index: number, item: XTableRow) {\r\n    if (!isNaN(index)) return index;\r\n    return this.data.indexOf(item);\r\n  }\r\n\r\n  getFlex(column: XTableColumn) {\r\n    if (column.width) return 'none';\r\n    if (!column.flex) return 1;\r\n    return column.flex;\r\n  }\r\n\r\n  getTitle(row: XTableRow, column: XTableCell | any) {\r\n    let it = row[column.id as string];\r\n    return it ? stripTags(it) : '';\r\n  }\r\n\r\n  setAdaptionHeight() {\r\n    if ((this.adaptionHeight as number) > 0) {\r\n      const captionHeight = this.table.tcaption?.nativeElement.clientHeight || 0;\r\n      let headHeight = 0;\r\n      for (let thead of this.table.thead) {\r\n        headHeight += thead.nativeElement.clientHeight;\r\n      }\r\n      const footHeight = this.table.tfoot?.nativeElement.clientHeight || 0;\r\n      console.log(captionHeight, footHeight);\r\n      const paginationHeight = this.table.pagination?.elementRef.nativeElement.clientHeight || 0;\r\n      this.bodyHeight =\r\n        Number(this.docPercent) * this.doc.documentElement.clientHeight -\r\n        captionHeight -\r\n        headHeight -\r\n        footHeight -\r\n        paginationHeight -\r\n        Number(this.adaptionHeight);\r\n      if (this.bodyHeight < 0) this.bodyHeight = 0;\r\n      this.minBufferPx = this.bodyHeight;\r\n      this.maxBufferPx = this.bodyHeight * 1.2;\r\n      this.virtualBody['_scrollStrategy']['_minBufferPx'] = this.minBufferPx;\r\n      this.virtualBody['_scrollStrategy']['_maxBufferPx'] = this.maxBufferPx;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  rowClick(row: XTableRow) {\r\n    this.activatedRow = row;\r\n    if (this.allowSelectRow && this.table.rowChecked) {\r\n      if (!Array.from((event as any).path).find((x: any) => x.localName == 'x-checkbox')) {\r\n        row[this.table.rowChecked.id] = !row[this.table.rowChecked.id];\r\n        this.table.bodyChecked(row[this.table.rowChecked.id], this.table.rowChecked);\r\n      }\r\n    }\r\n    this.activatedRowChange.emit(row);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onExpanded(_event: Event, node: XTableRow) {\r\n    node.expanded = !node.expanded;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  trackByItem(_index: number, item: XTableRow | XTableColumn) {\r\n    return item.id;\r\n  }\r\n}\r\n","<tbody #tbody>\r\n  <ng-container *ngIf=\"cellConfig; else virtualScrollTpl\">\r\n    <tr *ngFor=\"let row of data; index as i; trackBy: trackByItem\" [style.gridTemplateColumns]=\"cellConfig.gridTemplateColumns\">\r\n      <td\r\n        *ngFor=\"let column of cellConfig.cells; index as j\"\r\n        [title]=\"getTitle(row, column)\"\r\n        [class.x-table-sticky]=\"table.getStickyLeft(column) || table.getStickyRight(column)\"\r\n        [class.x-table-sticky-left]=\"table.getStickyLeft(column)\"\r\n        [class.x-table-sticky-right]=\"table.getStickyRight(column)\"\r\n        [class.x-table-sticky-left-last]=\"table.getStickyLeftLast(column)\"\r\n        [class.x-table-sticky-right-first]=\"table.getStickyRightFirst(column)\"\r\n        [style.left.px]=\"column.left\"\r\n        [style.right.px]=\"column.right\"\r\n        [style.grid-area]=\"column.gridArea\"\r\n      >\r\n        <ng-container *ngTemplateOutlet=\"cellTpl; context: { column: column, row: row, i: i }\"></ng-container>\r\n      </td>\r\n    </tr>\r\n  </ng-container>\r\n  <x-empty *ngIf=\"isEmpty && level === 0\"></x-empty>\r\n</tbody>\r\n\r\n<ng-template #virtualScrollTpl>\r\n  <cdk-virtual-scroll-viewport\r\n    #virtualBody\r\n    *ngIf=\"virtualScroll; else bodyTpl\"\r\n    [itemSize]=\"getItemSize\"\r\n    [minBufferPx]=\"minBufferPx\"\r\n    [maxBufferPx]=\"maxBufferPx\"\r\n    [style.height.px]=\"bodyHeight\"\r\n  >\r\n    <tr\r\n      *cdkVirtualFor=\"let row of data; let index = index; trackBy: trackByItem\"\r\n      [class.x-table-activated]=\"allowSelectRow && activatedRow?.id === row.id\"\r\n      [style.height.px]=\"getRowHeight\"\r\n      [style.min-height.px]=\"getRowHeight\"\r\n      (click)=\"rowClick(row)\"\r\n    >\r\n      <!-- rowHeight 为 0 的时候，index 下标获取不到 -->\r\n      <ng-container *ngTemplateOutlet=\"rowTpl; context: { row: row, i: getIndex(index, row) }\"></ng-container>\r\n    </tr>\r\n  </cdk-virtual-scroll-viewport>\r\n</ng-template>\r\n\r\n<ng-template #bodyTpl>\r\n  <ng-container *ngFor=\"let row of data; index as i; trackBy: trackByItem\">\r\n    <tr\r\n      [class.x-table-activated]=\"allowSelectRow && activatedRow?.id === row.id\"\r\n      [style.height.px]=\"getRowHeight\"\r\n      [style.min-height.px]=\"getRowHeight\"\r\n      (click)=\"rowClick(row)\"\r\n    >\r\n      <ng-container *ngTemplateOutlet=\"rowTpl; context: { row: row, i: i }\"></ng-container>\r\n    </tr>\r\n    <div class=\"x-table-children\" [class.x-table-expandTpl]=\"expandTpl\" *ngIf=\"table.treeTable && row.children && row.expanded\">\r\n      <x-table-body\r\n        [data]=\"row.children\"\r\n        [columns]=\"table.columns\"\r\n        [itemSize]=\"table.itemSize\"\r\n        [rowHeight]=\"table.rowHeight\"\r\n        [columnTpl]=\"table.bodyColumnTpl\"\r\n        [allowSelectRow]=\"table.allowSelectRow\"\r\n        [rowClass]=\"table.rowClass\"\r\n        [cellConfig]=\"table.cellConfig?.tbody\"\r\n        [(activatedRow)]=\"table.activatedRow\"\r\n        [expandedAll]=\"expandedAll\"\r\n        [expandTpl]=\"expandTpl\"\r\n        (activatedRowChange)=\"table.activatedRowChange.emit($event)\"\r\n        [level]=\"row.level! + 1\"\r\n        [table]=\"table\"\r\n      ></x-table-body>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #rowTpl let-row=\"row\" let-i=\"i\">\r\n  <ng-container *ngIf=\"level > 0 && expandTpl\">\r\n    <ng-container *xOutlet=\"expandTpl; context: { $row: row, $index: i, $level: level }\"></ng-container>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"level === 0 || !expandTpl\">\r\n    <ng-container *xOutlet=\"rowDefault; context: { row: row, i: i, level: level }\"></ng-container>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #rowDefault let-row=\"row\" let-i=\"i\">\r\n  <ng-container *ngFor=\"let column of columns; index as j; trackBy: trackByItem\">\r\n    <td\r\n      [style.width.px]=\"column.width\"\r\n      [style.flex]=\"getFlex(column)\"\r\n      [title]=\"getTitle(row, column)\"\r\n      [class.x-table-sticky]=\"table.getStickyLeft(column) || table.getStickyRight(column)\"\r\n      [class.x-table-sticky-left]=\"table.getStickyLeft(column)\"\r\n      [class.x-table-sticky-right]=\"table.getStickyRight(column)\"\r\n      [class.x-table-sticky-left-last]=\"table.getStickyLeftLast(column)\"\r\n      [class.x-table-sticky-right-first]=\"table.getStickyRightFirst(column)\"\r\n      [style.left.px]=\"column.left\"\r\n      [style.right.px]=\"column.right\"\r\n      [ngClass]=\"!rowClass ? {} : rowClass(row, i)\"\r\n    >\r\n      <ng-template *ngTemplateOutlet=\"cellTpl; context: { column: column, row: row, i: i }\"></ng-template>\r\n    </td>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #cellTpl let-column=\"column\" let-row=\"row\" let-i=\"i\">\r\n  <ng-container [ngSwitch]=\"column.type\">\r\n    <ng-container *ngSwitchCase=\"'checkbox'\">\r\n      <x-checkbox\r\n        [data]=\"[{ id: true, label: '' }]\"\r\n        [(ngModel)]=\"row[column.id]\"\r\n        (ngModelChange)=\"table.bodyChecked($event, column)\"\r\n      ></x-checkbox>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'index'\">\r\n      <div>{{ table.getIndex(i) }}</div>\r\n    </ng-container>\r\n    <ng-container *ngSwitchDefault>\r\n      <ng-container *ngIf=\"table.isExpandColumn(column)\">\r\n        <x-button\r\n          [class.is-leaf]=\"!row.leaf\"\r\n          [class.is-expanded]=\"row.expanded\"\r\n          (click)=\"onExpanded($event, row)\"\r\n          icon=\"fto-chevron-right\"\r\n          size=\"mini\"\r\n          onlyIcon\r\n          class=\"x-table-expand\"\r\n          [style.margin-left.rem]=\"row.level - 0.5\"\r\n        ></x-button>\r\n      </ng-container>\r\n      <ng-container *xOutlet=\"columnTpl[column.id]; context: { $column: column, $row: row, $index: table.getIndex(i) }\">\r\n        <div [innerHTML]=\"row[column.id]\" [style.text-align]=\"column.textAlign\"></div>\r\n        {{ table.rowExpandNext && table.rowExpandNext.id === column.id ? 'x-table-body-level-' + row.level : '' }}\r\n      </ng-container>\r\n    </ng-container>\r\n  </ng-container>\r\n</ng-template>\r\n"]}