UNPKG

ornamentum

Version:
157 lines 16.4 kB
/** * @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. */ export class DataTableColumnFilterTemplateComponent { /** * @param {?} config * @param {?} dataStateService * @param {?} eventStateService * @param {?} scrollPositionService */ constructor(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. * @return {?} */ ngOnInit() { if (this.column.showDropdownFilter) { this.scrollPositionStreamSubscription = this.scrollPositionService.scrollPositionStream .subscribe((/** * @param {?} pos * @return {?} */ (pos) => { if (pos.isHorizontal) { this.filterDropdown.close(); } })); if (this.dataStateService.onFilterValueExtract) { this.fetchFilterOptionsStreamSubscription = this.eventStateService.fetchFilterOptionsStream .pipe(switchMap((/** * @return {?} */ () => { return this.dataStateService.onFilterValueExtract(this.column); }))) .subscribe((/** * @param {?} options * @return {?} */ (options) => { setTimeout((/** * @return {?} */ () => this.filterDataStream.next(options)), 0); // TODO: remove the timeout })); } } } /** * Component destroy lifecycle event. * @return {?} */ ngOnDestroy() { if (this.fetchFilterOptionsStreamSubscription) { this.fetchFilterOptionsStreamSubscription.unsubscribe(); } if (this.scrollPositionStreamSubscription) { this.scrollPositionStreamSubscription.unsubscribe(); } this.filterDataStream.complete(); } /** * @param {?} filterDropdown * @return {?} */ onFilterDropdownInit(filterDropdown) { this.filterDropdown = filterDropdown; } /** * Clear current column filter value. * @return {?} */ clearFilter() { 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 = () => [ { type: DataTableConfigService }, { type: DataTableDataStateService }, { type: DataTableEventStateService }, { type: DataTableScrollPositionService } ]; DataTableColumnFilterTemplateComponent.propDecorators = { column: [{ type: Input }], customFilterStream: [{ type: Input }], index: [{ type: Input }], filter: [{ type: Output }] }; 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"]}