bbj-screen-widget 2.4.44 → 2.4.45
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/bbj-screen-widget.metadata.json +1 -1
- package/bundles/bbj-screen-widget.umd.js +78 -24
- package/bundles/bbj-screen-widget.umd.js.map +1 -1
- package/bundles/bbj-screen-widget.umd.min.js +1 -1
- package/bundles/bbj-screen-widget.umd.min.js.map +1 -1
- package/esm2015/lib/tree-control/tree-control.component.js +80 -26
- package/fesm2015/bbj-screen-widget.js +77 -24
- package/fesm2015/bbj-screen-widget.js.map +1 -1
- package/lib/tree-control/tree-control.component.d.ts +6 -3
- package/package.json +1 -1
- package/src/assets/js/BMapGL/mapvgl.min.js +914 -898
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { __decorate, __metadata, __param } from "tslib";
|
|
2
2
|
import { Component, EventEmitter, ElementRef, ViewChild } from '@angular/core';
|
|
3
|
-
import { Data, Property, Widget, DataOutput, Event, EventParam, Method, Param } from 'bbj-widget-base';
|
|
3
|
+
import { Data, Property, Widget, DataOutput, Event, EventParam, Method, Param, DataInput } from 'bbj-widget-base';
|
|
4
|
+
import { NzTreeComponent } from 'ng-zorro-antd/tree';
|
|
4
5
|
import { ArrayService } from '@delon/util';
|
|
5
6
|
import { getFontStyle } from '../shared/util/style.util';
|
|
6
7
|
let TreeControlComponent = class TreeControlComponent {
|
|
@@ -22,6 +23,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
22
23
|
left: 0,
|
|
23
24
|
};
|
|
24
25
|
this.checkable = false;
|
|
26
|
+
this.outputType = 'array';
|
|
25
27
|
this.checkStrictly = false;
|
|
26
28
|
this.showLine = false;
|
|
27
29
|
this.expandAll = false;
|
|
@@ -51,6 +53,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
51
53
|
this.keyChange = new EventEmitter();
|
|
52
54
|
this.nodes = [];
|
|
53
55
|
this.selectedKeys = [];
|
|
56
|
+
// checkedKeys: string[] = [];
|
|
54
57
|
this.style = {};
|
|
55
58
|
}
|
|
56
59
|
ngOnInit() {
|
|
@@ -77,7 +80,14 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
77
80
|
if (data) {
|
|
78
81
|
data.forEach(({ title, key, parentKey, parentKey_value, icon, count }) => {
|
|
79
82
|
if (key) {
|
|
80
|
-
const node = {
|
|
83
|
+
const node = {
|
|
84
|
+
key,
|
|
85
|
+
title,
|
|
86
|
+
parentKey: parentKey_value || parentKey,
|
|
87
|
+
icon,
|
|
88
|
+
isLeaf: true,
|
|
89
|
+
count,
|
|
90
|
+
};
|
|
81
91
|
if (this.selectedKeys.includes(key)) {
|
|
82
92
|
node.selected = true;
|
|
83
93
|
}
|
|
@@ -133,7 +143,12 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
133
143
|
this.waittingSelect = null;
|
|
134
144
|
this.selectedKeys = keys;
|
|
135
145
|
if (this.checkable) {
|
|
136
|
-
this.
|
|
146
|
+
if (this.outputType === 'string') {
|
|
147
|
+
this.keyChange.emit(keys === null || keys === void 0 ? void 0 : keys.join(';'));
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
this.keyChange.emit(keys);
|
|
151
|
+
}
|
|
137
152
|
}
|
|
138
153
|
else {
|
|
139
154
|
this.keyChange.emit(keys[0]);
|
|
@@ -164,17 +179,37 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
164
179
|
}
|
|
165
180
|
select(id) {
|
|
166
181
|
let find = false;
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
if (
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
182
|
+
const keys = [];
|
|
183
|
+
if (id) {
|
|
184
|
+
if (this.checkable) {
|
|
185
|
+
if (typeof id === 'string') {
|
|
186
|
+
id = id.split(';');
|
|
187
|
+
}
|
|
188
|
+
keys.push(...id);
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
keys.push(id);
|
|
173
192
|
}
|
|
174
193
|
}
|
|
175
|
-
|
|
176
|
-
if (
|
|
177
|
-
this.
|
|
194
|
+
this.selectedKeys = keys;
|
|
195
|
+
if (keys.length) {
|
|
196
|
+
if (this.nodes) {
|
|
197
|
+
const nodes = [];
|
|
198
|
+
this.arrayService.visitTree(this.nodes, (n) => {
|
|
199
|
+
if (keys.includes(n.key)) {
|
|
200
|
+
nodes.push(n);
|
|
201
|
+
}
|
|
202
|
+
});
|
|
203
|
+
if (nodes.length) {
|
|
204
|
+
this.onKeysChange(keys);
|
|
205
|
+
nodes.forEach((node) => this.nodeClick(node.key, node.title));
|
|
206
|
+
find = true;
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
// 数据有可能还没加载,等数据加载了再选中
|
|
210
|
+
if (!find) {
|
|
211
|
+
this.waittingSelect = id;
|
|
212
|
+
}
|
|
178
213
|
}
|
|
179
214
|
}
|
|
180
215
|
nodeClick(id, title) { }
|
|
@@ -183,7 +218,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
183
218
|
TreeControlComponent.decorators = [
|
|
184
219
|
{ type: Component, args: [{
|
|
185
220
|
selector: 'sc-tree-control',
|
|
186
|
-
template: "<div *ngIf=\"showSearch\" class=\"searchBox\">\n <input\n class=\"search-input\"\n type=\"text\"\n nz-input\n [(ngModel)]=\"searchValue\"\n [placeholder]=\"searchPlaceholder\"\n [style]=\"{ 'border-color': searchBorderColor, background: searchBackgroundColor }\"\n />\n <i nz-icon nzType=\"search\"></i>\n</div>\n\n<div class=\"warp-tree\">\n <nz-tree\n [ngClass]=\"{ 'ant-tree-nodeBgCustom': nodeBackground }\"\n [ngStyle]=\"style\"\n [nzData]=\"nodes\"\n [nzCheckable]=\"checkable\"\n [nzExpandAll]=\"expandAll\"\n [nzShowLine]=\"showLine\"\n [nzExpandedKeys]=\"expandedKeys\"\n [nzCheckStrictly]=\"checkStrictly\"\n [nzExpandedIcon]=\"nodeDefaultIcon ? multiExpandedIconTpl : null\"\n [nzTreeTemplate]=\"nzTreeTemplate\"\n [nzSearchValue]=\"searchValue\"\n [nzHideUnMatched]=\"true\"\n [nzSelectedKeys]=\"selectedKeys\"\n (nzClick)=\"onClick($event)\"\n (nzDblClick)=\"onNodeDblclick($event)\"\n (nzCheckBoxChange)=\"onCheckBoxChange($event)\"\n >\n </nz-tree>\n <ng-template #multiExpandedIconTpl let-node let-origin=\"origin\">\n <img [src]=\"nodeDefaultIcon\" [class]=\"node.isExpanded ? 'nodeImg-open' : ''\" />\n </ng-template>\n\n <ng-template #nzTreeTemplate let-node let-origin=\"origin\">\n <div\n class=\"custom-node\"\n [style.color]=\"node.isSelected ? nodeCheckedColor : ''\"\n [style.backgroundImage]=\"\n node.isSelected ? 'url(' + nodeCheckedBackground + ')' : nodeBackground ? 'url(' + nodeBackground + ')' : ''\n \"\n [style.padding]=\"\n (grid?.top || 0) + 'px ' + (grid?.right || 0) + 'px ' + (grid?.bottom || 0) + 'px ' + (grid?.left || 0) + 'px'\n \"\n >\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n (click)=\"showNode(node)\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n\n <span class=\"node-count\" [class.noCount]=\"origin.count === '0'\" *ngIf=\"origin.count || origin.count === '0'\"\n >({{ origin.count }})</span\n >\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n\n <!-- \n\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n /> -->\n </div>\n </ng-template>\n</div>\n",
|
|
221
|
+
template: "<div *ngIf=\"showSearch\" class=\"searchBox\">\n <input\n class=\"search-input\"\n type=\"text\"\n nz-input\n [(ngModel)]=\"searchValue\"\n [placeholder]=\"searchPlaceholder\"\n [style]=\"{ 'border-color': searchBorderColor, background: searchBackgroundColor }\"\n />\n <i nz-icon nzType=\"search\"></i>\n</div>\n\n<div class=\"warp-tree\">\n <nz-tree\n #tree\n [ngClass]=\"{ 'ant-tree-nodeBgCustom': nodeBackground }\"\n [ngStyle]=\"style\"\n [nzData]=\"nodes\"\n [nzCheckable]=\"checkable\"\n [nzMultiple]=\"checkable\"\n [nzExpandAll]=\"expandAll\"\n [nzShowLine]=\"showLine\"\n [nzExpandedKeys]=\"expandedKeys\"\n [nzCheckStrictly]=\"checkStrictly\"\n [nzExpandedIcon]=\"nodeDefaultIcon ? multiExpandedIconTpl : null\"\n [nzTreeTemplate]=\"nzTreeTemplate\"\n [nzSearchValue]=\"searchValue\"\n [nzHideUnMatched]=\"true\"\n [nzSelectedKeys]=\"selectedKeys\"\n [nzCheckedKeys]=\"selectedKeys\"\n (nzClick)=\"onClick($event)\"\n (nzDblClick)=\"onNodeDblclick($event)\"\n (nzCheckBoxChange)=\"onCheckBoxChange($event)\"\n >\n </nz-tree>\n <ng-template #multiExpandedIconTpl let-node let-origin=\"origin\">\n <img [src]=\"nodeDefaultIcon\" [class]=\"node.isExpanded ? 'nodeImg-open' : ''\" />\n </ng-template>\n\n <ng-template #nzTreeTemplate let-node let-origin=\"origin\">\n <div\n class=\"custom-node\"\n [style.color]=\"node.isSelected ? nodeCheckedColor : ''\"\n [style.backgroundImage]=\"\n node.isSelected ? 'url(' + nodeCheckedBackground + ')' : nodeBackground ? 'url(' + nodeBackground + ')' : ''\n \"\n [style.padding]=\"\n (grid?.top || 0) + 'px ' + (grid?.right || 0) + 'px ' + (grid?.bottom || 0) + 'px ' + (grid?.left || 0) + 'px'\n \"\n >\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n (click)=\"showNode(node)\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n\n <span class=\"node-count\" [class.noCount]=\"origin.count === '0'\" *ngIf=\"origin.count || origin.count === '0'\"\n >({{ origin.count }})</span\n >\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n\n <!-- \n\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n /> -->\n </div>\n </ng-template>\n</div>\n",
|
|
187
222
|
styles: [":host{display:block;height:100%;width:100%;overflow:hidden;display:flex;flex-direction:column}.ant-tree,.ant-tree ::ng-deep .ant-tree-checkbox-inner,.ant-tree ::ng-deep .ant-tree-switcher{background:initial}.ant-tree ::ng-deep .ant-tree-switcher-icon{font-size:inherit}.ant-tree ::ng-deep .ant-tree-checkbox{color:inherit}.ant-tree ::ng-deep .ant-tree-checkbox-checked .ant-tree-checkbox-inner:after{border-color:#1890ff}.ant-tree ::ng-deep .ant-tree-switcher-noop>i{display:none}.ant-tree ::ng-deep .ant-tree-node-content-wrapper.ant-tree-node-selected,.ant-tree ::ng-deep .ant-tree-node-content-wrapper:hover{background-color:var(--selected-background)}::ng-deep .ant-tree.ant-tree-nodeBgCustom .ant-tree-node-content-wrapper{flex:1}::ng-deep .ant-tree.ant-tree-nodeBgCustom nz-tree-node-switcher{width:16px}.custom-node{display:flex;align-items:center;white-space:nowrap;background-repeat:no-repeat;background-size:180px 8px;background-position:0 bottom}.searchBox{position:relative;margin-bottom:20px}.searchBox .search-input{line-height:32px;height:32px;color:#7a8799;outline:none;box-shadow:none}.searchBox i.anticon{width:16px;height:16px;color:#8f9ab3;position:absolute;top:10px;right:10px}.warp-tree{flex:1;overflow:auto}.warp-tree::-webkit-scrollbar-thumb{background-color:var(--treeScrollbar-thumb-background,\"#ddd\")!important}.warp-tree::-webkit-scrollbar-corner{background-color:transparent}.folder-name{flex:1}.node-count{color:hsla(0,0%,100%,.8)}.node-count.noCount{color:#7a8799}"]
|
|
188
223
|
},] }
|
|
189
224
|
];
|
|
@@ -192,6 +227,7 @@ TreeControlComponent.ctorParameters = () => [
|
|
|
192
227
|
{ type: ElementRef }
|
|
193
228
|
];
|
|
194
229
|
TreeControlComponent.propDecorators = {
|
|
230
|
+
tree: [{ type: ViewChild, args: ['tree',] }],
|
|
195
231
|
renameInput: [{ type: ViewChild, args: ['renameInput',] }]
|
|
196
232
|
};
|
|
197
233
|
__decorate([
|
|
@@ -206,6 +242,20 @@ __decorate([
|
|
|
206
242
|
Property('复选框', { type: 'boolean' }),
|
|
207
243
|
__metadata("design:type", Object)
|
|
208
244
|
], TreeControlComponent.prototype, "checkable", void 0);
|
|
245
|
+
__decorate([
|
|
246
|
+
Property('输出格式', {
|
|
247
|
+
type: 'string',
|
|
248
|
+
enum: [
|
|
249
|
+
{ label: '数组', value: 'array' },
|
|
250
|
+
{ label: '字符串', value: 'string' },
|
|
251
|
+
],
|
|
252
|
+
ui: {
|
|
253
|
+
widget: 'select',
|
|
254
|
+
visibleIf: { checkable: [true] },
|
|
255
|
+
},
|
|
256
|
+
}),
|
|
257
|
+
__metadata("design:type", Object)
|
|
258
|
+
], TreeControlComponent.prototype, "outputType", void 0);
|
|
209
259
|
__decorate([
|
|
210
260
|
Property('选择完全受控', {
|
|
211
261
|
type: 'boolean',
|
|
@@ -251,7 +301,7 @@ __decorate([
|
|
|
251
301
|
type: 'string',
|
|
252
302
|
ui: {
|
|
253
303
|
widget: 'myUpload',
|
|
254
|
-
}
|
|
304
|
+
},
|
|
255
305
|
}),
|
|
256
306
|
__metadata("design:type", Object)
|
|
257
307
|
], TreeControlComponent.prototype, "nodeDefaultIcon", void 0);
|
|
@@ -260,7 +310,7 @@ __decorate([
|
|
|
260
310
|
type: 'string',
|
|
261
311
|
ui: {
|
|
262
312
|
widget: 'myUpload',
|
|
263
|
-
}
|
|
313
|
+
},
|
|
264
314
|
}),
|
|
265
315
|
__metadata("design:type", Object)
|
|
266
316
|
], TreeControlComponent.prototype, "nodeBackground", void 0);
|
|
@@ -277,7 +327,7 @@ __decorate([
|
|
|
277
327
|
type: 'string',
|
|
278
328
|
ui: {
|
|
279
329
|
widget: 'myUpload',
|
|
280
|
-
}
|
|
330
|
+
},
|
|
281
331
|
}),
|
|
282
332
|
__metadata("design:type", Object)
|
|
283
333
|
], TreeControlComponent.prototype, "nodeCheckedBackground", void 0);
|
|
@@ -293,8 +343,8 @@ __decorate([
|
|
|
293
343
|
Property('搜索框颜色', {
|
|
294
344
|
ui: {
|
|
295
345
|
widget: 'myColor',
|
|
296
|
-
visibleIf: { showSearch: [true] }
|
|
297
|
-
}
|
|
346
|
+
visibleIf: { showSearch: [true] },
|
|
347
|
+
},
|
|
298
348
|
}),
|
|
299
349
|
__metadata("design:type", Object)
|
|
300
350
|
], TreeControlComponent.prototype, "searchBorderColor", void 0);
|
|
@@ -302,8 +352,8 @@ __decorate([
|
|
|
302
352
|
Property('搜索框背景色', {
|
|
303
353
|
ui: {
|
|
304
354
|
widget: 'myColor',
|
|
305
|
-
visibleIf: { showSearch: [true] }
|
|
306
|
-
}
|
|
355
|
+
visibleIf: { showSearch: [true] },
|
|
356
|
+
},
|
|
307
357
|
}),
|
|
308
358
|
__metadata("design:type", Object)
|
|
309
359
|
], TreeControlComponent.prototype, "searchBackgroundColor", void 0);
|
|
@@ -311,8 +361,8 @@ __decorate([
|
|
|
311
361
|
Property('搜索框提示语', {
|
|
312
362
|
type: 'string',
|
|
313
363
|
ui: {
|
|
314
|
-
visibleIf: { showSearch: [true] }
|
|
315
|
-
}
|
|
364
|
+
visibleIf: { showSearch: [true] },
|
|
365
|
+
},
|
|
316
366
|
}),
|
|
317
367
|
__metadata("design:type", Object)
|
|
318
368
|
], TreeControlComponent.prototype, "searchPlaceholder", void 0);
|
|
@@ -320,7 +370,7 @@ __decorate([
|
|
|
320
370
|
Property('滚动条颜色', {
|
|
321
371
|
ui: {
|
|
322
372
|
widget: 'myColor',
|
|
323
|
-
}
|
|
373
|
+
},
|
|
324
374
|
}),
|
|
325
375
|
__metadata("design:type", Object)
|
|
326
376
|
], TreeControlComponent.prototype, "treeScrollbarThumbBackground", void 0);
|
|
@@ -331,11 +381,15 @@ __decorate([
|
|
|
331
381
|
key: { type: 'string', title: 'id' },
|
|
332
382
|
parentKey: { type: 'string', title: '父级id' },
|
|
333
383
|
icon: { type: 'string', title: '图标' },
|
|
334
|
-
count: { type: 'string', title: '数量' }
|
|
384
|
+
count: { type: 'string', title: '数量' },
|
|
335
385
|
},
|
|
336
386
|
}),
|
|
337
387
|
__metadata("design:type", Object)
|
|
338
388
|
], TreeControlComponent.prototype, "data", void 0);
|
|
389
|
+
__decorate([
|
|
390
|
+
DataInput('选中值'),
|
|
391
|
+
__metadata("design:type", Object)
|
|
392
|
+
], TreeControlComponent.prototype, "value", void 0);
|
|
339
393
|
__decorate([
|
|
340
394
|
DataOutput('选中id'),
|
|
341
395
|
Event('选中值改变', { params: 'id' }),
|
|
@@ -352,7 +406,7 @@ __decorate([
|
|
|
352
406
|
Method('选中'),
|
|
353
407
|
__param(0, Param('id')),
|
|
354
408
|
__metadata("design:type", Function),
|
|
355
|
-
__metadata("design:paramtypes", [
|
|
409
|
+
__metadata("design:paramtypes", [Object]),
|
|
356
410
|
__metadata("design:returntype", void 0)
|
|
357
411
|
], TreeControlComponent.prototype, "select", null);
|
|
358
412
|
__decorate([
|
|
@@ -378,4 +432,4 @@ TreeControlComponent = __decorate([
|
|
|
378
432
|
__metadata("design:paramtypes", [ArrayService, ElementRef])
|
|
379
433
|
], TreeControlComponent);
|
|
380
434
|
export { TreeControlComponent };
|
|
381
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-control.component.js","sourceRoot":"","sources":["../../../../../projects/screen-widget/src/lib/tree-control/tree-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, SimpleChanges, OnChanges, EventEmitter, ElementRef, ViewChild } from '@angular/core';\nimport { Data, Property, Widget, DataOutput, Event, EventParam, Method, Param } from 'bbj-widget-base';\nimport { NzFormatEmitEvent, NzTreeNode, NzTreeNodeOptions } from 'ng-zorro-antd/tree';\nimport { ArrayService } from '@delon/util';\nimport { getFontStyle } from '../shared/util/style.util';\n\n@Component({\n  selector: 'sc-tree-control',\n  templateUrl: './tree-control.component.html',\n  styleUrls: ['./tree-control.component.less'],\n})\n@Widget('树控件', {\n  group: 'component',\n  image: 'assets/img/screen/Tree.png',\n  icon: 'bianzu40',\n})\nexport class TreeControlComponent implements OnInit, OnChanges {\n  @Property('字体', { ui: { widget: 'myFont' } })\n  font: any = {\n    family: '',\n    color: '#595F7A',\n    weight: 'normal',\n    size: 16,\n    space: 0,\n    lineHeight: 0,\n  };\n  @Property('边距', { ui: { widget: 'myGrid' } })\n  grid: any = {\n    top: 0,\n    right: 0,\n    bottom: 0,\n    left: 0,\n  };\n  @Property('复选框', { type: 'boolean' })\n  checkable = false;\n  @Property('选择完全受控', {\n    type: 'boolean',\n    ui: { optionalHelp: '父子节点选中状态不再关联', visibleIf: { checkable: [true] } },\n  })\n  checkStrictly = false;\n  @Property('连接线', { type: 'boolean' })\n  showLine = false;\n  @Property('展开所有', { type: 'boolean' })\n  expandAll = false;\n  @Property('展开层级', {\n    type: 'integer',\n    minimum: 0,\n    ui: { precision: 0, visibleIf: { expandAll: [false] } },\n  })\n  expandLevel = 0;\n\n  @Property('图标宽度', { type: 'integer' })\n  iconWidth = 20;\n  @Property('图标高度', { type: 'integer' })\n  iconHeight = 20;\n  @Property('图标位置', {\n    enum: [\n      { label: '左', value: 'left' },\n      { label: '右', value: 'right' },\n    ],\n  })\n  iconPosition = 'left';\n\n\n\n  @Property('节点图标', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    }\n  })\n  nodeDefaultIcon = null;\n  @Property('节点背景', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    }\n  })\n  nodeBackground = null;\n\n  @Property('节点选中背景色', { ui: { widget: 'myColor' } })\n  selectedBackground = '#bae7ff';\n\n  @Property('节点选中字体色', { ui: { widget: 'myColor' } })\n  nodeCheckedColor = '#333';\n\n  @Property('节点选中背景', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    }\n  })\n  nodeCheckedBackground = null;\n\n  @Property('双击重命名')\n  renamable: boolean;\n  @Property('显示搜索框')\n  showSearch: boolean;\n  searchValue: string;\n\n  @Property('搜索框颜色', {\n    ui: {\n      widget: 'myColor',\n      visibleIf: { showSearch: [true] }\n    }\n  })\n  searchBorderColor = '#8F9AB3';\n\n  @Property('搜索框背景色', {\n    ui: {\n      widget: 'myColor',\n      visibleIf: { showSearch: [true] }\n    }\n  })\n  searchBackgroundColor = 'rgba(0,0,0,0)';\n\n  @Property('搜索框提示语', {\n    type: 'string',\n    ui: {\n      visibleIf: { showSearch: [true] }\n    }\n  })\n  searchPlaceholder = '请输入搜索内容';\n\n  @Property('滚动条颜色', {\n    ui: {\n      widget: 'myColor',\n    }\n  })\n  treeScrollbarThumbBackground = '#ddd';\n\n\n  @Data({\n    properties: {\n      title: { type: 'string', title: '标题' },\n      key: { type: 'string', title: 'id' },\n      parentKey: { type: 'string', title: '父级id' },\n      icon: { type: 'string', title: '图标' },\n      count: { type: 'string', title: '数量' }\n    },\n  })\n  data = [\n    { title: '江苏省', key: '300', parentKey: '' },\n    { title: '浙江省', key: '100', parentKey: '' },\n    { title: '杭州市', key: '1001', parentKey: '100' },\n    { title: '顶顶区', key: '10010', parentKey: '1001' },\n    { title: '的方区', key: '10011', parentKey: '1001' },\n    { title: '温州市', key: '1002', parentKey: '100' },\n    { title: '鹿城区', key: '10020', parentKey: '1002' },\n    { title: '龙湾区', key: '10021', parentKey: '1002' },\n  ];\n\n  @DataOutput('选中id')\n  @Event('选中值改变', { params: 'id' })\n  keyChange = new EventEmitter<any>();\n\n  nodes: NzTreeNodeOptions[] = [];\n\n  expandedKeys: string[];\n\n  edittingNode: NzTreeNode; // 正在重命名的节点\n\n  @ViewChild('renameInput')\n  renameInput: ElementRef;\n\n  selectedKeys: string[] = [];\n  style = {};\n  waittingSelect: string;\n\n  paddNum: any;\n  constructor(private arrayService: ArrayService, private elementRef: ElementRef) { }\n\n  ngOnInit(): void {\n    document.body.style.setProperty('--treeScrollbar-thumb-background', this.treeScrollbarThumbBackground || '#ddd');\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.data) {\n      this.nodes = this.toTree(this.data);\n      if (this.waittingSelect) {\n        this.select(this.waittingSelect);\n      }\n    }\n    if (changes.font) {\n      this.updateStyle();\n    }\n\n    if (changes.data || changes.expandLevel || changes.expandAll) {\n      this.expand();\n    }\n  }\n\n  toTree(data: any[]) {\n    const nodeMap = {};\n    const nodes = [];\n    const root = [];\n    if (data) {\n      data.forEach(({ title, key, parentKey, parentKey_value, icon, count }) => {\n        if (key) {\n          const node: NzTreeNodeOptions = { key, title, parentKey: parentKey_value || parentKey, icon, isLeaf: true, count };\n          if (this.selectedKeys.includes(key)) {\n            node.selected = true;\n          }\n          nodeMap[key] = node;\n          nodes.push(node);\n        }\n      });\n      nodes.forEach((node) => {\n        if (node.parentKey) {\n          const parent = nodeMap[node.parentKey];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push(node);\n            parent.isLeaf = false;\n            return;\n          }\n        }\n        root.push(node);\n      });\n    }\n    return root;\n  }\n\n  expand() {\n    // TODO nz的bug，在数据改变之后nzExpandAll无效，等修复了可以切换成这里的代码\n    // if (!this.expandAll) {\n    //   this.expandedKeys = [];\n    //   if (this.expandLevel) {\n    //     this.arrayService.visitTree(this.nodes, (item, parent, deep) => {\n    //       if (deep <= this.expandLevel) {\n    //         this.expandedKeys.push(item.key);\n    //       }\n    //     });\n    //   }\n    // }\n    this.expandedKeys = [];\n    if (this.expandAll || this.expandLevel) {\n      this.arrayService.visitTree(this.nodes, (item, parent, deep) => {\n        if (this.expandAll || deep <= this.expandLevel) {\n          this.expandedKeys.push(item.key);\n        }\n      });\n    }\n  }\n\n  updateStyle() {\n    this.style = getFontStyle(this.font);\n    this.elementRef.nativeElement.style.setProperty('--selected-background', this.selectedBackground || '#bae7ff');\n  }\n\n  onClick(event: NzFormatEmitEvent) {\n    this.onKeysChange(event.keys);\n    this.nodeClick(event.node.key, event.node.title);\n  }\n\n  onKeysChange(keys: string[]) {\n    this.waittingSelect = null;\n    this.selectedKeys = keys;\n    if (this.checkable) {\n      this.keyChange.emit(keys);\n    } else {\n      this.keyChange.emit(keys[0]);\n    }\n  }\n\n  onCheckBoxChange(event: NzFormatEmitEvent) {\n    this.onKeysChange(event.keys);\n  }\n\n  onNodeDblclick(event: NzFormatEmitEvent) {\n    if (this.renamable) {\n      this.edittingNode = event.node;\n      setTimeout(() => {\n        if (this.renameInput) {\n          this.renameInput.nativeElement.focus();\n        }\n      });\n    }\n  }\n\n  renameEnd(node: NzTreeNode) {\n    this.edittingNode = null;\n    this.rename(node.key, node.title);\n  }\n\n\n  showNode(e) {\n    console.log(e);\n  }\n\n  @Method('搜索')\n  search(@Param('内容') value: string) {\n    this.searchValue = value;\n  }\n\n  @Method('选中')\n  select(@Param('id') id: string) {\n    let find = false;\n    if (this.nodes) {\n      const node = this.arrayService.findTree(this.nodes, (n) => n.key === id);\n      if (node) {\n        this.onKeysChange([id]);\n        this.nodeClick(node.key, node.title);\n        find = true;\n      }\n    }\n    // 数据有可能还没加载，等数据加载了再选中\n    if (!find) {\n      this.waittingSelect = id;\n    }\n  }\n\n  @Event('点击')\n  nodeClick(@EventParam('id') id: string, @EventParam('标题') title: string) { }\n\n  @Event('重命名')\n  rename(@EventParam('id') id: string, @EventParam('名称') name: string) { }\n}\n"]}
|
|
435
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-control.component.js","sourceRoot":"","sources":["../../../../../projects/screen-widget/src/lib/tree-control/tree-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, SimpleChanges, OnChanges, EventEmitter, ElementRef, ViewChild } from '@angular/core';\nimport { Data, Property, Widget, DataOutput, Event, EventParam, Method, Param, DataInput } from 'bbj-widget-base';\nimport { NzFormatEmitEvent, NzTreeComponent, NzTreeNode, NzTreeNodeOptions } from 'ng-zorro-antd/tree';\nimport { ArrayService } from '@delon/util';\nimport { getFontStyle } from '../shared/util/style.util';\n\n@Component({\n  selector: 'sc-tree-control',\n  templateUrl: './tree-control.component.html',\n  styleUrls: ['./tree-control.component.less'],\n})\n@Widget('树控件', {\n  group: 'component',\n  image: 'assets/img/screen/Tree.png',\n  icon: 'bianzu40',\n})\nexport class TreeControlComponent implements OnInit, OnChanges {\n  @Property('字体', { ui: { widget: 'myFont' } })\n  font: any = {\n    family: '',\n    color: '#595F7A',\n    weight: 'normal',\n    size: 16,\n    space: 0,\n    lineHeight: 0,\n  };\n  @Property('边距', { ui: { widget: 'myGrid' } })\n  grid: any = {\n    top: 0,\n    right: 0,\n    bottom: 0,\n    left: 0,\n  };\n  @Property('复选框', { type: 'boolean' })\n  checkable = false;\n  @Property('输出格式', {\n    type: 'string',\n    enum: [\n      { label: '数组', value: 'array' },\n      { label: '字符串', value: 'string' },\n    ],\n    ui: {\n      widget: 'select',\n      visibleIf: { checkable: [true] },\n    },\n  })\n  outputType = 'array';\n  @Property('选择完全受控', {\n    type: 'boolean',\n    ui: { optionalHelp: '父子节点选中状态不再关联', visibleIf: { checkable: [true] } },\n  })\n  checkStrictly = false;\n  @Property('连接线', { type: 'boolean' })\n  showLine = false;\n  @Property('展开所有', { type: 'boolean' })\n  expandAll = false;\n  @Property('展开层级', {\n    type: 'integer',\n    minimum: 0,\n    ui: { precision: 0, visibleIf: { expandAll: [false] } },\n  })\n  expandLevel = 0;\n\n  @Property('图标宽度', { type: 'integer' })\n  iconWidth = 20;\n  @Property('图标高度', { type: 'integer' })\n  iconHeight = 20;\n  @Property('图标位置', {\n    enum: [\n      { label: '左', value: 'left' },\n      { label: '右', value: 'right' },\n    ],\n  })\n  iconPosition = 'left';\n\n  @Property('节点图标', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    },\n  })\n  nodeDefaultIcon = null;\n  @Property('节点背景', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    },\n  })\n  nodeBackground = null;\n\n  @Property('节点选中背景色', { ui: { widget: 'myColor' } })\n  selectedBackground = '#bae7ff';\n\n  @Property('节点选中字体色', { ui: { widget: 'myColor' } })\n  nodeCheckedColor = '#333';\n\n  @Property('节点选中背景', {\n    type: 'string',\n    ui: {\n      widget: 'myUpload',\n    },\n  })\n  nodeCheckedBackground = null;\n\n  @Property('双击重命名')\n  renamable: boolean;\n  @Property('显示搜索框')\n  showSearch: boolean;\n  searchValue: string;\n\n  @Property('搜索框颜色', {\n    ui: {\n      widget: 'myColor',\n      visibleIf: { showSearch: [true] },\n    },\n  })\n  searchBorderColor = '#8F9AB3';\n\n  @Property('搜索框背景色', {\n    ui: {\n      widget: 'myColor',\n      visibleIf: { showSearch: [true] },\n    },\n  })\n  searchBackgroundColor = 'rgba(0,0,0,0)';\n\n  @Property('搜索框提示语', {\n    type: 'string',\n    ui: {\n      visibleIf: { showSearch: [true] },\n    },\n  })\n  searchPlaceholder = '请输入搜索内容';\n\n  @Property('滚动条颜色', {\n    ui: {\n      widget: 'myColor',\n    },\n  })\n  treeScrollbarThumbBackground = '#ddd';\n\n  @Data({\n    properties: {\n      title: { type: 'string', title: '标题' },\n      key: { type: 'string', title: 'id' },\n      parentKey: { type: 'string', title: '父级id' },\n      icon: { type: 'string', title: '图标' },\n      count: { type: 'string', title: '数量' },\n    },\n  })\n  data = [\n    { title: '江苏省', key: '300', parentKey: '' },\n    { title: '浙江省', key: '100', parentKey: '' },\n    { title: '杭州市', key: '1001', parentKey: '100' },\n    { title: '顶顶区', key: '10010', parentKey: '1001' },\n    { title: '的方区', key: '10011', parentKey: '1001' },\n    { title: '温州市', key: '1002', parentKey: '100' },\n    { title: '鹿城区', key: '10020', parentKey: '1002' },\n    { title: '龙湾区', key: '10021', parentKey: '1002' },\n  ];\n\n  @DataInput('选中值')\n  value: any;\n\n  @DataOutput('选中id')\n  @Event('选中值改变', { params: 'id' })\n  keyChange = new EventEmitter<any>();\n\n  nodes: NzTreeNodeOptions[] = [];\n\n  expandedKeys: string[];\n\n  edittingNode: NzTreeNode; // 正在重命名的节点\n\n  @ViewChild('tree')\n  tree: NzTreeComponent;\n\n  @ViewChild('renameInput')\n  renameInput: ElementRef;\n\n  selectedKeys: string[] = [];\n  // checkedKeys: string[] = [];\n  style = {};\n  waittingSelect: string | string[];\n\n  paddNum: any;\n  constructor(private arrayService: ArrayService, private elementRef: ElementRef) {}\n\n  ngOnInit(): void {\n    document.body.style.setProperty('--treeScrollbar-thumb-background', this.treeScrollbarThumbBackground || '#ddd');\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.data) {\n      this.nodes = this.toTree(this.data);\n      if (this.waittingSelect) {\n        this.select(this.waittingSelect);\n      }\n    }\n    if (changes.font) {\n      this.updateStyle();\n    }\n\n    if (changes.data || changes.expandLevel || changes.expandAll) {\n      this.expand();\n    }\n  }\n\n  toTree(data: any[]) {\n    const nodeMap = {};\n    const nodes = [];\n    const root = [];\n    if (data) {\n      data.forEach(({ title, key, parentKey, parentKey_value, icon, count }) => {\n        if (key) {\n          const node: NzTreeNodeOptions = {\n            key,\n            title,\n            parentKey: parentKey_value || parentKey,\n            icon,\n            isLeaf: true,\n            count,\n          };\n          if (this.selectedKeys.includes(key)) {\n            node.selected = true;\n          }\n          nodeMap[key] = node;\n          nodes.push(node);\n        }\n      });\n      nodes.forEach((node) => {\n        if (node.parentKey) {\n          const parent = nodeMap[node.parentKey];\n          if (parent) {\n            parent.children = parent.children || [];\n            parent.children.push(node);\n            parent.isLeaf = false;\n            return;\n          }\n        }\n        root.push(node);\n      });\n    }\n    return root;\n  }\n\n  expand() {\n    // TODO nz的bug，在数据改变之后nzExpandAll无效，等修复了可以切换成这里的代码\n    // if (!this.expandAll) {\n    //   this.expandedKeys = [];\n    //   if (this.expandLevel) {\n    //     this.arrayService.visitTree(this.nodes, (item, parent, deep) => {\n    //       if (deep <= this.expandLevel) {\n    //         this.expandedKeys.push(item.key);\n    //       }\n    //     });\n    //   }\n    // }\n    this.expandedKeys = [];\n    if (this.expandAll || this.expandLevel) {\n      this.arrayService.visitTree(this.nodes, (item, parent, deep) => {\n        if (this.expandAll || deep <= this.expandLevel) {\n          this.expandedKeys.push(item.key);\n        }\n      });\n    }\n  }\n\n  updateStyle() {\n    this.style = getFontStyle(this.font);\n    this.elementRef.nativeElement.style.setProperty('--selected-background', this.selectedBackground || '#bae7ff');\n  }\n\n  onClick(event: NzFormatEmitEvent) {\n    this.onKeysChange(event.keys);\n    this.nodeClick(event.node.key, event.node.title);\n  }\n\n  onKeysChange(keys: string[]) {\n    this.waittingSelect = null;\n    this.selectedKeys = keys;\n    if (this.checkable) {\n      if (this.outputType === 'string') {\n        this.keyChange.emit(keys?.join(';'));\n      } else {\n        this.keyChange.emit(keys);\n      }\n    } else {\n      this.keyChange.emit(keys[0]);\n    }\n  }\n\n  onCheckBoxChange(event: NzFormatEmitEvent) {\n    this.onKeysChange(event.keys);\n  }\n\n  onNodeDblclick(event: NzFormatEmitEvent) {\n    if (this.renamable) {\n      this.edittingNode = event.node;\n      setTimeout(() => {\n        if (this.renameInput) {\n          this.renameInput.nativeElement.focus();\n        }\n      });\n    }\n  }\n\n  renameEnd(node: NzTreeNode) {\n    this.edittingNode = null;\n    this.rename(node.key, node.title);\n  }\n\n  showNode(e) {\n    console.log(e);\n  }\n\n  @Method('搜索')\n  search(@Param('内容') value: string) {\n    this.searchValue = value;\n  }\n\n  @Method('选中')\n  select(@Param('id') id: string | string[]) {\n    let find = false;\n    const keys = [];\n    if (id) {\n      if (this.checkable) {\n        if (typeof id === 'string') {\n          id = id.split(';');\n        }\n        keys.push(...id);\n      } else {\n        keys.push(id);\n      }\n    }\n    this.selectedKeys = keys;\n    if (keys.length) {\n      if (this.nodes) {\n        const nodes = [];\n        this.arrayService.visitTree(this.nodes, (n) => {\n          if (keys.includes(n.key)) {\n            nodes.push(n);\n          }\n        });\n        if (nodes.length) {\n          this.onKeysChange(keys);\n          nodes.forEach((node) => this.nodeClick(node.key, node.title));\n          find = true;\n        }\n      }\n      // 数据有可能还没加载，等数据加载了再选中\n      if (!find) {\n        this.waittingSelect = id;\n      }\n    }\n  }\n\n  @Event('点击')\n  nodeClick(@EventParam('id') id: string, @EventParam('标题') title: string) {}\n\n  @Event('重命名')\n  rename(@EventParam('id') id: string, @EventParam('名称') name: string) {}\n}\n"]}
|
|
@@ -11606,6 +11606,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11606
11606
|
left: 0,
|
|
11607
11607
|
};
|
|
11608
11608
|
this.checkable = false;
|
|
11609
|
+
this.outputType = 'array';
|
|
11609
11610
|
this.checkStrictly = false;
|
|
11610
11611
|
this.showLine = false;
|
|
11611
11612
|
this.expandAll = false;
|
|
@@ -11635,6 +11636,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11635
11636
|
this.keyChange = new EventEmitter();
|
|
11636
11637
|
this.nodes = [];
|
|
11637
11638
|
this.selectedKeys = [];
|
|
11639
|
+
// checkedKeys: string[] = [];
|
|
11638
11640
|
this.style = {};
|
|
11639
11641
|
}
|
|
11640
11642
|
ngOnInit() {
|
|
@@ -11661,7 +11663,14 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11661
11663
|
if (data) {
|
|
11662
11664
|
data.forEach(({ title, key, parentKey, parentKey_value, icon, count }) => {
|
|
11663
11665
|
if (key) {
|
|
11664
|
-
const node = {
|
|
11666
|
+
const node = {
|
|
11667
|
+
key,
|
|
11668
|
+
title,
|
|
11669
|
+
parentKey: parentKey_value || parentKey,
|
|
11670
|
+
icon,
|
|
11671
|
+
isLeaf: true,
|
|
11672
|
+
count,
|
|
11673
|
+
};
|
|
11665
11674
|
if (this.selectedKeys.includes(key)) {
|
|
11666
11675
|
node.selected = true;
|
|
11667
11676
|
}
|
|
@@ -11717,7 +11726,12 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11717
11726
|
this.waittingSelect = null;
|
|
11718
11727
|
this.selectedKeys = keys;
|
|
11719
11728
|
if (this.checkable) {
|
|
11720
|
-
this.
|
|
11729
|
+
if (this.outputType === 'string') {
|
|
11730
|
+
this.keyChange.emit(keys === null || keys === void 0 ? void 0 : keys.join(';'));
|
|
11731
|
+
}
|
|
11732
|
+
else {
|
|
11733
|
+
this.keyChange.emit(keys);
|
|
11734
|
+
}
|
|
11721
11735
|
}
|
|
11722
11736
|
else {
|
|
11723
11737
|
this.keyChange.emit(keys[0]);
|
|
@@ -11748,17 +11762,37 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11748
11762
|
}
|
|
11749
11763
|
select(id) {
|
|
11750
11764
|
let find = false;
|
|
11751
|
-
|
|
11752
|
-
|
|
11753
|
-
if (
|
|
11754
|
-
|
|
11755
|
-
|
|
11756
|
-
|
|
11765
|
+
const keys = [];
|
|
11766
|
+
if (id) {
|
|
11767
|
+
if (this.checkable) {
|
|
11768
|
+
if (typeof id === 'string') {
|
|
11769
|
+
id = id.split(';');
|
|
11770
|
+
}
|
|
11771
|
+
keys.push(...id);
|
|
11772
|
+
}
|
|
11773
|
+
else {
|
|
11774
|
+
keys.push(id);
|
|
11757
11775
|
}
|
|
11758
11776
|
}
|
|
11759
|
-
|
|
11760
|
-
if (
|
|
11761
|
-
this.
|
|
11777
|
+
this.selectedKeys = keys;
|
|
11778
|
+
if (keys.length) {
|
|
11779
|
+
if (this.nodes) {
|
|
11780
|
+
const nodes = [];
|
|
11781
|
+
this.arrayService.visitTree(this.nodes, (n) => {
|
|
11782
|
+
if (keys.includes(n.key)) {
|
|
11783
|
+
nodes.push(n);
|
|
11784
|
+
}
|
|
11785
|
+
});
|
|
11786
|
+
if (nodes.length) {
|
|
11787
|
+
this.onKeysChange(keys);
|
|
11788
|
+
nodes.forEach((node) => this.nodeClick(node.key, node.title));
|
|
11789
|
+
find = true;
|
|
11790
|
+
}
|
|
11791
|
+
}
|
|
11792
|
+
// 数据有可能还没加载,等数据加载了再选中
|
|
11793
|
+
if (!find) {
|
|
11794
|
+
this.waittingSelect = id;
|
|
11795
|
+
}
|
|
11762
11796
|
}
|
|
11763
11797
|
}
|
|
11764
11798
|
nodeClick(id, title) { }
|
|
@@ -11767,7 +11801,7 @@ let TreeControlComponent = class TreeControlComponent {
|
|
|
11767
11801
|
TreeControlComponent.decorators = [
|
|
11768
11802
|
{ type: Component, args: [{
|
|
11769
11803
|
selector: 'sc-tree-control',
|
|
11770
|
-
template: "<div *ngIf=\"showSearch\" class=\"searchBox\">\n <input\n class=\"search-input\"\n type=\"text\"\n nz-input\n [(ngModel)]=\"searchValue\"\n [placeholder]=\"searchPlaceholder\"\n [style]=\"{ 'border-color': searchBorderColor, background: searchBackgroundColor }\"\n />\n <i nz-icon nzType=\"search\"></i>\n</div>\n\n<div class=\"warp-tree\">\n <nz-tree\n [ngClass]=\"{ 'ant-tree-nodeBgCustom': nodeBackground }\"\n [ngStyle]=\"style\"\n [nzData]=\"nodes\"\n [nzCheckable]=\"checkable\"\n [nzExpandAll]=\"expandAll\"\n [nzShowLine]=\"showLine\"\n [nzExpandedKeys]=\"expandedKeys\"\n [nzCheckStrictly]=\"checkStrictly\"\n [nzExpandedIcon]=\"nodeDefaultIcon ? multiExpandedIconTpl : null\"\n [nzTreeTemplate]=\"nzTreeTemplate\"\n [nzSearchValue]=\"searchValue\"\n [nzHideUnMatched]=\"true\"\n [nzSelectedKeys]=\"selectedKeys\"\n (nzClick)=\"onClick($event)\"\n (nzDblClick)=\"onNodeDblclick($event)\"\n (nzCheckBoxChange)=\"onCheckBoxChange($event)\"\n >\n </nz-tree>\n <ng-template #multiExpandedIconTpl let-node let-origin=\"origin\">\n <img [src]=\"nodeDefaultIcon\" [class]=\"node.isExpanded ? 'nodeImg-open' : ''\" />\n </ng-template>\n\n <ng-template #nzTreeTemplate let-node let-origin=\"origin\">\n <div\n class=\"custom-node\"\n [style.color]=\"node.isSelected ? nodeCheckedColor : ''\"\n [style.backgroundImage]=\"\n node.isSelected ? 'url(' + nodeCheckedBackground + ')' : nodeBackground ? 'url(' + nodeBackground + ')' : ''\n \"\n [style.padding]=\"\n (grid?.top || 0) + 'px ' + (grid?.right || 0) + 'px ' + (grid?.bottom || 0) + 'px ' + (grid?.left || 0) + 'px'\n \"\n >\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n (click)=\"showNode(node)\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n\n <span class=\"node-count\" [class.noCount]=\"origin.count === '0'\" *ngIf=\"origin.count || origin.count === '0'\"\n >({{ origin.count }})</span\n >\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n\n <!-- \n\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n /> -->\n </div>\n </ng-template>\n</div>\n",
|
|
11804
|
+
template: "<div *ngIf=\"showSearch\" class=\"searchBox\">\n <input\n class=\"search-input\"\n type=\"text\"\n nz-input\n [(ngModel)]=\"searchValue\"\n [placeholder]=\"searchPlaceholder\"\n [style]=\"{ 'border-color': searchBorderColor, background: searchBackgroundColor }\"\n />\n <i nz-icon nzType=\"search\"></i>\n</div>\n\n<div class=\"warp-tree\">\n <nz-tree\n #tree\n [ngClass]=\"{ 'ant-tree-nodeBgCustom': nodeBackground }\"\n [ngStyle]=\"style\"\n [nzData]=\"nodes\"\n [nzCheckable]=\"checkable\"\n [nzMultiple]=\"checkable\"\n [nzExpandAll]=\"expandAll\"\n [nzShowLine]=\"showLine\"\n [nzExpandedKeys]=\"expandedKeys\"\n [nzCheckStrictly]=\"checkStrictly\"\n [nzExpandedIcon]=\"nodeDefaultIcon ? multiExpandedIconTpl : null\"\n [nzTreeTemplate]=\"nzTreeTemplate\"\n [nzSearchValue]=\"searchValue\"\n [nzHideUnMatched]=\"true\"\n [nzSelectedKeys]=\"selectedKeys\"\n [nzCheckedKeys]=\"selectedKeys\"\n (nzClick)=\"onClick($event)\"\n (nzDblClick)=\"onNodeDblclick($event)\"\n (nzCheckBoxChange)=\"onCheckBoxChange($event)\"\n >\n </nz-tree>\n <ng-template #multiExpandedIconTpl let-node let-origin=\"origin\">\n <img [src]=\"nodeDefaultIcon\" [class]=\"node.isExpanded ? 'nodeImg-open' : ''\" />\n </ng-template>\n\n <ng-template #nzTreeTemplate let-node let-origin=\"origin\">\n <div\n class=\"custom-node\"\n [style.color]=\"node.isSelected ? nodeCheckedColor : ''\"\n [style.backgroundImage]=\"\n node.isSelected ? 'url(' + nodeCheckedBackground + ')' : nodeBackground ? 'url(' + nodeBackground + ')' : ''\n \"\n [style.padding]=\"\n (grid?.top || 0) + 'px ' + (grid?.right || 0) + 'px ' + (grid?.bottom || 0) + 'px ' + (grid?.left || 0) + 'px'\n \"\n >\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n (click)=\"showNode(node)\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n\n <span class=\"node-count\" [class.noCount]=\"origin.count === '0'\" *ngIf=\"origin.count || origin.count === '0'\"\n >({{ origin.count }})</span\n >\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n\n <!-- \n\n <img\n *ngIf=\"origin.icon && iconPosition !== 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n />\n <span\n *ngIf=\"edittingNode !== node\"\n class=\"folder-name\"\n [innerHTML]=\"node.title | nzHighlight: searchValue:'i':'font-highlight'\"\n ></span>\n <input *ngIf=\"edittingNode === node\" #renameInput nz-input [(ngModel)]=\"node.title\" (blur)=\"renameEnd(node)\" />\n <img\n *ngIf=\"origin.icon && iconPosition === 'right'\"\n [src]=\"origin.icon\"\n [style.width.px]=\"iconWidth\"\n [style.height.px]=\"iconHeight\"\n /> -->\n </div>\n </ng-template>\n</div>\n",
|
|
11771
11805
|
styles: [":host{display:block;height:100%;width:100%;overflow:hidden;display:flex;flex-direction:column}.ant-tree,.ant-tree ::ng-deep .ant-tree-checkbox-inner,.ant-tree ::ng-deep .ant-tree-switcher{background:initial}.ant-tree ::ng-deep .ant-tree-switcher-icon{font-size:inherit}.ant-tree ::ng-deep .ant-tree-checkbox{color:inherit}.ant-tree ::ng-deep .ant-tree-checkbox-checked .ant-tree-checkbox-inner:after{border-color:#1890ff}.ant-tree ::ng-deep .ant-tree-switcher-noop>i{display:none}.ant-tree ::ng-deep .ant-tree-node-content-wrapper.ant-tree-node-selected,.ant-tree ::ng-deep .ant-tree-node-content-wrapper:hover{background-color:var(--selected-background)}::ng-deep .ant-tree.ant-tree-nodeBgCustom .ant-tree-node-content-wrapper{flex:1}::ng-deep .ant-tree.ant-tree-nodeBgCustom nz-tree-node-switcher{width:16px}.custom-node{display:flex;align-items:center;white-space:nowrap;background-repeat:no-repeat;background-size:180px 8px;background-position:0 bottom}.searchBox{position:relative;margin-bottom:20px}.searchBox .search-input{line-height:32px;height:32px;color:#7a8799;outline:none;box-shadow:none}.searchBox i.anticon{width:16px;height:16px;color:#8f9ab3;position:absolute;top:10px;right:10px}.warp-tree{flex:1;overflow:auto}.warp-tree::-webkit-scrollbar-thumb{background-color:var(--treeScrollbar-thumb-background,\"#ddd\")!important}.warp-tree::-webkit-scrollbar-corner{background-color:transparent}.folder-name{flex:1}.node-count{color:hsla(0,0%,100%,.8)}.node-count.noCount{color:#7a8799}"]
|
|
11772
11806
|
},] }
|
|
11773
11807
|
];
|
|
@@ -11776,6 +11810,7 @@ TreeControlComponent.ctorParameters = () => [
|
|
|
11776
11810
|
{ type: ElementRef }
|
|
11777
11811
|
];
|
|
11778
11812
|
TreeControlComponent.propDecorators = {
|
|
11813
|
+
tree: [{ type: ViewChild, args: ['tree',] }],
|
|
11779
11814
|
renameInput: [{ type: ViewChild, args: ['renameInput',] }]
|
|
11780
11815
|
};
|
|
11781
11816
|
__decorate([
|
|
@@ -11790,6 +11825,20 @@ __decorate([
|
|
|
11790
11825
|
Property('复选框', { type: 'boolean' }),
|
|
11791
11826
|
__metadata("design:type", Object)
|
|
11792
11827
|
], TreeControlComponent.prototype, "checkable", void 0);
|
|
11828
|
+
__decorate([
|
|
11829
|
+
Property('输出格式', {
|
|
11830
|
+
type: 'string',
|
|
11831
|
+
enum: [
|
|
11832
|
+
{ label: '数组', value: 'array' },
|
|
11833
|
+
{ label: '字符串', value: 'string' },
|
|
11834
|
+
],
|
|
11835
|
+
ui: {
|
|
11836
|
+
widget: 'select',
|
|
11837
|
+
visibleIf: { checkable: [true] },
|
|
11838
|
+
},
|
|
11839
|
+
}),
|
|
11840
|
+
__metadata("design:type", Object)
|
|
11841
|
+
], TreeControlComponent.prototype, "outputType", void 0);
|
|
11793
11842
|
__decorate([
|
|
11794
11843
|
Property('选择完全受控', {
|
|
11795
11844
|
type: 'boolean',
|
|
@@ -11835,7 +11884,7 @@ __decorate([
|
|
|
11835
11884
|
type: 'string',
|
|
11836
11885
|
ui: {
|
|
11837
11886
|
widget: 'myUpload',
|
|
11838
|
-
}
|
|
11887
|
+
},
|
|
11839
11888
|
}),
|
|
11840
11889
|
__metadata("design:type", Object)
|
|
11841
11890
|
], TreeControlComponent.prototype, "nodeDefaultIcon", void 0);
|
|
@@ -11844,7 +11893,7 @@ __decorate([
|
|
|
11844
11893
|
type: 'string',
|
|
11845
11894
|
ui: {
|
|
11846
11895
|
widget: 'myUpload',
|
|
11847
|
-
}
|
|
11896
|
+
},
|
|
11848
11897
|
}),
|
|
11849
11898
|
__metadata("design:type", Object)
|
|
11850
11899
|
], TreeControlComponent.prototype, "nodeBackground", void 0);
|
|
@@ -11861,7 +11910,7 @@ __decorate([
|
|
|
11861
11910
|
type: 'string',
|
|
11862
11911
|
ui: {
|
|
11863
11912
|
widget: 'myUpload',
|
|
11864
|
-
}
|
|
11913
|
+
},
|
|
11865
11914
|
}),
|
|
11866
11915
|
__metadata("design:type", Object)
|
|
11867
11916
|
], TreeControlComponent.prototype, "nodeCheckedBackground", void 0);
|
|
@@ -11877,8 +11926,8 @@ __decorate([
|
|
|
11877
11926
|
Property('搜索框颜色', {
|
|
11878
11927
|
ui: {
|
|
11879
11928
|
widget: 'myColor',
|
|
11880
|
-
visibleIf: { showSearch: [true] }
|
|
11881
|
-
}
|
|
11929
|
+
visibleIf: { showSearch: [true] },
|
|
11930
|
+
},
|
|
11882
11931
|
}),
|
|
11883
11932
|
__metadata("design:type", Object)
|
|
11884
11933
|
], TreeControlComponent.prototype, "searchBorderColor", void 0);
|
|
@@ -11886,8 +11935,8 @@ __decorate([
|
|
|
11886
11935
|
Property('搜索框背景色', {
|
|
11887
11936
|
ui: {
|
|
11888
11937
|
widget: 'myColor',
|
|
11889
|
-
visibleIf: { showSearch: [true] }
|
|
11890
|
-
}
|
|
11938
|
+
visibleIf: { showSearch: [true] },
|
|
11939
|
+
},
|
|
11891
11940
|
}),
|
|
11892
11941
|
__metadata("design:type", Object)
|
|
11893
11942
|
], TreeControlComponent.prototype, "searchBackgroundColor", void 0);
|
|
@@ -11895,8 +11944,8 @@ __decorate([
|
|
|
11895
11944
|
Property('搜索框提示语', {
|
|
11896
11945
|
type: 'string',
|
|
11897
11946
|
ui: {
|
|
11898
|
-
visibleIf: { showSearch: [true] }
|
|
11899
|
-
}
|
|
11947
|
+
visibleIf: { showSearch: [true] },
|
|
11948
|
+
},
|
|
11900
11949
|
}),
|
|
11901
11950
|
__metadata("design:type", Object)
|
|
11902
11951
|
], TreeControlComponent.prototype, "searchPlaceholder", void 0);
|
|
@@ -11904,7 +11953,7 @@ __decorate([
|
|
|
11904
11953
|
Property('滚动条颜色', {
|
|
11905
11954
|
ui: {
|
|
11906
11955
|
widget: 'myColor',
|
|
11907
|
-
}
|
|
11956
|
+
},
|
|
11908
11957
|
}),
|
|
11909
11958
|
__metadata("design:type", Object)
|
|
11910
11959
|
], TreeControlComponent.prototype, "treeScrollbarThumbBackground", void 0);
|
|
@@ -11915,11 +11964,15 @@ __decorate([
|
|
|
11915
11964
|
key: { type: 'string', title: 'id' },
|
|
11916
11965
|
parentKey: { type: 'string', title: '父级id' },
|
|
11917
11966
|
icon: { type: 'string', title: '图标' },
|
|
11918
|
-
count: { type: 'string', title: '数量' }
|
|
11967
|
+
count: { type: 'string', title: '数量' },
|
|
11919
11968
|
},
|
|
11920
11969
|
}),
|
|
11921
11970
|
__metadata("design:type", Object)
|
|
11922
11971
|
], TreeControlComponent.prototype, "data", void 0);
|
|
11972
|
+
__decorate([
|
|
11973
|
+
DataInput('选中值'),
|
|
11974
|
+
__metadata("design:type", Object)
|
|
11975
|
+
], TreeControlComponent.prototype, "value", void 0);
|
|
11923
11976
|
__decorate([
|
|
11924
11977
|
DataOutput('选中id'),
|
|
11925
11978
|
Event('选中值改变', { params: 'id' }),
|
|
@@ -11936,7 +11989,7 @@ __decorate([
|
|
|
11936
11989
|
Method('选中'),
|
|
11937
11990
|
__param(0, Param('id')),
|
|
11938
11991
|
__metadata("design:type", Function),
|
|
11939
|
-
__metadata("design:paramtypes", [
|
|
11992
|
+
__metadata("design:paramtypes", [Object]),
|
|
11940
11993
|
__metadata("design:returntype", void 0)
|
|
11941
11994
|
], TreeControlComponent.prototype, "select", null);
|
|
11942
11995
|
__decorate([
|