@coreui/angular
Version:
CoreUI for Angular UI components library
131 lines • 14.1 kB
JavaScript
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;
}
/**
* 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;
}
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
};
}
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.0", 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.0", 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" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", 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
}], 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';\nimport { Breakpoints, Colors } from '../coreui.types';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\n\n@Directive({\n  selector: '[cTable]'\n})\nexport class TableDirective implements OnInit {\n  static ngAcceptInputType_bordered: BooleanInput;\n  static ngAcceptInputType_borderless: BooleanInput;\n  static ngAcceptInputType_hover: BooleanInput;\n  static ngAcceptInputType_small: BooleanInput;\n  static ngAcceptInputType_striped: BooleanInput;\n\n  /**\n   * Set the vertical alignment.\n   * @type string\n   * @values 'bottom' | 'middle' | 'top'\n   */\n  @Input() align?: 'bottom' | 'middle' | 'top';\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   * Add borders on all sides of the table and cells.\n   * @type boolean\n   */\n  @Input()\n  set bordered(value: boolean) {\n    this._bordered = coerceBooleanProperty(value);\n  };\n  get bordered() {\n    return this._bordered;\n  }\n  private _bordered = false;\n  /**\n   * Remove borders on all sides of the table and cells.\n   * @type boolean\n   */\n  @Input()\n  set borderless(value: boolean) {\n    this._borderless = coerceBooleanProperty(value);\n  };\n  get borderless() {\n    return this._borderless;\n  }\n  private _borderless = false;\n  /**\n   * Put the `<caption>` on the top of the table.\n   * @values 'top'\n   */\n  @Input() caption?: 'top';\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   * Enable a hover state on table rows within table body.\n   * @type boolean\n   */\n  @Input()\n  set hover(value: boolean) {\n    this._hover = coerceBooleanProperty(value);\n  };\n  get hover() {\n    return this._hover;\n  }\n  private _hover = false;\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   * Make table more compact by cutting all cell `padding` in half.\n   * @type boolean\n   */\n  @Input()\n  set small(value: boolean) {\n    this._small = coerceBooleanProperty(value);\n  };\n  get small() {\n    return this._small;\n  }\n  private _small = false;\n  /**\n   * Add zebra-striping to any table row within the table body`.\n   * @type boolean\n   */\n  @Input()\n  set striped(value: boolean) {\n    this._striped = coerceBooleanProperty(value);\n  };\n  get striped() {\n    return this._striped;\n  }\n  private _striped = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private hostElement: ElementRef\n  ) { }\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    };\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"]}