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,5 +1,5 @@
|
|
|
1
1
|
/** @format */
|
|
2
|
-
import { Component, HostListener,
|
|
2
|
+
import { Component, HostListener, ChangeDetectionStrategy, input, signal, computed } from "@angular/core";
|
|
3
3
|
import { trigger, transition, style, animate, state } from "@angular/animations";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
@@ -38,7 +38,7 @@ function FabComponent_div_0_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
|
38
38
|
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
39
39
|
i0.ɵɵproperty("@slideUpFab", undefined);
|
|
40
40
|
i0.ɵɵadvance();
|
|
41
|
-
i0.ɵɵproperty("ngForOf", ctx_r3.items.reverse());
|
|
41
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.items().reverse());
|
|
42
42
|
} }
|
|
43
43
|
function FabComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
44
44
|
const _r1 = i0.ɵɵgetCurrentView();
|
|
@@ -53,51 +53,53 @@ function FabComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
|
53
53
|
} if (rf & 2) {
|
|
54
54
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
55
55
|
i0.ɵɵadvance();
|
|
56
|
-
i0.ɵɵproperty("ngIf", ctx_r3.isOpen);
|
|
56
|
+
i0.ɵɵproperty("ngIf", ctx_r3.isOpen());
|
|
57
57
|
i0.ɵɵadvance();
|
|
58
|
-
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(3, _c0, ctx_r3.isOpen ? ctx_r3.
|
|
58
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(3, _c0, ctx_r3.isOpen() ? ctx_r3.computedOptions().backgroundColorOpened : ctx_r3.computedOptions().backgroundColorClosed));
|
|
59
59
|
i0.ɵɵadvance();
|
|
60
|
-
i0.ɵɵproperty("@rotateButton", ctx_r3.isOpen ? "rotated" : "default");
|
|
60
|
+
i0.ɵɵproperty("@rotateButton", ctx_r3.isOpen() ? "rotated" : "default");
|
|
61
61
|
} }
|
|
62
62
|
export class FabComponent {
|
|
63
63
|
constructor(eRef) {
|
|
64
64
|
this.eRef = eRef;
|
|
65
|
-
this.show = false;
|
|
66
|
-
this.options = {};
|
|
67
|
-
this.items = [];
|
|
68
|
-
this.isOpen = false;
|
|
65
|
+
this.show = input(false);
|
|
66
|
+
this.options = input({});
|
|
67
|
+
this.items = input([]);
|
|
68
|
+
this.isOpen = signal(false);
|
|
69
|
+
// Computed signal for options with defaults
|
|
70
|
+
this.computedOptions = computed(() => {
|
|
71
|
+
const currentOptions = this.options();
|
|
72
|
+
return {
|
|
73
|
+
size: 56,
|
|
74
|
+
backgroundColorClosed: "#0937B2",
|
|
75
|
+
backgroundColorOpened: "#3a5fc1",
|
|
76
|
+
...currentOptions
|
|
77
|
+
};
|
|
78
|
+
});
|
|
69
79
|
}
|
|
70
80
|
clickout(event) {
|
|
71
81
|
if (!this.eRef.nativeElement.contains(event.target)) {
|
|
72
82
|
this.closeFab();
|
|
73
83
|
}
|
|
74
84
|
}
|
|
75
|
-
ngOnInit() {
|
|
76
|
-
this.options = {
|
|
77
|
-
size: 56,
|
|
78
|
-
backgroundColorClosed: "#0937B2",
|
|
79
|
-
backgroundColorOpened: "#3a5fc1",
|
|
80
|
-
...this.options
|
|
81
|
-
};
|
|
82
|
-
}
|
|
83
85
|
ngOnDestroy() { }
|
|
84
86
|
clickItem(item) {
|
|
85
87
|
this.closeFab();
|
|
86
|
-
item.click();
|
|
88
|
+
item.click?.();
|
|
87
89
|
}
|
|
88
90
|
closeFab() {
|
|
89
|
-
this.isOpen
|
|
91
|
+
this.isOpen.set(false);
|
|
90
92
|
}
|
|
91
93
|
toogleFab() {
|
|
92
|
-
this.isOpen
|
|
94
|
+
this.isOpen.set(!this.isOpen());
|
|
93
95
|
}
|
|
94
96
|
static { this.ɵfac = function FabComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || FabComponent)(i0.ɵɵdirectiveInject(i0.ElementRef)); }; }
|
|
95
97
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FabComponent, selectors: [["mis-fab"]], hostBindings: function FabComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
96
98
|
i0.ɵɵlistener("click", function FabComponent_click_HostBindingHandler($event) { return ctx.clickout($event); }, false, i0.ɵɵresolveDocument);
|
|
97
|
-
} }, inputs: { show: "show", options: "options", items: "items" }, decls: 1, vars: 1, consts: [["class", "fab-wrapper", 4, "ngIf"], [1, "fab-wrapper"], ["class", "fab-items", 4, "ngIf"], [1, "fab-container", 3, "click", "ngStyle"], ["width", "24", "height", "24", "viewBox", "0 0 24 24", "fill", "none", "xmlns", "http://www.w3.org/2000/svg", 1, "add-img"], ["fill-rule", "evenodd", "clip-rule", "evenodd", "d", "M13.1424 5.15607C13.1424 4.51759 12.6313 4 12.0009 4C11.3704 4 10.8594 4.51759 10.8594 5.15607V10.8421H5.14149C4.51106 10.8421 4 11.3597 4 11.9982C4 12.6367 4.51106 13.1543 5.14149 13.1543H10.8594V18.8439C10.8594 19.4824 11.3704 20 12.0009 20C12.6313 20 13.1424 19.4824 13.1424 18.8439V13.1543H18.8585C19.4889 13.1543 20 12.6367 20 11.9982C20 11.3597 19.4889 10.8421 18.8585 10.8421H13.1424V5.15607Z", "fill", "white"], [1, "fab-items"], ["class", "fab-item", 3, "click", 4, "ngFor", "ngForOf"], [1, "fab-item", 3, "click"], ["class", "fab-tooltip", 4, "ngIf"], [1, "fab-button", 3, "ngStyle"], [1, "add-img", 3, "src"], [1, "fab-tooltip"]], template: function FabComponent_Template(rf, ctx) { if (rf & 1) {
|
|
99
|
+
} }, inputs: { show: [1, "show"], options: [1, "options"], items: [1, "items"] }, decls: 1, vars: 1, consts: [["class", "fab-wrapper", 4, "ngIf"], [1, "fab-wrapper"], ["class", "fab-items", 4, "ngIf"], [1, "fab-container", 3, "click", "ngStyle"], ["width", "24", "height", "24", "viewBox", "0 0 24 24", "fill", "none", "xmlns", "http://www.w3.org/2000/svg", 1, "add-img"], ["fill-rule", "evenodd", "clip-rule", "evenodd", "d", "M13.1424 5.15607C13.1424 4.51759 12.6313 4 12.0009 4C11.3704 4 10.8594 4.51759 10.8594 5.15607V10.8421H5.14149C4.51106 10.8421 4 11.3597 4 11.9982C4 12.6367 4.51106 13.1543 5.14149 13.1543H10.8594V18.8439C10.8594 19.4824 11.3704 20 12.0009 20C12.6313 20 13.1424 19.4824 13.1424 18.8439V13.1543H18.8585C19.4889 13.1543 20 12.6367 20 11.9982C20 11.3597 19.4889 10.8421 18.8585 10.8421H13.1424V5.15607Z", "fill", "white"], [1, "fab-items"], ["class", "fab-item", 3, "click", 4, "ngFor", "ngForOf"], [1, "fab-item", 3, "click"], ["class", "fab-tooltip", 4, "ngIf"], [1, "fab-button", 3, "ngStyle"], [1, "add-img", 3, "src"], [1, "fab-tooltip"]], template: function FabComponent_Template(rf, ctx) { if (rf & 1) {
|
|
98
100
|
i0.ɵɵtemplate(0, FabComponent_div_0_Template, 5, 5, "div", 0);
|
|
99
101
|
} if (rf & 2) {
|
|
100
|
-
i0.ɵɵproperty("ngIf", ctx.show);
|
|
102
|
+
i0.ɵɵproperty("ngIf", ctx.show());
|
|
101
103
|
} }, dependencies: [i1.NgForOf, i1.NgIf, i1.NgStyle], styles: [".fab-wrapper[_ngcontent-%COMP%]{position:fixed;right:24px;bottom:24px;z-index:1000}.fab-wrapper[_ngcontent-%COMP%] .fab-item[_ngcontent-%COMP%]{position:relative;padding:0 0 16px 8px}.fab-wrapper[_ngcontent-%COMP%] .fab-item[_ngcontent-%COMP%] .fab-tooltip[_ngcontent-%COMP%]{position:absolute;background-color:#181f33;border-radius:4px;color:#fff;padding:8px;display:flex;justify-content:center;align-items:center;white-space:nowrap;right:100%;top:calc(50% - 8px);transform:translateY(-50%)}.fab-wrapper[_ngcontent-%COMP%] .fab-item[_ngcontent-%COMP%] .fab-button[_ngcontent-%COMP%]{width:40px;height:40px;cursor:pointer;border-radius:50%;display:flex;justify-content:center;align-items:center}.fab-wrapper[_ngcontent-%COMP%] .fab-container[_ngcontent-%COMP%]{border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;width:56px;height:56px}.add-img[_ngcontent-%COMP%]{height:24px;width:24px}"], data: { animation: [
|
|
102
104
|
trigger("slideUpFab", [
|
|
103
105
|
transition(":enter", [
|
|
@@ -112,11 +114,11 @@ export class FabComponent {
|
|
|
112
114
|
transition("rotated => default", animate("300ms ease-out")),
|
|
113
115
|
transition("default => rotated", animate("200ms ease-in"))
|
|
114
116
|
])
|
|
115
|
-
] } }); }
|
|
117
|
+
] }, changeDetection: 0 }); }
|
|
116
118
|
}
|
|
117
119
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FabComponent, [{
|
|
118
120
|
type: Component,
|
|
119
|
-
args: [{ selector: "mis-fab", animations: [
|
|
121
|
+
args: [{ selector: "mis-fab", changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
120
122
|
trigger("slideUpFab", [
|
|
121
123
|
transition(":enter", [
|
|
122
124
|
style({ transform: "translateY(50px)", opacity: 0 }),
|
|
@@ -130,16 +132,10 @@ export class FabComponent {
|
|
|
130
132
|
transition("rotated => default", animate("300ms ease-out")),
|
|
131
133
|
transition("default => rotated", animate("200ms ease-in"))
|
|
132
134
|
])
|
|
133
|
-
], template: "<div class=\"fab-wrapper\" *ngIf=\"show\">\n <div class=\"fab-items\" *ngIf=\"isOpen\" @slideUpFab>\n <div class=\"fab-item\" *ngFor=\"let item of items.reverse(); let i = index\" (click)=\"clickItem(item)\">\n <div *ngIf=\"item.label\" class=\"fab-tooltip\">\n {{ item.label }}\n </div>\n <div\n class=\"fab-button\"\n [ngStyle]=\"{\n backgroundColor: item.backgroundColor || '#0937B2'\n }\"\n >\n <img [src]=\"item.icon\" class=\"add-img\" />\n </div>\n </div>\n </div>\n <div\n class=\"fab-container\"\n [ngStyle]=\"{\n backgroundColor: isOpen ?
|
|
134
|
-
}], () => [{ type: i0.ElementRef }], {
|
|
135
|
-
type: Input
|
|
136
|
-
}], options: [{
|
|
137
|
-
type: Input
|
|
138
|
-
}], items: [{
|
|
139
|
-
type: Input
|
|
140
|
-
}], clickout: [{
|
|
135
|
+
], template: "<div class=\"fab-wrapper\" *ngIf=\"show()\">\n <div class=\"fab-items\" *ngIf=\"isOpen()\" @slideUpFab>\n <div class=\"fab-item\" *ngFor=\"let item of items().reverse(); let i = index\" (click)=\"clickItem(item)\">\n <div *ngIf=\"item.label\" class=\"fab-tooltip\">\n {{ item.label }}\n </div>\n <div\n class=\"fab-button\"\n [ngStyle]=\"{\n backgroundColor: item.backgroundColor || '#0937B2'\n }\"\n >\n <img [src]=\"item.icon\" class=\"add-img\" />\n </div>\n </div>\n </div>\n <div\n class=\"fab-container\"\n [ngStyle]=\"{\n backgroundColor: isOpen() ? computedOptions().backgroundColorOpened : computedOptions().backgroundColorClosed\n }\"\n (click)=\"toogleFab()\"\n >\n <svg\n [@rotateButton]=\"isOpen() ? 'rotated' : 'default'\"\n class=\"add-img\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M13.1424 5.15607C13.1424 4.51759 12.6313 4 12.0009 4C11.3704 4 10.8594 4.51759 10.8594 5.15607V10.8421H5.14149C4.51106 10.8421 4 11.3597 4 11.9982C4 12.6367 4.51106 13.1543 5.14149 13.1543H10.8594V18.8439C10.8594 19.4824 11.3704 20 12.0009 20C12.6313 20 13.1424 19.4824 13.1424 18.8439V13.1543H18.8585C19.4889 13.1543 20 12.6367 20 11.9982C20 11.3597 19.4889 10.8421 18.8585 10.8421H13.1424V5.15607Z\"\n fill=\"white\"\n />\n </svg>\n </div>\n</div>\n", styles: [".fab-wrapper{position:fixed;right:24px;bottom:24px;z-index:1000}.fab-wrapper .fab-item{position:relative;padding:0 0 16px 8px}.fab-wrapper .fab-item .fab-tooltip{position:absolute;background-color:#181f33;border-radius:4px;color:#fff;padding:8px;display:flex;justify-content:center;align-items:center;white-space:nowrap;right:100%;top:calc(50% - 8px);transform:translateY(-50%)}.fab-wrapper .fab-item .fab-button{width:40px;height:40px;cursor:pointer;border-radius:50%;display:flex;justify-content:center;align-items:center}.fab-wrapper .fab-container{border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;width:56px;height:56px}.add-img{height:24px;width:24px}\n"] }]
|
|
136
|
+
}], () => [{ type: i0.ElementRef }], { clickout: [{
|
|
141
137
|
type: HostListener,
|
|
142
138
|
args: ["document:click", ["$event"]]
|
|
143
139
|
}] }); })();
|
|
144
140
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FabComponent, { className: "FabComponent" }); })();
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fab.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/fab/fab.component.ts","../../../../projects/mis-components/fab/fab.component.html"],"names":[],"mappings":"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","sourcesContent":["/** @format */\n\nimport { Component, ElementRef, HostListener, OnDestroy, ChangeDetectionStrategy, input, signal, WritableSignal, computed } from \"@angular/core\";\nimport { trigger, transition, style, animate, state } from \"@angular/animations\";\n\nexport type FabOptions = {\n  backgroundColorClosed?: string;\n  backgroundColorOpened?: string;\n  size?: number;\n};\n\nexport type FabItem = {\n  label?: string;\n  icon: string;\n  backgroundColor?: string;\n  id?: string;\n  click?: () => any;\n};\n\nexport type FabItems = FabItem[];\n\n@Component({\n  selector: \"mis-fab\",\n  templateUrl: \"./fab.component.html\",\n  styleUrls: [\"./fab.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger(\"slideUpFab\", [\n      transition(\":enter\", [\n        style({ transform: \"translateY(50px)\", opacity: 0 }),\n        animate(\"300ms ease-out\", style({ transform: \"translateY(0px)\", opacity: 1 }))\n      ]),\n      transition(\":leave\", [animate(\"200ms ease-out\", style({ transform: \"translateY(70px)\", opacity: 0 }))])\n    ]),\n    trigger(\"rotateButton\", [\n      state(\"default\", style({ transform: \"rotate(0)\" })),\n      state(\"rotated\", style({ transform: \"rotate(45deg)\" })),\n      transition(\"rotated => default\", animate(\"300ms ease-out\")),\n      transition(\"default => rotated\", animate(\"200ms ease-in\"))\n    ])\n  ]\n})\nexport class FabComponent implements OnDestroy {\n  show = input<boolean>(false);\n  options = input<FabOptions>({});\n  items = input<FabItems>([]);\n\n  isOpen: WritableSignal<boolean> = signal(false);\n\n  // Computed signal for options with defaults\n  computedOptions = computed(() => {\n    const currentOptions = this.options();\n    return {\n      size: 56,\n      backgroundColorClosed: \"#0937B2\",\n      backgroundColorOpened: \"#3a5fc1\",\n      ...currentOptions\n    };\n  });\n\n  constructor(private eRef: ElementRef) {}\n\n  @HostListener(\"document:click\", [\"$event\"])\n  clickout(event: any) {\n    if (!this.eRef.nativeElement.contains(event.target)) {\n      this.closeFab();\n    }\n  }\n\n  ngOnDestroy(): void {}\n\n  clickItem(item: FabItem) {\n    this.closeFab();\n    item.click?.();\n  }\n\n  closeFab() {\n    this.isOpen.set(false);\n  }\n\n  toogleFab() {\n    this.isOpen.set(!this.isOpen());\n  }\n}\n","<div class=\"fab-wrapper\" *ngIf=\"show()\">\n  <div class=\"fab-items\" *ngIf=\"isOpen()\" @slideUpFab>\n    <div class=\"fab-item\" *ngFor=\"let item of items().reverse(); let i = index\" (click)=\"clickItem(item)\">\n      <div *ngIf=\"item.label\" class=\"fab-tooltip\">\n        {{ item.label }}\n      </div>\n      <div\n        class=\"fab-button\"\n        [ngStyle]=\"{\n          backgroundColor: item.backgroundColor || '#0937B2'\n        }\"\n      >\n        <img [src]=\"item.icon\" class=\"add-img\" />\n      </div>\n    </div>\n  </div>\n  <div\n    class=\"fab-container\"\n    [ngStyle]=\"{\n      backgroundColor: isOpen() ? computedOptions().backgroundColorOpened : computedOptions().backgroundColorClosed\n    }\"\n    (click)=\"toogleFab()\"\n  >\n    <svg\n      [@rotateButton]=\"isOpen() ? 'rotated' : 'default'\"\n      class=\"add-img\"\n      width=\"24\"\n      height=\"24\"\n      viewBox=\"0 0 24 24\"\n      fill=\"none\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n    >\n      <path\n        fill-rule=\"evenodd\"\n        clip-rule=\"evenodd\"\n        d=\"M13.1424 5.15607C13.1424 4.51759 12.6313 4 12.0009 4C11.3704 4 10.8594 4.51759 10.8594 5.15607V10.8421H5.14149C4.51106 10.8421 4 11.3597 4 11.9982C4 12.6367 4.51106 13.1543 5.14149 13.1543H10.8594V18.8439C10.8594 19.4824 11.3704 20 12.0009 20C12.6313 20 13.1424 19.4824 13.1424 18.8439V13.1543H18.8585C19.4889 13.1543 20 12.6367 20 11.9982C20 11.3597 19.4889 10.8421 18.8585 10.8421H13.1424V5.15607Z\"\n        fill=\"white\"\n      />\n    </svg>\n  </div>\n</div>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, signal, computed, input, output } from '@angular/core';
|
|
2
2
|
import { slideFromRight } from '../animations/slideFromRight';
|
|
3
3
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -94,7 +94,7 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_7_Template
|
|
|
94
94
|
const filter_r4 = i0.ɵɵnextContext(2).$implicit;
|
|
95
95
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
96
96
|
i0.ɵɵadvance(2);
|
|
97
|
-
i0.ɵɵproperty("placeholder", !ctx_r1.dateRangeSelectedDates.startDate && !ctx_r1.dateRangeSelectedDates.endDate ? filter_r4.placeholder || "Select" : ctx_r1.dateRangeSelectedDates.startDate + " - " + ctx_r1.dateRangeSelectedDates.endDate)("value", !ctx_r1.dateRangeSelectedDates.startDate && !ctx_r1.dateRangeSelectedDates.endDate ? filter_r4.placeholder || "Select" : ctx_r1.dateRangeSelectedDates.startDate + " - " + ctx_r1.dateRangeSelectedDates.endDate)("positionX", "start")("positionY", "top")("selectedDates", ctx_r1.dateRangeSelectedDates)("dpConfig", filter_r4.dateRangePickerConfig);
|
|
97
|
+
i0.ɵɵproperty("placeholder", !ctx_r1.dateRangeSelectedDates().startDate && !ctx_r1.dateRangeSelectedDates().endDate ? filter_r4.placeholder || "Select" : ctx_r1.dateRangeSelectedDates().startDate + " - " + ctx_r1.dateRangeSelectedDates().endDate)("value", !ctx_r1.dateRangeSelectedDates().startDate && !ctx_r1.dateRangeSelectedDates().endDate ? filter_r4.placeholder || "Select" : ctx_r1.dateRangeSelectedDates().startDate + " - " + ctx_r1.dateRangeSelectedDates().endDate)("positionX", "start")("positionY", "top")("selectedDates", ctx_r1.dateRangeSelectedDates())("dpConfig", filter_r4.dateRangePickerConfig);
|
|
98
98
|
} }
|
|
99
99
|
function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_8_Template(rf, ctx) { if (rf & 1) {
|
|
100
100
|
i0.ɵɵelementContainerStart(0);
|
|
@@ -217,7 +217,7 @@ function FilterPanelComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
|
217
217
|
i0.ɵɵadvance(8);
|
|
218
218
|
i0.ɵɵproperty("formGroup", ctx_r1.filterForm);
|
|
219
219
|
i0.ɵɵadvance();
|
|
220
|
-
i0.ɵɵproperty("ngForOf", ctx_r1.config);
|
|
220
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.config());
|
|
221
221
|
i0.ɵɵadvance(2);
|
|
222
222
|
i0.ɵɵproperty("name", "Clear All")("size", "Small")("type", "Text");
|
|
223
223
|
i0.ɵɵadvance();
|
|
@@ -226,26 +226,52 @@ function FilterPanelComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
|
226
226
|
export class FilterPanelComponent {
|
|
227
227
|
constructor(hasValue) {
|
|
228
228
|
this.hasValue = hasValue;
|
|
229
|
-
|
|
230
|
-
this.
|
|
231
|
-
this.config =
|
|
232
|
-
this.emitFiltersAfterSettingNewValues = false;
|
|
233
|
-
|
|
234
|
-
this.
|
|
229
|
+
// Signal inputs replacing @Input()
|
|
230
|
+
this.show = input(false);
|
|
231
|
+
this.config = input.required();
|
|
232
|
+
this.emitFiltersAfterSettingNewValues = input(false);
|
|
233
|
+
// Signal outputs replacing @Output()
|
|
234
|
+
this.onClose = output();
|
|
235
|
+
this.onApply = output();
|
|
236
|
+
this.filterForm = new FormGroup({});
|
|
237
|
+
this.dateRangeSelectedDates = signal({
|
|
235
238
|
startDate: '',
|
|
236
239
|
endDate: '',
|
|
237
|
-
};
|
|
240
|
+
});
|
|
241
|
+
// Computed signal for filter count
|
|
242
|
+
this.filterCount = computed(() => {
|
|
243
|
+
let count = 0;
|
|
244
|
+
const formValue = this.filterForm.value;
|
|
245
|
+
// Access the config signal value by calling it like a function
|
|
246
|
+
this.config().forEach((filter) => {
|
|
247
|
+
const value = formValue[filter.key];
|
|
248
|
+
if (this.hasValue.transform(value)) {
|
|
249
|
+
if (filter.type === 'range') {
|
|
250
|
+
if (value.min !== null || value.max !== null) {
|
|
251
|
+
count++;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
|
|
255
|
+
if (value.length > 0) {
|
|
256
|
+
count++;
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
count++;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
return count;
|
|
265
|
+
});
|
|
238
266
|
}
|
|
239
267
|
ngOnInit() {
|
|
240
|
-
|
|
268
|
+
// Access the config signal value by calling it like a function
|
|
269
|
+
this.initializeFormControls(this.config());
|
|
241
270
|
}
|
|
242
|
-
ngOnChanges
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
}
|
|
247
|
-
initializeFormControls() {
|
|
248
|
-
this.config.forEach((filter) => {
|
|
271
|
+
// The ngOnChanges lifecycle hook is no longer necessary with signal inputs.
|
|
272
|
+
initializeFormControls(config) {
|
|
273
|
+
this.filterForm = new FormGroup({});
|
|
274
|
+
config.forEach((filter) => {
|
|
249
275
|
let control;
|
|
250
276
|
if (filter.type === 'range') {
|
|
251
277
|
control = new FormGroup({
|
|
@@ -284,66 +310,52 @@ export class FilterPanelComponent {
|
|
|
284
310
|
else {
|
|
285
311
|
this.clearFormValues();
|
|
286
312
|
}
|
|
313
|
+
// Emit the close event using the signal output
|
|
287
314
|
this.onClose.emit();
|
|
288
315
|
}
|
|
289
|
-
filterCount() {
|
|
290
|
-
let count = 0;
|
|
291
|
-
this.config.forEach((filter) => {
|
|
292
|
-
if (this.hasValue.transform(this.filterForm.get(filter.key).value)) {
|
|
293
|
-
if (filter.type === 'range' && this.filterForm.get(filter.key).value.min == null && this.filterForm.get(filter.key).value.max == null) {
|
|
294
|
-
return;
|
|
295
|
-
}
|
|
296
|
-
count++;
|
|
297
|
-
}
|
|
298
|
-
});
|
|
299
|
-
return count;
|
|
300
|
-
}
|
|
301
316
|
applyFilters() {
|
|
302
317
|
if (this.filterForm.invalid) {
|
|
303
318
|
this.filterForm.markAllAsTouched();
|
|
304
319
|
return;
|
|
305
320
|
}
|
|
306
321
|
this.lastAppliedData = { ...this.filterForm.value };
|
|
322
|
+
// Emit the apply event with the filter data using the signal output
|
|
307
323
|
this.onApply.emit({
|
|
308
324
|
filterData: this.filterForm.value,
|
|
309
325
|
filterCount: this.filterCount()
|
|
310
326
|
});
|
|
311
|
-
this.show = false;
|
|
312
327
|
this.closePanel();
|
|
313
328
|
}
|
|
314
329
|
handleSelect(event, filterKey, filter) {
|
|
315
330
|
this.filterForm.get(filterKey).setValue(event);
|
|
316
331
|
if (filter.onChange) {
|
|
317
|
-
filter.onChange(event, this.config);
|
|
332
|
+
filter.onChange(event, this.config(), this.filterForm.value);
|
|
318
333
|
}
|
|
319
334
|
}
|
|
320
335
|
onDateChange(event, filterKey, filter) {
|
|
321
336
|
this.filterForm.get(filterKey).setValue(event);
|
|
322
337
|
if (typeof event === 'object') {
|
|
323
|
-
this.dateRangeSelectedDates
|
|
338
|
+
this.dateRangeSelectedDates.set({
|
|
324
339
|
startDate: event.startDate,
|
|
325
340
|
endDate: event.endDate,
|
|
326
|
-
};
|
|
327
|
-
}
|
|
328
|
-
else {
|
|
329
|
-
console.log(this.filterForm.get(filterKey).value);
|
|
341
|
+
});
|
|
330
342
|
}
|
|
331
343
|
}
|
|
332
344
|
handleCheckbox(event, filterKey, checkboxValue, filter) {
|
|
345
|
+
const currentValues = this.filterForm.get(filterKey).value;
|
|
333
346
|
if (event.value) {
|
|
334
|
-
this.filterForm.get(filterKey).setValue([...
|
|
347
|
+
this.filterForm.get(filterKey).setValue([...currentValues, checkboxValue]);
|
|
335
348
|
}
|
|
336
349
|
else {
|
|
337
|
-
|
|
338
|
-
this.filterForm.get(filterKey).setValue(filterValue.filter((value) => value !== checkboxValue));
|
|
350
|
+
this.filterForm.get(filterKey).setValue(currentValues.filter((value) => value !== checkboxValue));
|
|
339
351
|
}
|
|
340
352
|
if (filter.onChange) {
|
|
341
|
-
filter.onChange(event, this.config, this.filterForm.value);
|
|
353
|
+
filter.onChange(event, this.config(), this.filterForm.value);
|
|
342
354
|
}
|
|
343
355
|
}
|
|
344
356
|
clearFormValues() {
|
|
345
357
|
const resetValues = {};
|
|
346
|
-
this.config.forEach((filter) => {
|
|
358
|
+
this.config().forEach((filter) => {
|
|
347
359
|
let defaultValue = filter.defaultValue || null;
|
|
348
360
|
if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
|
|
349
361
|
defaultValue = filter.defaultValue || [];
|
|
@@ -367,30 +379,20 @@ export class FilterPanelComponent {
|
|
|
367
379
|
anyValueSet = true;
|
|
368
380
|
}
|
|
369
381
|
}
|
|
370
|
-
if (anyValueSet && this.emitFiltersAfterSettingNewValues) {
|
|
382
|
+
if (anyValueSet && this.emitFiltersAfterSettingNewValues()) {
|
|
371
383
|
this.applyFilters();
|
|
372
384
|
}
|
|
373
385
|
}
|
|
374
386
|
static { this.ɵfac = function FilterPanelComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || FilterPanelComponent)(i0.ɵɵdirectiveInject(i1.HasValuePipe)); }; }
|
|
375
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FilterPanelComponent, selectors: [["mis-filter-panel"]], inputs: { show: "show", config: "config", emitFiltersAfterSettingNewValues: "emitFiltersAfterSettingNewValues" }, outputs: { onClose: "onClose", onApply: "onApply" },
|
|
387
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FilterPanelComponent, selectors: [["mis-filter-panel"]], inputs: { show: [1, "show"], config: [1, "config"], emitFiltersAfterSettingNewValues: [1, "emitFiltersAfterSettingNewValues"] }, outputs: { onClose: "onClose", onApply: "onApply" }, decls: 1, vars: 1, consts: [["class", "filter-panel-container", 4, "ngIf"], [1, "filter-panel-container"], [1, "panel-header"], ["width", "25", "height", "25", "viewBox", "0 0 25 25", "fill", "none", "xmlns", "http://www.w3.org/2000/svg", 1, "close-icon", 3, "click"], ["id", "ic-navigation-cancel-24"], ["id", "Union", "fill-rule", "evenodd", "clip-rule", "evenodd", "d", "M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z", "fill", "#181F33"], [1, "horizontal-divider", "first"], [1, "filters", 3, "formGroup"], [4, "ngFor", "ngForOf"], [1, "actions"], [3, "click", "name", "size", "type"], [3, "click", "name", "size", "type", "disabled"], ["class", "filter", 4, "ngIf"], [1, "filter"], [1, "filter-title"], [4, "ngIf"], ["class", "horizontal-divider", 4, "ngIf"], [1, "multiselect-filter"], ["width", "100%", "height", "44px", 1, "no-padding", 3, "onChange", "label", "selectedItems", "data", "searchEnabled", "showSelectedCount", "enableSelectAll", "hideApplyButton"], ["width", "100%", "height", "44px", 3, "onChange", "data", "searchEnabled", "selectedItem"], [1, "checkbox-row"], ["class", "checkbox-container", 4, "ngFor", "ngForOf"], [1, "checkbox-container"], [3, "valueChange", "type", "checked"], [1, "checkbox-label"], ["type", "rounded"], ["misTzDp", "", "misInput", "", "type", "text", "readonly", "", 1, "mis-input", 3, "dateChange", "dpConfig", "placeholder", "value", "selectedDate", "positionX", "offsetX"], ["misTzDrp", "", "misInput", "", "type", "text", "readonly", "", 1, "mis-input", 3, "dateChange", "placeholder", "value", "positionX", "positionY", "selectedDates", "dpConfig"], ["misInput", "", "type", "text", 1, "input", 3, "placeholder", "formControlName"], ["misInput", "", "type", "number", 1, "input", 3, "placeholder", "formControlName"], [1, "range-container", 3, "formGroup"], [1, "range-inner-container"], ["misInput", "", "type", "number", "formControlName", "min", 1, "input", 3, "placeholder"], ["misInput", "", "type", "number", "formControlName", "max", 1, "input", 3, "placeholder", "min"], [1, "horizontal-divider"]], template: function FilterPanelComponent_Template(rf, ctx) { if (rf & 1) {
|
|
376
388
|
i0.ɵɵtemplate(0, FilterPanelComponent_div_0_Template, 13, 10, "div", 0);
|
|
377
389
|
} if (rf & 2) {
|
|
378
|
-
i0.ɵɵproperty("ngIf", ctx.show);
|
|
390
|
+
i0.ɵɵproperty("ngIf", ctx.show());
|
|
379
391
|
} }, dependencies: [i2.NgForOf, i2.NgIf, i3.ButtonComponent, i4.DefaultValueAccessor, i4.NumberValueAccessor, i4.NgControlStatus, i4.NgControlStatusGroup, i4.MinValidator, i4.FormGroupDirective, i4.FormControlName, i5.MultiSelectDropdownComponent, i6.DropdownComponent, i7.MisInputComponent, i7.MisInputDirective, i8.TzDatepickerDirective, i9.TzDaterangepickerDirective, i10.CheckboxComponent], styles: [".filter-panel-container[_ngcontent-%COMP%]{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:#fff;top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container[_ngcontent-%COMP%] .panel-header[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container[_ngcontent-%COMP%] .panel-header[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{font-size:1.25rem}.filter-panel-container[_ngcontent-%COMP%] .panel-header[_ngcontent-%COMP%] .close-icon[_ngcontent-%COMP%]{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container[_ngcontent-%COMP%] .panel-header[_ngcontent-%COMP%] .close-icon[_ngcontent-%COMP%]:hover{background:#f5f5f5}.filter-panel-container[_ngcontent-%COMP%] .panel-header[_ngcontent-%COMP%] .close-icon[_ngcontent-%COMP%]:active{background:#e0e0e0}.filter-panel-container[_ngcontent-%COMP%] .mat-divider.horizontal[_ngcontent-%COMP%]{margin:1rem}.filters[_ngcontent-%COMP%]{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%]{display:flex;flex-direction:column}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .filter-title[_ngcontent-%COMP%]{color:#6a737d;font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .checkbox-row[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .checkbox-row[_ngcontent-%COMP%] .checkbox-container[_ngcontent-%COMP%]{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .checkbox-row[_ngcontent-%COMP%] .checkbox-label[_ngcontent-%COMP%]{display:block;width:8rem}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .checkbox-row[_ngcontent-%COMP%] .mat-checkbox-inner-container{width:20px;height:20px}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .checkbox-row[_ngcontent-%COMP%] .mat-checkbox-frame{border-radius:5px}.filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] .multiselect-filter[_ngcontent-%COMP%], .filters[_ngcontent-%COMP%] .filter[_ngcontent-%COMP%] mis-input[_ngcontent-%COMP%]{padding:.7rem 0}.horizontal-divider[_ngcontent-%COMP%]{display:block;width:100%;height:1px;margin:.5rem 0;background:#e0e0e0}.first[_ngcontent-%COMP%]{margin-top:0}.actions[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid #E0E0E0;flex-basis:4%;padding:.5rem}.actions[_ngcontent-%COMP%] button[_ngcontent-%COMP%]{font-weight:700;border-radius:.5rem;width:6rem}.no-padding[_ngcontent-%COMP%] .container{padding:0!important}.range-container[_ngcontent-%COMP%]{display:flex;justify-content:space-between;padding:.8rem 0}.range-container[_ngcontent-%COMP%] .range-inner-container[_ngcontent-%COMP%]{display:flex;flex-direction:column}.range-container[_ngcontent-%COMP%] .range-inner-container[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid #e0e0e0;width:8rem;padding:0 .5rem}.range-container[_ngcontent-%COMP%] .range-inner-container[_ngcontent-%COMP%] span[_ngcontent-%COMP%]{margin-bottom:.2rem}input.ng-invalid.ng-touched[_ngcontent-%COMP%]{border:1px solid red;background-color:#ffe6e6}"], data: { animation: [slideFromRight] } }); }
|
|
380
392
|
}
|
|
381
393
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterPanelComponent, [{
|
|
382
394
|
type: Component,
|
|
383
|
-
args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show\" @slideFromRight
|
|
384
|
-
}], () => [{ type: i1.HasValuePipe }],
|
|
385
|
-
type: Input
|
|
386
|
-
}], onClose: [{
|
|
387
|
-
type: Output
|
|
388
|
-
}], onApply: [{
|
|
389
|
-
type: Output
|
|
390
|
-
}], config: [{
|
|
391
|
-
type: Input
|
|
392
|
-
}], emitFiltersAfterSettingNewValues: [{
|
|
393
|
-
type: Input
|
|
394
|
-
}] }); })();
|
|
395
|
+
args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n <div class=\"panel-header\">\n <span>Filters</span>\n <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"ic-navigation-cancel-24\">\n <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n </g>\n </svg>\n </div>\n\n <div class=\"horizontal-divider first\"></div>\n\n <div class=\"filters\" [formGroup]=\"filterForm\">\n <ng-container *ngFor=\"let filter of config(); let last = last\">\n <div class=\"filter\" *ngIf=\"!filter.hidden\">\n <span class=\"filter-title\">{{filter.title}}</span>\n <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n <div class=\"multiselect-filter\">\n <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key).value\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'select'\">\n <div class=\"multiselect-filter\">\n <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key).value\">\n </mis-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'checkbox'\">\n <div class=\"checkbox-row\">\n <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key).value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n <span class=\"checkbox-label\">{{option.label}}</span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'datePicker'\">\n {{filter.placeholder}}\n <mis-input type=\"rounded\">\n <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datepickerConfig\" [placeholder]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" [value]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key).value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n [dpConfig]=\"filter.dateRangePickerConfig\" />\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'text'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'number'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'range'\">\n <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"min\"\n />\n </div>\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"max\"\n [min]=\"filterForm.get?.(filter.key)?.get('min')?.value || 0\"\n />\n </div>\n </div>\n </ng-container>\n <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n </div>\n </ng-container>\n </div>\n\n <div class=\"actions\">\n <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n </div>\n</div>\n\n", styles: [".filter-panel-container{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:#fff;top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container .panel-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container .panel-header span{font-size:1.25rem}.filter-panel-container .panel-header .close-icon{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container .panel-header .close-icon:hover{background:#f5f5f5}.filter-panel-container .panel-header .close-icon:active{background:#e0e0e0}.filter-panel-container .mat-divider.horizontal{margin:1rem}.filters{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters .filter{display:flex;flex-direction:column}.filters .filter .filter-title{color:#6a737d;font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters .filter .checkbox-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters .filter .checkbox-row .checkbox-container{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters .filter .checkbox-row .checkbox-label{display:block;width:8rem}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-inner-container{width:20px;height:20px}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-frame{border-radius:5px}.filters .filter .multiselect-filter,.filters .filter mis-input{padding:.7rem 0}.horizontal-divider{display:block;width:100%;height:1px;margin:.5rem 0;background:#e0e0e0}.first{margin-top:0}.actions{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid #E0E0E0;flex-basis:4%;padding:.5rem}.actions button{font-weight:700;border-radius:.5rem;width:6rem}.no-padding ::ng-deep .container{padding:0!important}.range-container{display:flex;justify-content:space-between;padding:.8rem 0}.range-container .range-inner-container{display:flex;flex-direction:column}.range-container .range-inner-container input{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid #e0e0e0;width:8rem;padding:0 .5rem}.range-container .range-inner-container span{margin-bottom:.2rem}input.ng-invalid.ng-touched{border:1px solid red;background-color:#ffe6e6}\n"] }]
|
|
396
|
+
}], () => [{ type: i1.HasValuePipe }], null); })();
|
|
395
397
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterPanelComponent, { className: "FilterPanelComponent" }); })();
|
|
396
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-panel.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.ts","../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { slideFromRight } from '../animations/slideFromRight';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { IDatePickerConfig } from 'mis-crystal-design-system/datepicker_v2';\nimport { IRSelectedDatesConfig } from 'mis-crystal-design-system/specificdatepicker';\nimport { IDatePickerConfig as IDateRangePickerConfig } from \"mis-crystal-design-system/daterangepicker_v2\";\nimport { HasValuePipe } from '../has-value.pipe';\n\n\nexport interface FilterPanelConfig {\n  key: string;\n  title: string;\n  type: 'multiSelect' | 'select' | 'datePicker' | 'dateRangePicker' | 'checkbox' | 'radio' | 'text' | 'number' | 'range';\n  options?: Array<{\n    label: string;\n    value: string;\n    data?: any[];\n  }>;\n  placeholder?: string;\n  hidden?: boolean;\n  datePickerConfig?: IDatePickerConfig;\n  dateRangePickerConfig?: IDateRangePickerConfig;\n  onChange?: (event: any, config?: FilterPanelConfig[], formValue?: any) => void;\n  defaultValue?: any;\n  selectedValue?: any;\n}\n\n@Component({\n  selector: 'mis-filter-panel',\n  templateUrl: './filter-panel.component.html',\n  styleUrls: ['./filter-panel.component.scss'],\n  animations: [slideFromRight]\n})\n\n\n\nexport class FilterPanelComponent implements OnInit, OnChanges {\n  constructor(private hasValue: HasValuePipe){}\n  @Input() show: boolean;\n  @Output() onClose = new EventEmitter();\n  @Output() onApply = new EventEmitter();\n  @Input() config: FilterPanelConfig[] = [];\n  @Input() emitFiltersAfterSettingNewValues: boolean = false;\n  filterForm: FormGroup = new FormGroup([]);\n  lastAppliedData: any;\n\n  rangeMin: number;\n  rangeMax: number;\n\n  dateRangeSelectedDates: IRSelectedDatesConfig = {\n    startDate: '',\n    endDate: '',\n  };\n\n  ngOnInit() {\n    this.initializeFormControls();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if(changes.config && !changes.config.firstChange){\n      this.setFilterValue(this.config);\n    }\n  }\n\n  initializeFormControls() {\n    this.config.forEach((filter: FilterPanelConfig) => {\n      let control: any;\n      if (filter.type === 'range') {\n        control = new FormGroup({\n          min: new FormControl(null),\n          max: new FormControl(null),\n        }, {\n          validators: (group: FormGroup) => {\n            const min = group.get('min').value;\n            const max = group.get('max').value;\n            if (min !== null && max !== null && min > max) {\n              return { rangeError: 'Min value should be less than max value' };\n            }\n            return null;\n          }\n        });\n      } else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        control = new FormControl([]);\n      } else if (filter.type === 'select') {\n        control = new FormControl('');\n      } else {\n        control = new FormControl(null);\n      }\n      if(this.hasValue.transform(filter.defaultValue)){\n        control.setValue(filter.defaultValue);\n      }\n      this.filterForm.addControl(filter.key, control);\n    });\n  }\n\n  closePanel(){\n    if(this.lastAppliedData){\n      this.filterForm.setValue(this.lastAppliedData);\n    } else {\n      this.clearFormValues();\n    }\n    this.onClose.emit();\n  }\n\n  filterCount(){\n    let count = 0;\n    this.config.forEach((filter: FilterPanelConfig) => {\n      if(this.hasValue.transform(this.filterForm.get(filter.key).value)){\n        if(filter.type === 'range' && this.filterForm.get(filter.key).value.min == null && this.filterForm.get(filter.key).value.max == null){\n          return;\n        }\n        count++;\n      }\n    });\n    return count;\n  }\n\n  applyFilters(){\n    if (this.filterForm.invalid) {\n      this.filterForm.markAllAsTouched();\n      return;\n    }\n  \n    this.lastAppliedData = {...this.filterForm.value};\n    this.onApply.emit({\n      filterData: this.filterForm.value,\n      filterCount: this.filterCount()\n    });\n    this.show = false;\n    this.closePanel();\n  }\n\n  handleSelect(event: any, filterKey: string, filter: FilterPanelConfig){\n    this.filterForm.get(filterKey).setValue(event);\n    if(filter.onChange){\n      filter.onChange(event, this.config);\n    }\n  }\n\n  onDateChange(event: any, filterKey: string, filter: FilterPanelConfig){\n    this.filterForm.get(filterKey).setValue(event);\n    if(typeof event === 'object'){\n      this.dateRangeSelectedDates = {\n        startDate: event.startDate,\n        endDate: event.endDate,\n      };\n   } else {\n      console.log(this.filterForm.get(filterKey).value); \n   }\n  }\n\n  handleCheckbox(event: any, filterKey: string, checkboxValue: string, filter: FilterPanelConfig){\n    if(event.value){\n      this.filterForm.get(filterKey).setValue([...this.filterForm.get(filterKey).value, checkboxValue]);\n    } else {\n      const filterValue = this.filterForm.get(filterKey).value;\n      this.filterForm.get(filterKey).setValue(filterValue.filter((value: string) => value !== checkboxValue));\n    }\n    if(filter.onChange){\n      filter.onChange(event, this.config, this.filterForm.value);\n    }\n  }\n\n  clearFormValues(){\n    const resetValues: any = {};\n    this.config.forEach((filter: FilterPanelConfig) => {\n      let defaultValue: any = filter.defaultValue || null;\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        defaultValue = filter.defaultValue || [];\n      }\n      if(filter.type === 'range'){\n        defaultValue = filter.defaultValue || { min: null, max: null };\n      }\n      resetValues[filter.key] = defaultValue;\n    });\n    this.filterForm.patchValue(resetValues);\n  }\n\n  resetFilters() {\n    this.clearFormValues();\n    this.applyFilters();\n  }\n\n  setFilterValue(config: FilterPanelConfig[]){\n   let anyValueSet = false;\n   for(const filter of config){\n    if(filter?.selectedValue){\n      this.filterForm.get(filter.key).setValue(filter.selectedValue);\n      anyValueSet = true;\n    }\n   }\n   if(anyValueSet && this.emitFiltersAfterSettingNewValues){\n    this.applyFilters();\n   }\n  }\n\n}\n","<div class=\"filter-panel-container\" *ngIf=\"show\" @slideFromRight> \n    <div class=\"panel-header\">\n        <span>Filters</span>\n        <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <g id=\"ic-navigation-cancel-24\">\n            <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.6056 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.385 17.455 18.385 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.622 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\"/>\n            </g>\n        </svg>            \n    </div>\n    \n    <div class=\"horizontal-divider first\"></div>\n    \n    <div class=\"filters\" [formGroup]=\"filterForm\">\n        <ng-container *ngFor=\"let filter of config; let last = last\">\n            <div class=\"filter\" *ngIf=\"!filter.hidden\">\n                <span class=\"filter-title\">{{filter.title}}</span>\n\n                <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n                    <div class=\"multiselect-filter\">\n                        <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key).value\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n                            [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n                            [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n                    </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'select'\">\n                    <div class=\"multiselect-filter\">\n                        <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n                                (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key).value\">\n                        </mis-dropdown>\n                    </div>\n                </ng-container>\n        \n                <ng-container *ngIf=\"filter.type === 'checkbox'\">\n                    <div class=\"checkbox-row\">\n                        <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n                            <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key).value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n                            <span class=\"checkbox-label\">{{option.label}}</span>\n                        </div>\n                    </div>\n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'datePicker'\">\n                    {{filter.placeholder}}\n                    <mis-input type=\"rounded\">\n                        <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datepickerConfig\" [placeholder]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" [value]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key).value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n                    </mis-input>\n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n                <mis-input type=\"rounded\">\n                    <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n                        [placeholder]=\"(!dateRangeSelectedDates.startDate && !dateRangeSelectedDates.endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates.startDate + ' - ' + dateRangeSelectedDates.endDate\"\n                        [value]=\"(!dateRangeSelectedDates.startDate && !dateRangeSelectedDates.endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates.startDate + ' - ' + dateRangeSelectedDates.endDate\" [positionX]=\"'start'\"\n                        [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n                        [dpConfig]=\"filter.dateRangePickerConfig\" />\n                        </mis-input>    \n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'text'\">\n                    <mis-input type=\"rounded\">\n                        <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                    </mis-input>\n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'number'\">\n                    <mis-input type=\"rounded\">\n                        <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                    </mis-input>\n                </ng-container>\n\n                <ng-container *ngIf=\"filter.type === 'range'\">\n                    <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n                      <div class=\"range-inner-container\">\n                        <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n                        <input \n                          misInput \n                          type=\"number\" \n                          class=\"input\" \n                          [placeholder]=\"filter.placeholder || 'Type here'\" \n                          formControlName=\"min\" \n                          />\n                      </div>\n                      <div class=\"range-inner-container\">\n                        <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n                        <input \n                          misInput \n                          type=\"number\" \n                          class=\"input\" \n                          [placeholder]=\"filter.placeholder || 'Type here'\" \n                          formControlName=\"max\"\n                            [min]=\"filterForm.get?.(filter.key)?.get('min')?.value || 0\"\n                         />\n                      </div>\n                    </div>\n                  </ng-container>\n                  \n\n                <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n            </div>  \n        </ng-container>\n    </div>\n\n    <div class=\"actions\">\n        <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n        <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n    </div>\n</div> \n"]}
|
|
398
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-panel.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.ts","../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, signal, WritableSignal, computed, input, output } from '@angular/core';\nimport { slideFromRight } from '../animations/slideFromRight';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { IDatePickerConfig } from 'mis-crystal-design-system/datepicker_v2';\nimport { IRSelectedDatesConfig } from 'mis-crystal-design-system/specificdatepicker';\nimport { IDatePickerConfig as IDateRangePickerConfig } from \"mis-crystal-design-system/daterangepicker_v2\";\nimport { HasValuePipe } from '../has-value.pipe';\n\n\nexport interface FilterPanelConfig {\n  key: string;\n  title: string;\n  type: 'multiSelect' | 'select' | 'datePicker' | 'dateRangePicker' | 'checkbox' | 'radio' | 'text' | 'number' | 'range';\n  options?: Array<{\n    label: string;\n    value: string;\n    data?: any[];\n  }>;\n  placeholder?: string;\n  hidden?: boolean;\n  datePickerConfig?: IDatePickerConfig;\n  dateRangePickerConfig?: IDateRangePickerConfig;\n  onChange?: (event: any, config?: FilterPanelConfig[], formValue?: any) => void;\n  defaultValue?: any;\n  selectedValue?: any;\n}\n\n@Component({\n  selector: 'mis-filter-panel',\n  templateUrl: './filter-panel.component.html',\n  styleUrls: ['./filter-panel.component.scss'],\n  animations: [slideFromRight]\n})\nexport class FilterPanelComponent implements OnInit {\n  constructor(private hasValue: HasValuePipe) {}\n\n  // Signal inputs replacing @Input()\n  public show = input<boolean>(false);\n  public config = input.required<FilterPanelConfig[]>();\n  public emitFiltersAfterSettingNewValues = input<boolean>(false);\n\n  // Signal outputs replacing @Output()\n  public onClose = output();\n  public onApply = output<{ filterData: any, filterCount: number }>();\n\n  filterForm: FormGroup = new FormGroup({});\n  lastAppliedData: any;\n\n  public dateRangeSelectedDates: WritableSignal<IRSelectedDatesConfig> = signal({\n    startDate: '',\n    endDate: '',\n  });\n\n  // Computed signal for filter count\n  filterCount = computed(() => {\n    let count = 0;\n    const formValue = this.filterForm.value;\n    // Access the config signal value by calling it like a function\n    this.config().forEach((filter: FilterPanelConfig) => {\n      const value = formValue[filter.key];\n      if (this.hasValue.transform(value)) {\n        if (filter.type === 'range') {\n          if (value.min !== null || value.max !== null) {\n            count++;\n          }\n        } else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n          if (value.length > 0) {\n            count++;\n          }\n        } else {\n          count++;\n        }\n      }\n    });\n    return count;\n  });\n\n  ngOnInit() {\n    // Access the config signal value by calling it like a function\n    this.initializeFormControls(this.config());\n  }\n\n  // The ngOnChanges lifecycle hook is no longer necessary with signal inputs.\n\n  initializeFormControls(config: FilterPanelConfig[]) {\n    this.filterForm = new FormGroup({});\n    config.forEach((filter: FilterPanelConfig) => {\n      let control: any;\n      if (filter.type === 'range') {\n        control = new FormGroup({\n          min: new FormControl(null),\n          max: new FormControl(null),\n        }, {\n          validators: (group: FormGroup) => {\n            const min = group.get('min').value;\n            const max = group.get('max').value;\n            if (min !== null && max !== null && min > max) {\n              return { rangeError: 'Min value should be less than max value' };\n            }\n            return null;\n          }\n        });\n      } else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        control = new FormControl([]);\n      } else if (filter.type === 'select') {\n        control = new FormControl('');\n      } else {\n        control = new FormControl(null);\n      }\n      if (this.hasValue.transform(filter.defaultValue)) {\n        control.setValue(filter.defaultValue);\n      }\n      this.filterForm.addControl(filter.key, control);\n    });\n  }\n\n  closePanel() {\n    if (this.lastAppliedData) {\n      this.filterForm.setValue(this.lastAppliedData);\n    } else {\n      this.clearFormValues();\n    }\n    // Emit the close event using the signal output\n    this.onClose.emit();\n  }\n\n  applyFilters() {\n    if (this.filterForm.invalid) {\n      this.filterForm.markAllAsTouched();\n      return;\n    }\n  \n    this.lastAppliedData = { ...this.filterForm.value };\n    // Emit the apply event with the filter data using the signal output\n    this.onApply.emit({\n      filterData: this.filterForm.value,\n      filterCount: this.filterCount()\n    });\n    this.closePanel();\n  }\n\n  handleSelect(event: any, filterKey: string, filter: FilterPanelConfig) {\n    this.filterForm.get(filterKey).setValue(event);\n    if (filter.onChange) {\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  onDateChange(event: any, filterKey: string, filter: FilterPanelConfig) {\n    this.filterForm.get(filterKey).setValue(event);\n    if (typeof event === 'object') {\n      this.dateRangeSelectedDates.set({\n        startDate: event.startDate,\n        endDate: event.endDate,\n      });\n    }\n  }\n\n  handleCheckbox(event: any, filterKey: string, checkboxValue: string, filter: FilterPanelConfig) {\n    const currentValues = this.filterForm.get(filterKey).value;\n    if (event.value) {\n      this.filterForm.get(filterKey).setValue([...currentValues, checkboxValue]);\n    } else {\n      this.filterForm.get(filterKey).setValue(currentValues.filter((value: string) => value !== checkboxValue));\n    }\n    if (filter.onChange) {\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  clearFormValues() {\n    const resetValues: any = {};\n    this.config().forEach((filter: FilterPanelConfig) => {\n      let defaultValue: any = filter.defaultValue || null;\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        defaultValue = filter.defaultValue || [];\n      }\n      if (filter.type === 'range') {\n        defaultValue = filter.defaultValue || { min: null, max: null };\n      }\n      resetValues[filter.key] = defaultValue;\n    });\n    this.filterForm.patchValue(resetValues);\n  }\n\n  resetFilters() {\n    this.clearFormValues();\n    this.applyFilters();\n  }\n\n  setFilterValue(config: FilterPanelConfig[]) {\n    let anyValueSet = false;\n    for (const filter of config) {\n      if (filter?.selectedValue) {\n        this.filterForm.get(filter.key).setValue(filter.selectedValue);\n        anyValueSet = true;\n      }\n    }\n    if (anyValueSet && this.emitFiltersAfterSettingNewValues()) {\n      this.applyFilters();\n    }\n  }\n}\n\n","<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n  <div class=\"panel-header\">\n      <span>Filters</span>\n      <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <g id=\"ic-navigation-cancel-24\">\n              <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n          </g>\n      </svg>\n  </div>\n\n  <div class=\"horizontal-divider first\"></div>\n\n  <div class=\"filters\" [formGroup]=\"filterForm\">\n      <ng-container *ngFor=\"let filter of config(); let last = last\">\n          <div class=\"filter\" *ngIf=\"!filter.hidden\">\n              <span class=\"filter-title\">{{filter.title}}</span>\n              <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n                  <div class=\"multiselect-filter\">\n                      <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key).value\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n                          [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n                          [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'select'\">\n                  <div class=\"multiselect-filter\">\n                      <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n                              (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key).value\">\n                      </mis-dropdown>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'checkbox'\">\n                  <div class=\"checkbox-row\">\n                      <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n                          <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key).value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n                          <span class=\"checkbox-label\">{{option.label}}</span>\n                      </div>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'datePicker'\">\n                  {{filter.placeholder}}\n                  <mis-input type=\"rounded\">\n                      <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datepickerConfig\" [placeholder]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" [value]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key).value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n                  <mis-input type=\"rounded\">\n                      <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n                          [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n                          [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n                          [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n                          [dpConfig]=\"filter.dateRangePickerConfig\" />\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'text'\">\n                  <mis-input type=\"rounded\">\n                      <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'number'\">\n                  <mis-input type=\"rounded\">\n                      <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'range'\">\n                  <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n                      <div class=\"range-inner-container\">\n                          <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n                          <input\n                              misInput\n                              type=\"number\"\n                              class=\"input\"\n                              [placeholder]=\"filter.placeholder || 'Type here'\"\n                              formControlName=\"min\"\n                          />\n                      </div>\n                      <div class=\"range-inner-container\">\n                          <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n                          <input\n                              misInput\n                              type=\"number\"\n                              class=\"input\"\n                              [placeholder]=\"filter.placeholder || 'Type here'\"\n                              formControlName=\"max\"\n                              [min]=\"filterForm.get?.(filter.key)?.get('min')?.value || 0\"\n                          />\n                      </div>\n                  </div>\n              </ng-container>\n              <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n          </div>\n      </ng-container>\n  </div>\n\n  <div class=\"actions\">\n      <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n      <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n  </div>\n</div>\n\n"]}
|