UNPKG

@coreui/angular

Version:

CoreUI Components Library for Angular

112 lines 13.2 kB
import { booleanAttribute, Directive, HostBinding, Input } from '@angular/core'; import * as i0 from "@angular/core"; export class TableDirective { constructor(renderer, hostElement) { this.renderer = renderer; this.hostElement = hostElement; /** * Add borders on all sides of the table and cells. * @type boolean */ this.bordered = false; /** * Remove borders on all sides of the table and cells. * @type boolean */ this.borderless = false; /** * Enable a hover state on table rows within table body. * @type boolean */ this.hover = false; /** * Make table more compact by cutting all cell `padding` in half. * @type boolean */ this.small = false; /** * Add zebra-striping to any table row within the table body. * @type boolean */ this.striped = false; /** * Add zebra-striping to any table column. * @type boolean * @since 4.2.4 */ this.stripedColumns = false; } 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); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TableDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.12", type: TableDirective, isStandalone: true, selector: "table[cTable]", inputs: { align: "align", borderColor: "borderColor", bordered: ["bordered", "bordered", booleanAttribute], borderless: ["borderless", "borderless", booleanAttribute], caption: "caption", color: "color", hover: ["hover", "hover", booleanAttribute], responsive: "responsive", small: ["small", "small", booleanAttribute], striped: ["striped", "striped", booleanAttribute], stripedColumns: ["stripedColumns", "stripedColumns", booleanAttribute] }, host: { properties: { "class": "this.hostClasses" }, classAttribute: "table" }, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TableDirective, decorators: [{ type: Directive, args: [{ selector: 'table[cTable]', standalone: true, host: { class: 'table' } }] }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { align: [{ type: Input }], borderColor: [{ type: Input }], bordered: [{ type: Input, args: [{ transform: booleanAttribute }] }], borderless: [{ type: Input, args: [{ transform: booleanAttribute }] }], caption: [{ type: Input }], color: [{ type: Input }], hover: [{ type: Input, args: [{ transform: booleanAttribute }] }], responsive: [{ type: Input }], small: [{ type: Input, args: [{ transform: booleanAttribute }] }], striped: [{ type: Input, args: [{ transform: booleanAttribute }] }], stripedColumns: [{ type: Input, args: [{ transform: booleanAttribute }] }], 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 { booleanAttribute, Directive, ElementRef, HostBinding, Input, OnInit, Renderer2 } from '@angular/core';\nimport { Breakpoints, Colors } from '../coreui.types';\nimport { ITable } from './table.type';\n\n@Directive({\n  selector: 'table[cTable]',\n  standalone: true,\n  host: { class: 'table' }\n})\nexport class TableDirective implements ITable, OnInit {\n  constructor(\n    private renderer: Renderer2,\n    private hostElement: ElementRef\n  ) {}\n\n  /**\n   * Set the vertical alignment.\n   * @type string\n   * @values 'bottom' | 'middle' | 'top'\n   */\n  @Input() align?: 'bottom' | 'middle' | 'top';\n\n  /**\n   * Sets the border color of the component to one of CoreUI’s themed colors.\n   * @type Colors\n   */\n  @Input() borderColor?: Colors;\n\n  /**\n   * Add borders on all sides of the table and cells.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) bordered: string | boolean = false;\n\n  /**\n   * Remove borders on all sides of the table and cells.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) borderless: string | boolean = false;\n\n  /**\n   * Put the `<caption>` on the top of the table.\n   * @values 'top'\n   */\n  @Input() caption?: 'top';\n\n  /**\n   * Sets the color context of the component to one of CoreUI’s themed colors.\n   * @type Colors\n   */\n  @Input() color?: Colors;\n\n  /**\n   * Enable a hover state on table rows within table body.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) hover: string | boolean = false;\n\n  /**\n   * Make table responsive across all viewports or pick a maximum breakpoint with which to have a responsive table up to.\n   * @type: {boolean | 'sm' | 'md' | 'lg' | 'xl' | 'xxl'}\n   */\n  @Input() responsive?: boolean | Omit<Breakpoints, 'xs'>;\n\n  /**\n   * Make table more compact by cutting all cell `padding` in half.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) small: string | boolean = false;\n\n  /**\n   * Add zebra-striping to any table row within the table body.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) striped: string | boolean = false;\n\n  /**\n   * Add zebra-striping to any table column.\n   * @type boolean\n   * @since 4.2.4\n   */\n  @Input({ transform: booleanAttribute }) stripedColumns: string | boolean = false;\n\n  @HostBinding('class')\n  get hostClasses(): any {\n    return {\n      table: true,\n      [`align-${this.align}`]: !!this.align,\n      [`caption-${this.caption}`]: !!this.caption,\n      [`border-${this.borderColor}`]: !!this.borderColor,\n      'table-bordered': this.bordered,\n      'table-borderless': this.borderless,\n      [`table-${this.color}`]: !!this.color,\n      'table-hover': this.hover,\n      'table-sm': this.small,\n      'table-striped': this.striped,\n      'table-striped-columns': this.stripedColumns\n    };\n  }\n\n  ngOnInit(): void {\n    this.setResponsiveWrapper();\n  }\n\n  // todo\n  setResponsiveWrapper(): void {\n    if (!!this.responsive) {\n      const nativeElement: HTMLElement = this.hostElement.nativeElement;\n      const wrapper = this.renderer.createElement('div');\n      const className = this.responsive === true ? 'table-responsive' : `table-responsive-${this.responsive}`;\n      this.renderer.addClass(wrapper, className);\n      const parentNode = this.renderer.parentNode(nativeElement);\n      this.renderer.appendChild(parentNode, wrapper);\n      this.renderer.insertBefore(parentNode, wrapper, nativeElement);\n      this.renderer.appendChild(wrapper, nativeElement);\n    }\n  }\n}\n"]}