@leanix/components 0.4.470 → 0.4.473
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.
- package/esm2022/lib/core-ui/components/spinner/spinner.component.mjs +4 -4
- package/esm2022/lib/core-ui/components/table/table-header/table-header.component.mjs +85 -33
- package/esm2022/lib/core-ui/components/table/table.component.mjs +13 -57
- package/esm2022/lib/core-ui/components/tokenizer/tokenizer.component.mjs +40 -1
- package/esm2022/lib/core-ui/core-ui.module.mjs +2 -1
- package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +4 -2
- package/esm2022/lib/forms-ui/components/picker/picker.component.mjs +4 -2
- package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +12 -1
- package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +24 -1
- package/fesm2022/leanix-components.mjs +184 -99
- package/fesm2022/leanix-components.mjs.map +1 -1
- package/lib/core-ui/components/spinner/spinner.component.d.ts +3 -3
- package/lib/core-ui/components/table/table-header/table-header.component.d.ts +8 -10
- package/lib/core-ui/components/table/table.component.d.ts +5 -13
- package/lib/core-ui/components/tokenizer/tokenizer.component.d.ts +39 -0
- package/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.d.ts +3 -1
- package/lib/forms-ui/components/picker/picker.component.d.ts +3 -1
- package/lib/forms-ui/components/single-select/single-select.component.d.ts +11 -0
- package/lib/tab-ui/components/tab-group/tab-group.component.d.ts +23 -0
- package/package.json +3 -2
@@ -2,10 +2,10 @@ import { Component, HostBinding, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
3
3
|
/**
|
4
4
|
* The following CSS classes should be used to style this component. The use of the inputs is deprecated.
|
5
|
-
* - fullSpace
|
6
|
-
* - fullSpaceFixed
|
5
|
+
* - `fullSpace`: Sets position to absolute with full height and width => fills ancestor with position set.
|
6
|
+
* - `fullSpaceFixed`: Sets position to fixed with full height and width => fills window
|
7
7
|
* (or ancestor with new rendering context, created, for example, with `transform: translate(0, 0)`
|
8
|
-
* - fadeBackground
|
8
|
+
* - `fadeBackground`: Sets background to 60% transparent white. TODO: Always use for fullSpace* classes and remove.
|
9
9
|
*/
|
10
10
|
export class SpinnerComponent {
|
11
11
|
constructor() {
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
23
23
|
}, {
|
24
24
|
type: Input
|
25
25
|
}] } });
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL2NvbXBvbmVudHMvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUU5RDs7Ozs7O0dBTUc7QUFPSCxNQUFNLE9BQU8sZ0JBQWdCO0lBTjdCO1FBT2dFLG1CQUFjLEdBQVksS0FBSyxDQUFDO0tBQy9GOzhHQUZZLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLHNNQ2Y3Qiw2V0FjQTs7MkZEQ2EsZ0JBQWdCO2tCQU41QixTQUFTOytCQUNFLFlBQVksY0FHVixJQUFJOzhCQUc4QyxjQUFjO3NCQUEzRSxXQUFXO3VCQUFDLCtCQUErQjs7c0JBQUcsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogVGhlIGZvbGxvd2luZyBDU1MgY2xhc3NlcyBzaG91bGQgYmUgdXNlZCB0byBzdHlsZSB0aGlzIGNvbXBvbmVudC4gVGhlIHVzZSBvZiB0aGUgaW5wdXRzIGlzIGRlcHJlY2F0ZWQuXG4gKiAtIGBmdWxsU3BhY2VgOiBTZXRzIHBvc2l0aW9uIHRvIGFic29sdXRlIHdpdGggZnVsbCBoZWlnaHQgYW5kIHdpZHRoID0+IGZpbGxzIGFuY2VzdG9yIHdpdGggcG9zaXRpb24gc2V0LlxuICogLSBgZnVsbFNwYWNlRml4ZWRgOiBTZXRzIHBvc2l0aW9uIHRvIGZpeGVkIHdpdGggZnVsbCBoZWlnaHQgYW5kIHdpZHRoID0+IGZpbGxzIHdpbmRvd1xuICogICAob3IgYW5jZXN0b3Igd2l0aCBuZXcgcmVuZGVyaW5nIGNvbnRleHQsIGNyZWF0ZWQsIGZvciBleGFtcGxlLCB3aXRoIGB0cmFuc2Zvcm06IHRyYW5zbGF0ZSgwLCAwKWBcbiAqIC0gYGZhZGVCYWNrZ3JvdW5kYDogU2V0cyBiYWNrZ3JvdW5kIHRvIDYwJSB0cmFuc3BhcmVudCB3aGl0ZS4gVE9ETzogQWx3YXlzIHVzZSBmb3IgZnVsbFNwYWNlKiBjbGFzc2VzIGFuZCByZW1vdmUuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LXNwaW5uZXInLFxuICB0ZW1wbGF0ZVVybDogJ3NwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnc3Bpbm5lci5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFNwaW5uZXJDb21wb25lbnQge1xuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmZhZGVCYWNrZ3JvdW5kRnJvbUlucHV0JykgQElucHV0KCkgcHVibGljIGZhZGVCYWNrZ3JvdW5kOiBib29sZWFuID0gZmFsc2U7XG59XG4iLCI8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCI+XG4gIDxkaXYgY2xhc3M9XCJtaWRkbGVcIj5cbiAgICA8ZGl2IGNsYXNzPVwiY2VudGVyXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVjdDFcIj48L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cInJlY3QyXCI+PC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJyZWN0M1wiPjwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVjdDRcIj48L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cInJlY3Q1XCI+PC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
@@ -1,50 +1,92 @@
|
|
1
|
-
import {
|
2
|
-
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Optional, Output, computed, signal } from '@angular/core';
|
2
|
+
// eslint-disable-next-line no-restricted-imports
|
3
|
+
import { IconComponent } from '@ui5/webcomponents-ngx/main/icon';
|
4
|
+
// eslint-disable-next-line no-restricted-imports
|
5
|
+
import { registerIcon } from '@ui5/webcomponents-base/dist/asset-registries/Icons.js';
|
3
6
|
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../table.component";
|
8
|
+
registerIcon('sort', {
|
9
|
+
pathData: '',
|
10
|
+
ltr: false,
|
11
|
+
collection: 'lx-icons',
|
12
|
+
packageName: '@leanix/theming',
|
13
|
+
viewBox: '0 0 16 16',
|
14
|
+
customTemplate: () => ({
|
15
|
+
strings: [
|
16
|
+
'<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"/>',
|
17
|
+
'<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"/>'
|
18
|
+
]
|
19
|
+
})
|
20
|
+
});
|
21
|
+
registerIcon('sort-desc', {
|
22
|
+
pathData: '',
|
23
|
+
ltr: false,
|
24
|
+
collection: 'lx-icons',
|
25
|
+
packageName: '@leanix/theming',
|
26
|
+
viewBox: '0 0 16 16',
|
27
|
+
customTemplate: () => ({
|
28
|
+
strings: [
|
29
|
+
'<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"/>',
|
30
|
+
'<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"/>'
|
31
|
+
]
|
32
|
+
})
|
33
|
+
});
|
34
|
+
registerIcon('sort-asc', {
|
35
|
+
pathData: '',
|
36
|
+
ltr: false,
|
37
|
+
collection: 'lx-icons',
|
38
|
+
packageName: '@leanix/theming',
|
39
|
+
viewBox: '0 0 16 16',
|
40
|
+
customTemplate: () => ({
|
41
|
+
strings: [
|
42
|
+
'<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"/>',
|
43
|
+
'<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"/>'
|
44
|
+
]
|
45
|
+
})
|
46
|
+
});
|
4
47
|
export class TableHeaderComponent {
|
5
|
-
|
6
|
-
|
7
|
-
this.
|
48
|
+
#sort;
|
49
|
+
constructor(parentTable) {
|
50
|
+
this.parentTable = parentTable;
|
8
51
|
this.sortChange = new EventEmitter();
|
9
|
-
this.sortable = false;
|
52
|
+
this.sortable = computed(() => this.parentTable?.isSortable() ?? false);
|
53
|
+
this.order = computed(() => {
|
54
|
+
const sort = this.parentTable ? this.parentTable.sort() : this.#sort();
|
55
|
+
if (this.column !== sort?.key) {
|
56
|
+
return undefined;
|
57
|
+
}
|
58
|
+
else {
|
59
|
+
return sort?.order;
|
60
|
+
}
|
61
|
+
});
|
62
|
+
this.#sort = signal({ key: this.column, order: undefined });
|
10
63
|
}
|
11
64
|
onSort() {
|
12
65
|
if (this.column) {
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
else if (this.order === 'ASC') {
|
17
|
-
this.order = 'DESC';
|
18
|
-
}
|
19
|
-
else {
|
20
|
-
this.order = undefined;
|
66
|
+
const sort = { key: this.column, order: determineNewOrder(this.order()) };
|
67
|
+
if (!this.parentTable) {
|
68
|
+
this.#sort.set(sort);
|
21
69
|
}
|
22
|
-
this.sortChange.emit(
|
70
|
+
this.sortChange.emit(sort);
|
71
|
+
this.parentTable?.onTableHeaderSortChange(sort);
|
23
72
|
}
|
24
73
|
}
|
25
|
-
|
26
|
-
|
27
|
-
this.changeDetection.markForCheck();
|
28
|
-
}
|
29
|
-
get order() {
|
30
|
-
return this._order;
|
31
|
-
}
|
32
|
-
set isTabable(tabable) {
|
33
|
-
this.elmentRef.nativeElement.tabIndex = tabable ? 0 : -1;
|
34
|
-
}
|
35
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
36
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column" }, outputs: { sortChange: "sortChange" }, host: { listeners: { "keydown.enter": "onSort()", "click": "onSort()" }, properties: { "class.sortable": "this.sortable" } }, ngImport: i0, template: "<span>\n <ng-content />\n</span>\n<i\n class=\"fas\"\n [class.fa-sort]=\"!order\"\n [class.inactive]=\"!order\"\n [class.fa-sort-up]=\"order === 'ASC'\"\n [class.fa-sort-down]=\"order === 'DESC'\"\n *ngIf=\"sortable\"\n></i>\n", styles: [":host{display:table-cell;padding:8px;vertical-align:bottom;border-bottom:2px solid #e1e5eb;border-top:none;font-weight:700}:host.sortable span{cursor:pointer}i{margin-left:4px;cursor:pointer}.inactive{color:#e1e5eb}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
74
|
+
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 }); }
|
75
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: TableHeaderComponent, isStandalone: true, selector: "lx-th", inputs: { column: "column" }, 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 }); }
|
37
76
|
}
|
38
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableHeaderComponent, decorators: [{
|
39
78
|
type: Component,
|
40
|
-
args: [{ selector: 'lx-th', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true,
|
41
|
-
|
79
|
+
args: [{ selector: 'lx-th', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, host: {
|
80
|
+
'[class.sortable]': 'sortable()',
|
81
|
+
'[tabIndex]': 'sortable() ? 0 : -1',
|
82
|
+
role: 'columnheader'
|
83
|
+
}, 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"] }]
|
84
|
+
}], ctorParameters: () => [{ type: i1.TableComponent, decorators: [{
|
85
|
+
type: Optional
|
86
|
+
}] }], propDecorators: { column: [{
|
42
87
|
type: Input
|
43
88
|
}], sortChange: [{
|
44
89
|
type: Output
|
45
|
-
}], sortable: [{
|
46
|
-
type: HostBinding,
|
47
|
-
args: ['class.sortable']
|
48
90
|
}], onSort: [{
|
49
91
|
type: HostListener,
|
50
92
|
args: ['keydown.enter']
|
@@ -52,4 +94,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
52
94
|
type: HostListener,
|
53
95
|
args: ['click']
|
54
96
|
}] } });
|
55
|
-
|
97
|
+
function determineNewOrder(currentOrder) {
|
98
|
+
let newOrder = undefined;
|
99
|
+
if (!currentOrder) {
|
100
|
+
newOrder = 'ASC';
|
101
|
+
}
|
102
|
+
else if (currentOrder === 'ASC') {
|
103
|
+
newOrder = 'DESC';
|
104
|
+
}
|
105
|
+
return newOrder;
|
106
|
+
}
|
107
|
+
//# 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@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  @Input() column?: string;\n\n  @Output() sortChange = new EventEmitter<SortingOptions>();\n\n  sortable = computed(() => this.parentTable?.isSortable() ?? false);\n  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  #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) {\n      const sort = { key: this.column, order: determineNewOrder(this.order()) };\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) {\n  let newOrder: OrderOption = undefined;\n  if (!currentOrder) {\n    newOrder = 'ASC';\n  } else if (currentOrder === 'ASC') {\n    newOrder = 'DESC';\n  }\n  return newOrder;\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"]}
|
@@ -1,70 +1,26 @@
|
|
1
|
-
import {
|
2
|
-
import { merge } from 'rxjs';
|
3
|
-
import { TableHeaderComponent } from './table-header/table-header.component';
|
1
|
+
import { Directive, input, model } from '@angular/core';
|
4
2
|
import * as i0 from "@angular/core";
|
5
3
|
// eslint-disable-next-line @angular-eslint/directive-class-suffix
|
6
4
|
export class TableComponent {
|
7
|
-
constructor(
|
8
|
-
this.
|
9
|
-
this.
|
10
|
-
this.sortChange = new EventEmitter();
|
11
|
-
this.elementRef.nativeElement.classList.add('table', 'table-hover');
|
5
|
+
constructor() {
|
6
|
+
this.isSortable = input(false);
|
7
|
+
this.sort = model({});
|
12
8
|
}
|
13
|
-
|
14
|
-
|
15
|
-
this.tableHeaders.forEach((header) => {
|
16
|
-
this.setSortValueOnHeader(header);
|
17
|
-
});
|
18
|
-
}
|
19
|
-
if (changes['isSortable'] && this.tableHeaders) {
|
20
|
-
this.tableHeaders.forEach((header) => {
|
21
|
-
header.sortable = this.isSortable;
|
22
|
-
header.isTabable = this.isSortable;
|
23
|
-
});
|
24
|
-
}
|
9
|
+
onTableHeaderSortChange(sort) {
|
10
|
+
this.sort.set(sort);
|
25
11
|
}
|
26
|
-
|
27
|
-
|
28
|
-
header.sortable = this.isSortable;
|
29
|
-
header.isTabable = this.isSortable;
|
30
|
-
if (this.sort) {
|
31
|
-
this.setSortValueOnHeader(header);
|
32
|
-
}
|
33
|
-
});
|
34
|
-
const sortChange$ = merge(...this.tableHeaders.map((header) => header.sortChange.asObservable()));
|
35
|
-
sortChange$.subscribe((change) => {
|
36
|
-
this.tableHeaders.forEach((header) => {
|
37
|
-
this.setSortValueOnHeader(header);
|
38
|
-
});
|
39
|
-
this.sortChange.emit(change);
|
40
|
-
});
|
41
|
-
}
|
42
|
-
setSortValueOnHeader(header) {
|
43
|
-
if (header.column !== this.sort?.key) {
|
44
|
-
header.order = undefined;
|
45
|
-
}
|
46
|
-
else {
|
47
|
-
header.order = this.sort?.order;
|
48
|
-
}
|
49
|
-
}
|
50
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
51
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: TableComponent, isStandalone: true, selector: "table[lx-table]", inputs: { isSortable: "isSortable", sort: "sort" }, outputs: { sortChange: "sortChange" }, queries: [{ propertyName: "tableHeaders", predicate: TableHeaderComponent, descendants: true }], usesOnChanges: true, ngImport: i0 }); }
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
13
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.8", type: TableComponent, isStandalone: true, selector: "table[lx-table]", inputs: { isSortable: { classPropertyName: "isSortable", publicName: "isSortable", isSignal: true, isRequired: false, transformFunction: null }, sort: { classPropertyName: "sort", publicName: "sort", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { sort: "sortChange" }, host: { classAttribute: "table table-hover" }, ngImport: i0 }); }
|
52
14
|
}
|
53
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TableComponent, decorators: [{
|
54
16
|
type: Directive,
|
55
17
|
args: [{
|
56
18
|
// eslint-disable-next-line @angular-eslint/directive-selector
|
57
19
|
selector: 'table[lx-table]',
|
20
|
+
host: {
|
21
|
+
class: 'table table-hover'
|
22
|
+
},
|
58
23
|
standalone: true
|
59
24
|
}]
|
60
|
-
}]
|
61
|
-
|
62
|
-
}], sort: [{
|
63
|
-
type: Input
|
64
|
-
}], sortChange: [{
|
65
|
-
type: Output
|
66
|
-
}], tableHeaders: [{
|
67
|
-
type: ContentChildren,
|
68
|
-
args: [TableHeaderComponent, { descendants: true }]
|
69
|
-
}] } });
|
70
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsZUFBZSxFQUNmLFNBQVMsRUFFVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFHUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDOztBQU83RSxrRUFBa0U7QUFDbEUsTUFBTSxPQUFPLGNBQWM7SUFPekIsWUFBb0IsVUFBd0M7UUFBeEMsZUFBVSxHQUFWLFVBQVUsQ0FBOEI7UUFObkQsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUVsQixlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWtCLENBQUM7UUFLeEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDdEUsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDekMsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtnQkFDbkMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUVELElBQUksT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO2dCQUNuQyxNQUFNLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7Z0JBQ2xDLE1BQU0sQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUNyQyxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDbkMsTUFBTSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1lBQ2xDLE1BQU0sQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUVuQyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDZCxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDcEMsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRWxHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUMvQixJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO2dCQUNuQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDLENBQUM7WUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyxvQkFBb0IsQ0FBQyxNQUE0QjtRQUN2RCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQztZQUNyQyxNQUFNLENBQUMsS0FBSyxHQUFHLFNBQVMsQ0FBQztRQUMzQixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7OEdBcERVLGNBQWM7a0dBQWQsY0FBYyxtTUFLUixvQkFBb0I7OzJGQUwxQixjQUFjO2tCQU4xQixTQUFTO21CQUFDO29CQUNULDhEQUE4RDtvQkFDOUQsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOytFQUdVLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNJLFVBQVU7c0JBQW5CLE1BQU07Z0JBRXVELFlBQVk7c0JBQXpFLGVBQWU7dUJBQUMsb0JBQW9CLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgQ29udGVudENoaWxkcmVuLFxuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT3V0cHV0LFxuICBRdWVyeUxpc3QsXG4gIFNpbXBsZUNoYW5nZXNcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBtZXJnZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgU29ydGluZ09wdGlvbnMgfSBmcm9tICcuLi8uLi9waXBlcy9zb3J0LnBpcGUnO1xuaW1wb3J0IHsgVGFibGVIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlLWhlYWRlci90YWJsZS1oZWFkZXIuY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLXNlbGVjdG9yXG4gIHNlbGVjdG9yOiAndGFibGVbbHgtdGFibGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLWNsYXNzLXN1ZmZpeFxuZXhwb3J0IGNsYXNzIFRhYmxlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgaXNTb3J0YWJsZSA9IGZhbHNlO1xuICBASW5wdXQoKSBzb3J0PzogU29ydGluZ09wdGlvbnM7XG4gIEBPdXRwdXQoKSBzb3J0Q2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxTb3J0aW5nT3B0aW9ucz4oKTtcblxuICBAQ29udGVudENoaWxkcmVuKFRhYmxlSGVhZGVyQ29tcG9uZW50LCB7IGRlc2NlbmRhbnRzOiB0cnVlIH0pIHRhYmxlSGVhZGVycyE6IFF1ZXJ5TGlzdDxUYWJsZUhlYWRlckNvbXBvbmVudD47XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxUYWJsZUVsZW1lbnQ+KSB7XG4gICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgndGFibGUnLCAndGFibGUtaG92ZXInKTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1snc29ydCddICYmIHRoaXMudGFibGVIZWFkZXJzKSB7XG4gICAgICB0aGlzLnRhYmxlSGVhZGVycy5mb3JFYWNoKChoZWFkZXIpID0+IHtcbiAgICAgICAgdGhpcy5zZXRTb3J0VmFsdWVPbkhlYWRlcihoZWFkZXIpO1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgaWYgKGNoYW5nZXNbJ2lzU29ydGFibGUnXSAmJiB0aGlzLnRhYmxlSGVhZGVycykge1xuICAgICAgdGhpcy50YWJsZUhlYWRlcnMuZm9yRWFjaCgoaGVhZGVyKSA9PiB7XG4gICAgICAgIGhlYWRlci5zb3J0YWJsZSA9IHRoaXMuaXNTb3J0YWJsZTtcbiAgICAgICAgaGVhZGVyLmlzVGFiYWJsZSA9IHRoaXMuaXNTb3J0YWJsZTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYmxlSGVhZGVycy5mb3JFYWNoKChoZWFkZXIpID0+IHtcbiAgICAgIGhlYWRlci5zb3J0YWJsZSA9IHRoaXMuaXNTb3J0YWJsZTtcbiAgICAgIGhlYWRlci5pc1RhYmFibGUgPSB0aGlzLmlzU29ydGFibGU7XG5cbiAgICAgIGlmICh0aGlzLnNvcnQpIHtcbiAgICAgICAgdGhpcy5zZXRTb3J0VmFsdWVPbkhlYWRlcihoZWFkZXIpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgY29uc3Qgc29ydENoYW5nZSQgPSBtZXJnZSguLi50aGlzLnRhYmxlSGVhZGVycy5tYXAoKGhlYWRlcikgPT4gaGVhZGVyLnNvcnRDaGFuZ2UuYXNPYnNlcnZhYmxlKCkpKTtcblxuICAgIHNvcnRDaGFuZ2UkLnN1YnNjcmliZSgoY2hhbmdlKSA9PiB7XG4gICAgICB0aGlzLnRhYmxlSGVhZGVycy5mb3JFYWNoKChoZWFkZXIpID0+IHtcbiAgICAgICAgdGhpcy5zZXRTb3J0VmFsdWVPbkhlYWRlcihoZWFkZXIpO1xuICAgICAgfSk7XG4gICAgICB0aGlzLnNvcnRDaGFuZ2UuZW1pdChjaGFuZ2UpO1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBzZXRTb3J0VmFsdWVPbkhlYWRlcihoZWFkZXI6IFRhYmxlSGVhZGVyQ29tcG9uZW50KSB7XG4gICAgaWYgKGhlYWRlci5jb2x1bW4gIT09IHRoaXMuc29ydD8ua2V5KSB7XG4gICAgICBoZWFkZXIub3JkZXIgPSB1bmRlZmluZWQ7XG4gICAgfSBlbHNlIHtcbiAgICAgIGhlYWRlci5vcmRlciA9IHRoaXMuc29ydD8ub3JkZXI7XG4gICAgfVxuICB9XG59XG4iXX0=
|
25
|
+
}] });
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBV3hELGtFQUFrRTtBQUNsRSxNQUFNLE9BQU8sY0FBYztJQVQzQjtRQVVFLGVBQVUsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUIsU0FBSSxHQUFHLEtBQUssQ0FBaUIsRUFBRSxDQUFDLENBQUM7S0FLbEM7SUFIQyx1QkFBdUIsQ0FBQyxJQUFvQjtRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0QixDQUFDOzhHQU5VLGNBQWM7a0dBQWQsY0FBYzs7MkZBQWQsY0FBYztrQkFUMUIsU0FBUzttQkFBQztvQkFDVCw4REFBOEQ7b0JBQzlELFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsbUJBQW1CO3FCQUMzQjtvQkFDRCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBtb2RlbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU29ydGluZ09wdGlvbnMgfSBmcm9tICcuLi8uLi9waXBlcy9zb3J0LnBpcGUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9kaXJlY3RpdmUtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICd0YWJsZVtseC10YWJsZV0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICd0YWJsZSB0YWJsZS1ob3ZlcidcbiAgfSxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLWNsYXNzLXN1ZmZpeFxuZXhwb3J0IGNsYXNzIFRhYmxlQ29tcG9uZW50IHtcbiAgaXNTb3J0YWJsZSA9IGlucHV0KGZhbHNlKTtcbiAgc29ydCA9IG1vZGVsPFNvcnRpbmdPcHRpb25zPih7fSk7XG5cbiAgb25UYWJsZUhlYWRlclNvcnRDaGFuZ2Uoc29ydDogU29ydGluZ09wdGlvbnMpIHtcbiAgICB0aGlzLnNvcnQuc2V0KHNvcnQpO1xuICB9XG59XG4iXX0=
|
@@ -10,6 +10,45 @@ import { TokenComponent } from './token/token.component';
|
|
10
10
|
import * as i0 from "@angular/core";
|
11
11
|
import * as i1 from "../../services/resize-observer.service";
|
12
12
|
import * as i2 from "@ngx-translate/core";
|
13
|
+
/**
|
14
|
+
* The tokenizer component (`lx-tokenizer`) is responsible for rendering a list of items into a container and hiding those that do not fit behind a placeholder. The items are represented as `lx-token`. Each `lx-token` allows to project any content into it, so anything can become a token. The tokenizer calculates how many items fit into the container (based on width), hiding those items that are overflowing and showing a overflow placeholder instead (e.g. "+4").
|
15
|
+
*
|
16
|
+
* ## Usage
|
17
|
+
*
|
18
|
+
* 1. Import `TokenizerComponent` & `TokenComponent` into your module or component.
|
19
|
+
* 2. Use the component in your template. All items should be wrapped in a `lx-token` element for the tokenizer to identify the individual tokens.
|
20
|
+
*
|
21
|
+
* ```ts
|
22
|
+
* import { TokenizerComponent } from '@leanix/components';
|
23
|
+
*
|
24
|
+
* @Component({
|
25
|
+
* selector: 'lx-my-component',
|
26
|
+
* standalone: true,
|
27
|
+
* imports: [TokenizerComponent, TokenComponent],
|
28
|
+
* template: `
|
29
|
+
* <lx-tokenizer>
|
30
|
+
* <lx-token>Token One</lx-token>
|
31
|
+
* <lx-token>Token Two</lx-token>
|
32
|
+
* </lx-tokenizer>
|
33
|
+
* `
|
34
|
+
* })
|
35
|
+
* export class MyComponent {}
|
36
|
+
* ```
|
37
|
+
*
|
38
|
+
* ## API
|
39
|
+
*
|
40
|
+
* ### Inputs
|
41
|
+
*
|
42
|
+
* - `active`: Can be used to activate & deactivate tokenization
|
43
|
+
*
|
44
|
+
* ### Outputs
|
45
|
+
*
|
46
|
+
* - `overflowPlaceholderClick`: Fires when the user clicks on the overflow placeholder
|
47
|
+
*
|
48
|
+
* ### Content projection
|
49
|
+
*
|
50
|
+
* - `lx-token`: All `lx-tokens` will be projected into the tokenizer
|
51
|
+
*/
|
13
52
|
export class TokenizerComponent {
|
14
53
|
constructor(elementRef, destroyRef, changeDetectorRef, resizeObserverService) {
|
15
54
|
this.elementRef = elementRef;
|
@@ -104,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
104
143
|
type: ViewChild,
|
105
144
|
args: ['tokensContainer', { read: ElementRef }]
|
106
145
|
}] } });
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenizer.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  ContentChildren,\n  DestroyRef,\n  effect,\n  ElementRef,\n  EventEmitter,\n  input,\n  Output,\n  QueryList,\n  signal,\n  ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { combineLatest } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, map, startWith } from 'rxjs/operators';\nimport { ButtonComponent } from '../../components/button/button.component';\nimport { CounterComponent } from '../../components/counter/counter.component';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { TokenComponent } from './token/token.component';\n\n@Component({\n  selector: 'lx-tokenizer',\n  standalone: true,\n  templateUrl: './tokenizer.component.html',\n  styleUrls: ['./tokenizer.component.scss'],\n  imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenizerComponent implements AfterContentInit {\n  readonly NAME = 'TokenizerComponent';\n\n  protected overflowItems = signal<TokenComponent[]>([]);\n  protected overflowItemCount = computed(() => this.overflowItems().length);\n  protected showCounter = computed(() => this.active() && this.overflowItemCount() > 0);\n\n  active = input(true);\n  private active$ = toObservable(this.active);\n  private overflowStartIndex = signal<number | null>(null);\n\n  /**\n   * Emitted when the counter button is clicked\n   * @param startIndex The index of the first overflowing element\n   * @param counterElement The counter button element\n   */\n  @Output() overflowPlaceholderClick = new EventEmitter<{ startIndex: number; counterElement: ElementRef<HTMLElement> }>();\n\n  @ContentChildren(TokenComponent) items?: QueryList<TokenComponent>;\n  @ViewChild('counter', { read: ElementRef }) counter?: ElementRef<HTMLElement>;\n  @ViewChild('tokensContainer', { read: ElementRef }) tokensContainer!: ElementRef<HTMLElement>;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private destroyRef: DestroyRef,\n    private changeDetectorRef: ChangeDetectorRef,\n    private resizeObserverService: ResizeObserverService\n  ) {\n    effect(() => {\n      // Whenever the tokenizer is disabled, ensure all tokens are shown\n      if (!this.active()) {\n        this.items!.forEach((item) => item.show());\n      }\n    });\n  }\n\n  ngAfterContentInit() {\n    const containerWidth = this.resizeObserverService.createResizeObservable(this.elementRef.nativeElement).pipe(\n      map((entry) => entry.contentRect.width ?? 0),\n      debounceTime(16),\n      distinctUntilChanged()\n    );\n    const itemsChanged$ = this.items!.changes;\n\n    combineLatest([\n      this.active$,\n      containerWidth.pipe(startWith(this.elementRef.nativeElement.getBoundingClientRect().width)),\n      itemsChanged$.pipe(startWith(this.items))\n    ])\n      .pipe(\n        filter(([active]) => active),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe(([, containerWidth]) => {\n        this.tokenize(containerWidth);\n      });\n  }\n\n  onCounterClicked(): void {\n    const startIndex = this.overflowStartIndex();\n    if (typeof startIndex === 'number') {\n      this.overflowPlaceholderClick.emit({ startIndex, counterElement: this.counter! });\n    }\n  }\n\n  private tokenize(containerWidth: number): void {\n    if (!this.items) {\n      return;\n    }\n\n    this.items.forEach((item) => item.hide());\n    this.overflowItems.set([]);\n    this.changeDetectorRef.detectChanges();\n\n    let index = 0;\n    for (const item of this.items) {\n      item.show();\n      const usedWidth = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n      if (usedWidth > containerWidth) {\n        item.hide();\n        this.updateOverflowCounter(index);\n\n        const usedWidthIncludingCounter = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n        if (usedWidthIncludingCounter > containerWidth && index >= 1) {\n          const previousItem = this.items.toArray()[index - 1];\n          previousItem?.hide();\n          this.updateOverflowCounter(index - 1);\n        }\n\n        break;\n      }\n      index++;\n    }\n  }\n\n  private updateOverflowCounter(index: number) {\n    this.overflowStartIndex.set(index);\n\n    const overflowingItems = this.items?.toArray().slice(index) ?? [];\n    this.overflowItems.set(overflowingItems);\n    this.changeDetectorRef.detectChanges();\n  }\n}\n","<div #tokensContainer class=\"tokensContainer\">\n  <ng-content select=\"lx-token\" />\n  @if (showCounter()) {\n    <button\n      lx-button\n      class=\"counterButton\"\n      mode=\"ghost\"\n      (click)=\"onCounterClicked()\"\n      [attr.aria-label]=\"\n        NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n      \"\n    >\n      <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n    </button>\n  }\n</div>\n"]}
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenizer.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/tokenizer/tokenizer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  ContentChildren,\n  DestroyRef,\n  effect,\n  ElementRef,\n  EventEmitter,\n  input,\n  Output,\n  QueryList,\n  signal,\n  ViewChild\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { combineLatest } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, map, startWith } from 'rxjs/operators';\nimport { ButtonComponent } from '../../components/button/button.component';\nimport { CounterComponent } from '../../components/counter/counter.component';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { TokenComponent } from './token/token.component';\n\n/**\n * The tokenizer component (`lx-tokenizer`) is responsible for rendering a list of items into a container and hiding those that do not fit behind a placeholder. The items are represented as `lx-token`. Each `lx-token` allows to project any content into it, so anything can become a token. The tokenizer calculates how many items fit into the container (based on width), hiding those items that are overflowing and showing a overflow placeholder instead (e.g. \"+4\").\n *\n * ## Usage\n *\n * 1. Import `TokenizerComponent` & `TokenComponent` into your module or component.\n * 2. Use the component in your template. All items should be wrapped in a `lx-token` element for the tokenizer to identify the individual tokens.\n *\n * ```ts\n * import { TokenizerComponent } from '@leanix/components';\n *\n * @Component({\n *   selector: 'lx-my-component',\n *   standalone: true,\n *   imports: [TokenizerComponent, TokenComponent],\n *   template: `\n *     <lx-tokenizer>\n *       <lx-token>Token One</lx-token>\n *       <lx-token>Token Two</lx-token>\n *     </lx-tokenizer>\n *   `\n * })\n * export class MyComponent {}\n * ```\n *\n * ## API\n *\n * ### Inputs\n *\n * - `active`: Can be used to activate & deactivate tokenization\n *\n * ### Outputs\n *\n * - `overflowPlaceholderClick`: Fires when the user clicks on the overflow placeholder\n *\n * ### Content projection\n *\n * - `lx-token`: All `lx-tokens` will be projected into the tokenizer\n */\n@Component({\n  selector: 'lx-tokenizer',\n  standalone: true,\n  templateUrl: './tokenizer.component.html',\n  styleUrls: ['./tokenizer.component.scss'],\n  imports: [NgIf, CounterComponent, ButtonComponent, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TokenizerComponent implements AfterContentInit {\n  readonly NAME = 'TokenizerComponent';\n\n  protected overflowItems = signal<TokenComponent[]>([]);\n  protected overflowItemCount = computed(() => this.overflowItems().length);\n  protected showCounter = computed(() => this.active() && this.overflowItemCount() > 0);\n\n  active = input(true);\n  private active$ = toObservable(this.active);\n  private overflowStartIndex = signal<number | null>(null);\n\n  /**\n   * Emitted when the counter button is clicked\n   * @param startIndex The index of the first overflowing element\n   * @param counterElement The counter button element\n   */\n  @Output() overflowPlaceholderClick = new EventEmitter<{ startIndex: number; counterElement: ElementRef<HTMLElement> }>();\n\n  @ContentChildren(TokenComponent) items?: QueryList<TokenComponent>;\n  @ViewChild('counter', { read: ElementRef }) counter?: ElementRef<HTMLElement>;\n  @ViewChild('tokensContainer', { read: ElementRef }) tokensContainer!: ElementRef<HTMLElement>;\n\n  constructor(\n    private elementRef: ElementRef<HTMLElement>,\n    private destroyRef: DestroyRef,\n    private changeDetectorRef: ChangeDetectorRef,\n    private resizeObserverService: ResizeObserverService\n  ) {\n    effect(() => {\n      // Whenever the tokenizer is disabled, ensure all tokens are shown\n      if (!this.active()) {\n        this.items!.forEach((item) => item.show());\n      }\n    });\n  }\n\n  ngAfterContentInit() {\n    const containerWidth = this.resizeObserverService.createResizeObservable(this.elementRef.nativeElement).pipe(\n      map((entry) => entry.contentRect.width ?? 0),\n      debounceTime(16),\n      distinctUntilChanged()\n    );\n    const itemsChanged$ = this.items!.changes;\n\n    combineLatest([\n      this.active$,\n      containerWidth.pipe(startWith(this.elementRef.nativeElement.getBoundingClientRect().width)),\n      itemsChanged$.pipe(startWith(this.items))\n    ])\n      .pipe(\n        filter(([active]) => active),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe(([, containerWidth]) => {\n        this.tokenize(containerWidth);\n      });\n  }\n\n  onCounterClicked(): void {\n    const startIndex = this.overflowStartIndex();\n    if (typeof startIndex === 'number') {\n      this.overflowPlaceholderClick.emit({ startIndex, counterElement: this.counter! });\n    }\n  }\n\n  private tokenize(containerWidth: number): void {\n    if (!this.items) {\n      return;\n    }\n\n    this.items.forEach((item) => item.hide());\n    this.overflowItems.set([]);\n    this.changeDetectorRef.detectChanges();\n\n    let index = 0;\n    for (const item of this.items) {\n      item.show();\n      const usedWidth = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n      if (usedWidth > containerWidth) {\n        item.hide();\n        this.updateOverflowCounter(index);\n\n        const usedWidthIncludingCounter = this.tokensContainer.nativeElement.getBoundingClientRect().width;\n        if (usedWidthIncludingCounter > containerWidth && index >= 1) {\n          const previousItem = this.items.toArray()[index - 1];\n          previousItem?.hide();\n          this.updateOverflowCounter(index - 1);\n        }\n\n        break;\n      }\n      index++;\n    }\n  }\n\n  private updateOverflowCounter(index: number) {\n    this.overflowStartIndex.set(index);\n\n    const overflowingItems = this.items?.toArray().slice(index) ?? [];\n    this.overflowItems.set(overflowingItems);\n    this.changeDetectorRef.detectChanges();\n  }\n}\n","<div #tokensContainer class=\"tokensContainer\">\n  <ng-content select=\"lx-token\" />\n  @if (showCounter()) {\n    <button\n      lx-button\n      class=\"counterButton\"\n      mode=\"ghost\"\n      (click)=\"onCounterClicked()\"\n      [attr.aria-label]=\"\n        NAME + (overflowItemCount() === 1 ? '.showMoreItem' : '.showMoreItems') | translate: { count: overflowItemCount() }\n      \"\n    >\n      <lx-counter #counter aria-hidden=\"true\" [content]=\"'+' + overflowItemCount()\" color=\"gray\" />\n    </button>\n  }\n</div>\n"]}
|
@@ -118,6 +118,7 @@ export class LxCoreUiModule {
|
|
118
118
|
CollapsibleComponent,
|
119
119
|
EllipsisComponent,
|
120
120
|
StepperComponent,
|
121
|
+
TableHeaderComponent,
|
121
122
|
EmptyStateComponent] }); }
|
122
123
|
}
|
123
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: LxCoreUiModule, decorators: [{
|
@@ -203,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
203
204
|
providers: [LxTimeAgo]
|
204
205
|
}]
|
205
206
|
}] });
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-ui.module.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/core-ui/core-ui.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { BadgeComponent } from './components/badge/badge.component';\nimport { BannerComponent } from './components/banner/banner.component';\nimport { ButtonGroupComponent } from './components/button-group/button-group.component';\nimport { ButtonComponent } from './components/button/button.component';\nimport { CardComponent } from './components/card/card.component';\nimport { CollapsibleComponent } from './components/collapsible/collapsible.component';\nimport { CounterComponent } from './components/counter/counter.component';\nimport { EllipsisComponent } from './components/ellipsis/ellipsis.component';\nimport { EmptyStateComponent } from './components/empty-state/empty-state.component';\nimport { IconScaleComponent } from './components/icon-scale/icon-scale.component';\nimport { SpinnerComponent } from './components/spinner/spinner.component';\nimport { StepperComponent } from './components/stepper/stepper.component';\nimport { TableHeaderComponent } from './components/table/table-header/table-header.component';\nimport { TableComponent } from './components/table/table.component';\nimport { TinySpinnerComponent } from './components/tiny-spinner/tiny-spinner.component';\nimport { AfterViewInitDirective } from './directives/after-view-init.directive';\nimport { AutocloseDirective } from './directives/autoclose.directive';\nimport { AutofocusDirective } from './directives/autofocus.directive';\nimport { LxLinkifyPipe } from './linkify/linkify.pipe';\nimport { LxUnlinkifyPipe } from './linkify/unlinkify.pipe';\nimport { BrPipe } from './pipes/br.pipe';\nimport { ContrastColorPipe } from './pipes/contrast-color.pipe';\nimport { CustomDatePipe } from './pipes/custom-date.pipe';\nimport { HighlightRangePipe } from './pipes/highlight-range.pipe';\nimport { HighlightTermPipe } from './pipes/highlight-term.pipe';\nimport { LxIsUuidPipe } from './pipes/lx-is-uuid.pipe';\nimport { LxTimeAgo } from './pipes/lx-time-ago.pipe';\nimport { LxTranslatePipe } from './pipes/lx-translate.pipe';\nimport { MarkdownPipe } from './pipes/markdown.pipe';\nimport { NbspPipe } from './pipes/nbsp.pipe';\nimport { SortPipe } from './pipes/sort.pipe';\nimport { TranslationAfterPipe } from './pipes/translation-after.pipe';\nimport { TranslationBeforePipe } from './pipes/translation-before.pipe';\nimport { TranslationBetweenPipe } from './pipes/translation-between.pipe';\nimport { UnescapeCurlyBracesPipe } from './pipes/unescape-curly-braces.pipe';\nimport { TooltipDirective } from './tooltip/tooltip.directive';\n\n@NgModule({\n  imports: [\n    TranslateModule.forChild(),\n    AfterViewInitDirective,\n    AutocloseDirective,\n    AutofocusDirective,\n    CounterComponent,\n    BadgeComponent,\n    BannerComponent,\n    ButtonComponent,\n    ButtonGroupComponent,\n    BrPipe,\n    CardComponent,\n    CollapsibleComponent,\n    CustomDatePipe,\n    EllipsisComponent,\n    HighlightRangePipe,\n    HighlightTermPipe,\n    IconScaleComponent,\n    LxLinkifyPipe,\n    LxUnlinkifyPipe,\n    LxTimeAgo,\n    LxTranslatePipe,\n    MarkdownPipe,\n    NbspPipe,\n    LxIsUuidPipe,\n    StepperComponent,\n    SpinnerComponent,\n    TableComponent,\n    TableHeaderComponent,\n    TinySpinnerComponent,\n    TooltipDirective,\n    TranslationAfterPipe,\n    TranslationBeforePipe,\n    TranslationBetweenPipe,\n    SortPipe,\n    ContrastColorPipe,\n    UnescapeCurlyBracesPipe,\n    EmptyStateComponent\n  ],\n  exports: [\n    AfterViewInitDirective,\n    AutocloseDirective,\n    AutofocusDirective,\n    BadgeComponent,\n    CounterComponent,\n    BannerComponent,\n    ButtonComponent,\n    BrPipe,\n    ButtonGroupComponent,\n    CardComponent,\n    CustomDatePipe,\n    EllipsisComponent,\n    HighlightRangePipe,\n    HighlightTermPipe,\n    IconScaleComponent,\n    LxLinkifyPipe,\n    LxUnlinkifyPipe,\n    LxTimeAgo,\n    LxTranslatePipe,\n    MarkdownPipe,\n    NbspPipe,\n    LxIsUuidPipe,\n    StepperComponent,\n    SpinnerComponent,\n    TableComponent,\n    TableHeaderComponent,\n    TinySpinnerComponent,\n    TooltipDirective,\n    TranslationAfterPipe,\n    TranslationBeforePipe,\n    TranslationBetweenPipe,\n    CollapsibleComponent,\n    SortPipe,\n    ContrastColorPipe,\n    UnescapeCurlyBracesPipe,\n    EmptyStateComponent\n  ],\n  providers: [LxTimeAgo]\n})\nexport class LxCoreUiModule {}\n"]}
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-ui.module.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/core-ui/core-ui.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { BadgeComponent } from './components/badge/badge.component';\nimport { BannerComponent } from './components/banner/banner.component';\nimport { ButtonGroupComponent } from './components/button-group/button-group.component';\nimport { ButtonComponent } from './components/button/button.component';\nimport { CardComponent } from './components/card/card.component';\nimport { CollapsibleComponent } from './components/collapsible/collapsible.component';\nimport { CounterComponent } from './components/counter/counter.component';\nimport { EllipsisComponent } from './components/ellipsis/ellipsis.component';\nimport { EmptyStateComponent } from './components/empty-state/empty-state.component';\nimport { IconScaleComponent } from './components/icon-scale/icon-scale.component';\nimport { SpinnerComponent } from './components/spinner/spinner.component';\nimport { StepperComponent } from './components/stepper/stepper.component';\nimport { TableHeaderComponent } from './components/table/table-header/table-header.component';\nimport { TableComponent } from './components/table/table.component';\nimport { TinySpinnerComponent } from './components/tiny-spinner/tiny-spinner.component';\nimport { AfterViewInitDirective } from './directives/after-view-init.directive';\nimport { AutocloseDirective } from './directives/autoclose.directive';\nimport { AutofocusDirective } from './directives/autofocus.directive';\nimport { LxLinkifyPipe } from './linkify/linkify.pipe';\nimport { LxUnlinkifyPipe } from './linkify/unlinkify.pipe';\nimport { BrPipe } from './pipes/br.pipe';\nimport { ContrastColorPipe } from './pipes/contrast-color.pipe';\nimport { CustomDatePipe } from './pipes/custom-date.pipe';\nimport { HighlightRangePipe } from './pipes/highlight-range.pipe';\nimport { HighlightTermPipe } from './pipes/highlight-term.pipe';\nimport { LxIsUuidPipe } from './pipes/lx-is-uuid.pipe';\nimport { LxTimeAgo } from './pipes/lx-time-ago.pipe';\nimport { LxTranslatePipe } from './pipes/lx-translate.pipe';\nimport { MarkdownPipe } from './pipes/markdown.pipe';\nimport { NbspPipe } from './pipes/nbsp.pipe';\nimport { SortPipe } from './pipes/sort.pipe';\nimport { TranslationAfterPipe } from './pipes/translation-after.pipe';\nimport { TranslationBeforePipe } from './pipes/translation-before.pipe';\nimport { TranslationBetweenPipe } from './pipes/translation-between.pipe';\nimport { UnescapeCurlyBracesPipe } from './pipes/unescape-curly-braces.pipe';\nimport { TooltipDirective } from './tooltip/tooltip.directive';\n\n@NgModule({\n  imports: [\n    TranslateModule.forChild(),\n    AfterViewInitDirective,\n    AutocloseDirective,\n    AutofocusDirective,\n    CounterComponent,\n    BadgeComponent,\n    BannerComponent,\n    ButtonComponent,\n    ButtonGroupComponent,\n    BrPipe,\n    CardComponent,\n    CollapsibleComponent,\n    CustomDatePipe,\n    EllipsisComponent,\n    HighlightRangePipe,\n    HighlightTermPipe,\n    IconScaleComponent,\n    LxLinkifyPipe,\n    LxUnlinkifyPipe,\n    LxTimeAgo,\n    LxTranslatePipe,\n    MarkdownPipe,\n    NbspPipe,\n    LxIsUuidPipe,\n    StepperComponent,\n    SpinnerComponent,\n    TableComponent,\n    TableHeaderComponent,\n    TinySpinnerComponent,\n    TooltipDirective,\n    TranslationAfterPipe,\n    TranslationBeforePipe,\n    TranslationBetweenPipe,\n    SortPipe,\n    ContrastColorPipe,\n    UnescapeCurlyBracesPipe,\n    EmptyStateComponent\n  ],\n  exports: [\n    AfterViewInitDirective,\n    AutocloseDirective,\n    AutofocusDirective,\n    BadgeComponent,\n    CounterComponent,\n    BannerComponent,\n    ButtonComponent,\n    BrPipe,\n    ButtonGroupComponent,\n    CardComponent,\n    CustomDatePipe,\n    EllipsisComponent,\n    HighlightRangePipe,\n    HighlightTermPipe,\n    IconScaleComponent,\n    LxLinkifyPipe,\n    LxUnlinkifyPipe,\n    LxTimeAgo,\n    LxTranslatePipe,\n    MarkdownPipe,\n    NbspPipe,\n    LxIsUuidPipe,\n    StepperComponent,\n    SpinnerComponent,\n    TableComponent,\n    TableHeaderComponent,\n    TinySpinnerComponent,\n    TooltipDirective,\n    TranslationAfterPipe,\n    TranslationBeforePipe,\n    TranslationBetweenPipe,\n    CollapsibleComponent,\n    SortPipe,\n    ContrastColorPipe,\n    UnescapeCurlyBracesPipe,\n    EmptyStateComponent\n  ],\n  providers: [LxTimeAgo]\n})\nexport class LxCoreUiModule {}\n"]}
|
package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs
CHANGED
@@ -14,6 +14,8 @@ import * as i1 from "ngx-infinite-scroll";
|
|
14
14
|
import * as i2 from "@ngx-translate/core";
|
15
15
|
/**
|
16
16
|
* Usage:
|
17
|
+
*
|
18
|
+
* ```
|
17
19
|
* <lx-single-select
|
18
20
|
* #singleSelect
|
19
21
|
* [selection]="value"
|
@@ -28,7 +30,7 @@ import * as i2 from "@ngx-translate/core";
|
|
28
30
|
* (onItemSelected)="singleSelect.selectOption($event)">
|
29
31
|
* </lx-option-group-dropdown>
|
30
32
|
* </lx-single-select>
|
31
|
-
*
|
33
|
+
* ```
|
32
34
|
*/
|
33
35
|
export class OptionGroupDropdownComponent extends KeyboardSelectDirective {
|
34
36
|
constructor() {
|
@@ -125,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
125
127
|
type: ViewChild,
|
126
128
|
args: ['selectOrigin', { static: false }]
|
127
129
|
}] } });
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n *\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n *\n * ```\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n * ```\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
|