@delon/abc 16.2.0 → 16.3.0

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 (187) hide show
  1. package/avatar-list/avatar-list.component.d.ts +3 -4
  2. package/cell/cell-host.directive.d.ts +13 -0
  3. package/cell/cell.component.d.ts +45 -0
  4. package/cell/cell.module.d.ts +17 -0
  5. package/cell/cell.service.d.ts +23 -0
  6. package/cell/cell.types.d.ts +238 -0
  7. package/cell/index.d.ts +5 -0
  8. package/cell/style/index.less +63 -0
  9. package/error-collect/error-collect.component.d.ts +2 -3
  10. package/esm2022/auto-focus/auto-focus.directive.mjs +3 -3
  11. package/esm2022/auto-focus/auto-focus.module.mjs +4 -4
  12. package/esm2022/avatar-list/avatar-list-item.component.mjs +5 -5
  13. package/esm2022/avatar-list/avatar-list.component.mjs +9 -12
  14. package/esm2022/avatar-list/avatar-list.module.mjs +4 -4
  15. package/esm2022/cell/cell-host.directive.mjs +34 -0
  16. package/esm2022/cell/cell.component.mjs +270 -0
  17. package/esm2022/cell/cell.mjs +5 -0
  18. package/esm2022/cell/cell.module.mjs +54 -0
  19. package/esm2022/cell/cell.service.mjs +168 -0
  20. package/esm2022/cell/cell.types.mjs +2 -0
  21. package/esm2022/cell/index.mjs +6 -0
  22. package/esm2022/count-down/count-down.component.mjs +5 -5
  23. package/esm2022/count-down/count-down.module.mjs +4 -4
  24. package/esm2022/date-picker/date-picker.module.mjs +4 -4
  25. package/esm2022/date-picker/range-shortcut.component.mjs +3 -3
  26. package/esm2022/date-picker/range.directive.mjs +3 -3
  27. package/esm2022/down-file/down-file.directive.mjs +3 -3
  28. package/esm2022/down-file/down-file.module.mjs +4 -4
  29. package/esm2022/ellipsis/ellipsis.component.mjs +5 -5
  30. package/esm2022/ellipsis/ellipsis.module.mjs +4 -4
  31. package/esm2022/error-collect/error-collect.component.mjs +11 -13
  32. package/esm2022/error-collect/error-collect.module.mjs +4 -4
  33. package/esm2022/exception/exception.component.mjs +14 -14
  34. package/esm2022/exception/exception.module.mjs +4 -4
  35. package/esm2022/footer-toolbar/footer-toolbar.component.mjs +5 -5
  36. package/esm2022/footer-toolbar/footer-toolbar.module.mjs +4 -4
  37. package/esm2022/full-content/full-content-toggle.directive.mjs +3 -3
  38. package/esm2022/full-content/full-content.component.mjs +12 -14
  39. package/esm2022/full-content/full-content.module.mjs +4 -4
  40. package/esm2022/full-content/full-content.service.mjs +3 -3
  41. package/esm2022/global-footer/global-footer-item.component.mjs +5 -5
  42. package/esm2022/global-footer/global-footer.component.mjs +12 -14
  43. package/esm2022/global-footer/global-footer.module.mjs +4 -4
  44. package/esm2022/hotkey/hotkey.directive.mjs +3 -3
  45. package/esm2022/hotkey/hotkey.module.mjs +4 -4
  46. package/esm2022/let/let.directive.mjs +3 -3
  47. package/esm2022/let/let.module.mjs +4 -4
  48. package/esm2022/loading/loading.component.mjs +5 -5
  49. package/esm2022/loading/loading.module.mjs +4 -4
  50. package/esm2022/loading/loading.service.mjs +3 -3
  51. package/esm2022/lodop/lodop.module.mjs +4 -4
  52. package/esm2022/lodop/lodop.service.mjs +3 -3
  53. package/esm2022/media/media.component.mjs +11 -13
  54. package/esm2022/media/media.module.mjs +4 -4
  55. package/esm2022/media/media.service.mjs +3 -3
  56. package/esm2022/notice-icon/notice-icon-tab.component.mjs +5 -5
  57. package/esm2022/notice-icon/notice-icon.component.mjs +5 -5
  58. package/esm2022/notice-icon/notice-icon.module.mjs +4 -4
  59. package/esm2022/observers/observer-size.mjs +10 -10
  60. package/esm2022/onboarding/onboarding.component.mjs +3 -3
  61. package/esm2022/onboarding/onboarding.module.mjs +4 -4
  62. package/esm2022/onboarding/onboarding.service.mjs +3 -3
  63. package/esm2022/page-header/page-header.component.mjs +16 -16
  64. package/esm2022/page-header/page-header.module.mjs +27 -6
  65. package/esm2022/pdf/pdf.component.mjs +14 -16
  66. package/esm2022/pdf/pdf.module.mjs +4 -4
  67. package/esm2022/pdf/pdf.types.mjs +2 -1
  68. package/esm2022/qr/qr.component.mjs +3 -3
  69. package/esm2022/qr/qr.module.mjs +4 -4
  70. package/esm2022/quick-menu/quick-menu.component.mjs +5 -5
  71. package/esm2022/quick-menu/quick-menu.module.mjs +4 -4
  72. package/esm2022/result/result.component.mjs +12 -14
  73. package/esm2022/result/result.module.mjs +4 -4
  74. package/esm2022/reuse-tab/public_api.mjs +2 -1
  75. package/esm2022/reuse-tab/reuse-tab-context-menu.component.mjs +3 -3
  76. package/esm2022/reuse-tab/reuse-tab-context.component.mjs +3 -3
  77. package/esm2022/reuse-tab/reuse-tab-context.directive.mjs +3 -3
  78. package/esm2022/reuse-tab/reuse-tab-context.service.mjs +3 -3
  79. package/esm2022/reuse-tab/reuse-tab.component.mjs +12 -16
  80. package/esm2022/reuse-tab/reuse-tab.module.mjs +4 -4
  81. package/esm2022/reuse-tab/reuse-tab.service.mjs +3 -3
  82. package/esm2022/se/se-container.component.mjs +10 -10
  83. package/esm2022/se/se.component.mjs +13 -15
  84. package/esm2022/se/se.module.mjs +4 -4
  85. package/esm2022/sg/sg-container.component.mjs +5 -5
  86. package/esm2022/sg/sg.component.mjs +5 -5
  87. package/esm2022/sg/sg.module.mjs +4 -4
  88. package/esm2022/st/st-column-source.mjs +8 -4
  89. package/esm2022/st/st-data-source.mjs +14 -7
  90. package/esm2022/st/st-export.mjs +3 -3
  91. package/esm2022/st/st-filter.component.mjs +12 -12
  92. package/esm2022/st/st-row.directive.mjs +6 -6
  93. package/esm2022/st/st-widget-host.directive.mjs +3 -3
  94. package/esm2022/st/st-widget.mjs +3 -3
  95. package/esm2022/st/st.component.mjs +83 -97
  96. package/esm2022/st/st.interfaces.mjs +1 -1
  97. package/esm2022/st/st.module.mjs +9 -5
  98. package/esm2022/st/st.types.mjs +1 -1
  99. package/esm2022/sv/sv-container.component.mjs +22 -12
  100. package/esm2022/sv/sv-value.component.mjs +6 -6
  101. package/esm2022/sv/sv.component.mjs +12 -9
  102. package/esm2022/sv/sv.module.mjs +4 -4
  103. package/esm2022/tag-select/tag-select.component.mjs +10 -14
  104. package/esm2022/tag-select/tag-select.module.mjs +4 -4
  105. package/esm2022/xlsx/xlsx.directive.mjs +3 -3
  106. package/esm2022/xlsx/xlsx.module.mjs +4 -4
  107. package/esm2022/xlsx/xlsx.service.mjs +3 -3
  108. package/esm2022/zip/zip.module.mjs +4 -4
  109. package/esm2022/zip/zip.service.mjs +3 -3
  110. package/exception/exception.component.d.ts +2 -3
  111. package/fesm2022/auto-focus.mjs +7 -7
  112. package/fesm2022/avatar-list.mjs +16 -19
  113. package/fesm2022/avatar-list.mjs.map +1 -1
  114. package/fesm2022/cell.mjs +521 -0
  115. package/fesm2022/cell.mjs.map +1 -0
  116. package/fesm2022/chart-observer-size.mjs +10 -10
  117. package/fesm2022/count-down.mjs +8 -8
  118. package/fesm2022/count-down.mjs.map +1 -1
  119. package/fesm2022/date-picker.mjs +10 -10
  120. package/fesm2022/down-file.mjs +7 -7
  121. package/fesm2022/ellipsis.mjs +8 -8
  122. package/fesm2022/ellipsis.mjs.map +1 -1
  123. package/fesm2022/error-collect.mjs +14 -16
  124. package/fesm2022/error-collect.mjs.map +1 -1
  125. package/fesm2022/exception.mjs +17 -17
  126. package/fesm2022/exception.mjs.map +1 -1
  127. package/fesm2022/footer-toolbar.mjs +8 -8
  128. package/fesm2022/footer-toolbar.mjs.map +1 -1
  129. package/fesm2022/full-content.mjs +21 -23
  130. package/fesm2022/full-content.mjs.map +1 -1
  131. package/fesm2022/global-footer.mjs +19 -21
  132. package/fesm2022/global-footer.mjs.map +1 -1
  133. package/fesm2022/hotkey.mjs +7 -7
  134. package/fesm2022/let.mjs +7 -7
  135. package/fesm2022/loading.mjs +11 -11
  136. package/fesm2022/loading.mjs.map +1 -1
  137. package/fesm2022/lodop.mjs +7 -7
  138. package/fesm2022/media.mjs +17 -19
  139. package/fesm2022/media.mjs.map +1 -1
  140. package/fesm2022/notice-icon.mjs +12 -12
  141. package/fesm2022/notice-icon.mjs.map +1 -1
  142. package/fesm2022/onboarding.mjs +10 -10
  143. package/fesm2022/page-header.mjs +41 -20
  144. package/fesm2022/page-header.mjs.map +1 -1
  145. package/fesm2022/pdf.mjs +18 -19
  146. package/fesm2022/pdf.mjs.map +1 -1
  147. package/fesm2022/qr.mjs +7 -7
  148. package/fesm2022/quick-menu.mjs +8 -8
  149. package/fesm2022/quick-menu.mjs.map +1 -1
  150. package/fesm2022/result.mjs +15 -17
  151. package/fesm2022/result.mjs.map +1 -1
  152. package/fesm2022/reuse-tab.mjs +31 -35
  153. package/fesm2022/reuse-tab.mjs.map +1 -1
  154. package/fesm2022/se.mjs +25 -27
  155. package/fesm2022/se.mjs.map +1 -1
  156. package/fesm2022/sg.mjs +12 -12
  157. package/fesm2022/sg.mjs.map +1 -1
  158. package/fesm2022/st.mjs +134 -133
  159. package/fesm2022/st.mjs.map +1 -1
  160. package/fesm2022/sv.mjs +41 -28
  161. package/fesm2022/sv.mjs.map +1 -1
  162. package/fesm2022/tag-select.mjs +13 -17
  163. package/fesm2022/tag-select.mjs.map +1 -1
  164. package/fesm2022/xlsx.mjs +10 -10
  165. package/fesm2022/zip.mjs +7 -7
  166. package/global-footer/global-footer.component.d.ts +6 -6
  167. package/index.less +1 -0
  168. package/package.json +10 -5
  169. package/page-header/page-header.component.d.ts +5 -5
  170. package/page-header/page-header.module.d.ts +2 -1
  171. package/page-header/style/index.less +1 -0
  172. package/pdf/pdf.component.d.ts +6 -5
  173. package/pdf/pdf.types.d.ts +2 -1
  174. package/result/result.component.d.ts +6 -6
  175. package/reuse-tab/public_api.d.ts +1 -0
  176. package/reuse-tab/reuse-tab.component.d.ts +2 -3
  177. package/se/se.component.d.ts +2 -3
  178. package/st/st-data-source.d.ts +1 -1
  179. package/st/st.component.d.ts +7 -7
  180. package/st/st.interfaces.d.ts +22 -2
  181. package/st/st.module.d.ts +17 -16
  182. package/st/st.types.d.ts +3 -0
  183. package/sv/style/index.less +36 -0
  184. package/sv/sv-container.component.d.ts +7 -2
  185. package/sv/sv.component.d.ts +3 -3
  186. package/tag-select/tag-select.component.d.ts +2 -3
  187. package/theme-default.less +11 -0
@@ -7,11 +7,11 @@ import { AvatarListComponent } from './avatar-list.component';
7
7
  import * as i0 from "@angular/core";
8
8
  const COMPONENTS = [AvatarListComponent, AvatarListItemComponent];
9
9
  export class AvatarListModule {
10
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AvatarListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: AvatarListModule, declarations: [AvatarListComponent, AvatarListItemComponent], imports: [CommonModule, NzAvatarModule, NzToolTipModule], exports: [AvatarListComponent, AvatarListItemComponent] }); }
12
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AvatarListModule, imports: [CommonModule, NzAvatarModule, NzToolTipModule] }); }
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AvatarListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: AvatarListModule, declarations: [AvatarListComponent, AvatarListItemComponent], imports: [CommonModule, NzAvatarModule, NzToolTipModule], exports: [AvatarListComponent, AvatarListItemComponent] }); }
12
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AvatarListModule, imports: [CommonModule, NzAvatarModule, NzToolTipModule] }); }
13
13
  }
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AvatarListModule, decorators: [{
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: AvatarListModule, decorators: [{
15
15
  type: NgModule,
16
16
  args: [{
17
17
  imports: [CommonModule, NzAvatarModule, NzToolTipModule],
@@ -0,0 +1,34 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import { warn } from '@delon/util/other';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./cell.service";
5
+ export class CellHostDirective {
6
+ constructor(srv, viewContainerRef) {
7
+ this.srv = srv;
8
+ this.viewContainerRef = viewContainerRef;
9
+ }
10
+ ngOnInit() {
11
+ const widget = this.data.options.widget;
12
+ const componentType = this.srv.getWidget(widget.key)?.ref;
13
+ if (componentType == null) {
14
+ if (typeof ngDevMode === 'undefined' || ngDevMode) {
15
+ warn(`cell: No widget for type "${widget.key}"`);
16
+ }
17
+ return;
18
+ }
19
+ this.viewContainerRef.clear();
20
+ const componentRef = this.viewContainerRef.createComponent(componentType);
21
+ componentRef.instance.data = this.data;
22
+ }
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellHostDirective, deps: [{ token: i1.CellService }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
24
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: CellHostDirective, selector: "[cell-widget-host]", inputs: { data: "data" }, ngImport: i0 }); }
25
+ }
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellHostDirective, decorators: [{
27
+ type: Directive,
28
+ args: [{
29
+ selector: '[cell-widget-host]'
30
+ }]
31
+ }], ctorParameters: function () { return [{ type: i1.CellService }, { type: i0.ViewContainerRef }]; }, propDecorators: { data: [{
32
+ type: Input
33
+ }] } });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1ob3N0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FiYy9jZWxsL2NlbGwtaG9zdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWtDLE1BQU0sZUFBZSxDQUFDO0FBRWpGLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBUXpDLE1BQU0sT0FBTyxpQkFBaUI7SUFHNUIsWUFDVSxHQUFnQixFQUNoQixnQkFBa0M7UUFEbEMsUUFBRyxHQUFILEdBQUcsQ0FBYTtRQUNoQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQ3pDLENBQUM7SUFFSixRQUFRO1FBQ04sTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFRLENBQUMsTUFBTyxDQUFDO1FBQzFDLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFJLENBQUMsRUFBRSxHQUFvQixDQUFDO1FBQzVFLElBQUksYUFBYSxJQUFJLElBQUksRUFBRTtZQUN6QixJQUFJLE9BQU8sU0FBUyxLQUFLLFdBQVcsSUFBSSxTQUFTLEVBQUU7Z0JBQ2pELElBQUksQ0FBQyw2QkFBNkIsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUM7YUFDbEQ7WUFDRCxPQUFPO1NBQ1I7UUFFRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDOUIsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN6RSxZQUFZLENBQUMsUUFBcUMsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztJQUN2RSxDQUFDOzhHQXJCVSxpQkFBaUI7a0dBQWpCLGlCQUFpQjs7MkZBQWpCLGlCQUFpQjtrQkFIN0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO2lCQUMvQjtpSUFFVSxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkluaXQsIFR5cGUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgd2FybiB9IGZyb20gJ0BkZWxvbi91dGlsL290aGVyJztcblxuaW1wb3J0IHsgQ2VsbFNlcnZpY2UgfSBmcm9tICcuL2NlbGwuc2VydmljZSc7XG5pbXBvcnQgeyBDZWxsV2lkZ2V0RGF0YSB9IGZyb20gJy4vY2VsbC50eXBlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tjZWxsLXdpZGdldC1ob3N0XSdcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbEhvc3REaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBkYXRhITogQ2VsbFdpZGdldERhdGE7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBzcnY6IENlbGxTZXJ2aWNlLFxuICAgIHByaXZhdGUgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZlxuICApIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgY29uc3Qgd2lkZ2V0ID0gdGhpcy5kYXRhLm9wdGlvbnMhLndpZGdldCE7XG4gICAgY29uc3QgY29tcG9uZW50VHlwZSA9IHRoaXMuc3J2LmdldFdpZGdldCh3aWRnZXQua2V5ISk/LnJlZiBhcyBUeXBlPHVua25vd24+O1xuICAgIGlmIChjb21wb25lbnRUeXBlID09IG51bGwpIHtcbiAgICAgIGlmICh0eXBlb2YgbmdEZXZNb2RlID09PSAndW5kZWZpbmVkJyB8fCBuZ0Rldk1vZGUpIHtcbiAgICAgICAgd2FybihgY2VsbDogTm8gd2lkZ2V0IGZvciB0eXBlIFwiJHt3aWRnZXQua2V5fVwiYCk7XG4gICAgICB9XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG4gICAgY29uc3QgY29tcG9uZW50UmVmID0gdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudChjb21wb25lbnRUeXBlKTtcbiAgICAoY29tcG9uZW50UmVmLmluc3RhbmNlIGFzIHsgZGF0YTogQ2VsbFdpZGdldERhdGEgfSkuZGF0YSA9IHRoaXMuZGF0YTtcbiAgfVxufVxuIl19
@@ -0,0 +1,270 @@
1
+ import { __decorate } from "tslib";
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output, ViewEncapsulation } from '@angular/core';
3
+ import { updateHostClass } from '@delon/util/browser';
4
+ import { InputBoolean } from '@delon/util/decorator';
5
+ import { WINDOW } from '@delon/util/token';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./cell.service";
8
+ import * as i2 from "@angular/router";
9
+ import * as i3 from "ng-zorro-antd/image";
10
+ import * as i4 from "@angular/common";
11
+ import * as i5 from "@angular/forms";
12
+ import * as i6 from "ng-zorro-antd/checkbox";
13
+ import * as i7 from "ng-zorro-antd/radio";
14
+ import * as i8 from "ng-zorro-antd/badge";
15
+ import * as i9 from "ng-zorro-antd/tag";
16
+ import * as i10 from "ng-zorro-antd/tooltip";
17
+ import * as i11 from "ng-zorro-antd/icon";
18
+ import * as i12 from "./cell-host.directive";
19
+ export class CellComponent {
20
+ get safeOpt() {
21
+ return this.res?.options ?? {};
22
+ }
23
+ get isText() {
24
+ return this.res?.safeHtml === 'text';
25
+ }
26
+ get hostData() {
27
+ return {
28
+ value: this.value,
29
+ options: this.srv.fixOptions(this.options)
30
+ };
31
+ }
32
+ constructor(srv, router, cdr, el, renderer, imgSrv,
33
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
34
+ win) {
35
+ this.srv = srv;
36
+ this.router = router;
37
+ this.cdr = cdr;
38
+ this.el = el;
39
+ this.renderer = renderer;
40
+ this.imgSrv = imgSrv;
41
+ this.win = win;
42
+ this.showDefault = false;
43
+ this.valueChange = new EventEmitter();
44
+ this.loading = false;
45
+ this.disabled = false;
46
+ }
47
+ updateValue() {
48
+ this.destroy$?.unsubscribe();
49
+ this.destroy$ = this.srv.get(this.value, this.options).subscribe(res => {
50
+ this.res = res;
51
+ this.showDefault = this.value == this.safeOpt.default.condition;
52
+ this._text = res.result?.text ?? '';
53
+ this._unit = res.result?.unit ?? this.safeOpt?.unit;
54
+ this.cdr.detectChanges();
55
+ this.setClass();
56
+ });
57
+ }
58
+ setClass() {
59
+ const { el, renderer } = this;
60
+ const { renderType, size } = this.safeOpt;
61
+ updateHostClass(el.nativeElement, renderer, {
62
+ [`cell`]: true,
63
+ [`cell__${renderType}`]: renderType != null,
64
+ [`cell__${size}`]: size != null,
65
+ [`cell__has-unit`]: this._unit,
66
+ [`cell__has-default`]: this.showDefault,
67
+ [`cell__disabled`]: this.disabled
68
+ });
69
+ el.nativeElement.dataset.type = this.safeOpt.type;
70
+ }
71
+ ngOnChanges(changes) {
72
+ // Do not call updateValue when only updating loading, disabled
73
+ if (Object.keys(changes).every(k => ['loading', 'disabled'].includes(k))) {
74
+ this.setClass();
75
+ }
76
+ else {
77
+ this.updateValue();
78
+ }
79
+ }
80
+ change(value) {
81
+ this.value = value;
82
+ this.valueChange.emit(value);
83
+ }
84
+ _link(e) {
85
+ e.preventDefault();
86
+ e.stopPropagation();
87
+ if (this.disabled)
88
+ return;
89
+ const link = this.safeOpt.link;
90
+ const url = link?.url;
91
+ if (url == null)
92
+ return;
93
+ if (/https?:\/\//g.test(url)) {
94
+ this.win.open(url, link?.target);
95
+ }
96
+ else {
97
+ this.router.navigateByUrl(url);
98
+ }
99
+ }
100
+ _showImg(img) {
101
+ const config = this.safeOpt.img;
102
+ if (config == null || config.big == null)
103
+ return;
104
+ let idx = -1;
105
+ const list = this._text.map((p, index) => {
106
+ if (idx === -1 && p === img)
107
+ idx = index;
108
+ return typeof config.big === 'function' ? config.big(p) : p;
109
+ });
110
+ this.imgSrv
111
+ .preview(list.map(p => ({ src: p })), config.previewOptions)
112
+ .switchTo(idx);
113
+ }
114
+ ngOnDestroy() {
115
+ this.destroy$?.unsubscribe();
116
+ }
117
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellComponent, deps: [{ token: i1.CellService }, { token: i2.Router }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i3.NzImageService }, { token: WINDOW }], target: i0.ɵɵFactoryTarget.Component }); }
118
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: CellComponent, selector: "cell, [cell]", inputs: { value: "value", options: "options", loading: "loading", disabled: "disabled" }, outputs: { valueChange: "valueChange" }, exportAs: ["cell"], usesOnChanges: true, ngImport: i0, template: `
119
+ <ng-template #text>
120
+ <ng-container [ngSwitch]="safeOpt.type">
121
+ <label
122
+ *ngSwitchCase="'checkbox'"
123
+ nz-checkbox
124
+ [nzDisabled]="disabled"
125
+ [ngModel]="value"
126
+ (ngModelChange)="change($event)"
127
+ >
128
+ {{ safeOpt.checkbox?.label }}
129
+ </label>
130
+ <label
131
+ *ngSwitchCase="'radio'"
132
+ nz-radio
133
+ [nzDisabled]="disabled"
134
+ [ngModel]="value"
135
+ (ngModelChange)="change($event)"
136
+ >
137
+ {{ safeOpt.radio?.label }}
138
+ </label>
139
+ <a
140
+ *ngSwitchCase="'link'"
141
+ (click)="_link($event)"
142
+ [attr.target]="safeOpt.link?.target"
143
+ [attr.title]="value"
144
+ [innerHTML]="_text"
145
+ ></a>
146
+ <nz-tag *ngSwitchCase="'tag'" [nzColor]="res?.result?.color">
147
+ <span [innerHTML]="_text"></span>
148
+ </nz-tag>
149
+ <nz-badge *ngSwitchCase="'badge'" [nzStatus]="res?.result?.color" nzText="{{ _text }}" />
150
+ <ng-template *ngSwitchCase="'widget'" cell-widget-host [data]="hostData" />
151
+ <ng-container *ngSwitchCase="'img'">
152
+ <img
153
+ *ngFor="let i of $any(_text)"
154
+ [attr.src]="i"
155
+ [attr.height]="safeOpt.img?.size"
156
+ [attr.width]="safeOpt.img?.size"
157
+ (click)="_showImg(i)"
158
+ class="img"
159
+ [class.point]="safeOpt.img?.big"
160
+ />
161
+ </ng-container>
162
+ <ng-container *ngSwitchDefault>
163
+ <span *ngIf="!isText" [innerHTML]="_text" [attr.title]="value"></span>
164
+ <span *ngIf="isText" [innerText]="_text" [attr.title]="value"></span>
165
+ <span *ngIf="_unit" class="unit">{{ _unit }}</span>
166
+ </ng-container>
167
+ </ng-container>
168
+ </ng-template>
169
+ <ng-template #textWrap>
170
+ <ng-container *ngIf="showDefault">{{ safeOpt.default?.text }}</ng-container>
171
+ <ng-container *ngIf="!showDefault">
172
+ <span *ngIf="safeOpt.tooltip; else text" [nz-tooltip]="safeOpt.tooltip">
173
+ <ng-template [ngTemplateOutlet]="text" />
174
+ </span>
175
+ </ng-container>
176
+ </ng-template>
177
+ <span *ngIf="loading; else textWrap" nz-icon nzType="loading"></span>
178
+ `, isInline: true, dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.NzCheckboxComponent, selector: "[nz-checkbox]", inputs: ["nzValue", "nzAutoFocus", "nzDisabled", "nzIndeterminate", "nzChecked", "nzId"], outputs: ["nzCheckedChange"], exportAs: ["nzCheckbox"] }, { kind: "component", type: i7.NzRadioComponent, selector: "[nz-radio],[nz-radio-button]", inputs: ["nzValue", "nzDisabled", "nzAutoFocus"], exportAs: ["nzRadio"] }, { kind: "component", type: i8.NzBadgeComponent, selector: "nz-badge", inputs: ["nzShowZero", "nzShowDot", "nzStandalone", "nzDot", "nzOverflowCount", "nzColor", "nzStyle", "nzText", "nzTitle", "nzStatus", "nzCount", "nzOffset", "nzSize"], exportAs: ["nzBadge"] }, { kind: "component", type: i9.NzTagComponent, selector: "nz-tag", inputs: ["nzMode", "nzColor", "nzChecked"], outputs: ["nzOnClose", "nzCheckedChange"], exportAs: ["nzTag"] }, { kind: "directive", type: i10.NzTooltipDirective, selector: "[nz-tooltip]", inputs: ["nzTooltipTitle", "nzTooltipTitleContext", "nz-tooltip", "nzTooltipTrigger", "nzTooltipPlacement", "nzTooltipOrigin", "nzTooltipVisible", "nzTooltipMouseEnterDelay", "nzTooltipMouseLeaveDelay", "nzTooltipOverlayClassName", "nzTooltipOverlayStyle", "nzTooltipArrowPointAtCenter", "nzTooltipColor"], outputs: ["nzTooltipVisibleChange"], exportAs: ["nzTooltip"] }, { kind: "directive", type: i11.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "directive", type: i12.CellHostDirective, selector: "[cell-widget-host]", inputs: ["data"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
179
+ }
180
+ __decorate([
181
+ InputBoolean()
182
+ ], CellComponent.prototype, "loading", void 0);
183
+ __decorate([
184
+ InputBoolean()
185
+ ], CellComponent.prototype, "disabled", void 0);
186
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellComponent, decorators: [{
187
+ type: Component,
188
+ args: [{
189
+ selector: 'cell, [cell]',
190
+ template: `
191
+ <ng-template #text>
192
+ <ng-container [ngSwitch]="safeOpt.type">
193
+ <label
194
+ *ngSwitchCase="'checkbox'"
195
+ nz-checkbox
196
+ [nzDisabled]="disabled"
197
+ [ngModel]="value"
198
+ (ngModelChange)="change($event)"
199
+ >
200
+ {{ safeOpt.checkbox?.label }}
201
+ </label>
202
+ <label
203
+ *ngSwitchCase="'radio'"
204
+ nz-radio
205
+ [nzDisabled]="disabled"
206
+ [ngModel]="value"
207
+ (ngModelChange)="change($event)"
208
+ >
209
+ {{ safeOpt.radio?.label }}
210
+ </label>
211
+ <a
212
+ *ngSwitchCase="'link'"
213
+ (click)="_link($event)"
214
+ [attr.target]="safeOpt.link?.target"
215
+ [attr.title]="value"
216
+ [innerHTML]="_text"
217
+ ></a>
218
+ <nz-tag *ngSwitchCase="'tag'" [nzColor]="res?.result?.color">
219
+ <span [innerHTML]="_text"></span>
220
+ </nz-tag>
221
+ <nz-badge *ngSwitchCase="'badge'" [nzStatus]="res?.result?.color" nzText="{{ _text }}" />
222
+ <ng-template *ngSwitchCase="'widget'" cell-widget-host [data]="hostData" />
223
+ <ng-container *ngSwitchCase="'img'">
224
+ <img
225
+ *ngFor="let i of $any(_text)"
226
+ [attr.src]="i"
227
+ [attr.height]="safeOpt.img?.size"
228
+ [attr.width]="safeOpt.img?.size"
229
+ (click)="_showImg(i)"
230
+ class="img"
231
+ [class.point]="safeOpt.img?.big"
232
+ />
233
+ </ng-container>
234
+ <ng-container *ngSwitchDefault>
235
+ <span *ngIf="!isText" [innerHTML]="_text" [attr.title]="value"></span>
236
+ <span *ngIf="isText" [innerText]="_text" [attr.title]="value"></span>
237
+ <span *ngIf="_unit" class="unit">{{ _unit }}</span>
238
+ </ng-container>
239
+ </ng-container>
240
+ </ng-template>
241
+ <ng-template #textWrap>
242
+ <ng-container *ngIf="showDefault">{{ safeOpt.default?.text }}</ng-container>
243
+ <ng-container *ngIf="!showDefault">
244
+ <span *ngIf="safeOpt.tooltip; else text" [nz-tooltip]="safeOpt.tooltip">
245
+ <ng-template [ngTemplateOutlet]="text" />
246
+ </span>
247
+ </ng-container>
248
+ </ng-template>
249
+ <span *ngIf="loading; else textWrap" nz-icon nzType="loading"></span>
250
+ `,
251
+ exportAs: 'cell',
252
+ preserveWhitespaces: false,
253
+ changeDetection: ChangeDetectionStrategy.OnPush,
254
+ encapsulation: ViewEncapsulation.None
255
+ }]
256
+ }], ctorParameters: function () { return [{ type: i1.CellService }, { type: i2.Router }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i3.NzImageService }, { type: undefined, decorators: [{
257
+ type: Inject,
258
+ args: [WINDOW]
259
+ }] }]; }, propDecorators: { value: [{
260
+ type: Input
261
+ }], valueChange: [{
262
+ type: Output
263
+ }], options: [{
264
+ type: Input
265
+ }], loading: [{
266
+ type: Input
267
+ }], disabled: [{
268
+ type: Input
269
+ }] } });
270
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.component.js","sourceRoot":"","sources":["../../../../../packages/abc/cell/cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChange,\n  ViewEncapsulation\n} from '@angular/core';\nimport type { SafeValue } from '@angular/platform-browser';\nimport { Router } from '@angular/router';\nimport { Subscription } from 'rxjs';\n\nimport { updateHostClass } from '@delon/util/browser';\nimport { BooleanInput, InputBoolean } from '@delon/util/decorator';\nimport { WINDOW } from '@delon/util/token';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzImage, NzImageService } from 'ng-zorro-antd/image';\n\nimport { CellService } from './cell.service';\nimport type { CellDefaultText, CellOptions, CellTextResult, CellValue, CellWidgetData } from './cell.types';\n\n@Component({\n  selector: 'cell, [cell]',\n  template: `\n    <ng-template #text>\n      <ng-container [ngSwitch]=\"safeOpt.type\">\n        <label\n          *ngSwitchCase=\"'checkbox'\"\n          nz-checkbox\n          [nzDisabled]=\"disabled\"\n          [ngModel]=\"value\"\n          (ngModelChange)=\"change($event)\"\n        >\n          {{ safeOpt.checkbox?.label }}\n        </label>\n        <label\n          *ngSwitchCase=\"'radio'\"\n          nz-radio\n          [nzDisabled]=\"disabled\"\n          [ngModel]=\"value\"\n          (ngModelChange)=\"change($event)\"\n        >\n          {{ safeOpt.radio?.label }}\n        </label>\n        <a\n          *ngSwitchCase=\"'link'\"\n          (click)=\"_link($event)\"\n          [attr.target]=\"safeOpt.link?.target\"\n          [attr.title]=\"value\"\n          [innerHTML]=\"_text\"\n        ></a>\n        <nz-tag *ngSwitchCase=\"'tag'\" [nzColor]=\"res?.result?.color\">\n          <span [innerHTML]=\"_text\"></span>\n        </nz-tag>\n        <nz-badge *ngSwitchCase=\"'badge'\" [nzStatus]=\"res?.result?.color\" nzText=\"{{ _text }}\" />\n        <ng-template *ngSwitchCase=\"'widget'\" cell-widget-host [data]=\"hostData\" />\n        <ng-container *ngSwitchCase=\"'img'\">\n          <img\n            *ngFor=\"let i of $any(_text)\"\n            [attr.src]=\"i\"\n            [attr.height]=\"safeOpt.img?.size\"\n            [attr.width]=\"safeOpt.img?.size\"\n            (click)=\"_showImg(i)\"\n            class=\"img\"\n            [class.point]=\"safeOpt.img?.big\"\n          />\n        </ng-container>\n        <ng-container *ngSwitchDefault>\n          <span *ngIf=\"!isText\" [innerHTML]=\"_text\" [attr.title]=\"value\"></span>\n          <span *ngIf=\"isText\" [innerText]=\"_text\" [attr.title]=\"value\"></span>\n          <span *ngIf=\"_unit\" class=\"unit\">{{ _unit }}</span>\n        </ng-container>\n      </ng-container>\n    </ng-template>\n    <ng-template #textWrap>\n      <ng-container *ngIf=\"showDefault\">{{ safeOpt.default?.text }}</ng-container>\n      <ng-container *ngIf=\"!showDefault\">\n        <span *ngIf=\"safeOpt.tooltip; else text\" [nz-tooltip]=\"safeOpt.tooltip\">\n          <ng-template [ngTemplateOutlet]=\"text\" />\n        </span>\n      </ng-container>\n    </ng-template>\n    <span *ngIf=\"loading; else textWrap\" nz-icon nzType=\"loading\"></span>\n  `,\n  exportAs: 'cell',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class CellComponent implements OnChanges, OnDestroy {\n  static ngAcceptInputType_loading: BooleanInput;\n  static ngAcceptInputType_disabled: BooleanInput;\n\n  private destroy$?: Subscription;\n\n  _text!: string | SafeValue | string[] | number;\n  _unit?: string;\n  res?: CellTextResult;\n  showDefault = false;\n\n  @Input() value?: CellValue;\n  @Output() readonly valueChange = new EventEmitter<NzSafeAny>();\n  @Input() options?: CellOptions;\n  @Input() @InputBoolean() loading = false;\n  @Input() @InputBoolean() disabled = false;\n\n  get safeOpt(): CellOptions {\n    return this.res?.options ?? {};\n  }\n\n  get isText(): boolean {\n    return this.res?.safeHtml === 'text';\n  }\n\n  get hostData(): CellWidgetData {\n    return {\n      value: this.value,\n      options: this.srv.fixOptions(this.options)\n    };\n  }\n\n  constructor(\n    private srv: CellService,\n    private router: Router,\n    private cdr: ChangeDetectorRef,\n    private el: ElementRef<HTMLElement>,\n    private renderer: Renderer2,\n    private imgSrv: NzImageService,\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Inject(WINDOW) private win: any\n  ) {}\n\n  private updateValue(): void {\n    this.destroy$?.unsubscribe();\n    this.destroy$ = this.srv.get(this.value, this.options).subscribe(res => {\n      this.res = res;\n      this.showDefault = this.value == (this.safeOpt.default as CellDefaultText).condition;\n      this._text = res.result?.text ?? '';\n      this._unit = res.result?.unit ?? this.safeOpt?.unit;\n      this.cdr.detectChanges();\n      this.setClass();\n    });\n  }\n\n  private setClass(): void {\n    const { el, renderer } = this;\n    const { renderType, size } = this.safeOpt;\n    updateHostClass(el.nativeElement, renderer, {\n      [`cell`]: true,\n      [`cell__${renderType}`]: renderType != null,\n      [`cell__${size}`]: size != null,\n      [`cell__has-unit`]: this._unit,\n      [`cell__has-default`]: this.showDefault,\n      [`cell__disabled`]: this.disabled\n    });\n    el.nativeElement.dataset.type = this.safeOpt.type;\n  }\n\n  ngOnChanges(changes: { [p in keyof CellComponent]?: SimpleChange }): void {\n    // Do not call updateValue when only updating loading, disabled\n    if (Object.keys(changes).every(k => ['loading', 'disabled'].includes(k))) {\n      this.setClass();\n    } else {\n      this.updateValue();\n    }\n  }\n\n  change(value: NzSafeAny): void {\n    this.value = value;\n    this.valueChange.emit(value);\n  }\n\n  _link(e: Event): void {\n    e.preventDefault();\n    e.stopPropagation();\n\n    if (this.disabled) return;\n\n    const link = this.safeOpt.link;\n    const url = link?.url;\n    if (url == null) return;\n\n    if (/https?:\\/\\//g.test(url)) {\n      (this.win as Window).open(url, link?.target);\n    } else {\n      this.router.navigateByUrl(url);\n    }\n  }\n\n  _showImg(img: string): void {\n    const config = this.safeOpt.img;\n    if (config == null || config.big == null) return;\n\n    let idx = -1;\n    const list = (this._text as string[]).map((p, index) => {\n      if (idx === -1 && p === img) idx = index;\n      return typeof config.big === 'function' ? config.big(p) : p;\n    });\n    this.imgSrv\n      .preview(\n        list.map(p => ({ src: p }) as NzImage),\n        config.previewOptions\n      )\n      .switchTo(idx);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$?.unsubscribe();\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FiYy9jZWxsL2NlbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,54 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { NzBadgeModule } from 'ng-zorro-antd/badge';
5
+ import { NzCheckboxModule } from 'ng-zorro-antd/checkbox';
6
+ import { NzImageModule } from 'ng-zorro-antd/experimental/image';
7
+ import { NzIconModule } from 'ng-zorro-antd/icon';
8
+ import { NzRadioModule } from 'ng-zorro-antd/radio';
9
+ import { NzTagModule } from 'ng-zorro-antd/tag';
10
+ import { NzToolTipModule } from 'ng-zorro-antd/tooltip';
11
+ import { CellHostDirective } from './cell-host.directive';
12
+ import { CellComponent } from './cell.component';
13
+ import * as i0 from "@angular/core";
14
+ const COMPS = [CellComponent];
15
+ export class CellModule {
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
17
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: CellModule, declarations: [CellComponent, CellHostDirective], imports: [CommonModule,
18
+ FormsModule,
19
+ NzCheckboxModule,
20
+ NzRadioModule,
21
+ NzBadgeModule,
22
+ NzTagModule,
23
+ NzToolTipModule,
24
+ NzIconModule,
25
+ NzImageModule], exports: [CellComponent] }); }
26
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellModule, imports: [CommonModule,
27
+ FormsModule,
28
+ NzCheckboxModule,
29
+ NzRadioModule,
30
+ NzBadgeModule,
31
+ NzTagModule,
32
+ NzToolTipModule,
33
+ NzIconModule,
34
+ NzImageModule] }); }
35
+ }
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellModule, decorators: [{
37
+ type: NgModule,
38
+ args: [{
39
+ imports: [
40
+ CommonModule,
41
+ FormsModule,
42
+ NzCheckboxModule,
43
+ NzRadioModule,
44
+ NzBadgeModule,
45
+ NzTagModule,
46
+ NzToolTipModule,
47
+ NzIconModule,
48
+ NzImageModule
49
+ ],
50
+ declarations: [...COMPS, CellHostDirective],
51
+ exports: COMPS
52
+ }]
53
+ }] });
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hYmMvY2VsbC9jZWxsLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzFELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFeEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQUVqRCxNQUFNLEtBQUssR0FBRyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0FBaUI5QixNQUFNLE9BQU8sVUFBVTs4R0FBVixVQUFVOytHQUFWLFVBQVUsaUJBakJSLGFBQWEsRUFjRCxpQkFBaUIsYUFWeEMsWUFBWTtZQUNaLFdBQVc7WUFDWCxnQkFBZ0I7WUFDaEIsYUFBYTtZQUNiLGFBQWE7WUFDYixXQUFXO1lBQ1gsZUFBZTtZQUNmLFlBQVk7WUFDWixhQUFhLGFBWkYsYUFBYTsrR0FpQmYsVUFBVSxZQWJuQixZQUFZO1lBQ1osV0FBVztZQUNYLGdCQUFnQjtZQUNoQixhQUFhO1lBQ2IsYUFBYTtZQUNiLFdBQVc7WUFDWCxlQUFlO1lBQ2YsWUFBWTtZQUNaLGFBQWE7OzJGQUtKLFVBQVU7a0JBZnRCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWixhQUFhO3FCQUNkO29CQUNELFlBQVksRUFBRSxDQUFDLEdBQUcsS0FBSyxFQUFFLGlCQUFpQixDQUFDO29CQUMzQyxPQUFPLEVBQUUsS0FBSztpQkFDZiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IE56QmFkZ2VNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2JhZGdlJztcbmltcG9ydCB7IE56Q2hlY2tib3hNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2NoZWNrYm94JztcbmltcG9ydCB7IE56SW1hZ2VNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2V4cGVyaW1lbnRhbC9pbWFnZSc7XG5pbXBvcnQgeyBOekljb25Nb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL2ljb24nO1xuaW1wb3J0IHsgTnpSYWRpb01vZHVsZSB9IGZyb20gJ25nLXpvcnJvLWFudGQvcmFkaW8nO1xuaW1wb3J0IHsgTnpUYWdNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL3RhZyc7XG5pbXBvcnQgeyBOelRvb2xUaXBNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL3Rvb2x0aXAnO1xuXG5pbXBvcnQgeyBDZWxsSG9zdERpcmVjdGl2ZSB9IGZyb20gJy4vY2VsbC1ob3N0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLmNvbXBvbmVudCc7XG5cbmNvbnN0IENPTVBTID0gW0NlbGxDb21wb25lbnRdO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIE56Q2hlY2tib3hNb2R1bGUsXG4gICAgTnpSYWRpb01vZHVsZSxcbiAgICBOekJhZGdlTW9kdWxlLFxuICAgIE56VGFnTW9kdWxlLFxuICAgIE56VG9vbFRpcE1vZHVsZSxcbiAgICBOekljb25Nb2R1bGUsXG4gICAgTnpJbWFnZU1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QUywgQ2VsbEhvc3REaXJlY3RpdmVdLFxuICBleHBvcnRzOiBDT01QU1xufSlcbmV4cG9ydCBjbGFzcyBDZWxsTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,168 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { map, of } from 'rxjs';
3
+ import { yn } from '@delon/theme';
4
+ import { formatDate } from '@delon/util/date-time';
5
+ import { formatMask } from '@delon/util/format';
6
+ import { deepMerge } from '@delon/util/other';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@delon/util/config";
9
+ import * as i2 from "ng-zorro-antd/i18n";
10
+ import * as i3 from "@delon/util/format";
11
+ import * as i4 from "@angular/platform-browser";
12
+ export class CellService {
13
+ constructor(configSrv, nzI18n, currency, dom) {
14
+ this.nzI18n = nzI18n;
15
+ this.currency = currency;
16
+ this.dom = dom;
17
+ this.widgets = {
18
+ date: {
19
+ type: 'fn',
20
+ ref: (value, opt) => {
21
+ return { text: formatDate(value, opt.date.format, this.nzI18n.getDateLocale()) };
22
+ }
23
+ },
24
+ mega: {
25
+ type: 'fn',
26
+ ref: (value, opt) => {
27
+ const res = this.currency.mega(value, opt.mega);
28
+ return { text: res.value, unit: res.unitI18n };
29
+ }
30
+ },
31
+ currency: {
32
+ type: 'fn',
33
+ ref: (value, opt) => {
34
+ return { text: this.currency.format(value, opt.currency) };
35
+ }
36
+ },
37
+ cny: {
38
+ type: 'fn',
39
+ ref: (value, opt) => {
40
+ return { text: this.currency.cny(value, opt.cny) };
41
+ }
42
+ },
43
+ boolean: {
44
+ type: 'fn',
45
+ ref: (value, opt) => {
46
+ return { text: this.dom.bypassSecurityTrustHtml(yn(value, opt.boolean)) };
47
+ }
48
+ },
49
+ img: {
50
+ type: 'fn',
51
+ ref: value => {
52
+ return { text: Array.isArray(value) ? value : [value] };
53
+ }
54
+ }
55
+ };
56
+ this.globalOptions = configSrv.merge('cell', {
57
+ date: { format: 'yyyy-MM-dd HH:mm:ss' },
58
+ img: { size: 32 },
59
+ default: { text: '-' }
60
+ });
61
+ }
62
+ registerWidget(key, widget) {
63
+ this.widgets[key] = { type: 'widget', ref: widget };
64
+ }
65
+ getWidget(key) {
66
+ return this.widgets[key];
67
+ }
68
+ genType(value, options) {
69
+ if (options.type != null)
70
+ return options.type;
71
+ const typeOf = typeof value;
72
+ // When is timestamp
73
+ if (typeOf === 'number' && /^[0-9]{13}$/g.test(value))
74
+ return 'date';
75
+ if (value instanceof Date || options.date != null)
76
+ return 'date';
77
+ // Auto detection
78
+ if (options.widget != null)
79
+ return 'widget';
80
+ else if (options.mega != null)
81
+ return 'mega';
82
+ else if (options.currency != null)
83
+ return 'currency';
84
+ else if (options.cny != null)
85
+ return 'cny';
86
+ else if (options.img != null)
87
+ return 'img';
88
+ else if (options.link != null)
89
+ return 'link';
90
+ else if (options.html != null)
91
+ return 'html';
92
+ else if (options.badge != null)
93
+ return 'badge';
94
+ else if (options.tag != null)
95
+ return 'tag';
96
+ else if (options.checkbox != null)
97
+ return 'checkbox';
98
+ else if (options.radio != null)
99
+ return 'radio';
100
+ else if (options.enum != null)
101
+ return 'enum';
102
+ else if (typeOf === 'number')
103
+ return 'number';
104
+ else if (typeOf === 'boolean' || options.boolean != null)
105
+ return 'boolean';
106
+ else
107
+ return 'string';
108
+ }
109
+ fixOptions(options) {
110
+ return deepMerge({}, this.globalOptions, options);
111
+ }
112
+ get(value, options) {
113
+ const type = this.genType(value, { ...options });
114
+ const opt = this.fixOptions(options);
115
+ opt.type = type;
116
+ const isSafeHtml = typeof value === 'object' &&
117
+ typeof value?.getTypeName === 'function' &&
118
+ value?.getTypeName() != null;
119
+ let res = {
120
+ result: typeof value === 'object' && !isSafeHtml
121
+ ? value
122
+ : { text: value == null ? '' : isSafeHtml ? value : `${value}` },
123
+ options: opt
124
+ };
125
+ const widget = this.widgets[type];
126
+ if (widget?.type === 'fn') {
127
+ res.result = widget.ref(value, opt);
128
+ }
129
+ return (typeof value === 'function' ? value(value, opt) : of(res.result)).pipe(map(text => {
130
+ res.result = text;
131
+ let dictData;
132
+ switch (type) {
133
+ case 'badge':
134
+ dictData = (opt.badge?.data ?? {})[value];
135
+ res.result = { color: 'default', ...dictData };
136
+ break;
137
+ case 'tag':
138
+ dictData = (opt.tag?.data ?? {})[value];
139
+ res.result = dictData;
140
+ break;
141
+ case 'enum':
142
+ res.result = { text: (opt.enum ?? {})[value] };
143
+ break;
144
+ case 'html':
145
+ res.safeHtml = opt.html?.safe;
146
+ break;
147
+ case 'string':
148
+ if (isSafeHtml)
149
+ res.safeHtml = 'safeHtml';
150
+ break;
151
+ }
152
+ if ((type === 'badge' || type === 'tag') && dictData?.tooltip != null) {
153
+ res.options.tooltip = dictData.tooltip;
154
+ }
155
+ if (opt.mask != null) {
156
+ res.result.text = formatMask(res.result.text, opt.mask);
157
+ }
158
+ return res;
159
+ }));
160
+ }
161
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellService, deps: [{ token: i1.AlainConfigService }, { token: i2.NzI18nService }, { token: i3.CurrencyService }, { token: i4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Injectable }); }
162
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellService, providedIn: 'root' }); }
163
+ }
164
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CellService, decorators: [{
165
+ type: Injectable,
166
+ args: [{ providedIn: 'root' }]
167
+ }], ctorParameters: function () { return [{ type: i1.AlainConfigService }, { type: i2.NzI18nService }, { type: i3.CurrencyService }, { type: i4.DomSanitizer }]; } });
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.service.js","sourceRoot":"","sources":["../../../../../packages/abc/cell/cell.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { map, Observable, of } from 'rxjs';\n\nimport { yn } from '@delon/theme';\nimport { AlainCellConfig, AlainConfigService } from '@delon/util/config';\nimport { formatDate } from '@delon/util/date-time';\nimport { CurrencyService, formatMask } from '@delon/util/format';\nimport { deepMerge } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzI18nService } from 'ng-zorro-antd/i18n';\n\nimport type {\n  CellFuValue,\n  CellOptions,\n  CellTextResult,\n  CellTextUnit,\n  CellType,\n  CellWidget,\n  CellWidgetFn\n} from './cell.types';\n\n@Injectable({ providedIn: 'root' })\nexport class CellService {\n  private globalOptions!: AlainCellConfig;\n  private widgets: { [key: string]: CellWidget } = {\n    date: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: formatDate(value as string, opt.date!.format!, this.nzI18n.getDateLocale()) };\n      }\n    },\n    mega: {\n      type: 'fn',\n      ref: (value, opt) => {\n        const res = this.currency.mega(value as number, opt.mega);\n        return { text: res.value, unit: res.unitI18n };\n      }\n    },\n    currency: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.currency.format(value as number, opt.currency) };\n      }\n    },\n    cny: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.currency.cny(value as number, opt.cny) };\n      }\n    },\n    boolean: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.dom.bypassSecurityTrustHtml(yn(value as boolean, opt.boolean)) };\n      }\n    },\n    img: {\n      type: 'fn',\n      ref: value => {\n        return { text: Array.isArray(value) ? value : [value] };\n      }\n    }\n  };\n\n  constructor(\n    configSrv: AlainConfigService,\n    private nzI18n: NzI18nService,\n    private currency: CurrencyService,\n    private dom: DomSanitizer\n  ) {\n    this.globalOptions = configSrv.merge('cell', {\n      date: { format: 'yyyy-MM-dd HH:mm:ss' },\n      img: { size: 32 },\n      default: { text: '-' }\n    })!;\n  }\n\n  registerWidget(key: string, widget: Type<unknown>): void {\n    this.widgets[key] = { type: 'widget', ref: widget };\n  }\n\n  getWidget(key: string): CellWidget | undefined {\n    return this.widgets[key];\n  }\n\n  private genType(value: unknown, options: CellOptions): CellType {\n    if (options.type != null) return options.type;\n\n    const typeOf = typeof value;\n    // When is timestamp\n    if (typeOf === 'number' && /^[0-9]{13}$/g.test(value as string)) return 'date';\n    if (value instanceof Date || options.date != null) return 'date';\n\n    // Auto detection\n    if (options.widget != null) return 'widget';\n    else if (options.mega != null) return 'mega';\n    else if (options.currency != null) return 'currency';\n    else if (options.cny != null) return 'cny';\n    else if (options.img != null) return 'img';\n    else if (options.link != null) return 'link';\n    else if (options.html != null) return 'html';\n    else if (options.badge != null) return 'badge';\n    else if (options.tag != null) return 'tag';\n    else if (options.checkbox != null) return 'checkbox';\n    else if (options.radio != null) return 'radio';\n    else if (options.enum != null) return 'enum';\n    else if (typeOf === 'number') return 'number';\n    else if (typeOf === 'boolean' || options.boolean != null) return 'boolean';\n    else return 'string';\n  }\n\n  fixOptions(options?: CellOptions): CellOptions {\n    return deepMerge({}, this.globalOptions, options);\n  }\n\n  get(value: unknown, options?: CellOptions): Observable<CellTextResult> {\n    const type = this.genType(value, { ...options });\n    const opt = this.fixOptions(options);\n    opt.type = type;\n    const isSafeHtml =\n      typeof value === 'object' &&\n      typeof (value as NzSafeAny)?.getTypeName === 'function' &&\n      (value as NzSafeAny)?.getTypeName() != null;\n\n    let res: CellTextResult = {\n      result:\n        typeof value === 'object' && !isSafeHtml\n          ? (value as CellTextUnit)\n          : { text: value == null ? '' : isSafeHtml ? value : `${value}` },\n      options: opt\n    };\n\n    const widget = this.widgets[type];\n    if (widget?.type === 'fn') {\n      res.result = (widget.ref as CellWidgetFn)(value, opt);\n    }\n\n    return (typeof value === 'function' ? (value as CellFuValue)(value, opt) : of(res.result)).pipe(\n      map(text => {\n        res.result = text;\n        let dictData: { tooltip?: string } | undefined;\n        switch (type) {\n          case 'badge':\n            dictData = (opt.badge?.data ?? {})[value as string];\n            res.result = { color: 'default', ...dictData };\n            break;\n          case 'tag':\n            dictData = (opt.tag?.data ?? {})[value as string];\n            res.result = dictData as CellTextUnit;\n            break;\n          case 'enum':\n            res.result = { text: (opt.enum ?? {})[value as string] };\n            break;\n          case 'html':\n            res.safeHtml = opt.html?.safe;\n            break;\n          case 'string':\n            if (isSafeHtml) res.safeHtml = 'safeHtml';\n            break;\n        }\n        if ((type === 'badge' || type === 'tag') && dictData?.tooltip != null) {\n          res.options.tooltip = dictData.tooltip;\n        }\n        if (opt.mask != null) {\n          res.result.text = formatMask(res.result.text as string, opt.mask);\n        }\n        return res;\n      })\n    );\n  }\n}\n"]}