UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

124 lines 14 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'; let FilterPopupComponent = class FilterPopupComponent { constructor(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 = []; } get visible() { return this.popup.visible; } popupClosed(e) { this.closed.emit(e); } popupShow(e) { this.show.emit(); } createComponent(filterComponentType, filter, rows) { this.unsubscribeAll(); this.container.clear(); const 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(); let s_closed; let s_set; let s_reset; s_closed = this._componentRef.instance.closed.subscribe((e) => this.closePopup()); s_set = this._componentRef.instance.setFilter.subscribe((e) => { this.setFilter.emit(e); this.closePopup(true); }); s_reset = this._componentRef.instance.resetFilter.subscribe((e) => { this.resetFilter.emit(e); this.closePopup(false); }); this._subscribes.push(s_closed); this._subscribes.push(s_set); this._subscribes.push(s_reset); } showByTarget(target, filter, filterComponentType, rows) { this.filter = filter; this.createComponent(filterComponentType, filter, rows); this.popup.showByTarget(target, 'left'); } closePopup(result = null) { if (this._componentRef) { this._componentRef.destroy(); this._componentRef = null; } this.popup.closePopup(result); } unsubscribeAll() { this._subscribes.forEach(sb => sb.unsubscribe()); this._subscribes = []; } ngAfterContentInit() { this.unsubscribeAll(); } ngOnDestroy() { this.unsubscribeAll(); } changes() { 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: ` <true-popup #popup (closed)="popupClosed($event)" (show)="popupShow($event)"> <template #container></template> </true-popup> `, styles: [` div { position: relative; } `] }), tslib_1.__param(0, Inject('gridState')), tslib_1.__metadata("design:paramtypes", [GridStateService, ComponentFactoryResolver, ChangeDetectorRef]) ], 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"]}