igniteui-angular 14.0.10 → 14.0.13

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.
@@ -524,6 +524,9 @@ export class IgxTreeNodeComponent extends ToggleAnimationPlayer {
524
524
  * ```
525
525
  */
526
526
  expand() {
527
+ if (this.expanded && !this.treeService.collapsingNodes.has(this)) {
528
+ return;
529
+ }
527
530
  const args = {
528
531
  owner: this.tree,
529
532
  node: this,
@@ -552,6 +555,9 @@ export class IgxTreeNodeComponent extends ToggleAnimationPlayer {
552
555
  * ```
553
556
  */
554
557
  collapse() {
558
+ if (!this.expanded || this.treeService.collapsingNodes.has(this)) {
559
+ return;
560
+ }
555
561
  const args = {
556
562
  owner: this.tree,
557
563
  node: this,
@@ -645,4 +651,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.0", ngImpor
645
651
  }], expanded: [{
646
652
  type: Input
647
653
  }] } });
648
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-node.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/tree/tree-node/tree-node.component.ts","../../../../../../projects/igniteui-angular/src/lib/tree/tree-node/tree-node.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    SkipSelf,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { DisplayDensity } from '../../core/displayDensity';\nimport { CurrentResourceStrings } from '../../core/i18n/resources';\nimport { ITreeResourceStrings } from '../../core/i18n/tree-resources';\nimport { ToggleAnimationPlayer, ToggleAnimationSettings } from '../../expansion-panel/toggle-animation-component';\nimport { IgxAngularAnimationService } from '../../services/animation/angular-animation-service';\nimport { AnimationService } from '../../services/animation/animation';\nimport {\n    IgxTree,\n    IgxTreeNode,\n    IgxTreeSelectionType,\n    IGX_TREE_COMPONENT,\n    IGX_TREE_NODE_COMPONENT,\n    ITreeNodeTogglingEventArgs\n} from '../common';\nimport { IgxTreeNavigationService } from '../tree-navigation.service';\nimport { IgxTreeSelectionService } from '../tree-selection.service';\nimport { IgxTreeService } from '../tree.service';\n\n// TODO: Implement aria functionality\n/**\n * @hidden @internal\n * Used for links (`a` tags) in the body of an `igx-tree-node`. Handles aria and event dispatch.\n */\n@Directive({\n    selector: `[igxTreeNodeLink]`\n})\nexport class IgxTreeNodeLinkDirective implements OnDestroy {\n\n    @HostBinding('attr.role')\n    public role = 'treeitem';\n\n    /**\n     * The node's parent. Should be used only when the link is defined\n     * in `<ng-template>` tag outside of its parent, as Angular DI will not properly provide a reference\n     *\n     * ```html\n     * <igx-tree>\n     *     <igx-tree-node #myNode *ngFor=\"let node of data\" [data]=\"node\">\n     *         <ng-template *ngTemplateOutlet=\"nodeTemplate; context: { $implicit: data, parentNode: myNode }\">\n     *         </ng-template>\n     *     </igx-tree-node>\n     *     ...\n     *     <!-- node template is defined under tree to access related services -->\n     *     <ng-template #nodeTemplate let-data let-node=\"parentNode\">\n     *         <a [igxTreeNodeLink]=\"node\">{{ data.label }}</a>\n     *     </ng-template>\n     * </igx-tree>\n     * ```\n     */\n    @Input('igxTreeNodeLink')\n    public set parentNode(val: any) {\n        if (val) {\n            this._parentNode = val;\n            (this._parentNode as any).addLinkChild(this);\n        }\n    }\n\n    public get parentNode(): any {\n        return this._parentNode;\n    }\n\n    /** A pointer to the parent node */\n    private get target(): IgxTreeNode<any> {\n        return this.node || this.parentNode;\n    }\n\n    private _parentNode: IgxTreeNode<any> = null;\n\n    constructor(@Optional() @Inject(IGX_TREE_NODE_COMPONENT)\n    private node: IgxTreeNode<any>,\n        private navService: IgxTreeNavigationService,\n        public elementRef: ElementRef) {\n    }\n\n    /** @hidden @internal */\n    @HostBinding('attr.tabindex')\n    public get tabIndex(): number {\n        return this.navService.focusedNode === this.target ? (this.target?.disabled ? -1 : 0) : -1;\n    }\n\n    /**\n     * @hidden @internal\n     * Clear the node's focused state\n     */\n    @HostListener('blur')\n    public handleBlur() {\n        this.target.isFocused = false;\n    }\n\n    /**\n     * @hidden @internal\n     * Set the node as focused\n     */\n    @HostListener('focus')\n    public handleFocus() {\n        if (this.target && !this.target.disabled) {\n            if (this.navService.focusedNode !== this.target) {\n                this.navService.focusedNode = this.target;\n            }\n            this.target.isFocused = true;\n        }\n    }\n\n    public ngOnDestroy() {\n        this.target.removeLinkChild(this);\n    }\n}\n\n/**\n *\n * The tree node component represents a child node of the tree component or another tree node.\n * Usage:\n *\n * ```html\n *  <igx-tree>\n *  ...\n *    <igx-tree-node [data]=\"data\" [selected]=\"service.isNodeSelected(data.Key)\" [expanded]=\"service.isNodeExpanded(data.Key)\">\n *      {{ data.FirstName }} {{ data.LastName }}\n *    </igx-tree-node>\n *  ...\n *  </igx-tree>\n * ```\n */\n@Component({\n    selector: 'igx-tree-node',\n    templateUrl: 'tree-node.component.html',\n    providers: [\n        { provide: IGX_TREE_NODE_COMPONENT, useExisting: IgxTreeNodeComponent }\n    ]\n})\nexport class IgxTreeNodeComponent<T> extends ToggleAnimationPlayer implements IgxTreeNode<T>, OnInit, OnDestroy {\n    /**\n     * The data entry that the node is visualizing.\n     *\n     * @remarks\n     * Required for searching through nodes.\n     *\n     * @example\n     * ```html\n     *  <igx-tree>\n     *  ...\n     *    <igx-tree-node [data]=\"data\">\n     *      {{ data.FirstName }} {{ data.LastName }}\n     *    </igx-tree-node>\n     *  ...\n     *  </igx-tree>\n     * ```\n     */\n    @Input()\n    public data: T;\n\n    /**\n     * To be used for load-on-demand scenarios in order to specify whether the node is loading data.\n     *\n     * @remarks\n     * Loading nodes do not render children.\n     */\n    @Input()\n    public loading = false;\n\n    // TO DO: return different tab index depending on anchor child\n    /** @hidden @internal */\n    public set tabIndex(val: number) {\n        this._tabIndex = val;\n    }\n\n    /** @hidden @internal */\n    public get tabIndex(): number {\n        if (this.disabled) {\n            return -1;\n        }\n        if (this._tabIndex === null) {\n            if (this.navService.focusedNode === null) {\n                return this.hasLinkChildren ? -1 : 0;\n            }\n            return -1;\n        }\n        return this.hasLinkChildren ? -1 : this._tabIndex;\n    }\n\n    /** @hidden @internal */\n    public get animationSettings(): ToggleAnimationSettings {\n        return this.tree.animationSettings;\n    }\n\n    /**\n     * Gets/Sets the resource strings.\n     *\n     * @remarks\n     * Uses EN resources by default.\n     */\n    @Input()\n    public set resourceStrings(value: ITreeResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * An accessor that returns the resource strings.\n     */\n    public get resourceStrings(): ITreeResourceStrings {\n        if (!this._resourceStrings) {\n            this._resourceStrings = CurrentResourceStrings.TreeResStrings;\n        }\n        return this._resourceStrings;\n    }\n\n    /**\n     * Gets/Sets the active state of the node\n     *\n     * @param value: boolean\n     */\n    @Input()\n    public set active(value: boolean) {\n        if (value) {\n            this.navService.activeNode = this;\n            this.tree.activeNodeBindingChange.emit(this);\n        }\n    }\n\n    public get active(): boolean {\n        return this.navService.activeNode === this;\n    }\n\n    /**\n     * Emitted when the node's `selected` property changes.\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\" [(selected)]=\"node.selected\">\n     *      </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * node.selectedChange.pipe(takeUntil(this.destroy$)).subscribe((e: boolean) => console.log(\"Node selection changed to \", e))\n     * ```\n     */\n    @Output()\n    public selectedChange = new EventEmitter<boolean>();\n\n    /**\n     * Emitted when the node's `expanded` property changes.\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\" [(expanded)]=\"node.expanded\">\n     *      </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * node.expandedChange.pipe(takeUntil(this.destroy$)).subscribe((e: boolean) => console.log(\"Node expansion state changed to \", e))\n     * ```\n     */\n    @Output()\n    public expandedChange = new EventEmitter<boolean>();\n\n    /** @hidden @internal */\n    public get focused() {\n        return this.isFocused &&\n            this.navService.focusedNode === this;\n    }\n\n    /**\n     * Retrieves the full path to the node incuding itself\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const path: IgxTreeNode<any>[] = node.path;\n     * ```\n     */\n    public get path(): IgxTreeNode<any>[] {\n        return this.parentNode?.path ? [...this.parentNode.path, this] : [this];\n    }\n\n    // TODO: bind to disabled state when node is dragged\n    /**\n     * Gets/Sets the disabled state of the node\n     *\n     * @param value: boolean\n     */\n    @Input()\n    @HostBinding('class.igx-tree-node--disabled')\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        if (value !== this._disabled) {\n            this._disabled = value;\n            this.tree.disabledChange.emit(this);\n        }\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-tree-node')\n    public cssClass = 'igx-tree-node';\n\n    /** @hidden @internal */\n    @HostBinding('attr.role')\n    public get role() {\n        return this.hasLinkChildren ? 'none' : 'treeitem';\n    };\n\n    /** @hidden @internal */\n    @ContentChildren(IgxTreeNodeLinkDirective, { read: ElementRef })\n    public linkChildren: QueryList<ElementRef>;\n\n    /** @hidden @internal */\n    @ContentChildren(IGX_TREE_NODE_COMPONENT, { read: IGX_TREE_NODE_COMPONENT })\n    public _children: QueryList<IgxTreeNode<any>>;\n\n    /** @hidden @internal */\n    @ContentChildren(IGX_TREE_NODE_COMPONENT, { read: IGX_TREE_NODE_COMPONENT, descendants: true })\n    public allChildren: QueryList<IgxTreeNode<any>>;\n\n    /**\n     * Return the child nodes of the node (if any)\n     *\n     * @remark\n     * Returns `null` if node does not have children\n     *\n     * @example\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const children: IgxTreeNode<any>[] = node.children;\n     * ```\n     */\n    public get children(): IgxTreeNode<any>[] {\n        return this._children?.length ? this._children.toArray() : null;\n    }\n\n    // TODO: will be used in Drag and Drop implementation\n    /** @hidden @internal */\n    @ViewChild('ghostTemplate', { read: ElementRef })\n    public header: ElementRef;\n\n    @ViewChild('defaultIndicator', { read: TemplateRef, static: true })\n    private _defaultExpandIndicatorTemplate: TemplateRef<any>;\n\n    @ViewChild('childrenContainer', { read: ElementRef })\n    private childrenContainer: ElementRef;\n\n    private get hasLinkChildren(): boolean {\n        return this.linkChildren?.length > 0 || this.registeredChildren?.length > 0;\n    }\n\n    /** @hidden @internal */\n    public get isCompact(): boolean {\n        return this.tree?.displayDensity === DisplayDensity.compact;\n    }\n\n    /** @hidden @internal */\n    public get isCosy(): boolean {\n        return this.tree?.displayDensity === DisplayDensity.cosy;\n    }\n\n    /** @hidden @internal */\n    public isFocused: boolean;\n\n    /** @hidden @internal */\n    public registeredChildren: IgxTreeNodeLinkDirective[] = [];\n\n    /** @hidden @internal */\n    private _resourceStrings = CurrentResourceStrings.TreeResStrings;\n\n    private _tabIndex = null;\n    private _disabled = false;\n\n    constructor(\n        @Inject(IGX_TREE_COMPONENT) public tree: IgxTree,\n        protected selectionService: IgxTreeSelectionService,\n        protected treeService: IgxTreeService,\n        protected navService: IgxTreeNavigationService,\n        protected cdr: ChangeDetectorRef,\n        @Inject(IgxAngularAnimationService)protected animationService: AnimationService,\n        private element: ElementRef<HTMLElement>,\n        @Optional() @SkipSelf() @Inject(IGX_TREE_NODE_COMPONENT) public parentNode: IgxTreeNode<any>\n    ) {\n        super(animationService);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get showSelectors() {\n        return this.tree.selection !== IgxTreeSelectionType.None;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get indeterminate(): boolean {\n        return this.selectionService.isNodeIndeterminate(this);\n    }\n\n    /** The depth of the node, relative to the root\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node #node>\n     *      My level is {{ node.level }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[12])[0];\n     * const level: number = node.level;\n     * ```\n     */\n    public get level(): number {\n        return this.parentNode ? this.parentNode.level + 1 : 0;\n    }\n\n    /** Get/set whether the node is selected. Supporst two-way binding.\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node *ngFor=\"let node of data\" [(selected)]=\"node.selected\">\n     *      {{ node.label }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const selected = node.selected;\n     * node.selected = true;\n     * ```\n     */\n    @Input()\n    public get selected(): boolean {\n        return this.selectionService.isNodeSelected(this);\n    }\n\n    public set selected(val: boolean) {\n        if (!(this.tree?.nodes && this.tree.nodes.find((e) => e === this)) && val) {\n            this.tree.forceSelect.push(this);\n            return;\n        }\n        if (val && !this.selectionService.isNodeSelected(this)) {\n            this.selectionService.selectNodesWithNoEvent([this]);\n        }\n        if (!val && this.selectionService.isNodeSelected(this)) {\n            this.selectionService.deselectNodesWithNoEvent([this]);\n        }\n    }\n\n    /** Get/set whether the node is expanded\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node *ngFor=\"let node of data\" [expanded]=\"node.name === this.expandedNode\">\n     *      {{ node.label }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const expanded = node.expanded;\n     * node.expanded = true;\n     * ```\n     */\n    @Input()\n    public get expanded() {\n        return this.treeService.isExpanded(this);\n    }\n\n    public set expanded(val: boolean) {\n        if (val) {\n            this.treeService.expand(this, false);\n        } else {\n            this.treeService.collapse(this);\n        }\n    }\n\n    /** @hidden @internal */\n    public get expandIndicatorTemplate(): TemplateRef<any> {\n        return this.tree?.expandIndicator ? this.tree.expandIndicator : this._defaultExpandIndicatorTemplate;\n    }\n\n    /**\n     * The native DOM element representing the node. Could be null in certain environments.\n     *\n     * ```typescript\n     * // get the nativeElement of the second node\n     * const node: IgxTreeNode = this.tree.nodes.first();\n     * const nodeElement: HTMLElement = node.nativeElement;\n     * ```\n     */\n    /** @hidden @internal */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        this.openAnimationDone.pipe(takeUntil(this.destroy$)).subscribe(\n            () => {\n                this.tree.nodeExpanded.emit({ owner: this.tree, node: this });\n            }\n        );\n        this.closeAnimationDone.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.tree.nodeCollapsed.emit({ owner: this.tree, node: this });\n            this.treeService.collapse(this);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * Sets the focus to the node's <a> child, if present\n     * Sets the node as the tree service's focusedNode\n     * Marks the node as the current active element\n     */\n    public handleFocus(): void {\n        if (this.disabled) {\n            return;\n        }\n        if (this.navService.focusedNode !== this) {\n            this.navService.focusedNode = this;\n        }\n        this.isFocused = true;\n        if (this.linkChildren?.length) {\n            this.linkChildren.first.nativeElement.focus();\n            return;\n        }\n        if (this.registeredChildren.length) {\n            this.registeredChildren[0].elementRef.nativeElement.focus();\n            return;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * Clear the node's focused status\n     */\n    public clearFocus(): void {\n        this.isFocused = false;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSelectorClick(event) {\n        // event.stopPropagation();\n        event.preventDefault();\n        // this.navService.handleFocusedAndActiveNode(this);\n        if (event.shiftKey) {\n            this.selectionService.selectMultipleNodes(this, event);\n            return;\n        }\n        if (this.selected) {\n            this.selectionService.deselectNode(this, event);\n        } else {\n            this.selectionService.selectNode(this, event);\n        }\n    }\n\n    /**\n     * Toggles the node expansion state, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.toggle()\">Toggle Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.toggle();\n     * ```\n     */\n    public toggle() {\n        if (this.expanded) {\n            this.collapse();\n        } else {\n            this.expand();\n        }\n    }\n\n    /** @hidden @internal */\n    public indicatorClick() {\n        this.toggle();\n        this.navService.setFocusedAndActiveNode(this);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onPointerDown(event) {\n        event.stopPropagation();\n        this.navService.setFocusedAndActiveNode(this);\n    }\n\n    public ngOnDestroy() {\n        super.ngOnDestroy();\n        this.selectionService.ensureStateOnNodeDelete(this);\n    }\n\n    /**\n     * Expands the node, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.expand()\">Expand Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.expand();\n     * ```\n     */\n    public expand() {\n        const args: ITreeNodeTogglingEventArgs = {\n            owner: this.tree,\n            node: this,\n            cancel: false\n\n        };\n        this.tree.nodeExpanding.emit(args);\n        if (!args.cancel) {\n            this.treeService.expand(this, true);\n            this.cdr.detectChanges();\n            this.playOpenAnimation(\n                this.childrenContainer\n            );\n        }\n    }\n\n    /**\n     * Collapses the node, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.collapse()\">Collapse Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.collapse();\n     * ```\n     */\n    public collapse() {\n        const args: ITreeNodeTogglingEventArgs = {\n            owner: this.tree,\n            node: this,\n            cancel: false\n\n        };\n        this.tree.nodeCollapsing.emit(args);\n        if (!args.cancel) {\n            this.treeService.collapsing(this);\n            this.playCloseAnimation(\n                this.childrenContainer\n            );\n        }\n    }\n\n    /** @hidden @internal */\n    public addLinkChild(link: IgxTreeNodeLinkDirective) {\n        this._tabIndex = -1;\n        this.registeredChildren.push(link);\n    };\n\n    /** @hidden @internal */\n    public removeLinkChild(link: IgxTreeNodeLinkDirective) {\n        const index = this.registeredChildren.indexOf(link);\n        if (index !== -1) {\n            this.registeredChildren.splice(index, 1);\n        }\n    }\n}\n","<ng-template #noDragTemplate>\n    <ng-template *ngTemplateOutlet=\"headerTemplate\"></ng-template>\n</ng-template>\n\n<!-- Will switch templates depending on dragDrop -->\n<ng-template *ngTemplateOutlet=\"noDragTemplate\">\n</ng-template>\n\n<div #childrenContainer\n    *ngIf=\"expanded && !loading\"\n    class=\"igx-tree-node__group\"\n    role=\"group\"\n>\n    <ng-content select=\"igx-tree-node\"></ng-content>\n</div>\n\n\n<ng-template #defaultIndicator>\n    <igx-icon [attr.aria-label]=\"expanded ? resourceStrings.igx_collapse : resourceStrings.igx_expand\">\n        {{ expanded ? \"keyboard_arrow_down\" : \"keyboard_arrow_right\" }}\n    </igx-icon>\n</ng-template>\n\n<!-- separated in a template in case this ever needs to be templatable -->\n<ng-template #selectMarkerTemplate>\n    <igx-checkbox [checked]=\"selected\" [readonly]=\"true\" [indeterminate]=\"indeterminate\" [tabindex]=\"-1\">\n    </igx-checkbox>\n</ng-template>\n\n<ng-template #headerTemplate>\n    <div #ghostTemplate class=\"igx-tree-node__wrapper\"\n        [attr.role]=\"role\"\n        [tabIndex]=\"tabIndex\"\n        [ngClass]=\"{\n            'igx-tree-node__wrapper--cosy': isCosy,\n            'igx-tree-node__wrapper--compact': isCompact,\n            'igx-tree-node__wrapper--selected': selected,\n            'igx-tree-node__wrapper--active' : this.active,\n            'igx-tree-node__wrapper--focused' : this.focused,\n            'igx-tree-node__wrapper--disabled' : this.disabled\n        }\"\n        (pointerdown)=\"onPointerDown($event)\"\n        (focus)=\"handleFocus()\"\n        (blur)=\"clearFocus()\"\n    >\n        <div aria-hidden=\"true\">\n            <span *ngFor=\"let item of [].constructor(level)\"\n                aria-hidden=\"true\"\n                class=\"igx-tree-node__spacer\"\n            ></span>\n        </div>\n\n        <!-- Expand/Collapse indicator -->\n        <span *ngIf=\"!loading\"\n            class=\"igx-tree-node__toggle-button\"\n            [ngClass]=\"{ 'igx-tree-node__toggle-button--hidden': !_children?.length }\"\n            (click)=\"indicatorClick()\"\n        >\n            <ng-container *ngTemplateOutlet=\"expandIndicatorTemplate, context: { $implicit: expanded }\">\n            </ng-container>\n        </span>\n        <span *ngIf=\"loading\"\n            class=\"igx-tree-node__toggle-button\"\n        >\n        \t<igx-circular-bar\n            \t[animate]=\"false\"\n            \t[indeterminate]=\"true\"\n            \t[textVisibility]=\"false\"\n        \t>\n        \t</igx-circular-bar>\n        </span>\n\n        <!-- Item selection -->\n        <div *ngIf=\"showSelectors\"\n            class=\"igx-tree-node__select\"\n            (pointerdown)=\"$event.preventDefault()\"\n            (click)=\"onSelectorClick($event)\">\n            <ng-container *ngTemplateOutlet=\"selectMarkerTemplate\">\n            </ng-container>\n        </div>\n\n        <div class=\"igx-tree-node__content\">\n            <!-- Ghost content -->\n            <ng-content></ng-content>\n        </div>\n    </div>\n\n    <!--  Buffer element for 'move after' when D&D is implemented-->\n    <div class=\"igx-tree-node__drop-indicator\">\n        <span aria-hidden=\"true\" class=\"igx-tree-node__spacer\" *ngFor=\"let item of [].constructor(level)\"></span>\n        <!-- style rules target this div, do not delete it -->\n        <div></div>\n    </div>\n</ng-template>\n\n<ng-template #dragTemplate>\n    <!-- Drag drop goes here\n        igxDrop\n        #dropRef=\"drop\"\n        [igxNodeDrag]=\"this\"\n        (dragStart)=\"logDrop(dropRef)\"\n        (leave)=\"emitLeave()\"\n        (enter)=\"emitEnter()\" -->\n    <div class=\"igx-tree-node__drag-wrapper\">\n        <ng-template *ngTemplateOutlet=\"headerTemplate\"></ng-template>\n    </div>\n</ng-template>\n"]}
654
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-node.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/tree/tree-node/tree-node.component.ts","../../../../../../projects/igniteui-angular/src/lib/tree/tree-node/tree-node.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    SkipSelf,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { DisplayDensity } from '../../core/displayDensity';\nimport { CurrentResourceStrings } from '../../core/i18n/resources';\nimport { ITreeResourceStrings } from '../../core/i18n/tree-resources';\nimport { ToggleAnimationPlayer, ToggleAnimationSettings } from '../../expansion-panel/toggle-animation-component';\nimport { IgxAngularAnimationService } from '../../services/animation/angular-animation-service';\nimport { AnimationService } from '../../services/animation/animation';\nimport {\n    IgxTree,\n    IgxTreeNode,\n    IgxTreeSelectionType,\n    IGX_TREE_COMPONENT,\n    IGX_TREE_NODE_COMPONENT,\n    ITreeNodeTogglingEventArgs\n} from '../common';\nimport { IgxTreeNavigationService } from '../tree-navigation.service';\nimport { IgxTreeSelectionService } from '../tree-selection.service';\nimport { IgxTreeService } from '../tree.service';\n\n// TODO: Implement aria functionality\n/**\n * @hidden @internal\n * Used for links (`a` tags) in the body of an `igx-tree-node`. Handles aria and event dispatch.\n */\n@Directive({\n    selector: `[igxTreeNodeLink]`\n})\nexport class IgxTreeNodeLinkDirective implements OnDestroy {\n\n    @HostBinding('attr.role')\n    public role = 'treeitem';\n\n    /**\n     * The node's parent. Should be used only when the link is defined\n     * in `<ng-template>` tag outside of its parent, as Angular DI will not properly provide a reference\n     *\n     * ```html\n     * <igx-tree>\n     *     <igx-tree-node #myNode *ngFor=\"let node of data\" [data]=\"node\">\n     *         <ng-template *ngTemplateOutlet=\"nodeTemplate; context: { $implicit: data, parentNode: myNode }\">\n     *         </ng-template>\n     *     </igx-tree-node>\n     *     ...\n     *     <!-- node template is defined under tree to access related services -->\n     *     <ng-template #nodeTemplate let-data let-node=\"parentNode\">\n     *         <a [igxTreeNodeLink]=\"node\">{{ data.label }}</a>\n     *     </ng-template>\n     * </igx-tree>\n     * ```\n     */\n    @Input('igxTreeNodeLink')\n    public set parentNode(val: any) {\n        if (val) {\n            this._parentNode = val;\n            (this._parentNode as any).addLinkChild(this);\n        }\n    }\n\n    public get parentNode(): any {\n        return this._parentNode;\n    }\n\n    /** A pointer to the parent node */\n    private get target(): IgxTreeNode<any> {\n        return this.node || this.parentNode;\n    }\n\n    private _parentNode: IgxTreeNode<any> = null;\n\n    constructor(@Optional() @Inject(IGX_TREE_NODE_COMPONENT)\n    private node: IgxTreeNode<any>,\n        private navService: IgxTreeNavigationService,\n        public elementRef: ElementRef) {\n    }\n\n    /** @hidden @internal */\n    @HostBinding('attr.tabindex')\n    public get tabIndex(): number {\n        return this.navService.focusedNode === this.target ? (this.target?.disabled ? -1 : 0) : -1;\n    }\n\n    /**\n     * @hidden @internal\n     * Clear the node's focused state\n     */\n    @HostListener('blur')\n    public handleBlur() {\n        this.target.isFocused = false;\n    }\n\n    /**\n     * @hidden @internal\n     * Set the node as focused\n     */\n    @HostListener('focus')\n    public handleFocus() {\n        if (this.target && !this.target.disabled) {\n            if (this.navService.focusedNode !== this.target) {\n                this.navService.focusedNode = this.target;\n            }\n            this.target.isFocused = true;\n        }\n    }\n\n    public ngOnDestroy() {\n        this.target.removeLinkChild(this);\n    }\n}\n\n/**\n *\n * The tree node component represents a child node of the tree component or another tree node.\n * Usage:\n *\n * ```html\n *  <igx-tree>\n *  ...\n *    <igx-tree-node [data]=\"data\" [selected]=\"service.isNodeSelected(data.Key)\" [expanded]=\"service.isNodeExpanded(data.Key)\">\n *      {{ data.FirstName }} {{ data.LastName }}\n *    </igx-tree-node>\n *  ...\n *  </igx-tree>\n * ```\n */\n@Component({\n    selector: 'igx-tree-node',\n    templateUrl: 'tree-node.component.html',\n    providers: [\n        { provide: IGX_TREE_NODE_COMPONENT, useExisting: IgxTreeNodeComponent }\n    ]\n})\nexport class IgxTreeNodeComponent<T> extends ToggleAnimationPlayer implements IgxTreeNode<T>, OnInit, OnDestroy {\n    /**\n     * The data entry that the node is visualizing.\n     *\n     * @remarks\n     * Required for searching through nodes.\n     *\n     * @example\n     * ```html\n     *  <igx-tree>\n     *  ...\n     *    <igx-tree-node [data]=\"data\">\n     *      {{ data.FirstName }} {{ data.LastName }}\n     *    </igx-tree-node>\n     *  ...\n     *  </igx-tree>\n     * ```\n     */\n    @Input()\n    public data: T;\n\n    /**\n     * To be used for load-on-demand scenarios in order to specify whether the node is loading data.\n     *\n     * @remarks\n     * Loading nodes do not render children.\n     */\n    @Input()\n    public loading = false;\n\n    // TO DO: return different tab index depending on anchor child\n    /** @hidden @internal */\n    public set tabIndex(val: number) {\n        this._tabIndex = val;\n    }\n\n    /** @hidden @internal */\n    public get tabIndex(): number {\n        if (this.disabled) {\n            return -1;\n        }\n        if (this._tabIndex === null) {\n            if (this.navService.focusedNode === null) {\n                return this.hasLinkChildren ? -1 : 0;\n            }\n            return -1;\n        }\n        return this.hasLinkChildren ? -1 : this._tabIndex;\n    }\n\n    /** @hidden @internal */\n    public get animationSettings(): ToggleAnimationSettings {\n        return this.tree.animationSettings;\n    }\n\n    /**\n     * Gets/Sets the resource strings.\n     *\n     * @remarks\n     * Uses EN resources by default.\n     */\n    @Input()\n    public set resourceStrings(value: ITreeResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * An accessor that returns the resource strings.\n     */\n    public get resourceStrings(): ITreeResourceStrings {\n        if (!this._resourceStrings) {\n            this._resourceStrings = CurrentResourceStrings.TreeResStrings;\n        }\n        return this._resourceStrings;\n    }\n\n    /**\n     * Gets/Sets the active state of the node\n     *\n     * @param value: boolean\n     */\n    @Input()\n    public set active(value: boolean) {\n        if (value) {\n            this.navService.activeNode = this;\n            this.tree.activeNodeBindingChange.emit(this);\n        }\n    }\n\n    public get active(): boolean {\n        return this.navService.activeNode === this;\n    }\n\n    /**\n     * Emitted when the node's `selected` property changes.\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\" [(selected)]=\"node.selected\">\n     *      </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * node.selectedChange.pipe(takeUntil(this.destroy$)).subscribe((e: boolean) => console.log(\"Node selection changed to \", e))\n     * ```\n     */\n    @Output()\n    public selectedChange = new EventEmitter<boolean>();\n\n    /**\n     * Emitted when the node's `expanded` property changes.\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node *ngFor=\"let node of data\" [data]=\"node\" [(expanded)]=\"node.expanded\">\n     *      </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * node.expandedChange.pipe(takeUntil(this.destroy$)).subscribe((e: boolean) => console.log(\"Node expansion state changed to \", e))\n     * ```\n     */\n    @Output()\n    public expandedChange = new EventEmitter<boolean>();\n\n    /** @hidden @internal */\n    public get focused() {\n        return this.isFocused &&\n            this.navService.focusedNode === this;\n    }\n\n    /**\n     * Retrieves the full path to the node incuding itself\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const path: IgxTreeNode<any>[] = node.path;\n     * ```\n     */\n    public get path(): IgxTreeNode<any>[] {\n        return this.parentNode?.path ? [...this.parentNode.path, this] : [this];\n    }\n\n    // TODO: bind to disabled state when node is dragged\n    /**\n     * Gets/Sets the disabled state of the node\n     *\n     * @param value: boolean\n     */\n    @Input()\n    @HostBinding('class.igx-tree-node--disabled')\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        if (value !== this._disabled) {\n            this._disabled = value;\n            this.tree.disabledChange.emit(this);\n        }\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-tree-node')\n    public cssClass = 'igx-tree-node';\n\n    /** @hidden @internal */\n    @HostBinding('attr.role')\n    public get role() {\n        return this.hasLinkChildren ? 'none' : 'treeitem';\n    };\n\n    /** @hidden @internal */\n    @ContentChildren(IgxTreeNodeLinkDirective, { read: ElementRef })\n    public linkChildren: QueryList<ElementRef>;\n\n    /** @hidden @internal */\n    @ContentChildren(IGX_TREE_NODE_COMPONENT, { read: IGX_TREE_NODE_COMPONENT })\n    public _children: QueryList<IgxTreeNode<any>>;\n\n    /** @hidden @internal */\n    @ContentChildren(IGX_TREE_NODE_COMPONENT, { read: IGX_TREE_NODE_COMPONENT, descendants: true })\n    public allChildren: QueryList<IgxTreeNode<any>>;\n\n    /**\n     * Return the child nodes of the node (if any)\n     *\n     * @remark\n     * Returns `null` if node does not have children\n     *\n     * @example\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const children: IgxTreeNode<any>[] = node.children;\n     * ```\n     */\n    public get children(): IgxTreeNode<any>[] {\n        return this._children?.length ? this._children.toArray() : null;\n    }\n\n    // TODO: will be used in Drag and Drop implementation\n    /** @hidden @internal */\n    @ViewChild('ghostTemplate', { read: ElementRef })\n    public header: ElementRef;\n\n    @ViewChild('defaultIndicator', { read: TemplateRef, static: true })\n    private _defaultExpandIndicatorTemplate: TemplateRef<any>;\n\n    @ViewChild('childrenContainer', { read: ElementRef })\n    private childrenContainer: ElementRef;\n\n    private get hasLinkChildren(): boolean {\n        return this.linkChildren?.length > 0 || this.registeredChildren?.length > 0;\n    }\n\n    /** @hidden @internal */\n    public get isCompact(): boolean {\n        return this.tree?.displayDensity === DisplayDensity.compact;\n    }\n\n    /** @hidden @internal */\n    public get isCosy(): boolean {\n        return this.tree?.displayDensity === DisplayDensity.cosy;\n    }\n\n    /** @hidden @internal */\n    public isFocused: boolean;\n\n    /** @hidden @internal */\n    public registeredChildren: IgxTreeNodeLinkDirective[] = [];\n\n    /** @hidden @internal */\n    private _resourceStrings = CurrentResourceStrings.TreeResStrings;\n\n    private _tabIndex = null;\n    private _disabled = false;\n\n    constructor(\n        @Inject(IGX_TREE_COMPONENT) public tree: IgxTree,\n        protected selectionService: IgxTreeSelectionService,\n        protected treeService: IgxTreeService,\n        protected navService: IgxTreeNavigationService,\n        protected cdr: ChangeDetectorRef,\n        @Inject(IgxAngularAnimationService) protected animationService: AnimationService,\n        private element: ElementRef<HTMLElement>,\n        @Optional() @SkipSelf() @Inject(IGX_TREE_NODE_COMPONENT) public parentNode: IgxTreeNode<any>\n    ) {\n        super(animationService);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get showSelectors() {\n        return this.tree.selection !== IgxTreeSelectionType.None;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get indeterminate(): boolean {\n        return this.selectionService.isNodeIndeterminate(this);\n    }\n\n    /** The depth of the node, relative to the root\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node #node>\n     *      My level is {{ node.level }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[12])[0];\n     * const level: number = node.level;\n     * ```\n     */\n    public get level(): number {\n        return this.parentNode ? this.parentNode.level + 1 : 0;\n    }\n\n    /** Get/set whether the node is selected. Supporst two-way binding.\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node *ngFor=\"let node of data\" [(selected)]=\"node.selected\">\n     *      {{ node.label }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const selected = node.selected;\n     * node.selected = true;\n     * ```\n     */\n    @Input()\n    public get selected(): boolean {\n        return this.selectionService.isNodeSelected(this);\n    }\n\n    public set selected(val: boolean) {\n        if (!(this.tree?.nodes && this.tree.nodes.find((e) => e === this)) && val) {\n            this.tree.forceSelect.push(this);\n            return;\n        }\n        if (val && !this.selectionService.isNodeSelected(this)) {\n            this.selectionService.selectNodesWithNoEvent([this]);\n        }\n        if (!val && this.selectionService.isNodeSelected(this)) {\n            this.selectionService.deselectNodesWithNoEvent([this]);\n        }\n    }\n\n    /** Get/set whether the node is expanded\n     *\n     * ```html\n     * <igx-tree>\n     *  ...\n     *  <igx-tree-node *ngFor=\"let node of data\" [expanded]=\"node.name === this.expandedNode\">\n     *      {{ node.label }}\n     *  </igx-tree-node>\n     * </igx-tree>\n     * ```\n     *\n     * ```typescript\n     * const node: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * const expanded = node.expanded;\n     * node.expanded = true;\n     * ```\n     */\n    @Input()\n    public get expanded() {\n        return this.treeService.isExpanded(this);\n    }\n\n    public set expanded(val: boolean) {\n        if (val) {\n            this.treeService.expand(this, false);\n        } else {\n            this.treeService.collapse(this);\n        }\n    }\n\n    /** @hidden @internal */\n    public get expandIndicatorTemplate(): TemplateRef<any> {\n        return this.tree?.expandIndicator ? this.tree.expandIndicator : this._defaultExpandIndicatorTemplate;\n    }\n\n    /**\n     * The native DOM element representing the node. Could be null in certain environments.\n     *\n     * ```typescript\n     * // get the nativeElement of the second node\n     * const node: IgxTreeNode = this.tree.nodes.first();\n     * const nodeElement: HTMLElement = node.nativeElement;\n     * ```\n     */\n    /** @hidden @internal */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        this.openAnimationDone.pipe(takeUntil(this.destroy$)).subscribe(\n            () => {\n                this.tree.nodeExpanded.emit({ owner: this.tree, node: this });\n            }\n        );\n        this.closeAnimationDone.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.tree.nodeCollapsed.emit({ owner: this.tree, node: this });\n            this.treeService.collapse(this);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * @hidden @internal\n     * Sets the focus to the node's <a> child, if present\n     * Sets the node as the tree service's focusedNode\n     * Marks the node as the current active element\n     */\n    public handleFocus(): void {\n        if (this.disabled) {\n            return;\n        }\n        if (this.navService.focusedNode !== this) {\n            this.navService.focusedNode = this;\n        }\n        this.isFocused = true;\n        if (this.linkChildren?.length) {\n            this.linkChildren.first.nativeElement.focus();\n            return;\n        }\n        if (this.registeredChildren.length) {\n            this.registeredChildren[0].elementRef.nativeElement.focus();\n            return;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     * Clear the node's focused status\n     */\n    public clearFocus(): void {\n        this.isFocused = false;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onSelectorClick(event) {\n        // event.stopPropagation();\n        event.preventDefault();\n        // this.navService.handleFocusedAndActiveNode(this);\n        if (event.shiftKey) {\n            this.selectionService.selectMultipleNodes(this, event);\n            return;\n        }\n        if (this.selected) {\n            this.selectionService.deselectNode(this, event);\n        } else {\n            this.selectionService.selectNode(this, event);\n        }\n    }\n\n    /**\n     * Toggles the node expansion state, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.toggle()\">Toggle Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.toggle();\n     * ```\n     */\n    public toggle() {\n        if (this.expanded) {\n            this.collapse();\n        } else {\n            this.expand();\n        }\n    }\n\n    /** @hidden @internal */\n    public indicatorClick() {\n        this.toggle();\n        this.navService.setFocusedAndActiveNode(this);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public onPointerDown(event) {\n        event.stopPropagation();\n        this.navService.setFocusedAndActiveNode(this);\n    }\n\n    public ngOnDestroy() {\n        super.ngOnDestroy();\n        this.selectionService.ensureStateOnNodeDelete(this);\n    }\n\n    /**\n     * Expands the node, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.expand()\">Expand Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.expand();\n     * ```\n     */\n    public expand() {\n        if (this.expanded && !this.treeService.collapsingNodes.has(this)) {\n            return;\n        }\n        const args: ITreeNodeTogglingEventArgs = {\n            owner: this.tree,\n            node: this,\n            cancel: false\n\n        };\n        this.tree.nodeExpanding.emit(args);\n        if (!args.cancel) {\n            this.treeService.expand(this, true);\n            this.cdr.detectChanges();\n            this.playOpenAnimation(\n                this.childrenContainer\n            );\n        }\n    }\n\n    /**\n     * Collapses the node, triggering animation\n     *\n     * ```html\n     * <igx-tree>\n     *      <igx-tree-node #node>My Node</igx-tree-node>\n     * </igx-tree>\n     * <button igxButton (click)=\"node.collapse()\">Collapse Node</button>\n     * ```\n     *\n     * ```typescript\n     * const myNode: IgxTreeNode<any> = this.tree.findNodes(data[0])[0];\n     * myNode.collapse();\n     * ```\n     */\n    public collapse() {\n        if (!this.expanded || this.treeService.collapsingNodes.has(this)) {\n            return;\n        }\n        const args: ITreeNodeTogglingEventArgs = {\n            owner: this.tree,\n            node: this,\n            cancel: false\n\n        };\n        this.tree.nodeCollapsing.emit(args);\n        if (!args.cancel) {\n            this.treeService.collapsing(this);\n            this.playCloseAnimation(\n                this.childrenContainer\n            );\n        }\n    }\n\n    /** @hidden @internal */\n    public addLinkChild(link: IgxTreeNodeLinkDirective) {\n        this._tabIndex = -1;\n        this.registeredChildren.push(link);\n    };\n\n    /** @hidden @internal */\n    public removeLinkChild(link: IgxTreeNodeLinkDirective) {\n        const index = this.registeredChildren.indexOf(link);\n        if (index !== -1) {\n            this.registeredChildren.splice(index, 1);\n        }\n    }\n}\n","<ng-template #noDragTemplate>\n    <ng-template *ngTemplateOutlet=\"headerTemplate\"></ng-template>\n</ng-template>\n\n<!-- Will switch templates depending on dragDrop -->\n<ng-template *ngTemplateOutlet=\"noDragTemplate\">\n</ng-template>\n\n<div #childrenContainer\n    *ngIf=\"expanded && !loading\"\n    class=\"igx-tree-node__group\"\n    role=\"group\"\n>\n    <ng-content select=\"igx-tree-node\"></ng-content>\n</div>\n\n\n<ng-template #defaultIndicator>\n    <igx-icon [attr.aria-label]=\"expanded ? resourceStrings.igx_collapse : resourceStrings.igx_expand\">\n        {{ expanded ? \"keyboard_arrow_down\" : \"keyboard_arrow_right\" }}\n    </igx-icon>\n</ng-template>\n\n<!-- separated in a template in case this ever needs to be templatable -->\n<ng-template #selectMarkerTemplate>\n    <igx-checkbox [checked]=\"selected\" [readonly]=\"true\" [indeterminate]=\"indeterminate\" [tabindex]=\"-1\">\n    </igx-checkbox>\n</ng-template>\n\n<ng-template #headerTemplate>\n    <div #ghostTemplate class=\"igx-tree-node__wrapper\"\n        [attr.role]=\"role\"\n        [tabIndex]=\"tabIndex\"\n        [ngClass]=\"{\n            'igx-tree-node__wrapper--cosy': isCosy,\n            'igx-tree-node__wrapper--compact': isCompact,\n            'igx-tree-node__wrapper--selected': selected,\n            'igx-tree-node__wrapper--active' : this.active,\n            'igx-tree-node__wrapper--focused' : this.focused,\n            'igx-tree-node__wrapper--disabled' : this.disabled\n        }\"\n        (pointerdown)=\"onPointerDown($event)\"\n        (focus)=\"handleFocus()\"\n        (blur)=\"clearFocus()\"\n    >\n        <div aria-hidden=\"true\">\n            <span *ngFor=\"let item of [].constructor(level)\"\n                aria-hidden=\"true\"\n                class=\"igx-tree-node__spacer\"\n            ></span>\n        </div>\n\n        <!-- Expand/Collapse indicator -->\n        <span *ngIf=\"!loading\"\n            class=\"igx-tree-node__toggle-button\"\n            [ngClass]=\"{ 'igx-tree-node__toggle-button--hidden': !_children?.length }\"\n            (click)=\"indicatorClick()\"\n        >\n            <ng-container *ngTemplateOutlet=\"expandIndicatorTemplate, context: { $implicit: expanded }\">\n            </ng-container>\n        </span>\n        <span *ngIf=\"loading\"\n            class=\"igx-tree-node__toggle-button\"\n        >\n        \t<igx-circular-bar\n            \t[animate]=\"false\"\n            \t[indeterminate]=\"true\"\n            \t[textVisibility]=\"false\"\n        \t>\n        \t</igx-circular-bar>\n        </span>\n\n        <!-- Item selection -->\n        <div *ngIf=\"showSelectors\"\n            class=\"igx-tree-node__select\"\n            (pointerdown)=\"$event.preventDefault()\"\n            (click)=\"onSelectorClick($event)\">\n            <ng-container *ngTemplateOutlet=\"selectMarkerTemplate\">\n            </ng-container>\n        </div>\n\n        <div class=\"igx-tree-node__content\">\n            <!-- Ghost content -->\n            <ng-content></ng-content>\n        </div>\n    </div>\n\n    <!--  Buffer element for 'move after' when D&D is implemented-->\n    <div class=\"igx-tree-node__drop-indicator\">\n        <span aria-hidden=\"true\" class=\"igx-tree-node__spacer\" *ngFor=\"let item of [].constructor(level)\"></span>\n        <!-- style rules target this div, do not delete it -->\n        <div></div>\n    </div>\n</ng-template>\n\n<ng-template #dragTemplate>\n    <!-- Drag drop goes here\n        igxDrop\n        #dropRef=\"drop\"\n        [igxNodeDrag]=\"this\"\n        (dragStart)=\"logDrop(dropRef)\"\n        (leave)=\"emitLeave()\"\n        (enter)=\"emitEnter()\" -->\n    <div class=\"igx-tree-node__drag-wrapper\">\n        <ng-template *ngTemplateOutlet=\"headerTemplate\"></ng-template>\n    </div>\n</ng-template>\n"]}