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