@testgorilla/tgo-ui 2.24.22 → 2.24.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,7 @@ import * as i3 from "../../pipes/ui-translate.pipe";
5
5
  import * as i4 from "ng2-charts";
6
6
  import * as i5 from "@angular/material/tooltip";
7
7
  import * as i6 from "../icon/icon.component.module";
8
- import * as i7 from "projects/tgo-canopy-ui/pipes/memoize-func.pipe";
8
+ import * as i7 from "../../pipes/memoize-func.pipe";
9
9
  export declare class GaussianChartComponentModule {
10
10
  static ɵfac: i0.ɵɵFactoryDeclaration<GaussianChartComponentModule, never>;
11
11
  static ɵmod: i0.ɵɵNgModuleDeclaration<GaussianChartComponentModule, [typeof i1.GaussianChartComponent], [typeof i2.NgClass, typeof i3.UiTranslatePipe, typeof i4.NgChartsModule, typeof i5.MatTooltipModule, typeof i2.CommonModule, typeof i6.IconComponentModule, typeof i7.MemoizeFuncPipe], [typeof i1.GaussianChartComponent]>;
@@ -15,8 +15,6 @@ export interface TableConfigWithPagination<T> extends TableConfig<T> {
15
15
  export interface TableColumn<T = any> {
16
16
  title?: string;
17
17
  key: string;
18
- widthPerc?: number;
19
- minWidthPx?: number;
20
18
  allowMultiline?: boolean;
21
19
  bold?: boolean;
22
20
  showTooltip?: boolean;
@@ -6,7 +6,7 @@ import { Chart, registerables } from 'chart.js';
6
6
  import { MatTooltipModule } from '@angular/material/tooltip';
7
7
  import { CommonModule, NgClass } from '@angular/common';
8
8
  import { IconComponentModule } from '../icon/icon.component.module';
9
- import { MemoizeFuncPipe } from 'projects/tgo-canopy-ui/pipes/memoize-func.pipe';
9
+ import { MemoizeFuncPipe } from '../../pipes/memoize-func.pipe';
10
10
  import * as i0 from "@angular/core";
11
11
  Chart.register(...registerables);
12
12
  export class GaussianChartComponentModule {
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
39
39
  ],
40
40
  }]
41
41
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2F1c3NpYW4tY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2dhdXNzaWFuLWNoYXJ0L2dhdXNzaWFuLWNoYXJ0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxLQUFLLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDcEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdEQUFnRCxDQUFDOztBQUVqRixLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUM7QUFlakMsTUFBTSxPQUFPLDRCQUE0QjsrR0FBNUIsNEJBQTRCO2dIQUE1Qiw0QkFBNEIsaUJBWnhCLHNCQUFzQixhQUduQyxPQUFPO1lBQ1AsZUFBZTtZQUNmLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixlQUFlLGFBUlAsc0JBQXNCO2dIQVdyQiw0QkFBNEIsWUFQckMsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osbUJBQW1COzs0RkFJViw0QkFBNEI7a0JBYnhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUNqQyxPQUFPLEVBQUU7d0JBQ1AsT0FBTzt3QkFDUCxlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVWlUcmFuc2xhdGVQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMvdWktdHJhbnNsYXRlLnBpcGUnO1xuaW1wb3J0IHsgR2F1c3NpYW5DaGFydENvbXBvbmVudCB9IGZyb20gJy4vZ2F1c3NpYW4tY2hhcnQuY29tcG9uZW50JztcbmltcG9ydCB7IE5nQ2hhcnRzTW9kdWxlIH0gZnJvbSAnbmcyLWNoYXJ0cyc7XG5pbXBvcnQgeyBDaGFydCwgcmVnaXN0ZXJhYmxlcyB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdDbGFzcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJY29uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLmNvbXBvbmVudC5tb2R1bGUnO1xuaW1wb3J0IHsgTWVtb2l6ZUZ1bmNQaXBlIH0gZnJvbSAncHJvamVjdHMvdGdvLWNhbm9weS11aS9waXBlcy9tZW1vaXplLWZ1bmMucGlwZSc7XG5cbkNoYXJ0LnJlZ2lzdGVyKC4uLnJlZ2lzdGVyYWJsZXMpO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtHYXVzc2lhbkNoYXJ0Q29tcG9uZW50XSxcbiAgZXhwb3J0czogW0dhdXNzaWFuQ2hhcnRDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbXG4gICAgTmdDbGFzcyxcbiAgICBVaVRyYW5zbGF0ZVBpcGUsXG4gICAgTmdDaGFydHNNb2R1bGUsXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgSWNvbkNvbXBvbmVudE1vZHVsZSxcbiAgICBNZW1vaXplRnVuY1BpcGUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEdhdXNzaWFuQ2hhcnRDb21wb25lbnRNb2R1bGUge31cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2F1c3NpYW4tY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGdvLWNhbm9weS11aS9jb21wb25lbnRzL2dhdXNzaWFuLWNoYXJ0L2dhdXNzaWFuLWNoYXJ0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxLQUFLLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDcEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDOztBQUVoRSxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUM7QUFlakMsTUFBTSxPQUFPLDRCQUE0QjsrR0FBNUIsNEJBQTRCO2dIQUE1Qiw0QkFBNEIsaUJBWnhCLHNCQUFzQixhQUduQyxPQUFPO1lBQ1AsZUFBZTtZQUNmLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixlQUFlLGFBUlAsc0JBQXNCO2dIQVdyQiw0QkFBNEIsWUFQckMsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osbUJBQW1COzs0RkFJViw0QkFBNEI7a0JBYnhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUNqQyxPQUFPLEVBQUU7d0JBQ1AsT0FBTzt3QkFDUCxlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVWlUcmFuc2xhdGVQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMvdWktdHJhbnNsYXRlLnBpcGUnO1xuaW1wb3J0IHsgR2F1c3NpYW5DaGFydENvbXBvbmVudCB9IGZyb20gJy4vZ2F1c3NpYW4tY2hhcnQuY29tcG9uZW50JztcbmltcG9ydCB7IE5nQ2hhcnRzTW9kdWxlIH0gZnJvbSAnbmcyLWNoYXJ0cyc7XG5pbXBvcnQgeyBDaGFydCwgcmVnaXN0ZXJhYmxlcyB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdDbGFzcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJY29uQ29tcG9uZW50TW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLmNvbXBvbmVudC5tb2R1bGUnO1xuaW1wb3J0IHsgTWVtb2l6ZUZ1bmNQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMvbWVtb2l6ZS1mdW5jLnBpcGUnO1xuXG5DaGFydC5yZWdpc3RlciguLi5yZWdpc3RlcmFibGVzKTtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbR2F1c3NpYW5DaGFydENvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtHYXVzc2lhbkNoYXJ0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIE5nQ2xhc3MsXG4gICAgVWlUcmFuc2xhdGVQaXBlLFxuICAgIE5nQ2hhcnRzTW9kdWxlLFxuICAgIE1hdFRvb2x0aXBNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEljb25Db21wb25lbnRNb2R1bGUsXG4gICAgTWVtb2l6ZUZ1bmNQaXBlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBHYXVzc2lhbkNoYXJ0Q29tcG9uZW50TW9kdWxlIHt9XG4iXX0=
@@ -98,14 +98,12 @@ export class TableComponent {
98
98
  ngOnChanges(changes) {
99
99
  if (changes['config'] && changes['config'].currentValue) {
100
100
  this.onSortChange(changes['config'].currentValue.sort);
101
- }
102
- else if (changes['data']?.currentValue) {
103
- this.setTableData(changes['data'].currentValue);
104
- }
105
- else if (changes['config']?.currentValue) {
106
101
  const config = changes['config'].currentValue;
107
102
  this.setTableConfig(config);
108
103
  }
104
+ if (changes['data']?.currentValue) {
105
+ this.setTableData(changes['data'].currentValue);
106
+ }
109
107
  }
110
108
  hasTableScroll() {
111
109
  const table = this.table.nativeElement;
@@ -235,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
235
233
  type: ViewChild,
236
234
  args: ['table']
237
235
  }] } });
238
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/table/table.component.ts","../../../../../projects/tgo-canopy-ui/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  ColumnEllipse,\n  ColumnType,\n  ComponentRenderer,\n  DataSource,\n  Pagination,\n  ScrollSettings,\n  TableColumn,\n  TableConfig,\n  TableConfigWithPagination,\n  TableData,\n  TableDetailColumn\n} from './table.model';\nimport { PageEvent } from '@angular/material/paginator';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { sortByOrder } from '../../utils/table.utils';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { Sort } from '@angular/material/sort';\nimport { BehaviorSubject, fromEvent, Observable } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { IS_MOBILE_TOKEN } from '../../providers/is-mobile';\n\n@Component({\n  selector: 'ui-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger('expandDetail', [\n      state('collapsed, void', style({ height: '0px' })),\n      state('expanded', style({ height: '*' })),\n      transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\n      transition('expanded <=> void', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)'))\n    ])\n  ]\n})\nexport class TableComponent<T extends DataSource, TDetail extends DataSource> implements OnChanges, AfterViewInit {\n  /**\n   * Table configuration\n   *\n   * @type {TableConfig}\n   * @memberof TableComponent\n   */\n  @Input({ required: true }) config: TableConfigWithPagination<T>;\n\n  /**\n   * Input property for providing the table data.\n   *\n   * @type {TableData}\n   * @memberof TableComponent\n   */\n  @Input() data: TableData\n\n  /**\n   * Input property indicating whether the table is in a loading state.\n   *\n   * @type {boolean}\n   * @memberof TableComponent\n   * @default false\n   */\n  @Input() loading = false;\n\n  /**\n   *\n   * Defines the application theme\n   * @type {ApplicationTheme}\n   * @memberof TableComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Data structure to select which columns should be rendered and their capabilities\n   *\n   * @type {TableDetailColumn}\n   * @memberof TableComponent\n   */\n  @Input() tableDetailColumns: TableDetailColumn<T, TDetail>;\n  @Input() tableDetails = false;\n\n  /**\n   * Disable border radius for table\n   *\n   * @type {boolean}\n   * @memberof TableComponent\n   */\n  @Input() disableBorderRadius = false;\n\n  @Output() onRowClickEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() onDetailRowClickEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() paginatorChange = new EventEmitter<PageEvent>();\n  @Output() sortChange = new EventEmitter<Sort>();\n\n  @ViewChild('table') table: ElementRef;\n\n  protected tableData: TableData;\n  protected sourceData: TableData;\n  protected columnsTooltipState: ColumnEllipse[] = [];\n  protected tableConfig: TableConfigWithPagination<T>;\n  protected displayedColumns: string[] = [];\n  protected columnsDetailToDisplay: string[] = [];\n  protected skeletonStyleConfig = {\n    background: '#F6F6F6',\n    'border-radius': '4px',\n    height: '24px'\n  };\n  protected dataSourceDetail = new MatTableDataSource<any>([]);\n  protected elementDetail: any;\n  protected readonly DataType = ColumnType;\n  protected scrollSettings$ = new BehaviorSubject<ScrollSettings>({ scrollEnd: false, horizontalScroll: false, scrollStart: false });\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private destroyRef: DestroyRef,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.setTableConfig(this.config);\n    this.setTableData(this.data);\n\n    if (this.applicationTheme !== 'classic') {\n      this.skeletonStyleConfig.background = '#F4F4F4';\n    }\n    document.body.setAttribute('theme', this.applicationTheme);\n\n    if (this.tableDetailColumns) {\n      const filteredColumns = this.tableDetailColumns.columnDefs.filter(column => !column.hidden);\n      this.columnsDetailToDisplay = filteredColumns.length ?  filteredColumns.map(\n        (tableColumn: TableColumn<TDetail>) => tableColumn.title!\n      ) : [];\n    }\n\n    if (this.tableConfig?.sortable && this.tableConfig?.sort) {\n      this.onSortChange(this.tableConfig.sort as Sort);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.hasTableScroll();\n    fromEvent(this.table.nativeElement, 'scroll')\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => this.hasTableScroll());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && changes['config'].currentValue) {\n      this.onSortChange(changes['config'].currentValue.sort);\n    } else if (changes['data']?.currentValue) {\n      this.setTableData(changes['data'].currentValue as TableData);\n    } else if (changes['config']?.currentValue) {\n      const config = changes['config'].currentValue as TableConfig<T>;\n      this.setTableConfig(config);\n    }\n  }\n\n  hasTableScroll(): void {\n    const table = this.table.nativeElement;\n    const horizontalScroll = table.scrollWidth > table.clientWidth;\n    const scrollEnd = table.scrollLeft + table.clientWidth >= table.scrollWidth;\n    this.scrollSettings$.next({\n      scrollStart: !table.scrollLeft,\n      scrollEnd,\n      horizontalScroll\n    });\n  }\n\n  callRenderer([rendererFn, element]: [(v: T) => ComponentRenderer | string, T]): any {\n    if (rendererFn) {\n      return rendererFn(element);\n    }\n  }\n\n  protected onPaginatorChange(event: PageEvent): void {\n    this.paginatorChange.emit(event);\n  }\n\n  protected onChangeColumnSize(columnIndex: number, showTooltip: boolean): void {\n    this.columnsTooltipState = this.columnsTooltipState.map(column => {\n      if (column.index === columnIndex) {\n        column.showTooltip = showTooltip;\n      }\n      return column;\n    });\n  }\n\n  protected onSortChange(sortState: Sort): void {\n    this.sortChange.emit(sortState);\n\n    if (this.tableConfig?.sortable) {\n      this.tableData = [...this.tableData.sort((a, b) => {\n        const isAsc = sortState.direction === 'asc';\n        const aVal = a[sortState.active];\n        const bVal = b[sortState.active];\n        return (aVal < bVal ? -1 : 1) * (isAsc ? 1 : -1);\n      })]\n\n      if (!sortState.direction) {\n        this.tableData = [...this.sourceData];\n      }\n    }\n  }\n\n  protected onRowClick(rowParams: any): void {\n    this.onRowClickEvent.emit(rowParams);\n  }\n\n  protected onDetailRowClick(rowParams: any): void {\n    this.onDetailRowClickEvent.emit(rowParams);\n  }\n\n  protected toggleRow(element: T): void {\n    if (this.tableDetails) {\n      this.elementDetail = this.elementDetail === element ? null : element;\n      if (this.elementDetail) {\n        this.tableDetailColumns.setDetailRowData({\n          data: element,\n          setDetailDataSource: this.setTableDetailDataSource.bind(this)\n        });\n      }\n    }\n  }\n\n  private setTableDetailDataSource(rowData: TDetail[]): void {\n    this.dataSourceDetail = new MatTableDataSource<any>(rowData);\n  }\n\n  private setTableConfig(config: TableConfig<T>): void {\n    config.pagination = config?.pagination ?? this.defaultPaginationConfig;\n\n    this.tableConfig = config as TableConfigWithPagination<T>;\n\n    this.columnsTooltipState = config.columns.map((column, index) => ({\n      index,\n      showTooltip: column.showTooltip ?? false\n    }));\n    this.displayedColumns = sortByOrder<T>(config.columns.filter(column => !column.hidden)).map(column => column.uniqueId ?? column.key);\n  }\n\n  private setTableData(data: TableData): void {\n    this.sourceData = data;\n    this.tableData = data;\n  }\n\n  private defaultPaginationConfig: Pagination = {\n    currentPage: 0,\n    itemsPerPage: 10,\n    itemsPerPageOptions: [10, 25, 50],\n    totalItems: 20\n  };\n\n  trackColumnUniqueId = (index: number, column: TableColumn<T>): string => column.uniqueId ?? column.key;\n}\n","<div #tableContainer class=\"table-container\"\n     [ngClass]=\"{ 'without-title': !tableConfig?.title, 'disable-border-radius': disableBorderRadius }\"\n     [attr.theme]=\"applicationTheme\">\n  <div *ngIf=\"tableConfig?.title\" class=\"table-header\">\n    {{ tableConfig.title | sentencecase }}\n    <ng-content select=\"[title-actions]\"></ng-content>\n  </div>\n  <div\n    #table\n    *ngIf=\"scrollSettings$ | async as scrollSettings\"\n    class=\"table-wrapper\">\n    <table\n      class=\"main-table\"\n      mat-table\n      [dataSource]=\"tableData\"\n      matSort\n      [matSortStart]=\"tableConfig?.sort?.defaultSortStart ?? 'asc'\"\n      [matSortActive]=\"tableConfig?.sort?.active ?? ''\"\n      [matSortDirection]=\"tableConfig?.sort?.direction ?? ''\"\n      (matSortChange)=\"onSortChange($event)\"\n      multiTemplateDataRows\n    >\n\n      <ng-container\n        *ngFor=\"let column of tableConfig.columns; index as i, last as isLast; trackBy: trackColumnUniqueId\">\n        <ng-container *ngIf=\"isLast && column.isSticky && column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\" [stickyEnd]=\"!scrollSettings?.scrollEnd\">\n            <th mat-header-cell\n                [start]=\"column.sortStart ?? 'asc'\"\n                [mat-sort-header]=\"column.sortHeader ?? column.key\"\n                *matHeaderCellDef\n                [attr.sortable]=\"column.allowSort ?? false\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n                [style.font-weight]=\"'bold'\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: {$implicit: column.title, column, colIndex: i}\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\" [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: {$implicit: element, rowIndex}\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container *ngIf=\"isLast && column.isSticky && !column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [stickyEnd]=\"scrollSettings.horizontalScroll ? !scrollSettings.scrollEnd : true\">\n            <th mat-header-cell\n                *matHeaderCellDef\n                [attr.sortable]=\"column.allowSort ?? false\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n                [style.font-weight]=\"'bold'\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: {$implicit: column.title, column, colIndex: i}\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit: element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container\n          *ngIf=\"!(isLast && column.isSticky) && column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [sticky]=\"(isMobile$ | async) ? false : !scrollSettings.scrollStart  && !!column.isSticky\">\n            <th mat-header-cell\n                [start]=\"column.sortStart ?? 'asc'\"\n                [mat-sort-header]=\"column.sortHeader ?? column.key\"\n                [attr.sortable]=\"column.allowSort ?? false\"\n                *matHeaderCellDef\n                [style.font-weight]=\"'bold'\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: { $implicit: column.title, column, colIndex: i }\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit: element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container\n          *ngIf=\"!(isLast && column.isSticky) && !column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [sticky]=\"(isMobile$ | async) ? false : !scrollSettings.scrollStart && !!column.isSticky\">\n            <th mat-header-cell\n                [attr.sortable]=\"column.allowSort ?? false\"\n                *matHeaderCellDef\n                [style.font-weight]=\"'bold'\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: { $implicit: column.title, column, colIndex: i }\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit:  element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n      </ng-container>\n\n\n      <ng-container matColumnDef=\"expandedDetail\">\n        <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"displayedColumns.length\">\n          <div class=\"element-detail\" *ngIf=\"dataSourceDetail.data.length\"\n               [@expandDetail]=\"element === elementDetail ? 'expanded' : 'collapsed'\">\n            <table\n              mat-table\n              [dataSource]=\"dataSourceDetail\"\n              [ngClass]=\"{ 'hide-borders': element === tableData[tableData.length - 1] }\"\n            >\n              <ng-container *ngFor=\"let tableColumn of tableDetailColumns.columnDefs\"\n                            [matColumnDef]=\"tableColumn.title ?? ''\">\n                <th mat-header-cell *matHeaderCellDef=\"let element\" arrowPosition=\"after\"\n                    [ngStyle]=\"{width: tableColumn.styles?.width}\"\n                    [ngClass]=\"tableColumn.styles?.alignment ? 'th-'+tableColumn.styles?.alignment : ''\">\n                  {{ tableColumn.title | uppercase }}\n                </th>\n\n                <td mat-cell *matCellDef=\"let element\" (click)=\"onDetailRowClick(element)\"\n                    [align]=\"tableColumn.styles?.alignment\"\n                    [ngClass]=\"tableColumn.styles?.alignment ? 'td-'+tableColumn.styles?.alignment : ''\"\n                    [ngStyle]=\"{width: tableColumn.styles?.width }\">\n                  <ng-container *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn}\"></ng-container>\n                </td>\n              </ng-container>\n\n              <tr mat-header-row *matHeaderRowDef=\"columnsDetailToDisplay\"></tr>\n              <tr mat-row *matRowDef=\"let rowDetail; columns: columnsDetailToDisplay;\"></tr>\n            </table>\n          </div>\n        </td>\n      </ng-container>\n\n      <ng-template #tableDataTpl let-element=\"element\" let-tableColumn=\"tableColumn\">\n        <div class=\"align-wrapper\">\n          <ng-container [ngSwitch]=\"tableColumn.type\">\n            <ng-container *ngSwitchCase=\"DataType.FIELD\">\n              {{ element | dataPropertyGetter: tableColumn.key }}\n            </ng-container>\n            <ng-container *ngSwitchCase=\"DataType.FUNCTION\">\n              {{ tableColumn.function?.(element) }}\n            </ng-container>\n            <ng-container *ngSwitchCase=\"DataType.RENDERER\">\n              <ng-template\n                [dynamicComponent]=\"[tableColumn.renderer, element] | memoizeFunc : callRenderer\">\n              </ng-template>\n            </ng-container>\n            <ng-container *ngSwitchDefault>\n              {{ element | dataPropertyGetter: tableColumn.key }}\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-template>\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"\n          [ngClass]=\"{'expanded-row': elementDetail === row, 'row-clickable': tableDetails, 'selected': row?.selected, 'last-row': row === tableData[tableData.length - 1] && !elementDetail }\"\n          (click)=\"toggleRow(row)\">\n      </tr>\n      <ng-container *ngIf=\"tableDetails && tableDetailColumns?.columnDefs?.length\">\n        <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"detail-row\"></tr>\n      </ng-container>\n\n      <ng-container *ngIf=\"tableConfig.noDataRowTpl\">\n        <tr *matNoDataRow>\n          <ng-container *ngTemplateOutlet=\"tableConfig.noDataRowTpl\"></ng-container>\n        </tr>\n      </ng-container>\n    </table>\n  </div>\n\n  <ui-paginator\n    *ngIf=\"!tableConfig?.hidePagination\"\n    [disabled]=\"loading\"\n    [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n    [pageSize]=\"tableConfig.pagination.itemsPerPage\"\n    [length]=\"tableConfig.pagination.totalItems\"\n    [currentPage]=\"tableConfig.pagination.currentPage\"\n    [pageSizeOptions]=\"tableConfig.pagination.itemsPerPageOptions\"\n    (paginatorChange)=\"onPaginatorChange($event)\"\n  ></ui-paginator>\n</div>\n\n<ng-template #columnHeader let-column=\"column\" let-i=\"i\">\n  <div class=\"header-section\">\n                    <span uiEllipseText (onChangeTextState)=\"onChangeColumnSize(i, $event)\"\n                          class=\"column-title\">{{ column.title | sentencecase }}\n                 </span>\n    <ui-icon *ngIf=\"column?.showTooltip\" [name]=\"'Help-in-line'\"\n             [matTooltipClass]=\"applicationTheme\"\n             [matTooltip]=\"(column?.showTooltip ? (column?.tooltip ? column.tooltip : column.title ) : '') || ''\"\n    ></ui-icon>\n  </div>\n</ng-template>\n\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/table/table.component.ts","../../../../../projects/tgo-canopy-ui/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  ColumnEllipse,\n  ColumnType,\n  ComponentRenderer,\n  DataSource,\n  Pagination,\n  ScrollSettings,\n  TableColumn,\n  TableConfig,\n  TableConfigWithPagination,\n  TableData,\n  TableDetailColumn\n} from './table.model';\nimport { PageEvent } from '@angular/material/paginator';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { sortByOrder } from '../../utils/table.utils';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { Sort } from '@angular/material/sort';\nimport { BehaviorSubject, fromEvent, Observable } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { IS_MOBILE_TOKEN } from '../../providers/is-mobile';\n\n@Component({\n  selector: 'ui-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger('expandDetail', [\n      state('collapsed, void', style({ height: '0px' })),\n      state('expanded', style({ height: '*' })),\n      transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\n      transition('expanded <=> void', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)'))\n    ])\n  ]\n})\nexport class TableComponent<T extends DataSource, TDetail extends DataSource> implements OnChanges, AfterViewInit {\n  /**\n   * Table configuration\n   *\n   * @type {TableConfig}\n   * @memberof TableComponent\n   */\n  @Input({ required: true }) config: TableConfigWithPagination<T>;\n\n  /**\n   * Input property for providing the table data.\n   *\n   * @type {TableData}\n   * @memberof TableComponent\n   */\n  @Input() data: TableData\n\n  /**\n   * Input property indicating whether the table is in a loading state.\n   *\n   * @type {boolean}\n   * @memberof TableComponent\n   * @default false\n   */\n  @Input() loading = false;\n\n  /**\n   *\n   * Defines the application theme\n   * @type {ApplicationTheme}\n   * @memberof TableComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Data structure to select which columns should be rendered and their capabilities\n   *\n   * @type {TableDetailColumn}\n   * @memberof TableComponent\n   */\n  @Input() tableDetailColumns: TableDetailColumn<T, TDetail>;\n  @Input() tableDetails = false;\n\n  /**\n   * Disable border radius for table\n   *\n   * @type {boolean}\n   * @memberof TableComponent\n   */\n  @Input() disableBorderRadius = false;\n\n  @Output() onRowClickEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() onDetailRowClickEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() paginatorChange = new EventEmitter<PageEvent>();\n  @Output() sortChange = new EventEmitter<Sort>();\n\n  @ViewChild('table') table: ElementRef;\n\n  protected tableData: TableData;\n  protected sourceData: TableData;\n  protected columnsTooltipState: ColumnEllipse[] = [];\n  protected tableConfig: TableConfigWithPagination<T>;\n  protected displayedColumns: string[] = [];\n  protected columnsDetailToDisplay: string[] = [];\n  protected skeletonStyleConfig = {\n    background: '#F6F6F6',\n    'border-radius': '4px',\n    height: '24px'\n  };\n  protected dataSourceDetail = new MatTableDataSource<any>([]);\n  protected elementDetail: any;\n  protected readonly DataType = ColumnType;\n  protected scrollSettings$ = new BehaviorSubject<ScrollSettings>({ scrollEnd: false, horizontalScroll: false, scrollStart: false });\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private destroyRef: DestroyRef,\n    @Inject(IS_MOBILE_TOKEN) protected readonly isMobile$: Observable<boolean>\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.setTableConfig(this.config);\n    this.setTableData(this.data);\n\n    if (this.applicationTheme !== 'classic') {\n      this.skeletonStyleConfig.background = '#F4F4F4';\n    }\n    document.body.setAttribute('theme', this.applicationTheme);\n\n    if (this.tableDetailColumns) {\n      const filteredColumns = this.tableDetailColumns.columnDefs.filter(column => !column.hidden);\n      this.columnsDetailToDisplay = filteredColumns.length ?  filteredColumns.map(\n        (tableColumn: TableColumn<TDetail>) => tableColumn.title!\n      ) : [];\n    }\n\n    if (this.tableConfig?.sortable && this.tableConfig?.sort) {\n      this.onSortChange(this.tableConfig.sort as Sort);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.hasTableScroll();\n    fromEvent(this.table.nativeElement, 'scroll')\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => this.hasTableScroll());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] && changes['config'].currentValue) {\n      this.onSortChange(changes['config'].currentValue.sort);\n      const config = changes['config'].currentValue as TableConfig<T>;\n      this.setTableConfig(config);\n    }\n    if (changes['data']?.currentValue) {\n      this.setTableData(changes['data'].currentValue as TableData);\n    }\n  }\n\n  hasTableScroll(): void {\n    const table = this.table.nativeElement;\n    const horizontalScroll = table.scrollWidth > table.clientWidth;\n    const scrollEnd = table.scrollLeft + table.clientWidth >= table.scrollWidth;\n    this.scrollSettings$.next({\n      scrollStart: !table.scrollLeft,\n      scrollEnd,\n      horizontalScroll\n    });\n  }\n\n  callRenderer([rendererFn, element]: [(v: T) => ComponentRenderer | string, T]): any {\n    if (rendererFn) {\n      return rendererFn(element);\n    }\n  }\n\n  protected onPaginatorChange(event: PageEvent): void {\n    this.paginatorChange.emit(event);\n  }\n\n  protected onChangeColumnSize(columnIndex: number, showTooltip: boolean): void {\n    this.columnsTooltipState = this.columnsTooltipState.map(column => {\n      if (column.index === columnIndex) {\n        column.showTooltip = showTooltip;\n      }\n      return column;\n    });\n  }\n\n  protected onSortChange(sortState: Sort): void {\n    this.sortChange.emit(sortState);\n\n    if (this.tableConfig?.sortable) {\n      this.tableData = [...this.tableData.sort((a, b) => {\n        const isAsc = sortState.direction === 'asc';\n        const aVal = a[sortState.active];\n        const bVal = b[sortState.active];\n        return (aVal < bVal ? -1 : 1) * (isAsc ? 1 : -1);\n      })]\n\n      if (!sortState.direction) {\n        this.tableData = [...this.sourceData];\n      }\n    }\n  }\n\n  protected onRowClick(rowParams: any): void {\n    this.onRowClickEvent.emit(rowParams);\n  }\n\n  protected onDetailRowClick(rowParams: any): void {\n    this.onDetailRowClickEvent.emit(rowParams);\n  }\n\n  protected toggleRow(element: T): void {\n    if (this.tableDetails) {\n      this.elementDetail = this.elementDetail === element ? null : element;\n      if (this.elementDetail) {\n        this.tableDetailColumns.setDetailRowData({\n          data: element,\n          setDetailDataSource: this.setTableDetailDataSource.bind(this)\n        });\n      }\n    }\n  }\n\n  private setTableDetailDataSource(rowData: TDetail[]): void {\n    this.dataSourceDetail = new MatTableDataSource<any>(rowData);\n  }\n\n  private setTableConfig(config: TableConfig<T>): void {\n    config.pagination = config?.pagination ?? this.defaultPaginationConfig;\n\n    this.tableConfig = config as TableConfigWithPagination<T>;\n\n    this.columnsTooltipState = config.columns.map((column, index) => ({\n      index,\n      showTooltip: column.showTooltip ?? false\n    }));\n    this.displayedColumns = sortByOrder<T>(config.columns.filter(column => !column.hidden)).map(column => column.uniqueId ?? column.key);\n  }\n\n  private setTableData(data: TableData): void {\n    this.sourceData = data;\n    this.tableData = data;\n  }\n\n  private defaultPaginationConfig: Pagination = {\n    currentPage: 0,\n    itemsPerPage: 10,\n    itemsPerPageOptions: [10, 25, 50],\n    totalItems: 20\n  };\n\n  trackColumnUniqueId = (index: number, column: TableColumn<T>): string => column.uniqueId ?? column.key;\n}\n","<div #tableContainer class=\"table-container\"\n     [ngClass]=\"{ 'without-title': !tableConfig?.title, 'disable-border-radius': disableBorderRadius }\"\n     [attr.theme]=\"applicationTheme\">\n  <div *ngIf=\"tableConfig?.title\" class=\"table-header\">\n    {{ tableConfig.title | sentencecase }}\n    <ng-content select=\"[title-actions]\"></ng-content>\n  </div>\n  <div\n    #table\n    *ngIf=\"scrollSettings$ | async as scrollSettings\"\n    class=\"table-wrapper\">\n    <table\n      class=\"main-table\"\n      mat-table\n      [dataSource]=\"tableData\"\n      matSort\n      [matSortStart]=\"tableConfig?.sort?.defaultSortStart ?? 'asc'\"\n      [matSortActive]=\"tableConfig?.sort?.active ?? ''\"\n      [matSortDirection]=\"tableConfig?.sort?.direction ?? ''\"\n      (matSortChange)=\"onSortChange($event)\"\n      multiTemplateDataRows\n    >\n\n      <ng-container\n        *ngFor=\"let column of tableConfig.columns; index as i, last as isLast; trackBy: trackColumnUniqueId\">\n        <ng-container *ngIf=\"isLast && column.isSticky && column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\" [stickyEnd]=\"!scrollSettings?.scrollEnd\">\n            <th mat-header-cell\n                [start]=\"column.sortStart ?? 'asc'\"\n                [mat-sort-header]=\"column.sortHeader ?? column.key\"\n                *matHeaderCellDef\n                [attr.sortable]=\"column.allowSort ?? false\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n                [style.font-weight]=\"'bold'\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: {$implicit: column.title, column, colIndex: i}\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\" [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: {$implicit: element, rowIndex}\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container *ngIf=\"isLast && column.isSticky && !column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [stickyEnd]=\"scrollSettings.horizontalScroll ? !scrollSettings.scrollEnd : true\">\n            <th mat-header-cell\n                *matHeaderCellDef\n                [attr.sortable]=\"column.allowSort ?? false\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n                [style.font-weight]=\"'bold'\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: {$implicit: column.title, column, colIndex: i}\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit: element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container\n          *ngIf=\"!(isLast && column.isSticky) && column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [sticky]=\"(isMobile$ | async) ? false : !scrollSettings.scrollStart  && !!column.isSticky\">\n            <th mat-header-cell\n                [start]=\"column.sortStart ?? 'asc'\"\n                [mat-sort-header]=\"column.sortHeader ?? column.key\"\n                [attr.sortable]=\"column.allowSort ?? false\"\n                *matHeaderCellDef\n                [style.font-weight]=\"'bold'\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: { $implicit: column.title, column, colIndex: i }\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit: element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n        <ng-container\n          *ngIf=\"!(isLast && column.isSticky) && !column.allowSort\">\n          <ng-container [matColumnDef]=\"column.uniqueId ?? column.key\"\n                        [sticky]=\"(isMobile$ | async) ? false : !scrollSettings.scrollStart && !!column.isSticky\">\n            <th mat-header-cell\n                [attr.sortable]=\"column.allowSort ?? false\"\n                *matHeaderCellDef\n                [style.font-weight]=\"'bold'\"\n                [ngStyle]=\"{width: column.styles?.width, minWidth: column.styles?.['min-width']}\"\n                [ngClass]=\"column.styles?.alignment ? 'th-'+column.styles?.alignment : ''\"\n            >\n              <ng-container *ngIf=\"column.headerCellTemplate; else configValue\">\n                <ng-container\n                  *ngTemplateOutlet=\"column.headerCellTemplate; context: { $implicit: column.title, column, colIndex: i }\"></ng-container>\n              </ng-container>\n              <ng-template #configValue>\n                <ng-container [ngTemplateOutlet]=\"columnHeader\" [ngTemplateOutletContext]=\"{ i, column }\"></ng-container>\n              </ng-template>\n            </th>\n\n            <td mat-cell\n                *matCellDef=\"let element; let rowIndex = dataIndex\"\n                [align]=\"column.styles?.alignment\"\n                (click)=\"onRowClick(element); column?.rowCellTemplateClick ? column!.rowCellTemplateClick?.() : ''\"\n            >\n              <ui-skeleton class=\"table-skeleton-loader\" [count]=\"1\" [theme]=\"skeletonStyleConfig\"\n                           [appearance]=\"'line'\"\n                           *ngIf=\"loading; else value\"></ui-skeleton>\n              <ng-template #value>\n                <div class=\"row-value\">\n                  @if (column?.type) {\n                    <ng-container\n                      *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn: column}\"></ng-container>\n                  } @else {\n                    <ui-icon\n                      [applicationTheme]=\"applicationTheme\"\n                      *ngIf=\"!i && tableDetails\"\n                      size=\"24\"\n                      [ngClass]=\"{ opened: elementDetail && element == elementDetail }\"\n                      [name]=\"applicationTheme === 'classic' ? 'Arrow_down' : 'Arrow-chevron-down-in-line'\"\n                    ></ui-icon>\n\n                    <ng-container *ngIf=\"column.rowCellTemplate; else configData\">\n                      <ng-container\n                        *ngTemplateOutlet=\"column.rowCellTemplate; context: { $implicit:  element, rowIndex }\"></ng-container>\n                    </ng-container>\n                    <ng-template #configData>\n                  <span [style.font-weight]=\"column.bold ? 'bold' : 'normal'\"\n                        [style.font-size]=\"column.fontSize ?? '14px'\">{{ element | dataPropertyGetter: column.key }}</span>\n                    </ng-template>\n                  }\n                </div>\n              </ng-template>\n            </td>\n          </ng-container>\n        </ng-container>\n\n      </ng-container>\n\n\n      <ng-container matColumnDef=\"expandedDetail\">\n        <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"displayedColumns.length\">\n          <div class=\"element-detail\" *ngIf=\"dataSourceDetail.data.length\"\n               [@expandDetail]=\"element === elementDetail ? 'expanded' : 'collapsed'\">\n            <table\n              mat-table\n              [dataSource]=\"dataSourceDetail\"\n              [ngClass]=\"{ 'hide-borders': element === tableData[tableData.length - 1] }\"\n            >\n              <ng-container *ngFor=\"let tableColumn of tableDetailColumns.columnDefs\"\n                            [matColumnDef]=\"tableColumn.title ?? ''\">\n                <th mat-header-cell *matHeaderCellDef=\"let element\" arrowPosition=\"after\"\n                    [ngStyle]=\"{width: tableColumn.styles?.width}\"\n                    [ngClass]=\"tableColumn.styles?.alignment ? 'th-'+tableColumn.styles?.alignment : ''\">\n                  {{ tableColumn.title | uppercase }}\n                </th>\n\n                <td mat-cell *matCellDef=\"let element\" (click)=\"onDetailRowClick(element)\"\n                    [align]=\"tableColumn.styles?.alignment\"\n                    [ngClass]=\"tableColumn.styles?.alignment ? 'td-'+tableColumn.styles?.alignment : ''\"\n                    [ngStyle]=\"{width: tableColumn.styles?.width }\">\n                  <ng-container *ngTemplateOutlet=\"tableDataTpl; context: {element, tableColumn}\"></ng-container>\n                </td>\n              </ng-container>\n\n              <tr mat-header-row *matHeaderRowDef=\"columnsDetailToDisplay\"></tr>\n              <tr mat-row *matRowDef=\"let rowDetail; columns: columnsDetailToDisplay;\"></tr>\n            </table>\n          </div>\n        </td>\n      </ng-container>\n\n      <ng-template #tableDataTpl let-element=\"element\" let-tableColumn=\"tableColumn\">\n        <div class=\"align-wrapper\">\n          <ng-container [ngSwitch]=\"tableColumn.type\">\n            <ng-container *ngSwitchCase=\"DataType.FIELD\">\n              {{ element | dataPropertyGetter: tableColumn.key }}\n            </ng-container>\n            <ng-container *ngSwitchCase=\"DataType.FUNCTION\">\n              {{ tableColumn.function?.(element) }}\n            </ng-container>\n            <ng-container *ngSwitchCase=\"DataType.RENDERER\">\n              <ng-template\n                [dynamicComponent]=\"[tableColumn.renderer, element] | memoizeFunc : callRenderer\">\n              </ng-template>\n            </ng-container>\n            <ng-container *ngSwitchDefault>\n              {{ element | dataPropertyGetter: tableColumn.key }}\n            </ng-container>\n          </ng-container>\n        </div>\n      </ng-template>\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"\n          [ngClass]=\"{'expanded-row': elementDetail === row, 'row-clickable': tableDetails, 'selected': row?.selected, 'last-row': row === tableData[tableData.length - 1] && !elementDetail }\"\n          (click)=\"toggleRow(row)\">\n      </tr>\n      <ng-container *ngIf=\"tableDetails && tableDetailColumns?.columnDefs?.length\">\n        <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"detail-row\"></tr>\n      </ng-container>\n\n      <ng-container *ngIf=\"tableConfig.noDataRowTpl\">\n        <tr *matNoDataRow>\n          <ng-container *ngTemplateOutlet=\"tableConfig.noDataRowTpl\"></ng-container>\n        </tr>\n      </ng-container>\n    </table>\n  </div>\n\n  <ui-paginator\n    *ngIf=\"!tableConfig?.hidePagination\"\n    [disabled]=\"loading\"\n    [applicationTheme]=\"applicationTheme !== 'classic' ? 'light' : 'classic'\"\n    [pageSize]=\"tableConfig.pagination.itemsPerPage\"\n    [length]=\"tableConfig.pagination.totalItems\"\n    [currentPage]=\"tableConfig.pagination.currentPage\"\n    [pageSizeOptions]=\"tableConfig.pagination.itemsPerPageOptions\"\n    (paginatorChange)=\"onPaginatorChange($event)\"\n  ></ui-paginator>\n</div>\n\n<ng-template #columnHeader let-column=\"column\" let-i=\"i\">\n  <div class=\"header-section\">\n                    <span uiEllipseText (onChangeTextState)=\"onChangeColumnSize(i, $event)\"\n                          class=\"column-title\">{{ column.title | sentencecase }}\n                 </span>\n    <ui-icon *ngIf=\"column?.showTooltip\" [name]=\"'Help-in-line'\"\n             [matTooltipClass]=\"applicationTheme\"\n             [matTooltip]=\"(column?.showTooltip ? (column?.tooltip ? column.tooltip : column.title ) : '') || ''\"\n    ></ui-icon>\n  </div>\n</ng-template>\n\n"]}
@@ -10,4 +10,4 @@ export var ColumnAlignment;
10
10
  ColumnAlignment["RIGHT"] = "right";
11
11
  ColumnAlignment["CENTER"] = "center";
12
12
  })(ColumnAlignment || (ColumnAlignment = {}));
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvdGFibGUvdGFibGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVBLE1BQU0sQ0FBTixJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDcEIsNkJBQWUsQ0FBQTtJQUNmLG1DQUFxQixDQUFBO0lBQ3JCLG1DQUFxQixDQUFBO0FBQ3ZCLENBQUMsRUFKVyxVQUFVLEtBQVYsVUFBVSxRQUlyQjtBQWVELE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsZ0NBQWEsQ0FBQTtJQUNiLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBSlcsZUFBZSxLQUFmLGVBQWUsUUFJMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wbGF0ZVJlZiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnPFQgPSBhbnk+IHtcbiAgY29sdW1uczogVGFibGVDb2x1bW48VD5bXTtcbiAgcGFnaW5hdGlvbj86IFBhZ2luYXRpb247XG4gIHRpdGxlPzogc3RyaW5nO1xuICB3aWR0aD86IG51bWJlcjtcbiAgc29ydD86IFNvcnQ7XG4gIGhpZGVQYWdpbmF0aW9uPzogYm9vbGVhbjtcbiAgbm9EYXRhUm93VHBsPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgc29ydGFibGU/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnV2l0aFBhZ2luYXRpb248VD4gZXh0ZW5kcyBUYWJsZUNvbmZpZzxUPiB7XG4gIHBhZ2luYXRpb246IFBhZ2luYXRpb247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDb2x1bW48VCA9IGFueT4ge1xuICB0aXRsZT86IHN0cmluZztcbiAga2V5OiBzdHJpbmc7XG4gIHdpZHRoUGVyYz86IG51bWJlcjtcbiAgbWluV2lkdGhQeD86IG51bWJlcjtcbiAgYWxsb3dNdWx0aWxpbmU/OiBib29sZWFuO1xuICBib2xkPzogYm9vbGVhbjtcbiAgc2hvd1Rvb2x0aXA/OiBib29sZWFuO1xuICB0b29sdGlwPzogc3RyaW5nO1xuICBhbGxvd1NvcnQ/OiBib29sZWFuO1xuICBpc1N0aWNreT86IGJvb2xlYW47XG4gIGhlYWRlckNlbGxUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG4gIHJvd0NlbGxUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XG4gIHJvd0NlbGxUZW1wbGF0ZUNsaWNrPzogKCkgPT4gYW55O1xuICBzb3J0SGVhZGVyPzogc3RyaW5nO1xuICBoaWRkZW4/OiBib29sZWFuO1xuICBvcmRlcj86IG51bWJlcjtcbiAgZm9udFNpemU/OiAnMTJweCcgfCAnMTRweCc7XG4gIGZpZWxkPzogc3RyaW5nO1xuICB0eXBlPzogQ29sdW1uVHlwZTtcbiAgZnVuY3Rpb24/OiAodjogVCkgPT4gc3RyaW5nO1xuICByZW5kZXJlcj86ICh2OiBUKSA9PiBDb21wb25lbnRSZW5kZXJlciB8IHN0cmluZztcbiAgc3R5bGVzPzogQ29sdW1uU3R5bGVzO1xuICBzb3J0U3RhcnQ/OiBTb3J0RGlyZWN0aW9uO1xuICB1bmlxdWVJZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uIHtcbiAgaXRlbXNQZXJQYWdlT3B0aW9uczogbnVtYmVyW107XG4gIGl0ZW1zUGVyUGFnZTogbnVtYmVyO1xuICBjdXJyZW50UGFnZTogbnVtYmVyO1xuICB0b3RhbEl0ZW1zOiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIFRhYmxlRGF0YSA9IFJlY29yZDxzdHJpbmcsIGFueT5bXTtcblxuZXhwb3J0IGludGVyZmFjZSBDb2x1bW5FbGxpcHNlIHtcbiAgaW5kZXg6IG51bWJlcjtcbiAgc2hvd1Rvb2x0aXA6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydCB7XG4gIGFjdGl2ZTogc3RyaW5nO1xuICBkaXJlY3Rpb246IFNvcnREaXJlY3Rpb247XG4gIGRlZmF1bHRTb3J0U3RhcnQ/OiBTb3J0RGlyZWN0aW9uO1xufVxuXG5leHBvcnQgdHlwZSBTb3J0RGlyZWN0aW9uID0gJ2FzYycgfCAnZGVzYycgfCAnJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZURldGFpbENvbHVtbjxULCBURGV0YWlsPiB7XG4gIGNvbHVtbkRlZnM6IFRhYmxlQ29sdW1uPFREZXRhaWw+W107XG4gIHNldERldGFpbFJvd0RhdGE6IChwYXJhbXM6IERldGFpbFJvd0RhdGFQYXJhbXM8VCwgVERldGFpbD4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGV0YWlsUm93RGF0YVBhcmFtczxULCBURGV0YWlsPiB7XG4gIGRhdGE6IFQ7XG5cbiAgc2V0RGV0YWlsRGF0YVNvdXJjZShyb3dEYXRhOiBURGV0YWlsW10pOiB2b2lkO1xufVxuXG5leHBvcnQgZW51bSBDb2x1bW5UeXBlIHtcbiAgRklFTEQgPSAnZmllbGQnLFxuICBGVU5DVElPTiA9ICdmdW5jdGlvbicsXG4gIFJFTkRFUkVSID0gJ3JlbmRlcmVyJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb21wb25lbnRSZW5kZXJlciB7XG4gIGNvbXBvbmVudDogVHlwZTxhbnk+O1xuICBpbnB1dHM/OiBhbnk7XG4gIG91dHB1dHM/OiB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbHVtblN0eWxlcyB7XG4gIGFsaWdubWVudD86IENvbHVtbkFsaWdubWVudDtcbiAgd2lkdGg/OiBzdHJpbmc7XG4gICdtaW4td2lkdGgnPzogc3RyaW5nO1xuICBwYWRkaW5nPzogc3RyaW5nO1xufVxuXG5leHBvcnQgZW51bSBDb2x1bW5BbGlnbm1lbnQge1xuICBMRUZUID0gJ2xlZnQnLFxuICBSSUdIVCA9ICdyaWdodCcsXG4gIENFTlRFUiA9ICdjZW50ZXInLFxufVxuXG5leHBvcnQgdHlwZSBEYXRhU291cmNlID0ge1xuICBba2V5OiBzdHJpbmddOiBhbnk7XG59O1xuXG5leHBvcnQgdHlwZSBTY3JvbGxTZXR0aW5ncyA9IHsgc2Nyb2xsRW5kOiBib29sZWFuLCBob3Jpem9udGFsU2Nyb2xsOiBib29sZWFuLCBzY3JvbGxTdGFydDogYm9vbGVhbiB9O1xuIl19
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Z28tY2Fub3B5LXVpL2NvbXBvbmVudHMvdGFibGUvdGFibGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkVBLE1BQU0sQ0FBTixJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDcEIsNkJBQWUsQ0FBQTtJQUNmLG1DQUFxQixDQUFBO0lBQ3JCLG1DQUFxQixDQUFBO0FBQ3ZCLENBQUMsRUFKVyxVQUFVLEtBQVYsVUFBVSxRQUlyQjtBQWVELE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsZ0NBQWEsQ0FBQTtJQUNiLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBSlcsZUFBZSxLQUFmLGVBQWUsUUFJMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wbGF0ZVJlZiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnPFQgPSBhbnk+IHtcbiAgY29sdW1uczogVGFibGVDb2x1bW48VD5bXTtcbiAgcGFnaW5hdGlvbj86IFBhZ2luYXRpb247XG4gIHRpdGxlPzogc3RyaW5nO1xuICB3aWR0aD86IG51bWJlcjtcbiAgc29ydD86IFNvcnQ7XG4gIGhpZGVQYWdpbmF0aW9uPzogYm9vbGVhbjtcbiAgbm9EYXRhUm93VHBsPzogVGVtcGxhdGVSZWY8YW55PjtcbiAgc29ydGFibGU/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnV2l0aFBhZ2luYXRpb248VD4gZXh0ZW5kcyBUYWJsZUNvbmZpZzxUPiB7XG4gIHBhZ2luYXRpb246IFBhZ2luYXRpb247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDb2x1bW48VCA9IGFueT4ge1xuICB0aXRsZT86IHN0cmluZztcbiAga2V5OiBzdHJpbmc7XG4gIGFsbG93TXVsdGlsaW5lPzogYm9vbGVhbjtcbiAgYm9sZD86IGJvb2xlYW47XG4gIHNob3dUb29sdGlwPzogYm9vbGVhbjtcbiAgdG9vbHRpcD86IHN0cmluZztcbiAgYWxsb3dTb3J0PzogYm9vbGVhbjtcbiAgaXNTdGlja3k/OiBib29sZWFuO1xuICBoZWFkZXJDZWxsVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xuICByb3dDZWxsVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+O1xuICByb3dDZWxsVGVtcGxhdGVDbGljaz86ICgpID0+IGFueTtcbiAgc29ydEhlYWRlcj86IHN0cmluZztcbiAgaGlkZGVuPzogYm9vbGVhbjtcbiAgb3JkZXI/OiBudW1iZXI7XG4gIGZvbnRTaXplPzogJzEycHgnIHwgJzE0cHgnO1xuICBmaWVsZD86IHN0cmluZztcbiAgdHlwZT86IENvbHVtblR5cGU7XG4gIGZ1bmN0aW9uPzogKHY6IFQpID0+IHN0cmluZztcbiAgcmVuZGVyZXI/OiAodjogVCkgPT4gQ29tcG9uZW50UmVuZGVyZXIgfCBzdHJpbmc7XG4gIHN0eWxlcz86IENvbHVtblN0eWxlcztcbiAgc29ydFN0YXJ0PzogU29ydERpcmVjdGlvbjtcbiAgdW5pcXVlSWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFnaW5hdGlvbiB7XG4gIGl0ZW1zUGVyUGFnZU9wdGlvbnM6IG51bWJlcltdO1xuICBpdGVtc1BlclBhZ2U6IG51bWJlcjtcbiAgY3VycmVudFBhZ2U6IG51bWJlcjtcbiAgdG90YWxJdGVtczogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBUYWJsZURhdGEgPSBSZWNvcmQ8c3RyaW5nLCBhbnk+W107XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sdW1uRWxsaXBzZSB7XG4gIGluZGV4OiBudW1iZXI7XG4gIHNob3dUb29sdGlwOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNvcnQge1xuICBhY3RpdmU6IHN0cmluZztcbiAgZGlyZWN0aW9uOiBTb3J0RGlyZWN0aW9uO1xuICBkZWZhdWx0U29ydFN0YXJ0PzogU29ydERpcmVjdGlvbjtcbn1cblxuZXhwb3J0IHR5cGUgU29ydERpcmVjdGlvbiA9ICdhc2MnIHwgJ2Rlc2MnIHwgJyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVEZXRhaWxDb2x1bW48VCwgVERldGFpbD4ge1xuICBjb2x1bW5EZWZzOiBUYWJsZUNvbHVtbjxURGV0YWlsPltdO1xuICBzZXREZXRhaWxSb3dEYXRhOiAocGFyYW1zOiBEZXRhaWxSb3dEYXRhUGFyYW1zPFQsIFREZXRhaWw+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERldGFpbFJvd0RhdGFQYXJhbXM8VCwgVERldGFpbD4ge1xuICBkYXRhOiBUO1xuXG4gIHNldERldGFpbERhdGFTb3VyY2Uocm93RGF0YTogVERldGFpbFtdKTogdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQ29sdW1uVHlwZSB7XG4gIEZJRUxEID0gJ2ZpZWxkJyxcbiAgRlVOQ1RJT04gPSAnZnVuY3Rpb24nLFxuICBSRU5ERVJFUiA9ICdyZW5kZXJlcicsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcG9uZW50UmVuZGVyZXIge1xuICBjb21wb25lbnQ6IFR5cGU8YW55PjtcbiAgaW5wdXRzPzogYW55O1xuICBvdXRwdXRzPzogeyBba2V5OiBzdHJpbmddOiBhbnkgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2x1bW5TdHlsZXMge1xuICBhbGlnbm1lbnQ/OiBDb2x1bW5BbGlnbm1lbnQ7XG4gIHdpZHRoPzogc3RyaW5nO1xuICAnbWluLXdpZHRoJz86IHN0cmluZztcbiAgcGFkZGluZz86IHN0cmluZztcbn1cblxuZXhwb3J0IGVudW0gQ29sdW1uQWxpZ25tZW50IHtcbiAgTEVGVCA9ICdsZWZ0JyxcbiAgUklHSFQgPSAncmlnaHQnLFxuICBDRU5URVIgPSAnY2VudGVyJyxcbn1cblxuZXhwb3J0IHR5cGUgRGF0YVNvdXJjZSA9IHtcbiAgW2tleTogc3RyaW5nXTogYW55O1xufTtcblxuZXhwb3J0IHR5cGUgU2Nyb2xsU2V0dGluZ3MgPSB7IHNjcm9sbEVuZDogYm9vbGVhbiwgaG9yaXpvbnRhbFNjcm9sbDogYm9vbGVhbiwgc2Nyb2xsU3RhcnQ6IGJvb2xlYW4gfTtcbiJdfQ==
@@ -82,7 +82,6 @@ import * as i2$b from 'ng2-charts';
82
82
  import { BaseChartDirective, NgChartsModule } from 'ng2-charts';
83
83
  import { Chart, registerables } from 'chart.js';
84
84
  import gaussian from 'gaussian';
85
- import { MemoizeFuncPipe as MemoizeFuncPipe$1 } from 'projects/tgo-canopy-ui/pipes/memoize-func.pipe';
86
85
 
87
86
  var BadgeColorEnum;
88
87
  (function (BadgeColorEnum) {
@@ -11884,14 +11883,12 @@ class TableComponent {
11884
11883
  ngOnChanges(changes) {
11885
11884
  if (changes['config'] && changes['config'].currentValue) {
11886
11885
  this.onSortChange(changes['config'].currentValue.sort);
11887
- }
11888
- else if (changes['data']?.currentValue) {
11889
- this.setTableData(changes['data'].currentValue);
11890
- }
11891
- else if (changes['config']?.currentValue) {
11892
11886
  const config = changes['config'].currentValue;
11893
11887
  this.setTableConfig(config);
11894
11888
  }
11889
+ if (changes['data']?.currentValue) {
11890
+ this.setTableData(changes['data'].currentValue);
11891
+ }
11895
11892
  }
11896
11893
  hasTableScroll() {
11897
11894
  const table = this.table.nativeElement;
@@ -15192,7 +15189,7 @@ class GaussianChartComponentModule {
15192
15189
  MatTooltipModule,
15193
15190
  CommonModule,
15194
15191
  IconComponentModule,
15195
- MemoizeFuncPipe$1], exports: [GaussianChartComponent] }); }
15192
+ MemoizeFuncPipe], exports: [GaussianChartComponent] }); }
15196
15193
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GaussianChartComponentModule, imports: [NgChartsModule,
15197
15194
  MatTooltipModule,
15198
15195
  CommonModule,
@@ -15210,7 +15207,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
15210
15207
  MatTooltipModule,
15211
15208
  CommonModule,
15212
15209
  IconComponentModule,
15213
- MemoizeFuncPipe$1,
15210
+ MemoizeFuncPipe,
15214
15211
  ],
15215
15212
  }]
15216
15213
  }] });