mis-crystal-design-system 17.0.2 → 17.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/analytics/analytics.service.d.ts +1 -1
- package/async-search-dropdown/async-dropdown.component.d.ts +4 -1
- package/esm2022/analytics/analytics.service.mjs +3 -3
- package/esm2022/async-search-dropdown/async-dropdown.component.mjs +27 -9
- package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +2 -1
- package/esm2022/filter/filter-panel/filter-panel.component.mjs +22 -22
- package/esm2022/input-stepper/input-stepper/input-stepper.component.mjs +29 -15
- package/esm2022/nested-multi-select-dropdown/nested-multi-select-dropdown.component.mjs +5 -5
- package/esm2022/slider/slider.component.mjs +2 -2
- package/esm2022/table/actions-cell/actions-cell.component.mjs +389 -0
- package/esm2022/table/public_api.mjs +5 -3
- package/esm2022/table/sort-icons.directive.mjs +139 -0
- package/esm2022/table/table.component.mjs +286 -109
- package/esm2022/table/table.module.mjs +41 -6
- package/esm2022/toast/public_api.mjs +3 -1
- package/esm2022/toast/toast.component.mjs +73 -16
- package/esm2022/toast/toast.constants.mjs +7 -0
- package/esm2022/toast/toast.data.service.mjs +1 -1
- package/esm2022/toast/toast.interface.mjs +2 -0
- package/esm2022/toast/toast.service.mjs +14 -7
- package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-analytics.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-analytics.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +26 -8
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +1 -0
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-filter.mjs +21 -21
- package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs +28 -14
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-menu.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs +4 -4
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-slider.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +1143 -411
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-toast.mjs +93 -22
- package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-widgets.mjs.map +1 -1
- package/filter/filter-panel/filter-panel.component.d.ts +4 -3
- package/input-stepper/input-stepper/input-stepper.component.d.ts +5 -1
- package/package.json +13 -13
- package/table/actions-cell/actions-cell.component.d.ts +45 -0
- package/table/filter/filter.component.d.ts +1 -1
- package/table/public_api.d.ts +4 -2
- package/table/sort-icons.directive.d.ts +36 -0
- package/table/table.component.d.ts +56 -10
- package/table/table.module.d.ts +8 -4
- package/toast/public_api.d.ts +2 -0
- package/toast/toast.component.d.ts +13 -1
- package/toast/toast.constants.d.ts +5 -0
- package/toast/toast.data.service.d.ts +3 -2
- package/toast/toast.interface.d.ts +6 -0
- package/toast/toast.service.d.ts +2 -1
|
@@ -0,0 +1,389 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, HostListener, ViewChild } from "@angular/core";
|
|
2
|
+
import { ConnectionPositionPair, OverlayConfig } from "@angular/cdk/overlay";
|
|
3
|
+
import { TemplatePortal } from "@angular/cdk/portal";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "mis-crystal-design-system/checkbox";
|
|
8
|
+
const _c0 = ["dropdownMenu"];
|
|
9
|
+
const _c1 = ["dropdownTrigger"];
|
|
10
|
+
const _c2 = a0 => ({ disabled: a0 });
|
|
11
|
+
function ActionsCellComponent_div_1_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
13
|
+
i0.ɵɵelementStart(0, "div", 10);
|
|
14
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_1_div_1_Template_div_click_0_listener($event) { const item_r2 = i0.ɵɵrestoreView(_r1).$implicit; const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.onActionClick(item_r2, $event)); });
|
|
15
|
+
i0.ɵɵelement(1, "img", 11);
|
|
16
|
+
i0.ɵɵelementEnd();
|
|
17
|
+
} if (rf & 2) {
|
|
18
|
+
const item_r2 = ctx.$implicit;
|
|
19
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
20
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c2, ctx_r2.isDisabled(item_r2)));
|
|
21
|
+
i0.ɵɵadvance();
|
|
22
|
+
i0.ɵɵproperty("src", item_r2.icon, i0.ɵɵsanitizeUrl)("alt", item_r2.label);
|
|
23
|
+
} }
|
|
24
|
+
function ActionsCellComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelementStart(0, "div", 8);
|
|
26
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_div_1_Template, 2, 5, "div", 9);
|
|
27
|
+
i0.ɵɵelementEnd();
|
|
28
|
+
} if (rf & 2) {
|
|
29
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
30
|
+
i0.ɵɵadvance();
|
|
31
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.actionItems)("ngForTrackBy", ctx_r2.trackByAction);
|
|
32
|
+
} }
|
|
33
|
+
function ActionsCellComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
34
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
|
35
|
+
i0.ɵɵelementStart(0, "div", 12)(1, "div", 13, 1);
|
|
36
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_2_Template_div_click_1_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.toggleDropdown($event)); });
|
|
37
|
+
i0.ɵɵnamespaceSVG();
|
|
38
|
+
i0.ɵɵelementStart(3, "svg", 14);
|
|
39
|
+
i0.ɵɵelement(4, "circle", 15)(5, "circle", 16)(6, "circle", 17);
|
|
40
|
+
i0.ɵɵelementEnd()()();
|
|
41
|
+
} }
|
|
42
|
+
function ActionsCellComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
43
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
44
|
+
i0.ɵɵelementStart(0, "div", 18)(1, "mis-checkbox", 19);
|
|
45
|
+
i0.ɵɵlistener("valueChange", function ActionsCellComponent_div_3_Template_mis_checkbox_valueChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.onClick($event)); });
|
|
46
|
+
i0.ɵɵelementEnd()();
|
|
47
|
+
} if (rf & 2) {
|
|
48
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
49
|
+
i0.ɵɵadvance();
|
|
50
|
+
i0.ɵɵproperty("checked", ctx_r2.currentState)("disabled", ctx_r2.disable ? ctx_r2.disable(ctx_r2.currentState) : false);
|
|
51
|
+
} }
|
|
52
|
+
function ActionsCellComponent_div_4__svg_svg_2_Template(rf, ctx) { if (rf & 1) {
|
|
53
|
+
i0.ɵɵnamespaceSVG();
|
|
54
|
+
i0.ɵɵelementStart(0, "svg", 23);
|
|
55
|
+
i0.ɵɵelement(1, "path", 24);
|
|
56
|
+
i0.ɵɵelementEnd();
|
|
57
|
+
} }
|
|
58
|
+
function ActionsCellComponent_div_4__svg_svg_3_Template(rf, ctx) { if (rf & 1) {
|
|
59
|
+
i0.ɵɵnamespaceSVG();
|
|
60
|
+
i0.ɵɵelementStart(0, "svg", 23);
|
|
61
|
+
i0.ɵɵelement(1, "path", 25);
|
|
62
|
+
i0.ɵɵelementEnd();
|
|
63
|
+
} }
|
|
64
|
+
function ActionsCellComponent_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
65
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
66
|
+
i0.ɵɵelementStart(0, "div", 20)(1, "div", 21);
|
|
67
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_div_4_Template_div_click_1_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.onClick($event)); });
|
|
68
|
+
i0.ɵɵtemplate(2, ActionsCellComponent_div_4__svg_svg_2_Template, 2, 0, "svg", 22)(3, ActionsCellComponent_div_4__svg_svg_3_Template, 2, 0, "svg", 22);
|
|
69
|
+
i0.ɵɵelementEnd()();
|
|
70
|
+
} if (rf & 2) {
|
|
71
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
72
|
+
i0.ɵɵadvance();
|
|
73
|
+
i0.ɵɵproperty("title", ctx_r2.currentState ? "Expand" : "Collapse");
|
|
74
|
+
i0.ɵɵadvance();
|
|
75
|
+
i0.ɵɵproperty("ngIf", ctx_r2.currentState);
|
|
76
|
+
i0.ɵɵadvance();
|
|
77
|
+
i0.ɵɵproperty("ngIf", !ctx_r2.currentState);
|
|
78
|
+
} }
|
|
79
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_container_1_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
80
|
+
i0.ɵɵelementStart(0, "span", 36);
|
|
81
|
+
i0.ɵɵelement(1, "img", 37);
|
|
82
|
+
i0.ɵɵelementEnd();
|
|
83
|
+
} if (rf & 2) {
|
|
84
|
+
const item_r8 = i0.ɵɵnextContext(2).$implicit;
|
|
85
|
+
i0.ɵɵadvance();
|
|
86
|
+
i0.ɵɵproperty("src", item_r8.icon, i0.ɵɵsanitizeUrl);
|
|
87
|
+
} }
|
|
88
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_div_1_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
89
|
+
i0.ɵɵelementStart(0, "span", 36);
|
|
90
|
+
i0.ɵɵelement(1, "img", 37);
|
|
91
|
+
i0.ɵɵelementEnd();
|
|
92
|
+
} if (rf & 2) {
|
|
93
|
+
const child_r10 = i0.ɵɵnextContext().$implicit;
|
|
94
|
+
i0.ɵɵadvance();
|
|
95
|
+
i0.ɵɵproperty("src", child_r10.icon, i0.ɵɵsanitizeUrl);
|
|
96
|
+
} }
|
|
97
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
98
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
99
|
+
i0.ɵɵelementStart(0, "div", 28);
|
|
100
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_div_1_Template_div_click_0_listener($event) { const child_r10 = i0.ɵɵrestoreView(_r9).$implicit; const ctx_r2 = i0.ɵɵnextContext(5); return i0.ɵɵresetView(ctx_r2.onDropdownItemClick(child_r10, $event)); });
|
|
101
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_div_1_span_1_Template, 2, 1, "span", 30);
|
|
102
|
+
i0.ɵɵelementStart(2, "span", 31);
|
|
103
|
+
i0.ɵɵtext(3);
|
|
104
|
+
i0.ɵɵelementEnd()();
|
|
105
|
+
} if (rf & 2) {
|
|
106
|
+
const child_r10 = ctx.$implicit;
|
|
107
|
+
const ctx_r2 = i0.ɵɵnextContext(5);
|
|
108
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c2, ctx_r2.isDisabled(child_r10)));
|
|
109
|
+
i0.ɵɵadvance();
|
|
110
|
+
i0.ɵɵproperty("ngIf", child_r10.icon);
|
|
111
|
+
i0.ɵɵadvance(2);
|
|
112
|
+
i0.ɵɵtextInterpolate(child_r10.label);
|
|
113
|
+
} }
|
|
114
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
115
|
+
i0.ɵɵelementStart(0, "div", 38);
|
|
116
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_div_1_Template, 4, 5, "div", 27);
|
|
117
|
+
i0.ɵɵelementEnd();
|
|
118
|
+
} if (rf & 2) {
|
|
119
|
+
const item_r8 = i0.ɵɵnextContext(2).$implicit;
|
|
120
|
+
i0.ɵɵadvance();
|
|
121
|
+
i0.ɵɵproperty("ngForOf", item_r8.children);
|
|
122
|
+
} }
|
|
123
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
124
|
+
i0.ɵɵelementContainerStart(0);
|
|
125
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_ng_template_5_div_1_ng_container_1_span_1_Template, 2, 1, "span", 30);
|
|
126
|
+
i0.ɵɵelementStart(2, "span", 31);
|
|
127
|
+
i0.ɵɵtext(3);
|
|
128
|
+
i0.ɵɵelementEnd();
|
|
129
|
+
i0.ɵɵelementStart(4, "span", 32);
|
|
130
|
+
i0.ɵɵnamespaceSVG();
|
|
131
|
+
i0.ɵɵelementStart(5, "svg", 33);
|
|
132
|
+
i0.ɵɵelement(6, "path", 34);
|
|
133
|
+
i0.ɵɵelementEnd()();
|
|
134
|
+
i0.ɵɵtemplate(7, ActionsCellComponent_ng_template_5_div_1_ng_container_1_div_7_Template, 2, 1, "div", 35);
|
|
135
|
+
i0.ɵɵelementContainerEnd();
|
|
136
|
+
} if (rf & 2) {
|
|
137
|
+
const item_r8 = i0.ɵɵnextContext().$implicit;
|
|
138
|
+
i0.ɵɵadvance();
|
|
139
|
+
i0.ɵɵproperty("ngIf", item_r8.icon);
|
|
140
|
+
i0.ɵɵadvance(2);
|
|
141
|
+
i0.ɵɵtextInterpolate(item_r8.label);
|
|
142
|
+
i0.ɵɵadvance(4);
|
|
143
|
+
i0.ɵɵproperty("ngIf", item_r8.showSubmenu);
|
|
144
|
+
} }
|
|
145
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_template_2_span_0_Template(rf, ctx) { if (rf & 1) {
|
|
146
|
+
i0.ɵɵelementStart(0, "span", 36);
|
|
147
|
+
i0.ɵɵelement(1, "img", 37);
|
|
148
|
+
i0.ɵɵelementEnd();
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
const item_r8 = i0.ɵɵnextContext(2).$implicit;
|
|
151
|
+
i0.ɵɵadvance();
|
|
152
|
+
i0.ɵɵproperty("src", item_r8.icon, i0.ɵɵsanitizeUrl);
|
|
153
|
+
} }
|
|
154
|
+
function ActionsCellComponent_ng_template_5_div_1_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
155
|
+
i0.ɵɵtemplate(0, ActionsCellComponent_ng_template_5_div_1_ng_template_2_span_0_Template, 2, 1, "span", 30);
|
|
156
|
+
i0.ɵɵelementStart(1, "span", 31);
|
|
157
|
+
i0.ɵɵtext(2);
|
|
158
|
+
i0.ɵɵelementEnd();
|
|
159
|
+
} if (rf & 2) {
|
|
160
|
+
const item_r8 = i0.ɵɵnextContext().$implicit;
|
|
161
|
+
i0.ɵɵproperty("ngIf", item_r8.icon);
|
|
162
|
+
i0.ɵɵadvance(2);
|
|
163
|
+
i0.ɵɵtextInterpolate(item_r8.label);
|
|
164
|
+
} }
|
|
165
|
+
function ActionsCellComponent_ng_template_5_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
166
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
167
|
+
i0.ɵɵelementStart(0, "div", 28);
|
|
168
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_ng_template_5_div_1_Template_div_click_0_listener($event) { const item_r8 = i0.ɵɵrestoreView(_r7).$implicit; const ctx_r2 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r2.onDropdownItemClick(item_r8, $event)); });
|
|
169
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_ng_template_5_div_1_ng_container_1_Template, 8, 3, "ng-container", 29)(2, ActionsCellComponent_ng_template_5_div_1_ng_template_2_Template, 3, 2, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
|
|
170
|
+
i0.ɵɵelementEnd();
|
|
171
|
+
} if (rf & 2) {
|
|
172
|
+
const item_r8 = ctx.$implicit;
|
|
173
|
+
const noChildren_r11 = i0.ɵɵreference(3);
|
|
174
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
175
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c2, ctx_r2.isDisabled(item_r8)));
|
|
176
|
+
i0.ɵɵadvance();
|
|
177
|
+
i0.ɵɵproperty("ngIf", item_r8.children == null ? null : item_r8.children.length)("ngIfElse", noChildren_r11);
|
|
178
|
+
} }
|
|
179
|
+
function ActionsCellComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
|
|
180
|
+
i0.ɵɵelementStart(0, "div", 26);
|
|
181
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_ng_template_5_div_1_Template, 4, 5, "div", 27);
|
|
182
|
+
i0.ɵɵelementEnd();
|
|
183
|
+
} if (rf & 2) {
|
|
184
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
185
|
+
i0.ɵɵadvance();
|
|
186
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.actionItems);
|
|
187
|
+
} }
|
|
188
|
+
export class ActionsCellComponent {
|
|
189
|
+
constructor(overlay, viewContainerRef) {
|
|
190
|
+
this.overlay = overlay;
|
|
191
|
+
this.viewContainerRef = viewContainerRef;
|
|
192
|
+
this.actionClick = new EventEmitter();
|
|
193
|
+
this.isDropdownOpen = false;
|
|
194
|
+
this.actionItems = [];
|
|
195
|
+
this.actionType = "inline";
|
|
196
|
+
this.currentState = false;
|
|
197
|
+
this._style = {};
|
|
198
|
+
this.containerStyle = {};
|
|
199
|
+
this.overlayRef = null;
|
|
200
|
+
}
|
|
201
|
+
ngOnInit() {
|
|
202
|
+
if (this.config) {
|
|
203
|
+
this.actionItems = this.config.actionItems;
|
|
204
|
+
this.actionType = this.config.actionType;
|
|
205
|
+
this._style = this.config.style;
|
|
206
|
+
this.action = this.config.action;
|
|
207
|
+
this.disable = this.config.disable;
|
|
208
|
+
this.processStyle();
|
|
209
|
+
}
|
|
210
|
+
if (this.cellData !== null) {
|
|
211
|
+
const defaultStates = {
|
|
212
|
+
'checkbox': false,
|
|
213
|
+
'row-collapse': true,
|
|
214
|
+
};
|
|
215
|
+
if (this.actionType in defaultStates) {
|
|
216
|
+
this.currentState = typeof this.cellData === 'boolean' ? this.cellData : defaultStates[this.actionType];
|
|
217
|
+
}
|
|
218
|
+
else {
|
|
219
|
+
this.data = this.cellData;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
ngOnDestroy() {
|
|
224
|
+
this.closeDropdown();
|
|
225
|
+
}
|
|
226
|
+
processStyle() {
|
|
227
|
+
// Remove width from style to avoid conflicts with table column width
|
|
228
|
+
const { width, ...restStyle } = this._style;
|
|
229
|
+
this.containerStyle = restStyle;
|
|
230
|
+
}
|
|
231
|
+
onActionClick(item, event) {
|
|
232
|
+
event.stopPropagation();
|
|
233
|
+
// Check permissions before executing action
|
|
234
|
+
if (this.isDisabled(item))
|
|
235
|
+
return;
|
|
236
|
+
// Execute action only if permitted
|
|
237
|
+
if (item.action) {
|
|
238
|
+
item.action(this.data);
|
|
239
|
+
}
|
|
240
|
+
this.actionClick.emit({ item });
|
|
241
|
+
}
|
|
242
|
+
trackByAction(index, item) {
|
|
243
|
+
return item.value;
|
|
244
|
+
}
|
|
245
|
+
isSvgFile(iconPath) {
|
|
246
|
+
if (!iconPath)
|
|
247
|
+
return false;
|
|
248
|
+
return iconPath.toLowerCase().includes(".svg") || iconPath.toLowerCase().includes("assets/icons/");
|
|
249
|
+
}
|
|
250
|
+
onDocumentClick() {
|
|
251
|
+
if (this.isDropdownOpen) {
|
|
252
|
+
this.closeDropdown();
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
toggleDropdown(event) {
|
|
256
|
+
event.stopPropagation();
|
|
257
|
+
if (this.isDropdownOpen) {
|
|
258
|
+
this.closeDropdown();
|
|
259
|
+
}
|
|
260
|
+
else {
|
|
261
|
+
this.openDropdown();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
openDropdown() {
|
|
265
|
+
if (!this.dropdownTrigger || !this.dropdownMenu)
|
|
266
|
+
return;
|
|
267
|
+
// Close all submenus when opening main menu
|
|
268
|
+
this.actionItems.forEach((item) => (item.showSubmenu = false));
|
|
269
|
+
const positions = this.getDropdownPositions();
|
|
270
|
+
const overlayConfig = new OverlayConfig({
|
|
271
|
+
hasBackdrop: true,
|
|
272
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
273
|
+
positionStrategy: this.overlay
|
|
274
|
+
.position()
|
|
275
|
+
.flexibleConnectedTo(this.dropdownTrigger)
|
|
276
|
+
.withPositions(positions)
|
|
277
|
+
.withPush(true),
|
|
278
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition()
|
|
279
|
+
});
|
|
280
|
+
this.overlayRef = this.overlay.create(overlayConfig);
|
|
281
|
+
const portal = new TemplatePortal(this.dropdownMenu, this.viewContainerRef);
|
|
282
|
+
this.overlayRef.attach(portal);
|
|
283
|
+
this.overlayRef.backdropClick().subscribe(() => {
|
|
284
|
+
this.closeDropdown();
|
|
285
|
+
});
|
|
286
|
+
this.isDropdownOpen = true;
|
|
287
|
+
}
|
|
288
|
+
closeDropdown() {
|
|
289
|
+
if (this.overlayRef) {
|
|
290
|
+
this.overlayRef.dispose();
|
|
291
|
+
this.overlayRef = null;
|
|
292
|
+
}
|
|
293
|
+
this.isDropdownOpen = false;
|
|
294
|
+
}
|
|
295
|
+
getDropdownPositions() {
|
|
296
|
+
// Use CDK Overlay's flexible positioning - it will automatically choose the best position
|
|
297
|
+
return [
|
|
298
|
+
// Primary position: below and aligned to end (right)
|
|
299
|
+
new ConnectionPositionPair({ originX: 'end', originY: 'bottom' }, { overlayX: 'end', overlayY: 'top' }, 0, 4),
|
|
300
|
+
// Fallback position: above and aligned to end (right)
|
|
301
|
+
new ConnectionPositionPair({ originX: 'end', originY: 'top' }, { overlayX: 'end', overlayY: 'bottom' }, 0, -4),
|
|
302
|
+
// Fallback position: below and aligned to start (left)
|
|
303
|
+
new ConnectionPositionPair({ originX: 'start', originY: 'bottom' }, { overlayX: 'start', overlayY: 'top' }, 0, 4),
|
|
304
|
+
// Fallback position: above and aligned to start (left)
|
|
305
|
+
new ConnectionPositionPair({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'bottom' }, 0, -4)
|
|
306
|
+
];
|
|
307
|
+
}
|
|
308
|
+
onDropdownItemClick(item, event) {
|
|
309
|
+
event.stopPropagation();
|
|
310
|
+
if (this.isDisabled(item))
|
|
311
|
+
return;
|
|
312
|
+
if (item?.children?.length) {
|
|
313
|
+
// Toggle submenu
|
|
314
|
+
item.showSubmenu = !item.showSubmenu;
|
|
315
|
+
// Optionally close other submenus
|
|
316
|
+
this.actionItems.forEach((i) => {
|
|
317
|
+
if (i !== item)
|
|
318
|
+
i.showSubmenu = false;
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
else {
|
|
322
|
+
// Handle action
|
|
323
|
+
if (item.action)
|
|
324
|
+
item.action(this.data);
|
|
325
|
+
this.actionClick.emit({ item, data: this.data });
|
|
326
|
+
this.closeDropdown(); // Only close if action was executed
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
onClick(event) {
|
|
330
|
+
this.currentState = !this.currentState;
|
|
331
|
+
this.actionClick.emit({
|
|
332
|
+
actionType: this.actionType,
|
|
333
|
+
value: this.currentState
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
isDisabled(item) {
|
|
337
|
+
if (typeof item.disable === "function") {
|
|
338
|
+
return item.disable(this.data);
|
|
339
|
+
}
|
|
340
|
+
return false;
|
|
341
|
+
}
|
|
342
|
+
static { this.ɵfac = function ActionsCellComponent_Factory(t) { return new (t || ActionsCellComponent)(i0.ɵɵdirectiveInject(i1.Overlay), i0.ɵɵdirectiveInject(i0.ViewContainerRef)); }; }
|
|
343
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ActionsCellComponent, selectors: [["mis-actions-cell"]], viewQuery: function ActionsCellComponent_Query(rf, ctx) { if (rf & 1) {
|
|
344
|
+
i0.ɵɵviewQuery(_c0, 5);
|
|
345
|
+
i0.ɵɵviewQuery(_c1, 5);
|
|
346
|
+
} if (rf & 2) {
|
|
347
|
+
let _t;
|
|
348
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dropdownMenu = _t.first);
|
|
349
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.dropdownTrigger = _t.first);
|
|
350
|
+
} }, hostBindings: function ActionsCellComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
351
|
+
i0.ɵɵlistener("click", function ActionsCellComponent_click_HostBindingHandler() { return ctx.onDocumentClick(); }, false, i0.ɵɵresolveDocument);
|
|
352
|
+
} }, inputs: { cellData: "cellData", config: "config" }, outputs: { actionClick: "actionClick" }, decls: 7, vars: 5, consts: [["dropdownMenu", ""], ["dropdownTrigger", ""], ["noChildren", ""], [1, "actions-cell-container", 3, "ngStyle"], ["class", "inline-actions", 4, "ngIf"], ["class", "dropdown-actions", 4, "ngIf"], ["class", "checkbox-actions", 4, "ngIf"], ["class", "collapse-toggle-action", 4, "ngIf"], [1, "inline-actions"], ["class", "action-item", 3, "ngClass", "click", 4, "ngFor", "ngForOf", "ngForTrackBy"], [1, "action-item", 3, "click", "ngClass"], [1, "action-icon-svg", 3, "src", "alt"], [1, "dropdown-actions"], ["title", "More actions", 1, "dropdown-trigger", 3, "click"], ["width", "20", "height", "20", "viewBox", "0 0 20 20", "fill", "none"], ["cx", "10", "cy", "4", "r", "2", "fill", "#333"], ["cx", "10", "cy", "10", "r", "2", "fill", "#333"], ["cx", "10", "cy", "16", "r", "2", "fill", "#333"], [1, "checkbox-actions"], [3, "valueChange", "checked", "disabled"], [1, "collapse-toggle-action"], [1, "collapse-icon", 3, "click", "title"], ["width", "20", "height", "20", "viewBox", "0 0 24 24", 4, "ngIf"], ["width", "20", "height", "20", "viewBox", "0 0 24 24"], ["d", "M7 10l5 5 5-5", "stroke", "#0D1321", "stroke-width", "2", "fill", "none", "stroke-linecap", "round", "stroke-linejoin", "round"], ["d", "M7 14l5-5 5 5", "stroke", "#0D1321", "stroke-width", "2", "fill", "none", "stroke-linecap", "round", "stroke-linejoin", "round"], [1, "dropdown-menu-overlay"], ["class", "dropdown-menu-item", 3, "ngClass", "click", 4, "ngFor", "ngForOf"], [1, "dropdown-menu-item", 3, "click", "ngClass"], [4, "ngIf", "ngIfElse"], ["class", "dropdown-icon", 4, "ngIf"], [1, "dropdown-label"], [1, "submenu-arrow"], ["width", "20", "height", "20", "viewBox", "0 0 24 24", "fill", "none"], ["d", "M9 6L15 12L9 18", "stroke", "#0D1321", "stroke-width", "2", "stroke-linecap", "round", "stroke-linejoin", "round"], ["class", "dropdown-submenu", 4, "ngIf"], [1, "dropdown-icon"], [3, "src"], [1, "dropdown-submenu"]], template: function ActionsCellComponent_Template(rf, ctx) { if (rf & 1) {
|
|
353
|
+
i0.ɵɵelementStart(0, "div", 3);
|
|
354
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_Template, 2, 2, "div", 4)(2, ActionsCellComponent_div_2_Template, 7, 0, "div", 5)(3, ActionsCellComponent_div_3_Template, 2, 2, "div", 6);
|
|
355
|
+
i0.ɵɵelementEnd();
|
|
356
|
+
i0.ɵɵtemplate(4, ActionsCellComponent_div_4_Template, 4, 3, "div", 7)(5, ActionsCellComponent_ng_template_5_Template, 2, 1, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
|
|
357
|
+
} if (rf & 2) {
|
|
358
|
+
i0.ɵɵproperty("ngStyle", ctx.containerStyle);
|
|
359
|
+
i0.ɵɵadvance();
|
|
360
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "inline");
|
|
361
|
+
i0.ɵɵadvance();
|
|
362
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "dropdown");
|
|
363
|
+
i0.ɵɵadvance();
|
|
364
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "checkbox");
|
|
365
|
+
i0.ɵɵadvance();
|
|
366
|
+
i0.ɵɵproperty("ngIf", ctx.actionType === "row-collapse");
|
|
367
|
+
} }, dependencies: [i2.NgClass, i2.NgForOf, i2.NgIf, i2.NgStyle, i3.CheckboxComponent], styles: [".actions-cell-container[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;box-sizing:border-box}.inline-actions[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;flex-wrap:nowrap;padding:4px 0;flex-direction:row}.action-item[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;height:20px;border-radius:4px;cursor:pointer;transition:all .2s ease;background-color:transparent;border:none;outline:none;flex-shrink:0;min-height:20px}.action-item[_ngcontent-%COMP%]:hover:not(.disabled){background-color:#0000000a;transform:scale(1.05)}.action-item[_ngcontent-%COMP%]:active:not(.disabled){transform:scale(.95)}.action-item.disabled[_ngcontent-%COMP%]{opacity:.5;cursor:not-allowed}.action-item.disabled[_ngcontent-%COMP%]:hover{background-color:transparent;transform:none}.action-icon[_ngcontent-%COMP%]{font-size:16px;color:#666;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.action-icon-svg[_ngcontent-%COMP%]{width:18px;height:18px;object-fit:contain;filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(.6) contrast(1);flex-shrink:0}.action-icon-svg[_ngcontent-%COMP%]:hover{filter:brightness(0) saturate(100%) invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0) contrast(1)}.dropdown-trigger[_ngcontent-%COMP%]{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-actions[_ngcontent-%COMP%]{position:relative}.dropdown-menu-overlay[_ngcontent-%COMP%]{width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1000}.dropdown-menu-item.disabled[_ngcontent-%COMP%]{color:#aaa;cursor:not-allowed}.dropdown-menu-item[_ngcontent-%COMP%]:hover:not(.disabled), .dropdown-menu-item.has-submenu[_ngcontent-%COMP%]:hover{background:#f5f5f5}.dropdown-menu-item[_ngcontent-%COMP%]{display:flex;align-items:center;padding:10px 18px;cursor:pointer;font-size:14px;position:relative}.dropdown-menu-item[_ngcontent-%COMP%] .dropdown-label[_ngcontent-%COMP%]{flex:1;margin-left:8px}.dropdown-menu-item[_ngcontent-%COMP%] .submenu-arrow[_ngcontent-%COMP%]{margin-left:auto;width:16px;height:16px}.dropdown-submenu[_ngcontent-%COMP%]{position:absolute;top:0;min-width:132px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1001}.dropdown-submenu[_ngcontent-%COMP%]{left:100%;margin-left:4px}.submenu-arrow[_ngcontent-%COMP%]{display:flex;align-items:center;margin-left:auto;z-index:9999}.dropdown-icon[_ngcontent-%COMP%]{display:flex;justify-content:center;align-items:center}.dropdown-menu-item.disabled[_ngcontent-%COMP%]{color:#181f33;filter:grayscale(100%) opacity(.3);cursor:not-allowed}.checkbox-actions[_ngcontent-%COMP%]{display:flex;align-items:center;justify-content:center;width:100%;height:100%}"] }); }
|
|
368
|
+
}
|
|
369
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ActionsCellComponent, [{
|
|
370
|
+
type: Component,
|
|
371
|
+
args: [{ selector: "mis-actions-cell", template: "<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle\">\n <!-- Inline Actions -->\n <div *ngIf=\"actionType === 'inline'\" class=\"inline-actions\">\n <div\n *ngFor=\"let item of actionItems; trackBy: trackByAction\"\n class=\"action-item\"\n [ngClass]=\"{ disabled: isDisabled(item) }\"\n (click)=\"onActionClick(item, $event)\"\n >\n <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n </div>\n </div>\n\n <!-- Dropdown Actions -->\n <div *ngIf=\"actionType === 'dropdown'\" class=\"dropdown-actions\">\n <div #dropdownTrigger class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n </svg>\n </div>\n </div>\n\n <!-- Checkbox Actions -->\n <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n <mis-checkbox [checked]=\"currentState\" (valueChange)=\"onClick($event)\" [disabled]=\"disable ? disable(currentState) : false\"> </mis-checkbox>\n </div>\n</div>\n\n<!-- Collapse / Expand Actions -->\n<div *ngIf=\"actionType === 'row-collapse'\" class=\"collapse-toggle-action\">\n <div class=\"collapse-icon\" (click)=\"onClick($event)\" [title]=\"currentState ? 'Expand' : 'Collapse'\">\n <svg *ngIf=\"currentState\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n <path d=\"M7 10l5 5 5-5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <svg *ngIf=\"!currentState\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n <path d=\"M7 14l5-5 5 5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n</div>\n\n<!-- CDK Overlay Template for Dropdown Menu -->\n<ng-template #dropdownMenu>\n <div class=\"dropdown-menu-overlay\">\n <div\n class=\"dropdown-menu-item\"\n *ngFor=\"let item of actionItems\"\n (click)=\"onDropdownItemClick(item, $event)\"\n [ngClass]=\"{ disabled: isDisabled(item) }\"\n >\n <ng-container *ngIf=\"item.children?.length; else noChildren\">\n <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n <img [src]=\"item.icon\" />\n </span>\n <span class=\"dropdown-label\">{{ item.label }}</span>\n <span class=\"submenu-arrow\">\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </span>\n\n <!-- DYNAMIC SUBMENU -->\n <div class=\"dropdown-submenu\" *ngIf=\"item.showSubmenu\">\n <div\n class=\"dropdown-menu-item\"\n *ngFor=\"let child of item.children\"\n [ngClass]=\"{ disabled: isDisabled(child) }\"\n (click)=\"onDropdownItemClick(child, $event)\"\n >\n <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n <img [src]=\"child.icon\" />\n </span>\n <span class=\"dropdown-label\">{{ child.label }}</span>\n </div>\n </div>\n </ng-container>\n\n <ng-template #noChildren>\n <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n <img [src]=\"item.icon\" />\n </span>\n <span class=\"dropdown-label\">{{ item.label }}</span>\n </ng-template>\n </div>\n </div>\n</ng-template>\n", styles: [".actions-cell-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;box-sizing:border-box}.inline-actions{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;flex-wrap:nowrap;padding:4px 0;flex-direction:row}.action-item{display:flex;align-items:center;justify-content:center;height:20px;border-radius:4px;cursor:pointer;transition:all .2s ease;background-color:transparent;border:none;outline:none;flex-shrink:0;min-height:20px}.action-item:hover:not(.disabled){background-color:#0000000a;transform:scale(1.05)}.action-item:active:not(.disabled){transform:scale(.95)}.action-item.disabled{opacity:.5;cursor:not-allowed}.action-item.disabled:hover{background-color:transparent;transform:none}.action-icon{font-size:16px;color:#666;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.action-icon-svg{width:18px;height:18px;object-fit:contain;filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(.6) contrast(1);flex-shrink:0}.action-icon-svg:hover{filter:brightness(0) saturate(100%) invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(0) contrast(1)}.dropdown-trigger{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-actions{position:relative}.dropdown-menu-overlay{width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1000}.dropdown-menu-item.disabled{color:#aaa;cursor:not-allowed}.dropdown-menu-item:hover:not(.disabled),.dropdown-menu-item.has-submenu:hover{background:#f5f5f5}.dropdown-menu-item{display:flex;align-items:center;padding:10px 18px;cursor:pointer;font-size:14px;position:relative}.dropdown-menu-item .dropdown-label{flex:1;margin-left:8px}.dropdown-menu-item .submenu-arrow{margin-left:auto;width:16px;height:16px}.dropdown-submenu{position:absolute;top:0;min-width:132px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;padding:8px 0;z-index:1001}.dropdown-submenu{left:100%;margin-left:4px}.submenu-arrow{display:flex;align-items:center;margin-left:auto;z-index:9999}.dropdown-icon{display:flex;justify-content:center;align-items:center}.dropdown-menu-item.disabled{color:#181f33;filter:grayscale(100%) opacity(.3);cursor:not-allowed}.checkbox-actions{display:flex;align-items:center;justify-content:center;width:100%;height:100%}\n"] }]
|
|
372
|
+
}], () => [{ type: i1.Overlay }, { type: i0.ViewContainerRef }], { cellData: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], config: [{
|
|
375
|
+
type: Input
|
|
376
|
+
}], actionClick: [{
|
|
377
|
+
type: Output
|
|
378
|
+
}], dropdownMenu: [{
|
|
379
|
+
type: ViewChild,
|
|
380
|
+
args: ['dropdownMenu', { static: false }]
|
|
381
|
+
}], dropdownTrigger: [{
|
|
382
|
+
type: ViewChild,
|
|
383
|
+
args: ['dropdownTrigger', { static: false }]
|
|
384
|
+
}], onDocumentClick: [{
|
|
385
|
+
type: HostListener,
|
|
386
|
+
args: ["document:click"]
|
|
387
|
+
}] }); })();
|
|
388
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
389
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-cell.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/table/actions-cell/actions-cell.component.ts","../../../../../projects/mis-components/table/actions-cell/actions-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, HostListener, ElementRef, ViewChild, TemplateRef, ViewContainerRef, OnDestroy, SimpleChanges, AfterViewInit } from \"@angular/core\";\nimport { ConnectionPositionPair, Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { ActionItem } from \"../table.component\";\n\n@Component({\n  selector: \"mis-actions-cell\",\n  templateUrl: \"./actions-cell.component.html\",\n  styleUrl: \"./actions-cell.component.css\"\n})\nexport class ActionsCellComponent implements OnInit, OnDestroy {\n  @Input() cellData;\n  @Input() config;\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data?: any, actionType?: string, value?: any }>();\n\n  @ViewChild('dropdownMenu', { static: false }) dropdownMenu: TemplateRef<any>;\n  @ViewChild('dropdownTrigger', { static: false }) dropdownTrigger: ElementRef;\n\n  isDropdownOpen: boolean = false;\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\" = \"inline\";\n  action?: (data: any) => void;\n  data: any;\n  disable: (data: any) => boolean;\n  currentState: boolean = false;\n  private _style: any = {};\n  containerStyle: any = {};\n  private overlayRef: OverlayRef | null = null;\n\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.actionItems = this.config.actionItems;\n      this.actionType = this.config.actionType;\n      this._style = this.config.style;\n      this.action = this.config.action;\n      this.disable = this.config.disable;\n      this.processStyle();\n    }\n  \n    if (this.cellData !== null) {\n      const defaultStates: Record<string, boolean> = {\n        'checkbox': false,\n        'row-collapse': true,\n      };\n      if (this.actionType in defaultStates) {\n        this.currentState = typeof this.cellData === 'boolean' ? this.cellData : defaultStates[this.actionType];\n      } else {\n        this.data = this.cellData;\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeDropdown();\n  }\n\n  private processStyle(): void {\n    // Remove width from style to avoid conflicts with table column width\n    const { width, ...restStyle } = this._style;\n    this.containerStyle = restStyle;\n  }\n\n  onActionClick(item: ActionItem, event: Event) {\n    event.stopPropagation();\n\n    // Check permissions before executing action\n    if (this.isDisabled(item)) return;\n\n    // Execute action only if permitted\n    if (item.action) {\n      item.action(this.data);\n    }\n\n    this.actionClick.emit({ item });\n  }\n\n  trackByAction(index: number, item: ActionItem): string {\n    return item.value;\n  }\n\n  isSvgFile(iconPath: string): boolean {\n    if (!iconPath) return false;\n    return iconPath.toLowerCase().includes(\".svg\") || iconPath.toLowerCase().includes(\"assets/icons/\");\n  }\n\n  @HostListener(\"document:click\")\n  onDocumentClick() {\n    if (this.isDropdownOpen) {\n      this.closeDropdown();\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    \n    if (this.isDropdownOpen) {\n      this.closeDropdown();\n    } else {\n      this.openDropdown();\n    }\n  }\n\n  private openDropdown(): void {\n    if (!this.dropdownTrigger || !this.dropdownMenu) return;\n\n    // Close all submenus when opening main menu\n    this.actionItems.forEach((item: any) => (item.showSubmenu = false));\n\n    const positions = this.getDropdownPositions();\n    \n    const overlayConfig = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy: this.overlay\n        .position()\n        .flexibleConnectedTo(this.dropdownTrigger)\n        .withPositions(positions)\n        .withPush(true),\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\n    });\n\n    this.overlayRef = this.overlay.create(overlayConfig);\n    const portal = new TemplatePortal(this.dropdownMenu, this.viewContainerRef);\n    this.overlayRef.attach(portal);\n\n    this.overlayRef.backdropClick().subscribe(() => {\n      this.closeDropdown();\n    });\n\n    this.isDropdownOpen = true;\n  }\n\n  private closeDropdown(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n    this.isDropdownOpen = false;\n  }\n\n  private getDropdownPositions(): ConnectionPositionPair[] {\n    // Use CDK Overlay's flexible positioning - it will automatically choose the best position\n    return [\n      // Primary position: below and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0, -4\n      ),\n      // Fallback position: below and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0, -4\n      )\n    ];\n  }\n\n  onDropdownItemClick(item: any, event: Event) {\n    event.stopPropagation();\n\n    if (this.isDisabled(item)) return;\n\n    if (item?.children?.length) {\n      // Toggle submenu\n      item.showSubmenu = !item.showSubmenu;\n      // Optionally close other submenus\n      this.actionItems.forEach((i: any) => {\n        if (i !== item) i.showSubmenu = false;\n      });\n    } else {\n      // Handle action\n      if (item.action) item.action(this.data);\n      this.actionClick.emit({ item, data: this.data });\n      this.closeDropdown(); // Only close if action was executed\n    }\n  }\n\n  onClick(event: any): void{\n    this.currentState = !this.currentState;\n    this.actionClick.emit({ \n      actionType: this.actionType,\n      value: this.currentState\n    });\n  }\n\n  isDisabled(item: ActionItem): boolean {\n    if (typeof item.disable === \"function\") {\n      return item.disable(this.data);\n    }\n    return false;\n  }\n  \n}\n","<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle\">\n  <!-- Inline Actions -->\n  <div *ngIf=\"actionType === 'inline'\" class=\"inline-actions\">\n    <div\n      *ngFor=\"let item of actionItems; trackBy: trackByAction\"\n      class=\"action-item\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n      (click)=\"onActionClick(item, $event)\"\n    >\n      <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n    </div>\n  </div>\n\n  <!-- Dropdown Actions -->\n  <div *ngIf=\"actionType === 'dropdown'\" class=\"dropdown-actions\">\n    <div #dropdownTrigger class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n        <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n      </svg>\n    </div>\n  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"currentState\" (valueChange)=\"onClick($event)\" [disabled]=\"disable ? disable(currentState) : false\"> </mis-checkbox>\n  </div>\n</div>\n\n<!-- Collapse / Expand Actions -->\n<div *ngIf=\"actionType === 'row-collapse'\" class=\"collapse-toggle-action\">\n  <div class=\"collapse-icon\" (click)=\"onClick($event)\" [title]=\"currentState ? 'Expand' : 'Collapse'\">\n    <svg *ngIf=\"currentState\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 10l5 5 5-5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n    <svg *ngIf=\"!currentState\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 14l5-5 5 5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n  </div>\n</div>\n\n<!-- CDK Overlay Template for Dropdown Menu -->\n<ng-template #dropdownMenu>\n  <div class=\"dropdown-menu-overlay\">\n    <div\n      class=\"dropdown-menu-item\"\n      *ngFor=\"let item of actionItems\"\n      (click)=\"onDropdownItemClick(item, $event)\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n    >\n      <ng-container *ngIf=\"item.children?.length; else noChildren\">\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n        <span class=\"submenu-arrow\">\n          <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n            <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n\n        <!-- DYNAMIC SUBMENU -->\n        <div class=\"dropdown-submenu\" *ngIf=\"item.showSubmenu\">\n          <div\n            class=\"dropdown-menu-item\"\n            *ngFor=\"let child of item.children\"\n            [ngClass]=\"{ disabled: isDisabled(child) }\"\n            (click)=\"onDropdownItemClick(child, $event)\"\n          >\n            <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n              <img [src]=\"child.icon\" />\n            </span>\n            <span class=\"dropdown-label\">{{ child.label }}</span>\n          </div>\n        </div>\n      </ng-container>\n\n      <ng-template #noChildren>\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n      </ng-template>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
export
|
|
1
|
+
export * from './table.component';
|
|
2
|
+
export * from './table.module';
|
|
3
|
+
export * from './sort-icons.directive';
|
|
2
4
|
export { SubTableComponent } from "./sub-table/sub-table.component";
|
|
3
5
|
export { CustomTableCellDirective } from "./custom-table-cell.directive";
|
|
4
|
-
export { TableModule } from "./table.module";
|
|
5
6
|
export { TableFilterComponent } from "./filter/filter.component";
|
|
6
|
-
|
|
7
|
+
export { ActionsCellComponent } from "./actions-cell/actions-cell.component";
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL3RhYmxlL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFHekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFakUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NvcnQtaWNvbnMuZGlyZWN0aXZlJztcbmV4cG9ydCB7IFN1YlRhYmxlQ29tcG9uZW50IH0gZnJvbSBcIi4vc3ViLXRhYmxlL3N1Yi10YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IEN1c3RvbVRhYmxlQ2VsbERpcmVjdGl2ZSB9IGZyb20gXCIuL2N1c3RvbS10YWJsZS1jZWxsLmRpcmVjdGl2ZVwiO1xuZXhwb3J0IHsgVGFibGVDb25maWcsIFBhZ2luYXRpb25Db25maWcsIFJvd0NvbmZpZywgQ29sSGVhZGVyQ29uZmlnLCBDb2xDb25maWcgfSBmcm9tIFwiLi90YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IFN1YlRhYmxlQ29uZmlnLCBTdWJUYWJsZUNvbENvbmZpZywgU3ViVGFibGVDb2xIZWFkZXJDb25maWcsIFN1YlRhYmxlUm93Q29uZmlnIH0gZnJvbSBcIi4vc3ViLXRhYmxlL3N1Yi10YWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCB7IFRhYmxlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsdGVyL2ZpbHRlci5jb21wb25lbnRcIjtcbmV4cG9ydCB7IEZpbHRlciB9IGZyb20gXCIuL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50XCI7XG5leHBvcnQgeyBBY3Rpb25zQ2VsbENvbXBvbmVudCB9IGZyb20gXCIuL2FjdGlvbnMtY2VsbC9hY3Rpb25zLWNlbGwuY29tcG9uZW50XCI7Il19
|