UNPKG

ngx-bootstrap-treeview

Version:

Ngx Bootstrap Treeview - Simple library to visualize, search and interact with tree data

175 lines 17.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ import { Component, Input, ElementRef, Renderer2, ViewChild, NgZone, Output, EventEmitter } from '@angular/core'; import { ContextMenuService } from '../../services/context-menu.service'; export class NgxBootstrapTreeviewContextMenuComponent { /** * @param {?} _renderer * @param {?} _zone * @param {?} _contextMenuService */ constructor(_renderer, _zone, _contextMenuService) { this._renderer = _renderer; this._zone = _zone; this._contextMenuService = _contextMenuService; this._defaultConfig = { containerClass: '', hoveredItemClass: '', itemsClass: '' }; this.config = {}; this.rootContextMenu = null; this.branchContextMenu = null; this.leafContextMenu = null; this.hidden = new EventEmitter(); this.shown = new EventEmitter(); this._activeMenu = null; } /** * @return {?} */ ngOnInit() { this.config = Object.assign({}, this._defaultConfig, this.config); this._contextMenuService.lastContextMenuEvent.subscribe((lastContextMenuEvent) => { if (lastContextMenuEvent) { this.show(lastContextMenuEvent); } else { this.hide(); } }); this._renderer.listen(document, 'click.out-zone', this.onDocumentClicked.bind(this)); this._renderer.listen(document, 'keyup.out-zone', this.onKeyPressed.bind(this)); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if ('config' in changes) { this.config = Object.assign({}, this._defaultConfig, changes.config.currentValue); } } /** * @param {?} event * @return {?} */ onDocumentClicked(event) { if (this.lastContextMenuEvent) { event.preventDefault(); event.stopPropagation(); this.hide(); } } /** * @param {?} event * @return {?} */ onKeyPressed(event) { if (this.lastContextMenuEvent && event.key.toLowerCase() === 'escape') { this.hide(); } } /** * @return {?} */ getLabels() { return this._activeMenu ? Object.keys(this._activeMenu) : []; } /** * @param {?} label * @return {?} */ onItemClicked(label) { this._activeMenu[label](this.lastContextMenuEvent.target); } /** * @return {?} */ hide() { this._zone.run(() => { this._activeMenu = null; this.lastContextMenuEvent = null; this.hidden.emit(); }); } /** * @param {?} contextMenuEvent * @return {?} */ show(contextMenuEvent) { this.lastContextMenuEvent = contextMenuEvent; if (!contextMenuEvent.target) { this._activeMenu = this.rootContextMenu; } else if (contextMenuEvent.target.children) { this._activeMenu = this.branchContextMenu; } else { this._activeMenu = this.leafContextMenu; } /** @type {?} */ const nativeElement = this.container.nativeElement; /** @type {?} */ const x = this.lastContextMenuEvent.event.pageX.toString(); /** @type {?} */ const y = this.lastContextMenuEvent.event.pageY.toString(); this._renderer.setStyle(nativeElement, 'top', y + 'px'); this._renderer.setStyle(nativeElement, 'left', x + 'px'); this.shown.emit(); } } NgxBootstrapTreeviewContextMenuComponent.decorators = [ { type: Component, args: [{ // tslint:disable-next-line: component-selector selector: 'ngx-bootstrap-treeview-context-menu', template: "<div\r\n class=\"context-menu list-group\"\r\n [ngClass]=\"{ 'd-none': !lastContextMenuEvent, 'd-block': lastContextMenuEvent }\"\r\n #container\r\n>\r\n <button\r\n class=\"context-menu-item {{ config.itemsClass }}\"\r\n *ngFor=\"let label of getLabels()\"\r\n (click)=\"onItemClicked(label)\"\r\n [ngClass]=\"{ 'list-group-item list-group-item-action px-3': !config.itemsClass }\"\r\n >\r\n {{ label }}\r\n </button>\r\n</div>\r\n", styles: [".context-menu{background-color:#fff;border-radius:.25rem;left:0;position:fixed;top:0;z-index:100}.context-menu .context-menu-item{border-top-width:0;border-bottom-width:0;padding-top:.0625rem;padding-bottom:.0625rem;transition:background-color .3s}.context-menu .context-menu-item:first-of-type{padding-top:.125rem;border-top-width:1px}.context-menu .context-menu-item:last-of-type{padding-bottom:.125rem;border-bottom-width:1px}.context-menu .context-menu-item:hover{background:rgba(0,0,0,.8);color:#fff}"] }] } ]; /** @nocollapse */ NgxBootstrapTreeviewContextMenuComponent.ctorParameters = () => [ { type: Renderer2 }, { type: NgZone }, { type: ContextMenuService } ]; NgxBootstrapTreeviewContextMenuComponent.propDecorators = { config: [{ type: Input }], rootContextMenu: [{ type: Input }], branchContextMenu: [{ type: Input }], leafContextMenu: [{ type: Input }], hidden: [{ type: Output }], shown: [{ type: Output }], container: [{ type: ViewChild, args: ['container',] }] }; if (false) { /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype._defaultConfig; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.config; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.rootContextMenu; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.branchContextMenu; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.leafContextMenu; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.hidden; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.shown; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.container; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype._activeMenu; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype.lastContextMenuEvent; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype._renderer; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype._zone; /** @type {?} */ NgxBootstrapTreeviewContextMenuComponent.prototype._contextMenuService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-bootstrap-treeview-context-menu.component.js","sourceRoot":"ng://ngx-bootstrap-treeview/","sources":["components/ngx-bootstrap-treeview-context-menu/ngx-bootstrap-treeview-context-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    OnInit,\r\n    Input,\r\n    ElementRef,\r\n    Renderer2,\r\n    SimpleChanges,\r\n    OnChanges,\r\n    ViewChild,\r\n    NgZone,\r\n    Output,\r\n    EventEmitter\r\n} from '@angular/core';\r\nimport { NgxBootstrapTreeviewContextMenuConfig } from '../../models/ngx-bootstrap-treeview-context-menu-config.model';\r\nimport { NgxBootstrapTreeviewContextMenuActions } from '../../models/ngx-bootstrap-treeview-context-menu-actions.model';\r\nimport { ContextMenuService } from '../../services/context-menu.service';\r\nimport { ContextMenuEvent } from '../../models/context-menu-event.model';\r\n\r\n@Component({\r\n    // tslint:disable-next-line: component-selector\r\n    selector: 'ngx-bootstrap-treeview-context-menu',\r\n    templateUrl: './ngx-bootstrap-treeview-context-menu.component.html',\r\n    styleUrls: ['./ngx-bootstrap-treeview-context-menu.component.scss']\r\n})\r\nexport class NgxBootstrapTreeviewContextMenuComponent implements OnInit, OnChanges {\r\n    public _defaultConfig: NgxBootstrapTreeviewContextMenuConfig = {\r\n        containerClass: '',\r\n        hoveredItemClass: '',\r\n        itemsClass: ''\r\n    };\r\n\r\n    @Input()\r\n    public config: NgxBootstrapTreeviewContextMenuConfig = {};\r\n\r\n    @Input()\r\n    public rootContextMenu: NgxBootstrapTreeviewContextMenuActions = null;\r\n\r\n    @Input()\r\n    public branchContextMenu: NgxBootstrapTreeviewContextMenuActions = null;\r\n\r\n    @Input()\r\n    public leafContextMenu: NgxBootstrapTreeviewContextMenuActions = null;\r\n\r\n    @Output()\r\n    public hidden = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public shown = new EventEmitter<void>();\r\n\r\n    @ViewChild('container')\r\n    public container: ElementRef<HTMLDivElement>;\r\n\r\n    private _activeMenu: NgxBootstrapTreeviewContextMenuActions = null;\r\n\r\n    public lastContextMenuEvent: ContextMenuEvent;\r\n\r\n    constructor(private _renderer: Renderer2, private _zone: NgZone, private _contextMenuService: ContextMenuService) {}\r\n\r\n    ngOnInit() {\r\n        this.config = { ...this._defaultConfig, ...this.config };\r\n\r\n        this._contextMenuService.lastContextMenuEvent.subscribe((lastContextMenuEvent: ContextMenuEvent) => {\r\n            if (lastContextMenuEvent) {\r\n                this.show(lastContextMenuEvent);\r\n            } else {\r\n                this.hide();\r\n            }\r\n        });\r\n\r\n        this._renderer.listen(document, 'click.out-zone', this.onDocumentClicked.bind(this));\r\n        this._renderer.listen(document, 'keyup.out-zone', this.onKeyPressed.bind(this));\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if ('config' in changes) {\r\n            this.config = { ...this._defaultConfig, ...changes.config.currentValue };\r\n        }\r\n    }\r\n\r\n    public onDocumentClicked(event: Event) {\r\n        if (this.lastContextMenuEvent) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n\r\n            this.hide();\r\n        }\r\n    }\r\n\r\n    public onKeyPressed(event: KeyboardEvent) {\r\n        if (this.lastContextMenuEvent && event.key.toLowerCase() === 'escape') {\r\n            this.hide();\r\n        }\r\n    }\r\n\r\n    public getLabels(): string[] {\r\n        return this._activeMenu ? Object.keys(this._activeMenu) : [];\r\n    }\r\n\r\n    public onItemClicked(label: string): void {\r\n        this._activeMenu[label](this.lastContextMenuEvent.target);\r\n    }\r\n\r\n    public hide(): void {\r\n        this._zone.run(() => {\r\n            this._activeMenu = null;\r\n            this.lastContextMenuEvent = null;\r\n\r\n            this.hidden.emit();\r\n        });\r\n    }\r\n\r\n    public show(contextMenuEvent: ContextMenuEvent): void {\r\n        this.lastContextMenuEvent = contextMenuEvent;\r\n\r\n        if (!contextMenuEvent.target) {\r\n            this._activeMenu = this.rootContextMenu;\r\n        } else if (contextMenuEvent.target.children) {\r\n            this._activeMenu = this.branchContextMenu;\r\n        } else {\r\n            this._activeMenu = this.leafContextMenu;\r\n        }\r\n\r\n        const nativeElement = this.container.nativeElement;\r\n        const x = this.lastContextMenuEvent.event.pageX.toString();\r\n        const y = this.lastContextMenuEvent.event.pageY.toString();\r\n\r\n        this._renderer.setStyle(nativeElement, 'top', y + 'px');\r\n        this._renderer.setStyle(nativeElement, 'left', x + 'px');\r\n\r\n        this.shown.emit();\r\n    }\r\n}\r\n"]}