UNPKG

@coreui/angular

Version:

CoreUI for Angular UI components library

147 lines 16 kB
import { Directive, HostBinding, Input } from '@angular/core'; import { coerceBooleanProperty } from '@angular/cdk/coercion'; import * as i0 from "@angular/core"; export class TableDirective { constructor(renderer, hostElement) { this.renderer = renderer; this.hostElement = hostElement; this._bordered = false; this._borderless = false; this._hover = false; this._small = false; this._striped = false; this._stripedColumns = false; } /** * Add borders on all sides of the table and cells. * @type boolean */ set bordered(value) { this._bordered = coerceBooleanProperty(value); } ; get bordered() { return this._bordered; } /** * Remove borders on all sides of the table and cells. * @type boolean */ set borderless(value) { this._borderless = coerceBooleanProperty(value); } ; get borderless() { return this._borderless; } /** * Enable a hover state on table rows within table body. * @type boolean */ set hover(value) { this._hover = coerceBooleanProperty(value); } ; get hover() { return this._hover; } /** * Make table more compact by cutting all cell `padding` in half. * @type boolean */ set small(value) { this._small = coerceBooleanProperty(value); } ; get small() { return this._small; } /** * Add zebra-striping to any table row within the table body. * @type boolean */ set striped(value) { this._striped = coerceBooleanProperty(value); } ; get striped() { return this._striped; } /** * Add zebra-striping to any table column. * @type boolean * @since 4.2.4 */ set stripedColumns(value) { this._stripedColumns = coerceBooleanProperty(value); } ; get stripedColumns() { return this._stripedColumns; } get hostClasses() { return { table: true, [`align-${this.align}`]: !!this.align, [`caption-${this.caption}`]: !!this.caption, [`border-${this.borderColor}`]: !!this.borderColor, 'table-bordered': this.bordered, 'table-borderless': this.borderless, [`table-${this.color}`]: !!this.color, 'table-hover': this.hover, 'table-sm': this.small, 'table-striped': this.striped, 'table-striped-columns': this.stripedColumns }; } ngOnInit() { this.setResponsiveWrapper(); } // todo setResponsiveWrapper() { if (!!this.responsive) { const nativeElement = this.hostElement.nativeElement; const wrapper = this.renderer.createElement('div'); const className = this.responsive === true ? 'table-responsive' : `table-responsive-${this.responsive}`; this.renderer.addClass(wrapper, className); const parentNode = this.renderer.parentNode(nativeElement); this.renderer.appendChild(parentNode, wrapper); this.renderer.insertBefore(parentNode, wrapper, nativeElement); this.renderer.appendChild(wrapper, nativeElement); } } } TableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TableDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); TableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.8", type: TableDirective, selector: "[cTable]", inputs: { align: "align", borderColor: "borderColor", bordered: "bordered", borderless: "borderless", caption: "caption", color: "color", hover: "hover", responsive: "responsive", small: "small", striped: "striped", stripedColumns: "stripedColumns" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TableDirective, decorators: [{ type: Directive, args: [{ selector: '[cTable]' }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { align: [{ type: Input }], borderColor: [{ type: Input }], bordered: [{ type: Input }], borderless: [{ type: Input }], caption: [{ type: Input }], color: [{ type: Input }], hover: [{ type: Input }], responsive: [{ type: Input }], small: [{ type: Input }], striped: [{ type: Input }], stripedColumns: [{ type: Input }], hostClasses: [{ type: HostBinding, args: ['class'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.directive.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/table/table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostBinding, Input, OnInit, Renderer2 } from '@angular/core';\r\nimport { Breakpoints, Colors } from '../coreui.types';\r\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\r\n\r\n@Directive({\r\n  selector: '[cTable]'\r\n})\r\nexport class TableDirective implements OnInit {\r\n  static ngAcceptInputType_bordered: BooleanInput;\r\n  static ngAcceptInputType_borderless: BooleanInput;\r\n  static ngAcceptInputType_hover: BooleanInput;\r\n  static ngAcceptInputType_small: BooleanInput;\r\n  static ngAcceptInputType_striped: BooleanInput;\r\n  static ngAcceptInputType_stripedColumns: BooleanInput;\r\n\r\n  /**\r\n   * Set the vertical alignment.\r\n   * @type string\r\n   * @values 'bottom' | 'middle' | 'top'\r\n   */\r\n  @Input() align?: 'bottom' | 'middle' | 'top';\r\n\r\n  /**\r\n   * Sets the border color of the component to one of CoreUI’s themed colors.\r\n   * @type Colors\r\n   */\r\n  @Input() borderColor?: Colors;\r\n\r\n  /**\r\n   * Add borders on all sides of the table and cells.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set bordered(value: boolean) {\r\n    this._bordered = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get bordered() {\r\n    return this._bordered;\r\n  }\r\n\r\n  private _bordered = false;\r\n\r\n  /**\r\n   * Remove borders on all sides of the table and cells.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set borderless(value: boolean) {\r\n    this._borderless = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get borderless() {\r\n    return this._borderless;\r\n  }\r\n\r\n  private _borderless = false;\r\n\r\n  /**\r\n   * Put the `<caption>` on the top of the table.\r\n   * @values 'top'\r\n   */\r\n  @Input() caption?: 'top';\r\n\r\n  /**\r\n   * Sets the color context of the component to one of CoreUI’s themed colors.\r\n   * @type Colors\r\n   */\r\n  @Input() color?: Colors;\r\n\r\n  /**\r\n   * Enable a hover state on table rows within table body.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set hover(value: boolean) {\r\n    this._hover = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get hover() {\r\n    return this._hover;\r\n  }\r\n\r\n  private _hover = false;\r\n\r\n  /**\r\n   * Make table responsive across all viewports or pick a maximum breakpoint with which to have a responsive table up to.\r\n   * @type: {boolean | 'sm' | 'md' | 'lg' | 'xl' | 'xxl'}\r\n   */\r\n  @Input() responsive?: boolean | Omit<Breakpoints, 'xs'>;\r\n\r\n  /**\r\n   * Make table more compact by cutting all cell `padding` in half.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set small(value: boolean) {\r\n    this._small = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get small() {\r\n    return this._small;\r\n  }\r\n\r\n  private _small = false;\r\n\r\n  /**\r\n   * Add zebra-striping to any table row within the table body.\r\n   * @type boolean\r\n   */\r\n  @Input()\r\n  set striped(value: boolean) {\r\n    this._striped = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get striped() {\r\n    return this._striped;\r\n  }\r\n\r\n  private _striped = false;\r\n\r\n  /**\r\n   * Add zebra-striping to any table column.\r\n   * @type boolean\r\n   * @since 4.2.4\r\n   */\r\n  @Input()\r\n  set stripedColumns(value: boolean) {\r\n    this._stripedColumns = coerceBooleanProperty(value);\r\n  };\r\n\r\n  get stripedColumns() {\r\n    return this._stripedColumns;\r\n  }\r\n\r\n  private _stripedColumns = false;\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private hostElement: ElementRef\r\n  ) { }\r\n\r\n  @HostBinding('class')\r\n  get hostClasses(): any {\r\n    return {\r\n      table: true,\r\n      [`align-${this.align}`]: !!this.align,\r\n      [`caption-${this.caption}`]: !!this.caption,\r\n      [`border-${this.borderColor}`]: !!this.borderColor,\r\n      'table-bordered': this.bordered,\r\n      'table-borderless': this.borderless,\r\n      [`table-${this.color}`]: !!this.color,\r\n      'table-hover': this.hover,\r\n      'table-sm': this.small,\r\n      'table-striped': this.striped,\r\n      'table-striped-columns': this.stripedColumns\r\n    };\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.setResponsiveWrapper();\r\n  }\r\n\r\n  // todo\r\n  setResponsiveWrapper(): void {\r\n    if (!!this.responsive) {\r\n      const nativeElement: HTMLElement = this.hostElement.nativeElement;\r\n      const wrapper = this.renderer.createElement('div');\r\n      const className = this.responsive === true ? 'table-responsive' : `table-responsive-${this.responsive}`;\r\n      this.renderer.addClass(wrapper, className);\r\n      const parentNode = this.renderer.parentNode(nativeElement);\r\n      this.renderer.appendChild(parentNode, wrapper);\r\n      this.renderer.insertBefore(parentNode, wrapper, nativeElement);\r\n      this.renderer.appendChild(wrapper, nativeElement);\r\n    }\r\n  }\r\n}\r\n"]}