1 | import * as i0 from '@angular/core';
|
---|
2 | import { forwardRef, Component, ViewEncapsulation, Inject, Input, EventEmitter, ChangeDetectionStrategy, Optional, Output, ContentChildren, ViewChild, NgModule } from '@angular/core';
|
---|
3 | import * as i4 from '@angular/cdk/scrolling';
|
---|
4 | import { CdkVirtualScrollViewport, ScrollingModule } from '@angular/cdk/scrolling';
|
---|
5 | import * as i1 from '@angular/common';
|
---|
6 | import { CommonModule } from '@angular/common';
|
---|
7 | import * as i3 from 'primeng/api';
|
---|
8 | import { TranslationKeys, PrimeTemplate, SharedModule } from 'primeng/api';
|
---|
9 | import { ObjectUtils } from 'primeng/utils';
|
---|
10 | import { DomHandler } from 'primeng/dom';
|
---|
11 | import * as i2 from 'primeng/ripple';
|
---|
12 | import { RippleModule } from 'primeng/ripple';
|
---|
13 |
|
---|
14 | class UITreeNode {
|
---|
15 | constructor(tree) {
|
---|
16 | this.tree = tree;
|
---|
17 | }
|
---|
18 | ngOnInit() {
|
---|
19 | this.node.parent = this.parentNode;
|
---|
20 | if (this.parentNode) {
|
---|
21 | this.tree.syncNodeOption(this.node, this.tree.value, 'parent', this.tree.getNodeWithKey(this.parentNode.key, this.tree.value));
|
---|
22 | }
|
---|
23 | }
|
---|
24 | getIcon() {
|
---|
25 | let icon;
|
---|
26 | if (this.node.icon)
|
---|
27 | icon = this.node.icon;
|
---|
28 | else
|
---|
29 | icon = this.node.expanded && this.node.children && this.node.children.length ? this.node.expandedIcon : this.node.collapsedIcon;
|
---|
30 | return UITreeNode.ICON_CLASS + ' ' + icon;
|
---|
31 | }
|
---|
32 | isLeaf() {
|
---|
33 | return this.tree.isNodeLeaf(this.node);
|
---|
34 | }
|
---|
35 | toggle(event) {
|
---|
36 | if (this.node.expanded)
|
---|
37 | this.collapse(event);
|
---|
38 | else
|
---|
39 | this.expand(event);
|
---|
40 | }
|
---|
41 | expand(event) {
|
---|
42 | this.node.expanded = true;
|
---|
43 | if (this.tree.virtualScroll) {
|
---|
44 | this.tree.updateSerializedValue();
|
---|
45 | }
|
---|
46 | this.tree.onNodeExpand.emit({ originalEvent: event, node: this.node });
|
---|
47 | }
|
---|
48 | collapse(event) {
|
---|
49 | this.node.expanded = false;
|
---|
50 | if (this.tree.virtualScroll) {
|
---|
51 | this.tree.updateSerializedValue();
|
---|
52 | }
|
---|
53 | this.tree.onNodeCollapse.emit({ originalEvent: event, node: this.node });
|
---|
54 | }
|
---|
55 | onNodeClick(event) {
|
---|
56 | this.tree.onNodeClick(event, this.node);
|
---|
57 | }
|
---|
58 | onNodeKeydown(event) {
|
---|
59 | if (event.which === 13) {
|
---|
60 | this.tree.onNodeClick(event, this.node);
|
---|
61 | }
|
---|
62 | }
|
---|
63 | onNodeTouchEnd() {
|
---|
64 | this.tree.onNodeTouchEnd();
|
---|
65 | }
|
---|
66 | onNodeRightClick(event) {
|
---|
67 | this.tree.onNodeRightClick(event, this.node);
|
---|
68 | }
|
---|
69 | isSelected() {
|
---|
70 | return this.tree.isSelected(this.node);
|
---|
71 | }
|
---|
72 | onDropPoint(event, position) {
|
---|
73 | event.preventDefault();
|
---|
74 | let dragNode = this.tree.dragNode;
|
---|
75 | let dragNodeIndex = this.tree.dragNodeIndex;
|
---|
76 | let dragNodeScope = this.tree.dragNodeScope;
|
---|
77 | let isValidDropPointIndex = this.tree.dragNodeTree === this.tree ? (position === 1 || dragNodeIndex !== this.index - 1) : true;
|
---|
78 | if (this.tree.allowDrop(dragNode, this.node, dragNodeScope) && isValidDropPointIndex) {
|
---|
79 | let dropParams = { ...this.createDropPointEventMetadata(position) };
|
---|
80 | if (this.tree.validateDrop) {
|
---|
81 | this.tree.onNodeDrop.emit({
|
---|
82 | originalEvent: event,
|
---|
83 | dragNode: dragNode,
|
---|
84 | dropNode: this.node,
|
---|
85 | index: this.index,
|
---|
86 | accept: () => {
|
---|
87 | this.processPointDrop(dropParams);
|
---|
88 | }
|
---|
89 | });
|
---|
90 | }
|
---|
91 | else {
|
---|
92 | this.processPointDrop(dropParams);
|
---|
93 | this.tree.onNodeDrop.emit({
|
---|
94 | originalEvent: event,
|
---|
95 | dragNode: dragNode,
|
---|
96 | dropNode: this.node,
|
---|
97 | index: this.index
|
---|
98 | });
|
---|
99 | }
|
---|
100 | }
|
---|
101 | this.draghoverPrev = false;
|
---|
102 | this.draghoverNext = false;
|
---|
103 | }
|
---|
104 | processPointDrop(event) {
|
---|
105 | let newNodeList = event.dropNode.parent ? event.dropNode.parent.children : this.tree.value;
|
---|
106 | event.dragNodeSubNodes.splice(event.dragNodeIndex, 1);
|
---|
107 | let dropIndex = this.index;
|
---|
108 | if (event.position < 0) {
|
---|
109 | dropIndex = (event.dragNodeSubNodes === newNodeList) ? ((event.dragNodeIndex > event.index) ? event.index : event.index - 1) : event.index;
|
---|
110 | newNodeList.splice(dropIndex, 0, event.dragNode);
|
---|
111 | }
|
---|
112 | else {
|
---|
113 | dropIndex = newNodeList.length;
|
---|
114 | newNodeList.push(event.dragNode);
|
---|
115 | }
|
---|
116 | this.tree.dragDropService.stopDrag({
|
---|
117 | node: event.dragNode,
|
---|
118 | subNodes: event.dropNode.parent ? event.dropNode.parent.children : this.tree.value,
|
---|
119 | index: event.dragNodeIndex
|
---|
120 | });
|
---|
121 | }
|
---|
122 | createDropPointEventMetadata(position) {
|
---|
123 | return {
|
---|
124 | dragNode: this.tree.dragNode,
|
---|
125 | dragNodeIndex: this.tree.dragNodeIndex,
|
---|
126 | dragNodeSubNodes: this.tree.dragNodeSubNodes,
|
---|
127 | dropNode: this.node,
|
---|
128 | index: this.index,
|
---|
129 | position: position
|
---|
130 | };
|
---|
131 | }
|
---|
132 | onDropPointDragOver(event) {
|
---|
133 | event.dataTransfer.dropEffect = 'move';
|
---|
134 | event.preventDefault();
|
---|
135 | }
|
---|
136 | onDropPointDragEnter(event, position) {
|
---|
137 | if (this.tree.allowDrop(this.tree.dragNode, this.node, this.tree.dragNodeScope)) {
|
---|
138 | if (position < 0)
|
---|
139 | this.draghoverPrev = true;
|
---|
140 | else
|
---|
141 | this.draghoverNext = true;
|
---|
142 | }
|
---|
143 | }
|
---|
144 | onDropPointDragLeave(event) {
|
---|
145 | this.draghoverPrev = false;
|
---|
146 | this.draghoverNext = false;
|
---|
147 | }
|
---|
148 | onDragStart(event) {
|
---|
149 | if (this.tree.draggableNodes && this.node.draggable !== false) {
|
---|
150 | event.dataTransfer.setData("text", "data");
|
---|
151 | this.tree.dragDropService.startDrag({
|
---|
152 | tree: this,
|
---|
153 | node: this.node,
|
---|
154 | subNodes: this.node.parent ? this.node.parent.children : this.tree.value,
|
---|
155 | index: this.index,
|
---|
156 | scope: this.tree.draggableScope
|
---|
157 | });
|
---|
158 | }
|
---|
159 | else {
|
---|
160 | event.preventDefault();
|
---|
161 | }
|
---|
162 | }
|
---|
163 | onDragStop(event) {
|
---|
164 | this.tree.dragDropService.stopDrag({
|
---|
165 | node: this.node,
|
---|
166 | subNodes: this.node.parent ? this.node.parent.children : this.tree.value,
|
---|
167 | index: this.index
|
---|
168 | });
|
---|
169 | }
|
---|
170 | onDropNodeDragOver(event) {
|
---|
171 | event.dataTransfer.dropEffect = 'move';
|
---|
172 | if (this.tree.droppableNodes) {
|
---|
173 | event.preventDefault();
|
---|
174 | event.stopPropagation();
|
---|
175 | }
|
---|
176 | }
|
---|
177 | onDropNode(event) {
|
---|
178 | if (this.tree.droppableNodes && this.node.droppable !== false) {
|
---|
179 | let dragNode = this.tree.dragNode;
|
---|
180 | if (this.tree.allowDrop(dragNode, this.node, this.tree.dragNodeScope)) {
|
---|
181 | let dropParams = { ...this.createDropNodeEventMetadata() };
|
---|
182 | if (this.tree.validateDrop) {
|
---|
183 | this.tree.onNodeDrop.emit({
|
---|
184 | originalEvent: event,
|
---|
185 | dragNode: dragNode,
|
---|
186 | dropNode: this.node,
|
---|
187 | index: this.index,
|
---|
188 | accept: () => {
|
---|
189 | this.processNodeDrop(dropParams);
|
---|
190 | }
|
---|
191 | });
|
---|
192 | }
|
---|
193 | else {
|
---|
194 | this.processNodeDrop(dropParams);
|
---|
195 | this.tree.onNodeDrop.emit({
|
---|
196 | originalEvent: event,
|
---|
197 | dragNode: dragNode,
|
---|
198 | dropNode: this.node,
|
---|
199 | index: this.index
|
---|
200 | });
|
---|
201 | }
|
---|
202 | }
|
---|
203 | }
|
---|
204 | event.preventDefault();
|
---|
205 | event.stopPropagation();
|
---|
206 | this.draghoverNode = false;
|
---|
207 | }
|
---|
208 | createDropNodeEventMetadata() {
|
---|
209 | return {
|
---|
210 | dragNode: this.tree.dragNode,
|
---|
211 | dragNodeIndex: this.tree.dragNodeIndex,
|
---|
212 | dragNodeSubNodes: this.tree.dragNodeSubNodes,
|
---|
213 | dropNode: this.node
|
---|
214 | };
|
---|
215 | }
|
---|
216 | processNodeDrop(event) {
|
---|
217 | let dragNodeIndex = event.dragNodeIndex;
|
---|
218 | event.dragNodeSubNodes.splice(dragNodeIndex, 1);
|
---|
219 | if (event.dropNode.children)
|
---|
220 | event.dropNode.children.push(event.dragNode);
|
---|
221 | else
|
---|
222 | event.dropNode.children = [event.dragNode];
|
---|
223 | this.tree.dragDropService.stopDrag({
|
---|
224 | node: event.dragNode,
|
---|
225 | subNodes: event.dropNode.parent ? event.dropNode.parent.children : this.tree.value,
|
---|
226 | index: dragNodeIndex
|
---|
227 | });
|
---|
228 | }
|
---|
229 | onDropNodeDragEnter(event) {
|
---|
230 | if (this.tree.droppableNodes && this.node.droppable !== false && this.tree.allowDrop(this.tree.dragNode, this.node, this.tree.dragNodeScope)) {
|
---|
231 | this.draghoverNode = true;
|
---|
232 | }
|
---|
233 | }
|
---|
234 | onDropNodeDragLeave(event) {
|
---|
235 | if (this.tree.droppableNodes) {
|
---|
236 | let rect = event.currentTarget.getBoundingClientRect();
|
---|
237 | if (event.x > rect.left + rect.width || event.x < rect.left || event.y >= Math.floor(rect.top + rect.height) || event.y < rect.top) {
|
---|
238 | this.draghoverNode = false;
|
---|
239 | }
|
---|
240 | }
|
---|
241 | }
|
---|
242 | onKeyDown(event) {
|
---|
243 | const nodeElement = event.target.parentElement.parentElement;
|
---|
244 | if (nodeElement.nodeName !== 'P-TREENODE' || (this.tree.contextMenu && this.tree.contextMenu.containerViewChild.nativeElement.style.display === 'block')) {
|
---|
245 | return;
|
---|
246 | }
|
---|
247 | switch (event.which) {
|
---|
248 | //down arrow
|
---|
249 | case 40:
|
---|
250 | const listElement = (this.tree.droppableNodes) ? nodeElement.children[1].children[1] : nodeElement.children[0].children[1];
|
---|
251 | if (listElement && listElement.children.length > 0) {
|
---|
252 | this.focusNode(listElement.children[0]);
|
---|
253 | }
|
---|
254 | else {
|
---|
255 | const nextNodeElement = nodeElement.nextElementSibling;
|
---|
256 | if (nextNodeElement) {
|
---|
257 | this.focusNode(nextNodeElement);
|
---|
258 | }
|
---|
259 | else {
|
---|
260 | let nextSiblingAncestor = this.findNextSiblingOfAncestor(nodeElement);
|
---|
261 | if (nextSiblingAncestor) {
|
---|
262 | this.focusNode(nextSiblingAncestor);
|
---|
263 | }
|
---|
264 | }
|
---|
265 | }
|
---|
266 | event.preventDefault();
|
---|
267 | break;
|
---|
268 | //up arrow
|
---|
269 | case 38:
|
---|
270 | if (nodeElement.previousElementSibling) {
|
---|
271 | this.focusNode(this.findLastVisibleDescendant(nodeElement.previousElementSibling));
|
---|
272 | }
|
---|
273 | else {
|
---|
274 | let parentNodeElement = this.getParentNodeElement(nodeElement);
|
---|
275 | if (parentNodeElement) {
|
---|
276 | this.focusNode(parentNodeElement);
|
---|
277 | }
|
---|
278 | }
|
---|
279 | event.preventDefault();
|
---|
280 | break;
|
---|
281 | //right arrow
|
---|
282 | case 39:
|
---|
283 | if (!this.node.expanded && !this.tree.isNodeLeaf(this.node)) {
|
---|
284 | this.expand(event);
|
---|
285 | }
|
---|
286 | event.preventDefault();
|
---|
287 | break;
|
---|
288 | //left arrow
|
---|
289 | case 37:
|
---|
290 | if (this.node.expanded) {
|
---|
291 | this.collapse(event);
|
---|
292 | }
|
---|
293 | else {
|
---|
294 | let parentNodeElement = this.getParentNodeElement(nodeElement);
|
---|
295 | if (parentNodeElement) {
|
---|
296 | this.focusNode(parentNodeElement);
|
---|
297 | }
|
---|
298 | }
|
---|
299 | event.preventDefault();
|
---|
300 | break;
|
---|
301 | //enter
|
---|
302 | case 13:
|
---|
303 | this.tree.onNodeClick(event, this.node);
|
---|
304 | event.preventDefault();
|
---|
305 | break;
|
---|
306 | default:
|
---|
307 | //no op
|
---|
308 | break;
|
---|
309 | }
|
---|
310 | }
|
---|
311 | findNextSiblingOfAncestor(nodeElement) {
|
---|
312 | let parentNodeElement = this.getParentNodeElement(nodeElement);
|
---|
313 | if (parentNodeElement) {
|
---|
314 | if (parentNodeElement.nextElementSibling)
|
---|
315 | return parentNodeElement.nextElementSibling;
|
---|
316 | else
|
---|
317 | return this.findNextSiblingOfAncestor(parentNodeElement);
|
---|
318 | }
|
---|
319 | else {
|
---|
320 | return null;
|
---|
321 | }
|
---|
322 | }
|
---|
323 | findLastVisibleDescendant(nodeElement) {
|
---|
324 | const listElement = Array.from(nodeElement.children).find(el => DomHandler.hasClass(el, 'p-treenode'));
|
---|
325 | const childrenListElement = listElement.children[1];
|
---|
326 | if (childrenListElement && childrenListElement.children.length > 0) {
|
---|
327 | const lastChildElement = childrenListElement.children[childrenListElement.children.length - 1];
|
---|
328 | return this.findLastVisibleDescendant(lastChildElement);
|
---|
329 | }
|
---|
330 | else {
|
---|
331 | return nodeElement;
|
---|
332 | }
|
---|
333 | }
|
---|
334 | getParentNodeElement(nodeElement) {
|
---|
335 | const parentNodeElement = nodeElement.parentElement.parentElement.parentElement;
|
---|
336 | return parentNodeElement.tagName === 'P-TREENODE' ? parentNodeElement : null;
|
---|
337 | }
|
---|
338 | focusNode(element) {
|
---|
339 | if (this.tree.droppableNodes)
|
---|
340 | element.children[1].children[0].focus();
|
---|
341 | else
|
---|
342 | element.children[0].children[0].focus();
|
---|
343 | }
|
---|
344 | }
|
---|
345 | UITreeNode.ICON_CLASS = 'p-treenode-icon ';
|
---|
346 | UITreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: UITreeNode, deps: [{ token: forwardRef(() => Tree) }], target: i0.ɵɵFactoryTarget.Component });
|
---|
347 | UITreeNode.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: UITreeNode, selector: "p-treeNode", inputs: { rowNode: "rowNode", node: "node", parentNode: "parentNode", root: "root", index: "index", firstChild: "firstChild", lastChild: "lastChild", level: "level", indentation: "indentation" }, host: { classAttribute: "p-element" }, ngImport: i0, template: `
|
---|
348 | <ng-template [ngIf]="node">
|
---|
349 | <li *ngIf="tree.droppableNodes" class="p-treenode-droppoint" [ngClass]="{'p-treenode-droppoint-active':draghoverPrev}"
|
---|
350 | (drop)="onDropPoint($event,-1)" (dragover)="onDropPointDragOver($event)" (dragenter)="onDropPointDragEnter($event,-1)" (dragleave)="onDropPointDragLeave($event)"></li>
|
---|
351 | <li *ngIf="!tree.horizontal" [ngClass]="['p-treenode',node.styleClass||'', isLeaf() ? 'p-treenode-leaf': '']">
|
---|
352 | <div class="p-treenode-content" [style.paddingLeft]="(level * indentation) + 'rem'" (click)="onNodeClick($event)" (contextmenu)="onNodeRightClick($event)" (touchend)="onNodeTouchEnd()"
|
---|
353 | (drop)="onDropNode($event)" (dragover)="onDropNodeDragOver($event)" (dragenter)="onDropNodeDragEnter($event)" (dragleave)="onDropNodeDragLeave($event)"
|
---|
354 | [draggable]="tree.draggableNodes" (dragstart)="onDragStart($event)" (dragend)="onDragStop($event)" [attr.tabindex]="0"
|
---|
355 | [ngClass]="{'p-treenode-selectable':tree.selectionMode && node.selectable !== false,'p-treenode-dragover':draghoverNode, 'p-highlight':isSelected()}" role="treeitem"
|
---|
356 | (keydown)="onKeyDown($event)" [attr.aria-posinset]="this.index + 1" [attr.aria-expanded]="this.node.expanded" [attr.aria-selected]="isSelected()" [attr.aria-label]="node.label">
|
---|
357 | <button type="button" [attr.aria-label]="tree.togglerAriaLabel" class="p-tree-toggler p-link" (click)="toggle($event)" pRipple tabindex="-1">
|
---|
358 | <span class="p-tree-toggler-icon pi pi-fw" [ngClass]="{'pi-chevron-right':!node.expanded,'pi-chevron-down':node.expanded}"></span>
|
---|
359 | </button>
|
---|
360 | <div class="p-checkbox p-component" [ngClass]="{'p-checkbox-disabled': node.selectable === false}" *ngIf="tree.selectionMode == 'checkbox'" [attr.aria-checked]="isSelected()">
|
---|
361 | <div class="p-checkbox-box" [ngClass]="{'p-highlight': isSelected(), 'p-indeterminate': node.partialSelected}">
|
---|
362 | <span class="p-checkbox-icon pi" [ngClass]="{'pi-check':isSelected(),'pi-minus':node.partialSelected}"></span>
|
---|
363 | </div>
|
---|
364 | </div>
|
---|
365 | <span [class]="getIcon()" *ngIf="node.icon||node.expandedIcon||node.collapsedIcon"></span>
|
---|
366 | <span class="p-treenode-label">
|
---|
367 | <span *ngIf="!tree.getTemplateForNode(node)">{{node.label}}</span>
|
---|
368 | <span *ngIf="tree.getTemplateForNode(node)">
|
---|
369 | <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node); context: {$implicit: node}"></ng-container>
|
---|
370 | </span>
|
---|
371 | </span>
|
---|
372 | </div>
|
---|
373 | <ul class="p-treenode-children" style="display: none;" *ngIf="!tree.virtualScroll && node.children && node.expanded" [style.display]="node.expanded ? 'block' : 'none'" role="group">
|
---|
374 | <p-treeNode *ngFor="let childNode of node.children;let firstChild=first;let lastChild=last; let index=index; trackBy: tree.trackBy" [node]="childNode" [parentNode]="node"
|
---|
375 | [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [style.height.px]="tree.virtualNodeHeight" [level]="level + 1"></p-treeNode>
|
---|
376 | </ul>
|
---|
377 | </li>
|
---|
378 | <li *ngIf="tree.droppableNodes&&lastChild" class="p-treenode-droppoint" [ngClass]="{'p-treenode-droppoint-active':draghoverNext}"
|
---|
379 | (drop)="onDropPoint($event,1)" (dragover)="onDropPointDragOver($event)" (dragenter)="onDropPointDragEnter($event,1)" (dragleave)="onDropPointDragLeave($event)"></li>
|
---|
380 | <table *ngIf="tree.horizontal" [class]="node.styleClass">
|
---|
381 | <tbody>
|
---|
382 | <tr>
|
---|
383 | <td class="p-treenode-connector" *ngIf="!root">
|
---|
384 | <table class="p-treenode-connector-table">
|
---|
385 | <tbody>
|
---|
386 | <tr>
|
---|
387 | <td [ngClass]="{'p-treenode-connector-line':!firstChild}"></td>
|
---|
388 | </tr>
|
---|
389 | <tr>
|
---|
390 | <td [ngClass]="{'p-treenode-connector-line':!lastChild}"></td>
|
---|
391 | </tr>
|
---|
392 | </tbody>
|
---|
393 | </table>
|
---|
394 | </td>
|
---|
395 | <td class="p-treenode" [ngClass]="{'p-treenode-collapsed':!node.expanded}">
|
---|
396 | <div class="p-treenode-content" tabindex="0" [ngClass]="{'p-treenode-selectable':tree.selectionMode,'p-highlight':isSelected()}" (click)="onNodeClick($event)" (contextmenu)="onNodeRightClick($event)"
|
---|
397 | (touchend)="onNodeTouchEnd()" (keydown)="onNodeKeydown($event)">
|
---|
398 | <span [attr.aria-label]="tree.togglerAriaLabel" class="p-tree-toggler pi pi-fw" [ngClass]="{'pi-plus':!node.expanded,'pi-minus':node.expanded}" *ngIf="!isLeaf()" (click)="toggle($event)"></span>
|
---|
399 | <span [class]="getIcon()" *ngIf="node.icon||node.expandedIcon||node.collapsedIcon"></span>
|
---|
400 | <span class="p-treenode-label">
|
---|
401 | <span *ngIf="!tree.getTemplateForNode(node)">{{node.label}}</span>
|
---|
402 | <span *ngIf="tree.getTemplateForNode(node)">
|
---|
403 | <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node); context: {$implicit: node}"></ng-container>
|
---|
404 | </span>
|
---|
405 | </span>
|
---|
406 | </div>
|
---|
407 | </td>
|
---|
408 | <td class="p-treenode-children-container" *ngIf="node.children && node.expanded" [style.display]="node.expanded ? 'table-cell' : 'none'">
|
---|
409 | <div class="p-treenode-children">
|
---|
410 | <p-treeNode *ngFor="let childNode of node.children;let firstChild=first;let lastChild=last; trackBy: tree.trackBy" [node]="childNode"
|
---|
411 | [firstChild]="firstChild" [lastChild]="lastChild"></p-treeNode>
|
---|
412 | </div>
|
---|
413 | </td>
|
---|
414 | </tr>
|
---|
415 | </tbody>
|
---|
416 | </table>
|
---|
417 | </ng-template>
|
---|
418 | `, isInline: true, components: [{ type: UITreeNode, selector: "p-treeNode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.Ripple, selector: "[pRipple]" }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], encapsulation: i0.ViewEncapsulation.None });
|
---|
419 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: UITreeNode, decorators: [{
|
---|
420 | type: Component,
|
---|
421 | args: [{
|
---|
422 | selector: 'p-treeNode',
|
---|
423 | template: `
|
---|
424 | <ng-template [ngIf]="node">
|
---|
425 | <li *ngIf="tree.droppableNodes" class="p-treenode-droppoint" [ngClass]="{'p-treenode-droppoint-active':draghoverPrev}"
|
---|
426 | (drop)="onDropPoint($event,-1)" (dragover)="onDropPointDragOver($event)" (dragenter)="onDropPointDragEnter($event,-1)" (dragleave)="onDropPointDragLeave($event)"></li>
|
---|
427 | <li *ngIf="!tree.horizontal" [ngClass]="['p-treenode',node.styleClass||'', isLeaf() ? 'p-treenode-leaf': '']">
|
---|
428 | <div class="p-treenode-content" [style.paddingLeft]="(level * indentation) + 'rem'" (click)="onNodeClick($event)" (contextmenu)="onNodeRightClick($event)" (touchend)="onNodeTouchEnd()"
|
---|
429 | (drop)="onDropNode($event)" (dragover)="onDropNodeDragOver($event)" (dragenter)="onDropNodeDragEnter($event)" (dragleave)="onDropNodeDragLeave($event)"
|
---|
430 | [draggable]="tree.draggableNodes" (dragstart)="onDragStart($event)" (dragend)="onDragStop($event)" [attr.tabindex]="0"
|
---|
431 | [ngClass]="{'p-treenode-selectable':tree.selectionMode && node.selectable !== false,'p-treenode-dragover':draghoverNode, 'p-highlight':isSelected()}" role="treeitem"
|
---|
432 | (keydown)="onKeyDown($event)" [attr.aria-posinset]="this.index + 1" [attr.aria-expanded]="this.node.expanded" [attr.aria-selected]="isSelected()" [attr.aria-label]="node.label">
|
---|
433 | <button type="button" [attr.aria-label]="tree.togglerAriaLabel" class="p-tree-toggler p-link" (click)="toggle($event)" pRipple tabindex="-1">
|
---|
434 | <span class="p-tree-toggler-icon pi pi-fw" [ngClass]="{'pi-chevron-right':!node.expanded,'pi-chevron-down':node.expanded}"></span>
|
---|
435 | </button>
|
---|
436 | <div class="p-checkbox p-component" [ngClass]="{'p-checkbox-disabled': node.selectable === false}" *ngIf="tree.selectionMode == 'checkbox'" [attr.aria-checked]="isSelected()">
|
---|
437 | <div class="p-checkbox-box" [ngClass]="{'p-highlight': isSelected(), 'p-indeterminate': node.partialSelected}">
|
---|
438 | <span class="p-checkbox-icon pi" [ngClass]="{'pi-check':isSelected(),'pi-minus':node.partialSelected}"></span>
|
---|
439 | </div>
|
---|
440 | </div>
|
---|
441 | <span [class]="getIcon()" *ngIf="node.icon||node.expandedIcon||node.collapsedIcon"></span>
|
---|
442 | <span class="p-treenode-label">
|
---|
443 | <span *ngIf="!tree.getTemplateForNode(node)">{{node.label}}</span>
|
---|
444 | <span *ngIf="tree.getTemplateForNode(node)">
|
---|
445 | <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node); context: {$implicit: node}"></ng-container>
|
---|
446 | </span>
|
---|
447 | </span>
|
---|
448 | </div>
|
---|
449 | <ul class="p-treenode-children" style="display: none;" *ngIf="!tree.virtualScroll && node.children && node.expanded" [style.display]="node.expanded ? 'block' : 'none'" role="group">
|
---|
450 | <p-treeNode *ngFor="let childNode of node.children;let firstChild=first;let lastChild=last; let index=index; trackBy: tree.trackBy" [node]="childNode" [parentNode]="node"
|
---|
451 | [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [style.height.px]="tree.virtualNodeHeight" [level]="level + 1"></p-treeNode>
|
---|
452 | </ul>
|
---|
453 | </li>
|
---|
454 | <li *ngIf="tree.droppableNodes&&lastChild" class="p-treenode-droppoint" [ngClass]="{'p-treenode-droppoint-active':draghoverNext}"
|
---|
455 | (drop)="onDropPoint($event,1)" (dragover)="onDropPointDragOver($event)" (dragenter)="onDropPointDragEnter($event,1)" (dragleave)="onDropPointDragLeave($event)"></li>
|
---|
456 | <table *ngIf="tree.horizontal" [class]="node.styleClass">
|
---|
457 | <tbody>
|
---|
458 | <tr>
|
---|
459 | <td class="p-treenode-connector" *ngIf="!root">
|
---|
460 | <table class="p-treenode-connector-table">
|
---|
461 | <tbody>
|
---|
462 | <tr>
|
---|
463 | <td [ngClass]="{'p-treenode-connector-line':!firstChild}"></td>
|
---|
464 | </tr>
|
---|
465 | <tr>
|
---|
466 | <td [ngClass]="{'p-treenode-connector-line':!lastChild}"></td>
|
---|
467 | </tr>
|
---|
468 | </tbody>
|
---|
469 | </table>
|
---|
470 | </td>
|
---|
471 | <td class="p-treenode" [ngClass]="{'p-treenode-collapsed':!node.expanded}">
|
---|
472 | <div class="p-treenode-content" tabindex="0" [ngClass]="{'p-treenode-selectable':tree.selectionMode,'p-highlight':isSelected()}" (click)="onNodeClick($event)" (contextmenu)="onNodeRightClick($event)"
|
---|
473 | (touchend)="onNodeTouchEnd()" (keydown)="onNodeKeydown($event)">
|
---|
474 | <span [attr.aria-label]="tree.togglerAriaLabel" class="p-tree-toggler pi pi-fw" [ngClass]="{'pi-plus':!node.expanded,'pi-minus':node.expanded}" *ngIf="!isLeaf()" (click)="toggle($event)"></span>
|
---|
475 | <span [class]="getIcon()" *ngIf="node.icon||node.expandedIcon||node.collapsedIcon"></span>
|
---|
476 | <span class="p-treenode-label">
|
---|
477 | <span *ngIf="!tree.getTemplateForNode(node)">{{node.label}}</span>
|
---|
478 | <span *ngIf="tree.getTemplateForNode(node)">
|
---|
479 | <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node); context: {$implicit: node}"></ng-container>
|
---|
480 | </span>
|
---|
481 | </span>
|
---|
482 | </div>
|
---|
483 | </td>
|
---|
484 | <td class="p-treenode-children-container" *ngIf="node.children && node.expanded" [style.display]="node.expanded ? 'table-cell' : 'none'">
|
---|
485 | <div class="p-treenode-children">
|
---|
486 | <p-treeNode *ngFor="let childNode of node.children;let firstChild=first;let lastChild=last; trackBy: tree.trackBy" [node]="childNode"
|
---|
487 | [firstChild]="firstChild" [lastChild]="lastChild"></p-treeNode>
|
---|
488 | </div>
|
---|
489 | </td>
|
---|
490 | </tr>
|
---|
491 | </tbody>
|
---|
492 | </table>
|
---|
493 | </ng-template>
|
---|
494 | `,
|
---|
495 | encapsulation: ViewEncapsulation.None,
|
---|
496 | host: {
|
---|
497 | 'class': 'p-element'
|
---|
498 | }
|
---|
499 | }]
|
---|
500 | }], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
---|
501 | type: Inject,
|
---|
502 | args: [forwardRef(() => Tree)]
|
---|
503 | }] }]; }, propDecorators: { rowNode: [{
|
---|
504 | type: Input
|
---|
505 | }], node: [{
|
---|
506 | type: Input
|
---|
507 | }], parentNode: [{
|
---|
508 | type: Input
|
---|
509 | }], root: [{
|
---|
510 | type: Input
|
---|
511 | }], index: [{
|
---|
512 | type: Input
|
---|
513 | }], firstChild: [{
|
---|
514 | type: Input
|
---|
515 | }], lastChild: [{
|
---|
516 | type: Input
|
---|
517 | }], level: [{
|
---|
518 | type: Input
|
---|
519 | }], indentation: [{
|
---|
520 | type: Input
|
---|
521 | }] } });
|
---|
522 | class Tree {
|
---|
523 | constructor(el, dragDropService, config) {
|
---|
524 | this.el = el;
|
---|
525 | this.dragDropService = dragDropService;
|
---|
526 | this.config = config;
|
---|
527 | this.selectionChange = new EventEmitter();
|
---|
528 | this.onNodeSelect = new EventEmitter();
|
---|
529 | this.onNodeUnselect = new EventEmitter();
|
---|
530 | this.onNodeExpand = new EventEmitter();
|
---|
531 | this.onNodeCollapse = new EventEmitter();
|
---|
532 | this.onNodeContextMenuSelect = new EventEmitter();
|
---|
533 | this.onNodeDrop = new EventEmitter();
|
---|
534 | this.layout = 'vertical';
|
---|
535 | this.metaKeySelection = true;
|
---|
536 | this.propagateSelectionUp = true;
|
---|
537 | this.propagateSelectionDown = true;
|
---|
538 | this.loadingIcon = 'pi pi-spinner';
|
---|
539 | this.emptyMessage = '';
|
---|
540 | this.filterBy = 'label';
|
---|
541 | this.filterMode = 'lenient';
|
---|
542 | this.indentation = 1.5;
|
---|
543 | this.trackBy = (index, item) => item;
|
---|
544 | this.onFilter = new EventEmitter();
|
---|
545 | }
|
---|
546 | ngOnInit() {
|
---|
547 | if (this.droppableNodes) {
|
---|
548 | this.dragStartSubscription = this.dragDropService.dragStart$.subscribe(event => {
|
---|
549 | this.dragNodeTree = event.tree;
|
---|
550 | this.dragNode = event.node;
|
---|
551 | this.dragNodeSubNodes = event.subNodes;
|
---|
552 | this.dragNodeIndex = event.index;
|
---|
553 | this.dragNodeScope = event.scope;
|
---|
554 | });
|
---|
555 | this.dragStopSubscription = this.dragDropService.dragStop$.subscribe(event => {
|
---|
556 | this.dragNodeTree = null;
|
---|
557 | this.dragNode = null;
|
---|
558 | this.dragNodeSubNodes = null;
|
---|
559 | this.dragNodeIndex = null;
|
---|
560 | this.dragNodeScope = null;
|
---|
561 | this.dragHover = false;
|
---|
562 | });
|
---|
563 | }
|
---|
564 | }
|
---|
565 | ngOnChanges(simpleChange) {
|
---|
566 | if (simpleChange.value) {
|
---|
567 | this.updateSerializedValue();
|
---|
568 | }
|
---|
569 | if (simpleChange.scrollHeight && this.virtualScrollBody) {
|
---|
570 | this.virtualScrollBody.ngOnInit();
|
---|
571 | }
|
---|
572 | }
|
---|
573 | get horizontal() {
|
---|
574 | return this.layout == 'horizontal';
|
---|
575 | }
|
---|
576 | get emptyMessageLabel() {
|
---|
577 | return this.emptyMessage || this.config.getTranslation(TranslationKeys.EMPTY_MESSAGE);
|
---|
578 | }
|
---|
579 | ngAfterContentInit() {
|
---|
580 | if (this.templates.length) {
|
---|
581 | this.templateMap = {};
|
---|
582 | }
|
---|
583 | this.templates.forEach((item) => {
|
---|
584 | switch (item.getType()) {
|
---|
585 | case 'header':
|
---|
586 | this.headerTemplate = item.template;
|
---|
587 | break;
|
---|
588 | case 'empty':
|
---|
589 | this.emptyMessageTemplate = item.template;
|
---|
590 | break;
|
---|
591 | case 'footer':
|
---|
592 | this.footerTemplate = item.template;
|
---|
593 | break;
|
---|
594 | default:
|
---|
595 | this.templateMap[item.name] = item.template;
|
---|
596 | break;
|
---|
597 | }
|
---|
598 | });
|
---|
599 | }
|
---|
600 | updateSerializedValue() {
|
---|
601 | this.serializedValue = [];
|
---|
602 | this.serializeNodes(null, this.getRootNode(), 0, true);
|
---|
603 | }
|
---|
604 | serializeNodes(parent, nodes, level, visible) {
|
---|
605 | if (nodes && nodes.length) {
|
---|
606 | for (let node of nodes) {
|
---|
607 | node.parent = parent;
|
---|
608 | const rowNode = {
|
---|
609 | node: node,
|
---|
610 | parent: parent,
|
---|
611 | level: level,
|
---|
612 | visible: visible && (parent ? parent.expanded : true)
|
---|
613 | };
|
---|
614 | this.serializedValue.push(rowNode);
|
---|
615 | if (rowNode.visible && node.expanded) {
|
---|
616 | this.serializeNodes(node, node.children, level + 1, rowNode.visible);
|
---|
617 | }
|
---|
618 | }
|
---|
619 | }
|
---|
620 | }
|
---|
621 | onNodeClick(event, node) {
|
---|
622 | let eventTarget = event.target;
|
---|
623 | if (DomHandler.hasClass(eventTarget, 'p-tree-toggler') || DomHandler.hasClass(eventTarget, 'p-tree-toggler-icon')) {
|
---|
624 | return;
|
---|
625 | }
|
---|
626 | else if (this.selectionMode) {
|
---|
627 | if (node.selectable === false) {
|
---|
628 | return;
|
---|
629 | }
|
---|
630 | if (this.hasFilteredNodes()) {
|
---|
631 | node = this.getNodeWithKey(node.key, this.value);
|
---|
632 | if (!node) {
|
---|
633 | return;
|
---|
634 | }
|
---|
635 | }
|
---|
636 | let index = this.findIndexInSelection(node);
|
---|
637 | let selected = (index >= 0);
|
---|
638 | if (this.isCheckboxSelectionMode()) {
|
---|
639 | if (selected) {
|
---|
640 | if (this.propagateSelectionDown)
|
---|
641 | this.propagateDown(node, false);
|
---|
642 | else
|
---|
643 | this.selection = this.selection.filter((val, i) => i != index);
|
---|
644 | if (this.propagateSelectionUp && node.parent) {
|
---|
645 | this.propagateUp(node.parent, false);
|
---|
646 | }
|
---|
647 | this.selectionChange.emit(this.selection);
|
---|
648 | this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
---|
649 | }
|
---|
650 | else {
|
---|
651 | if (this.propagateSelectionDown)
|
---|
652 | this.propagateDown(node, true);
|
---|
653 | else
|
---|
654 | this.selection = [...this.selection || [], node];
|
---|
655 | if (this.propagateSelectionUp && node.parent) {
|
---|
656 | this.propagateUp(node.parent, true);
|
---|
657 | }
|
---|
658 | this.selectionChange.emit(this.selection);
|
---|
659 | this.onNodeSelect.emit({ originalEvent: event, node: node });
|
---|
660 | }
|
---|
661 | }
|
---|
662 | else {
|
---|
663 | let metaSelection = this.nodeTouched ? false : this.metaKeySelection;
|
---|
664 | if (metaSelection) {
|
---|
665 | let metaKey = (event.metaKey || event.ctrlKey);
|
---|
666 | if (selected && metaKey) {
|
---|
667 | if (this.isSingleSelectionMode()) {
|
---|
668 | this.selectionChange.emit(null);
|
---|
669 | }
|
---|
670 | else {
|
---|
671 | this.selection = this.selection.filter((val, i) => i != index);
|
---|
672 | this.selectionChange.emit(this.selection);
|
---|
673 | }
|
---|
674 | this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
---|
675 | }
|
---|
676 | else {
|
---|
677 | if (this.isSingleSelectionMode()) {
|
---|
678 | this.selectionChange.emit(node);
|
---|
679 | }
|
---|
680 | else if (this.isMultipleSelectionMode()) {
|
---|
681 | this.selection = (!metaKey) ? [] : this.selection || [];
|
---|
682 | this.selection = [...this.selection, node];
|
---|
683 | this.selectionChange.emit(this.selection);
|
---|
684 | }
|
---|
685 | this.onNodeSelect.emit({ originalEvent: event, node: node });
|
---|
686 | }
|
---|
687 | }
|
---|
688 | else {
|
---|
689 | if (this.isSingleSelectionMode()) {
|
---|
690 | if (selected) {
|
---|
691 | this.selection = null;
|
---|
692 | this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
---|
693 | }
|
---|
694 | else {
|
---|
695 | this.selection = node;
|
---|
696 | this.onNodeSelect.emit({ originalEvent: event, node: node });
|
---|
697 | }
|
---|
698 | }
|
---|
699 | else {
|
---|
700 | if (selected) {
|
---|
701 | this.selection = this.selection.filter((val, i) => i != index);
|
---|
702 | this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
---|
703 | }
|
---|
704 | else {
|
---|
705 | this.selection = [...this.selection || [], node];
|
---|
706 | this.onNodeSelect.emit({ originalEvent: event, node: node });
|
---|
707 | }
|
---|
708 | }
|
---|
709 | this.selectionChange.emit(this.selection);
|
---|
710 | }
|
---|
711 | }
|
---|
712 | }
|
---|
713 | this.nodeTouched = false;
|
---|
714 | }
|
---|
715 | onNodeTouchEnd() {
|
---|
716 | this.nodeTouched = true;
|
---|
717 | }
|
---|
718 | onNodeRightClick(event, node) {
|
---|
719 | if (this.contextMenu) {
|
---|
720 | let eventTarget = event.target;
|
---|
721 | if (eventTarget.className && eventTarget.className.indexOf('p-tree-toggler') === 0) {
|
---|
722 | return;
|
---|
723 | }
|
---|
724 | else {
|
---|
725 | let index = this.findIndexInSelection(node);
|
---|
726 | let selected = (index >= 0);
|
---|
727 | if (!selected) {
|
---|
728 | if (this.isSingleSelectionMode())
|
---|
729 | this.selectionChange.emit(node);
|
---|
730 | else
|
---|
731 | this.selectionChange.emit([node]);
|
---|
732 | }
|
---|
733 | this.contextMenu.show(event);
|
---|
734 | this.onNodeContextMenuSelect.emit({ originalEvent: event, node: node });
|
---|
735 | }
|
---|
736 | }
|
---|
737 | }
|
---|
738 | findIndexInSelection(node) {
|
---|
739 | let index = -1;
|
---|
740 | if (this.selectionMode && this.selection) {
|
---|
741 | if (this.isSingleSelectionMode()) {
|
---|
742 | let areNodesEqual = (this.selection.key && this.selection.key === node.key) || this.selection == node;
|
---|
743 | index = areNodesEqual ? 0 : -1;
|
---|
744 | }
|
---|
745 | else {
|
---|
746 | for (let i = 0; i < this.selection.length; i++) {
|
---|
747 | let selectedNode = this.selection[i];
|
---|
748 | let areNodesEqual = (selectedNode.key && selectedNode.key === node.key) || selectedNode == node;
|
---|
749 | if (areNodesEqual) {
|
---|
750 | index = i;
|
---|
751 | break;
|
---|
752 | }
|
---|
753 | }
|
---|
754 | }
|
---|
755 | }
|
---|
756 | return index;
|
---|
757 | }
|
---|
758 | syncNodeOption(node, parentNodes, option, value) {
|
---|
759 | // to synchronize the node option between the filtered nodes and the original nodes(this.value)
|
---|
760 | const _node = this.hasFilteredNodes() ? this.getNodeWithKey(node.key, parentNodes) : null;
|
---|
761 | if (_node) {
|
---|
762 | _node[option] = value || node[option];
|
---|
763 | }
|
---|
764 | }
|
---|
765 | hasFilteredNodes() {
|
---|
766 | return this.filter && this.filteredNodes && this.filteredNodes.length;
|
---|
767 | }
|
---|
768 | getNodeWithKey(key, nodes) {
|
---|
769 | for (let node of nodes) {
|
---|
770 | if (node.key === key) {
|
---|
771 | return node;
|
---|
772 | }
|
---|
773 | if (node.children) {
|
---|
774 | let matchedNode = this.getNodeWithKey(key, node.children);
|
---|
775 | if (matchedNode) {
|
---|
776 | return matchedNode;
|
---|
777 | }
|
---|
778 | }
|
---|
779 | }
|
---|
780 | }
|
---|
781 | propagateUp(node, select) {
|
---|
782 | if (node.children && node.children.length) {
|
---|
783 | let selectedCount = 0;
|
---|
784 | let childPartialSelected = false;
|
---|
785 | for (let child of node.children) {
|
---|
786 | if (this.isSelected(child)) {
|
---|
787 | selectedCount++;
|
---|
788 | }
|
---|
789 | else if (child.partialSelected) {
|
---|
790 | childPartialSelected = true;
|
---|
791 | }
|
---|
792 | }
|
---|
793 | if (select && selectedCount == node.children.length) {
|
---|
794 | this.selection = [...this.selection || [], node];
|
---|
795 | node.partialSelected = false;
|
---|
796 | }
|
---|
797 | else {
|
---|
798 | if (!select) {
|
---|
799 | let index = this.findIndexInSelection(node);
|
---|
800 | if (index >= 0) {
|
---|
801 | this.selection = this.selection.filter((val, i) => i != index);
|
---|
802 | }
|
---|
803 | }
|
---|
804 | if (childPartialSelected || selectedCount > 0 && selectedCount != node.children.length)
|
---|
805 | node.partialSelected = true;
|
---|
806 | else
|
---|
807 | node.partialSelected = false;
|
---|
808 | }
|
---|
809 | this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
|
---|
810 | }
|
---|
811 | let parent = node.parent;
|
---|
812 | if (parent) {
|
---|
813 | this.propagateUp(parent, select);
|
---|
814 | }
|
---|
815 | }
|
---|
816 | propagateDown(node, select) {
|
---|
817 | let index = this.findIndexInSelection(node);
|
---|
818 | if (select && index == -1) {
|
---|
819 | this.selection = [...this.selection || [], node];
|
---|
820 | }
|
---|
821 | else if (!select && index > -1) {
|
---|
822 | this.selection = this.selection.filter((val, i) => i != index);
|
---|
823 | }
|
---|
824 | node.partialSelected = false;
|
---|
825 | this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
|
---|
826 | if (node.children && node.children.length) {
|
---|
827 | for (let child of node.children) {
|
---|
828 | this.propagateDown(child, select);
|
---|
829 | }
|
---|
830 | }
|
---|
831 | }
|
---|
832 | isSelected(node) {
|
---|
833 | return this.findIndexInSelection(node) != -1;
|
---|
834 | }
|
---|
835 | isSingleSelectionMode() {
|
---|
836 | return this.selectionMode && this.selectionMode == 'single';
|
---|
837 | }
|
---|
838 | isMultipleSelectionMode() {
|
---|
839 | return this.selectionMode && this.selectionMode == 'multiple';
|
---|
840 | }
|
---|
841 | isCheckboxSelectionMode() {
|
---|
842 | return this.selectionMode && this.selectionMode == 'checkbox';
|
---|
843 | }
|
---|
844 | isNodeLeaf(node) {
|
---|
845 | return node.leaf == false ? false : !(node.children && node.children.length);
|
---|
846 | }
|
---|
847 | getRootNode() {
|
---|
848 | return this.filteredNodes ? this.filteredNodes : this.value;
|
---|
849 | }
|
---|
850 | getTemplateForNode(node) {
|
---|
851 | if (this.templateMap)
|
---|
852 | return node.type ? this.templateMap[node.type] : this.templateMap['default'];
|
---|
853 | else
|
---|
854 | return null;
|
---|
855 | }
|
---|
856 | onDragOver(event) {
|
---|
857 | if (this.droppableNodes && (!this.value || this.value.length === 0)) {
|
---|
858 | event.dataTransfer.dropEffect = 'move';
|
---|
859 | event.preventDefault();
|
---|
860 | }
|
---|
861 | }
|
---|
862 | onDrop(event) {
|
---|
863 | if (this.droppableNodes && (!this.value || this.value.length === 0)) {
|
---|
864 | event.preventDefault();
|
---|
865 | let dragNode = this.dragNode;
|
---|
866 | if (this.allowDrop(dragNode, null, this.dragNodeScope)) {
|
---|
867 | let dragNodeIndex = this.dragNodeIndex;
|
---|
868 | this.value = this.value || [];
|
---|
869 | if (this.validateDrop) {
|
---|
870 | this.onNodeDrop.emit({
|
---|
871 | originalEvent: event,
|
---|
872 | dragNode: dragNode,
|
---|
873 | dropNode: null,
|
---|
874 | index: dragNodeIndex,
|
---|
875 | accept: () => {
|
---|
876 | this.processTreeDrop(dragNode, dragNodeIndex);
|
---|
877 | }
|
---|
878 | });
|
---|
879 | }
|
---|
880 | else {
|
---|
881 | this.onNodeDrop.emit({
|
---|
882 | originalEvent: event,
|
---|
883 | dragNode: dragNode,
|
---|
884 | dropNode: null,
|
---|
885 | index: dragNodeIndex
|
---|
886 | });
|
---|
887 | this.processTreeDrop(dragNode, dragNodeIndex);
|
---|
888 | }
|
---|
889 | }
|
---|
890 | }
|
---|
891 | }
|
---|
892 | processTreeDrop(dragNode, dragNodeIndex) {
|
---|
893 | this.dragNodeSubNodes.splice(dragNodeIndex, 1);
|
---|
894 | this.value.push(dragNode);
|
---|
895 | this.dragDropService.stopDrag({
|
---|
896 | node: dragNode
|
---|
897 | });
|
---|
898 | }
|
---|
899 | onDragEnter() {
|
---|
900 | if (this.droppableNodes && this.allowDrop(this.dragNode, null, this.dragNodeScope)) {
|
---|
901 | this.dragHover = true;
|
---|
902 | }
|
---|
903 | }
|
---|
904 | onDragLeave(event) {
|
---|
905 | if (this.droppableNodes) {
|
---|
906 | let rect = event.currentTarget.getBoundingClientRect();
|
---|
907 | if (event.x > rect.left + rect.width || event.x < rect.left || event.y > rect.top + rect.height || event.y < rect.top) {
|
---|
908 | this.dragHover = false;
|
---|
909 | }
|
---|
910 | }
|
---|
911 | }
|
---|
912 | allowDrop(dragNode, dropNode, dragNodeScope) {
|
---|
913 | if (!dragNode) {
|
---|
914 | //prevent random html elements to be dragged
|
---|
915 | return false;
|
---|
916 | }
|
---|
917 | else if (this.isValidDragScope(dragNodeScope)) {
|
---|
918 | let allow = true;
|
---|
919 | if (dropNode) {
|
---|
920 | if (dragNode === dropNode) {
|
---|
921 | allow = false;
|
---|
922 | }
|
---|
923 | else {
|
---|
924 | let parent = dropNode.parent;
|
---|
925 | while (parent != null) {
|
---|
926 | if (parent === dragNode) {
|
---|
927 | allow = false;
|
---|
928 | break;
|
---|
929 | }
|
---|
930 | parent = parent.parent;
|
---|
931 | }
|
---|
932 | }
|
---|
933 | }
|
---|
934 | return allow;
|
---|
935 | }
|
---|
936 | else {
|
---|
937 | return false;
|
---|
938 | }
|
---|
939 | }
|
---|
940 | isValidDragScope(dragScope) {
|
---|
941 | let dropScope = this.droppableScope;
|
---|
942 | if (dropScope) {
|
---|
943 | if (typeof dropScope === 'string') {
|
---|
944 | if (typeof dragScope === 'string')
|
---|
945 | return dropScope === dragScope;
|
---|
946 | else if (dragScope instanceof Array)
|
---|
947 | return dragScope.indexOf(dropScope) != -1;
|
---|
948 | }
|
---|
949 | else if (dropScope instanceof Array) {
|
---|
950 | if (typeof dragScope === 'string') {
|
---|
951 | return dropScope.indexOf(dragScope) != -1;
|
---|
952 | }
|
---|
953 | else if (dragScope instanceof Array) {
|
---|
954 | for (let s of dropScope) {
|
---|
955 | for (let ds of dragScope) {
|
---|
956 | if (s === ds) {
|
---|
957 | return true;
|
---|
958 | }
|
---|
959 | }
|
---|
960 | }
|
---|
961 | }
|
---|
962 | }
|
---|
963 | return false;
|
---|
964 | }
|
---|
965 | else {
|
---|
966 | return true;
|
---|
967 | }
|
---|
968 | }
|
---|
969 | _filter(value) {
|
---|
970 | let filterValue = value;
|
---|
971 | if (filterValue === '') {
|
---|
972 | this.filteredNodes = null;
|
---|
973 | }
|
---|
974 | else {
|
---|
975 | this.filteredNodes = [];
|
---|
976 | const searchFields = this.filterBy.split(',');
|
---|
977 | const filterText = ObjectUtils.removeAccents(filterValue).toLocaleLowerCase(this.filterLocale);
|
---|
978 | const isStrictMode = this.filterMode === 'strict';
|
---|
979 | for (let node of this.value) {
|
---|
980 | let copyNode = { ...node };
|
---|
981 | let paramsWithoutNode = { searchFields, filterText, isStrictMode };
|
---|
982 | if ((isStrictMode && (this.findFilteredNodes(copyNode, paramsWithoutNode) || this.isFilterMatched(copyNode, paramsWithoutNode))) ||
|
---|
983 | (!isStrictMode && (this.isFilterMatched(copyNode, paramsWithoutNode) || this.findFilteredNodes(copyNode, paramsWithoutNode)))) {
|
---|
984 | this.filteredNodes.push(copyNode);
|
---|
985 | }
|
---|
986 | }
|
---|
987 | }
|
---|
988 | this.updateSerializedValue();
|
---|
989 | this.onFilter.emit({
|
---|
990 | filter: filterValue,
|
---|
991 | filteredValue: this.filteredNodes
|
---|
992 | });
|
---|
993 | }
|
---|
994 | resetFilter() {
|
---|
995 | this.filteredNodes = null;
|
---|
996 | if (this.filterViewChild && this.filterViewChild.nativeElement) {
|
---|
997 | this.filterViewChild.nativeElement.value = '';
|
---|
998 | }
|
---|
999 | }
|
---|
1000 | findFilteredNodes(node, paramsWithoutNode) {
|
---|
1001 | if (node) {
|
---|
1002 | let matched = false;
|
---|
1003 | if (node.children) {
|
---|
1004 | let childNodes = [...node.children];
|
---|
1005 | node.children = [];
|
---|
1006 | for (let childNode of childNodes) {
|
---|
1007 | let copyChildNode = { ...childNode };
|
---|
1008 | if (this.isFilterMatched(copyChildNode, paramsWithoutNode)) {
|
---|
1009 | matched = true;
|
---|
1010 | node.children.push(copyChildNode);
|
---|
1011 | }
|
---|
1012 | }
|
---|
1013 | }
|
---|
1014 | if (matched) {
|
---|
1015 | node.expanded = true;
|
---|
1016 | return true;
|
---|
1017 | }
|
---|
1018 | }
|
---|
1019 | }
|
---|
1020 | isFilterMatched(node, { searchFields, filterText, isStrictMode }) {
|
---|
1021 | let matched = false;
|
---|
1022 | for (let field of searchFields) {
|
---|
1023 | let fieldValue = ObjectUtils.removeAccents(String(ObjectUtils.resolveFieldData(node, field))).toLocaleLowerCase(this.filterLocale);
|
---|
1024 | if (fieldValue.indexOf(filterText) > -1) {
|
---|
1025 | matched = true;
|
---|
1026 | }
|
---|
1027 | }
|
---|
1028 | if (!matched || (isStrictMode && !this.isNodeLeaf(node))) {
|
---|
1029 | matched = this.findFilteredNodes(node, { searchFields, filterText, isStrictMode }) || matched;
|
---|
1030 | }
|
---|
1031 | return matched;
|
---|
1032 | }
|
---|
1033 | getBlockableElement() {
|
---|
1034 | return this.el.nativeElement.children[0];
|
---|
1035 | }
|
---|
1036 | ngOnDestroy() {
|
---|
1037 | if (this.dragStartSubscription) {
|
---|
1038 | this.dragStartSubscription.unsubscribe();
|
---|
1039 | }
|
---|
1040 | if (this.dragStopSubscription) {
|
---|
1041 | this.dragStopSubscription.unsubscribe();
|
---|
1042 | }
|
---|
1043 | }
|
---|
1044 | }
|
---|
1045 | Tree.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Tree, deps: [{ token: i0.ElementRef }, { token: i3.TreeDragDropService, optional: true }, { token: i3.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
|
---|
1046 | Tree.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: Tree, selector: "p-tree", inputs: { value: "value", selectionMode: "selectionMode", selection: "selection", style: "style", styleClass: "styleClass", contextMenu: "contextMenu", layout: "layout", draggableScope: "draggableScope", droppableScope: "droppableScope", draggableNodes: "draggableNodes", droppableNodes: "droppableNodes", metaKeySelection: "metaKeySelection", propagateSelectionUp: "propagateSelectionUp", propagateSelectionDown: "propagateSelectionDown", loading: "loading", loadingIcon: "loadingIcon", emptyMessage: "emptyMessage", ariaLabel: "ariaLabel", togglerAriaLabel: "togglerAriaLabel", ariaLabelledBy: "ariaLabelledBy", validateDrop: "validateDrop", filter: "filter", filterBy: "filterBy", filterMode: "filterMode", filterPlaceholder: "filterPlaceholder", filterLocale: "filterLocale", scrollHeight: "scrollHeight", virtualScroll: "virtualScroll", virtualNodeHeight: "virtualNodeHeight", minBufferPx: "minBufferPx", maxBufferPx: "maxBufferPx", indentation: "indentation", trackBy: "trackBy" }, outputs: { selectionChange: "selectionChange", onNodeSelect: "onNodeSelect", onNodeUnselect: "onNodeUnselect", onNodeExpand: "onNodeExpand", onNodeCollapse: "onNodeCollapse", onNodeContextMenuSelect: "onNodeContextMenuSelect", onNodeDrop: "onNodeDrop", onFilter: "onFilter" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "virtualScrollBody", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "filterViewChild", first: true, predicate: ["filter"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
|
---|
1047 | <div [ngClass]="{'p-tree p-component':true,'p-tree-selectable':selectionMode,
|
---|
1048 | 'p-treenode-dragover':dragHover,'p-tree-loading': loading, 'p-tree-flex-scrollable': scrollHeight === 'flex'}"
|
---|
1049 | [ngStyle]="style" [class]="styleClass" *ngIf="!horizontal"
|
---|
1050 | (drop)="onDrop($event)" (dragover)="onDragOver($event)" (dragenter)="onDragEnter()" (dragleave)="onDragLeave($event)">
|
---|
1051 | <div class="p-tree-loading-overlay p-component-overlay" *ngIf="loading">
|
---|
1052 | <i [class]="'p-tree-loading-icon pi-spin ' + loadingIcon"></i>
|
---|
1053 | </div>
|
---|
1054 | <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
---|
1055 | <div *ngIf="filter" class="p-tree-filter-container">
|
---|
1056 | <input #filter type="text" autocomplete="off" class="p-tree-filter p-inputtext p-component" [attr.placeholder]="filterPlaceholder"
|
---|
1057 | (keydown.enter)="$event.preventDefault()" (input)="_filter($event.target.value)">
|
---|
1058 | <span class="p-tree-filter-icon pi pi-search"></span>
|
---|
1059 | </div>
|
---|
1060 | <ng-container *ngIf="!virtualScroll; else virtualScrollList">
|
---|
1061 | <div class="p-tree-wrapper" [style.max-height]="scrollHeight">
|
---|
1062 | <ul class="p-tree-container" *ngIf="getRootNode()" role="tree" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy">
|
---|
1063 | <p-treeNode *ngFor="let node of getRootNode(); let firstChild=first;let lastChild=last; let index=index; trackBy: trackBy" [node]="node"
|
---|
1064 | [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [level]="0"></p-treeNode>
|
---|
1065 | </ul>
|
---|
1066 | </div>
|
---|
1067 | </ng-container>
|
---|
1068 | <ng-template #virtualScrollList>
|
---|
1069 | <cdk-virtual-scroll-viewport class="p-tree-wrapper" [style.height]="scrollHeight" [itemSize]="virtualNodeHeight" [minBufferPx]="minBufferPx" [maxBufferPx]="maxBufferPx">
|
---|
1070 | <ul class="p-tree-container" *ngIf="getRootNode()" role="tree" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy">
|
---|
1071 | <p-treeNode *cdkVirtualFor="let rowNode of serializedValue; let firstChild=first; let lastChild=last; let index=index; trackBy: trackBy; templateCacheSize: 0" [level]="rowNode.level"
|
---|
1072 | [rowNode]="rowNode" [node]="rowNode.node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [style.height.px]="virtualNodeHeight" [indentation]="indentation"></p-treeNode>
|
---|
1073 | </ul>
|
---|
1074 | </cdk-virtual-scroll-viewport>
|
---|
1075 | </ng-template>
|
---|
1076 | <div class="p-tree-empty-message" *ngIf="!loading && (getRootNode() == null || getRootNode().length === 0)">
|
---|
1077 | <ng-container *ngIf="!emptyMessageTemplate; else emptyFilter">
|
---|
1078 | {{emptyMessageLabel}}
|
---|
1079 | </ng-container>
|
---|
1080 | <ng-container #emptyFilter *ngTemplateOutlet="emptyMessageTemplate"></ng-container>
|
---|
1081 | </div>
|
---|
1082 | <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
---|
1083 | </div>
|
---|
1084 | <div [ngClass]="{'p-tree p-tree-horizontal p-component':true,'p-tree-selectable':selectionMode}" [ngStyle]="style" [class]="styleClass" *ngIf="horizontal">
|
---|
1085 | <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
---|
1086 | <div class="p-tree-loading-mask p-component-overlay" *ngIf="loading">
|
---|
1087 | <i [class]="'p-tree-loading-icon pi-spin ' + loadingIcon"></i>
|
---|
1088 | </div>
|
---|
1089 | <table *ngIf="value&&value[0]">
|
---|
1090 | <p-treeNode [node]="value[0]" [root]="true"></p-treeNode>
|
---|
1091 | </table>
|
---|
1092 | <div class="p-tree-empty-message" *ngIf="!loading && (getRootNode() == null || getRootNode().length === 0)">
|
---|
1093 | <ng-container *ngIf="!emptyMessageTemplate; else emptyFilter">
|
---|
1094 | {{emptyMessageLabel}}
|
---|
1095 | </ng-container>
|
---|
1096 | <ng-container #emptyFilter *ngTemplateOutlet="emptyMessageTemplate"></ng-container>
|
---|
1097 | </div>
|
---|
1098 | <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
---|
1099 | </div>
|
---|
1100 | `, isInline: true, styles: [".p-tree-container{margin:0;padding:0;list-style-type:none;overflow:auto}.p-treenode-children{margin:0;padding:0;list-style-type:none}.p-tree-wrapper{overflow:auto}.p-treenode-selectable{cursor:pointer;-webkit-user-select:none;-ms-user-select:none;user-select:none}.p-tree-toggler{cursor:pointer;-webkit-user-select:none;-ms-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.p-treenode-leaf>.p-treenode-content .p-tree-toggler{visibility:hidden}.p-treenode-content{display:flex;align-items:center}.p-tree-filter{width:100%}.p-tree-filter-container{position:relative;display:block;width:100%}.p-tree-filter-icon{position:absolute;top:50%;margin-top:-.5rem}.p-tree-loading{position:relative;min-height:4rem}.p-tree .p-tree-loading-overlay{position:absolute;display:flex;align-items:center;justify-content:center;z-index:2}.p-tree-flex-scrollable{display:flex;flex:1;height:100%;flex-direction:column}.p-tree-flex-scrollable .p-tree-wrapper{flex:1}.p-tree .p-treenode-droppoint{height:4px;list-style-type:none}.p-tree .p-treenode-droppoint-active{border:0 none}.p-tree-horizontal{width:auto;padding-left:0;padding-right:0;overflow:auto}.p-tree.p-tree-horizontal table,.p-tree.p-tree-horizontal tr,.p-tree.p-tree-horizontal td{border-collapse:collapse;margin:0;padding:0;vertical-align:middle}.p-tree-horizontal .p-treenode-content{font-weight:normal;padding:.4em 1em .4em .2em;display:flex;align-items:center}.p-tree-horizontal .p-treenode-parent .p-treenode-content{font-weight:normal;white-space:nowrap}.p-tree.p-tree-horizontal .p-treenode{background:url() repeat-x scroll center center transparent;padding:.25rem 2.5rem}.p-tree.p-tree-horizontal .p-treenode.p-treenode-leaf,.p-tree.p-tree-horizontal .p-treenode.p-treenode-collapsed{padding-right:0}.p-tree.p-tree-horizontal .p-treenode-children{padding:0;margin:0}.p-tree.p-tree-horizontal .p-treenode-connector{width:1px}.p-tree.p-tree-horizontal .p-treenode-connector-table{height:100%;width:1px}.p-tree.p-tree-horizontal .p-treenode-connector-line{background:url() repeat-y scroll 0 0 transparent;width:1px}.p-tree.p-tree-horizontal table{height:0}\n"], components: [{ type: UITreeNode, selector: "p-treeNode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation"] }, { type: i4.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { type: i4.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
---|
1101 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Tree, decorators: [{
|
---|
1102 | type: Component,
|
---|
1103 | args: [{ selector: 'p-tree', template: `
|
---|
1104 | <div [ngClass]="{'p-tree p-component':true,'p-tree-selectable':selectionMode,
|
---|
1105 | 'p-treenode-dragover':dragHover,'p-tree-loading': loading, 'p-tree-flex-scrollable': scrollHeight === 'flex'}"
|
---|
1106 | [ngStyle]="style" [class]="styleClass" *ngIf="!horizontal"
|
---|
1107 | (drop)="onDrop($event)" (dragover)="onDragOver($event)" (dragenter)="onDragEnter()" (dragleave)="onDragLeave($event)">
|
---|
1108 | <div class="p-tree-loading-overlay p-component-overlay" *ngIf="loading">
|
---|
1109 | <i [class]="'p-tree-loading-icon pi-spin ' + loadingIcon"></i>
|
---|
1110 | </div>
|
---|
1111 | <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
---|
1112 | <div *ngIf="filter" class="p-tree-filter-container">
|
---|
1113 | <input #filter type="text" autocomplete="off" class="p-tree-filter p-inputtext p-component" [attr.placeholder]="filterPlaceholder"
|
---|
1114 | (keydown.enter)="$event.preventDefault()" (input)="_filter($event.target.value)">
|
---|
1115 | <span class="p-tree-filter-icon pi pi-search"></span>
|
---|
1116 | </div>
|
---|
1117 | <ng-container *ngIf="!virtualScroll; else virtualScrollList">
|
---|
1118 | <div class="p-tree-wrapper" [style.max-height]="scrollHeight">
|
---|
1119 | <ul class="p-tree-container" *ngIf="getRootNode()" role="tree" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy">
|
---|
1120 | <p-treeNode *ngFor="let node of getRootNode(); let firstChild=first;let lastChild=last; let index=index; trackBy: trackBy" [node]="node"
|
---|
1121 | [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [level]="0"></p-treeNode>
|
---|
1122 | </ul>
|
---|
1123 | </div>
|
---|
1124 | </ng-container>
|
---|
1125 | <ng-template #virtualScrollList>
|
---|
1126 | <cdk-virtual-scroll-viewport class="p-tree-wrapper" [style.height]="scrollHeight" [itemSize]="virtualNodeHeight" [minBufferPx]="minBufferPx" [maxBufferPx]="maxBufferPx">
|
---|
1127 | <ul class="p-tree-container" *ngIf="getRootNode()" role="tree" [attr.aria-label]="ariaLabel" [attr.aria-labelledby]="ariaLabelledBy">
|
---|
1128 | <p-treeNode *cdkVirtualFor="let rowNode of serializedValue; let firstChild=first; let lastChild=last; let index=index; trackBy: trackBy; templateCacheSize: 0" [level]="rowNode.level"
|
---|
1129 | [rowNode]="rowNode" [node]="rowNode.node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="index" [style.height.px]="virtualNodeHeight" [indentation]="indentation"></p-treeNode>
|
---|
1130 | </ul>
|
---|
1131 | </cdk-virtual-scroll-viewport>
|
---|
1132 | </ng-template>
|
---|
1133 | <div class="p-tree-empty-message" *ngIf="!loading && (getRootNode() == null || getRootNode().length === 0)">
|
---|
1134 | <ng-container *ngIf="!emptyMessageTemplate; else emptyFilter">
|
---|
1135 | {{emptyMessageLabel}}
|
---|
1136 | </ng-container>
|
---|
1137 | <ng-container #emptyFilter *ngTemplateOutlet="emptyMessageTemplate"></ng-container>
|
---|
1138 | </div>
|
---|
1139 | <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
---|
1140 | </div>
|
---|
1141 | <div [ngClass]="{'p-tree p-tree-horizontal p-component':true,'p-tree-selectable':selectionMode}" [ngStyle]="style" [class]="styleClass" *ngIf="horizontal">
|
---|
1142 | <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
|
---|
1143 | <div class="p-tree-loading-mask p-component-overlay" *ngIf="loading">
|
---|
1144 | <i [class]="'p-tree-loading-icon pi-spin ' + loadingIcon"></i>
|
---|
1145 | </div>
|
---|
1146 | <table *ngIf="value&&value[0]">
|
---|
1147 | <p-treeNode [node]="value[0]" [root]="true"></p-treeNode>
|
---|
1148 | </table>
|
---|
1149 | <div class="p-tree-empty-message" *ngIf="!loading && (getRootNode() == null || getRootNode().length === 0)">
|
---|
1150 | <ng-container *ngIf="!emptyMessageTemplate; else emptyFilter">
|
---|
1151 | {{emptyMessageLabel}}
|
---|
1152 | </ng-container>
|
---|
1153 | <ng-container #emptyFilter *ngTemplateOutlet="emptyMessageTemplate"></ng-container>
|
---|
1154 | </div>
|
---|
1155 | <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
|
---|
1156 | </div>
|
---|
1157 | `, changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, host: {
|
---|
1158 | 'class': 'p-element'
|
---|
1159 | }, styles: [".p-tree-container{margin:0;padding:0;list-style-type:none;overflow:auto}.p-treenode-children{margin:0;padding:0;list-style-type:none}.p-tree-wrapper{overflow:auto}.p-treenode-selectable{cursor:pointer;-webkit-user-select:none;-ms-user-select:none;user-select:none}.p-tree-toggler{cursor:pointer;-webkit-user-select:none;-ms-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.p-treenode-leaf>.p-treenode-content .p-tree-toggler{visibility:hidden}.p-treenode-content{display:flex;align-items:center}.p-tree-filter{width:100%}.p-tree-filter-container{position:relative;display:block;width:100%}.p-tree-filter-icon{position:absolute;top:50%;margin-top:-.5rem}.p-tree-loading{position:relative;min-height:4rem}.p-tree .p-tree-loading-overlay{position:absolute;display:flex;align-items:center;justify-content:center;z-index:2}.p-tree-flex-scrollable{display:flex;flex:1;height:100%;flex-direction:column}.p-tree-flex-scrollable .p-tree-wrapper{flex:1}.p-tree .p-treenode-droppoint{height:4px;list-style-type:none}.p-tree .p-treenode-droppoint-active{border:0 none}.p-tree-horizontal{width:auto;padding-left:0;padding-right:0;overflow:auto}.p-tree.p-tree-horizontal table,.p-tree.p-tree-horizontal tr,.p-tree.p-tree-horizontal td{border-collapse:collapse;margin:0;padding:0;vertical-align:middle}.p-tree-horizontal .p-treenode-content{font-weight:normal;padding:.4em 1em .4em .2em;display:flex;align-items:center}.p-tree-horizontal .p-treenode-parent .p-treenode-content{font-weight:normal;white-space:nowrap}.p-tree.p-tree-horizontal .p-treenode{background:url() repeat-x scroll center center transparent;padding:.25rem 2.5rem}.p-tree.p-tree-horizontal .p-treenode.p-treenode-leaf,.p-tree.p-tree-horizontal .p-treenode.p-treenode-collapsed{padding-right:0}.p-tree.p-tree-horizontal .p-treenode-children{padding:0;margin:0}.p-tree.p-tree-horizontal .p-treenode-connector{width:1px}.p-tree.p-tree-horizontal .p-treenode-connector-table{height:100%;width:1px}.p-tree.p-tree-horizontal .p-treenode-connector-line{background:url() repeat-y scroll 0 0 transparent;width:1px}.p-tree.p-tree-horizontal table{height:0}\n"] }]
|
---|
1160 | }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i3.TreeDragDropService, decorators: [{
|
---|
1161 | type: Optional
|
---|
1162 | }] }, { type: i3.PrimeNGConfig }]; }, propDecorators: { value: [{
|
---|
1163 | type: Input
|
---|
1164 | }], selectionMode: [{
|
---|
1165 | type: Input
|
---|
1166 | }], selection: [{
|
---|
1167 | type: Input
|
---|
1168 | }], selectionChange: [{
|
---|
1169 | type: Output
|
---|
1170 | }], onNodeSelect: [{
|
---|
1171 | type: Output
|
---|
1172 | }], onNodeUnselect: [{
|
---|
1173 | type: Output
|
---|
1174 | }], onNodeExpand: [{
|
---|
1175 | type: Output
|
---|
1176 | }], onNodeCollapse: [{
|
---|
1177 | type: Output
|
---|
1178 | }], onNodeContextMenuSelect: [{
|
---|
1179 | type: Output
|
---|
1180 | }], onNodeDrop: [{
|
---|
1181 | type: Output
|
---|
1182 | }], style: [{
|
---|
1183 | type: Input
|
---|
1184 | }], styleClass: [{
|
---|
1185 | type: Input
|
---|
1186 | }], contextMenu: [{
|
---|
1187 | type: Input
|
---|
1188 | }], layout: [{
|
---|
1189 | type: Input
|
---|
1190 | }], draggableScope: [{
|
---|
1191 | type: Input
|
---|
1192 | }], droppableScope: [{
|
---|
1193 | type: Input
|
---|
1194 | }], draggableNodes: [{
|
---|
1195 | type: Input
|
---|
1196 | }], droppableNodes: [{
|
---|
1197 | type: Input
|
---|
1198 | }], metaKeySelection: [{
|
---|
1199 | type: Input
|
---|
1200 | }], propagateSelectionUp: [{
|
---|
1201 | type: Input
|
---|
1202 | }], propagateSelectionDown: [{
|
---|
1203 | type: Input
|
---|
1204 | }], loading: [{
|
---|
1205 | type: Input
|
---|
1206 | }], loadingIcon: [{
|
---|
1207 | type: Input
|
---|
1208 | }], emptyMessage: [{
|
---|
1209 | type: Input
|
---|
1210 | }], ariaLabel: [{
|
---|
1211 | type: Input
|
---|
1212 | }], togglerAriaLabel: [{
|
---|
1213 | type: Input
|
---|
1214 | }], ariaLabelledBy: [{
|
---|
1215 | type: Input
|
---|
1216 | }], validateDrop: [{
|
---|
1217 | type: Input
|
---|
1218 | }], filter: [{
|
---|
1219 | type: Input
|
---|
1220 | }], filterBy: [{
|
---|
1221 | type: Input
|
---|
1222 | }], filterMode: [{
|
---|
1223 | type: Input
|
---|
1224 | }], filterPlaceholder: [{
|
---|
1225 | type: Input
|
---|
1226 | }], filterLocale: [{
|
---|
1227 | type: Input
|
---|
1228 | }], scrollHeight: [{
|
---|
1229 | type: Input
|
---|
1230 | }], virtualScroll: [{
|
---|
1231 | type: Input
|
---|
1232 | }], virtualNodeHeight: [{
|
---|
1233 | type: Input
|
---|
1234 | }], minBufferPx: [{
|
---|
1235 | type: Input
|
---|
1236 | }], maxBufferPx: [{
|
---|
1237 | type: Input
|
---|
1238 | }], indentation: [{
|
---|
1239 | type: Input
|
---|
1240 | }], trackBy: [{
|
---|
1241 | type: Input
|
---|
1242 | }], onFilter: [{
|
---|
1243 | type: Output
|
---|
1244 | }], templates: [{
|
---|
1245 | type: ContentChildren,
|
---|
1246 | args: [PrimeTemplate]
|
---|
1247 | }], virtualScrollBody: [{
|
---|
1248 | type: ViewChild,
|
---|
1249 | args: [CdkVirtualScrollViewport]
|
---|
1250 | }], filterViewChild: [{
|
---|
1251 | type: ViewChild,
|
---|
1252 | args: ['filter']
|
---|
1253 | }] } });
|
---|
1254 | class TreeModule {
|
---|
1255 | }
|
---|
1256 | TreeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
---|
1257 | TreeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, declarations: [Tree, UITreeNode], imports: [CommonModule, ScrollingModule, RippleModule], exports: [Tree, SharedModule, ScrollingModule] });
|
---|
1258 | TreeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, imports: [[CommonModule, ScrollingModule, RippleModule], SharedModule, ScrollingModule] });
|
---|
1259 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, decorators: [{
|
---|
1260 | type: NgModule,
|
---|
1261 | args: [{
|
---|
1262 | imports: [CommonModule, ScrollingModule, RippleModule],
|
---|
1263 | exports: [Tree, SharedModule, ScrollingModule],
|
---|
1264 | declarations: [Tree, UITreeNode]
|
---|
1265 | }]
|
---|
1266 | }] });
|
---|
1267 |
|
---|
1268 | /**
|
---|
1269 | * Generated bundle index. Do not edit.
|
---|
1270 | */
|
---|
1271 |
|
---|
1272 | export { Tree, TreeModule, UITreeNode };
|
---|