angular-bootstrap-md
Version:
Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.
260 lines • 32.4 kB
JavaScript
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"]}