@tilde-nlp/ngx-common 5.0.2 → 5.0.4
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 +187 -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 +2844 -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 +25 -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
|
@@ -15,6 +15,153 @@ import * as i11 from "@angular/material/button";
|
|
|
15
15
|
import * as i12 from "@angular/material/chips";
|
|
16
16
|
import * as i13 from "@angular/material/icon";
|
|
17
17
|
import * as i14 from "../pipes/sort-translations-by-property/sort-translations-by-property.pipe";
|
|
18
|
+
const _c0 = ["filterWrapper"];
|
|
19
|
+
const _c1 = (a0, a1) => ({ "hidden": a0, "engine-filter": a1 });
|
|
20
|
+
const _c2 = a0 => ({ default: a0 });
|
|
21
|
+
function FilterBarComponent_div_0_mat_form_field_3_span_3_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
+
i0.ɵɵelementStart(0, "span", 13);
|
|
23
|
+
i0.ɵɵpipe(1, "translate");
|
|
24
|
+
i0.ɵɵtext(2);
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
} if (rf & 2) {
|
|
27
|
+
const ctx_r0 = i0.ɵɵnextContext(3);
|
|
28
|
+
i0.ɵɵproperty("matTooltip", i0.ɵɵpipeBind1(1, 2, ctx_r0.searchTooltip));
|
|
29
|
+
i0.ɵɵadvance(2);
|
|
30
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r0.suffixIcon, " ");
|
|
31
|
+
} }
|
|
32
|
+
function FilterBarComponent_div_0_mat_form_field_3_Template(rf, ctx) { if (rf & 1) {
|
|
33
|
+
i0.ɵɵelementStart(0, "mat-form-field", 9)(1, "span", 10);
|
|
34
|
+
i0.ɵɵtext(2);
|
|
35
|
+
i0.ɵɵelementEnd();
|
|
36
|
+
i0.ɵɵtemplate(3, FilterBarComponent_div_0_mat_form_field_3_span_3_Template, 3, 4, "span", 11);
|
|
37
|
+
i0.ɵɵelement(4, "input", 12);
|
|
38
|
+
i0.ɵɵpipe(5, "translate");
|
|
39
|
+
i0.ɵɵelementEnd();
|
|
40
|
+
} if (rf & 2) {
|
|
41
|
+
const ctx_r0 = i0.ɵɵnextContext(2);
|
|
42
|
+
i0.ɵɵadvance(2);
|
|
43
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r0.prefixIcon, " ");
|
|
44
|
+
i0.ɵɵadvance();
|
|
45
|
+
i0.ɵɵproperty("ngIf", ctx_r0.showSuffixIcon);
|
|
46
|
+
i0.ɵɵadvance();
|
|
47
|
+
i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(5, 4, ctx_r0.searchTitle))("formControlName", ctx_r0.inputFormControlName);
|
|
48
|
+
} }
|
|
49
|
+
function FilterBarComponent_div_0_mat_form_field_5_ng_container_5_mat_option_1_Template(rf, ctx) { if (rf & 1) {
|
|
50
|
+
i0.ɵɵelementStart(0, "mat-option", 18);
|
|
51
|
+
i0.ɵɵtext(1);
|
|
52
|
+
i0.ɵɵpipe(2, "titlecase");
|
|
53
|
+
i0.ɵɵpipe(3, "translate");
|
|
54
|
+
i0.ɵɵelementEnd();
|
|
55
|
+
} if (rf & 2) {
|
|
56
|
+
const value_r2 = ctx.$implicit;
|
|
57
|
+
i0.ɵɵproperty("value", value_r2);
|
|
58
|
+
i0.ɵɵadvance();
|
|
59
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(3, 4, value_r2.key, i0.ɵɵpureFunction1(7, _c2, i0.ɵɵpipeBind1(2, 2, value_r2.value))), " ");
|
|
60
|
+
} }
|
|
61
|
+
function FilterBarComponent_div_0_mat_form_field_5_ng_container_5_Template(rf, ctx) { if (rf & 1) {
|
|
62
|
+
i0.ɵɵelementContainerStart(0);
|
|
63
|
+
i0.ɵɵtemplate(1, FilterBarComponent_div_0_mat_form_field_5_ng_container_5_mat_option_1_Template, 4, 9, "mat-option", 17);
|
|
64
|
+
i0.ɵɵpipe(2, "sortTranslationsByProperty");
|
|
65
|
+
i0.ɵɵelementContainerEnd();
|
|
66
|
+
} if (rf & 2) {
|
|
67
|
+
const filter_r3 = i0.ɵɵnextContext().$implicit;
|
|
68
|
+
i0.ɵɵadvance();
|
|
69
|
+
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind2(2, 1, filter_r3.values, "key"));
|
|
70
|
+
} }
|
|
71
|
+
function FilterBarComponent_div_0_mat_form_field_5_Template(rf, ctx) { if (rf & 1) {
|
|
72
|
+
i0.ɵɵelementStart(0, "mat-form-field", 14)(1, "mat-label");
|
|
73
|
+
i0.ɵɵtext(2);
|
|
74
|
+
i0.ɵɵpipe(3, "translate");
|
|
75
|
+
i0.ɵɵelementEnd();
|
|
76
|
+
i0.ɵɵelementStart(4, "mat-select", 15);
|
|
77
|
+
i0.ɵɵtemplate(5, FilterBarComponent_div_0_mat_form_field_5_ng_container_5_Template, 3, 4, "ng-container", 16);
|
|
78
|
+
i0.ɵɵelementEnd()();
|
|
79
|
+
} if (rf & 2) {
|
|
80
|
+
const filter_r3 = ctx.$implicit;
|
|
81
|
+
const i_r4 = ctx.index;
|
|
82
|
+
const ctx_r0 = i0.ɵɵnextContext(2);
|
|
83
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(6, _c1, ctx_r0.filterOverflow && ctx_r0.activeFilterIndex !== i_r4, !ctx_r0.filterOverflow));
|
|
84
|
+
i0.ɵɵadvance(2);
|
|
85
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 4, filter_r3.title));
|
|
86
|
+
i0.ɵɵadvance(2);
|
|
87
|
+
i0.ɵɵproperty("formControlName", filter_r3.fieldName);
|
|
88
|
+
i0.ɵɵadvance();
|
|
89
|
+
i0.ɵɵproperty("ngIf", filter_r3.values.length);
|
|
90
|
+
} }
|
|
91
|
+
function FilterBarComponent_div_0_button_6_Template(rf, ctx) { if (rf & 1) {
|
|
92
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
93
|
+
i0.ɵɵelementStart(0, "button", 19);
|
|
94
|
+
i0.ɵɵlistener("click", function FilterBarComponent_div_0_button_6_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r0 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r0.switchLeft()); });
|
|
95
|
+
i0.ɵɵelementStart(1, "span", 20);
|
|
96
|
+
i0.ɵɵtext(2, " arrow_back_ios ");
|
|
97
|
+
i0.ɵɵelementEnd()();
|
|
98
|
+
} }
|
|
99
|
+
function FilterBarComponent_div_0_button_7_Template(rf, ctx) { if (rf & 1) {
|
|
100
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
101
|
+
i0.ɵɵelementStart(0, "button", 19);
|
|
102
|
+
i0.ɵɵlistener("click", function FilterBarComponent_div_0_button_7_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r0 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r0.switchRight()); });
|
|
103
|
+
i0.ɵɵelementStart(1, "span", 20);
|
|
104
|
+
i0.ɵɵtext(2, " arrow_forward_ios ");
|
|
105
|
+
i0.ɵɵelementEnd()();
|
|
106
|
+
} }
|
|
107
|
+
function FilterBarComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
108
|
+
i0.ɵɵelementStart(0, "div", 3)(1, "div", 4, 0);
|
|
109
|
+
i0.ɵɵtemplate(3, FilterBarComponent_div_0_mat_form_field_3_Template, 6, 6, "mat-form-field", 5);
|
|
110
|
+
i0.ɵɵelementContainerStart(4, 6);
|
|
111
|
+
i0.ɵɵtemplate(5, FilterBarComponent_div_0_mat_form_field_5_Template, 6, 9, "mat-form-field", 7);
|
|
112
|
+
i0.ɵɵelementContainerEnd();
|
|
113
|
+
i0.ɵɵelementEnd();
|
|
114
|
+
i0.ɵɵtemplate(6, FilterBarComponent_div_0_button_6_Template, 3, 0, "button", 8)(7, FilterBarComponent_div_0_button_7_Template, 3, 0, "button", 8);
|
|
115
|
+
i0.ɵɵelementEnd();
|
|
116
|
+
} if (rf & 2) {
|
|
117
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
118
|
+
i0.ɵɵadvance();
|
|
119
|
+
i0.ɵɵproperty("formGroup", ctx_r0.form);
|
|
120
|
+
i0.ɵɵadvance(2);
|
|
121
|
+
i0.ɵɵproperty("ngIf", ctx_r0.showSearch && !ctx_r0.filterOverflow || ctx_r0.activeFilterIndex === ctx_r0.searchIndex);
|
|
122
|
+
i0.ɵɵadvance();
|
|
123
|
+
i0.ɵɵproperty("formGroup", ctx_r0.filterFormGroup);
|
|
124
|
+
i0.ɵɵadvance();
|
|
125
|
+
i0.ɵɵproperty("ngForOf", ctx_r0.settings == null ? null : ctx_r0.settings.filters);
|
|
126
|
+
i0.ɵɵadvance();
|
|
127
|
+
i0.ɵɵproperty("ngIf", ctx_r0.filterOverflow);
|
|
128
|
+
i0.ɵɵadvance();
|
|
129
|
+
i0.ɵɵproperty("ngIf", ctx_r0.filterOverflow);
|
|
130
|
+
} }
|
|
131
|
+
function FilterBarComponent_div_2_mat_chip_option_1_Template(rf, ctx) { if (rf & 1) {
|
|
132
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
133
|
+
i0.ɵɵelementStart(0, "mat-chip-option", 22);
|
|
134
|
+
i0.ɵɵlistener("removed", function FilterBarComponent_div_2_mat_chip_option_1_Template_mat_chip_option_removed_0_listener() { const ix_r8 = i0.ɵɵrestoreView(_r7).index; const filter_r9 = i0.ɵɵnextContext().$implicit; const ctx_r0 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r0.removeFilter(filter_r9.fieldName, ix_r8)); });
|
|
135
|
+
i0.ɵɵelementStart(1, "button", 23)(2, "mat-icon");
|
|
136
|
+
i0.ɵɵtext(3, "close");
|
|
137
|
+
i0.ɵɵelementEnd()();
|
|
138
|
+
i0.ɵɵelementStart(4, "span", 24);
|
|
139
|
+
i0.ɵɵtext(5);
|
|
140
|
+
i0.ɵɵpipe(6, "translate");
|
|
141
|
+
i0.ɵɵelementEnd();
|
|
142
|
+
i0.ɵɵelementStart(7, "span", 25);
|
|
143
|
+
i0.ɵɵtext(8);
|
|
144
|
+
i0.ɵɵpipe(9, "titlecase");
|
|
145
|
+
i0.ɵɵpipe(10, "translate");
|
|
146
|
+
i0.ɵɵelementEnd()();
|
|
147
|
+
} if (rf & 2) {
|
|
148
|
+
const filterValue_r10 = ctx.$implicit;
|
|
149
|
+
const filter_r9 = i0.ɵɵnextContext().$implicit;
|
|
150
|
+
i0.ɵɵadvance(5);
|
|
151
|
+
i0.ɵɵtextInterpolate1("", i0.ɵɵpipeBind1(6, 2, filter_r9.title), ":");
|
|
152
|
+
i0.ɵɵadvance(3);
|
|
153
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(10, 6, filterValue_r10.key, i0.ɵɵpureFunction1(9, _c2, i0.ɵɵpipeBind1(9, 4, filterValue_r10.value))), "");
|
|
154
|
+
} }
|
|
155
|
+
function FilterBarComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
156
|
+
i0.ɵɵelementStart(0, "div");
|
|
157
|
+
i0.ɵɵtemplate(1, FilterBarComponent_div_2_mat_chip_option_1_Template, 11, 11, "mat-chip-option", 21);
|
|
158
|
+
i0.ɵɵelementEnd();
|
|
159
|
+
} if (rf & 2) {
|
|
160
|
+
const filter_r9 = ctx.$implicit;
|
|
161
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
162
|
+
i0.ɵɵadvance();
|
|
163
|
+
i0.ɵɵproperty("ngForOf", ctx_r0.filterFormGroupValue[filter_r9.fieldName]);
|
|
164
|
+
} }
|
|
18
165
|
export class FilterBarComponent {
|
|
19
166
|
onResize() {
|
|
20
167
|
this.checkOverflow();
|
|
@@ -36,6 +183,9 @@ export class FilterBarComponent {
|
|
|
36
183
|
get showSearch() {
|
|
37
184
|
return !this.settings?.hideSearch;
|
|
38
185
|
}
|
|
186
|
+
get outputFilterKeyAndValue() {
|
|
187
|
+
return this.settings?.outputFilterKeyAndValue;
|
|
188
|
+
}
|
|
39
189
|
// eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures
|
|
40
190
|
set inputText(value) {
|
|
41
191
|
this._inputText = value;
|
|
@@ -119,28 +269,45 @@ export class FilterBarComponent {
|
|
|
119
269
|
for (const filterKey in this.form.value.filters) {
|
|
120
270
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
121
271
|
const filter = this.form.value.filters[filterKey];
|
|
122
|
-
this.filters.filters[filterKey] = filter.map((item) => item.value);
|
|
272
|
+
this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value);
|
|
123
273
|
}
|
|
124
274
|
this.emitFilters();
|
|
125
275
|
});
|
|
126
276
|
}
|
|
127
|
-
static { this.ɵfac =
|
|
128
|
-
static { this.ɵcmp = i0.ɵɵ
|
|
277
|
+
static { this.ɵfac = function FilterBarComponent_Factory(t) { return new (t || FilterBarComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.TranslateService)); }; }
|
|
278
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FilterBarComponent, selectors: [["tld-filter-bar"]], viewQuery: function FilterBarComponent_Query(rf, ctx) { if (rf & 1) {
|
|
279
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
280
|
+
} if (rf & 2) {
|
|
281
|
+
let _t;
|
|
282
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.filterWrapper = _t.first);
|
|
283
|
+
} }, hostBindings: function FilterBarComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
284
|
+
i0.ɵɵlistener("resize", function FilterBarComponent_resize_HostBindingHandler() { return ctx.onResize(); }, false, i0.ɵɵresolveWindow);
|
|
285
|
+
} }, inputs: { settings: "settings", filterRowVisible: "filterRowVisible" }, outputs: { filterBarChange: "filterBarChange" }, decls: 3, vars: 2, consts: [["filterWrapper", ""], ["class", "filter-row", 4, "ngIf"], [4, "ngFor", "ngForOf"], [1, "filter-row"], ["fxLayout", "row", 1, "filter-wrapper", 3, "formGroup"], ["fxFlex", "", "class", "filter-bar-search-input", 4, "ngIf"], [3, "formGroup"], [3, "ngClass", 4, "ngFor", "ngForOf"], ["mat-icon-button", "", 3, "click", 4, "ngIf"], ["fxFlex", "", 1, "filter-bar-search-input"], ["matPrefix", "", 1, "material-icons-outlined"], ["matSuffix", "", "class", "material-icons-outlined", 3, "matTooltip", 4, "ngIf"], ["matInput", "", 1, "search-input", 3, "placeholder", "formControlName"], ["matSuffix", "", 1, "material-icons-outlined", 3, "matTooltip"], [3, "ngClass"], ["multiple", "", 3, "formControlName"], [4, "ngIf"], [3, "value", 4, "ngFor", "ngForOf"], [3, "value"], ["mat-icon-button", "", 3, "click"], [1, "material-icons-outlined"], ["class", "text-s", 3, "removed", 4, "ngFor", "ngForOf"], [1, "text-s", 3, "removed"], ["matChipRemove", ""], [1, "chip-filter-title"], [1, "chip-value", "semi-bold"]], template: function FilterBarComponent_Template(rf, ctx) { if (rf & 1) {
|
|
286
|
+
i0.ɵɵtemplate(0, FilterBarComponent_div_0_Template, 8, 6, "div", 1);
|
|
287
|
+
i0.ɵɵelementStart(1, "mat-chip-listbox");
|
|
288
|
+
i0.ɵɵtemplate(2, FilterBarComponent_div_2_Template, 2, 1, "div", 2);
|
|
289
|
+
i0.ɵɵelementEnd();
|
|
290
|
+
} if (rf & 2) {
|
|
291
|
+
i0.ɵɵproperty("ngIf", ctx.filterRowVisible);
|
|
292
|
+
i0.ɵɵadvance(2);
|
|
293
|
+
i0.ɵɵproperty("ngForOf", ctx.settings == null ? null : ctx.settings.filters);
|
|
294
|
+
} }, dependencies: [i2.NgClass, i2.NgForOf, i2.NgIf, i3.MatInput, i4.MatFormField, i4.MatLabel, i4.MatPrefix, i4.MatSuffix, i5.DefaultLayoutDirective, i5.DefaultFlexDirective, i6.DefaultClassDirective, i7.MatSelect, i8.MatOption, i9.DefaultValueAccessor, i9.NgControlStatus, i9.NgControlStatusGroup, i10.MatTooltip, i11.MatIconButton, i12.MatChipListbox, i12.MatChipOption, i12.MatChipRemove, i13.MatIcon, i9.FormGroupDirective, i9.FormControlName, i2.TitleCasePipe, i1.TranslatePipe, i14.SortTranslationsByPropertyPipe], styles: ["[_nghost-%COMP%]{display:inline-block}.filter-row[_ngcontent-%COMP%]{display:flex;background-color:var(--base-95);min-height:40px;min-width:100%;border-radius:.5rem;padding:1.25rem 1.25rem 0;max-width:100%;align-items:baseline;margin-bottom:.5rem}.search-input[_ngcontent-%COMP%]{background-color:unset;border:none}.engine-filter[_ngcontent-%COMP%]{margin-left:1rem}.filter-bar-search-input[_ngcontent-%COMP%]{width:100%}.filter-bar-search-input[_ngcontent-%COMP%] .material-icons-outlined{vertical-align:bottom}.material-icons-outlined[_ngcontent-%COMP%]{color:var(--base-40)}.filter-wrapper[_ngcontent-%COMP%]{max-width:100%;overflow-x:hidden;overflow-y:hidden;display:flex;flex:1}.mat-mdc-chip.mat-mdc-standard-chip[_ngcontent-%COMP%]{background-color:var(--base-95);padding-left:.5em;padding-right:.75em;border:.5px solid var(--base-70)}.mat-mdc-chip.mat-mdc-standard-chip[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{display:inline-block}.mat-mdc-chip.mat-mdc-standard-chip[_ngcontent-%COMP%] .chip-filter-title[_ngcontent-%COMP%] + .chip-value[_ngcontent-%COMP%]{margin-left:.25rem}.chip-filter-title[_ngcontent-%COMP%]{margin-left:.5em}.hidden[_ngcontent-%COMP%]{display:none}[_nghost-%COMP%] .mat-mdc-form-field-focus-overlay, [_nghost-%COMP%] .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:var(--base-95)}[_nghost-%COMP%] .mat-mdc-chip-graphic{display:none}[_nghost-%COMP%] .mat-mdc-chip-remove{color:var(--base-40)!important}"] }); }
|
|
129
295
|
}
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoC,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACjK,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;;;AAaxD,MAAM,OAAO,kBAAkB;IAG7B,QAAQ;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAGD,IAAa,gBAAgB,CAAC,KAAc;QAC1C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAgCD,mCAAmC;IACnC,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;IACpC,CAAC;IACD,2EAA2E;IAC3E,IAAI,gBAAgB,KAAK,OAAO,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACzD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,UAAU;QACZ,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;IACpC,CAAC;IAED,2EAA2E;IAC3E,IAAI,SAAS,CAAC,KAAK;QACjB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,YAAoB,KAAwB,EAAU,SAA2B;QAA7D,UAAK,GAAL,KAAK,CAAmB;QAAU,cAAS,GAAT,SAAS,CAAkB;QAlDvE,oBAAe,GAAuC,IAAI,YAAY,EAAwB,CAAC;QAEjG,eAAU,GAAG,EAAE,CAAC;QAIxB,+CAA+C;QACtC,yBAAoB,GAAG,OAAO,CAAC;QAC/B,oBAAe,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QACpC,SAAI,GAAG,IAAI,SAAS,CAAC;YAC5B,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC;YAChD,OAAO,EAAE,IAAI,CAAC,eAAe;SAC9B,CAAC,CAAC;QAOH,YAAO,GAAyB;YAC9B,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,EAAE;SACV,CAAC;QAEF,mBAAc,GAAG,KAAK,CAAC;QACvB,sBAAiB,GAAG,CAAC,CAAC;QAEtB,8CAA8C;QAC9C,gBAAW,GAAG,CAAC,CAAC,CAAC;IAsBoE,CAAC;IAEtF,QAAQ;QACN,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACvC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QACxE,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,IAAI,2BAA2B,CAAC;QACjF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,WAAW,IAAI,mBAAmB,CAAC;QACrE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,EAAE,UAAU,IAAI,YAAY,CAAC;QAC5D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,EAAE,UAAU,IAAI,eAAe,CAAC;QAC/D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,EAAE,cAAc,IAAI,IAAI,CAAC;IAC9D,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,QAAQ,EAAE,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,iBAAiB,GAAG,CAAC,EAAE,CAAC;YAC3F,OAAO;QACT,CAAC;QACD,IAAI,CAAC,iBAAiB,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC;YAChD,OAAO;QACT,CAAC;QACD,IAAI,CAAC,iBAAiB,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,GAAW,EAAE,EAAU;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE9C,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAW,CAAC;QACrC,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAEO,aAAa;QACnB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC;QACpH,CAAC;IACH,CAAC;IAEO,2BAA2B;QACjC,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YACnE,IAAI,CAAC,OAAO,GAAG;gBACb,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;gBAClC,OAAO,EAAE,EAAE;aACZ,CAAC;YAEF,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;gBAChD,8DAA8D;gBAC9D,MAAM,MAAM,GAA2B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAe,CAAC,SAAS,CAA0B,CAAC;gBAC3G,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACpE,CAAC;YACD,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAA;IACJ,CAAC;8GA1IU,kBAAkB;kGAAlB,kBAAkB,uVCd/B,+9EAkDA;;2FDpCa,kBAAkB;kBAN9B,SAAS;+BAEE,gBAAgB;qHAKE,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAE1B,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,EAAE;gBAKxB,QAAQ;sBAAhB,KAAK;gBACO,gBAAgB;sBAA5B,KAAK;gBAMI,eAAe;sBAAxB,MAAM","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  /** To hide filters, but leave chips visible */\r\n  readonly inputFormControlName = \"input\";\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    [this.inputFormControlName]: new FormControl(\"\"),\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n  suffixIcon!: string;\r\n  prefixIcon!: string;\r\n  showSuffixIcon!: boolean;\r\n  filters: FilterBarChangeEvent = {\r\n    filters: {},\r\n    input: \"\"\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // when to show filter by name or id on mobile\r\n  searchIndex = -1;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get showSearch() {\r\n    return !this.settings?.hideSearch;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n    this.searchTooltip = this.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.prefixIcon = this.settings?.prefixIcon ?? \"filter_alt\";\r\n    this.suffixIcon = this.settings?.suffixIcon ?? \"question_mark\";\r\n    this.showSuffixIcon = this.settings?.showSuffixIcon ?? true;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.filters && this.settings?.filters.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === this.searchIndex) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper) {\r\n      this.filterOverflow = this.filterWrapper.nativeElement.clientWidth < this.filterWrapper.nativeElement.scrollWidth;\r\n    }\r\n  }\r\n\r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: this.form.value.input ?? \"\",\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <mat-form-field fxFlex *ngIf=\"showSearch && !filterOverflow || activeFilterIndex === searchIndex\" class=\"filter-bar-search-input\">\r\n      <span matPrefix class=\"material-icons-outlined\">\r\n        {{prefixIcon}}\r\n      </span>\r\n      <span matSuffix class=\"material-icons-outlined\" *ngIf=\"showSuffixIcon\" [matTooltip]=\"searchTooltip | translate\">\r\n        {{suffixIcon}}\r\n      </span>\r\n      <input class=\"search-input\" matInput [placeholder]=\"searchTitle | translate\"\r\n        [formControlName]=\"inputFormControlName\">\r\n    </mat-form-field>\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n\r\n      <mat-form-field [ngClass]=\"{'hidden': filterOverflow && activeFilterIndex !== i, 'engine-filter': !filterOverflow}\" *ngFor=\"let filter of settings?.filters; let i = index\">\r\n        <mat-label>{{filter.title | translate}}</mat-label>\r\n        <mat-select multiple [formControlName]=\"filter.fieldName\">\r\n          <ng-container *ngIf=\"filter.values.length\">\r\n            <mat-option *ngFor=\"let value of filter.values | sortTranslationsByProperty:'key'\" [value]=\"value\">\r\n              {{value.key | translate : {default: value.value | titlecase } }}\r\n            </mat-option>\r\n          </ng-container>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </ng-container>\r\n  </div>\r\n  <button mat-icon-button (click)=\"switchLeft()\" *ngIf=\"filterOverflow\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_back_ios\r\n    </span>\r\n  </button>\r\n  <button mat-icon-button *ngIf=\"filterOverflow\" (click)=\"switchRight()\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_forward_ios\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-chip-listbox>\r\n  <div *ngFor=\"let filter of settings?.filters\">\r\n    <mat-chip-option *ngFor=\"let filterValue of filterFormGroupValue[filter.fieldName]; let ix=index\"\r\n      (removed)=\"removeFilter(filter.fieldName, ix)\" class=\"text-s\">\r\n      <button matChipRemove>\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n      <span class=\"chip-filter-title\">{{filter.title | translate}}:</span>\r\n      <span class=\"chip-value semi-bold\"> {{filterValue.key | translate : {default: filterValue.value | titlecase }\r\n        }}</span>\r\n    </mat-chip-option>\r\n  </div>\r\n</mat-chip-listbox>\r\n"]}
|
|
296
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterBarComponent, [{
|
|
297
|
+
type: Component,
|
|
298
|
+
args: [{ selector: 'tld-filter-bar', template: "<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n <mat-form-field fxFlex *ngIf=\"showSearch && !filterOverflow || activeFilterIndex === searchIndex\" class=\"filter-bar-search-input\">\r\n <span matPrefix class=\"material-icons-outlined\">\r\n {{prefixIcon}}\r\n </span>\r\n <span matSuffix class=\"material-icons-outlined\" *ngIf=\"showSuffixIcon\" [matTooltip]=\"searchTooltip | translate\">\r\n {{suffixIcon}}\r\n </span>\r\n <input class=\"search-input\" matInput [placeholder]=\"searchTitle | translate\"\r\n [formControlName]=\"inputFormControlName\">\r\n </mat-form-field>\r\n <ng-container [formGroup]=\"filterFormGroup\">\r\n\r\n <mat-form-field [ngClass]=\"{'hidden': filterOverflow && activeFilterIndex !== i, 'engine-filter': !filterOverflow}\" *ngFor=\"let filter of settings?.filters; let i = index\">\r\n <mat-label>{{filter.title | translate}}</mat-label>\r\n <mat-select multiple [formControlName]=\"filter.fieldName\">\r\n <ng-container *ngIf=\"filter.values.length\">\r\n <mat-option *ngFor=\"let value of filter.values | sortTranslationsByProperty:'key'\" [value]=\"value\">\r\n {{value.key | translate : {default: value.value | titlecase } }}\r\n </mat-option>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </ng-container>\r\n </div>\r\n <button mat-icon-button (click)=\"switchLeft()\" *ngIf=\"filterOverflow\">\r\n <span class=\"material-icons-outlined\">\r\n arrow_back_ios\r\n </span>\r\n </button>\r\n <button mat-icon-button *ngIf=\"filterOverflow\" (click)=\"switchRight()\">\r\n <span class=\"material-icons-outlined\">\r\n arrow_forward_ios\r\n </span>\r\n </button>\r\n</div>\r\n<mat-chip-listbox>\r\n <div *ngFor=\"let filter of settings?.filters\">\r\n <mat-chip-option *ngFor=\"let filterValue of filterFormGroupValue[filter.fieldName]; let ix=index\"\r\n (removed)=\"removeFilter(filter.fieldName, ix)\" class=\"text-s\">\r\n <button matChipRemove>\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n <span class=\"chip-filter-title\">{{filter.title | translate}}:</span>\r\n <span class=\"chip-value semi-bold\"> {{filterValue.key | translate : {default: filterValue.value | titlecase }\r\n }}</span>\r\n </mat-chip-option>\r\n </div>\r\n</mat-chip-listbox>\r\n", styles: [":host{display:inline-block}.filter-row{display:flex;background-color:var(--base-95);min-height:40px;min-width:100%;border-radius:.5rem;padding:1.25rem 1.25rem 0;max-width:100%;align-items:baseline;margin-bottom:.5rem}.search-input{background-color:unset;border:none}.engine-filter{margin-left:1rem}.filter-bar-search-input{width:100%}.filter-bar-search-input::ng-deep .material-icons-outlined{vertical-align:bottom}.material-icons-outlined{color:var(--base-40)}.filter-wrapper{max-width:100%;overflow-x:hidden;overflow-y:hidden;display:flex;flex:1}.mat-mdc-chip.mat-mdc-standard-chip{background-color:var(--base-95);padding-left:.5em;padding-right:.75em;border:.5px solid var(--base-70)}.mat-mdc-chip.mat-mdc-standard-chip span{display:inline-block}.mat-mdc-chip.mat-mdc-standard-chip .chip-filter-title+.chip-value{margin-left:.25rem}.chip-filter-title{margin-left:.5em}.hidden{display:none}:host ::ng-deep .mat-mdc-form-field-focus-overlay,:host ::ng-deep .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:var(--base-95)}:host ::ng-deep .mat-mdc-chip-graphic{display:none}:host ::ng-deep .mat-mdc-chip-remove{color:var(--base-40)!important}\n"] }]
|
|
299
|
+
}], () => [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateService }], { filterWrapper: [{
|
|
300
|
+
type: ViewChild,
|
|
301
|
+
args: ["filterWrapper"]
|
|
302
|
+
}], onResize: [{
|
|
303
|
+
type: HostListener,
|
|
304
|
+
args: ['window:resize', []]
|
|
305
|
+
}], settings: [{
|
|
306
|
+
type: Input
|
|
307
|
+
}], filterRowVisible: [{
|
|
308
|
+
type: Input
|
|
309
|
+
}], filterBarChange: [{
|
|
310
|
+
type: Output
|
|
311
|
+
}] }); })();
|
|
312
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterBarComponent, { className: "FilterBarComponent", filePath: "lib\\filter-bar\\filter-bar.component.ts", lineNumber: 15 }); })();
|
|
313
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  /** To hide filters, but leave chips visible */\r\n  readonly inputFormControlName = \"input\";\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    [this.inputFormControlName]: new FormControl(\"\"),\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n  suffixIcon!: string;\r\n  prefixIcon!: string;\r\n  showSuffixIcon!: boolean;\r\n  filters: FilterBarChangeEvent = {\r\n    filters: {},\r\n    input: \"\"\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // when to show filter by name or id on mobile\r\n  searchIndex = -1;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get showSearch() {\r\n    return !this.settings?.hideSearch;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n    this.searchTooltip = this.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.prefixIcon = this.settings?.prefixIcon ?? \"filter_alt\";\r\n    this.suffixIcon = this.settings?.suffixIcon ?? \"question_mark\";\r\n    this.showSuffixIcon = this.settings?.showSuffixIcon ?? true;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.filters && this.settings?.filters.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === this.searchIndex) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper) {\r\n      this.filterOverflow = this.filterWrapper.nativeElement.clientWidth < this.filterWrapper.nativeElement.scrollWidth;\r\n    }\r\n  }\r\n\r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: this.form.value.input ?? \"\",\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <mat-form-field fxFlex *ngIf=\"showSearch && !filterOverflow || activeFilterIndex === searchIndex\" class=\"filter-bar-search-input\">\r\n      <span matPrefix class=\"material-icons-outlined\">\r\n        {{prefixIcon}}\r\n      </span>\r\n      <span matSuffix class=\"material-icons-outlined\" *ngIf=\"showSuffixIcon\" [matTooltip]=\"searchTooltip | translate\">\r\n        {{suffixIcon}}\r\n      </span>\r\n      <input class=\"search-input\" matInput [placeholder]=\"searchTitle | translate\"\r\n        [formControlName]=\"inputFormControlName\">\r\n    </mat-form-field>\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n\r\n      <mat-form-field [ngClass]=\"{'hidden': filterOverflow && activeFilterIndex !== i, 'engine-filter': !filterOverflow}\" *ngFor=\"let filter of settings?.filters; let i = index\">\r\n        <mat-label>{{filter.title | translate}}</mat-label>\r\n        <mat-select multiple [formControlName]=\"filter.fieldName\">\r\n          <ng-container *ngIf=\"filter.values.length\">\r\n            <mat-option *ngFor=\"let value of filter.values | sortTranslationsByProperty:'key'\" [value]=\"value\">\r\n              {{value.key | translate : {default: value.value | titlecase } }}\r\n            </mat-option>\r\n          </ng-container>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </ng-container>\r\n  </div>\r\n  <button mat-icon-button (click)=\"switchLeft()\" *ngIf=\"filterOverflow\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_back_ios\r\n    </span>\r\n  </button>\r\n  <button mat-icon-button *ngIf=\"filterOverflow\" (click)=\"switchRight()\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_forward_ios\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-chip-listbox>\r\n  <div *ngFor=\"let filter of settings?.filters\">\r\n    <mat-chip-option *ngFor=\"let filterValue of filterFormGroupValue[filter.fieldName]; let ix=index\"\r\n      (removed)=\"removeFilter(filter.fieldName, ix)\" class=\"text-s\">\r\n      <button matChipRemove>\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n      <span class=\"chip-filter-title\">{{filter.title | translate}}:</span>\r\n      <span class=\"chip-value semi-bold\"> {{filterValue.key | translate : {default: filterValue.value | titlecase }\r\n        }}</span>\r\n    </mat-chip-option>\r\n  </div>\r\n</mat-chip-listbox>\r\n"]}
|
|
@@ -14,21 +14,9 @@ import { MatIconModule } from '@angular/material/icon';
|
|
|
14
14
|
import { SortTranslationsByPropertyModule } from '../pipes/sort-translations-by-property';
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
16
16
|
export class FilterBarModule {
|
|
17
|
-
static { this.ɵfac =
|
|
18
|
-
static { this.ɵmod = i0.ɵɵ
|
|
19
|
-
|
|
20
|
-
MatInputModule,
|
|
21
|
-
MatFormFieldModule,
|
|
22
|
-
FlexLayoutModule,
|
|
23
|
-
MatSelectModule,
|
|
24
|
-
FormsModule,
|
|
25
|
-
MatTooltipModule,
|
|
26
|
-
MatButtonModule,
|
|
27
|
-
MatChipsModule,
|
|
28
|
-
MatIconModule,
|
|
29
|
-
ReactiveFormsModule,
|
|
30
|
-
SortTranslationsByPropertyModule], exports: [FilterBarComponent] }); }
|
|
31
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: FilterBarModule, imports: [CommonModule,
|
|
17
|
+
static { this.ɵfac = function FilterBarModule_Factory(t) { return new (t || FilterBarModule)(); }; }
|
|
18
|
+
static { this.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: FilterBarModule }); }
|
|
19
|
+
static { this.ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [CommonModule,
|
|
32
20
|
TranslateModule,
|
|
33
21
|
MatInputModule,
|
|
34
22
|
MatFormFieldModule,
|
|
@@ -42,30 +30,43 @@ export class FilterBarModule {
|
|
|
42
30
|
ReactiveFormsModule,
|
|
43
31
|
SortTranslationsByPropertyModule] }); }
|
|
44
32
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
33
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterBarModule, [{
|
|
34
|
+
type: NgModule,
|
|
35
|
+
args: [{
|
|
36
|
+
declarations: [
|
|
37
|
+
FilterBarComponent
|
|
38
|
+
],
|
|
39
|
+
imports: [
|
|
40
|
+
CommonModule,
|
|
41
|
+
TranslateModule,
|
|
42
|
+
MatInputModule,
|
|
43
|
+
MatFormFieldModule,
|
|
44
|
+
FlexLayoutModule,
|
|
45
|
+
MatSelectModule,
|
|
46
|
+
FormsModule,
|
|
47
|
+
MatTooltipModule,
|
|
48
|
+
MatButtonModule,
|
|
49
|
+
MatChipsModule,
|
|
50
|
+
MatIconModule,
|
|
51
|
+
ReactiveFormsModule,
|
|
52
|
+
SortTranslationsByPropertyModule
|
|
53
|
+
],
|
|
54
|
+
exports: [
|
|
55
|
+
FilterBarComponent
|
|
56
|
+
]
|
|
57
|
+
}]
|
|
58
|
+
}], null, null); })();
|
|
59
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(FilterBarModule, { declarations: [FilterBarComponent], imports: [CommonModule,
|
|
60
|
+
TranslateModule,
|
|
61
|
+
MatInputModule,
|
|
62
|
+
MatFormFieldModule,
|
|
63
|
+
FlexLayoutModule,
|
|
64
|
+
MatSelectModule,
|
|
65
|
+
FormsModule,
|
|
66
|
+
MatTooltipModule,
|
|
67
|
+
MatButtonModule,
|
|
68
|
+
MatChipsModule,
|
|
69
|
+
MatIconModule,
|
|
70
|
+
ReactiveFormsModule,
|
|
71
|
+
SortTranslationsByPropertyModule], exports: [FilterBarComponent] }); })();
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvZmlsdGVyLWJhci9maWx0ZXItYmFyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sd0NBQXdDLENBQUM7O0FBeUIxRixNQUFNLE9BQU8sZUFBZTtnRkFBZixlQUFlO21FQUFmLGVBQWU7dUVBbEJ4QixZQUFZO1lBQ1osZUFBZTtZQUNmLGNBQWM7WUFDZCxrQkFBa0I7WUFDbEIsZ0JBQWdCO1lBQ2hCLGVBQWU7WUFDZixXQUFXO1lBQ1gsZ0JBQWdCO1lBQ2hCLGVBQWU7WUFDZixjQUFjO1lBQ2QsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixnQ0FBZ0M7O2lGQU12QixlQUFlO2NBdkIzQixRQUFRO2VBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLGtCQUFrQjtpQkFDbkI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osZUFBZTtvQkFDZixjQUFjO29CQUNkLGtCQUFrQjtvQkFDbEIsZ0JBQWdCO29CQUNoQixlQUFlO29CQUNmLFdBQVc7b0JBQ1gsZ0JBQWdCO29CQUNoQixlQUFlO29CQUNmLGNBQWM7b0JBQ2QsYUFBYTtvQkFDYixtQkFBbUI7b0JBQ25CLGdDQUFnQztpQkFDakM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLGtCQUFrQjtpQkFDbkI7YUFDRjs7d0ZBQ1ksZUFBZSxtQkFyQnhCLGtCQUFrQixhQUdsQixZQUFZO1FBQ1osZUFBZTtRQUNmLGNBQWM7UUFDZCxrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZixXQUFXO1FBQ1gsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZixjQUFjO1FBQ2QsYUFBYTtRQUNiLG1CQUFtQjtRQUNuQixnQ0FBZ0MsYUFHaEMsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRmlsdGVyQmFyQ29tcG9uZW50IH0gZnJvbSAnLi9maWx0ZXItYmFyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0BuZ2JyYWNrZXQvbmd4LWxheW91dCc7XHJcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0VG9vbHRpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRDaGlwc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoaXBzJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBTb3J0VHJhbnNsYXRpb25zQnlQcm9wZXJ0eU1vZHVsZSB9IGZyb20gJy4uL3BpcGVzL3NvcnQtdHJhbnNsYXRpb25zLWJ5LXByb3BlcnR5JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBGaWx0ZXJCYXJDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgRmxleExheW91dE1vZHVsZSxcclxuICAgIE1hdFNlbGVjdE1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcclxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgIE1hdENoaXBzTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBTb3J0VHJhbnNsYXRpb25zQnlQcm9wZXJ0eU1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVyQmFyQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsdGVyQmFyTW9kdWxlIHsgfVxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci1zZXR0aW5ncy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9maWx0ZXItYmFyL21vZGVscy9maWx0ZXItYmFyLXNldHRpbmdzLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJCYXJGaWx0ZXIgfSBmcm9tIFwiLi9maWx0ZXItYmFyLWZpbHRlci5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJCYXJTZXR0aW5ncyB7XHJcbiAgLyoqIFNob3cvaGlkZSBzZWFyY2ggaW5wdXQuIEVuYWJsZWQgYnkgZGVmYXVsdC4gKi9cclxuICBoaWRlU2VhcmNoPzogYm9vbGVhbjtcclxuICAvKiogVG9nZ2xlIG91dHB1dCBmaWx0ZXIgaXRlbSBiZXR3ZWVuIHZhbHVlLCBhbmQgb2JqZWN0IHdpdGgga2V5IGFuZCB2YWx1ZSBmaWVsZHMuIFZhbHVlIGJ5IGRlZmF1bHQuICovXHJcbiAgb3V0cHV0RmlsdGVyS2V5QW5kVmFsdWU/OiBib29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIFRpdGxlIGZvciBzZWFyY2ggaW5wdXQgZmllbGQuIERlZmF1bHQgdmFsdWU6IEZJTFRFUl9CQVIuU0VBUkNIXHJcbiAgKi9cclxuICBzZWFyY2hUaXRsZT86IHN0cmluZztcclxuICAvKipcclxuICAgKiBTZWFyY2ggdG9vbHRpcCwgc2hvd24gYWZ0ZXIgaW5wdXQgZmllbGQgZm9yIGljb25cclxuICAgKi9cclxuICBzZWFyY2hUb29sdGlwPzogc3RyaW5nO1xyXG4gIC8qKiBQcmVmaXggaWNvbiBmcm9tIG1hdGVyaWFsIGljb25zLiAqL1xyXG4gIHByZWZpeEljb24/OiBzdHJpbmc7XHJcbiAgLyoqIFN1ZmZpeCBpY29uIGZyb20gbWF0ZXJpYWwgaWNvbnMuICovXHJcbiAgc3VmZml4SWNvbj86IHN0cmluZztcclxuICBzaG93U3VmZml4SWNvbj86IGJvb2xlYW47XHJcbiAgXHJcbiAgZmlsdGVycz86IEZpbHRlckJhckZpbHRlcltdO1xyXG59XHJcbiJdfQ==
|