@tilde-nlp/ngx-common 5.0.2 → 5.0.3
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/close-button/close-button.component.mjs +37 -18
- package/esm2022/lib/close-button/close-button.module.mjs +25 -24
- package/esm2022/lib/company-product/company-product.component.mjs +25 -11
- package/esm2022/lib/company-product/company-product.module.mjs +17 -16
- package/esm2022/lib/confirmation-modal/confirmation-modal.component.mjs +63 -10
- package/esm2022/lib/confirmation-modal/confirmation-modal.module.mjs +13 -12
- package/esm2022/lib/confirmation-modal/services/confirmation.service.mjs +9 -9
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +17 -15
- package/esm2022/lib/directives/click-outside/click-outside.module.mjs +19 -18
- package/esm2022/lib/directives/drag-and-drop/drag-and-drop.directive.mjs +28 -24
- package/esm2022/lib/directives/drag-and-drop/drag-and-drop.module.mjs +19 -18
- package/esm2022/lib/directives/mat-button-loading/mat-button-loading.directive.mjs +12 -12
- package/esm2022/lib/directives/mat-button-loading/mat-button-loading.module.mjs +15 -14
- package/esm2022/lib/extension-dialog/components/open-extension-dialog/open-extension-dialog.component.mjs +19 -9
- package/esm2022/lib/extension-dialog/extension-dialog.component.mjs +99 -10
- package/esm2022/lib/extension-dialog/extension-dialog.module.mjs +33 -32
- package/esm2022/lib/extension-dialog/services/extension-dialog.service.mjs +9 -9
- package/esm2022/lib/file-upload/file-upload.component.mjs +83 -33
- package/esm2022/lib/file-upload/file-upload.module.mjs +27 -26
- package/esm2022/lib/filter-bar/filter-bar.component.mjs +187 -20
- package/esm2022/lib/filter-bar/filter-bar.module.mjs +43 -42
- package/esm2022/lib/filter-bar/models/filter-bar-settings.model.mjs +1 -1
- package/esm2022/lib/footer/footer.component.mjs +121 -15
- package/esm2022/lib/footer/footer.module.mjs +23 -22
- package/esm2022/lib/inline-message/inline-message.component.mjs +59 -11
- package/esm2022/lib/inline-message/inline-message.module.mjs +23 -22
- package/esm2022/lib/multi-functional-table/models/filter-config.model.mjs +1 -1
- package/esm2022/lib/multi-functional-table/multi-functional-table.component.mjs +248 -44
- package/esm2022/lib/multi-functional-table/multi-functional-table.module.mjs +43 -42
- package/esm2022/lib/notification-message/notification-message.component.mjs +130 -17
- package/esm2022/lib/notification-message/notification-message.module.mjs +29 -28
- package/esm2022/lib/open-close-button/open-close-button.component.mjs +68 -25
- package/esm2022/lib/open-close-button/open-close-button.module.mjs +13 -12
- package/esm2022/lib/pipes/date-ago/date-ago.module.mjs +21 -20
- package/esm2022/lib/pipes/date-ago/date-ago.pipe.mjs +15 -15
- package/esm2022/lib/pipes/filter-with-highlight/filter-with-highlight.module.mjs +19 -18
- package/esm2022/lib/pipes/filter-with-highlight/filter-with-highlight.pipe.mjs +9 -9
- package/esm2022/lib/pipes/index.mjs +2 -1
- package/esm2022/lib/pipes/language-translate/language-translate.module.mjs +13 -12
- package/esm2022/lib/pipes/language-translate/language-translate.pipe.mjs +10 -10
- package/esm2022/lib/pipes/object-length/index.mjs +3 -0
- package/esm2022/lib/pipes/object-length/object-length.module.mjs +19 -0
- package/esm2022/lib/pipes/object-length/object-length.pipe.mjs +23 -0
- package/esm2022/lib/pipes/sort-translations/sort-translations.module.mjs +17 -16
- package/esm2022/lib/pipes/sort-translations/sort-translations.pipe.mjs +9 -9
- package/esm2022/lib/pipes/sort-translations-by-property/sort-translations-by-property.module.mjs +13 -12
- package/esm2022/lib/pipes/sort-translations-by-property/sort-translations-by-property.pipe.mjs +9 -9
- package/esm2022/lib/plausible/plausible-event.directive.mjs +16 -14
- package/esm2022/lib/plausible/plausible.module.mjs +19 -18
- package/esm2022/lib/services/alert/alert.service.mjs +12 -12
- package/esm2022/lib/services/dom/dom.service.mjs +9 -9
- package/esm2022/lib/services/icon/icon.service.mjs +9 -9
- package/esm2022/lib/services/language-translate/language-translate.service.mjs +9 -9
- package/esm2022/lib/services/notification/notification.service.mjs +9 -9
- package/esm2022/lib/services/system/system.service.mjs +12 -12
- package/esm2022/lib/status-display/status-display.component.mjs +55 -10
- package/esm2022/lib/status-display/status-display.module.mjs +13 -12
- package/esm2022/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-card/terminology-collection-card.component.mjs +196 -25
- package/esm2022/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.mjs +107 -14
- package/esm2022/lib/terminology/components/terminology-panel/terminology-create-collection/terminology-create-collection-dialog/terminology-create-collection-dialog.component.mjs +71 -10
- package/esm2022/lib/terminology/components/terminology-panel/terminology-create-collection/terminology-create-collection.component.mjs +29 -13
- package/esm2022/lib/terminology/components/terminology-panel/terminology-panel.component.mjs +83 -14
- package/esm2022/lib/terminology/config/services/terminology-config/terminology-config.service.mjs +27 -25
- package/esm2022/lib/terminology/factories/terminology-api.factory.mjs +4 -4
- package/esm2022/lib/terminology/factories/terminology-system.factory.mjs +4 -4
- package/esm2022/lib/terminology/models/active-data.model.mjs +1 -1
- package/esm2022/lib/terminology/models/system.model.mjs +1 -1
- package/esm2022/lib/terminology/services/engine-term-api/engine-term-api.service.mjs +9 -9
- package/esm2022/lib/terminology/services/system-api-v1/system-api-v1.service.mjs +9 -9
- package/esm2022/lib/terminology/services/system-api-v2/system-api-v2.service.mjs +9 -9
- package/esm2022/lib/terminology/services/terminology/terminology.service.mjs +15 -13
- package/esm2022/lib/terminology/services/terminology-api-v1/terminology-api-v1.service.mjs +9 -9
- package/esm2022/lib/terminology/services/terminology-api-v2/terminology-api-v2.service.mjs +9 -9
- package/esm2022/lib/terminology/services/terminology-collection/terminology-collection.service.mjs +9 -9
- package/esm2022/lib/terminology/terminology.component.mjs +109 -22
- package/esm2022/lib/terminology/terminology.module.mjs +73 -72
- package/esm2022/lib/text-to-speech/index.mjs +2 -0
- package/esm2022/lib/text-to-speech/services/text-play.service.mjs +22 -0
- package/esm2022/lib/text-to-speech/text-to-speech.component.mjs +171 -0
- package/esm2022/lib/text-to-speech/translations/tts-i18n.mjs +26 -0
- package/esm2022/lib/tld-loader/tld-loader.component.mjs +12 -7
- package/esm2022/lib/tld-loader/tld-loader.module.mjs +16 -15
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/tilde-nlp-ngx-common.mjs +2828 -1098
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/filter-bar/filter-bar.component.d.ts +1 -0
- package/lib/filter-bar/models/filter-bar-settings.model.d.ts +3 -1
- package/lib/multi-functional-table/models/filter-config.model.d.ts +1 -0
- package/lib/multi-functional-table/multi-functional-table.component.d.ts +4 -1
- package/lib/pipes/index.d.ts +1 -0
- package/lib/pipes/object-length/index.d.ts +2 -0
- package/lib/pipes/object-length/object-length.module.d.ts +8 -0
- package/lib/pipes/object-length/object-length.pipe.d.ts +7 -0
- package/lib/terminology/config/services/terminology-config/terminology-config.service.d.ts +1 -0
- package/lib/terminology/models/active-data.model.d.ts +1 -0
- package/lib/terminology/models/system.model.d.ts +1 -0
- package/lib/text-to-speech/index.d.ts +1 -0
- package/lib/text-to-speech/services/text-play.service.d.ts +8 -0
- package/lib/text-to-speech/text-to-speech.component.d.ts +23 -0
- package/lib/text-to-speech/translations/tts-i18n.d.ts +1 -0
- package/package.json +7 -4
- package/public-api.d.ts +1 -0
- package/styles/material-overrides.scss +33 -0
- package/web-components/3rdpartylicenses.txt +333 -0
- package/web-components/index.html +17 -0
- package/web-components/main.js +11 -0
- package/web-components/media/material-icons-outlined.woff2 +0 -0
- package/web-components/media/material-icons.woff2 +0 -0
- package/web-components/polyfills.js +3 -0
- package/web-components/styles.css +1 -0
- package/web-components/web-components.js +1 -0
|
@@ -20,18 +20,150 @@ import * as i9 from "../filter-bar/filter-bar.component";
|
|
|
20
20
|
import * as i10 from "@ngbracket/ngx-layout/flex";
|
|
21
21
|
import * as i11 from "@angular/material/tooltip";
|
|
22
22
|
import * as i12 from "../status-display/status-display.component";
|
|
23
|
+
const _c0 = [[["", "additionalActions", ""]], "*"];
|
|
24
|
+
const _c1 = ["[additionalActions]", "*"];
|
|
25
|
+
function MultiFunctionalTableComponent_button_3_Template(rf, ctx) { if (rf & 1) {
|
|
26
|
+
i0.ɵɵelementStart(0, "button", 19)(1, "span", 20);
|
|
27
|
+
i0.ɵɵtext(2, "menu");
|
|
28
|
+
i0.ɵɵelementEnd();
|
|
29
|
+
i0.ɵɵelementStart(3, "span");
|
|
30
|
+
i0.ɵɵtext(4);
|
|
31
|
+
i0.ɵɵpipe(5, "translate");
|
|
32
|
+
i0.ɵɵelementEnd()();
|
|
33
|
+
} if (rf & 2) {
|
|
34
|
+
i0.ɵɵnextContext();
|
|
35
|
+
const columnMenu_r2 = i0.ɵɵreference(8);
|
|
36
|
+
i0.ɵɵproperty("matMenuTriggerFor", columnMenu_r2);
|
|
37
|
+
i0.ɵɵadvance(4);
|
|
38
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(5, 2, "MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT"));
|
|
39
|
+
} }
|
|
40
|
+
function MultiFunctionalTableComponent_button_4_Template(rf, ctx) { if (rf & 1) {
|
|
41
|
+
const _r3 = i0.ɵɵgetCurrentView();
|
|
42
|
+
i0.ɵɵelementStart(0, "button", 21);
|
|
43
|
+
i0.ɵɵlistener("click", function MultiFunctionalTableComponent_button_4_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.toggleFilterBar()); });
|
|
44
|
+
i0.ɵɵelementStart(1, "span", 22);
|
|
45
|
+
i0.ɵɵtext(2, "filter_list");
|
|
46
|
+
i0.ɵɵelementEnd();
|
|
47
|
+
i0.ɵɵelementStart(3, "span");
|
|
48
|
+
i0.ɵɵtext(4);
|
|
49
|
+
i0.ɵɵpipe(5, "translate");
|
|
50
|
+
i0.ɵɵelementEnd()();
|
|
51
|
+
} if (rf & 2) {
|
|
52
|
+
i0.ɵɵadvance(4);
|
|
53
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(5, 1, "MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE"));
|
|
54
|
+
} }
|
|
55
|
+
function MultiFunctionalTableComponent_button_5_Template(rf, ctx) { if (rf & 1) {
|
|
56
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
57
|
+
i0.ɵɵelementStart(0, "button", 23);
|
|
58
|
+
i0.ɵɵlistener("click", function MultiFunctionalTableComponent_button_5_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.export()); });
|
|
59
|
+
i0.ɵɵelementStart(1, "span", 24);
|
|
60
|
+
i0.ɵɵtext(2, "cloud_download");
|
|
61
|
+
i0.ɵɵelementEnd();
|
|
62
|
+
i0.ɵɵelementStart(3, "span");
|
|
63
|
+
i0.ɵɵtext(4);
|
|
64
|
+
i0.ɵɵpipe(5, "translate");
|
|
65
|
+
i0.ɵɵelementEnd()();
|
|
66
|
+
} if (rf & 2) {
|
|
67
|
+
i0.ɵɵadvance(4);
|
|
68
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(5, 1, "MULTI_FUNCTIONAL_TABLE.EXPORT"));
|
|
69
|
+
} }
|
|
70
|
+
function MultiFunctionalTableComponent_div_10_Template(rf, ctx) { if (rf & 1) {
|
|
71
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
72
|
+
i0.ɵɵelementStart(0, "div")(1, "mat-checkbox", 25);
|
|
73
|
+
i0.ɵɵtwoWayListener("ngModelChange", function MultiFunctionalTableComponent_div_10_Template_mat_checkbox_ngModelChange_1_listener($event) { const column_r7 = i0.ɵɵrestoreView(_r6).$implicit; i0.ɵɵtwoWayBindingSet(column_r7.selected, $event) || (column_r7.selected = $event); return i0.ɵɵresetView($event); });
|
|
74
|
+
i0.ɵɵlistener("change", function MultiFunctionalTableComponent_div_10_Template_mat_checkbox_change_1_listener() { i0.ɵɵrestoreView(_r6); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.updateDisplayColumns()); });
|
|
75
|
+
i0.ɵɵtext(2);
|
|
76
|
+
i0.ɵɵpipe(3, "translate");
|
|
77
|
+
i0.ɵɵelementEnd()();
|
|
78
|
+
} if (rf & 2) {
|
|
79
|
+
const column_r7 = ctx.$implicit;
|
|
80
|
+
i0.ɵɵadvance();
|
|
81
|
+
i0.ɵɵtwoWayProperty("ngModel", column_r7.selected);
|
|
82
|
+
i0.ɵɵadvance();
|
|
83
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(3, 2, column_r7.displayName), " ");
|
|
84
|
+
} }
|
|
85
|
+
function MultiFunctionalTableComponent_tld_filter_bar_11_Template(rf, ctx) { if (rf & 1) {
|
|
86
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
87
|
+
i0.ɵɵelementStart(0, "tld-filter-bar", 26);
|
|
88
|
+
i0.ɵɵlistener("filterBarChange", function MultiFunctionalTableComponent_tld_filter_bar_11_Template_tld_filter_bar_filterBarChange_0_listener($event) { i0.ɵɵrestoreView(_r8); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.filtersChanged($event)); });
|
|
89
|
+
i0.ɵɵelementEnd();
|
|
90
|
+
} if (rf & 2) {
|
|
91
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
92
|
+
i0.ɵɵproperty("filterRowVisible", !ctx_r3.filterBarVisible)("settings", ctx_r3.config.filter.settings);
|
|
93
|
+
} }
|
|
94
|
+
function MultiFunctionalTableComponent_th_17_Template(rf, ctx) { if (rf & 1) {
|
|
95
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
96
|
+
i0.ɵɵelementStart(0, "th", 27)(1, "mat-checkbox", 28);
|
|
97
|
+
i0.ɵɵpipe(2, "translate");
|
|
98
|
+
i0.ɵɵlistener("change", function MultiFunctionalTableComponent_th_17_Template_mat_checkbox_change_1_listener() { i0.ɵɵrestoreView(_r9); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.toggleAllRowSelection()); });
|
|
99
|
+
i0.ɵɵelementEnd()();
|
|
100
|
+
} if (rf & 2) {
|
|
101
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
102
|
+
i0.ɵɵadvance();
|
|
103
|
+
i0.ɵɵproperty("matTooltip", i0.ɵɵpipeBind1(2, 4, "MULTI_FUNCTIONAL_TABLE.SELECT_ALL"))("disabled", ctx_r3.config.batchConfig.checkBoxesDisabled)("checked", ctx_r3.matSelection.hasValue() && ctx_r3.isAllSelected())("indeterminate", ctx_r3.matSelection.hasValue() && !ctx_r3.isAllSelected());
|
|
104
|
+
} }
|
|
105
|
+
function MultiFunctionalTableComponent_td_18_mat_checkbox_1_Template(rf, ctx) { if (rf & 1) {
|
|
106
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
107
|
+
i0.ɵɵelementStart(0, "mat-checkbox", 31);
|
|
108
|
+
i0.ɵɵpipe(1, "translate");
|
|
109
|
+
i0.ɵɵlistener("click", function MultiFunctionalTableComponent_td_18_mat_checkbox_1_Template_mat_checkbox_click_0_listener($event) { i0.ɵɵrestoreView(_r10); return i0.ɵɵresetView($event.stopPropagation()); })("change", function MultiFunctionalTableComponent_td_18_mat_checkbox_1_Template_mat_checkbox_change_0_listener() { i0.ɵɵrestoreView(_r10); const element_r11 = i0.ɵɵnextContext().$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.toggleElementSelection(element_r11)); });
|
|
110
|
+
i0.ɵɵelementEnd();
|
|
111
|
+
} if (rf & 2) {
|
|
112
|
+
const element_r11 = i0.ɵɵnextContext().$implicit;
|
|
113
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
114
|
+
i0.ɵɵproperty("matTooltip", i0.ɵɵpipeBind1(1, 3, "MULTI_FUNCTIONAL_TABLE.SELECT"))("disabled", ctx_r3.config.batchConfig.checkBoxesDisabled || ctx_r3.preselectedItems.includes(element_r11) && ctx_r3.disablePreselectedItems)("checked", ctx_r3.matSelection.isSelected(element_r11));
|
|
115
|
+
} }
|
|
116
|
+
function MultiFunctionalTableComponent_td_18_Template(rf, ctx) { if (rf & 1) {
|
|
117
|
+
i0.ɵɵelementStart(0, "td", 29);
|
|
118
|
+
i0.ɵɵtemplate(1, MultiFunctionalTableComponent_td_18_mat_checkbox_1_Template, 2, 5, "mat-checkbox", 30);
|
|
119
|
+
i0.ɵɵelementEnd();
|
|
120
|
+
} if (rf & 2) {
|
|
121
|
+
const element_r11 = ctx.$implicit;
|
|
122
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
123
|
+
i0.ɵɵadvance();
|
|
124
|
+
i0.ɵɵproperty("ngIf", ctx_r3.isRowCheckboxAlwaysVisible || ctx_r3.hoveredRow === element_r11 || ctx_r3.matSelection.isSelected(element_r11));
|
|
125
|
+
} }
|
|
126
|
+
function MultiFunctionalTableComponent_tr_19_Template(rf, ctx) { if (rf & 1) {
|
|
127
|
+
i0.ɵɵelement(0, "tr", 32);
|
|
128
|
+
} }
|
|
129
|
+
function MultiFunctionalTableComponent_tr_20_Template(rf, ctx) { if (rf & 1) {
|
|
130
|
+
const _r12 = i0.ɵɵgetCurrentView();
|
|
131
|
+
i0.ɵɵelementStart(0, "tr", 33);
|
|
132
|
+
i0.ɵɵlistener("mouseover", function MultiFunctionalTableComponent_tr_20_Template_tr_mouseover_0_listener() { const row_r13 = i0.ɵɵrestoreView(_r12).$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.hoveredRow = row_r13); })("mouseleave", function MultiFunctionalTableComponent_tr_20_Template_tr_mouseleave_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.hoveredRow = null); });
|
|
133
|
+
i0.ɵɵelementEnd();
|
|
134
|
+
} if (rf & 2) {
|
|
135
|
+
const row_r13 = ctx.$implicit;
|
|
136
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
137
|
+
i0.ɵɵclassProp("highlight", ctx_r3.highlightElement(row_r13));
|
|
138
|
+
} }
|
|
139
|
+
function MultiFunctionalTableComponent_ng_container_21_tr_1_Template(rf, ctx) { if (rf & 1) {
|
|
140
|
+
i0.ɵɵelementStart(0, "tr")(1, "td", 35);
|
|
141
|
+
i0.ɵɵelement(2, "lib-status-display", 36);
|
|
142
|
+
i0.ɵɵelementEnd()();
|
|
143
|
+
} if (rf & 2) {
|
|
144
|
+
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
145
|
+
i0.ɵɵadvance(2);
|
|
146
|
+
i0.ɵɵproperty("config", ctx_r3.noDataRowConfig);
|
|
147
|
+
} }
|
|
148
|
+
function MultiFunctionalTableComponent_ng_container_21_Template(rf, ctx) { if (rf & 1) {
|
|
149
|
+
i0.ɵɵelementContainerStart(0);
|
|
150
|
+
i0.ɵɵtemplate(1, MultiFunctionalTableComponent_ng_container_21_tr_1_Template, 3, 1, "tr", 34);
|
|
151
|
+
i0.ɵɵelementContainerEnd();
|
|
152
|
+
} }
|
|
23
153
|
export class MultiFunctionalTableComponent {
|
|
24
154
|
set selection(value) {
|
|
25
155
|
this.matSelection.setSelection(...(value ?? []));
|
|
26
156
|
}
|
|
27
157
|
get ignoreAttributeName() { return DISABLE_EXPORT_ATTRIBUTE_NAME; }
|
|
28
158
|
get filterActive() { return this.config.filter?.enabled; }
|
|
159
|
+
get showFilterToggle() { return !this.config.filter?.hideFilterToggle; }
|
|
29
160
|
constructor(domService, translateService) {
|
|
30
161
|
this.domService = domService;
|
|
31
162
|
this.translateService = translateService;
|
|
32
163
|
this.matSelection = new SelectionModel(true, []);
|
|
33
164
|
// Set this to false if you want to display checkboxes only on row hover.
|
|
34
165
|
this.isRowCheckboxAlwaysVisible = true;
|
|
166
|
+
this.disablePreselectedItems = false;
|
|
35
167
|
//#region Output properties
|
|
36
168
|
this.filterBarChange = new EventEmitter();
|
|
37
169
|
this.exported = new EventEmitter();
|
|
@@ -46,6 +178,7 @@ export class MultiFunctionalTableComponent {
|
|
|
46
178
|
this.setColumnSelectProperties();
|
|
47
179
|
this.setExportProperties();
|
|
48
180
|
this.setNoDataRowProperties();
|
|
181
|
+
this.preselectedItems = this.matSelection.selected;
|
|
49
182
|
}
|
|
50
183
|
ngAfterContentInit() {
|
|
51
184
|
this.columnDefs.forEach(columnDef => this.table.addColumnDef(columnDef));
|
|
@@ -120,8 +253,15 @@ export class MultiFunctionalTableComponent {
|
|
|
120
253
|
}
|
|
121
254
|
toggleAllRowSelection() {
|
|
122
255
|
if (this.isAllSelected()) {
|
|
123
|
-
this.
|
|
124
|
-
|
|
256
|
+
if (this.disablePreselectedItems) {
|
|
257
|
+
// deselect only those items which were not already preselected
|
|
258
|
+
this.matSelection.deselect(...this.matSelection.selected.filter(elm => !this.preselectedItems.map(elm => elm).includes(elm)));
|
|
259
|
+
return;
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.matSelection.clear();
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
125
265
|
}
|
|
126
266
|
this.matSelection.select(...this.config.dataSource.data);
|
|
127
267
|
}
|
|
@@ -183,46 +323,110 @@ export class MultiFunctionalTableComponent {
|
|
|
183
323
|
this.exportActive = true;
|
|
184
324
|
}
|
|
185
325
|
}
|
|
186
|
-
static { this.ɵfac =
|
|
187
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: MultiFunctionalTableComponent, selector: "tld-multi-functional-table", inputs: { config: "config", highlightedElements: "highlightedElements", selection: "selection", isRowCheckboxAlwaysVisible: "isRowCheckboxAlwaysVisible" }, outputs: { filterBarChange: "filterBarChange", exported: "exported", selectionChange: "selectionChange" }, queries: [{ propertyName: "noDataRow", first: true, predicate: MatNoDataRow, descendants: true }, { propertyName: "headerRowDefs", predicate: MatHeaderRowDef }, { propertyName: "rowDefs", predicate: MatRowDef, descendants: true }, { propertyName: "columnDefs", predicate: MatColumnDef }], viewQueries: [{ propertyName: "table", first: true, predicate: MatTable, descendants: true, static: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true }, { propertyName: "tableElementRef", first: true, predicate: MatTable, descendants: true, read: ElementRef }], ngImport: i0, template: "<div fxLayout=\"column\" fxLayoutGap=\"1rem\">\r\n\r\n <div fxLayout=\"row\">\r\n <div fxFlex fxLayoutGap=\"1rem\">\r\n <button mat-button [matMenuTriggerFor]=\"columnMenu\" *ngIf=\"columnSelectActive\">\r\n <span class=\"material-icons column-select-icon\">menu</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT' | translate}}</span>\r\n </button>\r\n\r\n <button mat-button *ngIf=\"filterActive\" (click)=\"toggleFilterBar()\">\r\n <span class=\"material-icons\">filter_list</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n </button>\r\n\r\n <button class=\"export-data\" mat-stroked-button *ngIf=\"exportActive\" (click)=\"export()\">\r\n <span class=\"material-icons-outlined\">cloud_download</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n </button>\r\n </div>\r\n\r\n <ng-content select=\"[additionalActions]\"></ng-content>\r\n </div>\r\n\r\n <mat-menu #columnMenu=\"matMenu\">\r\n <div class=\"column-select-wrapper\" (click)=\"$event.stopPropagation()\">\r\n <div *ngFor=\"let column of configurableColumns\">\r\n <mat-checkbox [(ngModel)]=\"column.selected\" (change)=\"updateDisplayColumns()\">\r\n {{column.displayName | translate}}\r\n </mat-checkbox>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n\r\n <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" [filterRowVisible]=\"!filterBarVisible\" [settings]=\"config.filter.settings\" \r\n (filterBarChange)=\"filtersChanged($event)\">\r\n </tld-filter-bar>\r\n\r\n <div class=\"table-overflow\">\r\n <table #table mat-table [dataSource]=\"config.dataSource\">\r\n <ng-content></ng-content>\r\n <ng-container [matColumnDef]=\"batchColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n </mat-checkbox>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (click)=\"$event.stopPropagation()\"\r\n (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\" sticky></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayColumns\" (mouseover)=\"hoveredRow = row\" (mouseleave)=\"hoveredRow = null\" [class.highlight]=\"highlightElement(row)\"></tr>\r\n\r\n <ng-container *ngIf=\"noDataRowActive\">\r\n <tr *matNoDataRow>\r\n <!-- add random number to make sure it takes full width -->\r\n <td colspan=\"99\">\r\n <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep th,:host ::ng-deep tr{white-space:nowrap}:host ::ng-deep td:not(:first-of-type){padding-right:10px!important}:host ::ng-deep tr.mat-mdc-row:hover,:host ::ng-deep tr.mat-mdc-row.highlight{background-color:var(--base-95)}:host ::ng-deep .export-data .mdc-button__label{display:flex;align-items:center}:host ::ng-deep .mat-mdc-cell,:host ::ng-deep .mat-mdc-header-cell,:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}:host ::ng-deep .mdc-data-table__cell:nth-child(2),:host ::ng-deep .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}table{width:100%}.column-select-icon{rotate:90deg}.column-select-wrapper{padding:1rem}.material-icons,.material-icons-outlined{margin-right:.5rem}.table-action-button{margin-bottom:1rem}th.mat-mdc-header-cell:first-of-type,td.mat-mdc-cell:first-of-type,td.mat-mdc-footer-cell:first-of-type{padding:0 0 0 10px}.row-select{width:0}.table-overflow{overflow-x:auto}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i4.MatNoDataRow, selector: "ng-template[matNoDataRow]" }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.FilterBarComponent, selector: "tld-filter-bar", inputs: ["settings", "filterRowVisible"], outputs: ["filterBarChange"] }, { kind: "directive", type: i10.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i10.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i10.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i11.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i12.StatusDisplayComponent, selector: "lib-status-display", inputs: ["config"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
326
|
+
static { this.ɵfac = function MultiFunctionalTableComponent_Factory(t) { return new (t || MultiFunctionalTableComponent)(i0.ɵɵdirectiveInject(i1.DOMService), i0.ɵɵdirectiveInject(i2.TranslateService)); }; }
|
|
327
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: MultiFunctionalTableComponent, selectors: [["tld-multi-functional-table"]], contentQueries: function MultiFunctionalTableComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
328
|
+
i0.ɵɵcontentQuery(dirIndex, MatNoDataRow, 5);
|
|
329
|
+
i0.ɵɵcontentQuery(dirIndex, MatHeaderRowDef, 4);
|
|
330
|
+
i0.ɵɵcontentQuery(dirIndex, MatRowDef, 5);
|
|
331
|
+
i0.ɵɵcontentQuery(dirIndex, MatColumnDef, 4);
|
|
332
|
+
} if (rf & 2) {
|
|
333
|
+
let _t;
|
|
334
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.noDataRow = _t.first);
|
|
335
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.headerRowDefs = _t);
|
|
336
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.rowDefs = _t);
|
|
337
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.columnDefs = _t);
|
|
338
|
+
} }, viewQuery: function MultiFunctionalTableComponent_Query(rf, ctx) { if (rf & 1) {
|
|
339
|
+
i0.ɵɵviewQuery(MatTable, 7);
|
|
340
|
+
i0.ɵɵviewQuery(MatSort, 5);
|
|
341
|
+
i0.ɵɵviewQuery(MatTable, 5, ElementRef);
|
|
342
|
+
} if (rf & 2) {
|
|
343
|
+
let _t;
|
|
344
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.table = _t.first);
|
|
345
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.sort = _t.first);
|
|
346
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tableElementRef = _t.first);
|
|
347
|
+
} }, inputs: { config: "config", highlightedElements: "highlightedElements", selection: "selection", isRowCheckboxAlwaysVisible: "isRowCheckboxAlwaysVisible", disablePreselectedItems: "disablePreselectedItems" }, outputs: { filterBarChange: "filterBarChange", exported: "exported", selectionChange: "selectionChange" }, ngContentSelectors: _c1, decls: 22, vars: 10, consts: [["columnMenu", "matMenu"], ["table", ""], ["fxLayout", "column", "fxLayoutGap", "1rem"], ["fxLayout", "row"], ["fxFlex", "", "fxLayoutGap", "1rem"], ["mat-button", "", 3, "matMenuTriggerFor", 4, "ngIf"], ["mat-button", "", 3, "click", 4, "ngIf"], ["class", "export-data", "mat-stroked-button", "", 3, "click", 4, "ngIf"], [1, "column-select-wrapper", 3, "click"], [4, "ngFor", "ngForOf"], [3, "filterRowVisible", "settings", "filterBarChange", 4, "ngIf"], [1, "table-overflow"], ["mat-table", "", 3, "dataSource"], [3, "matColumnDef"], ["class", "row-select", "mat-header-cell", "", "disable-export", "", 4, "matHeaderCellDef"], ["class", "row-select", "mat-cell", "", "disable-export", "", 4, "matCellDef"], ["mat-header-row", "", "sticky", "", 4, "matHeaderRowDef"], ["mat-row", "", 3, "highlight", "mouseover", "mouseleave", 4, "matRowDef", "matRowDefColumns"], [4, "ngIf"], ["mat-button", "", 3, "matMenuTriggerFor"], [1, "material-icons", "column-select-icon"], ["mat-button", "", 3, "click"], [1, "material-icons"], ["mat-stroked-button", "", 1, "export-data", 3, "click"], [1, "material-icons-outlined"], [3, "ngModelChange", "change", "ngModel"], [3, "filterBarChange", "filterRowVisible", "settings"], ["mat-header-cell", "", "disable-export", "", 1, "row-select"], [3, "change", "matTooltip", "disabled", "checked", "indeterminate"], ["mat-cell", "", "disable-export", "", 1, "row-select"], [3, "matTooltip", "disabled", "checked", "click", "change", 4, "ngIf"], [3, "click", "change", "matTooltip", "disabled", "checked"], ["mat-header-row", "", "sticky", ""], ["mat-row", "", 3, "mouseover", "mouseleave"], [4, "matNoDataRow"], ["colspan", "99"], [3, "config"]], template: function MultiFunctionalTableComponent_Template(rf, ctx) { if (rf & 1) {
|
|
348
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
349
|
+
i0.ɵɵprojectionDef(_c0);
|
|
350
|
+
i0.ɵɵelementStart(0, "div", 2)(1, "div", 3)(2, "div", 4);
|
|
351
|
+
i0.ɵɵtemplate(3, MultiFunctionalTableComponent_button_3_Template, 6, 4, "button", 5)(4, MultiFunctionalTableComponent_button_4_Template, 6, 3, "button", 6)(5, MultiFunctionalTableComponent_button_5_Template, 6, 3, "button", 7);
|
|
352
|
+
i0.ɵɵelementEnd();
|
|
353
|
+
i0.ɵɵprojection(6);
|
|
354
|
+
i0.ɵɵelementEnd();
|
|
355
|
+
i0.ɵɵelementStart(7, "mat-menu", null, 0)(9, "div", 8);
|
|
356
|
+
i0.ɵɵlistener("click", function MultiFunctionalTableComponent_Template_div_click_9_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView($event.stopPropagation()); });
|
|
357
|
+
i0.ɵɵtemplate(10, MultiFunctionalTableComponent_div_10_Template, 4, 4, "div", 9);
|
|
358
|
+
i0.ɵɵelementEnd()();
|
|
359
|
+
i0.ɵɵtemplate(11, MultiFunctionalTableComponent_tld_filter_bar_11_Template, 1, 2, "tld-filter-bar", 10);
|
|
360
|
+
i0.ɵɵelementStart(12, "div", 11)(13, "table", 12, 1);
|
|
361
|
+
i0.ɵɵprojection(15, 1);
|
|
362
|
+
i0.ɵɵelementContainerStart(16, 13);
|
|
363
|
+
i0.ɵɵtemplate(17, MultiFunctionalTableComponent_th_17_Template, 3, 6, "th", 14)(18, MultiFunctionalTableComponent_td_18_Template, 2, 1, "td", 15);
|
|
364
|
+
i0.ɵɵelementContainerEnd();
|
|
365
|
+
i0.ɵɵtemplate(19, MultiFunctionalTableComponent_tr_19_Template, 1, 0, "tr", 16)(20, MultiFunctionalTableComponent_tr_20_Template, 1, 2, "tr", 17)(21, MultiFunctionalTableComponent_ng_container_21_Template, 2, 0, "ng-container", 18);
|
|
366
|
+
i0.ɵɵelementEnd()()();
|
|
367
|
+
} if (rf & 2) {
|
|
368
|
+
i0.ɵɵadvance(3);
|
|
369
|
+
i0.ɵɵproperty("ngIf", ctx.columnSelectActive);
|
|
370
|
+
i0.ɵɵadvance();
|
|
371
|
+
i0.ɵɵproperty("ngIf", ctx.filterActive && ctx.showFilterToggle);
|
|
372
|
+
i0.ɵɵadvance();
|
|
373
|
+
i0.ɵɵproperty("ngIf", ctx.exportActive);
|
|
374
|
+
i0.ɵɵadvance(5);
|
|
375
|
+
i0.ɵɵproperty("ngForOf", ctx.configurableColumns);
|
|
376
|
+
i0.ɵɵadvance();
|
|
377
|
+
i0.ɵɵproperty("ngIf", ctx.config.filter && ctx.config.filter.enabled);
|
|
378
|
+
i0.ɵɵadvance(2);
|
|
379
|
+
i0.ɵɵproperty("dataSource", ctx.config.dataSource);
|
|
380
|
+
i0.ɵɵadvance(3);
|
|
381
|
+
i0.ɵɵproperty("matColumnDef", ctx.batchColumnName);
|
|
382
|
+
i0.ɵɵadvance(3);
|
|
383
|
+
i0.ɵɵproperty("matHeaderRowDef", ctx.displayColumns);
|
|
384
|
+
i0.ɵɵadvance();
|
|
385
|
+
i0.ɵɵproperty("matRowDefColumns", ctx.displayColumns);
|
|
386
|
+
i0.ɵɵadvance();
|
|
387
|
+
i0.ɵɵproperty("ngIf", ctx.noDataRowActive);
|
|
388
|
+
} }, dependencies: [i3.NgForOf, i3.NgIf, i4.MatTable, i4.MatHeaderCellDef, i4.MatHeaderRowDef, i4.MatColumnDef, i4.MatCellDef, i4.MatRowDef, i4.MatHeaderCell, i4.MatCell, i4.MatHeaderRow, i4.MatRow, i4.MatNoDataRow, i5.MatButton, i6.MatMenu, i6.MatMenuTrigger, i7.MatCheckbox, i8.NgControlStatus, i8.NgModel, i9.FilterBarComponent, i10.DefaultLayoutDirective, i10.DefaultLayoutGapDirective, i10.DefaultFlexDirective, i11.MatTooltip, i12.StatusDisplayComponent, i2.TranslatePipe], styles: ["[_nghost-%COMP%] th, [_nghost-%COMP%] tr{white-space:nowrap}[_nghost-%COMP%] td:not(:first-of-type){padding-right:10px!important}[_nghost-%COMP%] tr.mat-mdc-row:hover, [_nghost-%COMP%] tr.mat-mdc-row.highlight{background-color:var(--base-95)}[_nghost-%COMP%] .export-data .mdc-button__label{display:flex;align-items:center}[_nghost-%COMP%] .mat-mdc-cell, [_nghost-%COMP%] .mat-mdc-header-cell, [_nghost-%COMP%] .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}[_nghost-%COMP%] .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}[_nghost-%COMP%] .mdc-data-table__cell:nth-child(2), [_nghost-%COMP%] .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}table[_ngcontent-%COMP%]{width:100%}.column-select-icon[_ngcontent-%COMP%]{rotate:90deg}.column-select-wrapper[_ngcontent-%COMP%]{padding:1rem}.material-icons[_ngcontent-%COMP%], .material-icons-outlined[_ngcontent-%COMP%]{margin-right:.5rem}.table-action-button[_ngcontent-%COMP%]{margin-bottom:1rem}th.mat-mdc-header-cell[_ngcontent-%COMP%]:first-of-type, td.mat-mdc-cell[_ngcontent-%COMP%]:first-of-type, td.mat-mdc-footer-cell[_ngcontent-%COMP%]:first-of-type{padding:0 0 0 10px}.row-select[_ngcontent-%COMP%]{width:0}.table-overflow[_ngcontent-%COMP%]{overflow-x:auto}"] }); }
|
|
188
389
|
}
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-functional-table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.ts","../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { AfterContentInit, AfterViewInit, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild } from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatColumnDef, MatHeaderRowDef, MatNoDataRow, MatRowDef, MatTable } from '@angular/material/table';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { map, Observable, take } from 'rxjs';\r\nimport { FilterBarChangeEvent } from '../filter-bar/models/filter-bar-change-event.model';\r\nimport { HtmlElementParseHelper } from '../helpers';\r\nimport { SaveFileHelper } from '../helpers/save-file.helper';\r\nimport { DOMService } from '../services';\r\nimport { DISABLE_EXPORT_ATTRIBUTE_NAME } from './constants/disable-export-attribute-name.const';\r\nimport { ExportFormat } from './models';\r\nimport { ColumnConfig } from './models/column-config.model';\r\nimport { MultiFunctionalTableConfig } from './models/multi-functional-table-config.model';\r\nimport { SelectedColumnLocalStorageConfig } from './models/selected-column-local-storage-config.model';\r\nimport { StatusDisplayConfig } from '../status-display/models/status-display-config.model';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-multi-functional-table',\r\n  templateUrl: './multi-functional-table.component.html',\r\n  styleUrls: ['./multi-functional-table.component.scss']\r\n})\r\nexport class MultiFunctionalTableComponent<T> implements OnInit, AfterContentInit, AfterViewInit {\r\n  readonly matSelection = new SelectionModel<T>(true, []);\r\n\r\n  @Input() config!: MultiFunctionalTableConfig<T>;\r\n  @Input() highlightedElements!: T[];\r\n  @Input() set selection(value: T[]) {\r\n    this.matSelection.setSelection(...(value ?? []));\r\n  }\r\n\r\n  // Set this to false if you want to display checkboxes only on row hover.\r\n  @Input() isRowCheckboxAlwaysVisible = true;\r\n\r\n  //#region Output properties\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n  @Output() exported: EventEmitter<T[]> = new EventEmitter<T[]>();\r\n  @Output() selectionChange: Observable<T[]> = this.matSelection.changed.asObservable().pipe(map(() => { return this.matSelection.selected; }));\r\n  //#endregion\r\n\r\n  // #region Properties for mat table wrapper\r\n  @ContentChildren(MatHeaderRowDef) headerRowDefs!: QueryList<MatHeaderRowDef>;\r\n  @ContentChildren(MatRowDef, { descendants: true }) rowDefs!: QueryList<MatRowDef<T>>;\r\n  @ContentChildren(MatColumnDef) columnDefs!: QueryList<MatColumnDef>;\r\n  @ContentChild(MatNoDataRow) noDataRow!: MatNoDataRow;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<T>;\r\n  @ViewChild(MatSort) sort!: MatSort;\r\n  //#endregion\r\n\r\n  @ViewChild(MatTable, { read: ElementRef }) tableElementRef!: ElementRef<HTMLElement>;\r\n\r\n\r\n  get ignoreAttributeName() { return DISABLE_EXPORT_ATTRIBUTE_NAME }\r\n  displayColumns!: string[];\r\n\r\n  columnSelectActive!: boolean;\r\n  exportActive!: boolean;\r\n  noDataRowActive!: boolean;\r\n\r\n  filterBarVisible!: boolean;\r\n\r\n  noDataRowConfig!: StatusDisplayConfig;\r\n  noDataRowIcon = \"manage_search\";\r\n\r\n  configurableColumns!: ColumnConfig[];\r\n  batchSelectedEnabled!: boolean;\r\n\r\n  // is used in html to display batch checkbox on hovered row\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  hoveredRow: any;\r\n\r\n  get filterActive() { return this.config.filter?.enabled; }\r\n\r\n  private localStorageValue!: SelectedColumnLocalStorageConfig;\r\n  readonly batchColumnName = \"batch\";\r\n\r\n  constructor(private readonly domService: DOMService,\r\n    private readonly translateService: TranslateService) { }\r\n\r\n  //#region Angular lifecycle hooks\r\n  ngOnInit(): void {\r\n    this.readFromLocalStorage();\r\n    this.setFilterVisibility();\r\n    this.setColumnSelectProperties();\r\n    this.setExportProperties();\r\n    this.setNoDataRowProperties();\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.columnDefs.forEach(columnDef => this.table.addColumnDef(columnDef));\r\n    this.rowDefs.forEach(rowDef => this.table.addRowDef(rowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.table.setNoDataRow(this.noDataRow);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.config.dataSource.sort = this.sort;\r\n  }\r\n  //#endregion\r\n\r\n  updateDisplayColumns(initial = false) {\r\n    this.batchSelectedEnabled = this.config.batchConfig?.enabled ? true : false;\r\n    const allColumns = this.config.columnSelect?.columns ?? [];\r\n    this.displayColumns = [];\r\n    this.configurableColumns = allColumns.filter(column => !column.notConfigurable);\r\n\r\n    if (this.batchSelectedEnabled) {\r\n      this.displayColumns.push(this.batchColumnName);\r\n    }\r\n\r\n    if (!allColumns.length) {\r\n      return;\r\n    }\r\n\r\n    const localStorageValue = this.localStorageValue ?? {};\r\n    if (!localStorageValue.columns) {\r\n      localStorageValue.columns = {};\r\n    }\r\n\r\n    allColumns.forEach((column) => {\r\n      if (initial) {\r\n        column.selected = localStorageValue.columns?.[column.name] ?? column.selected;\r\n      }\r\n      else {\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        localStorageValue.columns![column.name] = column.selected;\r\n      }\r\n      if (column.selected) {\r\n        this.displayColumns.push(column.name);\r\n      }\r\n    })\r\n    if (!initial) {\r\n      this.updateLocalStorage(localStorageValue);\r\n    }\r\n  }\r\n\r\n  toggleFilterBar() {\r\n    const localstorageObject = this.localStorageValue ?? {};\r\n    if (!localstorageObject.filter) {\r\n      localstorageObject.filter = {};\r\n    }\r\n\r\n    this.filterBarVisible = !this.filterBarVisible;\r\n    localstorageObject.filter.visible = this.filterBarVisible;\r\n    this.updateLocalStorage(localstorageObject);\r\n  }\r\n\r\n  filtersChanged(filters: FilterBarChangeEvent) {\r\n    this.filterBarChange.emit(filters);\r\n  }\r\n\r\n  export() {\r\n    this.config.dataSource.connect().pipe(take(1)).subscribe((data) => {\r\n      this.exported.emit(data);\r\n    })\r\n\r\n    if (this.config.export?.fileOptions) {\r\n      this.exportToFile()\r\n    }\r\n  }\r\n\r\n  highlightElement(element: T) {\r\n    return this.highlightedElements?.includes(element);\r\n  }\r\n\r\n  //#region Methods for batch selection\r\n  isAllSelected() {\r\n    const numSelected = this.matSelection.selected.length;\r\n    const numRows = this.config.dataSource.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  toggleAllRowSelection() {\r\n    if (this.isAllSelected()) {\r\n      this.matSelection.clear();\r\n      return;\r\n    }\r\n\r\n    this.matSelection.select(...this.config.dataSource.data);\r\n  }\r\n\r\n  toggleElementSelection(element: T) {\r\n    this.matSelection.toggle(element);\r\n  }\r\n  //#endregion\r\n\r\n  private exportToFile() {\r\n    if (!this.config.export?.fileOptions?.saveToFile) {\r\n      return;\r\n    }\r\n\r\n    let fileString = \"\";\r\n    let extension!: ExportFormat;\r\n    switch (this.config.export.fileOptions.format) {\r\n      case ExportFormat.CSV:\r\n      default:\r\n        extension = ExportFormat.CSV;\r\n        fileString = HtmlElementParseHelper.tableAsCsv(this.tableElementRef.nativeElement, this.ignoreAttributeName);\r\n        break;\r\n    }\r\n    const translatedFileName = this.translateService.instant(this.config.export.fileOptions.fileName);\r\n    SaveFileHelper.saveFile(fileString, `${translatedFileName}.${extension}`);\r\n  }\r\n\r\n  private updateLocalStorage(newValue: SelectedColumnLocalStorageConfig) {\r\n    this.localStorageValue = newValue;\r\n    if (this.config.localStorageKey && newValue) {\r\n      this.domService.localStorage?.setItem(this.config.localStorageKey, JSON.stringify(newValue));\r\n    }\r\n  }\r\n  private readFromLocalStorage() {\r\n    if (this.config.localStorageKey) {\r\n      try {\r\n        const localStorageString = this.domService.localStorage?.getItem(this.config.localStorageKey);\r\n        if (localStorageString) {\r\n          this.localStorageValue = JSON.parse(localStorageString);\r\n        }\r\n      }\r\n      // eslint-disable-next-line no-empty\r\n      catch {\r\n      }\r\n    }\r\n  }\r\n\r\n  private setColumnSelectProperties() {\r\n    this.columnSelectActive = this.config.columnSelect?.enabled ? true : false;\r\n    this.updateDisplayColumns(true);\r\n  }\r\n\r\n  private setFilterVisibility() {\r\n    this.filterBarVisible = this.localStorageValue?.filter?.visible ?? this.config?.filter?.visible ?? false;\r\n  }\r\n\r\n  private setNoDataRowProperties() {\r\n    if (this.config.noDataRow) {\r\n      this.noDataRowActive = true;\r\n      this.noDataRowConfig = this.config.noDataRow;\r\n      this.noDataRowConfig.icon = this.config.noDataRow?.icon ?? this.noDataRowIcon;\r\n    }\r\n  }\r\n\r\n  private setExportProperties() {\r\n    if (this.config.export?.enabled) {\r\n      this.exportActive = true;\r\n    }\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxLayoutGap=\"1rem\">\r\n\r\n  <div fxLayout=\"row\">\r\n    <div fxFlex fxLayoutGap=\"1rem\">\r\n      <button mat-button [matMenuTriggerFor]=\"columnMenu\" *ngIf=\"columnSelectActive\">\r\n        <span class=\"material-icons column-select-icon\">menu</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT' | translate}}</span>\r\n      </button>\r\n\r\n       <button mat-button *ngIf=\"filterActive\" (click)=\"toggleFilterBar()\">\r\n        <span class=\"material-icons\">filter_list</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n      </button>\r\n\r\n      <button class=\"export-data\" mat-stroked-button *ngIf=\"exportActive\" (click)=\"export()\">\r\n        <span class=\"material-icons-outlined\">cloud_download</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n      </button>\r\n    </div>\r\n\r\n    <ng-content select=\"[additionalActions]\"></ng-content>\r\n  </div>\r\n\r\n  <mat-menu #columnMenu=\"matMenu\">\r\n    <div class=\"column-select-wrapper\" (click)=\"$event.stopPropagation()\">\r\n      <div *ngFor=\"let column of configurableColumns\">\r\n        <mat-checkbox [(ngModel)]=\"column.selected\" (change)=\"updateDisplayColumns()\">\r\n          {{column.displayName | translate}}\r\n        </mat-checkbox>\r\n      </div>\r\n    </div>\r\n  </mat-menu>\r\n\r\n  <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" [filterRowVisible]=\"!filterBarVisible\" [settings]=\"config.filter.settings\" \r\n    (filterBarChange)=\"filtersChanged($event)\">\r\n  </tld-filter-bar>\r\n\r\n  <div class=\"table-overflow\">\r\n    <table #table mat-table [dataSource]=\"config.dataSource\">\r\n      <ng-content></ng-content>\r\n      <ng-container [matColumnDef]=\"batchColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n            [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n            [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n          </mat-checkbox>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n          <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (click)=\"$event.stopPropagation()\"\r\n            (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n          </mat-checkbox>\r\n        </td>\r\n      </ng-container>\r\n      <tr mat-header-row *matHeaderRowDef=\"displayColumns\" sticky></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayColumns\" (mouseover)=\"hoveredRow = row\" (mouseleave)=\"hoveredRow = null\" [class.highlight]=\"highlightElement(row)\"></tr>\r\n\r\n      <ng-container *ngIf=\"noDataRowActive\">\r\n        <tr *matNoDataRow>\r\n          <!-- add random number to make sure it takes full width -->\r\n          <td colspan=\"99\">\r\n            <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n          </td>\r\n        </tr>\r\n      </ng-container>\r\n    </table>\r\n  </div>\r\n</div>\r\n"]}
|
|
390
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MultiFunctionalTableComponent, [{
|
|
391
|
+
type: Component,
|
|
392
|
+
args: [{ selector: 'tld-multi-functional-table', template: "<div fxLayout=\"column\" fxLayoutGap=\"1rem\">\r\n\r\n <div fxLayout=\"row\">\r\n <div fxFlex fxLayoutGap=\"1rem\">\r\n <button mat-button [matMenuTriggerFor]=\"columnMenu\" *ngIf=\"columnSelectActive\">\r\n <span class=\"material-icons column-select-icon\">menu</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT' | translate}}</span>\r\n </button>\r\n\r\n <button mat-button *ngIf=\"filterActive && showFilterToggle\" (click)=\"toggleFilterBar()\">\r\n <span class=\"material-icons\">filter_list</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n </button>\r\n\r\n <button class=\"export-data\" mat-stroked-button *ngIf=\"exportActive\" (click)=\"export()\">\r\n <span class=\"material-icons-outlined\">cloud_download</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n </button>\r\n </div>\r\n\r\n <ng-content select=\"[additionalActions]\"></ng-content>\r\n </div>\r\n\r\n <mat-menu #columnMenu=\"matMenu\">\r\n <div class=\"column-select-wrapper\" (click)=\"$event.stopPropagation()\">\r\n <div *ngFor=\"let column of configurableColumns\">\r\n <mat-checkbox [(ngModel)]=\"column.selected\" (change)=\"updateDisplayColumns()\">\r\n {{column.displayName | translate}}\r\n </mat-checkbox>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n\r\n <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" [filterRowVisible]=\"!filterBarVisible\" [settings]=\"config.filter.settings\" \r\n (filterBarChange)=\"filtersChanged($event)\">\r\n </tld-filter-bar>\r\n\r\n <div class=\"table-overflow\">\r\n <table #table mat-table [dataSource]=\"config.dataSource\">\r\n <ng-content></ng-content>\r\n <ng-container [matColumnDef]=\"batchColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n </mat-checkbox>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n <mat-checkbox \r\n [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"displayColumns\" sticky></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayColumns\" (mouseover)=\"hoveredRow = row\" (mouseleave)=\"hoveredRow = null\" [class.highlight]=\"highlightElement(row)\"></tr>\r\n\r\n <ng-container *ngIf=\"noDataRowActive\">\r\n <tr *matNoDataRow>\r\n <!-- add random number to make sure it takes full width -->\r\n <td colspan=\"99\">\r\n <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n</div>\r\n", styles: [":host ::ng-deep th,:host ::ng-deep tr{white-space:nowrap}:host ::ng-deep td:not(:first-of-type){padding-right:10px!important}:host ::ng-deep tr.mat-mdc-row:hover,:host ::ng-deep tr.mat-mdc-row.highlight{background-color:var(--base-95)}:host ::ng-deep .export-data .mdc-button__label{display:flex;align-items:center}:host ::ng-deep .mat-mdc-cell,:host ::ng-deep .mat-mdc-header-cell,:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}:host ::ng-deep .mdc-data-table__cell:nth-child(2),:host ::ng-deep .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}table{width:100%}.column-select-icon{rotate:90deg}.column-select-wrapper{padding:1rem}.material-icons,.material-icons-outlined{margin-right:.5rem}.table-action-button{margin-bottom:1rem}th.mat-mdc-header-cell:first-of-type,td.mat-mdc-cell:first-of-type,td.mat-mdc-footer-cell:first-of-type{padding:0 0 0 10px}.row-select{width:0}.table-overflow{overflow-x:auto}\n"] }]
|
|
393
|
+
}], () => [{ type: i1.DOMService }, { type: i2.TranslateService }], { config: [{
|
|
394
|
+
type: Input
|
|
395
|
+
}], highlightedElements: [{
|
|
396
|
+
type: Input
|
|
397
|
+
}], selection: [{
|
|
398
|
+
type: Input
|
|
399
|
+
}], isRowCheckboxAlwaysVisible: [{
|
|
400
|
+
type: Input
|
|
401
|
+
}], disablePreselectedItems: [{
|
|
402
|
+
type: Input
|
|
403
|
+
}], filterBarChange: [{
|
|
404
|
+
type: Output
|
|
405
|
+
}], exported: [{
|
|
406
|
+
type: Output
|
|
407
|
+
}], selectionChange: [{
|
|
408
|
+
type: Output
|
|
409
|
+
}], headerRowDefs: [{
|
|
410
|
+
type: ContentChildren,
|
|
411
|
+
args: [MatHeaderRowDef]
|
|
412
|
+
}], rowDefs: [{
|
|
413
|
+
type: ContentChildren,
|
|
414
|
+
args: [MatRowDef, { descendants: true }]
|
|
415
|
+
}], columnDefs: [{
|
|
416
|
+
type: ContentChildren,
|
|
417
|
+
args: [MatColumnDef]
|
|
418
|
+
}], noDataRow: [{
|
|
419
|
+
type: ContentChild,
|
|
420
|
+
args: [MatNoDataRow]
|
|
421
|
+
}], table: [{
|
|
422
|
+
type: ViewChild,
|
|
423
|
+
args: [MatTable, { static: true }]
|
|
424
|
+
}], sort: [{
|
|
425
|
+
type: ViewChild,
|
|
426
|
+
args: [MatSort]
|
|
427
|
+
}], tableElementRef: [{
|
|
428
|
+
type: ViewChild,
|
|
429
|
+
args: [MatTable, { read: ElementRef }]
|
|
430
|
+
}] }); })();
|
|
431
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MultiFunctionalTableComponent, { className: "MultiFunctionalTableComponent", filePath: "lib\\multi-functional-table\\multi-functional-table.component.ts", lineNumber: 24 }); })();
|
|
432
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-functional-table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.ts","../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { AfterContentInit, AfterViewInit, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild } from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatColumnDef, MatHeaderRowDef, MatNoDataRow, MatRowDef, MatTable } from '@angular/material/table';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { map, Observable, take } from 'rxjs';\r\nimport { FilterBarChangeEvent } from '../filter-bar/models/filter-bar-change-event.model';\r\nimport { HtmlElementParseHelper } from '../helpers';\r\nimport { SaveFileHelper } from '../helpers/save-file.helper';\r\nimport { DOMService } from '../services';\r\nimport { DISABLE_EXPORT_ATTRIBUTE_NAME } from './constants/disable-export-attribute-name.const';\r\nimport { ExportFormat } from './models';\r\nimport { ColumnConfig } from './models/column-config.model';\r\nimport { MultiFunctionalTableConfig } from './models/multi-functional-table-config.model';\r\nimport { SelectedColumnLocalStorageConfig } from './models/selected-column-local-storage-config.model';\r\nimport { StatusDisplayConfig } from '../status-display/models/status-display-config.model';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-multi-functional-table',\r\n  templateUrl: './multi-functional-table.component.html',\r\n  styleUrls: ['./multi-functional-table.component.scss']\r\n})\r\nexport class MultiFunctionalTableComponent<T> implements OnInit, AfterContentInit, AfterViewInit {\r\n  readonly matSelection = new SelectionModel<T>(true, []);\r\n\r\n  @Input() config!: MultiFunctionalTableConfig<T>;\r\n  @Input() highlightedElements!: T[];\r\n  @Input() set selection(value: T[]) {\r\n    this.matSelection.setSelection(...(value ?? []));\r\n  }\r\n\r\n  // Set this to false if you want to display checkboxes only on row hover.\r\n  @Input() isRowCheckboxAlwaysVisible = true;\r\n\r\n  @Input() disablePreselectedItems = false;\r\n\r\n  //#region Output properties\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n  @Output() exported: EventEmitter<T[]> = new EventEmitter<T[]>();\r\n  @Output() selectionChange: Observable<T[]> = this.matSelection.changed.asObservable().pipe(map(() => { return this.matSelection.selected; }));\r\n  //#endregion\r\n\r\n  // #region Properties for mat table wrapper\r\n  @ContentChildren(MatHeaderRowDef) headerRowDefs!: QueryList<MatHeaderRowDef>;\r\n  @ContentChildren(MatRowDef, { descendants: true }) rowDefs!: QueryList<MatRowDef<T>>;\r\n  @ContentChildren(MatColumnDef) columnDefs!: QueryList<MatColumnDef>;\r\n  @ContentChild(MatNoDataRow) noDataRow!: MatNoDataRow;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<T>;\r\n  @ViewChild(MatSort) sort!: MatSort;\r\n  //#endregion\r\n\r\n  @ViewChild(MatTable, { read: ElementRef }) tableElementRef!: ElementRef<HTMLElement>;\r\n\r\n  preselectedItems!: T[];\r\n\r\n  get ignoreAttributeName() { return DISABLE_EXPORT_ATTRIBUTE_NAME }\r\n  displayColumns!: string[];\r\n\r\n  columnSelectActive!: boolean;\r\n  exportActive!: boolean;\r\n  noDataRowActive!: boolean;\r\n\r\n  filterBarVisible!: boolean;\r\n\r\n  noDataRowConfig!: StatusDisplayConfig;\r\n  noDataRowIcon = \"manage_search\";\r\n\r\n  configurableColumns!: ColumnConfig[];\r\n  batchSelectedEnabled!: boolean;\r\n\r\n  // is used in html to display batch checkbox on hovered row\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  hoveredRow: any;\r\n\r\n  get filterActive() { return this.config.filter?.enabled; }\r\n  get showFilterToggle() { return !this.config.filter?.hideFilterToggle; }\r\n\r\n  private localStorageValue!: SelectedColumnLocalStorageConfig;\r\n  readonly batchColumnName = \"batch\";\r\n\r\n  constructor(private readonly domService: DOMService,\r\n    private readonly translateService: TranslateService) { }\r\n\r\n  //#region Angular lifecycle hooks\r\n  ngOnInit(): void {\r\n    this.readFromLocalStorage();\r\n    this.setFilterVisibility();\r\n    this.setColumnSelectProperties();\r\n    this.setExportProperties();\r\n    this.setNoDataRowProperties();\r\n    this.preselectedItems = this.matSelection.selected;\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.columnDefs.forEach(columnDef => this.table.addColumnDef(columnDef));\r\n    this.rowDefs.forEach(rowDef => this.table.addRowDef(rowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.table.setNoDataRow(this.noDataRow);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.config.dataSource.sort = this.sort;\r\n  }\r\n  //#endregion\r\n\r\n  updateDisplayColumns(initial = false) {\r\n    this.batchSelectedEnabled = this.config.batchConfig?.enabled ? true : false;\r\n    const allColumns = this.config.columnSelect?.columns ?? [];\r\n    this.displayColumns = [];\r\n    this.configurableColumns = allColumns.filter(column => !column.notConfigurable);\r\n\r\n    if (this.batchSelectedEnabled) {\r\n      this.displayColumns.push(this.batchColumnName);\r\n    }\r\n\r\n    if (!allColumns.length) {\r\n      return;\r\n    }\r\n\r\n    const localStorageValue = this.localStorageValue ?? {};\r\n    if (!localStorageValue.columns) {\r\n      localStorageValue.columns = {};\r\n    }\r\n\r\n    allColumns.forEach((column) => {\r\n      if (initial) {\r\n        column.selected = localStorageValue.columns?.[column.name] ?? column.selected;\r\n      }\r\n      else {\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        localStorageValue.columns![column.name] = column.selected;\r\n      }\r\n      if (column.selected) {\r\n        this.displayColumns.push(column.name);\r\n      }\r\n    })\r\n    if (!initial) {\r\n      this.updateLocalStorage(localStorageValue);\r\n    }\r\n  }\r\n\r\n  toggleFilterBar() {\r\n    const localstorageObject = this.localStorageValue ?? {};\r\n    if (!localstorageObject.filter) {\r\n      localstorageObject.filter = {};\r\n    }\r\n\r\n    this.filterBarVisible = !this.filterBarVisible;\r\n    localstorageObject.filter.visible = this.filterBarVisible;\r\n    this.updateLocalStorage(localstorageObject);\r\n  }\r\n\r\n  filtersChanged(filters: FilterBarChangeEvent) {\r\n    this.filterBarChange.emit(filters);\r\n  }\r\n\r\n  export() {\r\n    this.config.dataSource.connect().pipe(take(1)).subscribe((data) => {\r\n      this.exported.emit(data);\r\n    })\r\n\r\n    if (this.config.export?.fileOptions) {\r\n      this.exportToFile()\r\n    }\r\n  }\r\n\r\n  highlightElement(element: T) {\r\n    return this.highlightedElements?.includes(element);\r\n  }\r\n\r\n  //#region Methods for batch selection\r\n  isAllSelected() {\r\n    const numSelected = this.matSelection.selected.length;\r\n    const numRows = this.config.dataSource.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  toggleAllRowSelection() {\r\n    if (this.isAllSelected()) {\r\n      if (this.disablePreselectedItems) {\r\n        // deselect only those items which were not already preselected\r\n        this.matSelection.deselect(\r\n          ...this.matSelection.selected.filter(elm => !this.preselectedItems.map(elm => elm).includes(elm))\r\n        );\r\n        return;\r\n      }\r\n      else {\r\n        this.matSelection.clear();\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.matSelection.select(...this.config.dataSource.data);\r\n  }\r\n\r\n  toggleElementSelection(element: T) {\r\n    this.matSelection.toggle(element);\r\n  }\r\n  //#endregion\r\n\r\n  private exportToFile() {\r\n    if (!this.config.export?.fileOptions?.saveToFile) {\r\n      return;\r\n    }\r\n\r\n    let fileString = \"\";\r\n    let extension!: ExportFormat;\r\n    switch (this.config.export.fileOptions.format) {\r\n      case ExportFormat.CSV:\r\n      default:\r\n        extension = ExportFormat.CSV;\r\n        fileString = HtmlElementParseHelper.tableAsCsv(this.tableElementRef.nativeElement, this.ignoreAttributeName);\r\n        break;\r\n    }\r\n    const translatedFileName = this.translateService.instant(this.config.export.fileOptions.fileName);\r\n    SaveFileHelper.saveFile(fileString, `${translatedFileName}.${extension}`);\r\n  }\r\n\r\n  private updateLocalStorage(newValue: SelectedColumnLocalStorageConfig) {\r\n    this.localStorageValue = newValue;\r\n    if (this.config.localStorageKey && newValue) {\r\n      this.domService.localStorage?.setItem(this.config.localStorageKey, JSON.stringify(newValue));\r\n    }\r\n  }\r\n  private readFromLocalStorage() {\r\n    if (this.config.localStorageKey) {\r\n      try {\r\n        const localStorageString = this.domService.localStorage?.getItem(this.config.localStorageKey);\r\n        if (localStorageString) {\r\n          this.localStorageValue = JSON.parse(localStorageString);\r\n        }\r\n      }\r\n      // eslint-disable-next-line no-empty\r\n      catch {\r\n      }\r\n    }\r\n  }\r\n\r\n  private setColumnSelectProperties() {\r\n    this.columnSelectActive = this.config.columnSelect?.enabled ? true : false;\r\n    this.updateDisplayColumns(true);\r\n  }\r\n\r\n  private setFilterVisibility() {\r\n    this.filterBarVisible = this.localStorageValue?.filter?.visible ?? this.config?.filter?.visible ?? false;\r\n  }\r\n\r\n  private setNoDataRowProperties() {\r\n    if (this.config.noDataRow) {\r\n      this.noDataRowActive = true;\r\n      this.noDataRowConfig = this.config.noDataRow;\r\n      this.noDataRowConfig.icon = this.config.noDataRow?.icon ?? this.noDataRowIcon;\r\n    }\r\n  }\r\n\r\n  private setExportProperties() {\r\n    if (this.config.export?.enabled) {\r\n      this.exportActive = true;\r\n    }\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxLayoutGap=\"1rem\">\r\n\r\n  <div fxLayout=\"row\">\r\n    <div fxFlex fxLayoutGap=\"1rem\">\r\n      <button mat-button [matMenuTriggerFor]=\"columnMenu\" *ngIf=\"columnSelectActive\">\r\n        <span class=\"material-icons column-select-icon\">menu</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT' | translate}}</span>\r\n      </button>\r\n\r\n       <button mat-button *ngIf=\"filterActive && showFilterToggle\" (click)=\"toggleFilterBar()\">\r\n        <span class=\"material-icons\">filter_list</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n      </button>\r\n\r\n      <button class=\"export-data\" mat-stroked-button *ngIf=\"exportActive\" (click)=\"export()\">\r\n        <span class=\"material-icons-outlined\">cloud_download</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n      </button>\r\n    </div>\r\n\r\n    <ng-content select=\"[additionalActions]\"></ng-content>\r\n  </div>\r\n\r\n  <mat-menu #columnMenu=\"matMenu\">\r\n    <div class=\"column-select-wrapper\" (click)=\"$event.stopPropagation()\">\r\n      <div *ngFor=\"let column of configurableColumns\">\r\n        <mat-checkbox [(ngModel)]=\"column.selected\" (change)=\"updateDisplayColumns()\">\r\n          {{column.displayName | translate}}\r\n        </mat-checkbox>\r\n      </div>\r\n    </div>\r\n  </mat-menu>\r\n\r\n  <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" [filterRowVisible]=\"!filterBarVisible\" [settings]=\"config.filter.settings\" \r\n    (filterBarChange)=\"filtersChanged($event)\">\r\n  </tld-filter-bar>\r\n\r\n  <div class=\"table-overflow\">\r\n    <table #table mat-table [dataSource]=\"config.dataSource\">\r\n      <ng-content></ng-content>\r\n      <ng-container [matColumnDef]=\"batchColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n            [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n            [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n          </mat-checkbox>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n          <mat-checkbox \r\n            [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n            [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n            (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n          </mat-checkbox>\r\n        </td>\r\n      </ng-container>\r\n      <tr mat-header-row *matHeaderRowDef=\"displayColumns\" sticky></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayColumns\" (mouseover)=\"hoveredRow = row\" (mouseleave)=\"hoveredRow = null\" [class.highlight]=\"highlightElement(row)\"></tr>\r\n\r\n      <ng-container *ngIf=\"noDataRowActive\">\r\n        <tr *matNoDataRow>\r\n          <!-- add random number to make sure it takes full width -->\r\n          <td colspan=\"99\">\r\n            <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n          </td>\r\n        </tr>\r\n      </ng-container>\r\n    </table>\r\n  </div>\r\n</div>\r\n"]}
|