UNPKG

angular-bootstrap-md

Version:

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

94 lines 12.1 kB
import { coerceBooleanProperty } from '@angular/cdk/coercion'; import { Directive, Input } from '@angular/core'; import * as i0 from "@angular/core"; export class MdbTableScrollDirective { constructor(renderer, el) { this.renderer = renderer; this.el = el; this._scrollY = false; this._scrollX = false; } get scrollY() { return this._scrollY; } set scrollY(value) { this._scrollY = coerceBooleanProperty(value); } get maxHeight() { return this._maxHeight; } set maxHeight(value) { if (typeof value === 'number') { this._maxHeight = `${value}px`; } else { this._maxHeight = value; } } get scrollX() { return this._scrollX; } set scrollX(value) { this._scrollX = coerceBooleanProperty(value); } get maxWidth() { return this._maxWidth; } set maxWidth(value) { if (typeof value === 'number') { this._maxWidth = `${value}px`; } else { this._maxWidth = value; } } wrapTableWithVerticalScrollingWrapper(tableWrapper) { this.renderer.setStyle(tableWrapper, 'max-height', this.maxHeight); this.renderer.setStyle(tableWrapper, 'overflow-y', 'auto'); this.renderer.setStyle(tableWrapper, 'display', 'block'); } wrapTableWithHorizontalScrollingWrapper(tableWrapper) { this.renderer.setStyle(tableWrapper, 'max-width', this.maxWidth); this.renderer.setStyle(tableWrapper, 'overflow-x', 'auto'); this.renderer.setStyle(tableWrapper, 'display', 'block'); } wrapTableWithHorizontalAndVerticalScrollingWrapper(tableWrapper) { this.renderer.setStyle(tableWrapper, 'max-height', this.maxHeight); this.renderer.setStyle(tableWrapper, 'max-width', this.maxWidth); this.renderer.setStyle(tableWrapper, 'overflow-x', 'auto'); this.renderer.setStyle(tableWrapper, 'display', 'block'); } ngOnInit() { const parent = this.el.nativeElement.parentNode; const tableWrapper = this.renderer.createElement('div'); if (this.scrollY && this.scrollX && this.maxHeight && this.maxWidth) { this.wrapTableWithHorizontalAndVerticalScrollingWrapper(tableWrapper); } if (this.scrollY && this.maxHeight) { this.wrapTableWithVerticalScrollingWrapper(tableWrapper); } if (this.scrollX && this.maxWidth) { this.wrapTableWithHorizontalScrollingWrapper(tableWrapper); } this.renderer.insertBefore(parent, tableWrapper, this.el.nativeElement); this.renderer.removeChild(parent, this.el.nativeElement); this.renderer.appendChild(tableWrapper, this.el.nativeElement); } } MdbTableScrollDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableScrollDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); MdbTableScrollDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: MdbTableScrollDirective, selector: "[mdbTableScroll]", inputs: { scrollY: "scrollY", maxHeight: "maxHeight", scrollX: "scrollX", maxWidth: "maxWidth" }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableScrollDirective, decorators: [{ type: Directive, args: [{ selector: '[mdbTableScroll]', }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { scrollY: [{ type: Input }], maxHeight: [{ type: Input }], scrollX: [{ type: Input }], maxWidth: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdb-table-scroll.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular-bootstrap-md/src/lib/free/tables/directives/mdb-table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Directive, ElementRef, Renderer2, OnInit, Input } from '@angular/core';\n\n@Directive({\n  selector: '[mdbTableScroll]',\n})\nexport class MdbTableScrollDirective implements OnInit {\n  @Input()\n  get scrollY(): boolean {\n    return this._scrollY;\n  }\n  set scrollY(value: BooleanInput) {\n    this._scrollY = coerceBooleanProperty(value);\n  }\n  private _scrollY = false;\n\n  @Input()\n  get maxHeight(): number | string | null {\n    return this._maxHeight;\n  }\n  set maxHeight(value: number | string | null) {\n    if (typeof value === 'number') {\n      this._maxHeight = `${value}px`;\n    } else {\n      this._maxHeight = value;\n    }\n  }\n\n  @Input()\n  get scrollX(): boolean {\n    return this._scrollX;\n  }\n  set scrollX(value: BooleanInput) {\n    this._scrollX = coerceBooleanProperty(value);\n  }\n  private _scrollX = false;\n\n  @Input()\n  get maxWidth(): number | string | null {\n    return this._maxWidth;\n  }\n  set maxWidth(value: number | string | null) {\n    if (typeof value === 'number') {\n      this._maxWidth = `${value}px`;\n    } else {\n      this._maxWidth = value;\n    }\n  }\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  _maxWidth: number | string | null;\n  _maxHeight: number | string | null;\n\n  wrapTableWithVerticalScrollingWrapper(tableWrapper: ElementRef) {\n    this.renderer.setStyle(tableWrapper, 'max-height', this.maxHeight);\n    this.renderer.setStyle(tableWrapper, 'overflow-y', 'auto');\n    this.renderer.setStyle(tableWrapper, 'display', 'block');\n  }\n\n  wrapTableWithHorizontalScrollingWrapper(tableWrapper: ElementRef) {\n    this.renderer.setStyle(tableWrapper, 'max-width', this.maxWidth);\n    this.renderer.setStyle(tableWrapper, 'overflow-x', 'auto');\n    this.renderer.setStyle(tableWrapper, 'display', 'block');\n  }\n\n  wrapTableWithHorizontalAndVerticalScrollingWrapper(tableWrapper: ElementRef) {\n    this.renderer.setStyle(tableWrapper, 'max-height', this.maxHeight);\n    this.renderer.setStyle(tableWrapper, 'max-width', this.maxWidth);\n    this.renderer.setStyle(tableWrapper, 'overflow-x', 'auto');\n    this.renderer.setStyle(tableWrapper, 'display', 'block');\n  }\n\n  ngOnInit() {\n    const parent = this.el.nativeElement.parentNode;\n    const tableWrapper = this.renderer.createElement('div');\n\n    if (this.scrollY && this.scrollX && this.maxHeight && this.maxWidth) {\n      this.wrapTableWithHorizontalAndVerticalScrollingWrapper(tableWrapper);\n    }\n\n    if (this.scrollY && this.maxHeight) {\n      this.wrapTableWithVerticalScrollingWrapper(tableWrapper);\n    }\n\n    if (this.scrollX && this.maxWidth) {\n      this.wrapTableWithHorizontalScrollingWrapper(tableWrapper);\n    }\n\n    this.renderer.insertBefore(parent, tableWrapper, this.el.nativeElement);\n    this.renderer.removeChild(parent, this.el.nativeElement);\n    this.renderer.appendChild(tableWrapper, this.el.nativeElement);\n  }\n}\n"]}