igniteui-angular 13.2.3 → 13.2.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -114,6 +114,7 @@ export class IgxSplitterComponent {
114
114
  set type(value) {
115
115
  this._type = value;
116
116
  this.resetPaneSizes();
117
+ this.panes?.notifyOnChanges();
117
118
  }
118
119
  /**
119
120
  * @hidden @internal
@@ -218,7 +219,17 @@ export class IgxSplitterComponent {
218
219
  * This method inits panes with properties.
219
220
  */
220
221
  initPanes() {
221
- this.panes.forEach(pane => pane.owner = this);
222
+ this.panes.forEach(pane => {
223
+ pane.owner = this;
224
+ if (this.type === SplitterType.Horizontal) {
225
+ pane.minWidth = pane.minSize ?? '0';
226
+ pane.maxWidth = pane.maxSize ?? '100%';
227
+ }
228
+ else {
229
+ pane.minHeight = pane.minSize ?? '0';
230
+ pane.maxHeight = pane.maxSize ?? '100%';
231
+ }
232
+ });
222
233
  this.assignFlexOrder();
223
234
  if (this.panes.filter(x => x.collapsed).length > 0) {
224
235
  // if any panes are collapsed, reset sizes.
@@ -232,7 +243,13 @@ export class IgxSplitterComponent {
232
243
  resetPaneSizes() {
233
244
  if (this.panes) {
234
245
  // if type is changed runtime, should reset sizes.
235
- this.panes.forEach(x => x.size = 'auto');
246
+ this.panes.forEach(x => {
247
+ x.size = 'auto';
248
+ x.minWidth = '0';
249
+ x.maxWidth = '100%';
250
+ x.minHeight = '0';
251
+ x.maxHeight = '100%';
252
+ });
236
253
  }
237
254
  }
238
255
  /**
@@ -509,4 +526,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
509
526
  type: HostListener,
510
527
  args: ['keydown', ['$event']]
511
528
  }] } });
512
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.ts","../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.html","../../../../../projects/igniteui-angular/src/lib/splitter/splitter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, QueryList } from '@angular/core';\nimport { DragDirection, IDragMoveEventArgs, IDragStartEventArgs } from '../directives/drag-drop/drag-drop.directive';\nimport { IgxSplitterPaneComponent } from './splitter-pane/splitter-pane.component';\n\n/**\n * An enumeration that defines the `SplitterComponent` panes orientation.\n */\nexport enum SplitterType {\n    Horizontal,\n    Vertical\n}\n\nexport declare interface ISplitterBarResizeEventArgs {\n    pane: IgxSplitterPaneComponent;\n    sibling: IgxSplitterPaneComponent;\n}\n\n/**\n * Provides a framework for a simple layout, splitting the view horizontally or vertically\n * into multiple smaller resizable and collapsible areas.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent Layouts\n *\n * @igxTheme igx-splitter-theme\n *\n * @igxKeywords splitter panes layout\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <igx-splitter>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n * </igx-splitter>\n * ```\n */\n@Component({\n    selector: 'igx-splitter',\n    templateUrl: './splitter.component.html'\n})\nexport class IgxSplitterComponent implements AfterContentInit {\n    /**\n     * Gets the list of splitter panes.\n     *\n     * @example\n     * ```typescript\n     * const panes = this.splitter.panes;\n     * ```\n     */\n    @ContentChildren(IgxSplitterPaneComponent, { read: IgxSplitterPaneComponent })\n    public panes!: QueryList<IgxSplitterPaneComponent>;\n\n     /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('class.igx-splitter')\n    public cssClass = 'igx-splitter';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow` property of the current splitter.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'hidden';\n\n    /**\n     * @hidden @internal\n     * Sets/Gets the `display` property of the current splitter.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * Event fired when resizing of panes starts.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeStart)='resizeStart($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeStart = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    /**\n     * Event fired when resizing of panes is in progress.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizing)='resizing($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizing = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n\n    /**\n     * Event fired when resizing of panes ends.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeEnd)='resizeEnd($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeEnd = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    private _type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the main `IgxSplitterPaneComponent` in each pair of panes divided by a splitter bar.\n     */\n    private initialPaneSize!: number;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the sibling pane in each pair of panes divided by a gripper.\n     * @memberof SplitterComponent\n     */\n    private initialSiblingSize!: number;\n\n    /**\n     * @hidden @internal\n     * The main pane in each pair of panes divided by a gripper.\n     */\n    private pane!: IgxSplitterPaneComponent;\n\n    /**\n     * The sibling pane in each pair of panes divided by a splitter bar.\n     */\n    private sibling!: IgxSplitterPaneComponent;\n\n    constructor(@Inject(DOCUMENT) public document, private elementRef: ElementRef) {}\n    /**\n     * Gets/Sets the splitter orientation.\n     *\n     * @example\n     * ```html\n     * <igx-splitter [type]=\"type\">...</igx-splitter>\n     * ```\n     */\n    @Input()\n    public get type() {\n        return this._type;\n    }\n    public set type(value) {\n        this._type = value;\n        this.resetPaneSizes();\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex-direction` property of the current `SplitterComponent`.\n     */\n    @HostBinding('style.flex-direction')\n    public get direction(): string {\n        return this.type === SplitterType.Horizontal ? 'row' : 'column';\n    }\n\n    /** @hidden @internal */\n    public ngAfterContentInit(): void {\n        this.initPanes();\n        this.panes.changes.subscribe(() => {\n            this.initPanes();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs  initialization logic when the user starts dragging the splitter bar between each pair of panes.\n     * @param pane - the main pane associated with the currently dragged bar.\n     */\n    public onMoveStart(pane: IgxSplitterPaneComponent) {\n        const panes = this.panes.toArray();\n        this.pane = pane;\n        this.sibling = panes[panes.indexOf(this.pane) + 1];\n\n        const paneRect = this.pane.element.getBoundingClientRect();\n        this.initialPaneSize = this.type === SplitterType.Horizontal ? paneRect.width : paneRect.height;\n\n        const siblingRect = this.sibling.element.getBoundingClientRect();\n        this.initialSiblingSize = this.type === SplitterType.Horizontal ? siblingRect.width : siblingRect.height;\n        const args: ISplitterBarResizeEventArgs = {pane: this.pane, sibling: this.sibling};\n        this.resizeStart.emit(args);\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs calculations concerning the sizes of each pair of panes when the bar between them is dragged.\n     * @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.\n     */\n    public onMoving(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        this.pane.dragSize = paneSize + 'px';\n        this.sibling.dragSize = siblingSize + 'px';\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizing.emit(args);\n    }\n\n    public onMoveEnd(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        if (this.pane.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentPaneSize = (paneSize / totalSize) * 100;\n            this.pane.size = percentPaneSize + '%';\n        } else {\n            // px resize\n            this.pane.size = paneSize + 'px';\n        }\n\n        if (this.sibling.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentSiblingPaneSize =  (siblingSize / totalSize) * 100;\n            this.sibling.size = percentSiblingPaneSize + '%';\n        } else {\n            // px resize\n            this.sibling.size = siblingSize + 'px';\n        }\n        this.pane.dragSize = null;\n        this.sibling.dragSize = null;\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeEnd.emit(args);\n    }\n\n    /** @hidden @internal */\n    public getPaneSiblingsByOrder(order: number, barIndex: number): Array<IgxSplitterPaneComponent> {\n        const panes = this.panes.toArray();\n        const prevPane = panes[order - barIndex - 1];\n        const nextPane = panes[order - barIndex];\n        const siblings = [prevPane, nextPane];\n        return siblings;\n    }\n\n    private getTotalSize() {\n        const computed = this.document.defaultView.getComputedStyle(this.elementRef.nativeElement);\n        const totalSize = this.type === SplitterType.Horizontal ? computed.getPropertyValue('width') : computed.getPropertyValue('height');\n        return parseFloat(totalSize);\n    }\n\n\n    /**\n     * @hidden @internal\n     * This method inits panes with properties.\n     */\n    private initPanes() {\n        this.panes.forEach(pane => pane.owner = this);\n        this.assignFlexOrder();\n        if (this.panes.filter(x => x.collapsed).length > 0) {\n            // if any panes are collapsed, reset sizes.\n            this.resetPaneSizes();\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method reset pane sizes.\n     */\n    private resetPaneSizes() {\n        if (this.panes) {\n            // if type is changed runtime, should reset sizes.\n            this.panes.forEach(x => x.size = 'auto');\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method assigns the order of each pane.\n     */\n    private assignFlexOrder() {\n        let k = 0;\n        this.panes.forEach((pane: IgxSplitterPaneComponent) => {\n            pane.order = k;\n            k += 2;\n        });\n    }\n}\n\nexport const SPLITTER_INTERACTION_KEYS = new Set('right down left up arrowright arrowdown arrowleft arrowup'.split(' '));\n\n/**\n * @hidden @internal\n * Represents the draggable bar that visually separates panes and allows for changing their sizes.\n */\n @Component({\n    selector: 'igx-splitter-bar',\n    templateUrl: './splitter-bar.component.html'\n})\nexport class IgxSplitBarComponent {\n    /**\n     * Set css class to the host element.\n     */\n    @HostBinding('class.igx-splitter-bar-host')\n    public cssClass = 'igx-splitter-bar-host';\n\n    /**\n     * Gets/Sets the orientation.\n     */\n    @Input()\n    public type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * Sets/gets the element order.\n     */\n    @HostBinding('style.order')\n    @Input()\n    public order!: number;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.tabindex')\n    public get tabindex() {\n        return this.resizeDisallowed ? null : 0;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get cursor() {\n        if (this.resizeDisallowed) {\n            return '';\n        }\n        return this.type === SplitterType.Horizontal ? 'col-resize' : 'row-resize';\n    }\n\n    /**\n     * Sets/gets the `SplitPaneComponent` associated with the current `SplitBarComponent`.\n     *\n     * @memberof SplitBarComponent\n     */\n    @Input()\n    public pane!: IgxSplitterPaneComponent;\n\n    /**\n     * Sets/Gets the `SplitPaneComponent` sibling components associated with the current `SplitBarComponent`.\n     */\n    @Input()\n    public siblings!: Array<IgxSplitterPaneComponent>;\n\n    /**\n     * An event that is emitted whenever we start dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moveStart = new EventEmitter<IgxSplitterPaneComponent>();\n\n    /**\n     * An event that is emitted while we are dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moving = new EventEmitter<number>();\n\n    @Output()\n    public movingEnd = new EventEmitter<number>();\n\n    /**\n     * A temporary holder for the pointer coordinates.\n     */\n    private startPoint!: number;\n\n    /**\n     * @hidden @internal\n     */\n    public get prevButtonHidden() {\n        return this.siblings[0].collapsed && !this.siblings[1].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostListener('keydown', ['$event'])\n    public keyEvent(event: KeyboardEvent) {\n        const key = event.key.toLowerCase();\n        const ctrl = event.ctrlKey;\n        event.stopPropagation();\n        if (SPLITTER_INTERACTION_KEYS.has(key)) {\n            event.preventDefault();\n        }\n            switch (key) {\n                case 'arrowup':\n                case 'up':\n                    if (this.type === SplitterType.Vertical) {\n                        if (ctrl) {\n                            this.onCollapsing(false);\n                            break;\n                        }\n                        if (!this.resizeDisallowed) {\n                            event.preventDefault();\n                            this.moveStart.emit(this.pane);\n                            this.moving.emit(10);\n                        }\n                    }\n                    break;\n                case 'arrowdown':\n                case 'down':\n                    if (this.type === SplitterType.Vertical) {\n                        if (ctrl) {\n                            this.onCollapsing(true);\n                            break;\n                        }\n                        if (!this.resizeDisallowed) {\n                            event.preventDefault();\n                            this.moveStart.emit(this.pane);\n                            this.moving.emit(-10);\n                        }\n                    }\n                    break;\n                case 'arrowleft':\n                case 'left':\n                    if (this.type === SplitterType.Horizontal) {\n                        if (ctrl) {\n                            this.onCollapsing(false);\n                            break;\n                        }\n                        if (!this.resizeDisallowed) {\n                            event.preventDefault();\n                            this.moveStart.emit(this.pane);\n                            this.moving.emit(10);\n                        }\n                    }\n                    break;\n                case 'arrowright':\n                case 'right':\n                    if (this.type === SplitterType.Horizontal) {\n                        if (ctrl) {\n                            this.onCollapsing(true);\n                            break;\n                        }\n                        if (!this.resizeDisallowed) {\n                            event.preventDefault();\n                            this.moveStart.emit(this.pane);\n                            this.moving.emit(-10);\n                        }\n                    }\n                    break;\n                default:\n                    break;\n            }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get dragDir() {\n        return this.type === SplitterType.Horizontal ? DragDirection.VERTICAL : DragDirection.HORIZONTAL;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get nextButtonHidden() {\n        return this.siblings[1].collapsed && !this.siblings[0].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragStart(event: IDragStartEventArgs) {\n        if (this.resizeDisallowed) {\n            event.cancel = true;\n            return;\n        }\n        this.startPoint = this.type === SplitterType.Horizontal ? event.startX : event.startY;\n        this.moveStart.emit(this.pane);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragMove(event: IDragMoveEventArgs) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr =  isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.moving.emit(delta);\n            event.cancel = true;\n            event.owner.element.nativeElement.style.transform = '';\n        }\n    }\n\n    public onDragEnd(event: any) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr =  isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.movingEnd.emit(delta);\n        }\n    }\n\n    protected get resizeDisallowed() {\n        const relatedTabs = this.siblings;\n        return !!relatedTabs.find(x => x.resizable === false || x.collapsed === true);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onCollapsing(next: boolean) {\n        const prevSibling = this.siblings[0];\n        const nextSibling = this.siblings[1];\n        let target;\n        if (next) {\n            // if next is clicked when prev pane is hidden, show prev pane, else hide next pane.\n            target = prevSibling.collapsed ? prevSibling : nextSibling;\n        } else {\n            // if prev is clicked when next pane is hidden, show next pane, else hide prev pane.\n            target = nextSibling.collapsed ? nextSibling : prevSibling;\n        }\n        target.toggle();\n    }\n}\n","<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n    <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n                    [type]=\"type\"\n                    [pane]=\"pane\"\n                    [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n                    (moveStart)=\"onMoveStart($event)\"\n                    (moving)=\"onMoving($event)\"\n                    (movingEnd)='onMoveEnd($event)'>\n    </igx-splitter-bar>\n</ng-container>\n","<div class=\"igx-splitter-bar\"\n    [class.igx-splitter-bar--vertical]='type === 0'\n    [style.cursor]='cursor'\n    igxDrag\n    [ghost]=\"false\"\n    [dragDirection]='dragDir'\n    (dragStart)='onDragStart($event)'\n    (dragMove)=\"onDragMove($event)\"\n    (dragEnd)=\"onDragEnd($event)\"\n>\n    <div class=\"igx-splitter-bar__expander--start\" igxDragIgnore (click)='onCollapsing(false)' [hidden]='prevButtonHidden'></div>\n    <div class=\"igx-splitter-bar__handle\" ></div>\n    <div class=\"igx-splitter-bar__expander--end\" igxDragIgnore (click)='onCollapsing(true)' [hidden]='nextButtonHidden'></div>\n</div>\n"]}
529
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.ts","../../../../../projects/igniteui-angular/src/lib/splitter/splitter.component.html","../../../../../projects/igniteui-angular/src/lib/splitter/splitter-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAoB,SAAS,EAAE,eAAe,EAAc,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAa,MAAM,eAAe,CAAC;AACpK,OAAO,EAAE,aAAa,EAA2C,MAAM,6CAA6C,CAAC;AACrH,OAAO,EAAE,wBAAwB,EAAE,MAAM,yCAAyC,CAAC;;;;AAEnF;;GAEG;AACH,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,2DAAU,CAAA;IACV,uDAAQ,CAAA;AACZ,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AAOD;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AAKH,MAAM,OAAO,oBAAoB;IA4G7B,YAAqC,QAAQ,EAAU,UAAsB;QAAxC,aAAQ,GAAR,QAAQ,CAAA;QAAU,eAAU,GAAV,UAAU,CAAY;QAhG7E;;;UAGE;QAEK,aAAQ,GAAG,cAAc,CAAC;QAEjC;;;WAGG;QAEI,aAAQ,GAAG,QAAQ,CAAC;QAE3B;;;WAGG;QAEI,YAAO,GAAG,MAAM,CAAC;QAWxB;;;;;;;;;WASG;QAEI,gBAAW,GAAG,IAAI,YAAY,EAA+B,CAAC;QAErE;;;;;;;;;WASG;QAEI,aAAQ,GAAG,IAAI,YAAY,EAA+B,CAAC;QAGlE;;;;;;;;;WASG;QAEI,cAAS,GAAG,IAAI,YAAY,EAA+B,CAAC;QAE3D,UAAK,GAAiB,YAAY,CAAC,UAAU,CAAC;IA0B2B,CAAC;IA3ElF;;;OAGG;IACH,IACW,WAAW;QAClB,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC;IAC7E,CAAC;IAqED;;;;;;;OAOG;IACH,IACW,IAAI;QACX,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAW,IAAI,CAAC,KAAK;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,KAAK,EAAE,eAAe,EAAE,CAAC;IAClC,CAAC;IAED;;;OAGG;IACH,IACW,SAAS;QAChB,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC;IACpE,CAAC;IAED,wBAAwB;IACjB,kBAAkB;QACrB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,SAAS,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,IAA8B;QAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAEnD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;QAC3D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC;QAEhG,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;QACjE,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC;QACzG,MAAM,IAAI,GAAgC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC;QACrF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,KAAa;QACzB,MAAM,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;QACjD,MAAM,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAC9F,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;QAC3D,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAExG,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC9C,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QACpD,IAAI,QAAQ,GAAG,GAAG,IAAI,QAAQ,GAAG,GAAG,IAAI,WAAW,GAAG,UAAU,IAAI,WAAW,GAAG,UAAU,EAAE;YAC1F,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,QAAQ,GAAG,IAAI,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,WAAW,GAAG,IAAI,CAAC;QAE3C,MAAM,IAAI,GAAgC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC;QACrF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAEM,SAAS,CAAC,KAAa;QAC1B,MAAM,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;QACjD,MAAM,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAC9F,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;QAC3D,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAExG,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC9C,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAEpD,IAAI,QAAQ,GAAG,GAAG,IAAI,QAAQ,GAAG,GAAG,IAAI,WAAW,GAAG,UAAU,IAAI,WAAW,GAAG,UAAU,EAAE;YAC1F,OAAO;SACV;QACD,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC5B,mBAAmB;YACnB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACtC,MAAM,eAAe,GAAG,CAAC,QAAQ,GAAG,SAAS,CAAC,GAAG,GAAG,CAAC;YACrD,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,eAAe,GAAG,GAAG,CAAC;SAC1C;aAAM;YACH,YAAY;YACZ,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,QAAQ,GAAG,IAAI,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE;YAC/B,mBAAmB;YACnB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACtC,MAAM,sBAAsB,GAAG,CAAC,WAAW,GAAG,SAAS,CAAC,GAAG,GAAG,CAAC;YAC/D,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,sBAAsB,GAAG,GAAG,CAAC;SACpD;aAAM;YACH,YAAY;YACZ,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,WAAW,GAAG,IAAI,CAAC;SAC1C;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;QAE7B,MAAM,IAAI,GAAgC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC;QACrF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,wBAAwB;IACjB,sBAAsB,CAAC,KAAa,EAAE,QAAgB;QACzD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC;QAC7C,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;QACzC,MAAM,QAAQ,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACtC,OAAO,QAAQ,CAAC;IACpB,CAAC;IAEO,YAAY;QAChB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QAC3F,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QACnI,OAAO,UAAU,CAAC,SAAS,CAAC,CAAC;IACjC,CAAC;IAGD;;;OAGG;IACK,SAAS;QACb,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,EAAE;gBACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,IAAI,GAAG,CAAC;gBACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,IAAI,MAAM,CAAC;aAC1C;iBAAM;gBACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,IAAI,GAAG,CAAC;gBACrC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,IAAI,MAAM,CAAC;aAC3C;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAChD,2CAA2C;YAC3C,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;IACL,CAAC;IAED;;;OAGG;IACK,cAAc;QAClB,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,kDAAkD;YAClD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACnB,CAAC,CAAC,IAAI,GAAG,MAAM,CAAA;gBACf,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC;gBACjB,CAAC,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACpB,CAAC,CAAC,SAAS,GAAG,GAAG,CAAC;gBAClB,CAAC,CAAC,SAAS,GAAG,MAAM,CAAC;YACzB,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;;OAGG;IACK,eAAe;QACnB,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAA8B,EAAE,EAAE;YAClD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,CAAC,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;;iHAjSQ,oBAAoB,kBA4GT,QAAQ;qGA5GnB,oBAAoB,uZASZ,wBAAwB,QAAU,wBAAwB,6BCzD/E,kkBAWA,0DDmVa,oBAAoB;2FA9SpB,oBAAoB;kBAJhC,SAAS;+BACI,cAAc;;0BA+GX,MAAM;2BAAC,QAAQ;qEAlGrB,KAAK;sBADX,eAAe;uBAAC,wBAAwB,EAAE,EAAE,IAAI,EAAE,wBAAwB,EAAE;gBAQtE,QAAQ;sBADd,WAAW;uBAAC,oBAAoB;gBAQ1B,QAAQ;sBADd,WAAW;uBAAC,gBAAgB;gBAQtB,OAAO;sBADb,WAAW;uBAAC,eAAe;gBAQjB,WAAW;sBADrB,WAAW;uBAAC,uBAAuB;gBAgB7B,WAAW;sBADjB,MAAM;gBAcA,QAAQ;sBADd,MAAM;gBAeA,SAAS;sBADf,MAAM;gBAuCI,IAAI;sBADd,KAAK;gBAeK,SAAS;sBADnB,WAAW;uBAAC,sBAAsB;;AAiKvC,MAAM,CAAC,MAAM,yBAAyB,GAAG,IAAI,GAAG,CAAC,2DAA2D,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;AAEzH;;;GAGG;AAKH,MAAM,OAAO,oBAAoB;IAJjC;QAKI;;WAEG;QAEI,aAAQ,GAAG,uBAAuB,CAAC;QAE1C;;WAEG;QAEI,SAAI,GAAiB,YAAY,CAAC,UAAU,CAAC;QAoDpD;;WAEG;QAEI,cAAS,GAAG,IAAI,YAAY,EAA4B,CAAC;QAEhE;;WAEG;QAEI,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QAGpC,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;KA6JjD;IArNG;;;OAGG;IACH,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED;;;OAGG;IACH,IACW,WAAW;QAClB,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC;IAC7E,CAAC;IAED;;;OAGG;IACH,IAAW,MAAM;QACb,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,OAAO,EAAE,CAAC;SACb;QACD,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC;IAC/E,CAAC;IAoCD;;OAEG;IACH,IAAW,gBAAgB;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAED;;OAEG;IAEI,QAAQ,CAAC,KAAoB;QAChC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC;QAC3B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,yBAAyB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACpC,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QACD,QAAQ,GAAG,EAAE;YACT,KAAK,SAAS,CAAC;YACf,KAAK,IAAI;gBACL,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,QAAQ,EAAE;oBACrC,IAAI,IAAI,EAAE;wBACN,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;wBACzB,MAAM;qBACT;oBACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;wBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;qBACxB;iBACJ;gBACD,MAAM;YACV,KAAK,WAAW,CAAC;YACjB,KAAK,MAAM;gBACP,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,QAAQ,EAAE;oBACrC,IAAI,IAAI,EAAE;wBACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;wBACxB,MAAM;qBACT;oBACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;wBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;qBACzB;iBACJ;gBACD,MAAM;YACV,KAAK,WAAW,CAAC;YACjB,KAAK,MAAM;gBACP,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,EAAE;oBACvC,IAAI,IAAI,EAAE;wBACN,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;wBACzB,MAAM;qBACT;oBACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;wBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;qBACxB;iBACJ;gBACD,MAAM;YACV,KAAK,YAAY,CAAC;YAClB,KAAK,OAAO;gBACR,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,EAAE;oBACvC,IAAI,IAAI,EAAE;wBACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;wBACxB,MAAM;qBACT;oBACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;wBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;qBACzB;iBACJ;gBACD,MAAM;YACV;gBACI,MAAM;SACb;IACL,CAAC;IAED;;OAEG;IACH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC;IACrG,CAAC;IAED;;OAEG;IACH,IAAW,gBAAgB;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAA0B;QACzC,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,OAAO;SACV;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;QACtF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAyB;QACvC,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC;QAC3D,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACrC,IAAI,KAAK,KAAK,CAAC,EAAE;YACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxB,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;SAC1D;IACL,CAAC;IAEM,SAAS,CAAC,KAAU;QACvB,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC;QAC3D,MAAM,IAAI,GAAG,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;QACtD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACrC,IAAI,KAAK,KAAK,CAAC,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC9B;IACL,CAAC;IAED,IAAc,gBAAgB;QAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;QAClC,OAAO,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,KAAK,IAAI,CAAC,CAAC,SAAS,KAAK,IAAI,CAAC,CAAC;IAClF,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,IAAa;QAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACrC,IAAI,MAAM,CAAC;QACX,IAAI,IAAI,EAAE;YACN,oFAAoF;YACpF,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC;SAC9D;aAAM;YACH,oFAAoF;YACpF,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC;SAC9D;QACD,MAAM,CAAC,MAAM,EAAE,CAAC;IACpB,CAAC;;iHAxOQ,oBAAoB;qGAApB,oBAAoB,ybE9VjC,knBAcA;2FFgVa,oBAAoB;kBAJhC,SAAS;+BACI,kBAAkB;8BAQrB,QAAQ;sBADd,WAAW;uBAAC,6BAA6B;gBAOnC,IAAI;sBADV,KAAK;gBAQC,KAAK;sBAFX,WAAW;uBAAC,aAAa;;sBACzB,KAAK;gBAQK,QAAQ;sBADlB,WAAW;uBAAC,eAAe;gBAUjB,WAAW;sBADrB,WAAW;uBAAC,uBAAuB;gBAsB7B,IAAI;sBADV,KAAK;gBAOC,QAAQ;sBADd,KAAK;gBAOC,SAAS;sBADf,MAAM;gBAOA,MAAM;sBADZ,MAAM;gBAIA,SAAS;sBADf,MAAM;gBAmBA,QAAQ;sBADd,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, QueryList } from '@angular/core';\nimport { DragDirection, IDragMoveEventArgs, IDragStartEventArgs } from '../directives/drag-drop/drag-drop.directive';\nimport { IgxSplitterPaneComponent } from './splitter-pane/splitter-pane.component';\n\n/**\n * An enumeration that defines the `SplitterComponent` panes orientation.\n */\nexport enum SplitterType {\n    Horizontal,\n    Vertical\n}\n\nexport declare interface ISplitterBarResizeEventArgs {\n    pane: IgxSplitterPaneComponent;\n    sibling: IgxSplitterPaneComponent;\n}\n\n/**\n * Provides a framework for a simple layout, splitting the view horizontally or vertically\n * into multiple smaller resizable and collapsible areas.\n *\n * @igxModule IgxSplitterModule\n *\n * @igxParent Layouts\n *\n * @igxTheme igx-splitter-theme\n *\n * @igxKeywords splitter panes layout\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <igx-splitter>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n *  <igx-splitter-pane>\n *      ...\n *  </igx-splitter-pane>\n * </igx-splitter>\n * ```\n */\n@Component({\n    selector: 'igx-splitter',\n    templateUrl: './splitter.component.html'\n})\nexport class IgxSplitterComponent implements AfterContentInit {\n    /**\n     * Gets the list of splitter panes.\n     *\n     * @example\n     * ```typescript\n     * const panes = this.splitter.panes;\n     * ```\n     */\n    @ContentChildren(IgxSplitterPaneComponent, { read: IgxSplitterPaneComponent })\n    public panes!: QueryList<IgxSplitterPaneComponent>;\n\n    /**\n    * @hidden\n    * @internal\n    */\n    @HostBinding('class.igx-splitter')\n    public cssClass = 'igx-splitter';\n\n    /**\n     * @hidden @internal\n     * Gets/Sets the `overflow` property of the current splitter.\n     */\n    @HostBinding('style.overflow')\n    public overflow = 'hidden';\n\n    /**\n     * @hidden @internal\n     * Sets/Gets the `display` property of the current splitter.\n     */\n    @HostBinding('style.display')\n    public display = 'flex';\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * Event fired when resizing of panes starts.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeStart)='resizeStart($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeStart = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    /**\n     * Event fired when resizing of panes is in progress.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizing)='resizing($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizing = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n\n    /**\n     * Event fired when resizing of panes ends.\n     *\n     * @example\n     * ```html\n     * <igx-splitter (resizeEnd)='resizeEnd($event)'>\n     *  <igx-splitter-pane>...</igx-splitter-pane>\n     * </igx-splitter>\n     * ```\n     */\n    @Output()\n    public resizeEnd = new EventEmitter<ISplitterBarResizeEventArgs>();\n\n    private _type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the main `IgxSplitterPaneComponent` in each pair of panes divided by a splitter bar.\n     */\n    private initialPaneSize!: number;\n\n    /**\n     * @hidden @internal\n     * A field that holds the initial size of the sibling pane in each pair of panes divided by a gripper.\n     * @memberof SplitterComponent\n     */\n    private initialSiblingSize!: number;\n\n    /**\n     * @hidden @internal\n     * The main pane in each pair of panes divided by a gripper.\n     */\n    private pane!: IgxSplitterPaneComponent;\n\n    /**\n     * The sibling pane in each pair of panes divided by a splitter bar.\n     */\n    private sibling!: IgxSplitterPaneComponent;\n\n    constructor(@Inject(DOCUMENT) public document, private elementRef: ElementRef) { }\n    /**\n     * Gets/Sets the splitter orientation.\n     *\n     * @example\n     * ```html\n     * <igx-splitter [type]=\"type\">...</igx-splitter>\n     * ```\n     */\n    @Input()\n    public get type() {\n        return this._type;\n    }\n    public set type(value) {\n        this._type = value;\n        this.resetPaneSizes();\n        this.panes?.notifyOnChanges();\n    }\n\n    /**\n     * @hidden @internal\n     * Gets the `flex-direction` property of the current `SplitterComponent`.\n     */\n    @HostBinding('style.flex-direction')\n    public get direction(): string {\n        return this.type === SplitterType.Horizontal ? 'row' : 'column';\n    }\n\n    /** @hidden @internal */\n    public ngAfterContentInit(): void {\n        this.initPanes();\n        this.panes.changes.subscribe(() => {\n            this.initPanes();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs  initialization logic when the user starts dragging the splitter bar between each pair of panes.\n     * @param pane - the main pane associated with the currently dragged bar.\n     */\n    public onMoveStart(pane: IgxSplitterPaneComponent) {\n        const panes = this.panes.toArray();\n        this.pane = pane;\n        this.sibling = panes[panes.indexOf(this.pane) + 1];\n\n        const paneRect = this.pane.element.getBoundingClientRect();\n        this.initialPaneSize = this.type === SplitterType.Horizontal ? paneRect.width : paneRect.height;\n\n        const siblingRect = this.sibling.element.getBoundingClientRect();\n        this.initialSiblingSize = this.type === SplitterType.Horizontal ? siblingRect.width : siblingRect.height;\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeStart.emit(args);\n    }\n\n    /**\n     * @hidden @internal\n     * This method performs calculations concerning the sizes of each pair of panes when the bar between them is dragged.\n     * @param delta - The difference along the X (or Y) axis between the initial and the current point when dragging the bar.\n     */\n    public onMoving(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        this.pane.dragSize = paneSize + 'px';\n        this.sibling.dragSize = siblingSize + 'px';\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizing.emit(args);\n    }\n\n    public onMoveEnd(delta: number) {\n        const min = parseInt(this.pane.minSize, 10) || 0;\n        const max = parseInt(this.pane.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n        const minSibling = parseInt(this.sibling.minSize, 10) || 0;\n        const maxSibling = parseInt(this.sibling.maxSize, 10) || this.initialPaneSize + this.initialSiblingSize;\n\n        const paneSize = this.initialPaneSize - delta;\n        const siblingSize = this.initialSiblingSize + delta;\n\n        if (paneSize < min || paneSize > max || siblingSize < minSibling || siblingSize > maxSibling) {\n            return;\n        }\n        if (this.pane.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentPaneSize = (paneSize / totalSize) * 100;\n            this.pane.size = percentPaneSize + '%';\n        } else {\n            // px resize\n            this.pane.size = paneSize + 'px';\n        }\n\n        if (this.sibling.isPercentageSize) {\n            // handle % resizes\n            const totalSize = this.getTotalSize();\n            const percentSiblingPaneSize = (siblingSize / totalSize) * 100;\n            this.sibling.size = percentSiblingPaneSize + '%';\n        } else {\n            // px resize\n            this.sibling.size = siblingSize + 'px';\n        }\n        this.pane.dragSize = null;\n        this.sibling.dragSize = null;\n\n        const args: ISplitterBarResizeEventArgs = { pane: this.pane, sibling: this.sibling };\n        this.resizeEnd.emit(args);\n    }\n\n    /** @hidden @internal */\n    public getPaneSiblingsByOrder(order: number, barIndex: number): Array<IgxSplitterPaneComponent> {\n        const panes = this.panes.toArray();\n        const prevPane = panes[order - barIndex - 1];\n        const nextPane = panes[order - barIndex];\n        const siblings = [prevPane, nextPane];\n        return siblings;\n    }\n\n    private getTotalSize() {\n        const computed = this.document.defaultView.getComputedStyle(this.elementRef.nativeElement);\n        const totalSize = this.type === SplitterType.Horizontal ? computed.getPropertyValue('width') : computed.getPropertyValue('height');\n        return parseFloat(totalSize);\n    }\n\n\n    /**\n     * @hidden @internal\n     * This method inits panes with properties.\n     */\n    private initPanes() {\n        this.panes.forEach(pane => {\n            pane.owner = this;\n            if (this.type === SplitterType.Horizontal) {\n                pane.minWidth = pane.minSize ?? '0';\n                pane.maxWidth = pane.maxSize ?? '100%';\n            } else {\n                pane.minHeight = pane.minSize ?? '0';\n                pane.maxHeight = pane.maxSize ?? '100%';\n            }\n        });\n        this.assignFlexOrder();\n        if (this.panes.filter(x => x.collapsed).length > 0) {\n            // if any panes are collapsed, reset sizes.\n            this.resetPaneSizes();\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method reset pane sizes.\n     */\n    private resetPaneSizes() {\n        if (this.panes) {\n            // if type is changed runtime, should reset sizes.\n            this.panes.forEach(x => {\n                x.size = 'auto'\n                x.minWidth = '0';\n                x.maxWidth = '100%';\n                x.minHeight = '0';\n                x.maxHeight = '100%';\n            });\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * This method assigns the order of each pane.\n     */\n    private assignFlexOrder() {\n        let k = 0;\n        this.panes.forEach((pane: IgxSplitterPaneComponent) => {\n            pane.order = k;\n            k += 2;\n        });\n    }\n}\n\nexport const SPLITTER_INTERACTION_KEYS = new Set('right down left up arrowright arrowdown arrowleft arrowup'.split(' '));\n\n/**\n * @hidden @internal\n * Represents the draggable bar that visually separates panes and allows for changing their sizes.\n */\n@Component({\n    selector: 'igx-splitter-bar',\n    templateUrl: './splitter-bar.component.html'\n})\nexport class IgxSplitBarComponent {\n    /**\n     * Set css class to the host element.\n     */\n    @HostBinding('class.igx-splitter-bar-host')\n    public cssClass = 'igx-splitter-bar-host';\n\n    /**\n     * Gets/Sets the orientation.\n     */\n    @Input()\n    public type: SplitterType = SplitterType.Horizontal;\n\n    /**\n     * Sets/gets the element order.\n     */\n    @HostBinding('style.order')\n    @Input()\n    public order!: number;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.tabindex')\n    public get tabindex() {\n        return this.resizeDisallowed ? null : 0;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostBinding('attr.aria-orientation')\n    public get orientation() {\n        return this.type === SplitterType.Horizontal ? 'horizontal' : 'vertical';\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get cursor() {\n        if (this.resizeDisallowed) {\n            return '';\n        }\n        return this.type === SplitterType.Horizontal ? 'col-resize' : 'row-resize';\n    }\n\n    /**\n     * Sets/gets the `SplitPaneComponent` associated with the current `SplitBarComponent`.\n     *\n     * @memberof SplitBarComponent\n     */\n    @Input()\n    public pane!: IgxSplitterPaneComponent;\n\n    /**\n     * Sets/Gets the `SplitPaneComponent` sibling components associated with the current `SplitBarComponent`.\n     */\n    @Input()\n    public siblings!: Array<IgxSplitterPaneComponent>;\n\n    /**\n     * An event that is emitted whenever we start dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moveStart = new EventEmitter<IgxSplitterPaneComponent>();\n\n    /**\n     * An event that is emitted while we are dragging the current `SplitBarComponent`.\n     */\n    @Output()\n    public moving = new EventEmitter<number>();\n\n    @Output()\n    public movingEnd = new EventEmitter<number>();\n\n    /**\n     * A temporary holder for the pointer coordinates.\n     */\n    private startPoint!: number;\n\n    /**\n     * @hidden @internal\n     */\n    public get prevButtonHidden() {\n        return this.siblings[0].collapsed && !this.siblings[1].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostListener('keydown', ['$event'])\n    public keyEvent(event: KeyboardEvent) {\n        const key = event.key.toLowerCase();\n        const ctrl = event.ctrlKey;\n        event.stopPropagation();\n        if (SPLITTER_INTERACTION_KEYS.has(key)) {\n            event.preventDefault();\n        }\n        switch (key) {\n            case 'arrowup':\n            case 'up':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowdown':\n            case 'down':\n                if (this.type === SplitterType.Vertical) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            case 'arrowleft':\n            case 'left':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(false);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(10);\n                    }\n                }\n                break;\n            case 'arrowright':\n            case 'right':\n                if (this.type === SplitterType.Horizontal) {\n                    if (ctrl) {\n                        this.onCollapsing(true);\n                        break;\n                    }\n                    if (!this.resizeDisallowed) {\n                        event.preventDefault();\n                        this.moveStart.emit(this.pane);\n                        this.moving.emit(-10);\n                    }\n                }\n                break;\n            default:\n                break;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get dragDir() {\n        return this.type === SplitterType.Horizontal ? DragDirection.VERTICAL : DragDirection.HORIZONTAL;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get nextButtonHidden() {\n        return this.siblings[1].collapsed && !this.siblings[0].collapsed;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragStart(event: IDragStartEventArgs) {\n        if (this.resizeDisallowed) {\n            event.cancel = true;\n            return;\n        }\n        this.startPoint = this.type === SplitterType.Horizontal ? event.startX : event.startY;\n        this.moveStart.emit(this.pane);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onDragMove(event: IDragMoveEventArgs) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.moving.emit(delta);\n            event.cancel = true;\n            event.owner.element.nativeElement.style.transform = '';\n        }\n    }\n\n    public onDragEnd(event: any) {\n        const isHorizontal = this.type === SplitterType.Horizontal;\n        const curr = isHorizontal ? event.pageX : event.pageY;\n        const delta = this.startPoint - curr;\n        if (delta !== 0) {\n            this.movingEnd.emit(delta);\n        }\n    }\n\n    protected get resizeDisallowed() {\n        const relatedTabs = this.siblings;\n        return !!relatedTabs.find(x => x.resizable === false || x.collapsed === true);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onCollapsing(next: boolean) {\n        const prevSibling = this.siblings[0];\n        const nextSibling = this.siblings[1];\n        let target;\n        if (next) {\n            // if next is clicked when prev pane is hidden, show prev pane, else hide next pane.\n            target = prevSibling.collapsed ? prevSibling : nextSibling;\n        } else {\n            // if prev is clicked when next pane is hidden, show next pane, else hide prev pane.\n            target = nextSibling.collapsed ? nextSibling : prevSibling;\n        }\n        target.toggle();\n    }\n}\n","<ng-content select=\"igx-splitter-pane\"></ng-content>\n<ng-container *ngFor=\"let pane of panes; let last = last; let index= index;\">\n    <igx-splitter-bar *ngIf=\"!last\" [order]='pane.order + 1' role='separator'\n                    [type]=\"type\"\n                    [pane]=\"pane\"\n                    [siblings]='getPaneSiblingsByOrder(pane.order + 1, index)'\n                    (moveStart)=\"onMoveStart($event)\"\n                    (moving)=\"onMoving($event)\"\n                    (movingEnd)='onMoveEnd($event)'>\n    </igx-splitter-bar>\n</ng-container>\n","<div class=\"igx-splitter-bar\"\n    [class.igx-splitter-bar--vertical]='type === 0'\n    [style.cursor]='cursor'\n    igxDrag\n    [ghost]=\"false\"\n    [dragDirection]='dragDir'\n    (dragStart)='onDragStart($event)'\n    (dragMove)=\"onDragMove($event)\"\n    (dragEnd)=\"onDragEnd($event)\"\n>\n    <div class=\"igx-splitter-bar__expander--start\" igxDragIgnore (click)='onCollapsing(false)' [hidden]='prevButtonHidden'></div>\n    <div class=\"igx-splitter-bar__handle\" ></div>\n    <div class=\"igx-splitter-bar__expander--end\" igxDragIgnore (click)='onCollapsing(true)' [hidden]='nextButtonHidden'></div>\n</div>\n"]}
@@ -47,6 +47,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
47
47
  selector: '[igxTreeExpandIndicator]'
48
48
  }]
49
49
  }] });
50
+ /**
51
+ * IgxTreeComponent allows a developer to show a set of nodes in a hierarchical fashion.
52
+ *
53
+ * @igxModule IgxTreeModule
54
+ * @igxKeywords tree
55
+ * @igxTheme igx-tree-theme
56
+ * @igxGroup Grids & Lists
57
+ *
58
+ * @remark
59
+ * The Angular Tree Component allows users to represent hierarchical data in a tree-view structure,
60
+ * maintaining parent-child relationships, as well as to define static tree-view structure without a corresponding data model.
61
+ * Its primary purpose is to allow end-users to visualize and navigate within hierarchical data structures.
62
+ * The Ignite UI for Angular Tree Component also provides load on demand capabilities, item activation,
63
+ * bi-state and cascading selection of items through built-in checkboxes, built-in keyboard navigation and more.
64
+ *
65
+ * @example
66
+ * ```html
67
+ * <igx-tree>
68
+ * <igx-tree-node>
69
+ * I am a parent node 1
70
+ * <igx-tree-node>
71
+ * I am a child node 1
72
+ * </igx-tree-node>
73
+ * ...
74
+ * </igx-tree-node>
75
+ * ...
76
+ * </igx-tree>
77
+ * ```
78
+ */
50
79
  export class IgxTreeComponent extends DisplayDensityBase {
51
80
  constructor(navService, selectionService, treeService, element, _displayDensityOptions) {
52
81
  super(_displayDensityOptions);
@@ -520,4 +549,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
520
549
  ]
521
550
  }]
522
551
  }] });
523
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/tree/tree.component.ts","../../../../../projects/igniteui-angular/src/lib/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component, QueryList, Input, Output, EventEmitter, ContentChild, Directive,\n    NgModule, TemplateRef, OnInit, AfterViewInit, ContentChildren, OnDestroy, HostBinding, ElementRef, Optional, Inject\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { growVerIn, growVerOut } from '../animations/grow';\nimport { IgxCheckboxModule } from '../checkbox/checkbox.component';\nimport { DisplayDensityBase, DisplayDensityToken, IDisplayDensityOptions } from '../core/displayDensity';\nimport { IgxExpansionPanelModule } from '../expansion-panel/public_api';\nimport { ToggleAnimationSettings } from '../expansion-panel/toggle-animation-component';\nimport { IgxIconModule } from '../icon/public_api';\nimport { IgxInputGroupModule } from '../input-group/public_api';\nimport { IgxProgressBarModule } from '../progressbar/progressbar.component';\nimport {\n    IGX_TREE_COMPONENT, IgxTreeSelectionType, IgxTree, ITreeNodeToggledEventArgs,\n    ITreeNodeTogglingEventArgs, ITreeNodeSelectionEvent, IgxTreeNode, IgxTreeSearchResolver\n} from './common';\nimport { IgxTreeNavigationService } from './tree-navigation.service';\nimport { IgxTreeNodeComponent, IgxTreeNodeLinkDirective } from './tree-node/tree-node.component';\nimport { IgxTreeSelectionService } from './tree-selection.service';\nimport { IgxTreeService } from './tree.service';\n\n/**\n * @hidden @internal\n * Used for templating the select marker of the tree\n */\n@Directive({\n    selector: '[igxTreeSelectMarker]'\n})\nexport class IgxTreeSelectMarkerDirective {\n}\n\n/**\n * @hidden @internal\n * Used for templating the expand indicator of the tree\n */\n@Directive({\n    selector: '[igxTreeExpandIndicator]'\n})\nexport class IgxTreeExpandIndicatorDirective {\n}\n\n@Component({\n    selector: 'igx-tree',\n    templateUrl: 'tree.component.html',\n    providers: [\n        IgxTreeService,\n        IgxTreeSelectionService,\n        IgxTreeNavigationService,\n        { provide: IGX_TREE_COMPONENT, useExisting: IgxTreeComponent },\n    ]\n})\nexport class IgxTreeComponent extends DisplayDensityBase implements IgxTree, OnInit, AfterViewInit, OnDestroy {\n\n    @HostBinding('class.igx-tree')\n    public cssClass = 'igx-tree';\n\n    /**\n     * Gets/Sets tree selection mode\n     *\n     * @remarks\n     * By default the tree selection mode is 'None'\n     * @param selectionMode: IgxTreeSelectionType\n     */\n    @Input()\n    public get selection() {\n        return this._selection;\n    }\n\n    public set selection(selectionMode: IgxTreeSelectionType) {\n        this._selection = selectionMode;\n        this.selectionService.clearNodesSelection();\n    }\n\n    /** Get/Set how the tree should handle branch expansion.\n     * If set to `true`, only a single branch can be expanded at a time, collapsing all others\n     *\n     * ```html\n     * <igx-tree [singleBranchExpand]=\"true\">\n     * ...\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const tree: IgxTree = this.tree;\n     * this.tree.singleBranchExpand = false;\n     * ```\n     */\n    @Input()\n    public singleBranchExpand = false;\n\n    /** Get/Set the animation settings that branches should use when expanding/collpasing.\n     *\n     * ```html\n     * <igx-tree [animationSettings]=\"customAnimationSettings\">\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const animationSettings: ToggleAnimationSettings = {\n     *      openAnimation: growVerIn,\n     *      closeAnimation: growVerOut\n     * };\n     *\n     * this.tree.animationSettings = animationSettings;\n     * ```\n     */\n    @Input()\n    public animationSettings: ToggleAnimationSettings = {\n        openAnimation: growVerIn,\n        closeAnimation: growVerOut\n    };\n\n    /** Emitted when the node selection is changed through interaction\n     *\n     * ```html\n     * <igx-tree (nodeSelection)=\"handleNodeSelection($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeSelection(event: ITreeNodeSelectionEvent) {\n     *  const newSelection: IgxTreeNode<any>[] = event.newSelection;\n     *  const added: IgxTreeNode<any>[] = event.added;\n     *  console.log(\"New selection will be: \", newSelection);\n     *  console.log(\"Added nodes: \", event.added);\n     * }\n     *```\n     */\n    @Output()\n    public nodeSelection = new EventEmitter<ITreeNodeSelectionEvent>();\n\n    /** Emitted when a node is expanding, before it finishes\n     *\n     * ```html\n     * <igx-tree (nodeExpanding)=\"handleNodeExpanding($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeExpanding(event: ITreeNodeTogglingEventArgs) {\n     *  const expandedNode: IgxTreeNode<any> = event.node;\n     *  if (expandedNode.disabled) {\n     *      event.cancel = true;\n     *  }\n     * }\n     *```\n     */\n    @Output()\n    public nodeExpanding = new EventEmitter<ITreeNodeTogglingEventArgs>();\n\n    /** Emitted when a node is expanded, after it finishes\n     *\n     * ```html\n     * <igx-tree (nodeExpanded)=\"handleNodeExpanded($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeExpanded(event: ITreeNodeToggledEventArgs) {\n     *  const expandedNode: IgxTreeNode<any> = event.node;\n     *  console.log(\"Node is expanded: \", expandedNode.data);\n     * }\n     *```\n     */\n    @Output()\n    public nodeExpanded = new EventEmitter<ITreeNodeToggledEventArgs>();\n\n    /** Emitted when a node is collapsing, before it finishes\n     *\n     * ```html\n     * <igx-tree (nodeCollapsing)=\"handleNodeCollapsing($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeCollapsing(event: ITreeNodeTogglingEventArgs) {\n     *  const collapsedNode: IgxTreeNode<any> = event.node;\n     *  if (collapsedNode.alwaysOpen) {\n     *      event.cancel = true;\n     *  }\n     * }\n     *```\n     */\n    @Output()\n    public nodeCollapsing = new EventEmitter<ITreeNodeTogglingEventArgs>();\n\n    /** Emitted when a node is collapsed, after it finishes\n     *\n     * @example\n     * ```html\n     * <igx-tree (nodeCollapsed)=\"handleNodeCollapsed($event)\">\n     * </igx-tree>\n     * ```\n     * ```typescript\n     * public handleNodeCollapsed(event: ITreeNodeToggledEventArgs) {\n     *  const collapsedNode: IgxTreeNode<any> = event.node;\n     *  console.log(\"Node is collapsed: \", collapsedNode.data);\n     * }\n     * ```\n     */\n    @Output()\n    public nodeCollapsed = new EventEmitter<ITreeNodeToggledEventArgs>();\n\n    /**\n     * Emitted when the active node is changed.\n     *\n     * @example\n     * ```\n     * <igx-tree (activeNodeChanged)=\"activeNodeChanged($event)\"></igx-tree>\n     * ```\n     */\n    @Output()\n    public activeNodeChanged = new EventEmitter<IgxTreeNode<any>>();\n\n    /**\n     * A custom template to be used for the expand indicator of nodes\n     * ```html\n     * <igx-tree>\n     *  <ng-template igxTreeExpandIndicator let-expanded>\n     *      <igx-icon>{{ expanded ? \"close_fullscreen\": \"open_in_full\"}}</igx-icon>\n     *  </ng-template>\n     * </igx-tree>\n     * ```\n     */\n    @ContentChild(IgxTreeExpandIndicatorDirective, { read: TemplateRef })\n    public expandIndicator: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ContentChildren(IgxTreeNodeComponent, { descendants: true })\n    public nodes: QueryList<IgxTreeNodeComponent<any>>;\n\n    /** @hidden @internal */\n    public disabledChange = new EventEmitter<IgxTreeNode<any>>();\n\n    /**\n     * Returns all **root level** nodes\n     *\n     * ```typescript\n     * const tree: IgxTree = this.tree;\n     * const rootNodes: IgxTreeNodeComponent<any>[] = tree.rootNodes;\n     * ```\n     */\n    public get rootNodes(): IgxTreeNodeComponent<any>[] {\n        return this.nodes?.filter(node => node.level === 0);\n    }\n\n    /**\n     * Emitted when the active node is set through API\n     *\n     * @hidden @internal\n     */\n    public activeNodeBindingChange = new EventEmitter<IgxTreeNode<any>>();\n\n    /** @hidden @internal */\n    public forceSelect = [];\n\n    private _selection: IgxTreeSelectionType = IgxTreeSelectionType.None;\n    private destroy$ = new Subject<void>();\n    private unsubChildren$ = new Subject<void>();\n\n    constructor(\n        private navService: IgxTreeNavigationService,\n        private selectionService: IgxTreeSelectionService,\n        private treeService: IgxTreeService,\n        private element: ElementRef<HTMLElement>,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions?: IDisplayDensityOptions) {\n        super(_displayDensityOptions);\n        this.selectionService.register(this);\n        this.treeService.register(this);\n        this.navService.register(this);\n    }\n\n    /** @hidden @internal */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    /**\n     * Expands all of the passed nodes.\n     * If no nodes are passed, expands ALL nodes\n     *\n     * @param nodes nodes to be expanded\n     *\n     * ```typescript\n     * const targetNodes: IgxTreeNode<any> = this.tree.findNodes(true, (_data: any, node: IgxTreeNode<any>) => node.data.expandable);\n     * tree.expandAll(nodes);\n     * ```\n     */\n    public expandAll(nodes?: IgxTreeNode<any>[]) {\n        nodes = nodes || this.nodes.toArray();\n        nodes.forEach(e => e.expanded = true);\n    }\n\n    /**\n     * Collapses all of the passed nodes.\n     * If no nodes are passed, collapses ALL nodes\n     *\n     * @param nodes nodes to be collapsed\n     *\n     * ```typescript\n     * const targetNodes: IgxTreeNode<any> = this.tree.findNodes(true, (_data: any, node: IgxTreeNode<any>) => node.data.collapsible);\n     * tree.collapseAll(nodes);\n     * ```\n     */\n    public collapseAll(nodes?: IgxTreeNode<any>[]) {\n        nodes = nodes || this.nodes.toArray();\n        nodes.forEach(e => e.expanded = false);\n    }\n\n    /**\n     * Deselect all nodes if the nodes collection is empty. Otherwise, deselect the nodes in the nodes collection.\n     *\n     * @example\n     * ```typescript\n     *  const arr = [\n     *      this.tree.nodes.toArray()[0],\n     *      this.tree.nodes.toArray()[1]\n     *  ];\n     *  this.tree.deselectAll(arr);\n     * ```\n     * @param nodes: IgxTreeNodeComponent<any>[]\n     */\n    public deselectAll(nodes?: IgxTreeNodeComponent<any>[]) {\n        this.selectionService.deselectNodesWithNoEvent(nodes);\n    }\n\n    /**\n     * Returns all of the nodes that match the passed searchTerm.\n     * Accepts a custom comparer function for evaluating the search term against the nodes.\n     *\n     * @remark\n     * Default search compares the passed `searchTerm` against the node's `data` Input.\n     * When using `findNodes` w/o a `comparer`, make sure all nodes have `data` passed.\n     *\n     * @param searchTerm The data of the searched node\n     * @param comparer A custom comparer function that evaluates the passed `searchTerm` against all nodes.\n     * @returns Array of nodes that match the search. `null` if no nodes are found.\n     *\n     * ```html\n     * <igx-tree>\n     *     <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\">\n     *          {{ node.label }}\n     *     </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * public data: DataEntry[] = FETCHED_DATA;\n     * ...\n     * const matchedNodes: IgxTreeNode<DataEntry>[] = this.tree.findNodes<DataEntry>(searchTerm: data[5]);\n     * ```\n     *\n     * Using a custom comparer\n     * ```typescript\n     * public data: DataEntry[] = FETCHED_DATA;\n     * ...\n     * const comparer: IgxTreeSearchResolver = (data: any, node: IgxTreeNode<DataEntry>) {\n     *      return node.data.index % 2 === 0;\n     * }\n     * const evenIndexNodes: IgxTreeNode<DataEntry>[] = this.tree.findNodes<DataEntry>(null, comparer);\n     * ```\n     */\n    public findNodes(searchTerm: any, comparer?: IgxTreeSearchResolver): IgxTreeNodeComponent<any>[] | null {\n        const compareFunc = comparer || this._comparer;\n        const results = this.nodes.filter(node => compareFunc(searchTerm, node));\n        return results?.length === 0 ? null : results;\n    }\n\n    /** @hidden @internal */\n    public handleKeydown(event: KeyboardEvent) {\n        this.navService.handleKeydown(event);\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        super.ngOnInit();\n        this.disabledChange.pipe(takeUntil(this.destroy$)).subscribe((e) => {\n            this.navService.update_disabled_cache(e);\n        });\n        this.activeNodeBindingChange.pipe(takeUntil(this.destroy$)).subscribe((node) => {\n            this.expandToNode(this.navService.activeNode);\n            this.scrollNodeIntoView(node?.header?.nativeElement);\n        });\n        this.onDensityChanged.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            requestAnimationFrame(() => {\n                this.scrollNodeIntoView(this.navService.activeNode?.header.nativeElement);\n            });\n        });\n        this.subToCollapsing();\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewInit() {\n        this.nodes.changes.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.subToChanges();\n        });\n        this.scrollNodeIntoView(this.navService.activeNode?.header?.nativeElement);\n        this.subToChanges();\n    }\n\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        this.unsubChildren$.next();\n        this.unsubChildren$.complete();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private expandToNode(node: IgxTreeNode<any>) {\n        if (node && node.parentNode) {\n            node.path.forEach(n => {\n                if (n !== node && !n.expanded) {\n                    n.expanded = true;\n                }\n            });\n        }\n    }\n\n    private subToCollapsing() {\n        this.nodeCollapsing.pipe(takeUntil(this.destroy$)).subscribe(event => {\n            if (event.cancel) {\n                return;\n            }\n            this.navService.update_visible_cache(event.node, false);\n        });\n        this.nodeExpanding.pipe(takeUntil(this.destroy$)).subscribe(event => {\n            if (event.cancel) {\n                return;\n            }\n            this.navService.update_visible_cache(event.node, true);\n        });\n    }\n\n    private subToChanges() {\n        this.unsubChildren$.next();\n        const toBeSelected = [...this.forceSelect];\n        requestAnimationFrame(() => {\n            this.selectionService.selectNodesWithNoEvent(toBeSelected);\n        });\n        this.forceSelect = [];\n        this.nodes.forEach(node => {\n            node.expandedChange.pipe(takeUntil(this.unsubChildren$)).subscribe(nodeState => {\n                this.navService.update_visible_cache(node, nodeState);\n            });\n            node.closeAnimationDone.pipe(takeUntil(this.unsubChildren$)).subscribe(() => {\n                const targetElement = this.navService.focusedNode?.header.nativeElement;\n                this.scrollNodeIntoView(targetElement);\n            });\n            node.openAnimationDone.pipe(takeUntil(this.unsubChildren$)).subscribe(() => {\n                const targetElement = this.navService.focusedNode?.header.nativeElement;\n                this.scrollNodeIntoView(targetElement);\n            });\n        });\n        this.navService.init_invisible_cache();\n    }\n\n    private scrollNodeIntoView(el: HTMLElement) {\n        if (!el) {\n            return;\n        }\n        const nodeRect = el.getBoundingClientRect();\n        const treeRect = this.nativeElement.getBoundingClientRect();\n        const topOffset = treeRect.top > nodeRect.top ? nodeRect.top - treeRect.top : 0;\n        const bottomOffset = treeRect.bottom < nodeRect.bottom ? nodeRect.bottom - treeRect.bottom : 0;\n        const shouldScroll = !!topOffset || !!bottomOffset;\n        if (shouldScroll && this.nativeElement.scrollHeight > this.nativeElement.clientHeight) {\n            // this.nativeElement.scrollTop = nodeRect.y - treeRect.y - nodeRect.height;\n            this.nativeElement.scrollTop =\n            this.nativeElement.scrollTop + bottomOffset + topOffset + (topOffset ? -1 : +1) * nodeRect.height;\n        }\n    }\n\n    private _comparer = <T>(data: T, node: IgxTreeNodeComponent<T>) => node.data === data;\n\n}\n\n/**\n * @hidden\n *\n * NgModule defining the components and directives needed for `igx-tree`\n */\n@NgModule({\n    declarations: [\n        IgxTreeSelectMarkerDirective,\n        IgxTreeExpandIndicatorDirective,\n        IgxTreeNodeLinkDirective,\n        IgxTreeComponent,\n        IgxTreeNodeComponent\n    ],\n    imports: [\n        CommonModule,\n        FormsModule,\n        IgxIconModule,\n        IgxInputGroupModule,\n        IgxCheckboxModule,\n        IgxProgressBarModule\n    ],\n    exports: [\n        IgxTreeSelectMarkerDirective,\n        IgxTreeExpandIndicatorDirective,\n        IgxTreeNodeLinkDirective,\n        IgxTreeComponent,\n        IgxTreeNodeComponent,\n        IgxIconModule,\n        IgxInputGroupModule,\n        IgxCheckboxModule,\n        IgxExpansionPanelModule\n    ]\n})\nexport class IgxTreeModule {\n}\n","<div class=\"igx-tree__root\" role=\"tree\" (keydown)=\"handleKeydown($event)\">\n    <ng-content select=\"igx-tree-node\"></ng-content>\n</div>\n"]}
552
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/tree/tree.component.ts","../../../../../projects/igniteui-angular/src/lib/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component, QueryList, Input, Output, EventEmitter, ContentChild, Directive,\n    NgModule, TemplateRef, OnInit, AfterViewInit, ContentChildren, OnDestroy, HostBinding, ElementRef, Optional, Inject\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { growVerIn, growVerOut } from '../animations/grow';\nimport { IgxCheckboxModule } from '../checkbox/checkbox.component';\nimport { DisplayDensityBase, DisplayDensityToken, IDisplayDensityOptions } from '../core/displayDensity';\nimport { IgxExpansionPanelModule } from '../expansion-panel/public_api';\nimport { ToggleAnimationSettings } from '../expansion-panel/toggle-animation-component';\nimport { IgxIconModule } from '../icon/public_api';\nimport { IgxInputGroupModule } from '../input-group/public_api';\nimport { IgxProgressBarModule } from '../progressbar/progressbar.component';\nimport {\n    IGX_TREE_COMPONENT, IgxTreeSelectionType, IgxTree, ITreeNodeToggledEventArgs,\n    ITreeNodeTogglingEventArgs, ITreeNodeSelectionEvent, IgxTreeNode, IgxTreeSearchResolver\n} from './common';\nimport { IgxTreeNavigationService } from './tree-navigation.service';\nimport { IgxTreeNodeComponent, IgxTreeNodeLinkDirective } from './tree-node/tree-node.component';\nimport { IgxTreeSelectionService } from './tree-selection.service';\nimport { IgxTreeService } from './tree.service';\n\n/**\n * @hidden @internal\n * Used for templating the select marker of the tree\n */\n@Directive({\n    selector: '[igxTreeSelectMarker]'\n})\nexport class IgxTreeSelectMarkerDirective {\n}\n\n/**\n * @hidden @internal\n * Used for templating the expand indicator of the tree\n */\n@Directive({\n    selector: '[igxTreeExpandIndicator]'\n})\nexport class IgxTreeExpandIndicatorDirective {\n}\n\n/**\n * IgxTreeComponent allows a developer to show a set of nodes in a hierarchical fashion.\n *\n * @igxModule IgxTreeModule\n * @igxKeywords tree\n * @igxTheme igx-tree-theme\n * @igxGroup Grids & Lists\n *\n * @remark\n * The Angular Tree Component allows users to represent hierarchical data in a tree-view structure, \n * maintaining parent-child relationships, as well as to define static tree-view structure without a corresponding data model. \n * Its primary purpose is to allow end-users to visualize and navigate within hierarchical data structures. \n * The Ignite UI for Angular Tree Component also provides load on demand capabilities, item activation, \n * bi-state and cascading selection of items through built-in checkboxes, built-in keyboard navigation and more.\n *\n * @example\n * ```html\n * <igx-tree>\n *   <igx-tree-node>\n *      I am a parent node 1\n *      <igx-tree-node>\n *          I am a child node 1\n *      </igx-tree-node>\n *      ...\n *   </igx-tree-node>\n *\t ...\n * </igx-tree>\n * ```\n */\n@Component({\n    selector: 'igx-tree',\n    templateUrl: 'tree.component.html',\n    providers: [\n        IgxTreeService,\n        IgxTreeSelectionService,\n        IgxTreeNavigationService,\n        { provide: IGX_TREE_COMPONENT, useExisting: IgxTreeComponent },\n    ]\n})\nexport class IgxTreeComponent extends DisplayDensityBase implements IgxTree, OnInit, AfterViewInit, OnDestroy {\n\n    @HostBinding('class.igx-tree')\n    public cssClass = 'igx-tree';\n\n    /**\n     * Gets/Sets tree selection mode\n     *\n     * @remarks\n     * By default the tree selection mode is 'None'\n     * @param selectionMode: IgxTreeSelectionType\n     */\n    @Input()\n    public get selection() {\n        return this._selection;\n    }\n\n    public set selection(selectionMode: IgxTreeSelectionType) {\n        this._selection = selectionMode;\n        this.selectionService.clearNodesSelection();\n    }\n\n    /** Get/Set how the tree should handle branch expansion.\n     * If set to `true`, only a single branch can be expanded at a time, collapsing all others\n     *\n     * ```html\n     * <igx-tree [singleBranchExpand]=\"true\">\n     * ...\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const tree: IgxTree = this.tree;\n     * this.tree.singleBranchExpand = false;\n     * ```\n     */\n    @Input()\n    public singleBranchExpand = false;\n\n    /** Get/Set the animation settings that branches should use when expanding/collpasing.\n     *\n     * ```html\n     * <igx-tree [animationSettings]=\"customAnimationSettings\">\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const animationSettings: ToggleAnimationSettings = {\n     *      openAnimation: growVerIn,\n     *      closeAnimation: growVerOut\n     * };\n     *\n     * this.tree.animationSettings = animationSettings;\n     * ```\n     */\n    @Input()\n    public animationSettings: ToggleAnimationSettings = {\n        openAnimation: growVerIn,\n        closeAnimation: growVerOut\n    };\n\n    /** Emitted when the node selection is changed through interaction\n     *\n     * ```html\n     * <igx-tree (nodeSelection)=\"handleNodeSelection($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeSelection(event: ITreeNodeSelectionEvent) {\n     *  const newSelection: IgxTreeNode<any>[] = event.newSelection;\n     *  const added: IgxTreeNode<any>[] = event.added;\n     *  console.log(\"New selection will be: \", newSelection);\n     *  console.log(\"Added nodes: \", event.added);\n     * }\n     *```\n     */\n    @Output()\n    public nodeSelection = new EventEmitter<ITreeNodeSelectionEvent>();\n\n    /** Emitted when a node is expanding, before it finishes\n     *\n     * ```html\n     * <igx-tree (nodeExpanding)=\"handleNodeExpanding($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeExpanding(event: ITreeNodeTogglingEventArgs) {\n     *  const expandedNode: IgxTreeNode<any> = event.node;\n     *  if (expandedNode.disabled) {\n     *      event.cancel = true;\n     *  }\n     * }\n     *```\n     */\n    @Output()\n    public nodeExpanding = new EventEmitter<ITreeNodeTogglingEventArgs>();\n\n    /** Emitted when a node is expanded, after it finishes\n     *\n     * ```html\n     * <igx-tree (nodeExpanded)=\"handleNodeExpanded($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeExpanded(event: ITreeNodeToggledEventArgs) {\n     *  const expandedNode: IgxTreeNode<any> = event.node;\n     *  console.log(\"Node is expanded: \", expandedNode.data);\n     * }\n     *```\n     */\n    @Output()\n    public nodeExpanded = new EventEmitter<ITreeNodeToggledEventArgs>();\n\n    /** Emitted when a node is collapsing, before it finishes\n     *\n     * ```html\n     * <igx-tree (nodeCollapsing)=\"handleNodeCollapsing($event)\">\n     * </igx-tree>\n     * ```\n     *\n     *```typescript\n     * public handleNodeCollapsing(event: ITreeNodeTogglingEventArgs) {\n     *  const collapsedNode: IgxTreeNode<any> = event.node;\n     *  if (collapsedNode.alwaysOpen) {\n     *      event.cancel = true;\n     *  }\n     * }\n     *```\n     */\n    @Output()\n    public nodeCollapsing = new EventEmitter<ITreeNodeTogglingEventArgs>();\n\n    /** Emitted when a node is collapsed, after it finishes\n     *\n     * @example\n     * ```html\n     * <igx-tree (nodeCollapsed)=\"handleNodeCollapsed($event)\">\n     * </igx-tree>\n     * ```\n     * ```typescript\n     * public handleNodeCollapsed(event: ITreeNodeToggledEventArgs) {\n     *  const collapsedNode: IgxTreeNode<any> = event.node;\n     *  console.log(\"Node is collapsed: \", collapsedNode.data);\n     * }\n     * ```\n     */\n    @Output()\n    public nodeCollapsed = new EventEmitter<ITreeNodeToggledEventArgs>();\n\n    /**\n     * Emitted when the active node is changed.\n     *\n     * @example\n     * ```\n     * <igx-tree (activeNodeChanged)=\"activeNodeChanged($event)\"></igx-tree>\n     * ```\n     */\n    @Output()\n    public activeNodeChanged = new EventEmitter<IgxTreeNode<any>>();\n\n    /**\n     * A custom template to be used for the expand indicator of nodes\n     * ```html\n     * <igx-tree>\n     *  <ng-template igxTreeExpandIndicator let-expanded>\n     *      <igx-icon>{{ expanded ? \"close_fullscreen\": \"open_in_full\"}}</igx-icon>\n     *  </ng-template>\n     * </igx-tree>\n     * ```\n     */\n    @ContentChild(IgxTreeExpandIndicatorDirective, { read: TemplateRef })\n    public expandIndicator: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ContentChildren(IgxTreeNodeComponent, { descendants: true })\n    public nodes: QueryList<IgxTreeNodeComponent<any>>;\n\n    /** @hidden @internal */\n    public disabledChange = new EventEmitter<IgxTreeNode<any>>();\n\n    /**\n     * Returns all **root level** nodes\n     *\n     * ```typescript\n     * const tree: IgxTree = this.tree;\n     * const rootNodes: IgxTreeNodeComponent<any>[] = tree.rootNodes;\n     * ```\n     */\n    public get rootNodes(): IgxTreeNodeComponent<any>[] {\n        return this.nodes?.filter(node => node.level === 0);\n    }\n\n    /**\n     * Emitted when the active node is set through API\n     *\n     * @hidden @internal\n     */\n    public activeNodeBindingChange = new EventEmitter<IgxTreeNode<any>>();\n\n    /** @hidden @internal */\n    public forceSelect = [];\n\n    private _selection: IgxTreeSelectionType = IgxTreeSelectionType.None;\n    private destroy$ = new Subject<void>();\n    private unsubChildren$ = new Subject<void>();\n\n    constructor(\n        private navService: IgxTreeNavigationService,\n        private selectionService: IgxTreeSelectionService,\n        private treeService: IgxTreeService,\n        private element: ElementRef<HTMLElement>,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions?: IDisplayDensityOptions) {\n        super(_displayDensityOptions);\n        this.selectionService.register(this);\n        this.treeService.register(this);\n        this.navService.register(this);\n    }\n\n    /** @hidden @internal */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    /**\n     * Expands all of the passed nodes.\n     * If no nodes are passed, expands ALL nodes\n     *\n     * @param nodes nodes to be expanded\n     *\n     * ```typescript\n     * const targetNodes: IgxTreeNode<any> = this.tree.findNodes(true, (_data: any, node: IgxTreeNode<any>) => node.data.expandable);\n     * tree.expandAll(nodes);\n     * ```\n     */\n    public expandAll(nodes?: IgxTreeNode<any>[]) {\n        nodes = nodes || this.nodes.toArray();\n        nodes.forEach(e => e.expanded = true);\n    }\n\n    /**\n     * Collapses all of the passed nodes.\n     * If no nodes are passed, collapses ALL nodes\n     *\n     * @param nodes nodes to be collapsed\n     *\n     * ```typescript\n     * const targetNodes: IgxTreeNode<any> = this.tree.findNodes(true, (_data: any, node: IgxTreeNode<any>) => node.data.collapsible);\n     * tree.collapseAll(nodes);\n     * ```\n     */\n    public collapseAll(nodes?: IgxTreeNode<any>[]) {\n        nodes = nodes || this.nodes.toArray();\n        nodes.forEach(e => e.expanded = false);\n    }\n\n    /**\n     * Deselect all nodes if the nodes collection is empty. Otherwise, deselect the nodes in the nodes collection.\n     *\n     * @example\n     * ```typescript\n     *  const arr = [\n     *      this.tree.nodes.toArray()[0],\n     *      this.tree.nodes.toArray()[1]\n     *  ];\n     *  this.tree.deselectAll(arr);\n     * ```\n     * @param nodes: IgxTreeNodeComponent<any>[]\n     */\n    public deselectAll(nodes?: IgxTreeNodeComponent<any>[]) {\n        this.selectionService.deselectNodesWithNoEvent(nodes);\n    }\n\n    /**\n     * Returns all of the nodes that match the passed searchTerm.\n     * Accepts a custom comparer function for evaluating the search term against the nodes.\n     *\n     * @remark\n     * Default search compares the passed `searchTerm` against the node's `data` Input.\n     * When using `findNodes` w/o a `comparer`, make sure all nodes have `data` passed.\n     *\n     * @param searchTerm The data of the searched node\n     * @param comparer A custom comparer function that evaluates the passed `searchTerm` against all nodes.\n     * @returns Array of nodes that match the search. `null` if no nodes are found.\n     *\n     * ```html\n     * <igx-tree>\n     *     <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\">\n     *          {{ node.label }}\n     *     </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * public data: DataEntry[] = FETCHED_DATA;\n     * ...\n     * const matchedNodes: IgxTreeNode<DataEntry>[] = this.tree.findNodes<DataEntry>(searchTerm: data[5]);\n     * ```\n     *\n     * Using a custom comparer\n     * ```typescript\n     * public data: DataEntry[] = FETCHED_DATA;\n     * ...\n     * const comparer: IgxTreeSearchResolver = (data: any, node: IgxTreeNode<DataEntry>) {\n     *      return node.data.index % 2 === 0;\n     * }\n     * const evenIndexNodes: IgxTreeNode<DataEntry>[] = this.tree.findNodes<DataEntry>(null, comparer);\n     * ```\n     */\n    public findNodes(searchTerm: any, comparer?: IgxTreeSearchResolver): IgxTreeNodeComponent<any>[] | null {\n        const compareFunc = comparer || this._comparer;\n        const results = this.nodes.filter(node => compareFunc(searchTerm, node));\n        return results?.length === 0 ? null : results;\n    }\n\n    /** @hidden @internal */\n    public handleKeydown(event: KeyboardEvent) {\n        this.navService.handleKeydown(event);\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        super.ngOnInit();\n        this.disabledChange.pipe(takeUntil(this.destroy$)).subscribe((e) => {\n            this.navService.update_disabled_cache(e);\n        });\n        this.activeNodeBindingChange.pipe(takeUntil(this.destroy$)).subscribe((node) => {\n            this.expandToNode(this.navService.activeNode);\n            this.scrollNodeIntoView(node?.header?.nativeElement);\n        });\n        this.onDensityChanged.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            requestAnimationFrame(() => {\n                this.scrollNodeIntoView(this.navService.activeNode?.header.nativeElement);\n            });\n        });\n        this.subToCollapsing();\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewInit() {\n        this.nodes.changes.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.subToChanges();\n        });\n        this.scrollNodeIntoView(this.navService.activeNode?.header?.nativeElement);\n        this.subToChanges();\n    }\n\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        this.unsubChildren$.next();\n        this.unsubChildren$.complete();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private expandToNode(node: IgxTreeNode<any>) {\n        if (node && node.parentNode) {\n            node.path.forEach(n => {\n                if (n !== node && !n.expanded) {\n                    n.expanded = true;\n                }\n            });\n        }\n    }\n\n    private subToCollapsing() {\n        this.nodeCollapsing.pipe(takeUntil(this.destroy$)).subscribe(event => {\n            if (event.cancel) {\n                return;\n            }\n            this.navService.update_visible_cache(event.node, false);\n        });\n        this.nodeExpanding.pipe(takeUntil(this.destroy$)).subscribe(event => {\n            if (event.cancel) {\n                return;\n            }\n            this.navService.update_visible_cache(event.node, true);\n        });\n    }\n\n    private subToChanges() {\n        this.unsubChildren$.next();\n        const toBeSelected = [...this.forceSelect];\n        requestAnimationFrame(() => {\n            this.selectionService.selectNodesWithNoEvent(toBeSelected);\n        });\n        this.forceSelect = [];\n        this.nodes.forEach(node => {\n            node.expandedChange.pipe(takeUntil(this.unsubChildren$)).subscribe(nodeState => {\n                this.navService.update_visible_cache(node, nodeState);\n            });\n            node.closeAnimationDone.pipe(takeUntil(this.unsubChildren$)).subscribe(() => {\n                const targetElement = this.navService.focusedNode?.header.nativeElement;\n                this.scrollNodeIntoView(targetElement);\n            });\n            node.openAnimationDone.pipe(takeUntil(this.unsubChildren$)).subscribe(() => {\n                const targetElement = this.navService.focusedNode?.header.nativeElement;\n                this.scrollNodeIntoView(targetElement);\n            });\n        });\n        this.navService.init_invisible_cache();\n    }\n\n    private scrollNodeIntoView(el: HTMLElement) {\n        if (!el) {\n            return;\n        }\n        const nodeRect = el.getBoundingClientRect();\n        const treeRect = this.nativeElement.getBoundingClientRect();\n        const topOffset = treeRect.top > nodeRect.top ? nodeRect.top - treeRect.top : 0;\n        const bottomOffset = treeRect.bottom < nodeRect.bottom ? nodeRect.bottom - treeRect.bottom : 0;\n        const shouldScroll = !!topOffset || !!bottomOffset;\n        if (shouldScroll && this.nativeElement.scrollHeight > this.nativeElement.clientHeight) {\n            // this.nativeElement.scrollTop = nodeRect.y - treeRect.y - nodeRect.height;\n            this.nativeElement.scrollTop =\n            this.nativeElement.scrollTop + bottomOffset + topOffset + (topOffset ? -1 : +1) * nodeRect.height;\n        }\n    }\n\n    private _comparer = <T>(data: T, node: IgxTreeNodeComponent<T>) => node.data === data;\n\n}\n\n/**\n * @hidden\n *\n * NgModule defining the components and directives needed for `igx-tree`\n */\n@NgModule({\n    declarations: [\n        IgxTreeSelectMarkerDirective,\n        IgxTreeExpandIndicatorDirective,\n        IgxTreeNodeLinkDirective,\n        IgxTreeComponent,\n        IgxTreeNodeComponent\n    ],\n    imports: [\n        CommonModule,\n        FormsModule,\n        IgxIconModule,\n        IgxInputGroupModule,\n        IgxCheckboxModule,\n        IgxProgressBarModule\n    ],\n    exports: [\n        IgxTreeSelectMarkerDirective,\n        IgxTreeExpandIndicatorDirective,\n        IgxTreeNodeLinkDirective,\n        IgxTreeComponent,\n        IgxTreeNodeComponent,\n        IgxIconModule,\n        IgxInputGroupModule,\n        IgxCheckboxModule,\n        IgxExpansionPanelModule\n    ]\n})\nexport class IgxTreeModule {\n}\n","<div class=\"igx-tree__root\" role=\"tree\" (keydown)=\"handleKeydown($event)\">\n    <ng-content select=\"igx-tree-node\"></ng-content>\n</div>\n"]}