UNPKG

angular-bootstrap-md

Version:

Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.

260 lines 32.4 kB
import { coerceBooleanProperty } from '@angular/cdk/coercion'; import { Component, HostBinding, Input, ViewEncapsulation, } from '@angular/core'; import { Observable, Subject } from 'rxjs'; import * as i0 from "@angular/core"; // eslint-disable-next-line @angular-eslint/component-class-suffix export class MdbTableDirective { constructor(el, renderer) { this.el = el; this.renderer = renderer; this._striped = false; this._bordered = false; this._borderless = false; this._hover = false; this._small = false; this._responsive = false; this._stickyHeader = false; this.stickyHeaderBgColor = '#f2f2f2'; this.stickyHeaderTextColor = '#000000'; this._stickyFooter = false; this.stickyFooterBgColor = '#f2f2f2'; this.stickyFooterTextColor = '#000000'; this._dataSource = []; this._dataSourceChanged = new Subject(); } get striped() { return this._striped; } set striped(value) { this._striped = coerceBooleanProperty(value); } get bordered() { return this._bordered; } set bordered(value) { this._bordered = coerceBooleanProperty(value); } get borderless() { return this._borderless; } set borderless(value) { this._borderless = coerceBooleanProperty(value); } get hover() { return this._hover; } set hover(value) { this._hover = coerceBooleanProperty(value); } get small() { return this._small; } set small(value) { this._small = coerceBooleanProperty(value); } get responsive() { return this._responsive; } set responsive(value) { this._responsive = coerceBooleanProperty(value); } get stickyHeader() { return this._stickyHeader; } set stickyHeader(value) { this._stickyHeader = coerceBooleanProperty(value); } get stickyFooter() { return this._stickyFooter; } set stickyFooter(value) { this._stickyFooter = coerceBooleanProperty(value); } addRow(newRow) { this.getDataSource().push(newRow); } addRowAfter(index, row) { this.getDataSource().splice(index, 0, row); } removeRow(index) { this.getDataSource().splice(index, 1); } rowRemoved() { return new Observable((observer) => { observer.next(true); }); } removeLastRow() { this.getDataSource().pop(); } getDataSource() { return this._dataSource; } setDataSource(data) { this._dataSource = data; this._dataSourceChanged.next(this.getDataSource()); } dataSourceChange() { return this._dataSourceChanged; } filterLocalDataBy(searchKey) { return this.getDataSource().filter((obj) => { return Object.keys(obj).some((key) => { if (obj[key]) { // Fix(tableSearch): table search will now able to filter through nested data return JSON.stringify(obj).toLowerCase().includes(searchKey); } }); }); } filterLocalDataByFields(searchKey, keys) { return this.getDataSource().filter((obj) => { return Object.keys(obj).some((key) => { if (obj[key]) { if (keys.includes(key)) { if (obj[key].toLowerCase().includes(searchKey)) { return obj[key]; } } } }); }); } filterLocalDataByMultipleFields(searchKey, keys) { const items = searchKey.split(' ').map((x) => x.toLowerCase()); return this.getDataSource().filter((x) => { for (const item of items) { let flag = false; if (keys !== undefined) { for (const prop in x) { if (x[prop] && x.hasOwnProperty(prop)) { if (keys.includes(prop)) { if (x[prop].toLowerCase().indexOf(item) !== -1) { flag = true; break; } } } } } if (keys === undefined) { for (const prop in x) { if (x.hasOwnProperty(prop) && x[prop].toLowerCase().indexOf(item) !== -1) { flag = true; break; } } } if (!flag) { return false; } } return true; }); } searchLocalDataBy(searchKey) { if (!searchKey) { return this.getDataSource(); } if (searchKey) { return this.filterLocalDataBy(searchKey.toLowerCase()); } } searchLocalDataByFields(searchKey, keys) { if (!searchKey) { return this.getDataSource(); } if (searchKey && keys.length > 0) { return this.filterLocalDataByFields(searchKey.toLowerCase(), keys); } if (!keys || keys.length === 0) { return this.filterLocalDataBy(searchKey.toLowerCase()); } } searchLocalDataByMultipleFields(searchKey, keys) { if (!searchKey) { return this.getDataSource(); } if (searchKey && keys !== undefined) { return this.filterLocalDataByMultipleFields(searchKey.toLowerCase(), keys); } } searchDataObservable(searchKey) { return new Observable((observer) => { observer.next(this.searchLocalDataBy(searchKey)); }); } ngOnInit() { this.renderer.addClass(this.el.nativeElement, 'table'); } ngAfterViewInit() { // Fix(stickyHeader): resolved problem with not working stickyHeader="true" on Chrome if (this.stickyHeader) { this.makeSticky('thead', 'sticky-top', this.stickyHeaderBgColor, this.stickyHeaderTextColor); } if (this.stickyFooter) { this.makeSticky('tfoot', 'sticky-bottom', this.stickyFooterBgColor, this.stickyFooterTextColor); } } makeSticky(query, elementClass, bgColor, color) { const tableHead = this.el.nativeElement.querySelector(query); Array.from(tableHead.firstElementChild.children).forEach((child) => { this.renderer.addClass(child, elementClass); if (bgColor) { this.renderer.setStyle(child, 'background-color', bgColor); } if (color) { this.renderer.setStyle(child, 'color', color); } }); } } MdbTableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); MdbTableDirective.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: MdbTableDirective, selector: "[mdbTable]", inputs: { striped: "striped", bordered: "bordered", borderless: "borderless", hover: "hover", small: "small", responsive: "responsive", stickyHeader: "stickyHeader", stickyHeaderBgColor: "stickyHeaderBgColor", stickyHeaderTextColor: "stickyHeaderTextColor", stickyFooter: "stickyFooter", stickyFooterBgColor: "stickyFooterBgColor", stickyFooterTextColor: "stickyFooterTextColor" }, host: { properties: { "class.table-striped": "this.striped", "class.table-bordered": "this.bordered", "class.table-borderless": "this.borderless", "class.table-hover": "this.hover", "class.table-sm": "this.small", "class.table-responsive": "this.responsive" } }, exportAs: ["mdbTable"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: ["table th{font-size:.9rem;font-weight:400}table td{font-size:.9rem;font-weight:300}table thead th svg.ascending,table thead th svg.descending,table thead td svg.ascending,table thead td svg.descending{display:none;max-height:.9rem;max-width:.9rem}table thead th[aria-sort=ascending] svg.ascending,table thead td[aria-sort=ascending] svg.ascending{display:unset}table thead th[aria-sort=descending] svg.descending,table thead td[aria-sort=descending] svg.descending{display:unset}table thead th:not([aria-sort]):hover svg.descending,table thead th[aria-sort=constant]:hover svg.descending,table thead td:not([aria-sort]):hover svg.descending,table thead td[aria-sort=constant]:hover svg.descending{display:unset;opacity:.5}table tfoot .sticky-bottom{position:sticky;bottom:0}table.table{margin-bottom:0}table.table thead th{border-top:none;border-bottom-width:1px}table.table th,table.table td{padding:1.1rem 16px 1rem}table.table .label-table{margin:0;padding:0;line-height:.94rem;height:.94rem}table.table.btn-table td{vertical-align:middle}table.table-hover tbody tr:hover{transition:.5s;background-color:#00000013}table .th-lg{min-width:9rem}table .th-sm{min-width:6rem}table.table-sm th,table.table-sm td{padding-top:.6rem;padding-bottom:.6rem}.table-scroll-vertical{max-height:300px;overflow-y:auto}.table-fixed{table-layout:fixed}.table-responsive>.table-bordered,.table-responsive-sm>.table-bordered,.table-responsive-md>.table-bordered,.table-responsive-lg>.table-bordered,.table-responsive-xl>.table-bordered{border-top:1px solid #dee2e6}\n"], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableDirective, decorators: [{ type: Component, args: [{ selector: '[mdbTable]', exportAs: 'mdbTable', template: '<ng-content></ng-content>', encapsulation: ViewEncapsulation.None, styles: ["table th{font-size:.9rem;font-weight:400}table td{font-size:.9rem;font-weight:300}table thead th svg.ascending,table thead th svg.descending,table thead td svg.ascending,table thead td svg.descending{display:none;max-height:.9rem;max-width:.9rem}table thead th[aria-sort=ascending] svg.ascending,table thead td[aria-sort=ascending] svg.ascending{display:unset}table thead th[aria-sort=descending] svg.descending,table thead td[aria-sort=descending] svg.descending{display:unset}table thead th:not([aria-sort]):hover svg.descending,table thead th[aria-sort=constant]:hover svg.descending,table thead td:not([aria-sort]):hover svg.descending,table thead td[aria-sort=constant]:hover svg.descending{display:unset;opacity:.5}table tfoot .sticky-bottom{position:sticky;bottom:0}table.table{margin-bottom:0}table.table thead th{border-top:none;border-bottom-width:1px}table.table th,table.table td{padding:1.1rem 16px 1rem}table.table .label-table{margin:0;padding:0;line-height:.94rem;height:.94rem}table.table.btn-table td{vertical-align:middle}table.table-hover tbody tr:hover{transition:.5s;background-color:#00000013}table .th-lg{min-width:9rem}table .th-sm{min-width:6rem}table.table-sm th,table.table-sm td{padding-top:.6rem;padding-bottom:.6rem}.table-scroll-vertical{max-height:300px;overflow-y:auto}.table-fixed{table-layout:fixed}.table-responsive>.table-bordered,.table-responsive-sm>.table-bordered,.table-responsive-md>.table-bordered,.table-responsive-lg>.table-bordered,.table-responsive-xl>.table-bordered{border-top:1px solid #dee2e6}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { striped: [{ type: Input }, { type: HostBinding, args: ['class.table-striped'] }], bordered: [{ type: Input }, { type: HostBinding, args: ['class.table-bordered'] }], borderless: [{ type: Input }, { type: HostBinding, args: ['class.table-borderless'] }], hover: [{ type: Input }, { type: HostBinding, args: ['class.table-hover'] }], small: [{ type: Input }, { type: HostBinding, args: ['class.table-sm'] }], responsive: [{ type: Input }, { type: HostBinding, args: ['class.table-responsive'] }], stickyHeader: [{ type: Input }], stickyHeaderBgColor: [{ type: Input }], stickyHeaderTextColor: [{ type: Input }], stickyFooter: [{ type: Input }], stickyFooterBgColor: [{ type: Input }], stickyFooterTextColor: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdb-table.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular-bootstrap-md/src/lib/free/tables/directives/mdb-table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnInit,\n  Renderer2,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[mdbTable]',\n  exportAs: 'mdbTable',\n  template: '<ng-content></ng-content>',\n  styleUrls: ['./../tables-module.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\n// eslint-disable-next-line @angular-eslint/component-class-suffix\nexport class MdbTableDirective implements OnInit, AfterViewInit {\n  @Input()\n  @HostBinding('class.table-striped')\n  get striped(): boolean {\n    return this._striped;\n  }\n  set striped(value: BooleanInput) {\n    this._striped = coerceBooleanProperty(value);\n  }\n  private _striped = false;\n\n  @Input()\n  @HostBinding('class.table-bordered')\n  get bordered(): boolean {\n    return this._bordered;\n  }\n  set bordered(value: BooleanInput) {\n    this._bordered = coerceBooleanProperty(value);\n  }\n  private _bordered = false;\n\n  @Input()\n  @HostBinding('class.table-borderless')\n  get borderless(): boolean {\n    return this._borderless;\n  }\n  set borderless(value: BooleanInput) {\n    this._borderless = coerceBooleanProperty(value);\n  }\n  private _borderless = false;\n\n  @Input()\n  @HostBinding('class.table-hover')\n  get hover(): boolean {\n    return this._hover;\n  }\n  set hover(value: BooleanInput) {\n    this._hover = coerceBooleanProperty(value);\n  }\n  private _hover = false;\n\n  @Input()\n  @HostBinding('class.table-sm')\n  get small(): boolean {\n    return this._small;\n  }\n  set small(value: BooleanInput) {\n    this._small = coerceBooleanProperty(value);\n  }\n  private _small = false;\n\n  @Input()\n  @HostBinding('class.table-responsive')\n  get responsive(): boolean {\n    return this._responsive;\n  }\n  set responsive(value: BooleanInput) {\n    this._responsive = coerceBooleanProperty(value);\n  }\n  private _responsive = false;\n\n  @Input()\n  get stickyHeader(): boolean {\n    return this._stickyHeader;\n  }\n  set stickyHeader(value: BooleanInput) {\n    this._stickyHeader = coerceBooleanProperty(value);\n  }\n  private _stickyHeader = false;\n\n  @Input() stickyHeaderBgColor = '#f2f2f2';\n  @Input() stickyHeaderTextColor = '#000000';\n\n  @Input()\n  get stickyFooter(): boolean {\n    return this._stickyFooter;\n  }\n  set stickyFooter(value: BooleanInput) {\n    this._stickyFooter = coerceBooleanProperty(value);\n  }\n  private _stickyFooter = false;\n\n  @Input() stickyFooterBgColor = '#f2f2f2';\n  @Input() stickyFooterTextColor = '#000000';\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  private _dataSource: any = [];\n  private _dataSourceChanged: Subject<any> = new Subject<any>();\n\n  addRow(newRow: any) {\n    this.getDataSource().push(newRow);\n  }\n\n  addRowAfter(index: number, row: any) {\n    this.getDataSource().splice(index, 0, row);\n  }\n\n  removeRow(index: number) {\n    this.getDataSource().splice(index, 1);\n  }\n\n  rowRemoved(): Observable<boolean> {\n    return new Observable<boolean>((observer: any) => {\n      observer.next(true);\n    });\n  }\n\n  removeLastRow() {\n    this.getDataSource().pop();\n  }\n\n  getDataSource() {\n    return this._dataSource;\n  }\n\n  setDataSource(data: any) {\n    this._dataSource = data;\n    this._dataSourceChanged.next(this.getDataSource());\n  }\n\n  dataSourceChange(): Observable<any> {\n    return this._dataSourceChanged;\n  }\n\n  filterLocalDataBy(searchKey: string) {\n    return this.getDataSource().filter((obj: Array<any>) => {\n      return Object.keys(obj).some((key: any) => {\n        if (obj[key]) {\n          // Fix(tableSearch): table search will now able to filter through nested data\n\n          return JSON.stringify(obj).toLowerCase().includes(searchKey) as any;\n        }\n      });\n    });\n  }\n\n  filterLocalDataByFields(searchKey: string, keys: string[]) {\n    return this.getDataSource().filter((obj: Array<any>) => {\n      return Object.keys(obj).some((key: any) => {\n        if (obj[key]) {\n          if (keys.includes(key)) {\n            if (obj[key].toLowerCase().includes(searchKey)) {\n              return obj[key];\n            }\n          }\n        }\n      });\n    });\n  }\n\n  filterLocalDataByMultipleFields(searchKey: string, keys?: string[]) {\n    const items = searchKey.split(' ').map((x: { toLowerCase: () => void }) => x.toLowerCase());\n    return this.getDataSource().filter((x: Array<any>) => {\n      for (const item of items) {\n        let flag = false;\n\n        if (keys !== undefined) {\n          for (const prop in x) {\n            if (x[prop] && x.hasOwnProperty(prop)) {\n              if (keys.includes(prop)) {\n                if (x[prop].toLowerCase().indexOf(item) !== -1) {\n                  flag = true;\n                  break;\n                }\n              }\n            }\n          }\n        }\n        if (keys === undefined) {\n          for (const prop in x) {\n            if (x.hasOwnProperty(prop) && x[prop].toLowerCase().indexOf(item) !== -1) {\n              flag = true;\n              break;\n            }\n          }\n        }\n        if (!flag) {\n          return false;\n        }\n      }\n      return true;\n    });\n  }\n\n  searchLocalDataBy(searchKey: string) {\n    if (!searchKey) {\n      return this.getDataSource();\n    }\n\n    if (searchKey) {\n      return this.filterLocalDataBy(searchKey.toLowerCase());\n    }\n  }\n\n  searchLocalDataByFields(searchKey: string, keys: string[]) {\n    if (!searchKey) {\n      return this.getDataSource();\n    }\n\n    if (searchKey && keys.length > 0) {\n      return this.filterLocalDataByFields(searchKey.toLowerCase(), keys);\n    }\n    if (!keys || keys.length === 0) {\n      return this.filterLocalDataBy(searchKey.toLowerCase());\n    }\n  }\n\n  searchLocalDataByMultipleFields(searchKey: string, keys?: string[]) {\n    if (!searchKey) {\n      return this.getDataSource();\n    }\n    if (searchKey && keys !== undefined) {\n      return this.filterLocalDataByMultipleFields(searchKey.toLowerCase(), keys);\n    }\n  }\n\n  searchDataObservable(searchKey: string): Observable<any> {\n    return new Observable((observer: any) => {\n      observer.next(this.searchLocalDataBy(searchKey));\n    });\n  }\n\n  ngOnInit() {\n    this.renderer.addClass(this.el.nativeElement, 'table');\n  }\n\n  ngAfterViewInit() {\n    // Fix(stickyHeader): resolved problem with not working stickyHeader=\"true\" on Chrome\n    if (this.stickyHeader) {\n      this.makeSticky('thead', 'sticky-top', this.stickyHeaderBgColor, this.stickyHeaderTextColor);\n    }\n\n    if (this.stickyFooter) {\n      this.makeSticky(\n        'tfoot',\n        'sticky-bottom',\n        this.stickyFooterBgColor,\n        this.stickyFooterTextColor\n      );\n    }\n  }\n\n  private makeSticky(query: string, elementClass: string, bgColor: string, color: string) {\n    const tableHead = this.el.nativeElement.querySelector(query);\n    Array.from(tableHead.firstElementChild.children).forEach((child: any) => {\n      this.renderer.addClass(child, elementClass);\n      if (bgColor) {\n        this.renderer.setStyle(child, 'background-color', bgColor);\n      }\n      if (color) {\n        this.renderer.setStyle(child, 'color', color);\n      }\n    });\n  }\n}\n"]}