mis-crystal-design-system 18.0.24 → 18.1.0-signal-test
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/action-list/action-list.component.d.ts +17 -15
- package/async-search-dropdown/async-dropdown.component.d.ts +43 -61
- package/button/button.component.d.ts +35 -13
- package/button/button.directive.d.ts +10 -8
- package/checkbox/checkbox.component.d.ts +15 -12
- package/chip/chip.component.d.ts +9 -11
- package/datepicker_v2/models/dp-config.model.d.ts +1 -0
- package/datepicker_v2/tz-datepicker.directive.d.ts +15 -18
- package/datepicker_v2/tz-dp-container/tz-dp-container.component.d.ts +42 -21
- package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +12 -14
- package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +46 -23
- package/drawer/drawer-body/drawer-body.component.d.ts +2 -2
- package/dropdown/calculate-container-height.directive.d.ts +7 -8
- package/dropdown/dropdown.component.d.ts +41 -49
- package/dynamic-form/dynamic-form.component.d.ts +20 -16
- package/esm2022/action-list/action-list.component.mjs +112 -89
- package/esm2022/async-search-dropdown/async-dropdown.component.mjs +256 -326
- package/esm2022/button/button.component.mjs +55 -48
- package/esm2022/button/button.directive.mjs +36 -40
- package/esm2022/checkbox/checkbox.component.mjs +75 -70
- package/esm2022/chip/chip.component.mjs +20 -33
- package/esm2022/datepicker_v2/models/dp-config.model.mjs +1 -1
- package/esm2022/datepicker_v2/tz-datepicker.directive.mjs +42 -71
- package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +202 -172
- package/esm2022/datepicker_v2/utils/index.mjs +2 -1
- package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +26 -51
- package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +282 -235
- package/esm2022/drawer/drawer-body/drawer-body.component.mjs +8 -7
- package/esm2022/dropdown/calculate-container-height.directive.mjs +25 -22
- package/esm2022/dropdown/dropdown.component.mjs +162 -186
- package/esm2022/dynamic-form/dynamic-form.component.mjs +118 -72
- package/esm2022/fab/fab.component.mjs +29 -33
- package/esm2022/filter/filter-panel/filter-panel.component.mjs +60 -58
- package/esm2022/input/directives/input/input.directive.mjs +22 -26
- package/esm2022/input/mis-input.component.mjs +41 -45
- package/esm2022/input-stepper/input-stepper/input-stepper.component.mjs +40 -50
- package/esm2022/loader/loader.component.mjs +8 -11
- package/esm2022/mobile-filter/mobile-filter.component.mjs +61 -61
- package/esm2022/modal/module-wrapper/module-wrapper.component.mjs +11 -9
- package/esm2022/multi-select-dropdown/multi-select-dropdown.component.mjs +235 -281
- package/esm2022/nested-multi-select-dropdown/nested-multi-select-dropdown.component.mjs +250 -287
- package/esm2022/phone-input/phone-input.component.mjs +21 -43
- package/esm2022/radio-button/radio-button.component.mjs +15 -27
- package/esm2022/ske-loader/ske-loader.component.mjs +15 -29
- package/esm2022/slider/slider.component.mjs +23 -33
- package/esm2022/slider/slider.module.mjs +4 -11
- package/esm2022/snackbar/snackbar/snackbar.component.mjs +21 -15
- package/esm2022/snackbar/snackbar.service.mjs +3 -2
- package/esm2022/specificdatepicker/tz-sdp-container/tz-sdp-container.component.mjs +230 -343
- package/esm2022/specificdatepicker/tz-specificdatepicker.directive.mjs +77 -105
- package/esm2022/star-rating/star-rating.component.mjs +57 -71
- package/esm2022/switch/switch.component.mjs +34 -36
- package/esm2022/table/actions-cell/actions-cell.component.mjs +55 -54
- package/esm2022/table/custom-table-cell.directive.mjs +22 -18
- package/esm2022/table/filter/filter.component.mjs +60 -42
- package/esm2022/table/sort-icons.directive.mjs +16 -8
- package/esm2022/table/sub-table/sub-table.component.mjs +41 -44
- package/esm2022/table/table.component.mjs +181 -165
- package/esm2022/timepicker/timepicker.component.mjs +244 -159
- package/esm2022/timepicker/timepicker.directive.mjs +3 -2
- package/esm2022/timerangepicker/timerangepicker.component.mjs +200 -159
- package/esm2022/toast/toast.component.mjs +6 -7
- package/esm2022/toast/toast.data.service.mjs +15 -9
- package/esm2022/tooltip/tooltip-container/tooltip.component.mjs +12 -12
- package/esm2022/tooltip/tooltip.directive.mjs +4 -4
- package/esm2022/virtual-scroll/virtual-scroll.component.mjs +57 -59
- package/fab/fab.component.d.ts +12 -8
- package/fesm2022/mis-crystal-design-system-action-list.mjs +111 -88
- package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +253 -324
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-button.mjs +88 -85
- package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-checkbox.mjs +74 -69
- package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-chip.mjs +19 -32
- package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +242 -240
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +305 -283
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-drawer.mjs +7 -6
- package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dropdown.mjs +183 -204
- package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +118 -72
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-fab.mjs +28 -32
- package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-filter.mjs +59 -57
- package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs +39 -49
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input.mjs +62 -71
- package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-loader.mjs +7 -10
- package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs +60 -60
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-modal.mjs +10 -8
- package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs +233 -279
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs +249 -286
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-phone-input.mjs +20 -42
- package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-radio-button.mjs +14 -26
- package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-ske-loader.mjs +14 -28
- package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-slider.mjs +25 -42
- package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-snackbar.mjs +22 -15
- package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs +304 -445
- package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-star-rating.mjs +56 -70
- package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-switch.mjs +33 -35
- package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +365 -321
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timepicker.mjs +245 -159
- package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +199 -158
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-toast.mjs +18 -13
- package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-tooltip.mjs +14 -14
- package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs +57 -59
- package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
- package/filter/filter-panel/filter-panel.component.d.ts +14 -14
- package/input/directives/input/input.directive.d.ts +6 -10
- package/input/mis-input.component.d.ts +12 -13
- package/input-stepper/input-stepper/input-stepper.component.d.ts +8 -7
- package/loader/loader.component.d.ts +3 -6
- package/mobile-filter/mobile-filter.component.d.ts +15 -15
- package/modal/module-wrapper/module-wrapper.component.d.ts +2 -3
- package/multi-select-dropdown/multi-select-dropdown.component.d.ts +89 -51
- package/nested-multi-select-dropdown/nested-multi-select-dropdown.component.d.ts +99 -56
- package/package.json +17 -17
- package/phone-input/phone-input.component.d.ts +16 -18
- package/radio-button/radio-button.component.d.ts +9 -11
- package/ske-loader/ske-loader.component.d.ts +8 -11
- package/slider/slider.component.d.ts +8 -11
- package/slider/slider.module.d.ts +1 -2
- package/snackbar/snackbar/snackbar.component.d.ts +3 -3
- package/specificdatepicker/tz-sdp-container/tz-sdp-container.component.d.ts +35 -35
- package/specificdatepicker/tz-specificdatepicker.directive.d.ts +24 -28
- package/star-rating/star-rating.component.d.ts +18 -18
- package/switch/switch.component.d.ts +8 -10
- package/table/actions-cell/actions-cell.component.d.ts +14 -14
- package/table/custom-table-cell.directive.d.ts +3 -3
- package/table/filter/filter.component.d.ts +9 -9
- package/table/sub-table/sub-table.component.d.ts +5 -5
- package/table/table.component.d.ts +38 -35
- package/timepicker/timepicker.component.d.ts +29 -28
- package/timerangepicker/timerangepicker.component.d.ts +36 -33
- package/toast/toast.data.service.d.ts +1 -1
- package/tooltip/tooltip-container/tooltip.component.d.ts +4 -4
- package/virtual-scroll/virtual-scroll.component.d.ts +8 -9
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { debounceTime, distinctUntilChanged, tap } from
|
|
1
|
+
import { Component, ContentChild, HostListener, ViewChild, } from '@angular/core';
|
|
2
|
+
import { UntypedFormControl } from '@angular/forms';
|
|
3
|
+
import { OverlayConfig, ConnectionPositionPair, } from '@angular/cdk/overlay';
|
|
4
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
+
import { signal, effect, input, output } from '@angular/core';
|
|
6
|
+
import { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';
|
|
7
|
+
import { merge, Subject } from 'rxjs';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/cdk/overlay";
|
|
9
10
|
import * as i2 from "@angular/common";
|
|
@@ -16,410 +17,384 @@ const _c2 = ["ddBtn"];
|
|
|
16
17
|
const _c3 = ["input"];
|
|
17
18
|
const _c4 = ["dd"];
|
|
18
19
|
const _c5 = (a0, a1, a2) => ({ opened: a0, disabled: a1, readonly: a2 });
|
|
19
|
-
const _c6 = (a0, a1) => ({ "
|
|
20
|
-
const _c7 = (a0, a1) => ({ "
|
|
21
|
-
const _c8 = () => ({ "
|
|
22
|
-
const _c9 = a0 => ({
|
|
23
|
-
const _c10 = (a0, a1) => ({ "
|
|
24
|
-
const _c11 =
|
|
25
|
-
const _c12 = a0 => ({
|
|
26
|
-
const _c13 = a0 => ({ $implicit: a0 });
|
|
20
|
+
const _c6 = (a0, a1) => ({ "ip-md": a0, "ip-sm": a1 });
|
|
21
|
+
const _c7 = (a0, a1) => ({ "chip-md": a0, "chip-sm": a1 });
|
|
22
|
+
const _c8 = (a0, a1) => ({ "h6": a0, "h8-b": a1 });
|
|
23
|
+
const _c9 = a0 => ({ cursor: "pointer", "font-size": a0 });
|
|
24
|
+
const _c10 = (a0, a1) => ({ "max-height": a0, "width": a1 });
|
|
25
|
+
const _c11 = a0 => ({ "dd-list-pd": a0 });
|
|
26
|
+
const _c12 = a0 => ({ $implicit: a0 });
|
|
27
27
|
function AsyncDropdownComponent_div_2_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
28
|
-
const
|
|
29
|
-
i0.ɵɵelementStart(0, "div",
|
|
28
|
+
const _r2 = i0.ɵɵgetCurrentView();
|
|
29
|
+
i0.ɵɵelementStart(0, "div", 14)(1, "span", 15);
|
|
30
30
|
i0.ɵɵtext(2);
|
|
31
31
|
i0.ɵɵelementEnd();
|
|
32
|
-
i0.ɵɵelementStart(3, "span",
|
|
33
|
-
i0.ɵɵlistener("click", function AsyncDropdownComponent_div_2_div_1_Template_span_click_3_listener() { const
|
|
32
|
+
i0.ɵɵelementStart(3, "span", 16);
|
|
33
|
+
i0.ɵɵlistener("click", function AsyncDropdownComponent_div_2_div_1_Template_span_click_3_listener() { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.removeItem(item_r3)); })("keyup.enter", function AsyncDropdownComponent_div_2_div_1_Template_span_keyup_enter_3_listener() { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.removeItem(item_r3)); });
|
|
34
34
|
i0.ɵɵelementEnd()();
|
|
35
35
|
} if (rf & 2) {
|
|
36
|
-
const
|
|
37
|
-
const
|
|
38
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(
|
|
36
|
+
const item_r3 = ctx.$implicit;
|
|
37
|
+
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
38
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(4, _c7, ctx_r3.size() === "md", ctx_r3.size() === "sm"));
|
|
39
39
|
i0.ɵɵadvance();
|
|
40
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(
|
|
40
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(7, _c8, ctx_r3.size() === "md", ctx_r3.size() === "sm"));
|
|
41
41
|
i0.ɵɵadvance();
|
|
42
|
-
i0.ɵɵ
|
|
42
|
+
i0.ɵɵtextInterpolate1(" ", item_r3[ctx_r3.displayKey()], " ");
|
|
43
43
|
i0.ɵɵadvance();
|
|
44
|
-
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(
|
|
44
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(10, _c9, ctx_r3.size() === "sm" ? "12px" : "14px"));
|
|
45
45
|
} }
|
|
46
46
|
function AsyncDropdownComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
47
|
-
i0.ɵɵelementStart(0, "div",
|
|
48
|
-
i0.ɵɵtemplate(1, AsyncDropdownComponent_div_2_div_1_Template, 4,
|
|
47
|
+
i0.ɵɵelementStart(0, "div", 12);
|
|
48
|
+
i0.ɵɵtemplate(1, AsyncDropdownComponent_div_2_div_1_Template, 4, 12, "div", 13);
|
|
49
49
|
i0.ɵɵelementEnd();
|
|
50
50
|
} if (rf & 2) {
|
|
51
|
-
const
|
|
51
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
52
52
|
i0.ɵɵadvance();
|
|
53
|
-
i0.ɵɵproperty("ngForOf",
|
|
53
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.selectedItems);
|
|
54
54
|
} }
|
|
55
55
|
function AsyncDropdownComponent_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
56
|
-
i0.ɵɵelementStart(0, "div",
|
|
57
|
-
i0.ɵɵelement(1, "img",
|
|
56
|
+
i0.ɵɵelementStart(0, "div", 17);
|
|
57
|
+
i0.ɵɵelement(1, "img", 18);
|
|
58
58
|
i0.ɵɵelementEnd();
|
|
59
59
|
} if (rf & 2) {
|
|
60
|
-
const
|
|
60
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
61
61
|
i0.ɵɵadvance();
|
|
62
|
-
i0.ɵɵproperty("src",
|
|
62
|
+
i0.ɵɵproperty("src", ctx_r3.customPlaceholderIcon(), i0.ɵɵsanitizeUrl);
|
|
63
63
|
} }
|
|
64
64
|
function AsyncDropdownComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
|
|
65
|
-
i0.ɵɵelement(0, "span",
|
|
65
|
+
i0.ɵɵelement(0, "span", 19);
|
|
66
66
|
} }
|
|
67
|
-
function
|
|
68
|
-
const _r4 = i0.ɵɵgetCurrentView();
|
|
69
|
-
i0.ɵɵelementStart(0, "input", 21, 4);
|
|
70
|
-
i0.ɵɵlistener("focus", function AsyncDropdownComponent_input_7_Template_input_focus_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.defaultCall()); })("keyup.enter", function AsyncDropdownComponent_input_7_Template_input_keyup_enter_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.enablePopUpOnTab()); });
|
|
71
|
-
i0.ɵɵelementEnd();
|
|
72
|
-
} if (rf & 2) {
|
|
73
|
-
const ctx_r2 = i0.ɵɵnextContext();
|
|
74
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(3, _c10, ctx_r2.size === "md", ctx_r2.size === "sm"))("placeholder", ctx_r2.placeholder)("formControl", ctx_r2.searchInput);
|
|
75
|
-
} }
|
|
76
|
-
function AsyncDropdownComponent_ng_template_8_Template(rf, ctx) { if (rf & 1) {
|
|
67
|
+
function AsyncDropdownComponent_div_9_Template(rf, ctx) { if (rf & 1) {
|
|
77
68
|
const _r5 = i0.ɵɵgetCurrentView();
|
|
78
|
-
i0.ɵɵelementStart(0, "
|
|
79
|
-
i0.ɵɵlistener("
|
|
80
|
-
i0.ɵɵelementEnd();
|
|
81
|
-
} if (rf & 2) {
|
|
82
|
-
const ctx_r2 = i0.ɵɵnextContext();
|
|
83
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(3, _c10, ctx_r2.size === "md", ctx_r2.size === "sm"))("placeholder", ctx_r2.placeholder)("formControl", ctx_r2.searchInput);
|
|
84
|
-
} }
|
|
85
|
-
function AsyncDropdownComponent_div_10_Template(rf, ctx) { if (rf & 1) {
|
|
86
|
-
const _r6 = i0.ɵɵgetCurrentView();
|
|
87
|
-
i0.ɵɵelementStart(0, "div", 23);
|
|
88
|
-
i0.ɵɵlistener("click", function AsyncDropdownComponent_div_10_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.removeInputValue()); })("keyup.enter", function AsyncDropdownComponent_div_10_Template_div_keyup_enter_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.removeInputValue()); });
|
|
69
|
+
i0.ɵɵelementStart(0, "div", 20);
|
|
70
|
+
i0.ɵɵlistener("click", function AsyncDropdownComponent_div_9_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeInputValue()); })("keyup.enter", function AsyncDropdownComponent_div_9_Template_div_keyup_enter_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeInputValue()); });
|
|
89
71
|
i0.ɵɵelementEnd();
|
|
90
72
|
} }
|
|
91
|
-
function
|
|
92
|
-
i0.ɵɵelementContainer(0,
|
|
73
|
+
function AsyncDropdownComponent_ng_template_10_ng_container_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
74
|
+
i0.ɵɵelementContainer(0, 24);
|
|
93
75
|
} if (rf & 2) {
|
|
94
|
-
const
|
|
95
|
-
i0.ɵɵproperty("ngTemplateOutlet",
|
|
76
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
77
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.customLoader);
|
|
96
78
|
} }
|
|
97
|
-
function
|
|
98
|
-
i0.ɵɵelementStart(0, "div",
|
|
99
|
-
i0.ɵɵelement(1, "mis-loader",
|
|
79
|
+
function AsyncDropdownComponent_ng_template_10_ng_container_1_ng_template_2_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
80
|
+
i0.ɵɵelementStart(0, "div", 26);
|
|
81
|
+
i0.ɵɵelement(1, "mis-loader", 27);
|
|
100
82
|
i0.ɵɵelementEnd();
|
|
101
83
|
} if (rf & 2) {
|
|
102
84
|
i0.ɵɵadvance();
|
|
103
85
|
i0.ɵɵproperty("mobileView", true);
|
|
104
86
|
} }
|
|
105
|
-
function
|
|
106
|
-
i0.ɵɵtemplate(0,
|
|
87
|
+
function AsyncDropdownComponent_ng_template_10_ng_container_1_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
88
|
+
i0.ɵɵtemplate(0, AsyncDropdownComponent_ng_template_10_ng_container_1_ng_template_2_div_0_Template, 2, 1, "div", 25);
|
|
107
89
|
} if (rf & 2) {
|
|
108
|
-
const
|
|
109
|
-
i0.ɵɵproperty("ngIf",
|
|
90
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
91
|
+
i0.ɵɵproperty("ngIf", ctx_r3.loading() && !ctx_r3.customLoader);
|
|
110
92
|
} }
|
|
111
|
-
function
|
|
93
|
+
function AsyncDropdownComponent_ng_template_10_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
112
94
|
i0.ɵɵelementContainerStart(0);
|
|
113
|
-
i0.ɵɵtemplate(1,
|
|
95
|
+
i0.ɵɵtemplate(1, AsyncDropdownComponent_ng_template_10_ng_container_1_ng_container_1_Template, 1, 1, "ng-container", 23)(2, AsyncDropdownComponent_ng_template_10_ng_container_1_ng_template_2_Template, 1, 1, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
|
|
114
96
|
i0.ɵɵelementContainerEnd();
|
|
115
97
|
} if (rf & 2) {
|
|
116
|
-
const
|
|
117
|
-
const
|
|
98
|
+
const defaultLoader_r6 = i0.ɵɵreference(3);
|
|
99
|
+
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
118
100
|
i0.ɵɵadvance();
|
|
119
|
-
i0.ɵɵproperty("ngIf",
|
|
101
|
+
i0.ɵɵproperty("ngIf", ctx_r3.customLoader)("ngIfElse", defaultLoader_r6);
|
|
120
102
|
} }
|
|
121
|
-
function
|
|
103
|
+
function AsyncDropdownComponent_ng_template_10_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
122
104
|
i0.ɵɵelementContainerStart(0);
|
|
123
|
-
i0.ɵɵelementStart(1, "div",
|
|
105
|
+
i0.ɵɵelementStart(1, "div", 26)(2, "p");
|
|
124
106
|
i0.ɵɵtext(3, "Unknown error has occurred, ");
|
|
125
107
|
i0.ɵɵelement(4, "br");
|
|
126
108
|
i0.ɵɵtext(5, " Please try again later.");
|
|
127
109
|
i0.ɵɵelementEnd()();
|
|
128
110
|
i0.ɵɵelementContainerEnd();
|
|
129
111
|
} }
|
|
130
|
-
function
|
|
131
|
-
i0.ɵɵ
|
|
132
|
-
i0.ɵɵelementContainer(1,
|
|
133
|
-
i0.ɵɵ
|
|
112
|
+
function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_container_3_Template(rf, ctx) { if (rf & 1) {
|
|
113
|
+
i0.ɵɵelementContainerStart(0);
|
|
114
|
+
i0.ɵɵelementContainer(1, 32);
|
|
115
|
+
i0.ɵɵelementContainerEnd();
|
|
134
116
|
} if (rf & 2) {
|
|
135
|
-
const
|
|
136
|
-
const
|
|
137
|
-
i0.ɵɵproperty("tabindex", ctx_r2.openPopUpOnTab ? 0 : -1);
|
|
117
|
+
const item_r8 = i0.ɵɵnextContext().$implicit;
|
|
118
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
138
119
|
i0.ɵɵadvance();
|
|
139
|
-
i0.ɵɵproperty("ngTemplateOutlet",
|
|
120
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.customItem)("ngTemplateOutletContext", i0.ɵɵpureFunction1(2, _c12, item_r8));
|
|
140
121
|
} }
|
|
141
|
-
function
|
|
142
|
-
const
|
|
143
|
-
i0.ɵɵelement(0, "div",
|
|
144
|
-
i0.ɵɵelementStart(1, "div",
|
|
145
|
-
i0.ɵɵlistener("click", function
|
|
146
|
-
i0.ɵɵelementStart(2, "div",
|
|
122
|
+
function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_template_4_Template(rf, ctx) { if (rf & 1) {
|
|
123
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
124
|
+
i0.ɵɵelement(0, "div", 30);
|
|
125
|
+
i0.ɵɵelementStart(1, "div", 33);
|
|
126
|
+
i0.ɵɵlistener("click", function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_template_4_Template_div_click_1_listener() { i0.ɵɵrestoreView(_r9); const item_r8 = i0.ɵɵnextContext().$implicit; const ctx_r3 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r3.selectData(item_r8, false)); })("keyup.enter", function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_template_4_Template_div_keyup_enter_1_listener() { i0.ɵɵrestoreView(_r9); const item_r8 = i0.ɵɵnextContext().$implicit; const ctx_r3 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r3.selectData(item_r8, false)); });
|
|
127
|
+
i0.ɵɵelementStart(2, "div", 34)(3, "div", 35);
|
|
147
128
|
i0.ɵɵtext(4);
|
|
148
129
|
i0.ɵɵelementEnd();
|
|
149
|
-
i0.ɵɵelementStart(5, "div",
|
|
130
|
+
i0.ɵɵelementStart(5, "div", 36);
|
|
150
131
|
i0.ɵɵtext(6);
|
|
151
132
|
i0.ɵɵelementEnd()()();
|
|
152
133
|
} if (rf & 2) {
|
|
153
|
-
const
|
|
154
|
-
const
|
|
134
|
+
const item_r8 = i0.ɵɵnextContext().$implicit;
|
|
135
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
155
136
|
i0.ɵɵadvance();
|
|
156
|
-
i0.ɵɵproperty("tabindex",
|
|
137
|
+
i0.ɵɵproperty("tabindex", ctx_r3.openPopUpOnTab() ? 0 : -1);
|
|
157
138
|
i0.ɵɵadvance(3);
|
|
158
|
-
i0.ɵɵ
|
|
139
|
+
i0.ɵɵtextInterpolate(item_r8[ctx_r3.displayKey()]);
|
|
159
140
|
i0.ɵɵadvance(2);
|
|
160
|
-
i0.ɵɵ
|
|
141
|
+
i0.ɵɵtextInterpolate(item_r8[ctx_r3.secondaryDisplayKey()]);
|
|
161
142
|
} }
|
|
162
|
-
function
|
|
163
|
-
const
|
|
143
|
+
function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
144
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
164
145
|
i0.ɵɵelementContainerStart(0);
|
|
165
|
-
i0.ɵɵelementStart(1, "div",
|
|
166
|
-
i0.ɵɵlistener("click", function
|
|
167
|
-
i0.ɵɵelement(2, "div",
|
|
168
|
-
i0.ɵɵtemplate(3,
|
|
146
|
+
i0.ɵɵelementStart(1, "div", 29);
|
|
147
|
+
i0.ɵɵlistener("click", function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_Template_div_click_1_listener() { const item_r8 = i0.ɵɵrestoreView(_r7).$implicit; const ctx_r3 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r3.selectData(item_r8, false)); })("keyup.enter", function AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_Template_div_keyup_enter_1_listener() { const item_r8 = i0.ɵɵrestoreView(_r7).$implicit; const ctx_r3 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r3.selectData(item_r8, false)); });
|
|
148
|
+
i0.ɵɵelement(2, "div", 30);
|
|
149
|
+
i0.ɵɵtemplate(3, AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_container_3_Template, 2, 4, "ng-container", 31)(4, AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_ng_template_4_Template, 7, 3, "ng-template", null, 5, i0.ɵɵtemplateRefExtractor);
|
|
169
150
|
i0.ɵɵelementEnd();
|
|
170
151
|
i0.ɵɵelementContainerEnd();
|
|
171
152
|
} if (rf & 2) {
|
|
172
|
-
const
|
|
173
|
-
const
|
|
153
|
+
const standardItem_r10 = i0.ɵɵreference(5);
|
|
154
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
174
155
|
i0.ɵɵadvance(3);
|
|
175
|
-
i0.ɵɵproperty("ngIf",
|
|
156
|
+
i0.ɵɵproperty("ngIf", ctx_r3.customItem)("ngIfElse", standardItem_r10);
|
|
176
157
|
} }
|
|
177
|
-
function
|
|
158
|
+
function AsyncDropdownComponent_ng_template_10_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
178
159
|
i0.ɵɵelementStart(0, "div");
|
|
179
|
-
i0.ɵɵtemplate(1,
|
|
160
|
+
i0.ɵɵtemplate(1, AsyncDropdownComponent_ng_template_10_div_3_ng_container_1_Template, 6, 2, "ng-container", 28);
|
|
180
161
|
i0.ɵɵelementEnd();
|
|
181
162
|
} if (rf & 2) {
|
|
182
|
-
const
|
|
163
|
+
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
183
164
|
i0.ɵɵadvance();
|
|
184
|
-
i0.ɵɵproperty("ngForOf",
|
|
165
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.data());
|
|
185
166
|
} }
|
|
186
|
-
function
|
|
187
|
-
i0.ɵɵelementStart(0, "div")(1, "div",
|
|
167
|
+
function AsyncDropdownComponent_ng_template_10_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
168
|
+
i0.ɵɵelementStart(0, "div")(1, "div", 37);
|
|
188
169
|
i0.ɵɵtext(2, "No Data Available");
|
|
189
170
|
i0.ɵɵelementEnd()();
|
|
190
171
|
} }
|
|
191
|
-
function
|
|
192
|
-
i0.ɵɵelementStart(0, "div",
|
|
193
|
-
i0.ɵɵtemplate(1,
|
|
172
|
+
function AsyncDropdownComponent_ng_template_10_Template(rf, ctx) { if (rf & 1) {
|
|
173
|
+
i0.ɵɵelementStart(0, "div", 21);
|
|
174
|
+
i0.ɵɵtemplate(1, AsyncDropdownComponent_ng_template_10_ng_container_1_Template, 4, 2, "ng-container", 22)(2, AsyncDropdownComponent_ng_template_10_ng_container_2_Template, 6, 0, "ng-container", 22)(3, AsyncDropdownComponent_ng_template_10_div_3_Template, 2, 1, "div", 22)(4, AsyncDropdownComponent_ng_template_10_div_4_Template, 3, 0, "div", 22);
|
|
194
175
|
i0.ɵɵelementEnd();
|
|
195
176
|
} if (rf & 2) {
|
|
196
|
-
const
|
|
197
|
-
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(7,
|
|
177
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
178
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(7, _c10, ctx_r3.height(), ctx_r3.dropdownListWidth()))("ngClass", i0.ɵɵpureFunction1(10, _c11, ctx_r3.data().length === 0))("cdkTrapFocusAutoCapture", ctx_r3.openPopUpOnTab());
|
|
198
179
|
i0.ɵɵadvance();
|
|
199
|
-
i0.ɵɵproperty("ngIf",
|
|
180
|
+
i0.ɵɵproperty("ngIf", ctx_r3.loading());
|
|
200
181
|
i0.ɵɵadvance();
|
|
201
|
-
i0.ɵɵproperty("ngIf",
|
|
182
|
+
i0.ɵɵproperty("ngIf", ctx_r3.error());
|
|
202
183
|
i0.ɵɵadvance();
|
|
203
|
-
i0.ɵɵproperty("ngIf", !
|
|
184
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.loading() && !ctx_r3.error() && ctx_r3.data().length > 0);
|
|
204
185
|
i0.ɵɵadvance();
|
|
205
|
-
i0.ɵɵproperty("ngIf", !
|
|
186
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.loading() && !ctx_r3.error() && ctx_r3.data().length === 0 && ctx_r3.searchInput.value);
|
|
206
187
|
} }
|
|
207
188
|
export class AsyncDropdownComponent {
|
|
208
|
-
constructor(overlay, viewContainerRef, _ngZone) {
|
|
189
|
+
constructor(overlay, viewContainerRef, _ngZone, injector) {
|
|
209
190
|
this.overlay = overlay;
|
|
210
191
|
this.viewContainerRef = viewContainerRef;
|
|
211
192
|
this._ngZone = _ngZone;
|
|
212
|
-
this.
|
|
213
|
-
|
|
214
|
-
this.
|
|
215
|
-
this.
|
|
216
|
-
this.
|
|
217
|
-
this.
|
|
218
|
-
this.
|
|
219
|
-
this.
|
|
220
|
-
|
|
221
|
-
this.
|
|
193
|
+
this.injector = injector;
|
|
194
|
+
// === Inputs ===
|
|
195
|
+
this.height = input();
|
|
196
|
+
this.width = input();
|
|
197
|
+
this.size = input('md');
|
|
198
|
+
this.httpStream = input.required();
|
|
199
|
+
this.displayKey = input.required();
|
|
200
|
+
this.secondaryDisplayKey = input('');
|
|
201
|
+
this.placeholder = input('Select');
|
|
202
|
+
this.debounceTime = input(400);
|
|
203
|
+
this.minInputLength = input(2);
|
|
204
|
+
this.multi = input(false);
|
|
205
|
+
this.uniqueKey = input();
|
|
206
|
+
this.control = input(null);
|
|
207
|
+
this.disabled = input(false);
|
|
208
|
+
this.readonly = input(false);
|
|
209
|
+
this.disableCopyPaste = input(false);
|
|
210
|
+
this.dropdownListWidth = input();
|
|
211
|
+
this.dropdownListPosition = input('Left');
|
|
212
|
+
this.customPlaceholderIcon = input('');
|
|
213
|
+
this.selections = input(new Map());
|
|
214
|
+
this.searchValue = input();
|
|
215
|
+
// === Outputs ===
|
|
216
|
+
this.onSelect = output();
|
|
217
|
+
this.searchQueryChange = output();
|
|
218
|
+
this.clear = output();
|
|
219
|
+
this.itemSelected = output();
|
|
220
|
+
this.itemRemoved = output();
|
|
221
|
+
// === Internal state ===
|
|
222
222
|
this.searchInput = new UntypedFormControl();
|
|
223
|
-
this.data = [];
|
|
224
|
-
this.opened = false;
|
|
225
|
-
this.loading = false;
|
|
226
|
-
this.error = false;
|
|
227
|
-
this.openPopUpOnTab = false;
|
|
228
|
-
// tslint:disable-next-line
|
|
229
|
-
this.selections = new Map();
|
|
230
223
|
this.httpStreamTrigger = new Subject();
|
|
231
|
-
|
|
232
|
-
this.
|
|
233
|
-
this.
|
|
234
|
-
this.
|
|
235
|
-
this.
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
//
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
if (this.multi && !this.uniqueKey) {
|
|
244
|
-
throw new Error("[uniqueKey] required in multi mode.");
|
|
245
|
-
}
|
|
246
|
-
if (this.disabled) {
|
|
247
|
-
this.searchInput.disable();
|
|
248
|
-
}
|
|
249
|
-
const searchObservable = this.searchInput.valueChanges.pipe(tap((val) => this.searchQueryChange.emit(val)), debounceTime(this.debounceTime), distinctUntilChanged());
|
|
250
|
-
this.searchSubscription = merge(searchObservable, this.httpStreamTrigger)
|
|
251
|
-
.subscribe(res => {
|
|
252
|
-
this._ngZone.run(() => {
|
|
253
|
-
res = res?.trim() ?? '';
|
|
254
|
-
if (res?.length < this.minInputLength || !res?.length) {
|
|
224
|
+
// === Signals ===
|
|
225
|
+
this.opened = signal(false);
|
|
226
|
+
this.loading = signal(false);
|
|
227
|
+
this.error = signal(false);
|
|
228
|
+
this.openPopUpOnTab = signal(false);
|
|
229
|
+
this.data = signal([]);
|
|
230
|
+
// === Effect to handle search ===
|
|
231
|
+
this.searchEffect = effect(() => {
|
|
232
|
+
// Merge form control changes and manual triggers
|
|
233
|
+
merge(this.searchInput.valueChanges.pipe(tap((val) => this.searchQueryChange.emit(val)), debounceTime(this.debounceTime()), distinctUntilChanged()), this.httpStreamTrigger).subscribe((query) => {
|
|
234
|
+
const q = query?.trim() ?? '';
|
|
235
|
+
if (!q || q.length < this.minInputLength()) {
|
|
255
236
|
this.closeDropdown();
|
|
256
237
|
return;
|
|
257
238
|
}
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
this.httpStream(res).subscribe(list => {
|
|
264
|
-
this.loading = false;
|
|
265
|
-
this.data = list;
|
|
266
|
-
if (!this.overlayRef?.hasAttached() && list.length > 0) {
|
|
267
|
-
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
268
|
-
}
|
|
269
|
-
}, error => {
|
|
270
|
-
this.loading = false;
|
|
271
|
-
this.error = true;
|
|
272
|
-
});
|
|
239
|
+
this.loading.set(true);
|
|
240
|
+
this.error.set(false);
|
|
241
|
+
// Open overlay if not yet open
|
|
242
|
+
if (!this.overlayRef?.hasAttached()) {
|
|
243
|
+
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
273
244
|
}
|
|
245
|
+
// Call HTTP stream
|
|
246
|
+
this.httpStream()(q).subscribe({
|
|
247
|
+
next: (list) => {
|
|
248
|
+
this.loading.set(false);
|
|
249
|
+
this.data.set(list);
|
|
250
|
+
},
|
|
251
|
+
error: () => {
|
|
252
|
+
this.loading.set(false);
|
|
253
|
+
this.error.set(true);
|
|
254
|
+
},
|
|
255
|
+
});
|
|
274
256
|
});
|
|
275
257
|
});
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
}
|
|
279
|
-
this.controlSubscription = this.control?.valueChanges.subscribe(this.handleControlChanges);
|
|
258
|
+
this.handleControlChanges = (values) => {
|
|
259
|
+
values.forEach((el) => this.selectData(el, true));
|
|
260
|
+
};
|
|
280
261
|
}
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
this.
|
|
262
|
+
// === Lifecycle ===
|
|
263
|
+
ngOnInit() {
|
|
264
|
+
if (this.multi() && !this.uniqueKey()) {
|
|
265
|
+
throw new Error('[uniqueKey] required in multi mode.');
|
|
266
|
+
}
|
|
267
|
+
if (this.disabled())
|
|
268
|
+
this.searchInput.disable();
|
|
269
|
+
if (this.control()?.value) {
|
|
270
|
+
this.handleControlChanges(this.control().value);
|
|
271
|
+
}
|
|
272
|
+
this.control()?.valueChanges.subscribe(this.handleControlChanges);
|
|
284
273
|
}
|
|
285
|
-
ngOnChanges(
|
|
286
|
-
if (
|
|
287
|
-
this.searchInput.patchValue(
|
|
274
|
+
ngOnChanges() {
|
|
275
|
+
if (this.searchValue()) {
|
|
276
|
+
this.searchInput.patchValue(this.searchValue());
|
|
288
277
|
}
|
|
289
|
-
if (
|
|
278
|
+
if (this.disabled()) {
|
|
279
|
+
this.searchInput.disable();
|
|
280
|
+
}
|
|
281
|
+
else {
|
|
290
282
|
this.searchInput.enable();
|
|
291
|
-
if (this.disabled) {
|
|
292
|
-
this.searchInput.disable();
|
|
293
|
-
}
|
|
294
283
|
}
|
|
295
284
|
}
|
|
296
285
|
ngOnDestroy() {
|
|
297
|
-
this.
|
|
298
|
-
|
|
286
|
+
this.overlayRef?.dispose();
|
|
287
|
+
}
|
|
288
|
+
// === Methods ===
|
|
289
|
+
refreshHttpStream(query) {
|
|
290
|
+
this.httpStreamTrigger.next(query);
|
|
299
291
|
}
|
|
300
292
|
openDropdown(template, origin) {
|
|
301
293
|
const positionsBottom = [
|
|
302
|
-
new ConnectionPositionPair({ originX:
|
|
303
|
-
new ConnectionPositionPair({ originX:
|
|
294
|
+
new ConnectionPositionPair({ originX: 'start', originY: 'bottom' }, { overlayX: 'start', overlayY: 'top' }, 0, 4),
|
|
295
|
+
new ConnectionPositionPair({ originX: 'end', originY: 'bottom' }, { overlayX: 'end', overlayY: 'top' }, 0, 4),
|
|
304
296
|
];
|
|
305
297
|
const positionsTop = [
|
|
306
|
-
new ConnectionPositionPair({ originX:
|
|
307
|
-
new ConnectionPositionPair({ originX:
|
|
298
|
+
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'bottom' }, 0, -4),
|
|
299
|
+
new ConnectionPositionPair({ originX: 'end', originY: 'top' }, { overlayX: 'end', overlayY: 'bottom' }, 0, -4),
|
|
308
300
|
];
|
|
309
301
|
const positionStrategy = this.overlay
|
|
310
302
|
.position()
|
|
311
303
|
.flexibleConnectedTo(origin)
|
|
312
304
|
.withPositions([
|
|
313
|
-
...(this.dropdownListPosition ===
|
|
314
|
-
...(this.dropdownListPosition ===
|
|
305
|
+
...(this.dropdownListPosition() === 'Right' ? positionsBottom.reverse() : positionsBottom),
|
|
306
|
+
...(this.dropdownListPosition() === 'Right' ? positionsTop.reverse() : positionsTop),
|
|
315
307
|
])
|
|
316
308
|
.withPush(true);
|
|
317
309
|
const configs = new OverlayConfig({
|
|
318
310
|
hasBackdrop: true,
|
|
319
|
-
backdropClass:
|
|
311
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
320
312
|
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
321
313
|
positionStrategy,
|
|
322
|
-
width: origin.clientWidth
|
|
314
|
+
width: origin.clientWidth,
|
|
323
315
|
});
|
|
324
316
|
this.overlayRef = this.overlay.create(configs);
|
|
325
|
-
if (this.dropdownListWidth)
|
|
326
|
-
this.overlayRef.updateSize({ width: this.dropdownListWidth });
|
|
317
|
+
if (this.dropdownListWidth())
|
|
318
|
+
this.overlayRef.updateSize({ width: this.dropdownListWidth() });
|
|
327
319
|
this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));
|
|
328
|
-
this.overlayRef.backdropClick().subscribe(
|
|
329
|
-
this.closeDropdown();
|
|
330
|
-
});
|
|
320
|
+
this.overlayRef.backdropClick().subscribe(() => this.closeDropdown());
|
|
331
321
|
}
|
|
332
|
-
/**
|
|
333
|
-
* closes the dropdown
|
|
334
|
-
*/
|
|
335
322
|
closeDropdown() {
|
|
336
|
-
this.opened
|
|
337
|
-
this.openPopUpOnTab
|
|
323
|
+
this.opened.set(false);
|
|
324
|
+
this.openPopUpOnTab.set(false);
|
|
338
325
|
this.overlayRef?.detach();
|
|
339
|
-
this.data
|
|
326
|
+
this.data.set([]);
|
|
340
327
|
}
|
|
341
328
|
enablePopUpOnTab() {
|
|
342
|
-
this.openPopUpOnTab
|
|
329
|
+
this.openPopUpOnTab.set(true);
|
|
343
330
|
}
|
|
344
331
|
handleKeyDown(event) {
|
|
345
332
|
if (event.key === 'Escape') {
|
|
346
|
-
this.searchInput.
|
|
333
|
+
this.searchInput.reset();
|
|
347
334
|
this.closeDropdown();
|
|
348
335
|
}
|
|
349
336
|
}
|
|
350
|
-
/**
|
|
351
|
-
*
|
|
352
|
-
* @param item item to select
|
|
353
|
-
* if item property disabled is set to true, selection will be disabled
|
|
354
|
-
* @param effectedFromOutside set to true if calling from parent component, if true will focus on search input
|
|
355
|
-
*/
|
|
356
337
|
selectData(item, effectedFromOutside = true) {
|
|
357
|
-
if (item.disabled)
|
|
338
|
+
if (item.disabled)
|
|
358
339
|
return;
|
|
359
|
-
}
|
|
360
340
|
this.itemSelected.emit(item);
|
|
361
|
-
if (!this.multi) {
|
|
362
|
-
this.searchInput.patchValue(item[this.displayKey], { emitEvent: false });
|
|
341
|
+
if (!this.multi()) {
|
|
342
|
+
this.searchInput.patchValue(item[this.displayKey()], { emitEvent: false });
|
|
363
343
|
this.setControlValue(item);
|
|
364
344
|
}
|
|
365
345
|
else {
|
|
366
|
-
if (!this.selections.has(item[this.uniqueKey])) {
|
|
367
|
-
this.selections.set(item[this.uniqueKey], item);
|
|
346
|
+
if (!this.selections().has(item[this.uniqueKey()])) {
|
|
347
|
+
this.selections().set(item[this.uniqueKey()], item);
|
|
368
348
|
}
|
|
369
349
|
this.setControlValue(this.selectedItems);
|
|
370
350
|
if (!effectedFromOutside) {
|
|
371
351
|
setTimeout(() => {
|
|
372
|
-
this.
|
|
373
|
-
this.
|
|
352
|
+
this.inputRef.nativeElement.focus();
|
|
353
|
+
this.inputRef.nativeElement.scrollIntoView();
|
|
374
354
|
}, 10);
|
|
375
355
|
}
|
|
376
|
-
this.searchInput.patchValue(
|
|
377
|
-
this.data
|
|
356
|
+
this.searchInput.patchValue('');
|
|
357
|
+
this.data.set([]);
|
|
378
358
|
}
|
|
379
359
|
this.closeDropdown();
|
|
380
360
|
}
|
|
381
|
-
/**
|
|
382
|
-
*
|
|
383
|
-
* @param item remove item from selected list
|
|
384
|
-
*/
|
|
385
361
|
removeItem(item) {
|
|
386
362
|
this.itemRemoved.emit(item);
|
|
387
|
-
this.selections.delete(item[this.uniqueKey]);
|
|
363
|
+
this.selections().delete(item[this.uniqueKey()]);
|
|
388
364
|
this.setControlValue(this.selectedItems);
|
|
389
|
-
|
|
390
|
-
this.input["nativeElement"].focus();
|
|
365
|
+
this.inputRef.nativeElement.focus();
|
|
391
366
|
}
|
|
392
367
|
setControlValue(value) {
|
|
393
368
|
this.onSelect.emit(value);
|
|
394
|
-
this.control?.patchValue(value, { emitEvent: false });
|
|
369
|
+
this.control()?.patchValue(value, { emitEvent: false });
|
|
395
370
|
}
|
|
396
|
-
/**
|
|
397
|
-
* @returns list of selected items
|
|
398
|
-
*/
|
|
399
371
|
get selectedItems() {
|
|
400
|
-
return Array.from(this.selections.values());
|
|
372
|
+
return Array.from(this.selections().values());
|
|
401
373
|
}
|
|
402
374
|
removeInputValue() {
|
|
403
375
|
this.searchInput.reset();
|
|
404
|
-
this.data
|
|
376
|
+
this.data.set([]);
|
|
405
377
|
this.clear.emit(true);
|
|
406
378
|
}
|
|
407
379
|
defaultCall() {
|
|
408
|
-
if (this.minInputLength === -1) {
|
|
409
|
-
this.loading
|
|
410
|
-
this.
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
this.
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
380
|
+
if (this.minInputLength() === -1) {
|
|
381
|
+
this.loading.set(true);
|
|
382
|
+
this.httpStream()(this.searchInput.value || '').subscribe({
|
|
383
|
+
next: (list) => {
|
|
384
|
+
this.loading.set(false);
|
|
385
|
+
this.data.set(list);
|
|
386
|
+
if (!this.overlayRef?.hasAttached() && list.length > 0) {
|
|
387
|
+
this.openDropdown(this.dd, this.origin.nativeElement);
|
|
388
|
+
}
|
|
389
|
+
},
|
|
390
|
+
error: () => {
|
|
391
|
+
this.loading.set(false);
|
|
392
|
+
this.error.set(true);
|
|
393
|
+
},
|
|
419
394
|
});
|
|
420
395
|
}
|
|
421
396
|
}
|
|
422
|
-
static { this.ɵfac = function AsyncDropdownComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AsyncDropdownComponent)(i0.ɵɵdirectiveInject(i1.Overlay), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.NgZone)); }; }
|
|
397
|
+
static { this.ɵfac = function AsyncDropdownComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || AsyncDropdownComponent)(i0.ɵɵdirectiveInject(i1.Overlay), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.NgZone), i0.ɵɵdirectiveInject(i0.Injector)); }; }
|
|
423
398
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AsyncDropdownComponent, selectors: [["mis-async-search-dropdown"]], contentQueries: function AsyncDropdownComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
424
399
|
i0.ɵɵcontentQuery(dirIndex, _c0, 5);
|
|
425
400
|
i0.ɵɵcontentQuery(dirIndex, _c1, 5);
|
|
@@ -434,103 +409,58 @@ export class AsyncDropdownComponent {
|
|
|
434
409
|
} if (rf & 2) {
|
|
435
410
|
let _t;
|
|
436
411
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.origin = _t.first);
|
|
437
|
-
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.
|
|
412
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputRef = _t.first);
|
|
438
413
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dd = _t.first);
|
|
439
414
|
} }, hostBindings: function AsyncDropdownComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
440
415
|
i0.ɵɵlistener("keydown", function AsyncDropdownComponent_keydown_HostBindingHandler($event) { return ctx.handleKeyDown($event); }, false, i0.ɵɵresolveDocument);
|
|
441
|
-
} }, inputs: { height: "height", width: "width", size: "size", httpStream: "httpStream", displayKey: "displayKey", secondaryDisplayKey: "secondaryDisplayKey", placeholder: "placeholder", debounceTime: "debounceTime", minInputLength: "minInputLength", multi: "multi", uniqueKey: "uniqueKey", control: "control", disabled: "disabled", readonly: "readonly", disableCopyPaste: "disableCopyPaste", dropdownListWidth: "dropdownListWidth", dropdownListPosition: "dropdownListPosition", customPlaceholderIcon: "customPlaceholderIcon", selections: "selections", searchValue: "searchValue" }, outputs: { onSelect: "onSelect", searchQueryChange: "searchQueryChange", clear: "clear", itemSelected: "itemSelected", itemRemoved: "itemRemoved" }, features: [i0.ɵɵNgOnChangesFeature], decls:
|
|
442
|
-
i0.ɵɵ
|
|
443
|
-
i0.ɵɵ
|
|
444
|
-
i0.ɵɵ
|
|
445
|
-
i0.ɵɵ
|
|
416
|
+
} }, inputs: { height: [1, "height"], width: [1, "width"], size: [1, "size"], httpStream: [1, "httpStream"], displayKey: [1, "displayKey"], secondaryDisplayKey: [1, "secondaryDisplayKey"], placeholder: [1, "placeholder"], debounceTime: [1, "debounceTime"], minInputLength: [1, "minInputLength"], multi: [1, "multi"], uniqueKey: [1, "uniqueKey"], control: [1, "control"], disabled: [1, "disabled"], readonly: [1, "readonly"], disableCopyPaste: [1, "disableCopyPaste"], dropdownListWidth: [1, "dropdownListWidth"], dropdownListPosition: [1, "dropdownListPosition"], customPlaceholderIcon: [1, "customPlaceholderIcon"], selections: [1, "selections"], searchValue: [1, "searchValue"] }, outputs: { onSelect: "onSelect", searchQueryChange: "searchQueryChange", clear: "clear", itemSelected: "itemSelected", itemRemoved: "itemRemoved" }, features: [i0.ɵɵNgOnChangesFeature], decls: 12, vars: 21, consts: [["ddBtn", ""], ["defaultSearchIcon", ""], ["input", ""], ["dd", ""], ["defaultLoader", ""], ["standardItem", ""], [1, "dd-wrapper", 3, "ngClass"], ["class", "selected-list", 4, "ngIf"], [1, "search-input"], ["class", "custom-icon", 4, "ngIf", "ngIfElse"], ["type", "text", 1, "black-text", "h6", 3, "focus", "keyup.enter", "ngClass", "placeholder", "formControl"], ["class", "icon-ic-navigation-cancel-24 croos-icon", "tabindex", "0", 3, "click", "keyup.enter", 4, "ngIf"], [1, "selected-list"], ["class", "chip", 3, "ngClass", 4, "ngFor", "ngForOf"], [1, "chip", 3, "ngClass"], [2, "margin-right", "4px", 3, "ngClass"], ["tabindex", "0", 1, "icon-ic-navigation-cancel-24", 3, "click", "keyup.enter", "ngStyle"], [1, "custom-icon"], ["alt", "customIcon", 3, "src"], [1, "icon-ic-action-search-24"], ["tabindex", "0", 1, "icon-ic-navigation-cancel-24", "croos-icon", 3, "click", "keyup.enter"], ["tabindex", "0", "cdkTrapFocus", "", 1, "dd-list", 3, "ngStyle", "ngClass", "cdkTrapFocusAutoCapture"], [4, "ngIf"], [3, "ngTemplateOutlet", 4, "ngIf", "ngIfElse"], [3, "ngTemplateOutlet"], ["class", "status-container", 4, "ngIf"], [1, "status-container"], [3, "mobileView"], [4, "ngFor", "ngForOf"], [3, "click", "keyup.enter"], ["tabindex", "-1", "cdkFocusInitial", ""], [4, "ngIf", "ngIfElse"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [1, "item", 3, "click", "keyup.enter", "tabindex"], [1, "value"], [1, "primary"], [1, "secondary"], [1, "data-not-found"]], template: function AsyncDropdownComponent_Template(rf, ctx) { if (rf & 1) {
|
|
417
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
418
|
+
i0.ɵɵelementStart(0, "div", 6, 0);
|
|
419
|
+
i0.ɵɵtemplate(2, AsyncDropdownComponent_div_2_Template, 2, 1, "div", 7);
|
|
420
|
+
i0.ɵɵelementStart(3, "div", 8);
|
|
421
|
+
i0.ɵɵtemplate(4, AsyncDropdownComponent_div_4_Template, 2, 1, "div", 9)(5, AsyncDropdownComponent_ng_template_5_Template, 1, 0, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
|
|
422
|
+
i0.ɵɵelementStart(7, "input", 10, 2);
|
|
423
|
+
i0.ɵɵlistener("focus", function AsyncDropdownComponent_Template_input_focus_7_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.defaultCall()); })("keyup.enter", function AsyncDropdownComponent_Template_input_keyup_enter_7_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.enablePopUpOnTab()); });
|
|
424
|
+
i0.ɵɵelementEnd();
|
|
425
|
+
i0.ɵɵtemplate(9, AsyncDropdownComponent_div_9_Template, 1, 0, "div", 11);
|
|
446
426
|
i0.ɵɵelementEnd()();
|
|
447
|
-
i0.ɵɵtemplate(
|
|
427
|
+
i0.ɵɵtemplate(10, AsyncDropdownComponent_ng_template_10_Template, 5, 12, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
|
448
428
|
} if (rf & 2) {
|
|
449
|
-
const
|
|
450
|
-
|
|
451
|
-
i0.ɵɵ
|
|
452
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction3(9, _c5, ctx.opened, ctx.disabled, ctx.readonly));
|
|
429
|
+
const defaultSearchIcon_r11 = i0.ɵɵreference(6);
|
|
430
|
+
i0.ɵɵstyleProp("width", ctx.width());
|
|
431
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction3(14, _c5, ctx.opened(), ctx.disabled(), ctx.readonly()));
|
|
453
432
|
i0.ɵɵadvance(2);
|
|
454
|
-
i0.ɵɵproperty("ngIf", ctx.multi && ctx.
|
|
433
|
+
i0.ɵɵproperty("ngIf", ctx.multi() && ctx.selectedItems.length > 0);
|
|
455
434
|
i0.ɵɵadvance(2);
|
|
456
|
-
i0.ɵɵproperty("ngIf", ctx.customPlaceholderIcon)("ngIfElse",
|
|
435
|
+
i0.ɵɵproperty("ngIf", ctx.customPlaceholderIcon())("ngIfElse", defaultSearchIcon_r11);
|
|
457
436
|
i0.ɵɵadvance(3);
|
|
458
|
-
i0.ɵɵproperty("
|
|
459
|
-
i0.ɵɵ
|
|
460
|
-
i0.ɵɵ
|
|
437
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(18, _c6, ctx.size() === "md", ctx.size() === "sm"))("placeholder", ctx.placeholder())("formControl", ctx.searchInput);
|
|
438
|
+
i0.ɵɵattribute("tabindex", 0)("oncopy", ctx.disableCopyPaste() ? "return false;" : null)("onpaste", ctx.disableCopyPaste() ? "return false;" : null)("oncut", ctx.disableCopyPaste() ? "return false;" : null);
|
|
439
|
+
i0.ɵɵadvance(2);
|
|
440
|
+
i0.ɵɵproperty("ngIf", ctx.searchInput.value == null ? null : ctx.searchInput.value.length);
|
|
461
441
|
} }, dependencies: [i2.NgClass, i2.NgForOf, i2.NgIf, i2.NgTemplateOutlet, i2.NgStyle, i3.DefaultValueAccessor, i3.NgControlStatus, i3.FormControlDirective, i4.LoaderComponent, i5.CdkTrapFocus], styles: [".dd-wrapper[_ngcontent-%COMP%]{background:#fff;border:1px solid #e0e0e0;box-sizing:border-box;border-radius:4px;display:block;cursor:pointer;outline:none}.dd-wrapper.opened[_ngcontent-%COMP%], .dd-wrapper[_ngcontent-%COMP%]:hover{background:#f5f5f5}.dd-wrapper[_ngcontent-%COMP%] .selected-list[_ngcontent-%COMP%]{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:4px;padding:8px 16px}.dd-wrapper[_ngcontent-%COMP%]:focus-within{border-color:#0937b2;background:#f5f5f5}.dd-wrapper.disabled[_ngcontent-%COMP%], .dd-wrapper.readonly[_ngcontent-%COMP%]{pointer-events:none}.search-input[_ngcontent-%COMP%]{position:relative;border-radius:8px}.search-input[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{box-sizing:border-box;outline:none;padding-left:40px;padding-right:24px;background-color:transparent;color:#181f33;border-radius:inherit;border:1px solid transparent;width:100%}.search-input[_ngcontent-%COMP%] span[_ngcontent-%COMP%], .search-input[_ngcontent-%COMP%] .custom-icon[_ngcontent-%COMP%]{position:absolute;top:50%;transform:translateY(-50%);font-size:24px;line-height:24px;height:24px;left:8px}.search-input[_ngcontent-%COMP%] .croos-icon[_ngcontent-%COMP%]{position:absolute;top:50%;transform:translateY(-50%);font-size:16px;width:24px;line-height:16px;height:16px;right:0}.dd-list[_ngcontent-%COMP%]{padding:8px 0;max-height:200px;background:#fff;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:8px;min-width:100%;overflow-y:auto}.dd-list[_ngcontent-%COMP%]::-webkit-scrollbar{width:8px;border-radius:4px}.dd-list[_ngcontent-%COMP%]::-webkit-scrollbar-track{background:#fff;border-radius:4px}.dd-list[_ngcontent-%COMP%]::-webkit-scrollbar-thumb{background:#929dab;border-radius:4px}.dd-list[_ngcontent-%COMP%]::-webkit-scrollbar-thumb:hover{background:#929dab}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%]{padding:8px 16px;cursor:pointer}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%] .disabled[_ngcontent-%COMP%]{color:#6a737d!important;pointer-events:none}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%] .value[_ngcontent-%COMP%]{display:flex;justify-content:space-between;align-items:center}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%] .value[_ngcontent-%COMP%] .primary[_ngcontent-%COMP%], .dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%] .value[_ngcontent-%COMP%] .secondary[_ngcontent-%COMP%]{font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%] .reason[_ngcontent-%COMP%]{font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#6a737d}.dd-list[_ngcontent-%COMP%] .item[_ngcontent-%COMP%]:hover:not(.disabled){background:#f5f7fc}.dd-list[_ngcontent-%COMP%] .data-not-found[_ngcontent-%COMP%]{display:flex;justify-content:center;align-items:center;font-size:16px;padding:8px}.dd-list-pd[_ngcontent-%COMP%]{padding:unset}.chip[_ngcontent-%COMP%]{display:inline-flex;align-items:center;background:#e0e0e0;overflow-wrap:anywhere;cursor:default}.chip[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{color:#181f33}.chip-md[_ngcontent-%COMP%]{border-radius:16px;padding:4px 12px}.chip-sm[_ngcontent-%COMP%]{border-radius:6px;padding:4px 8px;text-transform:uppercase}.ip-md[_ngcontent-%COMP%]{padding-top:8px;padding-bottom:8px}.ip-sm[_ngcontent-%COMP%]{padding-top:3px;padding-bottom:3px}.status-container[_ngcontent-%COMP%]{display:flex;justify-content:center;align-items:center;height:128px}.status-container[_ngcontent-%COMP%] p[_ngcontent-%COMP%]{text-align:center} #spinner{position:relative!important}"] }); }
|
|
462
442
|
}
|
|
463
443
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AsyncDropdownComponent, [{
|
|
464
444
|
type: Component,
|
|
465
|
-
args: [{ selector:
|
|
466
|
-
}], () => [{ type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i0.NgZone }], {
|
|
467
|
-
type: Input
|
|
468
|
-
}], width: [{
|
|
469
|
-
type: Input
|
|
470
|
-
}], size: [{
|
|
471
|
-
type: Input
|
|
472
|
-
}], httpStream: [{
|
|
473
|
-
type: Input
|
|
474
|
-
}], displayKey: [{
|
|
475
|
-
type: Input
|
|
476
|
-
}], secondaryDisplayKey: [{
|
|
477
|
-
type: Input
|
|
478
|
-
}], placeholder: [{
|
|
479
|
-
type: Input
|
|
480
|
-
}], debounceTime: [{
|
|
481
|
-
type: Input
|
|
482
|
-
}], minInputLength: [{
|
|
483
|
-
type: Input
|
|
484
|
-
}], multi: [{
|
|
485
|
-
type: Input
|
|
486
|
-
}], uniqueKey: [{
|
|
487
|
-
type: Input
|
|
488
|
-
}], control: [{
|
|
489
|
-
type: Input
|
|
490
|
-
}], disabled: [{
|
|
491
|
-
type: Input
|
|
492
|
-
}], readonly: [{
|
|
493
|
-
type: Input
|
|
494
|
-
}], disableCopyPaste: [{
|
|
495
|
-
type: Input
|
|
496
|
-
}], dropdownListWidth: [{
|
|
497
|
-
type: Input
|
|
498
|
-
}], dropdownListPosition: [{
|
|
499
|
-
type: Input
|
|
500
|
-
}], customPlaceholderIcon: [{
|
|
501
|
-
type: Input
|
|
502
|
-
}], origin: [{
|
|
445
|
+
args: [{ selector: 'mis-async-search-dropdown', template: "<div class=\"dd-wrapper\"\n [ngClass]=\"{ opened: opened(), disabled: disabled(), readonly: readonly() }\"\n [style.width]=\"width()\"\n #ddBtn>\n \n <!-- Selected chips for multi-select -->\n <div class=\"selected-list\" *ngIf=\"multi() && selectedItems.length > 0\">\n <div class=\"chip\"\n [ngClass]=\"{ 'chip-md': size() === 'md', 'chip-sm': size() === 'sm' }\"\n *ngFor=\"let item of selectedItems\">\n <span [ngClass]=\"{ 'h6': size() === 'md', 'h8-b': size() === 'sm' }\"\n style=\"margin-right: 4px;\">\n {{ item[displayKey()] }}\n </span>\n <span class=\"icon-ic-navigation-cancel-24\"\n [ngStyle]=\"{ cursor: 'pointer', 'font-size': size() === 'sm' ? '12px' : '14px' }\"\n tabindex=\"0\"\n (click)=\"removeItem(item)\"\n (keyup.enter)=\"removeItem(item)\">\n </span>\n </div>\n </div>\n\n <!-- Search input -->\n <div class=\"search-input\">\n <!-- Placeholder icon -->\n <div *ngIf=\"customPlaceholderIcon(); else defaultSearchIcon\" class=\"custom-icon\">\n <img [src]=\"customPlaceholderIcon()\" alt=\"customIcon\" />\n </div>\n <ng-template #defaultSearchIcon>\n <span class=\"icon-ic-action-search-24\"></span>\n </ng-template>\n\n <!-- Input field -->\n <input [ngClass]=\"{ 'ip-md': size() === 'md', 'ip-sm': size() === 'sm' }\"\n [placeholder]=\"placeholder()\"\n [formControl]=\"searchInput\"\n [attr.tabindex]=\"0\"\n type=\"text\"\n class=\"black-text h6\"\n #input\n (focus)=\"defaultCall()\"\n (keyup.enter)=\"enablePopUpOnTab()\"\n [attr.oncopy]=\"disableCopyPaste() ? 'return false;' : null\"\n [attr.onpaste]=\"disableCopyPaste() ? 'return false;' : null\"\n [attr.oncut]=\"disableCopyPaste() ? 'return false;' : null\"/>\n\n <!-- Clear input -->\n <div class=\"icon-ic-navigation-cancel-24 croos-icon\"\n *ngIf=\"searchInput.value?.length\"\n tabindex=\"0\"\n (click)=\"removeInputValue()\"\n (keyup.enter)=\"removeInputValue()\">\n </div>\n </div>\n</div>\n\n<!-- Dropdown template -->\n<ng-template #dd>\n <div class=\"dd-list\"\n [ngStyle]=\"{ 'max-height': height(), 'width': dropdownListWidth() }\"\n [ngClass]=\"{ 'dd-list-pd': data().length === 0 }\"\n tabindex=\"0\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"openPopUpOnTab()\">\n\n <!-- Loader -->\n <ng-container *ngIf=\"loading()\">\n <ng-container *ngIf=\"customLoader; else defaultLoader\" [ngTemplateOutlet]=\"customLoader\"></ng-container>\n <ng-template #defaultLoader>\n <div class=\"status-container\" *ngIf=\"loading() && !customLoader\">\n <mis-loader [mobileView]=\"true\"></mis-loader>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Error -->\n <ng-container *ngIf=\"error()\">\n <div class=\"status-container\">\n <p>Unknown error has occurred, <br/> Please try again later.</p>\n </div>\n </ng-container>\n\n <!-- Data list -->\n <div *ngIf=\"!loading() && !error() && data().length > 0\">\n <ng-container *ngFor=\"let item of data()\">\n <div (click)=\"selectData(item, false)\" (keyup.enter)=\"selectData(item, false)\">\n <div tabindex=\"-1\" cdkFocusInitial></div>\n\n <!-- Custom item -->\n <ng-container *ngIf=\"customItem; else standardItem\">\n <ng-container [ngTemplateOutlet]=\"customItem\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\n </ng-container>\n\n <!-- Standard item -->\n <ng-template #standardItem>\n <div tabindex=\"-1\" cdkFocusInitial></div>\n <div class=\"item\"\n [tabindex]=\"openPopUpOnTab() ? 0 : -1\"\n (click)=\"selectData(item, false)\"\n (keyup.enter)=\"selectData(item, false)\">\n <div class=\"value\">\n <div class=\"primary\">{{ item[displayKey()] }}</div>\n <div class=\"secondary\">{{ item[secondaryDisplayKey()] }}</div>\n </div>\n </div>\n </ng-template>\n </div>\n </ng-container>\n </div>\n\n <!-- No data -->\n <div *ngIf=\"!loading() && !error() && data().length === 0 && searchInput.value\">\n <div class=\"data-not-found\">No Data Available</div>\n </div>\n </div>\n</ng-template>\n", styles: [".dd-wrapper{background:#fff;border:1px solid #e0e0e0;box-sizing:border-box;border-radius:4px;display:block;cursor:pointer;outline:none}.dd-wrapper.opened,.dd-wrapper:hover{background:#f5f5f5}.dd-wrapper .selected-list{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:4px;padding:8px 16px}.dd-wrapper:focus-within{border-color:#0937b2;background:#f5f5f5}.dd-wrapper.disabled,.dd-wrapper.readonly{pointer-events:none}.search-input{position:relative;border-radius:8px}.search-input input{box-sizing:border-box;outline:none;padding-left:40px;padding-right:24px;background-color:transparent;color:#181f33;border-radius:inherit;border:1px solid transparent;width:100%}.search-input span,.search-input .custom-icon{position:absolute;top:50%;transform:translateY(-50%);font-size:24px;line-height:24px;height:24px;left:8px}.search-input .croos-icon{position:absolute;top:50%;transform:translateY(-50%);font-size:16px;width:24px;line-height:16px;height:16px;right:0}.dd-list{padding:8px 0;max-height:200px;background:#fff;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:8px;min-width:100%;overflow-y:auto}.dd-list::-webkit-scrollbar{width:8px;border-radius:4px}.dd-list::-webkit-scrollbar-track{background:#fff;border-radius:4px}.dd-list::-webkit-scrollbar-thumb{background:#929dab;border-radius:4px}.dd-list::-webkit-scrollbar-thumb:hover{background:#929dab}.dd-list .item{padding:8px 16px;cursor:pointer}.dd-list .item .disabled{color:#6a737d!important;pointer-events:none}.dd-list .item .value{display:flex;justify-content:space-between;align-items:center}.dd-list .item .value .primary,.dd-list .item .value .secondary{font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.dd-list .item .reason{font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#6a737d}.dd-list .item:hover:not(.disabled){background:#f5f7fc}.dd-list .data-not-found{display:flex;justify-content:center;align-items:center;font-size:16px;padding:8px}.dd-list-pd{padding:unset}.chip{display:inline-flex;align-items:center;background:#e0e0e0;overflow-wrap:anywhere;cursor:default}.chip span{color:#181f33}.chip-md{border-radius:16px;padding:4px 12px}.chip-sm{border-radius:6px;padding:4px 8px;text-transform:uppercase}.ip-md{padding-top:8px;padding-bottom:8px}.ip-sm{padding-top:3px;padding-bottom:3px}.status-container{display:flex;justify-content:center;align-items:center;height:128px}.status-container p{text-align:center}::ng-deep #spinner{position:relative!important}\n"] }]
|
|
446
|
+
}], () => [{ type: i1.Overlay }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i0.Injector }], { origin: [{
|
|
503
447
|
type: ViewChild,
|
|
504
|
-
args: [
|
|
505
|
-
}],
|
|
448
|
+
args: ['ddBtn', { static: false }]
|
|
449
|
+
}], inputRef: [{
|
|
506
450
|
type: ViewChild,
|
|
507
|
-
args: [
|
|
451
|
+
args: ['input', { static: false }]
|
|
508
452
|
}], dd: [{
|
|
509
453
|
type: ViewChild,
|
|
510
|
-
args: [
|
|
454
|
+
args: ['dd', { static: false }]
|
|
511
455
|
}], customItem: [{
|
|
512
456
|
type: ContentChild,
|
|
513
|
-
args: [
|
|
457
|
+
args: ['misCustomItem', { static: false }]
|
|
514
458
|
}], customLoader: [{
|
|
515
459
|
type: ContentChild,
|
|
516
|
-
args: [
|
|
517
|
-
}], onSelect: [{
|
|
518
|
-
type: Output
|
|
519
|
-
}], selections: [{
|
|
520
|
-
type: Input
|
|
521
|
-
}], searchValue: [{
|
|
522
|
-
type: Input
|
|
523
|
-
}], searchQueryChange: [{
|
|
524
|
-
type: Output
|
|
525
|
-
}], clear: [{
|
|
526
|
-
type: Output
|
|
527
|
-
}], itemSelected: [{
|
|
528
|
-
type: Output
|
|
529
|
-
}], itemRemoved: [{
|
|
530
|
-
type: Output
|
|
460
|
+
args: ['asyncCustomLoader', { static: false }]
|
|
531
461
|
}], handleKeyDown: [{
|
|
532
462
|
type: HostListener,
|
|
533
463
|
args: ['document:keydown', ['$event']]
|
|
534
464
|
}] }); })();
|
|
535
465
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AsyncDropdownComponent, { className: "AsyncDropdownComponent" }); })();
|
|
536
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.ts","../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectionPositionPair, Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport {\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from \"@angular/core\";\nimport { AbstractControl, UntypedFormControl } from \"@angular/forms\";\nimport { merge, Observable, Subject, Subscription } from \"rxjs\";\nimport { debounceTime, distinctUntilChanged, tap } from \"rxjs/operators\";\n\n// tslint:disable-next-line\ntype IListData = any;\n\n@Component({\n  selector: \"mis-async-search-dropdown\",\n  templateUrl: \"./async-dropdown.component.html\",\n  styleUrls: [\"./async-dropdown.component.scss\"]\n})\nexport class AsyncDropdownComponent implements OnInit, OnChanges, OnDestroy {\n  constructor(private overlay: Overlay, private viewContainerRef: ViewContainerRef, private _ngZone: NgZone) { }\n  @Input() height;\n  @Input() width;\n  @Input() size: 'md' | 'sm' = 'md'\n  @Input() httpStream!: (searchKey: string) => Observable<IListData>; // function that returns an httpobservable\n  @Input() displayKey!: string; // string to show value in list\n  @Input() secondaryDisplayKey!: string; // string to display secondary value\n  @Input() placeholder = \"Select\"; // placeholder for input\n  @Input() debounceTime = 400; // wait time till which API call is paused\n  @Input() minInputLength = 2; // min length after which API call is made\n  @Input() multi = false; // maintain a list or emit value\n  @Input() uniqueKey: string; // for identifying unique values\n  @Input() control: AbstractControl | null; // form control for reactive forms\n  @Input() disabled: boolean; // disable actions on component\n  @Input() readonly: boolean; // make component readonly\n  @Input() disableCopyPaste: boolean = false;\n  @Input() dropdownListWidth; //width of dropdown list\n  @Input() dropdownListPosition: \"Left\" | \"Right\" = \"Left\"; //dropdown position\n  @Input() customPlaceholderIcon: string = \"\"; // custom icon for placeholder instead of default search icon\n  @ViewChild(\"ddBtn\", { static: false }) origin: ElementRef;\n  @ViewChild(\"input\", { static: false }) input: ElementRef;\n  @ViewChild(\"dd\", { static: false }) dd: TemplateRef<Element>;\n  @ContentChild(\"misCustomItem\", { static: false })\n  customItem: TemplateRef<Element>;\n  @ContentChild(\"asyncCustomLoader\", { static: false})\n  customLoader: TemplateRef<Element>;\n  // tslint:disable-next-line\n  @Output() onSelect: EventEmitter<IListData | IListData[]> = new EventEmitter(true); // emit selected values\n  searchInput: UntypedFormControl = new UntypedFormControl();\n  data: IListData[] = [];\n  opened = false;\n  loading: boolean = false;\n  error: boolean = false;\n  openPopUpOnTab: boolean = false;\n  // tslint:disable-next-line\n  @Input() selections: Map<string, any> = new Map();\n  private httpStreamTrigger = new Subject<string>();\n  private searchSubscription: Subscription;\n  private defaultCallSubscription: Subscription;\n  private overlayRef: OverlayRef;\n  controlSubscription: Subscription | undefined;\n  @Input() searchValue;\n  @Output() searchQueryChange = new EventEmitter<string>()\n  @Output() clear: EventEmitter<boolean> = new EventEmitter(false);\n  @Output() itemSelected = new EventEmitter<IListData>()\n  @Output() itemRemoved = new EventEmitter<IListData>()\n  ngOnInit(): void {\n    if (this.multi && !this.uniqueKey) {\n      throw new Error(\"[uniqueKey] required in multi mode.\");\n    }\n    if (this.disabled) {\n      this.searchInput.disable();\n    }\n\n    const searchObservable = this.searchInput.valueChanges.pipe(\n      tap((val) => this.searchQueryChange.emit(val)),\n      debounceTime(this.debounceTime),\n      distinctUntilChanged()\n    );\n\n    this.searchSubscription = merge(searchObservable, this.httpStreamTrigger)\n      .subscribe(res => {\n        this._ngZone.run(() => {\n          res = res?.trim() ?? '';\n          if (res?.length < this.minInputLength || !res?.length) {\n            this.closeDropdown();\n            return;\n          } else if (res?.length > this.minInputLength && this.httpStream) {\n            this.loading = true;\n            this.error = false;\n            if(!this.overlayRef?.hasAttached())\n              this.openDropdown(this.dd, this.origin.nativeElement);\n            this.httpStream(res).subscribe(list => {\n              this.loading = false;\n              this.data = list;\n              if (!this.overlayRef?.hasAttached() && list.length > 0) {\n                this.openDropdown(this.dd, this.origin.nativeElement);\n              }\n            }, error => {\n              this.loading = false;\n              this.error = true;\n            });\n          }\n        })\n      });\n    if (this.control?.value) {\n      this.handleControlChanges(this.control.value);\n    }\n    this.controlSubscription = this.control?.valueChanges.subscribe(this.handleControlChanges);\n  }\n\n  refreshHttpStream(query: string): void {\n    this.loading = true;\n    this.httpStreamTrigger.next(query);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes && changes?.searchValue?.currentValue) {\n      this.searchInput.patchValue(changes.searchValue.currentValue);\n    }\n    if (changes && changes.disabled) {\n      this.searchInput.enable();\n      if (this.disabled) {\n        this.searchInput.disable();\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.searchSubscription?.unsubscribe();\n    this.defaultCallSubscription?.unsubscribe();\n  }\n\n  private handleControlChanges = (values: IListData[]) => {\n    values.forEach(el => {\n      this.selectData(el, true);\n    });\n    // tslint:disable-next-line\n  };\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement): void {\n    const positionsBottom = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"bottom\" }, { overlayX: \"start\", overlayY: \"top\" }, 0, 4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"bottom\" }, { overlayX: \"end\", overlayY: \"top\" }, 0, 4)\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"top\" }, { overlayX: \"start\", overlayY: \"bottom\" }, 0, -4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"top\" }, { overlayX: \"end\", overlayY: \"bottom\" }, 0, -4)\n    ];\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition === \"Right\" ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition === \"Right\" ? positionsTop.reverse() : positionsTop)\n      ])\n      .withPush(true);\n\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: \"cdk-overlay-transparent-backdrop\",\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin.clientWidth\n    });\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth) this.overlayRef.updateSize({ width: this.dropdownListWidth });\n    this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef.backdropClick().subscribe(res => {\n      this.closeDropdown();\n    });\n  }\n\n  /**\n   * closes the dropdown\n   */\n  closeDropdown(): void {\n    this.opened = false;\n    this.openPopUpOnTab = false;\n    this.overlayRef?.detach();\n    this.data = [];\n  }\n\n  enablePopUpOnTab(){\n    this.openPopUpOnTab = true;\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  handleKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Escape') {\n      this.searchInput.patchValue(\"\");\n      this.closeDropdown();\n    }\n  }\n\n\n\n  /**\n   *\n   * @param item item to select\n   * if item property disabled is set to true, selection will be disabled\n   * @param effectedFromOutside set to true if calling from parent component, if true will focus on search input\n   */\n  selectData(item: IListData, effectedFromOutside = true): void {\n    if (item.disabled) {\n      return;\n    }\n    this.itemSelected.emit(item)\n    if (!this.multi) {\n      this.searchInput.patchValue(item[this.displayKey], { emitEvent: false });\n      this.setControlValue(item);\n    } else {\n      if (!this.selections.has(item[this.uniqueKey])) {\n        this.selections.set(item[this.uniqueKey], item);\n      }\n      this.setControlValue(this.selectedItems);\n      if (!effectedFromOutside) {\n        setTimeout(() => {\n          this.input.nativeElement.focus();\n          this.input.nativeElement.scrollIntoView();\n        }, 10);\n      }\n      this.searchInput.patchValue(\"\");\n      this.data = [];\n    }\n    this.closeDropdown();\n  }\n\n  /**\n   *\n   * @param item remove item from selected list\n   */\n  removeItem(item: IListData): void {\n    this.itemRemoved.emit(item)\n    this.selections.delete(item[this.uniqueKey]);\n    this.setControlValue(this.selectedItems);\n    // tslint:disable-next-line\n    this.input[\"nativeElement\"].focus();\n  }\n\n  private setControlValue(value: IListData): void {\n    this.onSelect.emit(value);\n    this.control?.patchValue(value, { emitEvent: false });\n  }\n\n  /**\n   * @returns list of selected items\n   */\n  get selectedItems(): Array<IListData> {\n    return Array.from(this.selections.values());\n  }\n\n  removeInputValue() {\n    this.searchInput.reset();\n    this.data = [];\n    this.clear.emit(true);\n  }\n  defaultCall(): void {\n    if (this.minInputLength === -1) {\n      this.loading = true;\n      this.defaultCallSubscription = this.httpStream(this.searchInput.value || '').subscribe(list => {\n        this.loading = false;\n        this.data = list;\n        if (!this.overlayRef?.hasAttached() && this.data?.length > 0) {\n          this.openDropdown(this.dd, this.origin.nativeElement);\n        }\n      }, error => {\n        this.loading = false;\n        this.error = true;\n      });\n    }\n  }\n}\n","<div class=\"dd-wrapper\" [ngClass]=\"{ opened: opened, disabled: disabled, readonly: readonly }\" [style.width]=\"width\" #ddBtn>\n  <div class=\"selected-list\" *ngIf=\"multi && selections.size > 0\">\n    <div class=\"chip\" [ngClass]=\"{'chip-md': size === 'md', 'chip-sm': size === 'sm'}\" *ngFor=\"let item of selectedItems\">\n      <span [ngClass]=\"{'h6': size === 'md', 'h8-b': size === 'sm'}\" [ngStyle]=\"{ 'margin-right': '4px'}\">{{item[displayKey]}}</span>\n      <span style=\"cursor: pointer;\" (click)=\"removeItem(item)\" tabindex=\"0\" (keyup.enter)=\"removeItem(item)\" [ngStyle]=\"{\n        'cursor': 'pointer',\n        'font-size': size === 'sm' ? '12px' : '14px'\n      }\" class=\"icon-ic-navigation-cancel-24\"></span>\n    </div>\n  </div>\n  <div class=\"search-input\">\n    <div *ngIf=\"customPlaceholderIcon; else defaultSearchIcon\" class=\"custom-icon\">\n      <img [src]=\"customPlaceholderIcon\" alt=\"customIcon\" />\n    </div>\n    <ng-template #defaultSearchIcon>\n      <span class=\"icon-ic-action-search-24\"></span>\n    </ng-template>\n    <input *ngIf=\"disableCopyPaste; else enableCopyPaste\" [ngClass]=\"{'ip-md': size === 'md', 'ip-sm': size === 'sm'}\" oncopy=\"return false;\" onpaste=\"return false\" oncut=\"return false\" tabindex=\"0\" type=\"text\" class=\"black-text h6\" #input [placeholder]=\"placeholder\" [formControl]=\"searchInput\" (focus)=\"defaultCall()\" (keyup.enter)=\"enablePopUpOnTab()\"/>\n    <ng-template #enableCopyPaste>\n      <input [ngClass]=\"{'ip-md': size === 'md', 'ip-sm': size === 'sm'}\" tabindex=\"0\" type=\"text\" class=\"black-text h6\" #input [placeholder]=\"placeholder\" [formControl]=\"searchInput\" (focus)=\"defaultCall()\" (keyup.enter)=\"enablePopUpOnTab()\" />\n    </ng-template>\n    <div class=\"icon-ic-navigation-cancel-24 croos-icon\" *ngIf=\"searchInput?.value?.length\" tabindex=\"0\" (click)=\"removeInputValue()\" (keyup.enter)=\"removeInputValue()\"></div>\n  </div>\n</div>\n\n<ng-template #dd>\n  <div class=\"dd-list\" [ngStyle]=\"{'max-height':height, 'width': dropdownListWidth}\"  [ngClass]=\"{'dd-list-pd':data.length === 0}\" tabindex=\"0\" cdkTrapFocus [cdkTrapFocusAutoCapture]=\"openPopUpOnTab\">\n    <ng-container *ngIf=\"loading\">\n      <ng-container\n        *ngIf=\"customLoader; else defaultLoader\"\n        [ngTemplateOutlet]=\"customLoader\"\n      ></ng-container>\n      <ng-template #defaultLoader>\n        <div class=\"status-container\" *ngIf=\"loading && !customLoader\">\n          <mis-loader [mobileView]=\"true\"></mis-loader>\n        </div>\n      </ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"error\">\n      <div class=\"status-container\">\n        <p>Unknown error has occurred, <br> Please try again later.</p>\n      </div>\n    </ng-container>\n    <div *ngIf=\"!loading && !error && data.length > 0\">\n      <ng-container *ngFor=\"let item of data\">\n        <div (click)=\"selectData(item, false)\" (keyup.enter)=\"selectData(item, false)\"> \n          <div tabindex=\"-1\" cdkFocusInitial></div>  \n          <div\n          [tabindex]=\"openPopUpOnTab ? 0 : -1\"\n          *ngIf=\"customItem; else standardItem\"\n        >\n          <ng-container\n            [ngTemplateOutlet]=\"customItem\"\n            [ngTemplateOutletContext]=\"{ $implicit: item }\"\n          ></ng-container>\n        </div>\n          <ng-template #standardItem>\n            <div tabindex=\"-1\" cdkFocusInitial></div>  \n            <div class=\"item\" (click)=\"selectData(item, false)\" [tabindex]=\"openPopUpOnTab ? 0 : -1\" (keyup.enter)=\"selectData(item, false)\">\n              <div class=\"value\">\n                <div class=\"primary\">\n                  {{ item[displayKey] }}\n                </div>\n                <div class=\"secondary\">\n                  {{ item[secondaryDisplayKey] }}\n                </div>\n              </div>\n            </div>\n          </ng-template>\n        </div>\n      </ng-container>\n    </div>\n    <div *ngIf=\"!loading && !error && data.length === 0 && searchInput.value\">\n      <div class=\"data-not-found\">No Data Available</div>\n  </div>\n  </div>\n</ng-template>\n"]}
|
|
466
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.ts","../../../../projects/mis-components/async-search-dropdown/async-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ElementRef,\n  HostListener,\n  Injector,\n  NgZone,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { AbstractControl, UntypedFormControl } from '@angular/forms';\nimport {\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ConnectionPositionPair,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { signal, effect, input, output } from '@angular/core';\nimport { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';\nimport { merge, Subject } from 'rxjs';\n\ntype IListData = any;\n\n@Component({\n  selector: 'mis-async-search-dropdown',\n  templateUrl: './async-dropdown.component.html',\n  styleUrls: ['./async-dropdown.component.scss'],\n})\nexport class AsyncDropdownComponent {\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private _ngZone: NgZone,\n    private injector: Injector\n  ) {}\n\n  // === Inputs ===\n  height = input<string>();\n  width = input<string>();\n  size = input<'md' | 'sm'>('md');\n  httpStream = input.required<(searchKey: string) => any>();\n  displayKey = input.required<string>();\n  secondaryDisplayKey = input<string>('');\n  placeholder = input('Select');\n  debounceTime = input(400);\n  minInputLength = input(2);\n  multi = input(false);\n  uniqueKey = input<string>();\n  control = input<AbstractControl | null>(null);\n  disabled = input(false);\n  readonly = input(false);\n  disableCopyPaste = input(false);\n  dropdownListWidth = input<string>();\n  dropdownListPosition = input<'Left' | 'Right'>('Left');\n  customPlaceholderIcon = input<string>('');\n  selections = input<Map<string, any>>(new Map());\n  searchValue = input<string>();\n\n  // === Outputs ===\n  onSelect = output<IListData | IListData[]>();\n  searchQueryChange = output<string>();\n  clear = output<boolean>();\n  itemSelected = output<IListData>();\n  itemRemoved = output<IListData>();\n\n  // === Template Refs ===\n  @ViewChild('ddBtn', { static: false }) origin!: ElementRef;\n  @ViewChild('input', { static: false }) inputRef!: ElementRef;\n  @ViewChild('dd', { static: false }) dd!: TemplateRef<Element>;\n  @ContentChild('misCustomItem', { static: false }) customItem!: TemplateRef<Element>;\n  @ContentChild('asyncCustomLoader', { static: false }) customLoader!: TemplateRef<Element>;\n\n  // === Internal state ===\n  searchInput: UntypedFormControl = new UntypedFormControl();\n  private httpStreamTrigger = new Subject<string>();\n  private overlayRef?: OverlayRef;\n\n  // === Signals ===\n  opened = signal(false);\n  loading = signal(false);\n  error = signal(false);\n  openPopUpOnTab = signal(false);\n  data = signal<IListData[]>([]);\n\n  // === Effect to handle search ===\n  private searchEffect = effect(() => {\n    // Merge form control changes and manual triggers\n    merge(\n      this.searchInput.valueChanges.pipe(\n        tap((val) => this.searchQueryChange.emit(val)),\n        debounceTime(this.debounceTime()),\n        distinctUntilChanged()\n      ),\n      this.httpStreamTrigger\n    ).subscribe((query: string) => {\n      const q = query?.trim() ?? '';\n      if (!q || q.length < this.minInputLength()) {\n        this.closeDropdown();\n        return;\n      }\n\n      this.loading.set(true);\n      this.error.set(false);\n\n      // Open overlay if not yet open\n      if (!this.overlayRef?.hasAttached()) {\n        this.openDropdown(this.dd, this.origin.nativeElement);\n      }\n\n      // Call HTTP stream\n      this.httpStream()(q).subscribe({\n        next: (list: IListData[]) => {\n          this.loading.set(false);\n          this.data.set(list);\n        },\n        error: () => {\n          this.loading.set(false);\n          this.error.set(true);\n        },\n      });\n    });\n  });\n\n  // === Lifecycle ===\n  ngOnInit() {\n    if (this.multi() && !this.uniqueKey()) {\n      throw new Error('[uniqueKey] required in multi mode.');\n    }\n\n    if (this.disabled()) this.searchInput.disable();\n\n    if (this.control()?.value) {\n      this.handleControlChanges(this.control()!.value);\n    }\n\n    this.control()?.valueChanges.subscribe(this.handleControlChanges);\n  }\n\n  ngOnChanges() {\n    if (this.searchValue()) {\n      this.searchInput.patchValue(this.searchValue());\n    }\n    if (this.disabled()) {\n      this.searchInput.disable();\n    } else {\n      this.searchInput.enable();\n    }\n  }\n\n  ngOnDestroy() {\n    this.overlayRef?.dispose();\n  }\n\n  // === Methods ===\n  refreshHttpStream(query: string) {\n    this.httpStreamTrigger.next(query);\n  }\n\n  private handleControlChanges = (values: IListData[]) => {\n    values.forEach((el) => this.selectData(el, true));\n  };\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement) {\n    const positionsBottom = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0,\n        4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0,\n        4\n      ),\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0,\n        -4\n      ),\n    ];\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition() === 'Right' ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition() === 'Right' ? positionsTop.reverse() : positionsTop),\n      ])\n      .withPush(true);\n\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin.clientWidth,\n    });\n\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth()) this.overlayRef.updateSize({ width: this.dropdownListWidth() });\n\n    this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef.backdropClick().subscribe(() => this.closeDropdown());\n  }\n\n  closeDropdown() {\n    this.opened.set(false);\n    this.openPopUpOnTab.set(false);\n    this.overlayRef?.detach();\n    this.data.set([]);\n  }\n\n  enablePopUpOnTab() {\n    this.openPopUpOnTab.set(true);\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  handleKeyDown(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.searchInput.reset();\n      this.closeDropdown();\n    }\n  }\n\n  selectData(item: IListData, effectedFromOutside = true) {\n    if (item.disabled) return;\n\n    this.itemSelected.emit(item);\n\n    if (!this.multi()) {\n      this.searchInput.patchValue(item[this.displayKey()], { emitEvent: false });\n      this.setControlValue(item);\n    } else {\n      if (!this.selections().has(item[this.uniqueKey()])) {\n        this.selections().set(item[this.uniqueKey()], item);\n      }\n      this.setControlValue(this.selectedItems);\n      if (!effectedFromOutside) {\n        setTimeout(() => {\n          this.inputRef.nativeElement.focus();\n          this.inputRef.nativeElement.scrollIntoView();\n        }, 10);\n      }\n      this.searchInput.patchValue('');\n      this.data.set([]);\n    }\n    this.closeDropdown();\n  }\n\n  removeItem(item: IListData) {\n    this.itemRemoved.emit(item);\n    this.selections().delete(item[this.uniqueKey()]);\n    this.setControlValue(this.selectedItems);\n    this.inputRef.nativeElement.focus();\n  }\n\n  private setControlValue(value: IListData | IListData[]) {\n    this.onSelect.emit(value);\n    this.control()?.patchValue(value, { emitEvent: false });\n  }\n\n  get selectedItems() {\n    return Array.from(this.selections().values());\n  }\n\n  removeInputValue() {\n    this.searchInput.reset();\n    this.data.set([]);\n    this.clear.emit(true);\n  }\n\n  defaultCall() {\n    if (this.minInputLength() === -1) {\n      this.loading.set(true);\n      this.httpStream()(this.searchInput.value || '').subscribe({\n        next: (list: IListData[]) => {\n          this.loading.set(false);\n          this.data.set(list);\n          if (!this.overlayRef?.hasAttached() && list.length > 0) {\n            this.openDropdown(this.dd, this.origin.nativeElement);\n          }\n        },\n        error: () => {\n          this.loading.set(false);\n          this.error.set(true);\n        },\n      });\n    }\n  }\n}\n","<div class=\"dd-wrapper\"\n     [ngClass]=\"{ opened: opened(), disabled: disabled(), readonly: readonly() }\"\n     [style.width]=\"width()\"\n     #ddBtn>\n  \n  <!-- Selected chips for multi-select -->\n  <div class=\"selected-list\" *ngIf=\"multi() && selectedItems.length > 0\">\n    <div class=\"chip\"\n         [ngClass]=\"{ 'chip-md': size() === 'md', 'chip-sm': size() === 'sm' }\"\n         *ngFor=\"let item of selectedItems\">\n      <span [ngClass]=\"{ 'h6': size() === 'md', 'h8-b': size() === 'sm' }\"\n            style=\"margin-right: 4px;\">\n        {{ item[displayKey()] }}\n      </span>\n      <span class=\"icon-ic-navigation-cancel-24\"\n            [ngStyle]=\"{ cursor: 'pointer', 'font-size': size() === 'sm' ? '12px' : '14px' }\"\n            tabindex=\"0\"\n            (click)=\"removeItem(item)\"\n            (keyup.enter)=\"removeItem(item)\">\n      </span>\n    </div>\n  </div>\n\n  <!-- Search input -->\n  <div class=\"search-input\">\n    <!-- Placeholder icon -->\n    <div *ngIf=\"customPlaceholderIcon(); else defaultSearchIcon\" class=\"custom-icon\">\n      <img [src]=\"customPlaceholderIcon()\" alt=\"customIcon\" />\n    </div>\n    <ng-template #defaultSearchIcon>\n      <span class=\"icon-ic-action-search-24\"></span>\n    </ng-template>\n\n    <!-- Input field -->\n    <input [ngClass]=\"{ 'ip-md': size() === 'md', 'ip-sm': size() === 'sm' }\"\n           [placeholder]=\"placeholder()\"\n           [formControl]=\"searchInput\"\n           [attr.tabindex]=\"0\"\n           type=\"text\"\n           class=\"black-text h6\"\n           #input\n           (focus)=\"defaultCall()\"\n           (keyup.enter)=\"enablePopUpOnTab()\"\n           [attr.oncopy]=\"disableCopyPaste() ? 'return false;' : null\"\n           [attr.onpaste]=\"disableCopyPaste() ? 'return false;' : null\"\n           [attr.oncut]=\"disableCopyPaste() ? 'return false;' : null\"/>\n\n    <!-- Clear input -->\n    <div class=\"icon-ic-navigation-cancel-24 croos-icon\"\n         *ngIf=\"searchInput.value?.length\"\n         tabindex=\"0\"\n         (click)=\"removeInputValue()\"\n         (keyup.enter)=\"removeInputValue()\">\n    </div>\n  </div>\n</div>\n\n<!-- Dropdown template -->\n<ng-template #dd>\n  <div class=\"dd-list\"\n       [ngStyle]=\"{ 'max-height': height(), 'width': dropdownListWidth() }\"\n       [ngClass]=\"{ 'dd-list-pd': data().length === 0 }\"\n       tabindex=\"0\"\n       cdkTrapFocus\n       [cdkTrapFocusAutoCapture]=\"openPopUpOnTab()\">\n\n    <!-- Loader -->\n    <ng-container *ngIf=\"loading()\">\n      <ng-container *ngIf=\"customLoader; else defaultLoader\" [ngTemplateOutlet]=\"customLoader\"></ng-container>\n      <ng-template #defaultLoader>\n        <div class=\"status-container\" *ngIf=\"loading() && !customLoader\">\n          <mis-loader [mobileView]=\"true\"></mis-loader>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Error -->\n    <ng-container *ngIf=\"error()\">\n      <div class=\"status-container\">\n        <p>Unknown error has occurred, <br/> Please try again later.</p>\n      </div>\n    </ng-container>\n\n    <!-- Data list -->\n    <div *ngIf=\"!loading() && !error() && data().length > 0\">\n      <ng-container *ngFor=\"let item of data()\">\n        <div (click)=\"selectData(item, false)\" (keyup.enter)=\"selectData(item, false)\">\n          <div tabindex=\"-1\" cdkFocusInitial></div>\n\n          <!-- Custom item -->\n          <ng-container *ngIf=\"customItem; else standardItem\">\n            <ng-container [ngTemplateOutlet]=\"customItem\"\n                          [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\n          </ng-container>\n\n          <!-- Standard item -->\n          <ng-template #standardItem>\n            <div tabindex=\"-1\" cdkFocusInitial></div>\n            <div class=\"item\"\n                 [tabindex]=\"openPopUpOnTab() ? 0 : -1\"\n                 (click)=\"selectData(item, false)\"\n                 (keyup.enter)=\"selectData(item, false)\">\n              <div class=\"value\">\n                <div class=\"primary\">{{ item[displayKey()] }}</div>\n                <div class=\"secondary\">{{ item[secondaryDisplayKey()] }}</div>\n              </div>\n            </div>\n          </ng-template>\n        </div>\n      </ng-container>\n    </div>\n\n    <!-- No data -->\n    <div *ngIf=\"!loading() && !error() && data().length === 0 && searchInput.value\">\n      <div class=\"data-not-found\">No Data Available</div>\n    </div>\n  </div>\n</ng-template>\n"]}
|