@delon/abc 12.2.2 → 12.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/bundles/abc.umd.js +3 -3
  2. package/bundles/autoFocus.umd.js +4 -4
  3. package/bundles/avatarList.umd.js +4 -4
  4. package/bundles/count-down.umd.js +4 -4
  5. package/bundles/datePicker.umd.js +5 -5
  6. package/bundles/downFile.umd.js +4 -4
  7. package/bundles/edit.umd.js +4 -4
  8. package/bundles/ellipsis.umd.js +4 -4
  9. package/bundles/errorCollect.umd.js +4 -4
  10. package/bundles/exception.umd.js +12 -9
  11. package/bundles/exception.umd.js.map +1 -1
  12. package/bundles/footerToolbar.umd.js +4 -4
  13. package/bundles/fullContent.umd.js +6 -8
  14. package/bundles/fullContent.umd.js.map +1 -1
  15. package/bundles/globalFooter.umd.js +4 -4
  16. package/bundles/grid.umd.js +3 -3
  17. package/bundles/image.umd.js +3 -3
  18. package/bundles/let.umd.js +4 -4
  19. package/bundles/loading.umd.js +6 -8
  20. package/bundles/loading.umd.js.map +1 -1
  21. package/bundles/lodop.umd.js +5 -7
  22. package/bundles/lodop.umd.js.map +1 -1
  23. package/bundles/media.umd.js +5 -7
  24. package/bundles/media.umd.js.map +1 -1
  25. package/bundles/noticeIcon.umd.js +4 -4
  26. package/bundles/onboarding.umd.js +6 -8
  27. package/bundles/onboarding.umd.js.map +1 -1
  28. package/bundles/pageHeader.umd.js +4 -4
  29. package/bundles/pdf.umd.js +4 -4
  30. package/bundles/qr.umd.js +3 -3
  31. package/bundles/quickMenu.umd.js +4 -4
  32. package/bundles/result.umd.js +4 -4
  33. package/bundles/reuseTab.umd.js +14 -25
  34. package/bundles/reuseTab.umd.js.map +1 -1
  35. package/bundles/table.umd.js +243 -145
  36. package/bundles/table.umd.js.map +1 -1
  37. package/bundles/tagSelect.umd.js +4 -4
  38. package/bundles/view.umd.js +4 -4
  39. package/bundles/xlsx.umd.js +30 -37
  40. package/bundles/xlsx.umd.js.map +1 -1
  41. package/bundles/zip.umd.js +5 -7
  42. package/bundles/zip.umd.js.map +1 -1
  43. package/esm2015/exception/exception.component.js +7 -4
  44. package/esm2015/exception/exception.module.js +3 -2
  45. package/esm2015/lodop/lodop.service.js +1 -1
  46. package/esm2015/reuse-tab/reuse-tab-context-menu.component.js +2 -2
  47. package/esm2015/reuse-tab/reuse-tab-context.service.js +4 -13
  48. package/esm2015/reuse-tab/reuse-tab.component.js +6 -6
  49. package/esm2015/st/index.js +2 -0
  50. package/esm2015/st/st-column-source.js +28 -7
  51. package/esm2015/st/st-data-source.js +4 -4
  52. package/esm2015/st/st-filter.component.js +149 -0
  53. package/esm2015/st/st-td.component.js +232 -0
  54. package/esm2015/st/st.component.js +28 -118
  55. package/esm2015/st/st.config.js +1 -2
  56. package/esm2015/st/st.interfaces.js +1 -1
  57. package/esm2015/st/st.module.js +9 -3
  58. package/esm2015/st/st.types.js +1 -1
  59. package/esm2015/st/table.js +3 -1
  60. package/esm2015/xlsx/xlsx.service.js +23 -29
  61. package/esm2015/xlsx/xlsx.types.js +1 -1
  62. package/esm2015/zip/zip.service.js +1 -1
  63. package/exception/exception.component.d.ts +3 -2
  64. package/exception/exception.metadata.json +1 -1
  65. package/fesm2015/exception.js +8 -4
  66. package/fesm2015/exception.js.map +1 -1
  67. package/fesm2015/lodop.js.map +1 -1
  68. package/fesm2015/reuseTab.js +9 -18
  69. package/fesm2015/reuseTab.js.map +1 -1
  70. package/fesm2015/table.js +439 -130
  71. package/fesm2015/table.js.map +1 -1
  72. package/fesm2015/xlsx.js +22 -28
  73. package/fesm2015/xlsx.js.map +1 -1
  74. package/fesm2015/zip.js.map +1 -1
  75. package/package.json +4 -4
  76. package/reuse-tab/reuse-tab.component.d.ts +1 -1
  77. package/reuse-tab/reuseTab.metadata.json +1 -1
  78. package/st/index.d.ts +1 -0
  79. package/st/st-filter.component.d.ts +18 -0
  80. package/st/st-td.component.d.ts +27 -0
  81. package/st/st.component.d.ts +8 -23
  82. package/st/st.interfaces.d.ts +57 -3
  83. package/st/st.types.d.ts +6 -0
  84. package/st/style/index.less +8 -0
  85. package/st/table.d.ts +2 -0
  86. package/st/table.metadata.json +1 -1
  87. package/sv/style/index.less +1 -0
  88. package/xlsx/xlsx.metadata.json +1 -1
  89. package/xlsx/xlsx.types.d.ts +3 -0
@@ -0,0 +1,149 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ export class STFilterComponent {
3
+ constructor() {
4
+ this.visible = false;
5
+ this.locale = {};
6
+ this.n = new EventEmitter();
7
+ this.handle = new EventEmitter();
8
+ }
9
+ get icon() {
10
+ return this.f.icon;
11
+ }
12
+ show($event) {
13
+ $event.stopPropagation();
14
+ }
15
+ checkboxChange() {
16
+ var _a;
17
+ this.n.emit((_a = this.f.menus) === null || _a === void 0 ? void 0 : _a.filter(w => w.checked));
18
+ }
19
+ radioChange(item) {
20
+ this.f.menus.forEach(i => (i.checked = false));
21
+ item.checked = !item.checked;
22
+ this.n.emit(item);
23
+ }
24
+ confirm() {
25
+ this.handle.emit(true);
26
+ }
27
+ reset() {
28
+ this.handle.emit(false);
29
+ }
30
+ }
31
+ STFilterComponent.decorators = [
32
+ { type: Component, args: [{
33
+ selector: 'st-filter',
34
+ template: `
35
+ <span
36
+ class="ant-table-filter-trigger"
37
+ [class.active]="visible || f.default"
38
+ nz-dropdown
39
+ [nzDropdownMenu]="filterMenu"
40
+ nzTrigger="click"
41
+ [nzClickHide]="false"
42
+ [(nzVisible)]="visible"
43
+ nzOverlayClassName="st__filter-wrap"
44
+ (click)="show($event)"
45
+ >
46
+ <i nz-icon [nzType]="icon.type" [nzTheme]="icon.theme!"></i>
47
+ </span>
48
+ <nz-dropdown-menu #filterMenu="nzDropdownMenu">
49
+ <div class="ant-table-filter-dropdown">
50
+ <ng-container [ngSwitch]="f.type">
51
+ <div *ngSwitchCase="'keyword'" class="st__filter-keyword">
52
+ <input
53
+ type="text"
54
+ nz-input
55
+ [attr.placeholder]="f.placeholder"
56
+ [(ngModel)]="f.menus![0]!.value"
57
+ (ngModelChange)="n.emit($event)"
58
+ (keyup.enter)="confirm()"
59
+ />
60
+ </div>
61
+ <div *ngSwitchCase="'number'" class="p-sm st__filter-number">
62
+ <nz-input-number
63
+ [(ngModel)]="f.menus![0]!.value"
64
+ (ngModelChange)="n.emit($event)"
65
+ [nzMin]="f.number!.min!"
66
+ [nzMax]="f.number!.max!"
67
+ [nzStep]="f.number!.step!"
68
+ [nzPrecision]="f.number!.precision"
69
+ [nzPlaceHolder]="f.placeholder!"
70
+ class="width-100"
71
+ ></nz-input-number>
72
+ </div>
73
+ <div *ngSwitchCase="'date'" class="p-sm st__filter-date">
74
+ <nz-date-picker
75
+ *ngIf="!f.date!.range"
76
+ nzInline
77
+ [nzMode]="f.date!.mode"
78
+ [(ngModel)]="f.menus![0]!.value"
79
+ (ngModelChange)="n.emit($event)"
80
+ [nzShowNow]="f.date!.showNow"
81
+ [nzShowToday]="f.date!.showToday"
82
+ [nzDisabledDate]="f.date!.disabledDate"
83
+ [nzDisabledTime]="f.date!.disabledTime"
84
+ ></nz-date-picker>
85
+ <nz-range-picker
86
+ *ngIf="f.date!.range"
87
+ nzInline
88
+ [nzMode]="f.date!.mode"
89
+ [(ngModel)]="f.menus![0]!.value"
90
+ (ngModelChange)="n.emit($event)"
91
+ [nzShowNow]="f.date!.showNow"
92
+ [nzShowToday]="f.date!.showToday"
93
+ [nzDisabledDate]="f.date!.disabledDate"
94
+ [nzDisabledTime]="f.date!.disabledTime"
95
+ ></nz-range-picker>
96
+ </div>
97
+ <div *ngSwitchCase="'time'" class="p-sm st__filter-time"> </div>
98
+ <div *ngSwitchCase="'custom'" class="st__filter-custom">
99
+ <ng-template
100
+ [ngTemplateOutlet]="f.custom!"
101
+ [ngTemplateOutletContext]="{ $implicit: f, col: col }"
102
+ ></ng-template>
103
+ </div>
104
+ <ul *ngSwitchDefault nz-menu>
105
+ <ng-container *ngIf="f.multiple">
106
+ <li nz-menu-item *ngFor="let filter of f.menus">
107
+ <label nz-checkbox [(ngModel)]="filter.checked" (ngModelChange)="checkboxChange()">
108
+ {{ filter.text }}
109
+ </label>
110
+ </li>
111
+ </ng-container>
112
+ <ng-container *ngIf="!f.multiple">
113
+ <li nz-menu-item *ngFor="let filter of f.menus">
114
+ <label nz-radio [ngModel]="filter.checked" (ngModelChange)="radioChange(filter)">
115
+ {{ filter.text }}
116
+ </label>
117
+ </li>
118
+ </ng-container>
119
+ </ul>
120
+ </ng-container>
121
+ <div *ngIf="f.showOPArea" class="ant-table-filter-dropdown-btns">
122
+ <a class="ant-table-filter-dropdown-link confirm" (click)="visible = false">
123
+ <span (click)="confirm()">{{ f.confirmText || locale.filterConfirm }}</span>
124
+ </a>
125
+ <a class="ant-table-filter-dropdown-link clear" (click)="visible = false">
126
+ <span (click)="reset()">{{ f.clearText || locale.filterReset }}</span>
127
+ </a>
128
+ </div>
129
+ </div>
130
+ </nz-dropdown-menu>
131
+ `,
132
+ host: {
133
+ '[class.ant-table-filter-trigger-container]': `true`,
134
+ '[class.st__filter]': `true`,
135
+ '[class.ant-table-filter-trigger-container-open]': `visible`
136
+ },
137
+ preserveWhitespaces: false,
138
+ changeDetection: ChangeDetectionStrategy.OnPush,
139
+ encapsulation: ViewEncapsulation.None
140
+ },] }
141
+ ];
142
+ STFilterComponent.propDecorators = {
143
+ col: [{ type: Input }],
144
+ locale: [{ type: Input }],
145
+ f: [{ type: Input }],
146
+ n: [{ type: Output }],
147
+ handle: [{ type: Output }]
148
+ };
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-filter.component.js","sourceRoot":"","sources":["../../../../../packages/abc/st/st-filter.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAoHnH,MAAM,OAAO,iBAAiB;IA7G9B;QA8GE,YAAO,GAAG,KAAK,CAAC;QAEP,WAAM,GAAe,EAAE,CAAC;QAEd,MAAC,GAAG,IAAI,YAAY,EAAW,CAAC;QAChC,WAAM,GAAG,IAAI,YAAY,EAAW,CAAC;IA0B1D,CAAC;IAzBC,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,CAAC,CAAC,IAAc,CAAC;IAC/B,CAAC;IAED,IAAI,CAAC,MAAkB;QACrB,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,cAAc;;QACZ,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAA,IAAI,CAAC,CAAC,CAAC,KAAK,0CAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,IAAwB;QAClC,IAAI,CAAC,CAAC,CAAC,KAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;;;YA5IF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;gBACrB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiGT;gBACD,IAAI,EAAE;oBACJ,4CAA4C,EAAE,MAAM;oBACpD,oBAAoB,EAAE,MAAM;oBAC5B,iDAAiD,EAAE,SAAS;iBAC7D;gBACD,mBAAmB,EAAE,KAAK;gBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;kBAGE,KAAK;qBACL,KAAK;gBACL,KAAK;gBACL,MAAM;qBACN,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\n\nimport { LocaleData } from '@delon/theme';\n\nimport { STColumnFilter, STColumnFilterMenu, STIcon } from './st.interfaces';\nimport { _STColumn } from './st.types';\n\n@Component({\n  selector: 'st-filter',\n  template: `\n    <span\n      class=\"ant-table-filter-trigger\"\n      [class.active]=\"visible || f.default\"\n      nz-dropdown\n      [nzDropdownMenu]=\"filterMenu\"\n      nzTrigger=\"click\"\n      [nzClickHide]=\"false\"\n      [(nzVisible)]=\"visible\"\n      nzOverlayClassName=\"st__filter-wrap\"\n      (click)=\"show($event)\"\n    >\n      <i nz-icon [nzType]=\"icon.type\" [nzTheme]=\"icon.theme!\"></i>\n    </span>\n    <nz-dropdown-menu #filterMenu=\"nzDropdownMenu\">\n      <div class=\"ant-table-filter-dropdown\">\n        <ng-container [ngSwitch]=\"f.type\">\n          <div *ngSwitchCase=\"'keyword'\" class=\"st__filter-keyword\">\n            <input\n              type=\"text\"\n              nz-input\n              [attr.placeholder]=\"f.placeholder\"\n              [(ngModel)]=\"f.menus![0]!.value\"\n              (ngModelChange)=\"n.emit($event)\"\n              (keyup.enter)=\"confirm()\"\n            />\n          </div>\n          <div *ngSwitchCase=\"'number'\" class=\"p-sm st__filter-number\">\n            <nz-input-number\n              [(ngModel)]=\"f.menus![0]!.value\"\n              (ngModelChange)=\"n.emit($event)\"\n              [nzMin]=\"f.number!.min!\"\n              [nzMax]=\"f.number!.max!\"\n              [nzStep]=\"f.number!.step!\"\n              [nzPrecision]=\"f.number!.precision\"\n              [nzPlaceHolder]=\"f.placeholder!\"\n              class=\"width-100\"\n            ></nz-input-number>\n          </div>\n          <div *ngSwitchCase=\"'date'\" class=\"p-sm st__filter-date\">\n            <nz-date-picker\n              *ngIf=\"!f.date!.range\"\n              nzInline\n              [nzMode]=\"f.date!.mode\"\n              [(ngModel)]=\"f.menus![0]!.value\"\n              (ngModelChange)=\"n.emit($event)\"\n              [nzShowNow]=\"f.date!.showNow\"\n              [nzShowToday]=\"f.date!.showToday\"\n              [nzDisabledDate]=\"f.date!.disabledDate\"\n              [nzDisabledTime]=\"f.date!.disabledTime\"\n            ></nz-date-picker>\n            <nz-range-picker\n              *ngIf=\"f.date!.range\"\n              nzInline\n              [nzMode]=\"f.date!.mode\"\n              [(ngModel)]=\"f.menus![0]!.value\"\n              (ngModelChange)=\"n.emit($event)\"\n              [nzShowNow]=\"f.date!.showNow\"\n              [nzShowToday]=\"f.date!.showToday\"\n              [nzDisabledDate]=\"f.date!.disabledDate\"\n              [nzDisabledTime]=\"f.date!.disabledTime\"\n            ></nz-range-picker>\n          </div>\n          <div *ngSwitchCase=\"'time'\" class=\"p-sm st__filter-time\"> </div>\n          <div *ngSwitchCase=\"'custom'\" class=\"st__filter-custom\">\n            <ng-template\n              [ngTemplateOutlet]=\"f.custom!\"\n              [ngTemplateOutletContext]=\"{ $implicit: f, col: col }\"\n            ></ng-template>\n          </div>\n          <ul *ngSwitchDefault nz-menu>\n            <ng-container *ngIf=\"f.multiple\">\n              <li nz-menu-item *ngFor=\"let filter of f.menus\">\n                <label nz-checkbox [(ngModel)]=\"filter.checked\" (ngModelChange)=\"checkboxChange()\">\n                  {{ filter.text }}\n                </label>\n              </li>\n            </ng-container>\n            <ng-container *ngIf=\"!f.multiple\">\n              <li nz-menu-item *ngFor=\"let filter of f.menus\">\n                <label nz-radio [ngModel]=\"filter.checked\" (ngModelChange)=\"radioChange(filter)\">\n                  {{ filter.text }}\n                </label>\n              </li>\n            </ng-container>\n          </ul>\n        </ng-container>\n        <div *ngIf=\"f.showOPArea\" class=\"ant-table-filter-dropdown-btns\">\n          <a class=\"ant-table-filter-dropdown-link confirm\" (click)=\"visible = false\">\n            <span (click)=\"confirm()\">{{ f.confirmText || locale.filterConfirm }}</span>\n          </a>\n          <a class=\"ant-table-filter-dropdown-link clear\" (click)=\"visible = false\">\n            <span (click)=\"reset()\">{{ f.clearText || locale.filterReset }}</span>\n          </a>\n        </div>\n      </div>\n    </nz-dropdown-menu>\n  `,\n  host: {\n    '[class.ant-table-filter-trigger-container]': `true`,\n    '[class.st__filter]': `true`,\n    '[class.ant-table-filter-trigger-container-open]': `visible`\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class STFilterComponent {\n  visible = false;\n  @Input() col: _STColumn;\n  @Input() locale: LocaleData = {};\n  @Input() f: STColumnFilter;\n  @Output() readonly n = new EventEmitter<unknown>();\n  @Output() readonly handle = new EventEmitter<boolean>();\n  get icon(): STIcon {\n    return this.f.icon as STIcon;\n  }\n\n  show($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  checkboxChange(): void {\n    this.n.emit(this.f.menus?.filter(w => w.checked));\n  }\n\n  radioChange(item: STColumnFilterMenu): void {\n    this.f.menus!.forEach(i => (i.checked = false));\n    item.checked = !item.checked;\n    this.n.emit(item);\n  }\n\n  confirm(): void {\n    this.handle.emit(true);\n  }\n\n  reset(): void {\n    this.handle.emit(false);\n  }\n}\n"]}
@@ -0,0 +1,232 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Host, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { Router } from '@angular/router';
3
+ import { filter } from 'rxjs/operators';
4
+ import { DrawerHelper, ModalHelper } from '@delon/theme';
5
+ import { deepMergeKey } from '@delon/util/other';
6
+ import { STComponent } from '.';
7
+ export class STTdComponent {
8
+ constructor(stComp, router, modalHelper, drawerHelper) {
9
+ this.stComp = stComp;
10
+ this.router = router;
11
+ this.modalHelper = modalHelper;
12
+ this.drawerHelper = drawerHelper;
13
+ this.n = new EventEmitter();
14
+ }
15
+ get routerState() {
16
+ const { pi, ps, total } = this.stComp;
17
+ return { pi, ps, total };
18
+ }
19
+ report(type) {
20
+ this.n.emit({ type, item: this.i, col: this.c });
21
+ }
22
+ _checkbox(value) {
23
+ this.i.checked = value;
24
+ this.report('checkbox');
25
+ }
26
+ _radio(checked) {
27
+ this.data.filter(w => !w.disabled).forEach(i => (i.checked = false));
28
+ this.i.checked = checked;
29
+ this.report('radio');
30
+ }
31
+ _link(e) {
32
+ this._stopPropagation(e);
33
+ const res = this.c.click(this.i, this.stComp);
34
+ if (typeof res === 'string') {
35
+ this.router.navigateByUrl(res, { state: this.routerState });
36
+ }
37
+ return false;
38
+ }
39
+ _stopPropagation(ev) {
40
+ ev.preventDefault();
41
+ ev.stopPropagation();
42
+ }
43
+ _btn(btn, ev) {
44
+ if (ev) {
45
+ ev.stopPropagation();
46
+ }
47
+ const record = this.i;
48
+ if (btn.type === 'modal' || btn.type === 'static') {
49
+ const { modal } = btn;
50
+ const obj = { [modal.paramsName]: record };
51
+ this.modalHelper[btn.type === 'modal' ? 'create' : 'createStatic'](modal.component, Object.assign(Object.assign({}, obj), (modal.params && modal.params(record))), deepMergeKey({}, true, this.stComp['cog'].modal, modal))
52
+ .pipe(filter(w => typeof w !== 'undefined'))
53
+ .subscribe((res) => this.btnCallback(record, btn, res));
54
+ return;
55
+ }
56
+ else if (btn.type === 'drawer') {
57
+ const { drawer } = btn;
58
+ const obj = { [drawer.paramsName]: record };
59
+ this.drawerHelper
60
+ .create(drawer.title, drawer.component, Object.assign(Object.assign({}, obj), (drawer.params && drawer.params(record))), deepMergeKey({}, true, this.stComp['cog'].drawer, drawer))
61
+ .pipe(filter(w => typeof w !== 'undefined'))
62
+ .subscribe(res => this.btnCallback(record, btn, res));
63
+ return;
64
+ }
65
+ else if (btn.type === 'link') {
66
+ const clickRes = this.btnCallback(record, btn);
67
+ if (typeof clickRes === 'string') {
68
+ this.router.navigateByUrl(clickRes, { state: this.routerState });
69
+ }
70
+ return;
71
+ }
72
+ this.btnCallback(record, btn);
73
+ }
74
+ btnCallback(record, btn, modal) {
75
+ if (!btn.click)
76
+ return;
77
+ if (typeof btn.click === 'string') {
78
+ switch (btn.click) {
79
+ case 'load':
80
+ this.stComp.load();
81
+ break;
82
+ case 'reload':
83
+ this.stComp.reload();
84
+ break;
85
+ }
86
+ }
87
+ else {
88
+ return btn.click(record, modal, this.stComp);
89
+ }
90
+ }
91
+ }
92
+ STTdComponent.decorators = [
93
+ { type: Component, args: [{
94
+ selector: 'st-td',
95
+ template: `
96
+ <ng-template #btnTpl let-i>
97
+ <ng-container *ngIf="!i.tooltip">
98
+ <ng-template [ngTemplateOutlet]="btnItemTpl" [ngTemplateOutletContext]="{ $implicit: i }"></ng-template>
99
+ </ng-container>
100
+ <span *ngIf="i.tooltip" nz-tooltip [nzTooltipTitle]="i.tooltip">
101
+ <ng-template [ngTemplateOutlet]="btnItemTpl" [ngTemplateOutletContext]="{ $implicit: i }"></ng-template>
102
+ </span>
103
+ </ng-template>
104
+ <ng-template #btnItemTpl let-i>
105
+ <a
106
+ *ngIf="i.pop"
107
+ nz-popconfirm
108
+ [nzPopconfirmTitle]="i.pop.title"
109
+ [nzIcon]="i.pop.icon"
110
+ [nzCondition]="i.pop.condition(i)"
111
+ [nzCancelText]="i.pop.cancelText"
112
+ [nzOkText]="i.pop.okText"
113
+ [nzOkType]="i.pop.okType"
114
+ (nzOnConfirm)="_btn(i)"
115
+ class="st__btn-text"
116
+ [ngClass]="i.className"
117
+ (click)="_stopPropagation($event)"
118
+ >
119
+ <ng-template [ngTemplateOutlet]="btnTextTpl" [ngTemplateOutletContext]="{ $implicit: i }"></ng-template>
120
+ </a>
121
+ <a *ngIf="!i.pop" (click)="_btn(i, $event)" class="st__btn-text" [ngClass]="i.className">
122
+ <ng-template [ngTemplateOutlet]="btnTextTpl" [ngTemplateOutletContext]="{ $implicit: i }"></ng-template>
123
+ </a>
124
+ </ng-template>
125
+ <ng-template #btnTextTpl let-i>
126
+ <ng-container *ngIf="i.icon">
127
+ <i
128
+ *ngIf="!i.icon.iconfont"
129
+ nz-icon
130
+ [nzType]="i.icon.type"
131
+ [nzTheme]="i.icon.theme"
132
+ [nzSpin]="i.icon.spin"
133
+ [nzTwotoneColor]="i.icon.twoToneColor"
134
+ ></i>
135
+ <i *ngIf="i.icon.iconfont" nz-icon [nzIconfont]="i.icon.iconfont"></i>
136
+ </ng-container>
137
+ <span [innerHTML]="i._text" [ngClass]="{ 'pl-xs': i.icon }"></span>
138
+ </ng-template>
139
+ <ng-template
140
+ #render
141
+ [ngTemplateOutlet]="c.__render!"
142
+ [ngTemplateOutletContext]="{ $implicit: i, index: index, column: c }"
143
+ ></ng-template>
144
+ <ng-container *ngIf="!c.__render; else render">
145
+ <ng-container [ngSwitch]="c.type">
146
+ <label
147
+ *ngSwitchCase="'checkbox'"
148
+ nz-checkbox
149
+ [nzDisabled]="i.disabled"
150
+ [ngModel]="i.checked"
151
+ (ngModelChange)="_checkbox($event)"
152
+ ></label>
153
+ <label
154
+ *ngSwitchCase="'radio'"
155
+ nz-radio
156
+ [nzDisabled]="i.disabled"
157
+ [ngModel]="i.checked"
158
+ (ngModelChange)="_radio($event)"
159
+ ></label>
160
+ <a
161
+ *ngSwitchCase="'link'"
162
+ (click)="_link($event)"
163
+ [innerHTML]="i._values[cIdx]._text"
164
+ [attr.title]="i._values[cIdx].text"
165
+ ></a>
166
+ <ng-container *ngIf="i._values[cIdx].text">
167
+ <nz-tag *ngSwitchCase="'tag'" [nzColor]="i._values[cIdx].color">
168
+ <span [innerHTML]="i._values[cIdx]._text"></span>
169
+ </nz-tag>
170
+ <nz-badge
171
+ *ngSwitchCase="'badge'"
172
+ [nzStatus]="i._values[cIdx].color"
173
+ [nzText]="i._values[cIdx].text"
174
+ ></nz-badge>
175
+ </ng-container>
176
+ <ng-template *ngSwitchCase="'widget'" st-widget-host [record]="i" [column]="c"></ng-template
177
+ ><ng-container *ngSwitchDefault>
178
+ <span
179
+ *ngIf="c.safeType !== 'text'"
180
+ [innerHTML]="i._values[cIdx]._text"
181
+ [attr.title]="c._isTruncate ? i._values[cIdx].text : null"
182
+ ></span>
183
+ <span
184
+ *ngIf="c.safeType === 'text'"
185
+ [innerText]="i._values[cIdx]._text"
186
+ [attr.title]="c._isTruncate ? i._values[cIdx].text : null"
187
+ ></span>
188
+ </ng-container>
189
+ </ng-container>
190
+ <ng-container *ngFor="let btn of i._values[cIdx].buttons; let last = last">
191
+ <a *ngIf="btn.children!.length > 0" nz-dropdown [nzDropdownMenu]="btnMenu" nzOverlayClassName="st__btn-sub">
192
+ <span [innerHTML]="btn._text"></span>
193
+ <i nz-icon nzType="down"></i>
194
+ </a>
195
+ <nz-dropdown-menu #btnMenu="nzDropdownMenu">
196
+ <ul nz-menu>
197
+ <ng-container *ngFor="let subBtn of btn.children!">
198
+ <li *ngIf="subBtn.type !== 'divider'" nz-menu-item [class.st__btn-disabled]="subBtn._disabled">
199
+ <ng-template [ngTemplateOutlet]="btnTpl" [ngTemplateOutletContext]="{ $implicit: subBtn }">
200
+ </ng-template>
201
+ </li>
202
+ <li *ngIf="subBtn.type === 'divider'" nz-menu-divider></li>
203
+ </ng-container>
204
+ </ul>
205
+ </nz-dropdown-menu>
206
+ <span *ngIf="btn.children!.length === 0" [class.st__btn-disabled]="btn._disabled">
207
+ <ng-template [ngTemplateOutlet]="btnTpl" [ngTemplateOutletContext]="{ $implicit: btn }"> </ng-template>
208
+ </span>
209
+ <nz-divider *ngIf="!last" nzType="vertical"></nz-divider>
210
+ </ng-container>
211
+ </ng-container>
212
+ `,
213
+ preserveWhitespaces: false,
214
+ changeDetection: ChangeDetectionStrategy.OnPush,
215
+ encapsulation: ViewEncapsulation.None
216
+ },] }
217
+ ];
218
+ STTdComponent.ctorParameters = () => [
219
+ { type: STComponent, decorators: [{ type: Host }] },
220
+ { type: Router },
221
+ { type: ModalHelper },
222
+ { type: DrawerHelper }
223
+ ];
224
+ STTdComponent.propDecorators = {
225
+ c: [{ type: Input }],
226
+ cIdx: [{ type: Input }],
227
+ data: [{ type: Input }],
228
+ i: [{ type: Input }],
229
+ index: [{ type: Input }],
230
+ n: [{ type: Output }]
231
+ };
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-td.component.js","sourceRoot":"","sources":["../../../../../packages/abc/st/st-td.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Host,\n  Input,\n  Output,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Router } from '@angular/router';\nimport { filter } from 'rxjs/operators';\n\nimport { DrawerHelper, ModalHelper } from '@delon/theme';\nimport { deepMergeKey } from '@delon/util/other';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { STComponent } from '.';\nimport { STColumnButton, STData } from './st.interfaces';\nimport { _STColumn, _STTdNotify, _STTdNotifyType } from './st.types';\n\n@Component({\n  selector: 'st-td',\n  template: `\n    <ng-template #btnTpl let-i>\n      <ng-container *ngIf=\"!i.tooltip\">\n        <ng-template [ngTemplateOutlet]=\"btnItemTpl\" [ngTemplateOutletContext]=\"{ $implicit: i }\"></ng-template>\n      </ng-container>\n      <span *ngIf=\"i.tooltip\" nz-tooltip [nzTooltipTitle]=\"i.tooltip\">\n        <ng-template [ngTemplateOutlet]=\"btnItemTpl\" [ngTemplateOutletContext]=\"{ $implicit: i }\"></ng-template>\n      </span>\n    </ng-template>\n    <ng-template #btnItemTpl let-i>\n      <a\n        *ngIf=\"i.pop\"\n        nz-popconfirm\n        [nzPopconfirmTitle]=\"i.pop.title\"\n        [nzIcon]=\"i.pop.icon\"\n        [nzCondition]=\"i.pop.condition(i)\"\n        [nzCancelText]=\"i.pop.cancelText\"\n        [nzOkText]=\"i.pop.okText\"\n        [nzOkType]=\"i.pop.okType\"\n        (nzOnConfirm)=\"_btn(i)\"\n        class=\"st__btn-text\"\n        [ngClass]=\"i.className\"\n        (click)=\"_stopPropagation($event)\"\n      >\n        <ng-template [ngTemplateOutlet]=\"btnTextTpl\" [ngTemplateOutletContext]=\"{ $implicit: i }\"></ng-template>\n      </a>\n      <a *ngIf=\"!i.pop\" (click)=\"_btn(i, $event)\" class=\"st__btn-text\" [ngClass]=\"i.className\">\n        <ng-template [ngTemplateOutlet]=\"btnTextTpl\" [ngTemplateOutletContext]=\"{ $implicit: i }\"></ng-template>\n      </a>\n    </ng-template>\n    <ng-template #btnTextTpl let-i>\n      <ng-container *ngIf=\"i.icon\">\n        <i\n          *ngIf=\"!i.icon.iconfont\"\n          nz-icon\n          [nzType]=\"i.icon.type\"\n          [nzTheme]=\"i.icon.theme\"\n          [nzSpin]=\"i.icon.spin\"\n          [nzTwotoneColor]=\"i.icon.twoToneColor\"\n        ></i>\n        <i *ngIf=\"i.icon.iconfont\" nz-icon [nzIconfont]=\"i.icon.iconfont\"></i>\n      </ng-container>\n      <span [innerHTML]=\"i._text\" [ngClass]=\"{ 'pl-xs': i.icon }\"></span>\n    </ng-template>\n    <ng-template\n      #render\n      [ngTemplateOutlet]=\"c.__render!\"\n      [ngTemplateOutletContext]=\"{ $implicit: i, index: index, column: c }\"\n    ></ng-template>\n    <ng-container *ngIf=\"!c.__render; else render\">\n      <ng-container [ngSwitch]=\"c.type\">\n        <label\n          *ngSwitchCase=\"'checkbox'\"\n          nz-checkbox\n          [nzDisabled]=\"i.disabled\"\n          [ngModel]=\"i.checked\"\n          (ngModelChange)=\"_checkbox($event)\"\n        ></label>\n        <label\n          *ngSwitchCase=\"'radio'\"\n          nz-radio\n          [nzDisabled]=\"i.disabled\"\n          [ngModel]=\"i.checked\"\n          (ngModelChange)=\"_radio($event)\"\n        ></label>\n        <a\n          *ngSwitchCase=\"'link'\"\n          (click)=\"_link($event)\"\n          [innerHTML]=\"i._values[cIdx]._text\"\n          [attr.title]=\"i._values[cIdx].text\"\n        ></a>\n        <ng-container *ngIf=\"i._values[cIdx].text\">\n          <nz-tag *ngSwitchCase=\"'tag'\" [nzColor]=\"i._values[cIdx].color\">\n            <span [innerHTML]=\"i._values[cIdx]._text\"></span>\n          </nz-tag>\n          <nz-badge\n            *ngSwitchCase=\"'badge'\"\n            [nzStatus]=\"i._values[cIdx].color\"\n            [nzText]=\"i._values[cIdx].text\"\n          ></nz-badge>\n        </ng-container>\n        <ng-template *ngSwitchCase=\"'widget'\" st-widget-host [record]=\"i\" [column]=\"c\"></ng-template\n        ><ng-container *ngSwitchDefault>\n          <span\n            *ngIf=\"c.safeType !== 'text'\"\n            [innerHTML]=\"i._values[cIdx]._text\"\n            [attr.title]=\"c._isTruncate ? i._values[cIdx].text : null\"\n          ></span>\n          <span\n            *ngIf=\"c.safeType === 'text'\"\n            [innerText]=\"i._values[cIdx]._text\"\n            [attr.title]=\"c._isTruncate ? i._values[cIdx].text : null\"\n          ></span>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngFor=\"let btn of i._values[cIdx].buttons; let last = last\">\n        <a *ngIf=\"btn.children!.length > 0\" nz-dropdown [nzDropdownMenu]=\"btnMenu\" nzOverlayClassName=\"st__btn-sub\">\n          <span [innerHTML]=\"btn._text\"></span>\n          <i nz-icon nzType=\"down\"></i>\n        </a>\n        <nz-dropdown-menu #btnMenu=\"nzDropdownMenu\">\n          <ul nz-menu>\n            <ng-container *ngFor=\"let subBtn of btn.children!\">\n              <li *ngIf=\"subBtn.type !== 'divider'\" nz-menu-item [class.st__btn-disabled]=\"subBtn._disabled\">\n                <ng-template [ngTemplateOutlet]=\"btnTpl\" [ngTemplateOutletContext]=\"{ $implicit: subBtn }\">\n                </ng-template>\n              </li>\n              <li *ngIf=\"subBtn.type === 'divider'\" nz-menu-divider></li>\n            </ng-container>\n          </ul>\n        </nz-dropdown-menu>\n        <span *ngIf=\"btn.children!.length === 0\" [class.st__btn-disabled]=\"btn._disabled\">\n          <ng-template [ngTemplateOutlet]=\"btnTpl\" [ngTemplateOutletContext]=\"{ $implicit: btn }\"> </ng-template>\n        </span>\n        <nz-divider *ngIf=\"!last\" nzType=\"vertical\"></nz-divider>\n      </ng-container>\n    </ng-container>\n  `,\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class STTdComponent {\n  @Input() c: _STColumn;\n  @Input() cIdx: number;\n  @Input() data: STData[];\n  @Input() i: STData;\n  @Input() index: number;\n  @Output() readonly n = new EventEmitter<_STTdNotify>();\n\n  private get routerState(): { pi: number; ps: number; total: number } {\n    const { pi, ps, total } = this.stComp;\n    return { pi, ps, total };\n  }\n\n  constructor(\n    @Host() private stComp: STComponent,\n    private router: Router,\n    private modalHelper: ModalHelper,\n    private drawerHelper: DrawerHelper\n  ) {}\n\n  private report(type: _STTdNotifyType): void {\n    this.n.emit({ type, item: this.i, col: this.c });\n  }\n\n  _checkbox(value: boolean): void {\n    this.i.checked = value;\n    this.report('checkbox');\n  }\n\n  _radio(checked: boolean): void {\n    this.data.filter(w => !w.disabled).forEach(i => (i.checked = false));\n    this.i.checked = checked;\n    this.report('radio');\n  }\n\n  _link(e: Event): boolean {\n    this._stopPropagation(e);\n    const res = this.c.click!(this.i, this.stComp);\n    if (typeof res === 'string') {\n      this.router.navigateByUrl(res, { state: this.routerState });\n    }\n    return false;\n  }\n\n  _stopPropagation(ev: Event): void {\n    ev.preventDefault();\n    ev.stopPropagation();\n  }\n\n  _btn(btn: STColumnButton, ev?: Event): void {\n    if (ev) {\n      ev.stopPropagation();\n    }\n    const record = this.i;\n    if (btn.type === 'modal' || btn.type === 'static') {\n      const { modal } = btn;\n      const obj = { [modal!.paramsName!]: record };\n      (this.modalHelper[btn.type === 'modal' ? 'create' : 'createStatic'] as NzSafeAny)(\n        modal!.component,\n        { ...obj, ...(modal!.params && modal!.params!(record)) },\n        deepMergeKey({}, true, this.stComp['cog'].modal, modal)\n      )\n        .pipe(filter(w => typeof w !== 'undefined'))\n        .subscribe((res: NzSafeAny) => this.btnCallback(record, btn, res));\n      return;\n    } else if (btn.type === 'drawer') {\n      const { drawer } = btn;\n      const obj = { [drawer!.paramsName!]: record };\n      this.drawerHelper\n        .create(\n          drawer!.title!,\n          drawer!.component,\n          { ...obj, ...(drawer!.params && drawer!.params!(record)) },\n          deepMergeKey({}, true, this.stComp['cog'].drawer, drawer)\n        )\n        .pipe(filter(w => typeof w !== 'undefined'))\n        .subscribe(res => this.btnCallback(record, btn, res));\n      return;\n    } else if (btn.type === 'link') {\n      const clickRes = this.btnCallback(record, btn);\n      if (typeof clickRes === 'string') {\n        this.router.navigateByUrl(clickRes, { state: this.routerState });\n      }\n      return;\n    }\n    this.btnCallback(record, btn);\n  }\n\n  private btnCallback(record: STData, btn: STColumnButton, modal?: NzSafeAny): NzSafeAny {\n    if (!btn.click) return;\n    if (typeof btn.click === 'string') {\n      switch (btn.click) {\n        case 'load':\n          this.stComp.load();\n          break;\n        case 'reload':\n          this.stComp.reload();\n          break;\n      }\n    } else {\n      return btn.click(record, modal, this.stComp);\n    }\n  }\n}\n"]}