@delon/abc 12.2.1 → 12.4.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.
- package/bundles/abc.umd.js +3 -3
- package/bundles/autoFocus.umd.js +4 -4
- package/bundles/avatarList.umd.js +4 -4
- package/bundles/count-down.umd.js +4 -4
- package/bundles/datePicker.umd.js +5 -5
- package/bundles/downFile.umd.js +4 -4
- package/bundles/edit.umd.js +4 -4
- package/bundles/ellipsis.umd.js +4 -4
- package/bundles/errorCollect.umd.js +4 -4
- package/bundles/exception.umd.js +12 -9
- package/bundles/exception.umd.js.map +1 -1
- package/bundles/footerToolbar.umd.js +4 -4
- package/bundles/fullContent.umd.js +6 -8
- package/bundles/fullContent.umd.js.map +1 -1
- package/bundles/globalFooter.umd.js +4 -4
- package/bundles/grid.umd.js +3 -3
- package/bundles/image.umd.js +3 -3
- package/bundles/let.umd.js +4 -4
- package/bundles/loading.umd.js +6 -8
- package/bundles/loading.umd.js.map +1 -1
- package/bundles/lodop.umd.js +5 -7
- package/bundles/lodop.umd.js.map +1 -1
- package/bundles/media.umd.js +5 -7
- package/bundles/media.umd.js.map +1 -1
- package/bundles/noticeIcon.umd.js +4 -4
- package/bundles/onboarding.umd.js +6 -8
- package/bundles/onboarding.umd.js.map +1 -1
- package/bundles/pageHeader.umd.js +4 -4
- package/bundles/pdf.umd.js +4 -4
- package/bundles/qr.umd.js +3 -3
- package/bundles/quickMenu.umd.js +4 -4
- package/bundles/result.umd.js +4 -4
- package/bundles/reuseTab.umd.js +15 -26
- package/bundles/reuseTab.umd.js.map +1 -1
- package/bundles/table.umd.js +251 -147
- package/bundles/table.umd.js.map +1 -1
- package/bundles/tagSelect.umd.js +4 -4
- package/bundles/view.umd.js +4 -4
- package/bundles/xlsx.umd.js +30 -37
- package/bundles/xlsx.umd.js.map +1 -1
- package/bundles/zip.umd.js +5 -7
- package/bundles/zip.umd.js.map +1 -1
- package/esm2015/exception/exception.component.js +7 -4
- package/esm2015/exception/exception.module.js +3 -2
- package/esm2015/lodop/lodop.service.js +1 -1
- package/esm2015/reuse-tab/reuse-tab-context-menu.component.js +2 -2
- package/esm2015/reuse-tab/reuse-tab-context.service.js +4 -13
- package/esm2015/reuse-tab/reuse-tab.component.js +7 -7
- package/esm2015/st/index.js +2 -0
- package/esm2015/st/st-column-source.js +28 -7
- package/esm2015/st/st-data-source.js +4 -4
- package/esm2015/st/st-export.js +9 -3
- package/esm2015/st/st-filter.component.js +149 -0
- package/esm2015/st/st-td.component.js +232 -0
- package/esm2015/st/st.component.js +28 -118
- package/esm2015/st/st.config.js +1 -2
- package/esm2015/st/st.interfaces.js +1 -1
- package/esm2015/st/st.module.js +9 -3
- package/esm2015/st/st.types.js +1 -1
- package/esm2015/st/table.js +3 -1
- package/esm2015/xlsx/xlsx.service.js +23 -29
- package/esm2015/xlsx/xlsx.types.js +1 -1
- package/esm2015/zip/zip.service.js +1 -1
- package/exception/exception.component.d.ts +3 -2
- package/exception/exception.metadata.json +1 -1
- package/fesm2015/exception.js +8 -4
- package/fesm2015/exception.js.map +1 -1
- package/fesm2015/lodop.js.map +1 -1
- package/fesm2015/reuseTab.js +10 -19
- package/fesm2015/reuseTab.js.map +1 -1
- package/fesm2015/table.js +447 -132
- package/fesm2015/table.js.map +1 -1
- package/fesm2015/xlsx.js +22 -28
- package/fesm2015/xlsx.js.map +1 -1
- package/fesm2015/zip.js.map +1 -1
- package/package.json +4 -4
- package/reuse-tab/reuse-tab.component.d.ts +1 -1
- package/reuse-tab/reuseTab.metadata.json +1 -1
- package/st/index.d.ts +1 -0
- package/st/st-filter.component.d.ts +18 -0
- package/st/st-td.component.d.ts +27 -0
- package/st/st.component.d.ts +8 -23
- package/st/st.interfaces.d.ts +57 -3
- package/st/st.types.d.ts +6 -0
- package/st/style/index.less +28 -12
- package/st/table.d.ts +2 -0
- package/st/table.metadata.json +1 -1
- package/sv/style/index.less +1 -0
- package/theme-default.less +3 -0
- package/xlsx/xlsx.metadata.json +1 -1
- 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"]}
|