@leanix/components 0.4.495 → 0.4.497

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.
@@ -87,7 +87,7 @@ export class TableHeaderComponent {
87
87
  }
88
88
  }
89
89
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, deps: [{ token: i1.TableComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column", disableSort: "disableSort", disableSortClear: "disableSortClear" }, outputs: { sortChange: "sortChange" }, host: { attributes: { "role": "columnheader" }, listeners: { "keydown.enter": "onSort()", "click": "onSort()" }, properties: { "class.sortable": "sortable()", "tabIndex": "sortable() ? 0 : -1" } }, ngImport: i0, template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable span{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}ui5-icon{cursor:pointer}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "ui5-icon", inputs: ["design", "name", "accessibleName", "showTooltip", "mode"], exportAs: ["ui5Icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
90
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column", disableSort: "disableSort", disableSortClear: "disableSortClear" }, outputs: { sortChange: "sortChange" }, host: { attributes: { "role": "columnheader" }, listeners: { "keydown.enter": "onSort()", "click": "onSort()" }, properties: { "class.sortable": "sortable()", "tabIndex": "sortable() ? 0 : -1" } }, ngImport: i0, template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;vertical-align:middle;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "ui5-icon", inputs: ["design", "name", "accessibleName", "showTooltip", "mode"], exportAs: ["ui5Icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
91
91
  }
92
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, decorators: [{
93
93
  type: Component,
@@ -95,7 +95,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
95
95
  '[class.sortable]': 'sortable()',
96
96
  '[tabIndex]': 'sortable() ? 0 : -1',
97
97
  role: 'columnheader'
98
- }, imports: [IconComponent], template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable span{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}ui5-icon{cursor:pointer}\n"] }]
98
+ }, imports: [IconComponent], template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;vertical-align:middle;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}\n"] }]
99
99
  }], ctorParameters: () => [{ type: i1.TableComponent, decorators: [{
100
100
  type: Optional
101
101
  }] }], propDecorators: { column: [{
@@ -125,4 +125,4 @@ function determineNewOrder(currentOrder, disableSortClear) {
125
125
  }
126
126
  return undefined;
127
127
  }
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-header.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/src/lib/core-ui/components/table/table-header/table-header.component.ts","../../../../../../../../../libs/components/src/lib/core-ui/components/table/table-header/table-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Optional, Output, computed, signal } from '@angular/core';\nimport { OrderOption, SortingOptions } from '../../../pipes/sort.pipe';\n// eslint-disable-next-line no-restricted-imports\nimport { IconComponent } from '@ui5/webcomponents-ngx/main/icon';\n// eslint-disable-next-line no-restricted-imports\nimport { registerIcon } from '@ui5/webcomponents-base/dist/asset-registries/Icons.js';\nimport { TableComponent } from '../table.component';\n\nregisterIcon('sort', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#99A5BB\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#99A5BB\"/>'\n    ]\n  })\n});\nregisterIcon('sort-desc', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#99A5BB\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#2A303D\"/>'\n    ]\n  })\n});\nregisterIcon('sort-asc', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#2A303D\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#99A5BB\"/>'\n    ]\n  })\n});\n\n/**\n * The `lx-th` can be used in combination with `lx-table` to implement sortable `<table>` elements.\n */\n@Component({\n  selector: 'lx-th',\n  templateUrl: './table-header.component.html',\n  styleUrls: ['./table-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  host: {\n    '[class.sortable]': 'sortable()',\n    '[tabIndex]': 'sortable() ? 0 : -1',\n    role: 'columnheader'\n  },\n  imports: [IconComponent]\n})\nexport class TableHeaderComponent {\n  /**\n   * The technical column name.\n   */\n  @Input() column?: string;\n\n  /**\n   * Indicates that the column is not sortable (default `false`).\n   */\n  @Input() disableSort = false;\n\n  /**\n   * Prevents the user from clearing the sort.\n   * Only allowing to toggle between asc & desc.\n   */\n  @Input() disableSortClear = false;\n\n  /**\n   * Triggers whenever the user changes the sort order.\n   */\n  @Output() sortChange = new EventEmitter<SortingOptions>();\n\n  readonly sortable = computed(() => (this.parentTable?.isSortable() && !this.disableSort) ?? false);\n  readonly order = computed<OrderOption>(() => {\n    const sort = this.parentTable ? this.parentTable.sort() : this.#sort();\n    if (this.column !== sort?.key) {\n      return undefined;\n    } else {\n      return sort?.order;\n    }\n  });\n\n  readonly #sort = signal<SortingOptions>({ key: this.column, order: undefined });\n\n  constructor(@Optional() private parentTable?: TableComponent) {}\n\n  @HostListener('keydown.enter') @HostListener('click') onSort() {\n    if (this.column && !this.disableSort) {\n      const sort = { key: this.column, order: determineNewOrder(this.order(), this.disableSortClear) };\n      if (!this.parentTable) {\n        this.#sort.set(sort);\n      }\n      this.sortChange.emit(sort);\n      this.parentTable?.onTableHeaderSortChange(sort);\n    }\n  }\n}\n\nfunction determineNewOrder(currentOrder: OrderOption, disableSortClear: boolean): OrderOption {\n  if (!currentOrder) {\n    return 'ASC';\n  } else if (currentOrder === 'ASC') {\n    return 'DESC';\n  } else if (currentOrder === 'DESC') {\n    return disableSortClear ? 'ASC' : undefined;\n  }\n  return undefined;\n}\n","<div class=\"wrapper\">\n  <span>\n    <ng-content />\n  </span>\n  @if (sortable()) {\n    @if (!order()) {\n      <ui5-icon name=\"lx-icons/sort\" />\n    } @else if (order() === 'ASC') {\n      <ui5-icon name=\"lx-icons/sort-asc\" />\n    } @else if (order() === 'DESC') {\n      <ui5-icon name=\"lx-icons/sort-desc\" />\n    }\n  }\n</div>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-header.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/src/lib/core-ui/components/table/table-header/table-header.component.ts","../../../../../../../../../libs/components/src/lib/core-ui/components/table/table-header/table-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Optional, Output, computed, signal } from '@angular/core';\nimport { OrderOption, SortingOptions } from '../../../pipes/sort.pipe';\n// eslint-disable-next-line no-restricted-imports\nimport { IconComponent } from '@ui5/webcomponents-ngx/main/icon';\n// eslint-disable-next-line no-restricted-imports\nimport { registerIcon } from '@ui5/webcomponents-base/dist/asset-registries/Icons.js';\nimport { TableComponent } from '../table.component';\n\nregisterIcon('sort', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#99A5BB\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#99A5BB\"/>'\n    ]\n  })\n});\nregisterIcon('sort-desc', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#99A5BB\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#2A303D\"/>'\n    ]\n  })\n});\nregisterIcon('sort-asc', {\n  pathData: '',\n  ltr: false,\n  collection: 'lx-icons',\n  packageName: '@leanix/theming',\n  viewBox: '0 0 16 16',\n  customTemplate: () => ({\n    strings: [\n      '<path d=\"M8.00278 2C8.19778 2 8.37778 2.09 8.49028 2.2475L10.8903 5.5475C11.0253 5.7275 11.0403 5.975 10.9428 6.17C10.8378 6.3725 10.6353 6.5 10.4103 6.5L5.61028 6.5C5.38528 6.5 5.17528 6.3725 5.07778 6.17C4.97278 5.9675 4.99528 5.7275 5.13028 5.5475L7.53028 2.2475C7.64278 2.09 7.82278 2 8.01778 2H8.00278Z\" fill=\"#2A303D\"/>',\n      '<path d=\"M8.00278 14.455C7.80778 14.455 7.62778 14.365 7.51528 14.2075L5.11528 10.9075C4.98028 10.7275 4.96528 10.48 5.06278 10.285C5.16778 10.0825 5.37028 9.95496 5.59528 9.95496H10.3953C10.6203 9.95496 10.8303 10.0825 10.9278 10.285C11.0328 10.4875 11.0103 10.7275 10.8753 10.9075L8.47528 14.2075C8.36278 14.365 8.18278 14.455 7.98778 14.455H8.00278Z\" fill=\"#99A5BB\"/>'\n    ]\n  })\n});\n\n/**\n * The `lx-th` can be used in combination with `lx-table` to implement sortable `<table>` elements.\n */\n@Component({\n  selector: 'lx-th',\n  templateUrl: './table-header.component.html',\n  styleUrls: ['./table-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  host: {\n    '[class.sortable]': 'sortable()',\n    '[tabIndex]': 'sortable() ? 0 : -1',\n    role: 'columnheader'\n  },\n  imports: [IconComponent]\n})\nexport class TableHeaderComponent {\n  /**\n   * The technical column name.\n   */\n  @Input() column?: string;\n\n  /**\n   * Indicates that the column is not sortable (default `false`).\n   */\n  @Input() disableSort = false;\n\n  /**\n   * Prevents the user from clearing the sort.\n   * Only allowing to toggle between asc & desc.\n   */\n  @Input() disableSortClear = false;\n\n  /**\n   * Triggers whenever the user changes the sort order.\n   */\n  @Output() sortChange = new EventEmitter<SortingOptions>();\n\n  readonly sortable = computed(() => (this.parentTable?.isSortable() && !this.disableSort) ?? false);\n  readonly order = computed<OrderOption>(() => {\n    const sort = this.parentTable ? this.parentTable.sort() : this.#sort();\n    if (this.column !== sort?.key) {\n      return undefined;\n    } else {\n      return sort?.order;\n    }\n  });\n\n  readonly #sort = signal<SortingOptions>({ key: this.column, order: undefined });\n\n  constructor(@Optional() private parentTable?: TableComponent) {}\n\n  @HostListener('keydown.enter') @HostListener('click') onSort() {\n    if (this.column && !this.disableSort) {\n      const sort = { key: this.column, order: determineNewOrder(this.order(), this.disableSortClear) };\n      if (!this.parentTable) {\n        this.#sort.set(sort);\n      }\n      this.sortChange.emit(sort);\n      this.parentTable?.onTableHeaderSortChange(sort);\n    }\n  }\n}\n\nfunction determineNewOrder(currentOrder: OrderOption, disableSortClear: boolean): OrderOption {\n  if (!currentOrder) {\n    return 'ASC';\n  } else if (currentOrder === 'ASC') {\n    return 'DESC';\n  } else if (currentOrder === 'DESC') {\n    return disableSortClear ? 'ASC' : undefined;\n  }\n  return undefined;\n}\n","<div class=\"wrapper\">\n  <span>\n    <ng-content />\n  </span>\n  @if (sortable()) {\n    @if (!order()) {\n      <ui5-icon name=\"lx-icons/sort\" />\n    } @else if (order() === 'ASC') {\n      <ui5-icon name=\"lx-icons/sort-asc\" />\n    } @else if (order() === 'DESC') {\n      <ui5-icon name=\"lx-icons/sort-desc\" />\n    }\n  }\n</div>\n"]}
@@ -13,6 +13,8 @@ import * as i0 from "@angular/core";
13
13
  * import { TableComponent } from '@leanix/components';
14
14
  * ```
15
15
  *
16
+ * 2. Add the `lx-table` directive to your `<table>` element.
17
+ *
16
18
  * ```html
17
19
  * <table lx-table></table>
18
20
  * ```
@@ -22,13 +24,20 @@ import * as i0 from "@angular/core";
22
24
  * To provide sortability within a table, the `isSortable` input has to be set to `true`
23
25
  * and the columns that support sorting should be `<lx-th>` elements with a column name applied via the `column` input.
24
26
  *
27
+ * Sorting can be disabled for individual columns via the `disableSort` input.
28
+ *
25
29
  * By default the sort order of columns can be changed between unsorted, ascending, and descending (after descending back to unsorted).
26
30
  * To prevent the user from clearing the sort order and just allow toggling between ascending and descending the `disableSortClear` input can be set to `true`.
27
31
  *
32
+ * To handle sort changes, the `(sortChange)` output can be used to receive the new sort (`key` of the column and `order` - either `ASC`, `DESC`, or `undefined`).
33
+ *
34
+ * ### Example code
28
35
  * ```html
29
- * <table lx-table [isSortable]="true">
36
+ * <table lx-table [isSortable]="true" [(sort)]="sort" (sortChange)="...">
30
37
  * <thead>
31
- * <lx-th column="column1" [disableSortClear]="false">Column 1</lx-th>
38
+ * <lx-th column="column1" [disableSortClear]="false">Allows asc, desc & unsorted</lx-th>
39
+ * <lx-th column="column2" [disableSortClear]="true">Allows only asc & desc</lx-th>
40
+ * <lx-th column="column3" [disableSort]="true">Is not sortable</lx-th>
32
41
  * </thead>
33
42
  * </table>
34
43
  * ```
@@ -45,6 +54,9 @@ export class TableComponent {
45
54
  */
46
55
  this.sort = model({});
47
56
  }
57
+ /**
58
+ * @internal To be called from `lx-th` elements to set the sort state.
59
+ */
48
60
  onTableHeaderSortChange(sort) {
49
61
  this.sort.set(sort);
50
62
  }
@@ -62,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
62
74
  standalone: true
63
75
  }]
64
76
  }] });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3hEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWdDRztBQVNILGtFQUFrRTtBQUNsRSxNQUFNLE9BQU8sY0FBYztJQVQzQjtRQVVFOztXQUVHO1FBQ00sZUFBVSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNNLFNBQUksR0FBRyxLQUFLLENBQWlCLEVBQUUsQ0FBQyxDQUFDO0tBSzNDO0lBSEMsdUJBQXVCLENBQUMsSUFBb0I7UUFDMUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEIsQ0FBQzs4R0FiVSxjQUFjO2tHQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBVDFCLFNBQVM7bUJBQUM7b0JBQ1QsOERBQThEO29CQUM5RCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLG1CQUFtQjtxQkFDM0I7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCwgbW9kZWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNvcnRpbmdPcHRpb25zIH0gZnJvbSAnLi4vLi4vcGlwZXMvc29ydC5waXBlJztcblxuLyoqXG4gKiBUaGUgYGx4LXRhYmxlYCBkaXJlY3RpdmUgY2FuIGJlIGFwcGxpZWQgdG8gYDx0YWJsZT5gIGVsZW1lbnRzIHRvIHByb3ZpZGUgYSBjb21tb24gc3R5bGluZy5cbiAqIEZ1cnRoZXJtb3JlIGl0IHN1cHBvcnRzIGNvbHVtbiBzb3J0aW5nIGluIGNvbWJpbmF0aW9uIHdpdGggYDxseC10aD5gIGZvciB0YWJsZSBoZWFkZXJzLlxuICpcbiAqXG4gKiAjIyBVc2FnZVxuICpcbiAqIDEuIEltcG9ydCB0aGUgYFRhYmxlQ29tcG9uZW50YCBmcm9tIGBAbGVhbml4L2NvbXBvbmVudHNgIHdoZXJlIHlvdSB3YW50IHRvIHVzZSBpdC5cbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgVGFibGVDb21wb25lbnQgfSBmcm9tICdAbGVhbml4L2NvbXBvbmVudHMnO1xuICogYGBgXG4gKlxuICogYGBgaHRtbFxuICogPHRhYmxlIGx4LXRhYmxlPjwvdGFibGU+XG4gKiBgYGBcbiAqXG4gKiAjIyBTb3J0YWJpbGl0eVxuICpcbiAqIFRvIHByb3ZpZGUgc29ydGFiaWxpdHkgd2l0aGluIGEgdGFibGUsIHRoZSBgaXNTb3J0YWJsZWAgaW5wdXQgaGFzIHRvIGJlIHNldCB0byBgdHJ1ZWBcbiAqIGFuZCB0aGUgY29sdW1ucyB0aGF0IHN1cHBvcnQgc29ydGluZyBzaG91bGQgYmUgYDxseC10aD5gIGVsZW1lbnRzIHdpdGggYSBjb2x1bW4gbmFtZSBhcHBsaWVkIHZpYSB0aGUgYGNvbHVtbmAgaW5wdXQuXG4gKlxuICogQnkgZGVmYXVsdCB0aGUgc29ydCBvcmRlciBvZiBjb2x1bW5zIGNhbiBiZSBjaGFuZ2VkIGJldHdlZW4gdW5zb3J0ZWQsIGFzY2VuZGluZywgYW5kIGRlc2NlbmRpbmcgKGFmdGVyIGRlc2NlbmRpbmcgYmFjayB0byB1bnNvcnRlZCkuXG4gKiBUbyBwcmV2ZW50IHRoZSB1c2VyIGZyb20gY2xlYXJpbmcgdGhlIHNvcnQgb3JkZXIgYW5kIGp1c3QgYWxsb3cgdG9nZ2xpbmcgYmV0d2VlbiBhc2NlbmRpbmcgYW5kIGRlc2NlbmRpbmcgdGhlIGBkaXNhYmxlU29ydENsZWFyYCBpbnB1dCBjYW4gYmUgc2V0IHRvIGB0cnVlYC5cbiAqXG4gKiBgYGBodG1sXG4gKiA8dGFibGUgbHgtdGFibGUgW2lzU29ydGFibGVdPVwidHJ1ZVwiPlxuICogICA8dGhlYWQ+XG4gKiAgICAgPGx4LXRoIGNvbHVtbj1cImNvbHVtbjFcIiBbZGlzYWJsZVNvcnRDbGVhcl09XCJmYWxzZVwiPkNvbHVtbiAxPC9seC10aD5cbiAqICAgPC90aGVhZD5cbiAqIDwvdGFibGU+XG4gKiBgYGBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLXNlbGVjdG9yXG4gIHNlbGVjdG9yOiAndGFibGVbbHgtdGFibGVdJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAndGFibGUgdGFibGUtaG92ZXInXG4gIH0sXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2RpcmVjdGl2ZS1jbGFzcy1zdWZmaXhcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBUaGlzIGVuYWJsZXMgb3IgZGlzYWJsZXMgdGhlIHNvcnRhYmlsaXR5IG9mIHRoZSB0YWJsZS5cbiAgICovXG4gIHJlYWRvbmx5IGlzU29ydGFibGUgPSBpbnB1dChmYWxzZSk7XG5cbiAgLyoqXG4gICAqIFRoZSBzb3J0IHN0YXRlIG9mIHRoZSB0YWJsZS4gV2hpY2ggY29sdW1uIGlzIHNvcnRlZCBpbiB3aGF0IG9yZGVyLlxuICAgKi9cbiAgcmVhZG9ubHkgc29ydCA9IG1vZGVsPFNvcnRpbmdPcHRpb25zPih7fSk7XG5cbiAgb25UYWJsZUhlYWRlclNvcnRDaGFuZ2Uoc29ydDogU29ydGluZ09wdGlvbnMpIHtcbiAgICB0aGlzLnNvcnQuc2V0KHNvcnQpO1xuICB9XG59XG4iXX0=
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3hEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXlDRztBQVNILGtFQUFrRTtBQUNsRSxNQUFNLE9BQU8sY0FBYztJQVQzQjtRQVVFOztXQUVHO1FBQ00sZUFBVSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNNLFNBQUksR0FBRyxLQUFLLENBQWlCLEVBQUUsQ0FBQyxDQUFDO0tBUTNDO0lBTkM7O09BRUc7SUFDSCx1QkFBdUIsQ0FBQyxJQUFvQjtRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0QixDQUFDOzhHQWhCVSxjQUFjO2tHQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBVDFCLFNBQVM7bUJBQUM7b0JBQ1QsOERBQThEO29CQUM5RCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLG1CQUFtQjtxQkFDM0I7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCwgbW9kZWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNvcnRpbmdPcHRpb25zIH0gZnJvbSAnLi4vLi4vcGlwZXMvc29ydC5waXBlJztcblxuLyoqXG4gKiBUaGUgYGx4LXRhYmxlYCBkaXJlY3RpdmUgY2FuIGJlIGFwcGxpZWQgdG8gYDx0YWJsZT5gIGVsZW1lbnRzIHRvIHByb3ZpZGUgYSBjb21tb24gc3R5bGluZy5cbiAqIEZ1cnRoZXJtb3JlIGl0IHN1cHBvcnRzIGNvbHVtbiBzb3J0aW5nIGluIGNvbWJpbmF0aW9uIHdpdGggYDxseC10aD5gIGZvciB0YWJsZSBoZWFkZXJzLlxuICpcbiAqXG4gKiAjIyBVc2FnZVxuICpcbiAqIDEuIEltcG9ydCB0aGUgYFRhYmxlQ29tcG9uZW50YCBmcm9tIGBAbGVhbml4L2NvbXBvbmVudHNgIHdoZXJlIHlvdSB3YW50IHRvIHVzZSBpdC5cbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgVGFibGVDb21wb25lbnQgfSBmcm9tICdAbGVhbml4L2NvbXBvbmVudHMnO1xuICogYGBgXG4gKlxuICogMi4gQWRkIHRoZSBgbHgtdGFibGVgIGRpcmVjdGl2ZSB0byB5b3VyIGA8dGFibGU+YCBlbGVtZW50LlxuICpcbiAqIGBgYGh0bWxcbiAqIDx0YWJsZSBseC10YWJsZT48L3RhYmxlPlxuICogYGBgXG4gKlxuICogIyMgU29ydGFiaWxpdHlcbiAqXG4gKiBUbyBwcm92aWRlIHNvcnRhYmlsaXR5IHdpdGhpbiBhIHRhYmxlLCB0aGUgYGlzU29ydGFibGVgIGlucHV0IGhhcyB0byBiZSBzZXQgdG8gYHRydWVgXG4gKiBhbmQgdGhlIGNvbHVtbnMgdGhhdCBzdXBwb3J0IHNvcnRpbmcgc2hvdWxkIGJlIGA8bHgtdGg+YCBlbGVtZW50cyB3aXRoIGEgY29sdW1uIG5hbWUgYXBwbGllZCB2aWEgdGhlIGBjb2x1bW5gIGlucHV0LlxuICpcbiAqIFNvcnRpbmcgY2FuIGJlIGRpc2FibGVkIGZvciBpbmRpdmlkdWFsIGNvbHVtbnMgdmlhIHRoZSBgZGlzYWJsZVNvcnRgIGlucHV0LlxuICpcbiAqIEJ5IGRlZmF1bHQgdGhlIHNvcnQgb3JkZXIgb2YgY29sdW1ucyBjYW4gYmUgY2hhbmdlZCBiZXR3ZWVuIHVuc29ydGVkLCBhc2NlbmRpbmcsIGFuZCBkZXNjZW5kaW5nIChhZnRlciBkZXNjZW5kaW5nIGJhY2sgdG8gdW5zb3J0ZWQpLlxuICogVG8gcHJldmVudCB0aGUgdXNlciBmcm9tIGNsZWFyaW5nIHRoZSBzb3J0IG9yZGVyIGFuZCBqdXN0IGFsbG93IHRvZ2dsaW5nIGJldHdlZW4gYXNjZW5kaW5nIGFuZCBkZXNjZW5kaW5nIHRoZSBgZGlzYWJsZVNvcnRDbGVhcmAgaW5wdXQgY2FuIGJlIHNldCB0byBgdHJ1ZWAuXG4gKlxuICogVG8gaGFuZGxlIHNvcnQgY2hhbmdlcywgdGhlIGAoc29ydENoYW5nZSlgIG91dHB1dCBjYW4gYmUgdXNlZCB0byByZWNlaXZlIHRoZSBuZXcgc29ydCAoYGtleWAgb2YgdGhlIGNvbHVtbiBhbmQgYG9yZGVyYCAtIGVpdGhlciBgQVNDYCwgYERFU0NgLCBvciBgdW5kZWZpbmVkYCkuXG4gKlxuICogIyMjIEV4YW1wbGUgY29kZVxuICogYGBgaHRtbFxuICogPHRhYmxlIGx4LXRhYmxlIFtpc1NvcnRhYmxlXT1cInRydWVcIiBbKHNvcnQpXT1cInNvcnRcIiAoc29ydENoYW5nZSk9XCIuLi5cIj5cbiAqICAgPHRoZWFkPlxuICogICAgIDxseC10aCBjb2x1bW49XCJjb2x1bW4xXCIgW2Rpc2FibGVTb3J0Q2xlYXJdPVwiZmFsc2VcIj5BbGxvd3MgYXNjLCBkZXNjICYgdW5zb3J0ZWQ8L2x4LXRoPlxuICogICAgIDxseC10aCBjb2x1bW49XCJjb2x1bW4yXCIgW2Rpc2FibGVTb3J0Q2xlYXJdPVwidHJ1ZVwiPkFsbG93cyBvbmx5IGFzYyAmIGRlc2M8L2x4LXRoPlxuICogICAgIDxseC10aCBjb2x1bW49XCJjb2x1bW4zXCIgW2Rpc2FibGVTb3J0XT1cInRydWVcIj5JcyBub3Qgc29ydGFibGU8L2x4LXRoPlxuICogICA8L3RoZWFkPlxuICogPC90YWJsZT5cbiAqIGBgYFxuICovXG5ARGlyZWN0aXZlKHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9kaXJlY3RpdmUtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICd0YWJsZVtseC10YWJsZV0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICd0YWJsZSB0YWJsZS1ob3ZlcidcbiAgfSxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLWNsYXNzLXN1ZmZpeFxuZXhwb3J0IGNsYXNzIFRhYmxlQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoaXMgZW5hYmxlcyBvciBkaXNhYmxlcyB0aGUgc29ydGFiaWxpdHkgb2YgdGhlIHRhYmxlLlxuICAgKi9cbiAgcmVhZG9ubHkgaXNTb3J0YWJsZSA9IGlucHV0KGZhbHNlKTtcblxuICAvKipcbiAgICogVGhlIHNvcnQgc3RhdGUgb2YgdGhlIHRhYmxlLiBXaGljaCBjb2x1bW4gaXMgc29ydGVkIGluIHdoYXQgb3JkZXIuXG4gICAqL1xuICByZWFkb25seSBzb3J0ID0gbW9kZWw8U29ydGluZ09wdGlvbnM+KHt9KTtcblxuICAvKipcbiAgICogQGludGVybmFsIFRvIGJlIGNhbGxlZCBmcm9tIGBseC10aGAgZWxlbWVudHMgdG8gc2V0IHRoZSBzb3J0IHN0YXRlLlxuICAgKi9cbiAgb25UYWJsZUhlYWRlclNvcnRDaGFuZ2Uoc29ydDogU29ydGluZ09wdGlvbnMpIHtcbiAgICB0aGlzLnNvcnQuc2V0KHNvcnQpO1xuICB9XG59XG4iXX0=
@@ -1212,6 +1212,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
1212
1212
  * import { TableComponent } from '@leanix/components';
1213
1213
  * ```
1214
1214
  *
1215
+ * 2. Add the `lx-table` directive to your `<table>` element.
1216
+ *
1215
1217
  * ```html
1216
1218
  * <table lx-table></table>
1217
1219
  * ```
@@ -1221,13 +1223,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
1221
1223
  * To provide sortability within a table, the `isSortable` input has to be set to `true`
1222
1224
  * and the columns that support sorting should be `<lx-th>` elements with a column name applied via the `column` input.
1223
1225
  *
1226
+ * Sorting can be disabled for individual columns via the `disableSort` input.
1227
+ *
1224
1228
  * By default the sort order of columns can be changed between unsorted, ascending, and descending (after descending back to unsorted).
1225
1229
  * To prevent the user from clearing the sort order and just allow toggling between ascending and descending the `disableSortClear` input can be set to `true`.
1226
1230
  *
1231
+ * To handle sort changes, the `(sortChange)` output can be used to receive the new sort (`key` of the column and `order` - either `ASC`, `DESC`, or `undefined`).
1232
+ *
1233
+ * ### Example code
1227
1234
  * ```html
1228
- * <table lx-table [isSortable]="true">
1235
+ * <table lx-table [isSortable]="true" [(sort)]="sort" (sortChange)="...">
1229
1236
  * <thead>
1230
- * <lx-th column="column1" [disableSortClear]="false">Column 1</lx-th>
1237
+ * <lx-th column="column1" [disableSortClear]="false">Allows asc, desc & unsorted</lx-th>
1238
+ * <lx-th column="column2" [disableSortClear]="true">Allows only asc & desc</lx-th>
1239
+ * <lx-th column="column3" [disableSort]="true">Is not sortable</lx-th>
1231
1240
  * </thead>
1232
1241
  * </table>
1233
1242
  * ```
@@ -1244,6 +1253,9 @@ class TableComponent {
1244
1253
  */
1245
1254
  this.sort = model({});
1246
1255
  }
1256
+ /**
1257
+ * @internal To be called from `lx-th` elements to set the sort state.
1258
+ */
1247
1259
  onTableHeaderSortChange(sort) {
1248
1260
  this.sort.set(sort);
1249
1261
  }
@@ -1344,7 +1356,7 @@ class TableHeaderComponent {
1344
1356
  }
1345
1357
  }
1346
1358
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, deps: [{ token: TableComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
1347
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column", disableSort: "disableSort", disableSortClear: "disableSortClear" }, outputs: { sortChange: "sortChange" }, host: { attributes: { "role": "columnheader" }, listeners: { "keydown.enter": "onSort()", "click": "onSort()" }, properties: { "class.sortable": "sortable()", "tabIndex": "sortable() ? 0 : -1" } }, ngImport: i0, template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable span{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}ui5-icon{cursor:pointer}\n"], dependencies: [{ kind: "component", type: IconComponent$1, selector: "ui5-icon", inputs: ["design", "name", "accessibleName", "showTooltip", "mode"], exportAs: ["ui5Icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1359
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column", disableSort: "disableSort", disableSortClear: "disableSortClear" }, outputs: { sortChange: "sortChange" }, host: { attributes: { "role": "columnheader" }, listeners: { "keydown.enter": "onSort()", "click": "onSort()" }, properties: { "class.sortable": "sortable()", "tabIndex": "sortable() ? 0 : -1" } }, ngImport: i0, template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;vertical-align:middle;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}\n"], dependencies: [{ kind: "component", type: IconComponent$1, selector: "ui5-icon", inputs: ["design", "name", "accessibleName", "showTooltip", "mode"], exportAs: ["ui5Icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1348
1360
  }
1349
1361
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, decorators: [{
1350
1362
  type: Component,
@@ -1352,7 +1364,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
1352
1364
  '[class.sortable]': 'sortable()',
1353
1365
  '[tabIndex]': 'sortable() ? 0 : -1',
1354
1366
  role: 'columnheader'
1355
- }, imports: [IconComponent$1], template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable span{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}ui5-icon{cursor:pointer}\n"] }]
1367
+ }, imports: [IconComponent$1], template: "<div class=\"wrapper\">\n <span>\n <ng-content />\n </span>\n @if (sortable()) {\n @if (!order()) {\n <ui5-icon name=\"lx-icons/sort\" />\n } @else if (order() === 'ASC') {\n <ui5-icon name=\"lx-icons/sort-asc\" />\n } @else if (order() === 'DESC') {\n <ui5-icon name=\"lx-icons/sort-desc\" />\n }\n }\n</div>\n", styles: [":host{display:table-cell;line-height:normal;vertical-align:middle;padding:8px;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700;color:#526179}:host.sortable{cursor:pointer}.wrapper{display:flex;align-items:center;gap:4px}\n"] }]
1356
1368
  }], ctorParameters: () => [{ type: TableComponent, decorators: [{
1357
1369
  type: Optional
1358
1370
  }] }], propDecorators: { column: [{