material-dynamic-table
Advanced tools
@@ -210,2 +210,52 @@ (function (global, factory) { | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getFilter = /** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Column with name '" + columnName + "' does not exist."); | ||
} | ||
return this.appliedFilters[filterColumn.name]; | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.setFilter = /** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
function (columnName, filter) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Cannot set filter for a column. Column with name '" + columnName + "' does not exist."); | ||
} | ||
this.appliedFilters[filterColumn.name] = filter; | ||
this.updateDataSource(); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getColumnByName = /** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
return this.columns.find(function (c) { | ||
return (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName); | ||
}); | ||
}; | ||
DynamicTableComponent.decorators = [ | ||
@@ -497,2 +547,2 @@ { type: core.Component, args: [{ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.umd.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;  \n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: ColumnFilter; } = {};\n  \n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }    \n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n    \n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {   \n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n        \n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n        \n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":["MatDialogConfig","Component","MatDialog","Input","ViewChild","MatSort","MatPaginator","Directive","ViewContainerRef","ComponentFactoryResolver","NgModule","CommonModule","MatTableModule","MatSortModule","MatPaginatorModule","MatIconModule","MatDialogModule"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.umd.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: any; } = {};\n\n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }\n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n\n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {\n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n\n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n\n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n\n  getFilter(columnName: string): any {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Column with name '${columnName}' does not exist.`);\n    }\n\n    return this.appliedFilters[filterColumn.name];\n  }\n\n  setFilter(columnName: string, filter: any) {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`);\n    }\n\n    this.appliedFilters[filterColumn.name] = filter;\n    this.updateDataSource();\n  }\n\n  private getColumnByName(columnName: string): ColumnConfig {\n    return this.columns.find(c =>\n      (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)\n    );\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":["MatDialogConfig","Component","MatDialog","Input","ViewChild","MatSort","MatPaginator","Directive","ViewContainerRef","ComponentFactoryResolver","NgModule","CommonModule","MatTableModule","MatSortModule","MatPaginatorModule","MatIconModule","MatDialogModule"],"mappings":"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"} |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/material"),require("@angular/common")):"function"==typeof define&&define.amd?define("material-dynamic-table",["exports","@angular/core","@angular/material","@angular/common"],e):e(t["material-dynamic-table"]={},t.ng.core,t.ng.material,t.ng.common)}(this,function(t,e,i,r){"use strict";var a=function y(){},n=function(){function t(){this.registeredFilters={}}return t.prototype.registerFilter=function(t,e){this.registeredFilters[t]=e},t.prototype.getFilter=function(t){return this.registeredFilters[t]},t}(),o=function(){function t(t,e){this.columnFilterService=t,this.dialog=e,this.pageSize=20,this.pageSizeOptions=[20,50,100],this.showFilters=!0,this.stickyHeader=!1,this.appliedFilters={}}return t.prototype.ngOnInit=function(){var r=this;if(null==this.dataSource)throw Error("DynamicTable must be provided with data source.");if(null==this.columns)throw Error("DynamicTable must be provided with column definitions.");this.paginator===undefined&&(this.paginator=this.internalPaginator),this.displayedColumns=this.columns.map(function(t,e){return r.prepareColumnName(t.name,e)});var t=this.dataSource;t.sort=this.sort,t.paginator=this.paginator},t.prototype.isUsingInternalPaginator=function(){return this.paginator===this.internalPaginator},t.prototype.canFilter=function(t){return null!=this.columnFilterService.getFilter(t.type)},t.prototype.isFiltered=function(t){return this.appliedFilters[t.name]},t.prototype.prepareColumnName=function(t,e){return t||"col"+e},t.prototype.filter=function(e){var r=this,t=this.columnFilterService.getFilter(e.type);if(t){var n=new i.MatDialogConfig,o=new a;o.column=e,this.appliedFilters[e.name]&&(o.filter=Object.create(this.appliedFilters[e.name])),n.data=o,this.dialog.open(t,n).afterClosed().subscribe(function(t){t?r.appliedFilters[e.name]=t:""===t&&delete r.appliedFilters[e.name],(t||""===t)&&r.updateDataSource()})}},t.prototype.clearFilters=function(){this.appliedFilters={},this.updateDataSource()},t.prototype.updateDataSource=function(){this.dataSource.filters=this.getFilters()},t.prototype.getFilters=function(){var e=this.appliedFilters;return Object.keys(e).map(function(t){return e[t]})},t.decorators=[{type:e.Component,args:[{selector:"mdt-dynamic-table",template:'<table mat-table [dataSource]="dataSource"\r\n matSort matSortDirection="asc">\r\n\r\n <ng-container *ngFor="let column of columns; let i = index" matColumnDef="{{ prepareColumnName(column.name, i) }}"\r\n [sticky]="column.sticky === \'start\'" [stickyEnd]="column.sticky === \'end\'">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header="{{ prepareColumnName(column.name, i) }}" [disabled]="!column.name || column.sort === false">\r\n {{ column.displayName }}\r\n <button class="mat-sort-header-button" *ngIf="showFilters && canFilter(column)" (click)="filter(column); $event.stopPropagation();">\r\n <mat-icon color="{{ isFiltered(column) ? \'primary\' : \'default\' }}">filter_list</mat-icon>\r\n </button>\r\n </th>\r\n <td mat-cell *matCellDef="let row"><mdt-table-cell [row]="row" [column]="column"></mdt-table-cell></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: [stickyHeader]"></tr>\r\n <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>\r\n</table>\r\n<mat-paginator [hidden]="!isUsingInternalPaginator()" [pageSize]="pageSize"\r\n [pageSizeOptions]="pageSizeOptions">\r\n</mat-paginator>',styles:["table{width:100%}th .mat-icon.mat-default{opacity:.54}th .mat-icon.mat-default:hover{opacity:1}[hidden]{display:none}"]}]}],t.ctorParameters=function(){return[{type:n},{type:i.MatDialog}]},t.propDecorators={columns:[{type:e.Input}],dataSource:[{type:e.Input}],pageSize:[{type:e.Input}],pageSizeOptions:[{type:e.Input}],showFilters:[{type:e.Input}],stickyHeader:[{type:e.Input}],paginator:[{type:e.Input}],sort:[{type:e.ViewChild,args:[i.MatSort]}],internalPaginator:[{type:e.ViewChild,args:[i.MatPaginator]}]},t}(),l=function(){function t(t){this.viewContainerRef=t}return t.decorators=[{type:e.Directive,args:[{selector:"[mdtCellHost]"}]}],t.ctorParameters=function(){return[{type:e.ViewContainerRef}]},t}(),s=function(){function t(){}return t.decorators=[{type:e.Component,args:[{selector:"mdt-text-cell",template:"{{ row[column.name] }}"}]}],t.propDecorators={column:[{type:e.Input}],row:[{type:e.Input}]},t}(),c=function(){function t(){this.registeredCells={}}return t.prototype.registerCell=function(t,e){this.registeredCells[t]=e},t.prototype.getCell=function(t){var e=this.registeredCells[t];return null==e?s:e},t}(),p=function(){function t(t,e){this.cellService=t,this.componentFactoryResolver=e}return t.prototype.ngOnInit=function(){this.initCell()},t.prototype.initCell=function(){var t=this.cellService.getCell(this.column.type),e=this.componentFactoryResolver.resolveComponentFactory(t),r=this.cellHost.viewContainerRef;r.clear();var n=r.createComponent(e).instance;n.row=this.row,n.column=this.column},t.decorators=[{type:e.Component,args:[{selector:"mdt-table-cell",template:"<ng-template mdtCellHost></ng-template>"}]}],t.ctorParameters=function(){return[{type:c},{type:e.ComponentFactoryResolver}]},t.propDecorators={cellHost:[{type:e.ViewChild,args:[l]}],row:[{type:e.Input}],column:[{type:e.Input}]},t}(),u=function f(){},m=function(){function t(){this.dateFormat="short"}return t.prototype.ngOnInit=function(){this.column.options&&this.column.options.dateFormat&&(this.dateFormat=this.column.options.dateFormat)},t.decorators=[{type:e.Component,args:[{selector:"mdt-date-cell",template:"{{ row[column.name] | date:dateFormat }}"}]}],t.propDecorators={column:[{type:e.Input}],row:[{type:e.Input}]},t}(),d=function(){function t(t){(this.cellService=t).registerCell("string",s),t.registerCell("date",m)}return t.decorators=[{type:e.NgModule,args:[{imports:[r.CommonModule,i.MatTableModule,i.MatSortModule,i.MatPaginatorModule,i.MatIconModule,i.MatDialogModule],declarations:[o,p,l,s,m],exports:[o],entryComponents:[s,m],providers:[c,n]}]}],t.ctorParameters=function(){return[{type:c}]},t}();t.DynamicTableComponent=o,t.CellService=c,t.CellDirective=l,t.ColumnFilterService=n,t.ColumnFilter=a,t.ColumnConfig=u,t.DynamicTableModule=d,t.ɵc=m,t.ɵb=s,t.ɵa=p,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/material"),require("@angular/common")):"function"==typeof define&&define.amd?define("material-dynamic-table",["exports","@angular/core","@angular/material","@angular/common"],e):e(t["material-dynamic-table"]={},t.ng.core,t.ng.material,t.ng.common)}(this,function(t,e,i,r){"use strict";var a=function f(){},n=function(){function t(){this.registeredFilters={}}return t.prototype.registerFilter=function(t,e){this.registeredFilters[t]=e},t.prototype.getFilter=function(t){return this.registeredFilters[t]},t}(),o=function(){function t(t,e){this.columnFilterService=t,this.dialog=e,this.pageSize=20,this.pageSizeOptions=[20,50,100],this.showFilters=!0,this.stickyHeader=!1,this.appliedFilters={}}return t.prototype.ngOnInit=function(){var r=this;if(null==this.dataSource)throw Error("DynamicTable must be provided with data source.");if(null==this.columns)throw Error("DynamicTable must be provided with column definitions.");this.paginator===undefined&&(this.paginator=this.internalPaginator),this.displayedColumns=this.columns.map(function(t,e){return r.prepareColumnName(t.name,e)});var t=this.dataSource;t.sort=this.sort,t.paginator=this.paginator},t.prototype.isUsingInternalPaginator=function(){return this.paginator===this.internalPaginator},t.prototype.canFilter=function(t){return null!=this.columnFilterService.getFilter(t.type)},t.prototype.isFiltered=function(t){return this.appliedFilters[t.name]},t.prototype.prepareColumnName=function(t,e){return t||"col"+e},t.prototype.filter=function(e){var r=this,t=this.columnFilterService.getFilter(e.type);if(t){var n=new i.MatDialogConfig,o=new a;o.column=e,this.appliedFilters[e.name]&&(o.filter=Object.create(this.appliedFilters[e.name])),n.data=o,this.dialog.open(t,n).afterClosed().subscribe(function(t){t?r.appliedFilters[e.name]=t:""===t&&delete r.appliedFilters[e.name],(t||""===t)&&r.updateDataSource()})}},t.prototype.clearFilters=function(){this.appliedFilters={},this.updateDataSource()},t.prototype.updateDataSource=function(){this.dataSource.filters=this.getFilters()},t.prototype.getFilters=function(){var e=this.appliedFilters;return Object.keys(e).map(function(t){return e[t]})},t.prototype.getFilter=function(t){var e=this.getColumnByName(t);if(!e)throw Error("Column with name '"+t+"' does not exist.");return this.appliedFilters[e.name]},t.prototype.setFilter=function(t,e){var r=this.getColumnByName(t);if(!r)throw Error("Cannot set filter for a column. Column with name '"+t+"' does not exist.");this.appliedFilters[r.name]=e,this.updateDataSource()},t.prototype.getColumnByName=function(e){return this.columns.find(function(t){return(t.name?t.name.toLowerCase():t.name)===(e?e.toLowerCase():e)})},t.decorators=[{type:e.Component,args:[{selector:"mdt-dynamic-table",template:'<table mat-table [dataSource]="dataSource"\r\n matSort matSortDirection="asc">\r\n\r\n <ng-container *ngFor="let column of columns; let i = index" matColumnDef="{{ prepareColumnName(column.name, i) }}"\r\n [sticky]="column.sticky === \'start\'" [stickyEnd]="column.sticky === \'end\'">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header="{{ prepareColumnName(column.name, i) }}" [disabled]="!column.name || column.sort === false">\r\n {{ column.displayName }}\r\n <button class="mat-sort-header-button" *ngIf="showFilters && canFilter(column)" (click)="filter(column); $event.stopPropagation();">\r\n <mat-icon color="{{ isFiltered(column) ? \'primary\' : \'default\' }}">filter_list</mat-icon>\r\n </button>\r\n </th>\r\n <td mat-cell *matCellDef="let row"><mdt-table-cell [row]="row" [column]="column"></mdt-table-cell></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: [stickyHeader]"></tr>\r\n <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>\r\n</table>\r\n<mat-paginator [hidden]="!isUsingInternalPaginator()" [pageSize]="pageSize"\r\n [pageSizeOptions]="pageSizeOptions">\r\n</mat-paginator>',styles:["table{width:100%}th .mat-icon.mat-default{opacity:.54}th .mat-icon.mat-default:hover{opacity:1}[hidden]{display:none}"]}]}],t.ctorParameters=function(){return[{type:n},{type:i.MatDialog}]},t.propDecorators={columns:[{type:e.Input}],dataSource:[{type:e.Input}],pageSize:[{type:e.Input}],pageSizeOptions:[{type:e.Input}],showFilters:[{type:e.Input}],stickyHeader:[{type:e.Input}],paginator:[{type:e.Input}],sort:[{type:e.ViewChild,args:[i.MatSort]}],internalPaginator:[{type:e.ViewChild,args:[i.MatPaginator]}]},t}(),l=function(){function t(t){this.viewContainerRef=t}return t.decorators=[{type:e.Directive,args:[{selector:"[mdtCellHost]"}]}],t.ctorParameters=function(){return[{type:e.ViewContainerRef}]},t}(),s=function(){function t(){}return t.decorators=[{type:e.Component,args:[{selector:"mdt-text-cell",template:"{{ row[column.name] }}"}]}],t.propDecorators={column:[{type:e.Input}],row:[{type:e.Input}]},t}(),c=function(){function t(){this.registeredCells={}}return t.prototype.registerCell=function(t,e){this.registeredCells[t]=e},t.prototype.getCell=function(t){var e=this.registeredCells[t];return null==e?s:e},t}(),u=function(){function t(t,e){this.cellService=t,this.componentFactoryResolver=e}return t.prototype.ngOnInit=function(){this.initCell()},t.prototype.initCell=function(){var t=this.cellService.getCell(this.column.type),e=this.componentFactoryResolver.resolveComponentFactory(t),r=this.cellHost.viewContainerRef;r.clear();var n=r.createComponent(e).instance;n.row=this.row,n.column=this.column},t.decorators=[{type:e.Component,args:[{selector:"mdt-table-cell",template:"<ng-template mdtCellHost></ng-template>"}]}],t.ctorParameters=function(){return[{type:c},{type:e.ComponentFactoryResolver}]},t.propDecorators={cellHost:[{type:e.ViewChild,args:[l]}],row:[{type:e.Input}],column:[{type:e.Input}]},t}(),p=function h(){},m=function(){function t(){this.dateFormat="short"}return t.prototype.ngOnInit=function(){this.column.options&&this.column.options.dateFormat&&(this.dateFormat=this.column.options.dateFormat)},t.decorators=[{type:e.Component,args:[{selector:"mdt-date-cell",template:"{{ row[column.name] | date:dateFormat }}"}]}],t.propDecorators={column:[{type:e.Input}],row:[{type:e.Input}]},t}(),d=function(){function t(t){(this.cellService=t).registerCell("string",s),t.registerCell("date",m)}return t.decorators=[{type:e.NgModule,args:[{imports:[r.CommonModule,i.MatTableModule,i.MatSortModule,i.MatPaginatorModule,i.MatIconModule,i.MatDialogModule],declarations:[o,u,l,s,m],exports:[o],entryComponents:[s,m],providers:[c,n]}]}],t.ctorParameters=function(){return[{type:c}]},t}();t.DynamicTableComponent=o,t.CellService=c,t.CellDirective=l,t.ColumnFilterService=n,t.ColumnFilter=a,t.ColumnConfig=p,t.DynamicTableModule=d,t.ɵc=m,t.ɵb=s,t.ɵa=u,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=material-dynamic-table.umd.min.js.map |
@@ -131,2 +131,36 @@ /** | ||
} | ||
/** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
getFilter(columnName) { | ||
/** @type {?} */ | ||
const filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error(`Column with name '${columnName}' does not exist.`); | ||
} | ||
return this.appliedFilters[filterColumn.name]; | ||
} | ||
/** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
setFilter(columnName, filter) { | ||
/** @type {?} */ | ||
const filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`); | ||
} | ||
this.appliedFilters[filterColumn.name] = filter; | ||
this.updateDataSource(); | ||
} | ||
/** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
getColumnByName(columnName) { | ||
return this.columns.find(c => (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)); | ||
} | ||
} | ||
@@ -196,2 +230,2 @@ DynamicTableComponent.decorators = [ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"ng://material-dynamic-table/","sources":["lib/dynamic-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;  \n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: ColumnFilter; } = {};\n  \n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }    \n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n    \n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {   \n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n        \n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n        \n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"ng://material-dynamic-table/","sources":["lib/dynamic-table.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAU,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACtF,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,+CAA+C,CAAC;AAOpF,MAAM,OAAO,qBAAqB;;;;;IAiBhC,YAA6B,mBAAwC,EAAmB,MAAiB;QAA5E,wBAAmB,GAAnB,mBAAmB,CAAqB;QAAmB,WAAM,GAAN,MAAM,CAAW;QAbhG,aAAQ,GAAG,EAAE,CAAC;QACd,oBAAe,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QAChC,gBAAW,GAAG,IAAI,CAAC;QACnB,iBAAY,GAAG,KAAK,CAAC;QAQtB,mBAAc,GAA4B,EAAE,CAAC;IAEwD,CAAC;;;;IAE9G,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,EAAE;YAC3B,MAAM,KAAK,CAAC,iDAAiD,CAAC,CAAC;SAChE;QACD,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,EAAE;YACxB,MAAM,KAAK,CAAC,wDAAwD,CAAC,CAAC;SACvE;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC;SACzC;QAED,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;;cAElG,UAAU,GAAG,mBAAA,IAAI,CAAC,UAAU,EAAO;QACzC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QAC5B,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IACxC,CAAC;;;;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,iBAAiB,CAAC;IACnD,CAAC;;;;;IAED,SAAS,CAAC,MAAoB;;cACtB,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;QAE9D,OAAO,MAAM,IAAI,IAAI,CAAC;IACxB,CAAC;;;;;IAED,UAAU,CAAC,MAAoB;QAC7B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;;;;;;IAED,iBAAiB,CAAC,IAAY,EAAE,YAAoB;QAClD,OAAO,IAAI,IAAI,KAAK,GAAG,YAAY,CAAC;IACtC,CAAC;;;;;IAED,MAAM,CAAC,MAAoB;;cACnB,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;QAE9D,IAAI,MAAM,EAAE;;kBACJ,YAAY,GAAG,IAAI,eAAe,EAAE;;kBACpC,YAAY,GAAG,IAAI,YAAY,EAAE;YACvC,YAAY,CAAC,MAAM,GAAG,MAAM,CAAC;YAE7B,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACpC,YAAY,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;aACvE;YAED,YAAY,CAAC,IAAI,GAAG,YAAY,CAAC;;kBAE3B,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,YAAY,CAAC;YAExD,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBACzC,IAAI,MAAM,EAAE;oBACV,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;iBAC3C;qBAAM,IAAI,MAAM,KAAK,EAAE,EAAE;oBACxB,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;iBACzC;gBAED,IAAI,MAAM,IAAI,MAAM,KAAK,EAAE,EAAE;oBAC3B,IAAI,CAAC,gBAAgB,EAAE,CAAC;iBACzB;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;;;;IAED,YAAY;QACV,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;;IAES,gBAAgB;;cAClB,UAAU,GAAG,mBAAA,IAAI,CAAC,UAAU,EAAO;QACzC,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;IACzC,CAAC;;;;IAED,UAAU;;cACF,OAAO,GAAG,IAAI,CAAC,cAAc;;cAC7B,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACnE,OAAO,WAAW,CAAC;IACrB,CAAC;;;;;IAED,SAAS,CAAC,UAAkB;;cACpB,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;QAErD,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,KAAK,CAAC,qBAAqB,UAAU,mBAAmB,CAAC,CAAC;SACjE;QAED,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;;;;;;IAED,SAAS,CAAC,UAAkB,EAAE,MAAW;;cACjC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;QAErD,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,KAAK,CAAC,qDAAqD,UAAU,mBAAmB,CAAC,CAAC;SACjG;QAED,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;QAChD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;;;IAEO,eAAe,CAAC,UAAkB;QACxC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAC3B,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAClG,CAAC;IACJ,CAAC;;;YApIF,SAAS,SAAC;gBACT,QAAQ,EAAE,mBAAmB;gBAC7B,mwCAA6C;;aAE9C;;;;YANQ,mBAAmB;YAJI,SAAS;;;sBAatC,KAAK;yBACL,KAAK;uBACL,KAAK;8BACL,KAAK;0BACL,KAAK;2BACL,KAAK;wBACL,KAAK;mBAIL,SAAS,SAAC,OAAO;gCACjB,SAAS,SAAC,YAAY;;;;IAXvB,wCAAiC;;IACjC,2CAAqC;;IACrC,yCAAuB;;IACvB,gDAAyC;;IACzC,4CAA4B;;IAC5B,6CAA8B;;IAC9B,0CAAiC;;IAEjC,iDAA2B;;IAE3B,qCAAkC;;;;;IAClC,kDAAiE;;;;;IAEjE,+CAAqD;;;;;IAEzC,oDAAyD;;;;;IAAE,uCAAkC","sourcesContent":["import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: any; } = {};\n\n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }\n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n\n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {\n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n\n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n\n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n\n  getFilter(columnName: string): any {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Column with name '${columnName}' does not exist.`);\n    }\n\n    return this.appliedFilters[filterColumn.name];\n  }\n\n  setFilter(columnName: string, filter: any) {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`);\n    }\n\n    this.appliedFilters[filterColumn.name] = filter;\n    this.updateDataSource();\n  }\n\n  private getColumnByName(columnName: string): ColumnConfig {\n    return this.columns.find(c =>\n      (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)\n    );\n  }\n}"]} |
@@ -162,2 +162,52 @@ /** | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getFilter = /** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Column with name '" + columnName + "' does not exist."); | ||
} | ||
return this.appliedFilters[filterColumn.name]; | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.setFilter = /** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
function (columnName, filter) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Cannot set filter for a column. Column with name '" + columnName + "' does not exist."); | ||
} | ||
this.appliedFilters[filterColumn.name] = filter; | ||
this.updateDataSource(); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getColumnByName = /** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
return this.columns.find(function (c) { | ||
return (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName); | ||
}); | ||
}; | ||
DynamicTableComponent.decorators = [ | ||
@@ -229,2 +279,2 @@ { type: Component, args: [{ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"ng://material-dynamic-table/","sources":["lib/dynamic-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;  \n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: ColumnFilter; } = {};\n  \n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }    \n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n    \n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {   \n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n        \n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n        \n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"ng://material-dynamic-table/","sources":["lib/dynamic-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: any; } = {};\n\n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }\n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n\n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {\n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n\n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n\n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n\n  getFilter(columnName: string): any {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Column with name '${columnName}' does not exist.`);\n    }\n\n    return this.appliedFilters[filterColumn.name];\n  }\n\n  setFilter(columnName: string, filter: any) {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`);\n    }\n\n    this.appliedFilters[filterColumn.name] = filter;\n    this.updateDataSource();\n  }\n\n  private getColumnByName(columnName: string): ColumnConfig {\n    return this.columns.find(c =>\n      (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)\n    );\n  }\n}"]} |
@@ -165,2 +165,36 @@ import { Component, ViewChild, Input, Directive, ViewContainerRef, ComponentFactoryResolver, NgModule } from '@angular/core'; | ||
} | ||
/** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
getFilter(columnName) { | ||
/** @type {?} */ | ||
const filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error(`Column with name '${columnName}' does not exist.`); | ||
} | ||
return this.appliedFilters[filterColumn.name]; | ||
} | ||
/** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
setFilter(columnName, filter) { | ||
/** @type {?} */ | ||
const filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`); | ||
} | ||
this.appliedFilters[filterColumn.name] = filter; | ||
this.updateDataSource(); | ||
} | ||
/** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
getColumnByName(columnName) { | ||
return this.columns.find(c => (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)); | ||
} | ||
} | ||
@@ -411,2 +445,2 @@ DynamicTableComponent.decorators = [ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;  \n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: ColumnFilter; } = {};\n  \n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }    \n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n    \n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {   \n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n        \n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n        \n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: any; } = {};\n\n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }\n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n\n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {\n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n\n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n\n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n\n  getFilter(columnName: string): any {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Column with name '${columnName}' does not exist.`);\n    }\n\n    return this.appliedFilters[filterColumn.name];\n  }\n\n  setFilter(columnName: string, filter: any) {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`);\n    }\n\n    this.appliedFilters[filterColumn.name] = filter;\n    this.updateDataSource();\n  }\n\n  private getColumnByName(columnName: string): ColumnConfig {\n    return this.columns.find(c =>\n      (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)\n    );\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":[],"mappings":"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"} |
@@ -209,2 +209,52 @@ import { Component, ViewChild, Input, Directive, ViewContainerRef, ComponentFactoryResolver, NgModule } from '@angular/core'; | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getFilter = /** | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Column with name '" + columnName + "' does not exist."); | ||
} | ||
return this.appliedFilters[filterColumn.name]; | ||
}; | ||
/** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.setFilter = /** | ||
* @param {?} columnName | ||
* @param {?} filter | ||
* @return {?} | ||
*/ | ||
function (columnName, filter) { | ||
/** @type {?} */ | ||
var filterColumn = this.getColumnByName(columnName); | ||
if (!filterColumn) { | ||
throw Error("Cannot set filter for a column. Column with name '" + columnName + "' does not exist."); | ||
} | ||
this.appliedFilters[filterColumn.name] = filter; | ||
this.updateDataSource(); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
DynamicTableComponent.prototype.getColumnByName = /** | ||
* @private | ||
* @param {?} columnName | ||
* @return {?} | ||
*/ | ||
function (columnName) { | ||
return this.columns.find(function (c) { | ||
return (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName); | ||
}); | ||
}; | ||
DynamicTableComponent.decorators = [ | ||
@@ -475,2 +525,2 @@ { type: Component, args: [{ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;  \n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: ColumnFilter; } = {};\n  \n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }    \n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n    \n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {   \n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n        \n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n        \n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"material-dynamic-table.js.map","sources":["ng://material-dynamic-table/lib/column-filter.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/column-filter.service.ts","ng://material-dynamic-table/lib/dynamic-table.component.ts","ng://material-dynamic-table/lib/table-cell/cell.directive.ts","ng://material-dynamic-table/lib/column-config.model.ts","ng://material-dynamic-table/lib/table-cell/cell-types/text-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/cell.service.ts","ng://material-dynamic-table/lib/table-cell/table-cell.component.ts","ng://material-dynamic-table/lib/table-cell/cell-types/date-cell.component.ts","ng://material-dynamic-table/lib/dynamic-table.module.ts"],"sourcesContent":["import { ColumnConfig } from './column-config.model';\n\nexport class ColumnFilter {\n    column: ColumnConfig;\n    filter: any;\n}","import { Type } from '@angular/core';\n\nexport class ColumnFilterService {\n\n    private registeredFilters: { [key: string]: Type<any>; } = {};\n    \n    registerFilter(type: string, component: Type<any>) {\n        this.registeredFilters[type] = component;\n    }\n\n    getFilter(type: string): Type<any> {\n        const component = this.registeredFilters[type];\n        \n        return component;\n    }\n}","import { Component, OnInit, ViewChild, Input } from '@angular/core';\nimport { MatSort, MatPaginator, MatDialog, MatDialogConfig } from '@angular/material';\nimport { DataSource } from '@angular/cdk/table';\nimport { ColumnConfig } from './column-config.model';\nimport { ColumnFilter } from './column-filter.model';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\n@Component({\n  selector: 'mdt-dynamic-table',\n  templateUrl: './dynamic-table.component.html',\n  styleUrls: ['./dynamic-table.component.css']\n})\nexport class DynamicTableComponent implements OnInit {\n\n  @Input() columns: ColumnConfig[];\n  @Input() dataSource: DataSource<any>;\n  @Input() pageSize = 20;\n  @Input() pageSizeOptions = [20, 50, 100];\n  @Input() showFilters = true;\n  @Input() stickyHeader = false;\n  @Input() paginator: MatPaginator;\n\n  displayedColumns: string[];\n\n  @ViewChild(MatSort) sort: MatSort;\n  @ViewChild(MatPaginator) private internalPaginator: MatPaginator;\n\n  private appliedFilters: { [key: string]: any; } = {};\n\n  constructor(private readonly columnFilterService: ColumnFilterService, private readonly dialog: MatDialog) { }\n\n  ngOnInit() {\n    if (this.dataSource == null) {\n      throw Error('DynamicTable must be provided with data source.');\n    }\n    if (this.columns == null) {\n      throw Error('DynamicTable must be provided with column definitions.');\n    }\n\n    if (this.paginator === undefined) {\n      this.paginator = this.internalPaginator;\n    }\n\n    this.displayedColumns = this.columns.map((column, index) => this.prepareColumnName(column.name, index));\n\n    const dataSource = this.dataSource as any;\n    dataSource.sort = this.sort;\n    dataSource.paginator = this.paginator;\n  }\n\n  isUsingInternalPaginator() {\n    return this.paginator === this.internalPaginator;\n  }\n\n  canFilter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    return filter != null;\n  }\n\n  isFiltered(column: ColumnConfig) {\n    return this.appliedFilters[column.name];\n  }\n\n  prepareColumnName(name: string, columnNumber: number) {\n    return name || 'col' + columnNumber;\n  }\n\n  filter(column: ColumnConfig) {\n    const filter = this.columnFilterService.getFilter(column.type);\n\n    if (filter) {\n      const dialogConfig = new MatDialogConfig();\n      const columnFilter = new ColumnFilter();\n      columnFilter.column = column;\n\n      if (this.appliedFilters[column.name]) {\n        columnFilter.filter = Object.create(this.appliedFilters[column.name]);\n      }\n\n      dialogConfig.data = columnFilter;\n\n      const dialogRef = this.dialog.open(filter, dialogConfig);\n\n      dialogRef.afterClosed().subscribe(result => {\n        if (result) {\n          this.appliedFilters[column.name] = result;\n        } else if (result === '') {\n          delete this.appliedFilters[column.name];\n        }\n\n        if (result || result === '') {\n          this.updateDataSource();\n        }\n      });\n    }\n  }\n\n  clearFilters() {\n    this.appliedFilters = {};\n    this.updateDataSource();\n  }\n\n  protected updateDataSource() {\n    const dataSource = this.dataSource as any;\n    dataSource.filters = this.getFilters();\n  }\n\n  getFilters() {\n    const filters = this.appliedFilters;\n    const filterArray = Object.keys(filters).map((key) => filters[key]);\n    return filterArray;\n  }\n\n  getFilter(columnName: string): any {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Column with name '${columnName}' does not exist.`);\n    }\n\n    return this.appliedFilters[filterColumn.name];\n  }\n\n  setFilter(columnName: string, filter: any) {\n    const filterColumn = this.getColumnByName(columnName);\n\n    if (!filterColumn) {\n      throw Error(`Cannot set filter for a column. Column with name '${columnName}' does not exist.`);\n    }\n\n    this.appliedFilters[filterColumn.name] = filter;\n    this.updateDataSource();\n  }\n\n  private getColumnByName(columnName: string): ColumnConfig {\n    return this.columns.find(c =>\n      (c.name ? c.name.toLowerCase() : c.name) === (columnName ? columnName.toLowerCase() : columnName)\n    );\n  }\n}","import { Directive, ViewContainerRef } from '@angular/core';\n\n@Directive({\n    selector: '[mdtCellHost]',\n})\nexport class CellDirective {\n    constructor(public viewContainerRef: ViewContainerRef) {}\n}","export class ColumnConfig {\r\n    name?: string;\r\n    displayName?: string;\r\n    type: string;\r\n    options?: any;\r\n    sticky?: string;\r\n    sort?: boolean;\r\n}","import { Component, Input } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-text-cell',\n    template: '{{ row[column.name] }}'\n})\nexport class TextCellComponent implements CellComponent {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n}","import { Type } from '@angular/core';\nimport { TextCellComponent } from './text-cell.component';\n\nexport class CellService {\n\n    private registeredCells: { [key: string]: Type<any>; } = {};\n    \n    registerCell(type: string, component: Type<any>) {\n        this.registeredCells[type] = component;\n    }\n\n    getCell(type: string): Type<any> {\n        const component = this.registeredCells[type];\n\n        if (component == null) {\n            return TextCellComponent;\n        }\n\n        return component;\n    }\n}","import { Component, ComponentFactoryResolver, Input, ViewChild, OnInit } from '@angular/core';\nimport { CellDirective } from './cell.directive';\nimport { CellService } from './cell-types/cell.service';\nimport { CellComponent } from './cell-types/cell.component';\nimport { ColumnConfig } from '../column-config.model';\n\n@Component({\n    selector: 'mdt-table-cell',\n    template: '<ng-template mdtCellHost></ng-template>'\n})\nexport class TableCellComponent implements OnInit {\n    @ViewChild(CellDirective) cellHost: CellDirective;\n\n    @Input() row: object;\n    @Input() column: ColumnConfig;\n\n    constructor(\n        private readonly cellService: CellService,\n        private readonly componentFactoryResolver: ComponentFactoryResolver) { }\n\n    ngOnInit() {\n        this.initCell();\n    }\n\n    initCell() {\n        const cellComponent = this.cellService.getCell(this.column.type);\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(cellComponent);\n        const viewContainerRef = this.cellHost.viewContainerRef;\n        viewContainerRef.clear();\n        const componentRef = viewContainerRef.createComponent(componentFactory);\n        const cell = componentRef.instance as CellComponent;\n        cell.row = this.row;\n        cell.column = this.column;\n    }\n}","import { Component, Input, OnInit } from '@angular/core';\nimport { CellComponent } from './cell.component';\nimport { ColumnConfig } from '../../column-config.model';\n\n@Component({\n    selector: 'mdt-date-cell',\n    template: '{{ row[column.name] | date:dateFormat }}'\n})\nexport class DateCellComponent implements CellComponent, OnInit {\n    @Input() column: ColumnConfig;\n    @Input() row: object;\n\n    dateFormat = 'short';\n\n    ngOnInit() {\n        if (this.column.options) {\n            if (this.column.options.dateFormat) {\n                this.dateFormat = this.column.options.dateFormat;\n            }\n        }\n    }\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport {\n  MatTableModule,\n  MatSortModule,\n  MatPaginatorModule,\n  MatIconModule,\n  MatDialogModule\n} from '@angular/material';\n\nimport { DynamicTableComponent } from './dynamic-table.component';\nimport { TableCellComponent } from './table-cell/table-cell.component';\n\nimport { CellService } from './table-cell/cell-types/cell.service';\nimport { CellDirective } from './table-cell/cell.directive';\nimport { ColumnFilterService } from './table-cell/cell-types/column-filter.service';\n\nexport { CellService, CellDirective, ColumnFilterService };\nexport { CellComponent } from './table-cell/cell-types/cell.component';\nexport { ColumnFilter } from './column-filter.model';\nexport { ColumnConfig } from './column-config.model';\n\nimport { TextCellComponent } from './table-cell/cell-types/text-cell.component';\nimport { DateCellComponent } from './table-cell/cell-types/date-cell.component';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatTableModule,\n    MatSortModule,\n    MatPaginatorModule,\n    MatIconModule,\n    MatDialogModule\n  ],\n  declarations: [\n    DynamicTableComponent,\n    TableCellComponent,\n    CellDirective,\n    TextCellComponent,\n    DateCellComponent\n  ],\n  exports: [DynamicTableComponent],\n  entryComponents: [\n    TextCellComponent,\n    DateCellComponent\n  ],\n  providers: [\n    CellService,\n    ColumnFilterService\n  ]\n})\nexport class DynamicTableModule {\n  constructor(private readonly cellService: CellService) {\n    cellService.registerCell('string', TextCellComponent);\n    cellService.registerCell('date', DateCellComponent);\n  }\n}\n"],"names":[],"mappings":"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"} |
@@ -5,3 +5,2 @@ import { OnInit } from '@angular/core'; | ||
import { ColumnConfig } from './column-config.model'; | ||
import { ColumnFilter } from './column-filter.model'; | ||
import { ColumnFilterService } from './table-cell/cell-types/column-filter.service'; | ||
@@ -26,3 +25,3 @@ export declare class DynamicTableComponent implements OnInit { | ||
canFilter(column: ColumnConfig): boolean; | ||
isFiltered(column: ColumnConfig): ColumnFilter; | ||
isFiltered(column: ColumnConfig): any; | ||
prepareColumnName(name: string, columnNumber: number): string; | ||
@@ -32,3 +31,6 @@ filter(column: ColumnConfig): void; | ||
protected updateDataSource(): void; | ||
getFilters(): ColumnFilter[]; | ||
getFilters(): any[]; | ||
getFilter(columnName: string): any; | ||
setFilter(columnName: string, filter: any): void; | ||
private getColumnByName; | ||
} |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"DynamicTableComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"mdt-dynamic-table","template":"<table mat-table [dataSource]=\"dataSource\"\r\n matSort matSortDirection=\"asc\">\r\n\r\n <ng-container *ngFor=\"let column of columns; let i = index\" matColumnDef=\"{{ prepareColumnName(column.name, i) }}\"\r\n [sticky]=\"column.sticky === 'start'\" [stickyEnd]=\"column.sticky === 'end'\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header=\"{{ prepareColumnName(column.name, i) }}\" [disabled]=\"!column.name || column.sort === false\">\r\n {{ column.displayName }}\r\n <button class=\"mat-sort-header-button\" *ngIf=\"showFilters && canFilter(column)\" (click)=\"filter(column); $event.stopPropagation();\">\r\n <mat-icon color=\"{{ isFiltered(column) ? 'primary' : 'default' }}\">filter_list</mat-icon>\r\n </button>\r\n </th>\r\n <td mat-cell *matCellDef=\"let row\"><mdt-table-cell [row]=\"row\" [column]=\"column\"></mdt-table-cell></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: [stickyHeader]\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\r\n</table>\r\n<mat-paginator [hidden]=\"!isUsingInternalPaginator()\" [pageSize]=\"pageSize\"\r\n [pageSizeOptions]=\"pageSizeOptions\">\r\n</mat-paginator>","styles":["table{width:100%}th .mat-icon.mat-default{opacity:.54}th .mat-icon.mat-default:hover{opacity:1}[hidden]{display:none}"]}]}],"members":{"columns":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"dataSource":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"pageSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"pageSizeOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"showFilters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"stickyHeader":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"paginator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"sort":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":24,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatSort","line":24,"character":13}]}]}],"internalPaginator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":25,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatPaginator","line":25,"character":13}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ColumnFilterService"},{"__symbolic":"reference","module":"@angular/material","name":"MatDialog","line":29,"character":98}]}],"ngOnInit":[{"__symbolic":"method"}],"isUsingInternalPaginator":[{"__symbolic":"method"}],"canFilter":[{"__symbolic":"method"}],"isFiltered":[{"__symbolic":"method"}],"prepareColumnName":[{"__symbolic":"method"}],"filter":[{"__symbolic":"method"}],"clearFilters":[{"__symbolic":"method"}],"updateDataSource":[{"__symbolic":"method"}],"getFilters":[{"__symbolic":"method"}]}},"CellService":{"__symbolic":"class","members":{"registerCell":[{"__symbolic":"method"}],"getCell":[{"__symbolic":"method"}]}},"CellDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":2,"character":1},"arguments":[{"selector":"[mdtCellHost]"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":6,"character":41}]}]}},"ColumnFilterService":{"__symbolic":"class","members":{"registerFilter":[{"__symbolic":"method"}],"getFilter":[{"__symbolic":"method"}]}},"DynamicTableModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":26,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":28,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatTableModule","line":29,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatSortModule","line":30,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatPaginatorModule","line":31,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatIconModule","line":32,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatDialogModule","line":33,"character":4}],"declarations":[{"__symbolic":"reference","name":"DynamicTableComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"CellDirective"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}],"exports":[{"__symbolic":"reference","name":"DynamicTableComponent"}],"entryComponents":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}],"providers":[{"__symbolic":"reference","name":"CellService"},{"__symbolic":"reference","name":"ColumnFilterService"}]}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CellService"}]}]}},"CellComponent":{"__symbolic":"interface"},"ColumnFilter":{"__symbolic":"class","members":{}},"ColumnConfig":{"__symbolic":"class","members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"mdt-table-cell","template":"<ng-template mdtCellHost></ng-template>"}]}],"members":{"cellHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":11,"character":5},"arguments":[{"__symbolic":"reference","name":"CellDirective"}]}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":5}}]}],"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":5}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CellService"},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":18,"character":51}]}],"ngOnInit":[{"__symbolic":"method"}],"initCell":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"mdt-text-cell","template":"{{ row[column.name] }}"}]}],"members":{"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"mdt-date-cell","template":"{{ row[column.name] | date:dateFormat }}"}]}],"members":{"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"DynamicTableComponent":"./lib/dynamic-table.component","CellService":"./lib/table-cell/cell-types/cell.service","CellDirective":"./lib/table-cell/cell.directive","ColumnFilterService":"./lib/table-cell/cell-types/column-filter.service","DynamicTableModule":"./lib/dynamic-table.module","CellComponent":"./lib/table-cell/cell-types/cell.component","ColumnFilter":"./lib/column-filter.model","ColumnConfig":"./lib/column-config.model","ɵa":"./lib/table-cell/table-cell.component","ɵb":"./lib/table-cell/cell-types/text-cell.component","ɵc":"./lib/table-cell/cell-types/date-cell.component"},"importAs":"material-dynamic-table"} | ||
{"__symbolic":"module","version":4,"metadata":{"DynamicTableComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"mdt-dynamic-table","template":"<table mat-table [dataSource]=\"dataSource\"\r\n matSort matSortDirection=\"asc\">\r\n\r\n <ng-container *ngFor=\"let column of columns; let i = index\" matColumnDef=\"{{ prepareColumnName(column.name, i) }}\"\r\n [sticky]=\"column.sticky === 'start'\" [stickyEnd]=\"column.sticky === 'end'\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header=\"{{ prepareColumnName(column.name, i) }}\" [disabled]=\"!column.name || column.sort === false\">\r\n {{ column.displayName }}\r\n <button class=\"mat-sort-header-button\" *ngIf=\"showFilters && canFilter(column)\" (click)=\"filter(column); $event.stopPropagation();\">\r\n <mat-icon color=\"{{ isFiltered(column) ? 'primary' : 'default' }}\">filter_list</mat-icon>\r\n </button>\r\n </th>\r\n <td mat-cell *matCellDef=\"let row\"><mdt-table-cell [row]=\"row\" [column]=\"column\"></mdt-table-cell></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: [stickyHeader]\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\r\n</table>\r\n<mat-paginator [hidden]=\"!isUsingInternalPaginator()\" [pageSize]=\"pageSize\"\r\n [pageSizeOptions]=\"pageSizeOptions\">\r\n</mat-paginator>","styles":["table{width:100%}th .mat-icon.mat-default{opacity:.54}th .mat-icon.mat-default:hover{opacity:1}[hidden]{display:none}"]}]}],"members":{"columns":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"dataSource":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"pageSize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"pageSizeOptions":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"showFilters":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"stickyHeader":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"paginator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"sort":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":24,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatSort","line":24,"character":13}]}]}],"internalPaginator":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":25,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatPaginator","line":25,"character":13}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ColumnFilterService"},{"__symbolic":"reference","module":"@angular/material","name":"MatDialog","line":29,"character":98}]}],"ngOnInit":[{"__symbolic":"method"}],"isUsingInternalPaginator":[{"__symbolic":"method"}],"canFilter":[{"__symbolic":"method"}],"isFiltered":[{"__symbolic":"method"}],"prepareColumnName":[{"__symbolic":"method"}],"filter":[{"__symbolic":"method"}],"clearFilters":[{"__symbolic":"method"}],"updateDataSource":[{"__symbolic":"method"}],"getFilters":[{"__symbolic":"method"}],"getFilter":[{"__symbolic":"method"}],"setFilter":[{"__symbolic":"method"}],"getColumnByName":[{"__symbolic":"method"}]}},"CellService":{"__symbolic":"class","members":{"registerCell":[{"__symbolic":"method"}],"getCell":[{"__symbolic":"method"}]}},"CellDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":2,"character":1},"arguments":[{"selector":"[mdtCellHost]"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ViewContainerRef","line":6,"character":41}]}]}},"ColumnFilterService":{"__symbolic":"class","members":{"registerFilter":[{"__symbolic":"method"}],"getFilter":[{"__symbolic":"method"}]}},"DynamicTableModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":26,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":28,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatTableModule","line":29,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatSortModule","line":30,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatPaginatorModule","line":31,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatIconModule","line":32,"character":4},{"__symbolic":"reference","module":"@angular/material","name":"MatDialogModule","line":33,"character":4}],"declarations":[{"__symbolic":"reference","name":"DynamicTableComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"CellDirective"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}],"exports":[{"__symbolic":"reference","name":"DynamicTableComponent"}],"entryComponents":[{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"}],"providers":[{"__symbolic":"reference","name":"CellService"},{"__symbolic":"reference","name":"ColumnFilterService"}]}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CellService"}]}]}},"CellComponent":{"__symbolic":"interface"},"ColumnFilter":{"__symbolic":"class","members":{}},"ColumnConfig":{"__symbolic":"class","members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"mdt-table-cell","template":"<ng-template mdtCellHost></ng-template>"}]}],"members":{"cellHost":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":11,"character":5},"arguments":[{"__symbolic":"reference","name":"CellDirective"}]}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":5}}]}],"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":5}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"CellService"},{"__symbolic":"reference","module":"@angular/core","name":"ComponentFactoryResolver","line":18,"character":51}]}],"ngOnInit":[{"__symbolic":"method"}],"initCell":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"mdt-text-cell","template":"{{ row[column.name] }}"}]}],"members":{"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"mdt-date-cell","template":"{{ row[column.name] | date:dateFormat }}"}]}],"members":{"column":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":5}}]}],"row":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":5}}]}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"DynamicTableComponent":"./lib/dynamic-table.component","CellService":"./lib/table-cell/cell-types/cell.service","CellDirective":"./lib/table-cell/cell.directive","ColumnFilterService":"./lib/table-cell/cell-types/column-filter.service","DynamicTableModule":"./lib/dynamic-table.module","CellComponent":"./lib/table-cell/cell-types/cell.component","ColumnFilter":"./lib/column-filter.model","ColumnConfig":"./lib/column-config.model","ɵa":"./lib/table-cell/table-cell.component","ɵb":"./lib/table-cell/cell-types/text-cell.component","ɵc":"./lib/table-cell/cell-types/date-cell.component"},"importAs":"material-dynamic-table"} |
{ | ||
"name": "material-dynamic-table", | ||
"version": "1.1.2", | ||
"version": "1.2.0", | ||
"license": "MIT", | ||
@@ -5,0 +5,0 @@ "author": "Marcin Suty", |
@@ -151,2 +151,12 @@ # material-dynamic-table | ||
##### Methods | ||
| Name | Description | | ||
|--------------|-----------------------------------------------------------------------------------------------------| | ||
| getFilter(columnName: string): any | Returns currently set filter for the column with provided name | | ||
| setFilter(columnName: string, filter: any) | Sets the filter for the column with provided name | | ||
| getFilters() | Returns all set column filters | | ||
| clearFilters() | Removes all applied filters | | ||
#### ColumnConfig definition | ||
@@ -153,0 +163,0 @@ ColumnConfig is used to provide specification for the columns to be displayed |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
319951
8.37%2911
8.26%269
3.86%