UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

123 lines 15 kB
import * as tslib_1 from "tslib"; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Component, Output, EventEmitter, ComponentFactoryResolver, Inject, ViewContainerRef, ChangeDetectorRef, ViewChild } from '@angular/core'; import { GridStateService } from '../grid-state.service'; var FilterPopupComponent = /** @class */ (function () { function FilterPopupComponent(state, _cfResolver, _changeDetector) { this.state = state; this._cfResolver = _cfResolver; this._changeDetector = _changeDetector; this.closed = new EventEmitter(); this.show = new EventEmitter(); this.setFilter = new EventEmitter(); this.resetFilter = new EventEmitter(); this._subscribes = []; } Object.defineProperty(FilterPopupComponent.prototype, "visible", { get: function () { return this.popup.visible; }, enumerable: true, configurable: true }); FilterPopupComponent.prototype.popupClosed = function (e) { this.closed.emit(e); }; FilterPopupComponent.prototype.popupShow = function (e) { this.show.emit(); }; FilterPopupComponent.prototype.createComponent = function (filterComponentType, filter, rows) { var _this = this; this.unsubscribeAll(); this.container.clear(); var factory = this._cfResolver.resolveComponentFactory(filterComponentType); this._componentRef = this.container.createComponent(factory); this._componentRef.instance.filter = filter; this._componentRef.instance.rows = rows; this._componentRef.instance.state = this.state; this._componentRef.instance.init(); var s_closed; var s_set; var s_reset; s_closed = this._componentRef.instance.closed.subscribe(function (e) { return _this.closePopup(); }); s_set = this._componentRef.instance.setFilter.subscribe(function (e) { _this.setFilter.emit(e); _this.closePopup(true); }); s_reset = this._componentRef.instance.resetFilter.subscribe(function (e) { _this.resetFilter.emit(e); _this.closePopup(false); }); this._subscribes.push(s_closed); this._subscribes.push(s_set); this._subscribes.push(s_reset); }; FilterPopupComponent.prototype.showByTarget = function (target, filter, filterComponentType, rows) { this.filter = filter; this.createComponent(filterComponentType, filter, rows); this.popup.showByTarget(target, 'left'); }; FilterPopupComponent.prototype.closePopup = function (result) { if (result === void 0) { result = null; } if (this._componentRef) { this._componentRef.destroy(); this._componentRef = null; } this.popup.closePopup(result); }; FilterPopupComponent.prototype.unsubscribeAll = function () { this._subscribes.forEach(function (sb) { return sb.unsubscribe(); }); this._subscribes = []; }; FilterPopupComponent.prototype.ngAfterContentInit = function () { this.unsubscribeAll(); }; FilterPopupComponent.prototype.ngOnDestroy = function () { this.unsubscribeAll(); }; FilterPopupComponent.prototype.changes = function () { this._changeDetector.detectChanges(); }; tslib_1.__decorate([ ViewChild('popup', { static: true }), tslib_1.__metadata("design:type", Object) ], FilterPopupComponent.prototype, "popup", void 0); tslib_1.__decorate([ ViewChild('container', { read: ViewContainerRef, static: true }), tslib_1.__metadata("design:type", Object) ], FilterPopupComponent.prototype, "container", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], FilterPopupComponent.prototype, "closed", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], FilterPopupComponent.prototype, "show", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], FilterPopupComponent.prototype, "setFilter", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], FilterPopupComponent.prototype, "resetFilter", void 0); FilterPopupComponent = tslib_1.__decorate([ Component({ selector: 'true-filter-popup', template: "\n <true-popup #popup (closed)=\"popupClosed($event)\" (show)=\"popupShow($event)\">\n <template #container></template>\n </true-popup>\n ", styles: ["\n div {\n position: relative;\n }\n "] }), tslib_1.__param(0, Inject('gridState')), tslib_1.__metadata("design:paramtypes", [GridStateService, ComponentFactoryResolver, ChangeDetectorRef]) ], FilterPopupComponent); return FilterPopupComponent; }()); export { FilterPopupComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-popup.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/filters/filter-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Output, EventEmitter, OnDestroy,\r\n         ComponentFactoryResolver, Inject,\r\n         ViewContainerRef, ChangeDetectorRef,\r\n         ViewChild } from '@angular/core';\r\n\r\nimport { GridStateService } from '../grid-state.service';\r\nimport { Filter } from '@true-directive/base';\r\n\r\n@Component({\r\n  selector: 'true-filter-popup',\r\n  template: `\r\n    <true-popup #popup (closed)=\"popupClosed($event)\" (show)=\"popupShow($event)\">\r\n      <template #container></template>\r\n    </true-popup>\r\n  `,\r\n  styles:[`\r\n    div {\r\n      position: relative;\r\n    }\r\n    `]\r\n  })\r\nexport class FilterPopupComponent implements OnDestroy {\r\n\r\n  @ViewChild('popup', {static: true})\r\n  popup: any;\r\n\r\n  @ViewChild('container', { read: ViewContainerRef, static: true })\r\n  container: any;\r\n\r\n  @Output()\r\n  closed: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  show: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  setFilter: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  resetFilter: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  get visible(): boolean {\r\n    return this.popup.visible;\r\n  }\r\n\r\n  public filter: Filter;\r\n\r\n  private _componentRef: any;\r\n\r\n  private _subscribes: any[] = [];\r\n\r\n  popupClosed(e: any) {\r\n    this.closed.emit(e);\r\n  }\r\n\r\n  popupShow(e: any) {\r\n    this.show.emit();\r\n  }\r\n\r\n  createComponent(filterComponentType: any, filter: Filter, rows: Array<any>) {\r\n    this.unsubscribeAll();\r\n    this.container.clear();\r\n    const factory = this._cfResolver.resolveComponentFactory(filterComponentType);\r\n\r\n    this._componentRef = this.container.createComponent(factory);\r\n    this._componentRef.instance.filter = filter;\r\n    this._componentRef.instance.rows = rows;\r\n    this._componentRef.instance.state = this.state;\r\n    this._componentRef.instance.init();\r\n\r\n    let s_closed: any;\r\n    let s_set: any;\r\n    let s_reset: any;\r\n\r\n    s_closed = this._componentRef.instance.closed.subscribe((e: any) => this.closePopup());\r\n\r\n    s_set = this._componentRef.instance.setFilter.subscribe((e: any) => {\r\n      this.setFilter.emit(e);\r\n      this.closePopup(true);\r\n    });\r\n\r\n    s_reset = this._componentRef.instance.resetFilter.subscribe((e: any) => {\r\n      this.resetFilter.emit(e);\r\n      this.closePopup(false);\r\n    });\r\n\r\n    this._subscribes.push(s_closed);\r\n    this._subscribes.push(s_set);\r\n    this._subscribes.push(s_reset);\r\n  }\r\n\r\n  public showByTarget(target: any, filter: Filter, filterComponentType: any, rows: Array<any>) {\r\n    this.filter = filter;\r\n    this.createComponent(filterComponentType, filter, rows);\r\n    this.popup.showByTarget(target, 'left');\r\n  }\r\n\r\n  public closePopup(result: any = null) {\r\n    if (this._componentRef) {\r\n      this._componentRef.destroy();\r\n      this._componentRef = null;\r\n    }\r\n    this.popup.closePopup(result);\r\n  }\r\n\r\n  private unsubscribeAll() {\r\n    this._subscribes.forEach(sb => sb.unsubscribe());\r\n    this._subscribes = [];\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.unsubscribeAll();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribeAll();\r\n  }\r\n\r\n  public changes() {\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  constructor(\r\n    @Inject('gridState') public state: GridStateService,\r\n    private _cfResolver: ComponentFactoryResolver,\r\n    private _changeDetector: ChangeDetectorRef) { }\r\n}\r\n"]}