ngx-bootstrap-treeview
Version:
Ngx Bootstrap Treeview - Simple library to visualize, search and interact with tree data
175 lines • 17.5 kB
JavaScript
/**
* @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":";;;;AAAA,OAAO,EACH,SAAS,EAET,KAAK,EACL,UAAU,EACV,SAAS,EAGT,SAAS,EACT,MAAM,EACN,MAAM,EACN,YAAY,EACf,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AASzE,MAAM,OAAO,wCAAwC;;;;;;IAgCjD,YAAoB,SAAoB,EAAU,KAAa,EAAU,mBAAuC;QAA5F,cAAS,GAAT,SAAS,CAAW;QAAU,UAAK,GAAL,KAAK,CAAQ;QAAU,wBAAmB,GAAnB,mBAAmB,CAAoB;QA/BzG,mBAAc,GAA0C;YAC3D,cAAc,EAAE,EAAE;YAClB,gBAAgB,EAAE,EAAE;YACpB,UAAU,EAAE,EAAE;SACjB,CAAC;QAGK,WAAM,GAA0C,EAAE,CAAC;QAGnD,oBAAe,GAA2C,IAAI,CAAC;QAG/D,sBAAiB,GAA2C,IAAI,CAAC;QAGjE,oBAAe,GAA2C,IAAI,CAAC;QAG/D,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAGlC,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAKhC,gBAAW,GAA2C,IAAI,CAAC;IAIgD,CAAC;;;;IAEpH,QAAQ;QACJ,IAAI,CAAC,MAAM,qBAAQ,IAAI,CAAC,cAAc,EAAK,IAAI,CAAC,MAAM,CAAE,CAAC;QAEzD,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,oBAAsC,EAAE,EAAE;YAC/F,IAAI,oBAAoB,EAAE;gBACtB,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;aACnC;iBAAM;gBACH,IAAI,CAAC,IAAI,EAAE,CAAC;aACf;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,gBAAgB,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACrF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACpF,CAAC;;;;;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,QAAQ,IAAI,OAAO,EAAE;YACrB,IAAI,CAAC,MAAM,qBAAQ,IAAI,CAAC,cAAc,EAAK,OAAO,CAAC,MAAM,CAAC,YAAY,CAAE,CAAC;SAC5E;IACL,CAAC;;;;;IAEM,iBAAiB,CAAC,KAAY;QACjC,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,CAAC,IAAI,EAAE,CAAC;SACf;IACL,CAAC;;;;;IAEM,YAAY,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,oBAAoB,IAAI,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE,KAAK,QAAQ,EAAE;YACnE,IAAI,CAAC,IAAI,EAAE,CAAC;SACf;IACL,CAAC;;;;IAEM,SAAS;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACjE,CAAC;;;;;IAEM,aAAa,CAAC,KAAa;QAC9B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC9D,CAAC;;;;IAEM,IAAI;QACP,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YAEjC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;;;;;IAEM,IAAI,CAAC,gBAAkC;QAC1C,IAAI,CAAC,oBAAoB,GAAG,gBAAgB,CAAC;QAE7C,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;YAC1B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC;SAC3C;aAAM,IAAI,gBAAgB,CAAC,MAAM,CAAC,QAAQ,EAAE;YACzC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC;SAC7C;aAAM;YACH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC;SAC3C;;cAEK,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa;;cAC5C,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;;cACpD,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;QAE1D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;QAEzD,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;;;YAhHJ,SAAS,SAAC;;gBAEP,QAAQ,EAAE,qCAAqC;gBAC/C,ifAAmE;;aAEtE;;;;YAlBG,SAAS;YAIT,MAAM;YAMD,kBAAkB;;;qBAgBtB,KAAK;8BAGL,KAAK;gCAGL,KAAK;8BAGL,KAAK;qBAGL,MAAM;oBAGN,MAAM;wBAGN,SAAS,SAAC,WAAW;;;;IAxBtB,kEAIE;;IAEF,0DAC0D;;IAE1D,mEACsE;;IAEtE,qEACwE;;IAExE,mEACsE;;IAEtE,0DACyC;;IAEzC,yDACwC;;IAExC,6DAC6C;;IAE7C,+DAAmE;;IAEnE,wEAA8C;;IAElC,6DAA4B;;IAAE,yDAAqB;;IAAE,uEAA+C","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"]}