@asadi/angular-date-components
Version:
`Angular Date Components` is a comprehensive angular library of date-related components designed to meet the needs of applications that require localization based on various calendar systems. While the package currently includes two powerful components (S
121 lines • 29.3 kB
JavaScript
import { CommonModule } from '@angular/common';
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, Renderer2, ViewChild } from '@angular/core';
import { TableViewControllerDirective } from '../../directives/table-view-controller.directive';
import { ADC_OPTIONS } from '../../injection-token';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
/**
* A reusable and customizable table component for displaying date-related data.
* The `adc-table` component is designed for use within the Angular Date Components package.
* It supports features like row and column labels, custom cell event builders, and date range selection.
*
* The component allows for displaying a dynamic table with custom rows, columns, and cells.
* It supports both left-to-right (`ltr`) and right-to-left (`rtl`) layouts.
*
* ### Features
* - Dynamically updates the table view when cell data changes.
* - Supports date filtering and custom event builders for handling cell events.
* - Emits an event when a date range is selected.
*
* @example
* ```html
* <adc-table
* [Rows]="tableRows"
* [Columns]="tableColumns"
* [Cells]="tableCells"
* [Title]="'My Schedule'"
* [TitleClass]="'table-title'"
* [ShowRowLabels]="true"
* [ShowColumnLabels]="false"
* [Dir]="'ltr'"
* [DateFilter]="customDateFilter"
* [EventBuilder]="eventBuilderInstance"
* (DateRangeSelect)="onDateRangeSelect($event)">
* </adc-table>
* ```
*
* @example
* ```typescript
* // In your component class
* tableRows: ADCITableRow[] = [...];
* tableColumns: ADCITableColumn[] = [...];
* tableCells: ADCITableCell[] = [...];
*
* onDateRangeSelect(selectedCells: ADCITableCell[]) {
* console.log('Selected cells:', selectedCells);
* }
* ```
*/
export class ADCTableComponent {
constructor() {
this.options = inject(ADC_OPTIONS);
this.renderer = inject(Renderer2);
/**
* An array of rows to display in the table.
*/
this.tableRows = [];
/**
* a boolean which determines if row details should be displayed or not
*/
this.showRow = true;
/**
*
* The title displayed above the table.
*/
this.title = '';
/**
* CSS classes to apply to the title.
*/
this.titleClassList = '';
this.viewReadyEvent = new EventEmitter();
}
ngAfterViewInit() {
if (this.viewCtrl == null)
return;
if (this.eventBuilder) {
if (this.viewCtrl == null)
return;
this.eventBuilder.init(this.renderer, this.viewCtrl, this.options);
}
if (this.selectionManager) {
this.selectionManager.init(this.viewCtrl);
}
}
onViewReady() {
this.viewReadyEvent.emit();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: ADCTableComponent, isStandalone: true, selector: "adc-table", inputs: { tableRows: ["rows", "tableRows"], showRow: ["showRowDetails", "showRow"], title: "title", titleClassList: ["titleClass", "titleClassList"], eventBuilder: "eventBuilder", selectionManager: "selectionManager" }, outputs: { viewReadyEvent: "viewReady" }, viewQueries: [{ propertyName: "viewCtrl", first: true, predicate: TableViewControllerDirective, descendants: true }], ngImport: i0, template: "\r\n<div [dir]=\"options.direction\">\r\n\r\n <div [classList]=\"titleClassList + ' font-bold text-xl'\" style=\"border-bottom: 1px solid #000; text-align: center;\">\r\n {{title}}\r\n </div>\r\n\r\n <div style=\"max-height: 700px;overflow: scroll;\">\r\n\r\n <div style=\"flex: 1;display: flex;flex-direction: column;\" class=\"adc-table\" tableViewController (viewReady)=\"onViewReady()\">\r\n\r\n <ng-container *ngFor=\"let row of tableRows; let lastRow = last; let rowIndex = index\">\r\n \r\n <div class=\"row\" style=\"position: relative;flex-shrink: 0;\" [attr.sticky]=\"rowIndex == 0\" \r\n [class.sticky]=\"rowIndex == 0\" [class.vertical-stick]=\"rowIndex == 0\" [attr.row-index]=\"rowIndex\">\r\n \r\n <!-- cells - columns -->\r\n <div style=\"display: flex;flex-direction: row;flex-wrap: nowrap;flex: 1;height: 100%;\" cells>\r\n \r\n <ng-container *ngIf=\"showRow\">\r\n \r\n <div style=\"min-width: 100px;display: flex;flex-direction: column;overflow: hidden;\r\n padding: 6px;\" [style.justifyContent]=\"row.verticalAlign\" [style.alignItems]=\"row.horizontalAlign\"\r\n [classList]=\"row.classList + ' column column-border sticky horizontal-stick'\" detail=\"true\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\">\r\n \r\n <span class=\"label\">{{row.prefix}}</span>\r\n <span class=\"label\">{{row.label}}</span>\r\n <span class=\"label\">{{row.suffix}}</span>\r\n \r\n </div>\r\n \r\n </ng-container>\r\n \r\n <ng-container *ngFor=\"let column of row.columns; let lastColumn = last; let columnIndex = index\">\r\n <div style=\"min-width: 50px;display: flex;flex-direction: column;overflow: hidden;\r\n white-space: nowrap;text-overflow: ellipsis;padding: 6px;flex: 1;\" [style.justifyContent]=\"column.verticalAlign\" [attr.selectable]=\"column.selectable\"\r\n [classList]=\"column.classList + ' column'\" [attr.columnValue]=\"column.value\" [style.alignItems]=\"column.horizontalAlign\"\r\n [attr.rowValue]=\"row.value\" [attr.rowIndex]=\"rowIndex\" [attr.columnIndex]=\"columnIndex\"\r\n [ngClass]=\"{'column-border': !lastColumn}\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\" detail=\"false\">\r\n \r\n <span class=\"label\">{{column.prefix}}</span>\r\n <span class=\"label\">{{column.label}}</span>\r\n <span class=\"label\">{{column.suffix}}</span>\r\n \r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n \r\n <!-- events -->\r\n <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 1;pointer-events: none;\" events></div>\r\n\r\n <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 3;pointer-events: none;\" tooltip></div>\r\n \r\n </div>\r\n \r\n </ng-container>\r\n \r\n </div>\r\n\r\n </div>\r\n\r\n</div>\r\n", styles: ["[dir=rtl] .column-border{border-left:1px solid #000}[dir=ltr] .column-border{border-right:1px solid #000}[dir=ltr] .adc-table{transform-origin:left top}[dir=rtl] .adc-table{transform-origin:right top}.adc-table{transition:transform;transition-duration:.2s;transition-timing-function:ease-out;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-smooth:always}.row .column:nth-child(2n):not(.today){background-color:#f0f0f0}.row .column:nth-child(odd):not(.today){background-color:#fff}.sticky{position:sticky!important;z-index:9}[dir=ltr] .sticky.horizontal-stick{left:0}[dir=rtl] .sticky.horizontal-stick{right:0}.sticky.vertical-stick{top:0}.today{background-color:#f7ffac}[selectable=true]:not([invalid]):hover{cursor:pointer;box-shadow:inset 0 1px 3px #00000080}[selectable=true][invalid]:hover{cursor:not-allowed}.unavailable{opacity:.5}.holiday{color:red}[dir=rtl]{text-align:right}[dir=ltr]{text-align:left}.label{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}[selectable=true][pointed]:not([invalid]):not([selected]){background-color:#c384ff80!important;opacity:1!important}[selectable=true][selected]:not([invalid]){background-color:#c384ff!important;opacity:1!important}[selectable=true][invalid]{background-color:#aaa!important;opacity:1!important}[dir=rtl] .table-event.event-start-day{border-top-right-radius:15px;border-bottom-right-radius:15px}[dir=ltr] .table-event.event-start-day,[dir=rtl] .table-event.event-end-day{border-top-left-radius:15px;border-bottom-left-radius:15px}[dir=ltr] .table-event.event-end-day{border-top-right-radius:15px;border-bottom-right-radius:15px}.table-event{overflow:hidden;position:absolute;display:flex;justify-content:center;align-items:center;font-weight:400;font-size:clamp(10px,14px,16px);line-height:22px;z-index:9;color:#fff;text-wrap:nowrap;pointer-events:fill}.tooltip{position:absolute;background-color:#000c;color:#fff;padding:5px 10px;border-radius:4px;pointer-events:none;white-space:nowrap;z-index:1000;overflow:hidden;max-width:350px;white-space:break-word;text-wrap:wrap;word-break:break-all}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TableViewControllerDirective, selector: "[tableViewController]", outputs: ["viewReady"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: ADCTableComponent, decorators: [{
type: Component,
args: [{ selector: 'adc-table', standalone: true, imports: [
CommonModule,
TableViewControllerDirective,
], changeDetection: ChangeDetectionStrategy.OnPush, template: "\r\n<div [dir]=\"options.direction\">\r\n\r\n <div [classList]=\"titleClassList + ' font-bold text-xl'\" style=\"border-bottom: 1px solid #000; text-align: center;\">\r\n {{title}}\r\n </div>\r\n\r\n <div style=\"max-height: 700px;overflow: scroll;\">\r\n\r\n <div style=\"flex: 1;display: flex;flex-direction: column;\" class=\"adc-table\" tableViewController (viewReady)=\"onViewReady()\">\r\n\r\n <ng-container *ngFor=\"let row of tableRows; let lastRow = last; let rowIndex = index\">\r\n \r\n <div class=\"row\" style=\"position: relative;flex-shrink: 0;\" [attr.sticky]=\"rowIndex == 0\" \r\n [class.sticky]=\"rowIndex == 0\" [class.vertical-stick]=\"rowIndex == 0\" [attr.row-index]=\"rowIndex\">\r\n \r\n <!-- cells - columns -->\r\n <div style=\"display: flex;flex-direction: row;flex-wrap: nowrap;flex: 1;height: 100%;\" cells>\r\n \r\n <ng-container *ngIf=\"showRow\">\r\n \r\n <div style=\"min-width: 100px;display: flex;flex-direction: column;overflow: hidden;\r\n padding: 6px;\" [style.justifyContent]=\"row.verticalAlign\" [style.alignItems]=\"row.horizontalAlign\"\r\n [classList]=\"row.classList + ' column column-border sticky horizontal-stick'\" detail=\"true\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\">\r\n \r\n <span class=\"label\">{{row.prefix}}</span>\r\n <span class=\"label\">{{row.label}}</span>\r\n <span class=\"label\">{{row.suffix}}</span>\r\n \r\n </div>\r\n \r\n </ng-container>\r\n \r\n <ng-container *ngFor=\"let column of row.columns; let lastColumn = last; let columnIndex = index\">\r\n <div style=\"min-width: 50px;display: flex;flex-direction: column;overflow: hidden;\r\n white-space: nowrap;text-overflow: ellipsis;padding: 6px;flex: 1;\" [style.justifyContent]=\"column.verticalAlign\" [attr.selectable]=\"column.selectable\"\r\n [classList]=\"column.classList + ' column'\" [attr.columnValue]=\"column.value\" [style.alignItems]=\"column.horizontalAlign\"\r\n [attr.rowValue]=\"row.value\" [attr.rowIndex]=\"rowIndex\" [attr.columnIndex]=\"columnIndex\"\r\n [ngClass]=\"{'column-border': !lastColumn}\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\" detail=\"false\">\r\n \r\n <span class=\"label\">{{column.prefix}}</span>\r\n <span class=\"label\">{{column.label}}</span>\r\n <span class=\"label\">{{column.suffix}}</span>\r\n \r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n \r\n <!-- events -->\r\n <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 1;pointer-events: none;\" events></div>\r\n\r\n <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 3;pointer-events: none;\" tooltip></div>\r\n \r\n </div>\r\n \r\n </ng-container>\r\n \r\n </div>\r\n\r\n </div>\r\n\r\n</div>\r\n", styles: ["[dir=rtl] .column-border{border-left:1px solid #000}[dir=ltr] .column-border{border-right:1px solid #000}[dir=ltr] .adc-table{transform-origin:left top}[dir=rtl] .adc-table{transform-origin:right top}.adc-table{transition:transform;transition-duration:.2s;transition-timing-function:ease-out;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-smooth:always}.row .column:nth-child(2n):not(.today){background-color:#f0f0f0}.row .column:nth-child(odd):not(.today){background-color:#fff}.sticky{position:sticky!important;z-index:9}[dir=ltr] .sticky.horizontal-stick{left:0}[dir=rtl] .sticky.horizontal-stick{right:0}.sticky.vertical-stick{top:0}.today{background-color:#f7ffac}[selectable=true]:not([invalid]):hover{cursor:pointer;box-shadow:inset 0 1px 3px #00000080}[selectable=true][invalid]:hover{cursor:not-allowed}.unavailable{opacity:.5}.holiday{color:red}[dir=rtl]{text-align:right}[dir=ltr]{text-align:left}.label{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}[selectable=true][pointed]:not([invalid]):not([selected]){background-color:#c384ff80!important;opacity:1!important}[selectable=true][selected]:not([invalid]){background-color:#c384ff!important;opacity:1!important}[selectable=true][invalid]{background-color:#aaa!important;opacity:1!important}[dir=rtl] .table-event.event-start-day{border-top-right-radius:15px;border-bottom-right-radius:15px}[dir=ltr] .table-event.event-start-day,[dir=rtl] .table-event.event-end-day{border-top-left-radius:15px;border-bottom-left-radius:15px}[dir=ltr] .table-event.event-end-day{border-top-right-radius:15px;border-bottom-right-radius:15px}.table-event{overflow:hidden;position:absolute;display:flex;justify-content:center;align-items:center;font-weight:400;font-size:clamp(10px,14px,16px);line-height:22px;z-index:9;color:#fff;text-wrap:nowrap;pointer-events:fill}.tooltip{position:absolute;background-color:#000c;color:#fff;padding:5px 10px;border-radius:4px;pointer-events:none;white-space:nowrap;z-index:1000;overflow:hidden;max-width:350px;white-space:break-word;text-wrap:wrap;word-break:break-all}\n"] }]
}], propDecorators: { tableRows: [{
type: Input,
args: ['rows']
}], showRow: [{
type: Input,
args: ['showRowDetails']
}], title: [{
type: Input,
args: ['title']
}], titleClassList: [{
type: Input,
args: ['titleClass']
}], eventBuilder: [{
type: Input,
args: ["eventBuilder"]
}], selectionManager: [{
type: Input,
args: ['selectionManager']
}], viewCtrl: [{
type: ViewChild,
args: [TableViewControllerDirective]
}], viewReadyEvent: [{
type: Output,
args: ['viewReady']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adc-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/asadi/angular-date-components/core/src/components/adc-table/adc-table.component.ts","../../../../../../../../projects/asadi/angular-date-components/core/src/components/adc-table/adc-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAiB,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE7I,OAAO,EAAE,4BAA4B,EAAE,MAAM,kDAAkD,CAAC;AAChG,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;;;AAIpD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AAYH,MAAM,OAAO,iBAAiB;IAX9B;QAaW,YAAO,GAAG,MAAM,CAAc,WAAW,CAAC,CAAC;QAC3C,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAEpC;;SAEC;QAEH,cAAS,GAAmB,EAAE,CAAC;QAE7B;;SAEC;QAEH,YAAO,GAAY,IAAI,CAAC;QAEtB;;;SAGC;QAEH,UAAK,GAAW,EAAE,CAAC;QAEjB;;SAEC;QAEH,mBAAc,GAAW,EAAE,CAAC;QAY5B,mBAAc,GAAG,IAAI,YAAY,EAAQ,CAAC;KAyB3C;IAtBC,eAAe;QAEb,IAAG,IAAI,CAAC,QAAQ,IAAI,IAAI;YAAE,OAAO;QAEjC,IAAG,IAAI,CAAC,YAAY,EACpB;YACE,IAAG,IAAI,CAAC,QAAQ,IAAI,IAAI;gBAAE,OAAO;YAEjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SACpE;QAED,IAAG,IAAI,CAAC,gBAAgB,EACxB;YACE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC3C;IACH,CAAC;IAED,WAAW;QAET,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;8GA/DU,iBAAiB;kGAAjB,iBAAiB,qXAoCjB,4BAA4B,gDCjGzC,0+GA+DA,mnEDTI,YAAY,8VACZ,4BAA4B;;2FAMnB,iBAAiB;kBAX7B,SAAS;+BACE,WAAW,cACT,IAAI,WACP;wBACP,YAAY;wBACZ,4BAA4B;qBAC7B,mBAGgB,uBAAuB,CAAC,MAAM;8BAW/C,SAAS;sBADR,KAAK;uBAAC,MAAM;gBAOb,OAAO;sBADN,KAAK;uBAAC,gBAAgB;gBAQvB,KAAK;sBADJ,KAAK;uBAAC,OAAO;gBAOd,cAAc;sBADb,KAAK;uBAAC,YAAY;gBAInB,YAAY;sBADX,KAAK;uBAAC,cAAc;gBAIrB,gBAAgB;sBADf,KAAK;uBAAC,kBAAkB;gBAIjB,QAAQ;sBADf,SAAS;uBAAC,4BAA4B;gBAIvC,cAAc;sBADb,MAAM;uBAAC,WAAW","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { AfterViewInit, ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, Renderer2, ViewChild } from '@angular/core';\r\nimport { ADCITableRow, ADCIOptions } from '../../interface';\r\nimport { TableViewControllerDirective } from '../../directives/table-view-controller.directive';\r\nimport { ADC_OPTIONS } from '../../injection-token';\r\nimport { TableSelection } from '../../table-selection';\r\nimport { FlatEventBuilder } from '../../flat-event-builder';\r\n\r\n/**\r\n * A reusable and customizable table component for displaying date-related data.\r\n * The `adc-table` component is designed for use within the Angular Date Components package.\r\n * It supports features like row and column labels, custom cell event builders, and date range selection.\r\n *\r\n * The component allows for displaying a dynamic table with custom rows, columns, and cells.\r\n * It supports both left-to-right (`ltr`) and right-to-left (`rtl`) layouts.\r\n * \r\n * ### Features\r\n * - Dynamically updates the table view when cell data changes.\r\n * - Supports date filtering and custom event builders for handling cell events.\r\n * - Emits an event when a date range is selected.\r\n *\r\n * @example\r\n * ```html\r\n * <adc-table\r\n *   [Rows]=\"tableRows\"\r\n *   [Columns]=\"tableColumns\"\r\n *   [Cells]=\"tableCells\"\r\n *   [Title]=\"'My Schedule'\"\r\n *   [TitleClass]=\"'table-title'\"\r\n *   [ShowRowLabels]=\"true\"\r\n *   [ShowColumnLabels]=\"false\"\r\n *   [Dir]=\"'ltr'\"\r\n *   [DateFilter]=\"customDateFilter\"\r\n *   [EventBuilder]=\"eventBuilderInstance\"\r\n *   (DateRangeSelect)=\"onDateRangeSelect($event)\">\r\n * </adc-table>\r\n * ```\r\n * \r\n * @example\r\n * ```typescript\r\n * // In your component class\r\n * tableRows: ADCITableRow[] = [...];\r\n * tableColumns: ADCITableColumn[] = [...];\r\n * tableCells: ADCITableCell[] = [...];\r\n * \r\n * onDateRangeSelect(selectedCells: ADCITableCell[]) {\r\n *   console.log('Selected cells:', selectedCells);\r\n * }\r\n * ```\r\n */\r\n@Component({\r\n  selector: 'adc-table',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    TableViewControllerDirective,\r\n  ],\r\n  templateUrl: './adc-table.component.html',\r\n  styleUrls: ['./adc-table.component.css'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ADCTableComponent implements AfterViewInit{\r\n\r\n  readonly options = inject<ADCIOptions>(ADC_OPTIONS);\r\n  readonly renderer = inject(Renderer2);\r\n\r\n    /**\r\n   * An array of rows to display in the table.\r\n   */\r\n  @Input('rows')\r\n  tableRows: ADCITableRow[] = [];\r\n\r\n    /**\r\n   * a boolean which determines if row details should be displayed or not\r\n   */\r\n  @Input('showRowDetails')\r\n  showRow: boolean = true;\r\n\r\n    /**\r\n     * \r\n   * The title displayed above the table.\r\n   */\r\n  @Input('title')\r\n  title: string = '';\r\n\r\n    /**\r\n   * CSS classes to apply to the title.\r\n   */\r\n  @Input('titleClass')\r\n  titleClassList: string = '';\r\n\r\n  @Input(\"eventBuilder\")\r\n  eventBuilder!: FlatEventBuilder;\r\n\r\n  @Input('selectionManager')\r\n  selectionManager!: TableSelection;\r\n\r\n  @ViewChild(TableViewControllerDirective)\r\n  private viewCtrl!: TableViewControllerDirective;\r\n\r\n  @Output('viewReady')\r\n  viewReadyEvent = new EventEmitter<void>();\r\n\r\n\r\n  ngAfterViewInit(): void \r\n  {\r\n    if(this.viewCtrl == null) return;\r\n\r\n    if(this.eventBuilder)\r\n    {\r\n      if(this.viewCtrl == null) return;\r\n      \r\n      this.eventBuilder.init(this.renderer, this.viewCtrl, this.options);\r\n    }\r\n\r\n    if(this.selectionManager)\r\n    {\r\n      this.selectionManager.init(this.viewCtrl);\r\n    }\r\n  }\r\n\r\n  onViewReady(): void\r\n  {\r\n    this.viewReadyEvent.emit();\r\n  }\r\n\r\n}\r\n","\r\n<div [dir]=\"options.direction\">\r\n\r\n    <div [classList]=\"titleClassList + ' font-bold text-xl'\" style=\"border-bottom: 1px solid #000; text-align: center;\">\r\n        {{title}}\r\n    </div>\r\n\r\n    <div style=\"max-height: 700px;overflow: scroll;\">\r\n\r\n        <div style=\"flex: 1;display: flex;flex-direction: column;\" class=\"adc-table\" tableViewController (viewReady)=\"onViewReady()\">\r\n\r\n            <ng-container *ngFor=\"let row of tableRows; let lastRow = last; let rowIndex = index\">\r\n    \r\n                <div class=\"row\" style=\"position: relative;flex-shrink: 0;\" [attr.sticky]=\"rowIndex == 0\" \r\n                [class.sticky]=\"rowIndex == 0\" [class.vertical-stick]=\"rowIndex == 0\" [attr.row-index]=\"rowIndex\">\r\n    \r\n                    <!-- cells - columns -->\r\n                    <div style=\"display: flex;flex-direction: row;flex-wrap: nowrap;flex: 1;height: 100%;\" cells>\r\n    \r\n                        <ng-container *ngIf=\"showRow\">\r\n    \r\n                            <div style=\"min-width: 100px;display: flex;flex-direction: column;overflow: hidden;\r\n                                padding: 6px;\" [style.justifyContent]=\"row.verticalAlign\" [style.alignItems]=\"row.horizontalAlign\"\r\n                                [classList]=\"row.classList + ' column column-border sticky horizontal-stick'\" detail=\"true\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\">\r\n        \r\n                                <span class=\"label\">{{row.prefix}}</span>\r\n                                <span class=\"label\">{{row.label}}</span>\r\n                                <span class=\"label\">{{row.suffix}}</span>\r\n        \r\n                            </div>\r\n    \r\n                        </ng-container>\r\n        \r\n                        <ng-container *ngFor=\"let column of row.columns; let lastColumn = last; let columnIndex = index\">\r\n                            <div style=\"min-width: 50px;display: flex;flex-direction: column;overflow: hidden;\r\n                            white-space: nowrap;text-overflow: ellipsis;padding: 6px;flex: 1;\" [style.justifyContent]=\"column.verticalAlign\" [attr.selectable]=\"column.selectable\"\r\n                            [classList]=\"column.classList + ' column'\" [attr.columnValue]=\"column.value\" [style.alignItems]=\"column.horizontalAlign\"\r\n                            [attr.rowValue]=\"row.value\" [attr.rowIndex]=\"rowIndex\" [attr.columnIndex]=\"columnIndex\"\r\n                            [ngClass]=\"{'column-border': !lastColumn}\" [style.borderBottom]=\"lastRow ? 'none' : '1px solid #000'\" detail=\"false\">\r\n        \r\n                                <span class=\"label\">{{column.prefix}}</span>\r\n                                <span class=\"label\">{{column.label}}</span>\r\n                                <span class=\"label\">{{column.suffix}}</span>\r\n        \r\n                            </div>\r\n                        </ng-container>\r\n    \r\n                    </div>\r\n    \r\n                    <!-- events -->\r\n                    <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 1;pointer-events: none;\" events></div>\r\n\r\n                    <div style=\"position: absolute;height: 100%;width: 100%;left: 0;top: 0;z-index: 3;pointer-events: none;\" tooltip></div>\r\n    \r\n                </div>\r\n    \r\n            </ng-container>\r\n    \r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>\r\n"]}