@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
123 lines • 15 kB
JavaScript
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"]}