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.
@@ -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 = { key, title, parentKey: parentKey_value || parentKey, icon, isLeaf: true, count };
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.keyChange.emit(keys);
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
- if (this.nodes) {
168
- const node = this.arrayService.findTree(this.nodes, (n) => n.key === id);
169
- if (node) {
170
- this.onKeysChange([id]);
171
- this.nodeClick(node.key, node.title);
172
- find = true;
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 (!find) {
177
- this.waittingSelect = id;
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", [String]),
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 = { key, title, parentKey: parentKey_value || parentKey, icon, isLeaf: true, count };
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.keyChange.emit(keys);
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
- if (this.nodes) {
11752
- const node = this.arrayService.findTree(this.nodes, (n) => n.key === id);
11753
- if (node) {
11754
- this.onKeysChange([id]);
11755
- this.nodeClick(node.key, node.title);
11756
- find = true;
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 (!find) {
11761
- this.waittingSelect = id;
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", [String]),
11992
+ __metadata("design:paramtypes", [Object]),
11940
11993
  __metadata("design:returntype", void 0)
11941
11994
  ], TreeControlComponent.prototype, "select", null);
11942
11995
  __decorate([