source: trip-planner-front/node_modules/primeng/fesm2020/primeng-tree.mjs@ 8d391a1

Last change on this file since 8d391a1 was 59329aa, checked in by Ema <ema_spirova@…>, 3 years ago

adding photos

  • Property mode set to 100644
File size: 136.2 KB
RevLine 
[59329aa]1import * as i0 from '@angular/core';
2import { forwardRef, Component, ViewEncapsulation, Inject, Input, EventEmitter, ChangeDetectionStrategy, Optional, Output, ContentChildren, ViewChild, NgModule } from '@angular/core';
3import * as i4 from '@angular/cdk/scrolling';
4import { CdkVirtualScrollViewport, ScrollingModule } from '@angular/cdk/scrolling';
5import * as i1 from '@angular/common';
6import { CommonModule } from '@angular/common';
7import * as i3 from 'primeng/api';
8import { TranslationKeys, PrimeTemplate, SharedModule } from 'primeng/api';
9import { ObjectUtils } from 'primeng/utils';
10import { DomHandler } from 'primeng/dom';
11import * as i2 from 'primeng/ripple';
12import { RippleModule } from 'primeng/ripple';
13
14class 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}
345UITreeNode.ICON_CLASS = 'p-treenode-icon ';
346UITreeNode.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: UITreeNode, deps: [{ token: forwardRef(() => Tree) }], target: i0.ɵɵFactoryTarget.Component });
347UITreeNode.ɵ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 });
419i0.ɵɵ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 }] } });
522class 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}
1045Tree.ɵ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 });
1046Tree.ɵ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 });
1101i0.ɵɵ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 }] } });
1254class TreeModule {
1255}
1256TreeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1257TreeModule.ɵ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] });
1258TreeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TreeModule, imports: [[CommonModule, ScrollingModule, RippleModule], SharedModule, ScrollingModule] });
1259i0.ɵɵ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
1272export { Tree, TreeModule, UITreeNode };
Note: See TracBrowser for help on using the repository browser.