ornamentum
Version:
Angular Toolkit
179 lines • 17.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { switchMap } from 'rxjs/operators';
import { DataTableColumnComponent } from '../data-table-column/data-table-column.component';
import { DataTableConfigService } from '../../services/data-table-config.service';
import { DataTableEventStateService } from '../../services/data-table-event.service';
import { DataTableDataStateService } from '../../services/data-table-data-state.service';
import { DataTableScrollPositionService } from '../../services/data-table-scroll-position.service';
/**
* Column filter template component. Render column filter template via this component.
*/
var DataTableColumnFilterTemplateComponent = /** @class */ (function () {
function DataTableColumnFilterTemplateComponent(config, dataStateService, eventStateService, scrollPositionService) {
this.config = config;
this.dataStateService = dataStateService;
this.eventStateService = eventStateService;
this.scrollPositionService = scrollPositionService;
this.filter = new EventEmitter();
this.filterDataStream = new Subject();
}
/**
* Component initialize lifecycle event.
*/
/**
* Component initialize lifecycle event.
* @return {?}
*/
DataTableColumnFilterTemplateComponent.prototype.ngOnInit = /**
* Component initialize lifecycle event.
* @return {?}
*/
function () {
var _this = this;
if (this.column.showDropdownFilter) {
this.scrollPositionStreamSubscription = this.scrollPositionService.scrollPositionStream
.subscribe((/**
* @param {?} pos
* @return {?}
*/
function (pos) {
if (pos.isHorizontal) {
_this.filterDropdown.close();
}
}));
if (this.dataStateService.onFilterValueExtract) {
this.fetchFilterOptionsStreamSubscription = this.eventStateService.fetchFilterOptionsStream
.pipe(switchMap((/**
* @return {?}
*/
function () {
return _this.dataStateService.onFilterValueExtract(_this.column);
})))
.subscribe((/**
* @param {?} options
* @return {?}
*/
function (options) {
setTimeout((/**
* @return {?}
*/
function () { return _this.filterDataStream.next(options); }), 0); // TODO: remove the timeout
}));
}
}
};
/**
* Component destroy lifecycle event.
*/
/**
* Component destroy lifecycle event.
* @return {?}
*/
DataTableColumnFilterTemplateComponent.prototype.ngOnDestroy = /**
* Component destroy lifecycle event.
* @return {?}
*/
function () {
if (this.fetchFilterOptionsStreamSubscription) {
this.fetchFilterOptionsStreamSubscription.unsubscribe();
}
if (this.scrollPositionStreamSubscription) {
this.scrollPositionStreamSubscription.unsubscribe();
}
this.filterDataStream.complete();
};
/**
* @param {?} filterDropdown
* @return {?}
*/
DataTableColumnFilterTemplateComponent.prototype.onFilterDropdownInit = /**
* @param {?} filterDropdown
* @return {?}
*/
function (filterDropdown) {
this.filterDropdown = filterDropdown;
};
/**
* Clear current column filter value.
*/
/**
* Clear current column filter value.
* @return {?}
*/
DataTableColumnFilterTemplateComponent.prototype.clearFilter = /**
* Clear current column filter value.
* @return {?}
*/
function () {
this.column.filter = '';
this.filter.emit();
};
DataTableColumnFilterTemplateComponent.decorators = [
{ type: Component, args: [{
selector: 'ng-data-table-column-filter-template',
template: "<ng-container *ngIf=\"column.filterable\">\n <ng-container\n *ngIf=\"column.filterTemplate\"\n [ngTemplateOutlet]=\"column.filterTemplate\"\n [ngTemplateOutletContext]=\"{ column: column, filter: customFilterStream }\"\n >\n </ng-container>\n <ng-container *ngIf=\"!column.filterTemplate\">\n <div class=\"ng-data-table-header-input-box\" *ngIf=\"!column.showDropdownFilter\">\n <input\n type=\"text\"\n class=\"ng-data-table-header-input\"\n [(ngModel)]=\"column.filter\"\n [class.ng-data-table-clear-filter]=\"column.showFilterClearButton\"\n (keyup)=\"filter.emit()\"\n [placeholder]=\"column.filterPlaceholder\"\n />\n <span class=\"ng-data-table-input-group-btn\">\n <button\n *ngIf=\"column.showFilterClearButton\"\n [hidden]=\"!column.filter\"\n class=\"ng-data-table-delete-button\"\n type=\"button\"\n (click)=\"clearFilter()\"\n ></button>\n </span>\n </div>\n <ng-dropdown\n *ngIf=\"column.showDropdownFilter\"\n [id]=\"dataStateService.getUniqueId('col', index)\"\n [relativeParentElement]=\"dataStateService.relativeParentElement\"\n [dataSource]=\"filterDataStream\"\n [menuPosition]=\"column.dropdownFilterMenuPosition\"\n [filterable]=\"column.dropdownFilterSearchable\"\n [filterDebounceTime]=\"column.dropdownFilterSearchDebounceTime\"\n [filterDebounce]=\"column.dropdownFilterSearchDebounce\"\n [selectMode]=\"column.dropdownFilterSelectMode\"\n [showSelectedOptionRemoveButton]=\"column.dropdownFilterShowSelectedOptionRemoveButton\"\n [showClearSelectionButton]=\"column.dropdownFilterShowClearSelectionButton\"\n [wrapDisplaySelectLimit]=\"column.dropdownFilterWrapDisplaySelectLimit\"\n [groupByField]=\"column.dropdownFilterGroupByField\"\n [showOptionSelectCheckbox]=\"column.dropDownFilterShowOptionSelectCheckbox\"\n [menuHeight]=\"column.dropdownFilterMenuHeight\"\n [menuWidth]=\"column.dropdownFilterMenuWidth\"\n [multiSelectOptionMaxWidth]=\"column.dropdownFilterMultiSelectOptionMaxWidth\"\n [closeMenuOnSelect]=\"column.dropdownFilterCloseMenuOnSelect\"\n [dynamicDimensionCalculation]=\"column.dropdownFilterDynamicDimensionCalculation\"\n [dynamicWidthRatio]=\"column.dropdownFilterDynamicWidthRatio\"\n [dynamicHeightRatio]=\"column.dropdownFilterDynamicHeightRatio\"\n [loadingSpinnerTemplateRef]=\"column.dropdownFilterLoadingSpinnerTemplate\"\n [optionTemplateRef]=\"column.dropdownFilterOptionTemplate\"\n [optionGroupHeaderTemplateRef]=\"column.dropdownFilterOptionGroupHeaderTemplate\"\n [translations]=\"config.translations.dropdownFilter\"\n [(ngModel)]=\"column.filter\"\n (selectChange)=\"filter.emit()\"\n (init)=\"onFilterDropdownInit($event)\"\n >\n </ng-dropdown>\n </ng-container>\n</ng-container>\n"
}] }
];
/** @nocollapse */
DataTableColumnFilterTemplateComponent.ctorParameters = function () { return [
{ type: DataTableConfigService },
{ type: DataTableDataStateService },
{ type: DataTableEventStateService },
{ type: DataTableScrollPositionService }
]; };
DataTableColumnFilterTemplateComponent.propDecorators = {
column: [{ type: Input }],
customFilterStream: [{ type: Input }],
index: [{ type: Input }],
filter: [{ type: Output }]
};
return DataTableColumnFilterTemplateComponent;
}());
export { DataTableColumnFilterTemplateComponent };
if (false) {
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.column;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.customFilterStream;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.index;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.filter;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.filterDataStream;
/**
* @type {?}
* @private
*/
DataTableColumnFilterTemplateComponent.prototype.fetchFilterOptionsStreamSubscription;
/**
* @type {?}
* @private
*/
DataTableColumnFilterTemplateComponent.prototype.scrollPositionStreamSubscription;
/**
* @type {?}
* @private
*/
DataTableColumnFilterTemplateComponent.prototype.filterDropdown;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.config;
/** @type {?} */
DataTableColumnFilterTemplateComponent.prototype.dataStateService;
/**
* @type {?}
* @private
*/
DataTableColumnFilterTemplateComponent.prototype.eventStateService;
/**
* @type {?}
* @private
*/
DataTableColumnFilterTemplateComponent.prototype.scrollPositionService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-column-filter-template.component.js","sourceRoot":"ng://ornamentum/","sources":["data-table/components/data-table-column-filter-template/data-table-column-filter-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\n\nimport { Observable, Subject, Subscription } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\n\nimport { DataTableFilterEventArgs } from '../../models/data-table-filter-event-args.model';\nimport { DataTableFilterOption } from '../../models/data-table-filter-option.model';\n\nimport { DataTableColumnComponent } from '../data-table-column/data-table-column.component';\nimport { DropdownComponent } from '../../../dropdown/components/dropdown/dropdown.component';\n\nimport { DataTableConfigService } from '../../services/data-table-config.service';\nimport { DataTableEventStateService } from '../../services/data-table-event.service';\nimport { DataTableDataStateService } from '../../services/data-table-data-state.service';\nimport { DataTableScrollPositionService } from '../../services/data-table-scroll-position.service';\nimport { DataTableScrollPoint } from '../../../data-table/models/data-table-scroll-point.model';\n\n/**\n * Column filter template component. Render column filter template via this component.\n */\n@Component({\n  selector: 'ng-data-table-column-filter-template',\n  templateUrl: './data-table-column-filter-template.component.html'\n})\nexport class DataTableColumnFilterTemplateComponent implements OnInit, OnDestroy {\n  @Input()\n  public column: DataTableColumnComponent;\n\n  @Input()\n  public customFilterStream: Observable<DataTableFilterEventArgs>;\n\n  @Input()\n  public index: number;\n\n  @Output()\n  public filter = new EventEmitter();\n\n  public filterDataStream = new Subject<DataTableFilterOption[]>();\n\n  private fetchFilterOptionsStreamSubscription: Subscription;\n  private scrollPositionStreamSubscription: Subscription;\n\n  private filterDropdown: DropdownComponent;\n\n  constructor(\n    public config: DataTableConfigService,\n    public dataStateService: DataTableDataStateService,\n    private eventStateService: DataTableEventStateService,\n    private scrollPositionService: DataTableScrollPositionService\n  ) {}\n\n  /**\n   * Component initialize lifecycle event.\n   */\n  public ngOnInit(): void {\n    if (this.column.showDropdownFilter) {\n      this.scrollPositionStreamSubscription = this.scrollPositionService.scrollPositionStream\n        .subscribe((pos: DataTableScrollPoint) => {\n          if (pos.isHorizontal) {\n            this.filterDropdown.close();\n          }\n        });\n\n      if (this.dataStateService.onFilterValueExtract) {\n        this.fetchFilterOptionsStreamSubscription = this.eventStateService.fetchFilterOptionsStream\n          .pipe(\n            switchMap(() => {\n              return this.dataStateService.onFilterValueExtract(this.column);\n            })\n          )\n          .subscribe((options: DataTableFilterOption[]) => {\n            setTimeout(() => this.filterDataStream.next(options), 0); // TODO: remove the timeout\n          });\n      }\n    }\n  }\n\n  /**\n   * Component destroy lifecycle event.\n   */\n  public ngOnDestroy(): void {\n    if (this.fetchFilterOptionsStreamSubscription) {\n      this.fetchFilterOptionsStreamSubscription.unsubscribe();\n    }\n\n    if (this.scrollPositionStreamSubscription) {\n      this.scrollPositionStreamSubscription.unsubscribe();\n    }\n\n    this.filterDataStream.complete();\n  }\n\n  public onFilterDropdownInit(filterDropdown: DropdownComponent): void {\n    this.filterDropdown = filterDropdown;\n  }\n\n  /**\n   * Clear current column filter value.\n   */\n  public clearFilter(): void {\n    this.column.filter = '';\n    this.filter.emit();\n  }\n}\n"]}