mis-crystal-design-system 18.0.17 → 18.0.19-test-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/dropdown/dropdown.component.mjs +23 -23
- package/esm2022/multi-select-dropdown/multi-select-dropdown.component.mjs +54 -54
- package/esm2022/table/actions-cell/actions-cell.component.mjs +32 -9
- package/esm2022/table/table.component.mjs +31 -19
- package/fesm2022/mis-crystal-design-system-dropdown.mjs +22 -22
- package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs +53 -53
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +571 -537
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/package.json +13 -13
- package/table/actions-cell/actions-cell.component.d.ts +10 -7
- package/table/table.component.d.ts +4 -0
- package/button/button.directive.scss +0 -69
- package/drawer/drawer.scss +0 -20
- package/input/mis-input.component.scss +0 -180
- package/modal/modal.scss +0 -9
- package/styles/fonts/icomoon.eot +0 -0
- package/styles/fonts/icomoon.svg +0 -315
- package/styles/fonts/icomoon.ttf +0 -0
- package/styles/fonts/icomoon.woff +0 -0
- package/styles/mis-borders-backgrounds.scss +0 -764
- package/styles/mis-color-constants.scss +0 -149
- package/styles/mis-flex.scss +0 -321
- package/styles/mis-fonts.scss +0 -124
- package/styles/mis-icons.scss +0 -1054
- package/styles/mis-mixins.scss +0 -46
- package/styles/mis-old-icon-styles.scss +0 -498
- package/styles/mis-spacing-sizing.scss +0 -2590
- package/styles/mis-typography.scss +0 -462
|
@@ -166,9 +166,9 @@ function MultiSelectDropdownComponent_ng_template_8_Template(rf, ctx) { if (rf &
|
|
|
166
166
|
} }
|
|
167
167
|
export class MultiSelectDropdownComponent {
|
|
168
168
|
set data(values) {
|
|
169
|
-
this.localData = values
|
|
169
|
+
this.localData = values?.map(item => {
|
|
170
170
|
return { ...item, checked: false };
|
|
171
|
-
});
|
|
171
|
+
}) || [];
|
|
172
172
|
}
|
|
173
173
|
set selectedItems(values) {
|
|
174
174
|
this.handlerSetLocalSelectedItems(values);
|
|
@@ -204,30 +204,30 @@ export class MultiSelectDropdownComponent {
|
|
|
204
204
|
}
|
|
205
205
|
ngOnInit() { }
|
|
206
206
|
handlerSetLocalSelectedItems(values) {
|
|
207
|
-
this.localSelectedItems = values;
|
|
208
|
-
this.localData = this.localData
|
|
209
|
-
if (item
|
|
207
|
+
this.localSelectedItems = values || [];
|
|
208
|
+
this.localData = this.localData?.map(item => {
|
|
209
|
+
if (item?.value === this.SELECT_ALL_ENUM && values?.length === this.localData?.length - 1) {
|
|
210
210
|
return { ...item, checked: true };
|
|
211
211
|
}
|
|
212
|
-
if (values
|
|
212
|
+
if (values?.some(base => base?.value === item?.value)) {
|
|
213
213
|
return { ...item, checked: true };
|
|
214
214
|
}
|
|
215
215
|
else {
|
|
216
|
-
if (item
|
|
216
|
+
if (item?.value !== this.SELECT_ALL_ENUM || !this.hideApplyButton) {
|
|
217
217
|
return { ...item, checked: false };
|
|
218
218
|
}
|
|
219
219
|
else {
|
|
220
220
|
return item;
|
|
221
221
|
}
|
|
222
222
|
}
|
|
223
|
-
});
|
|
223
|
+
}) || [];
|
|
224
224
|
this.localData = this.formatValues(this.localData);
|
|
225
225
|
}
|
|
226
226
|
searchInputFocused(isFocused) {
|
|
227
227
|
this.isSearchInputFocused = isFocused;
|
|
228
228
|
}
|
|
229
229
|
searchInputCanceled(event) {
|
|
230
|
-
event
|
|
230
|
+
event?.stopPropagation();
|
|
231
231
|
this.searchInput = "";
|
|
232
232
|
this.isSearchInputFocused = false;
|
|
233
233
|
}
|
|
@@ -239,7 +239,7 @@ export class MultiSelectDropdownComponent {
|
|
|
239
239
|
this.localData = this.formatValues(this.localData);
|
|
240
240
|
}
|
|
241
241
|
if (this.isOpen)
|
|
242
|
-
this.openDropdown(this.popupContainer, this.selectElement
|
|
242
|
+
this.openDropdown(this.popupContainer, this.selectElement?.nativeElement);
|
|
243
243
|
else
|
|
244
244
|
this.onCancel();
|
|
245
245
|
});
|
|
@@ -266,20 +266,20 @@ export class MultiSelectDropdownComponent {
|
|
|
266
266
|
backdropClass: "cdk-overlay-transparent-backdrop",
|
|
267
267
|
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
268
268
|
positionStrategy,
|
|
269
|
-
width: origin
|
|
269
|
+
width: origin?.clientWidth
|
|
270
270
|
});
|
|
271
271
|
this.overlayRef = this.overlay.create(configs);
|
|
272
272
|
if (this.dropdownListWidth)
|
|
273
|
-
this.overlayRef
|
|
273
|
+
this.overlayRef?.updateSize({ width: this.dropdownListWidth });
|
|
274
274
|
if (this.dropdownListHeight)
|
|
275
|
-
this.overlayRef
|
|
276
|
-
this.overlayRef
|
|
277
|
-
this.overlayRef
|
|
275
|
+
this.overlayRef?.updateSize({ height: this.dropdownListHeight });
|
|
276
|
+
this.overlayRef?.attach(new TemplatePortal(template, this.viewContainerRef));
|
|
277
|
+
this.overlayRef?.backdropClick()?.subscribe(res => {
|
|
278
278
|
this.onCancel();
|
|
279
279
|
});
|
|
280
280
|
}
|
|
281
281
|
filterByValue(array, string) {
|
|
282
|
-
return array
|
|
282
|
+
return array?.filter(o => o?.label?.toLowerCase()?.includes(string?.toLowerCase())) || [];
|
|
283
283
|
}
|
|
284
284
|
searchInputOnChange(newValue) {
|
|
285
285
|
this.searchInput = newValue;
|
|
@@ -292,73 +292,73 @@ export class MultiSelectDropdownComponent {
|
|
|
292
292
|
}
|
|
293
293
|
}
|
|
294
294
|
formatValues(array) {
|
|
295
|
-
let sortedArray = array;
|
|
296
|
-
if (this.options
|
|
295
|
+
let sortedArray = array || [];
|
|
296
|
+
if (this.options?.sortLabels) {
|
|
297
297
|
const checkedValues = array
|
|
298
|
-
|
|
299
|
-
|
|
298
|
+
?.filter(a => a?.checked)
|
|
299
|
+
?.sort((a, b) => (a?.label > b?.label ? 1 : b?.label > a?.label ? -1 : 0)) || [];
|
|
300
300
|
const unCheckedValues = array
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
sortedArray = [...checkedValues, ...unCheckedValues]
|
|
301
|
+
?.filter(a => !a?.checked)
|
|
302
|
+
?.sort((a, b) => (a?.label > b?.label ? 1 : b?.label > a?.label ? -1 : 0)) || [];
|
|
303
|
+
sortedArray = [...checkedValues, ...unCheckedValues]?.filter(t => t?.value !== this.SELECT_ALL_ENUM) || [];
|
|
304
304
|
}
|
|
305
|
-
if (!sortedArray
|
|
306
|
-
sortedArray
|
|
305
|
+
if (!sortedArray?.some(option => option?.value === this.SELECT_ALL_ENUM) && this.enableSelectAll && sortedArray?.length > 0) {
|
|
306
|
+
sortedArray?.unshift({
|
|
307
307
|
label: "Select all",
|
|
308
308
|
value: this.SELECT_ALL_ENUM,
|
|
309
|
-
checked: sortedArray
|
|
309
|
+
checked: sortedArray?.every(y => y?.checked)
|
|
310
310
|
});
|
|
311
311
|
}
|
|
312
312
|
return sortedArray;
|
|
313
313
|
}
|
|
314
314
|
toggleSelectedItems(event, item) {
|
|
315
|
-
event
|
|
316
|
-
if (this.enableSelectAll && item
|
|
317
|
-
this.localData = this.localData
|
|
315
|
+
event?.stopPropagation();
|
|
316
|
+
if (this.enableSelectAll && item?.value === this.SELECT_ALL_ENUM) {
|
|
317
|
+
this.localData = this.localData?.map(t => ({
|
|
318
318
|
...t,
|
|
319
|
-
checked: !item
|
|
320
|
-
}));
|
|
319
|
+
checked: !item?.checked
|
|
320
|
+
})) || [];
|
|
321
321
|
if (this.hideApplyButton) {
|
|
322
322
|
this.applyFilters();
|
|
323
323
|
}
|
|
324
324
|
return;
|
|
325
325
|
}
|
|
326
|
-
if (item
|
|
326
|
+
if (item?.checked) {
|
|
327
327
|
this.localData = [
|
|
328
|
-
...this.localData
|
|
329
|
-
if (a
|
|
328
|
+
...this.localData?.map(a => {
|
|
329
|
+
if (a?.value === item?.value || a?.value === this.SELECT_ALL_ENUM) {
|
|
330
330
|
return {
|
|
331
331
|
...a,
|
|
332
332
|
checked: false
|
|
333
333
|
};
|
|
334
334
|
}
|
|
335
335
|
return a;
|
|
336
|
-
})
|
|
336
|
+
}) || []
|
|
337
337
|
];
|
|
338
338
|
}
|
|
339
339
|
else {
|
|
340
340
|
this.localData = [
|
|
341
|
-
...this.localData
|
|
342
|
-
if (a
|
|
341
|
+
...this.localData?.map(a => {
|
|
342
|
+
if (a?.value === item?.value) {
|
|
343
343
|
return {
|
|
344
344
|
...a,
|
|
345
345
|
checked: true
|
|
346
346
|
};
|
|
347
347
|
}
|
|
348
348
|
return a;
|
|
349
|
-
})
|
|
349
|
+
}) || []
|
|
350
350
|
];
|
|
351
|
-
if (this.enableSelectAll && this.localData
|
|
351
|
+
if (this.enableSelectAll && this.localData?.filter(r => r?.value !== this.SELECT_ALL_ENUM)?.every(t => t?.checked)) {
|
|
352
352
|
this.localData = [
|
|
353
|
-
...this.localData
|
|
354
|
-
if (a
|
|
353
|
+
...this.localData?.map(a => {
|
|
354
|
+
if (a?.value === this.SELECT_ALL_ENUM) {
|
|
355
355
|
return {
|
|
356
356
|
...a,
|
|
357
357
|
checked: true
|
|
358
358
|
};
|
|
359
359
|
}
|
|
360
360
|
return a;
|
|
361
|
-
})
|
|
361
|
+
}) || []
|
|
362
362
|
];
|
|
363
363
|
}
|
|
364
364
|
}
|
|
@@ -370,32 +370,32 @@ export class MultiSelectDropdownComponent {
|
|
|
370
370
|
}
|
|
371
371
|
}
|
|
372
372
|
applyFilters() {
|
|
373
|
-
this.onChange
|
|
374
|
-
|
|
375
|
-
return a
|
|
373
|
+
this.onChange?.emit(this.localData
|
|
374
|
+
?.filter(a => {
|
|
375
|
+
return a?.checked && a?.value !== this.SELECT_ALL_ENUM;
|
|
376
376
|
})
|
|
377
|
-
|
|
378
|
-
const { checked, ...data } = item;
|
|
377
|
+
?.map(item => {
|
|
378
|
+
const { checked, ...data } = item || {};
|
|
379
379
|
return data;
|
|
380
|
-
}));
|
|
380
|
+
}) || []);
|
|
381
381
|
if (!this.hideApplyButton) {
|
|
382
382
|
this.onCancel();
|
|
383
383
|
}
|
|
384
384
|
}
|
|
385
385
|
onReset() {
|
|
386
386
|
this.isSearchInputFocused = false;
|
|
387
|
-
this.onChange
|
|
387
|
+
this.onChange?.emit([]);
|
|
388
388
|
this.isOpen = false;
|
|
389
389
|
this.searchInput = "";
|
|
390
390
|
}
|
|
391
391
|
onCancel() {
|
|
392
392
|
this.isSearchInputFocused = false;
|
|
393
|
-
this.localData = this.localData
|
|
394
|
-
if (this.localSelectedItems
|
|
393
|
+
this.localData = this.localData?.map(a => {
|
|
394
|
+
if (this.localSelectedItems?.some(b => b?.value === a?.value && String(b?.checked) !== String(a?.checked))) {
|
|
395
395
|
return a;
|
|
396
396
|
}
|
|
397
397
|
else {
|
|
398
|
-
if (a
|
|
398
|
+
if (a?.value !== this.SELECT_ALL_ENUM && this.hideApplyButton) {
|
|
399
399
|
return {
|
|
400
400
|
...a,
|
|
401
401
|
checked: false
|
|
@@ -403,7 +403,7 @@ export class MultiSelectDropdownComponent {
|
|
|
403
403
|
}
|
|
404
404
|
return a;
|
|
405
405
|
}
|
|
406
|
-
});
|
|
406
|
+
}) || [];
|
|
407
407
|
this.isOpen = false;
|
|
408
408
|
this.searchInput = "";
|
|
409
409
|
this.overlayRef?.detach();
|
|
@@ -486,4 +486,4 @@ export class MultiSelectDropdownComponent {
|
|
|
486
486
|
args: ["popupContainer", { static: false }]
|
|
487
487
|
}] }); })();
|
|
488
488
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MultiSelectDropdownComponent, { className: "MultiSelectDropdownComponent" }); })();
|
|
489
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.ts","../../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAkB,MAAM,EAAe,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC7I,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAuB,sBAAsB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;;;;;;;;ICgB5F,6BAA6E;IAC3E,YACF;IAAA,iBAAI;;;IADF,cACF;IADE,4GACF;;;IAJA,6BAA2C;IAC3C,4BAAgB;IAAA,YAAW;IAAA,iBAAI;IAC/B,wFAA6E;;;;IAD7D,eAAW;IAAX,kCAAW;IACvB,cAAyD;IAAzD,oIAAyD;;;IAK7D,wBACe;;;IAFjB,6BAA0C;IACxC,+GAAsD;;;;IAAvC,cAAqC;IAArC,6DAAqC;;;;IAmClD,+BAQC;IACC,2BAKE;IACJ,iBAAM;;;;;IAaN,+BASC;IANC,qNAAS,kCAA2B,KAAC;IAOrC,2BAKE;IACJ,iBAAM;;;;IA7CR,+BAAoD;IAClD,uGAQC;IAQD,iCAWE;IAFA,AAFA,4NAAiB,kCAA2B,KAAC,yLAEpC,0BAAmB,IAAI,CAAC,KAAC;IATpC,iBAWE;IACF,uGASC;IAQH,iBAAM;;;IA5CD,cAA2B;IAA3B,mDAA2B;IAgB5B,cAAuB;IAOvB,AANA,AADA,4CAAuB,8MAKrB,iFAEgE;IAKjE,cAA0B;IAA1B,kDAA0B;;;IAkC3B,+BAA8C;IAC5C,0BAAmD;IACrD,iBAAM;;;IADc,cAAiB;IAAjB,oDAAiB;;;;IAjBvC,+BAOC;IAHC,AADA,gPAAe,2CAAiC,KAAC,uNACxC,2CAAiC,KAAC;IAKzC,AADF,+BAAwC,cACN;IAC9B,mCAAoE;IACtE,iBAAM;IACN,4BAAiB;IACf,YACF;IACF,AADE,iBAAI,EACA;IACN,kGAA8C;IAGhD,iBAAM;;;IAbJ,sEAAsC;IAIpB,eAAwB;IAAxB,yCAAwB;IAGtC,eACF;IADE,8CACF;IAE2B,cAAe;IAAf,mCAAe;;;IAI9C,+BAAgF;IAC9E,YACF;IAAA,iBAAM;;;IADJ,cACF;IADE,gGACF;;;;IAGF,AADF,+BAAkF,cACd;IAApB,oMAAS,gBAAS,KAAC;IAC/D,iCAA4E;IAC9E,iBAAM;IACN,+BAAuE;IAAzB,oMAAS,qBAAc,KAAC;IACpE,iCAA6E;IAEjF,AADE,iBAAM,EACF;;IANC,cAAwC;IAAxC,oDAAwC;IAC/B,cAAgB;IAAiB,AAAhB,AAAjB,8BAAgB,gBAAgB,iBAAiB;IAE1D,cAAwC;IAAxC,oDAAwC;IAC/B,cAAgB;IAAkB,AAAjB,AAAjB,8BAAgB,iBAAiB,iBAAiB;;;IAxFpE,+BAUC;IACG,4FAAoD;IA+CpD,+BAAmB;IAqBjB,AApBA,4FAOC,+EAa+E;IAGlF,iBAAM;IACR,6FAAkF;IAQpF,iBAAM;;;IArFJ,AAJA,yGAGE,wHAIA;IAEM,cAAmB;IAAnB,2CAAmB;IAqDJ,eAAuC;IAAvC,mFAAuC;IAerC,cAAyD;IAAzD,+FAAyD;IAI5E,cAAgD;IAAhD,+EAAgD;;ADzH1D,MAAM,OAAO,4BAA4B;IAQvC,IAAa,IAAI,CAAC,MAAiC;QACjD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACjC,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IAcD,IAAa,aAAa,CAAC,MAAiC;QAC1D,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAUD,YAAoB,IAAgB,EAAU,OAAgB,EAAU,gBAAkC,EAAU,MAAc;QAA9G,SAAI,GAAJ,IAAI,CAAY;QAAU,YAAO,GAAP,OAAO,CAAS;QAAU,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAU,WAAM,GAAN,MAAM,CAAQ;QArClI,gBAAW,GAAW,EAAE,CAAC;QACzB,WAAM,GAAG,KAAK,CAAC;QACf,uBAAkB,GAA8B,EAAE,CAAC;QACnD,cAAS,GAA8B,EAAE,CAAC;QAC1C,eAAU,GAA8B,EAAE,CAAC;QAC3C,yBAAoB,GAAY,KAAK,CAAC;QACtC,oBAAe,GAAG,oBAAoB,CAAC;QAM9B,UAAK,GAAW,QAAQ,CAAC;QACzB,WAAM,GAAW,EAAE,CAAC;QACpB,UAAK,GAAW,EAAE,CAAC;QACnB,uBAAkB,GAAW,EAAE,CAAC;QAChC,sBAAiB,GAAW,EAAE,CAAC;QAC/B,yBAAoB,GAAqB,MAAM,CAAC;QAChD,oBAAe,GAAY,KAAK,CAAC;QACjC,kBAAa,GAAY,IAAI,CAAC;QAC9B,sBAAiB,GAAY,KAAK,CAAC;QACnC,kBAAa,GAAW,SAAS,CAAC;QAClC,YAAO,GAAY;YAC1B,UAAU,EAAE,IAAI;SACjB,CAAC;QAIO,oBAAe,GAAY,KAAK,CAAC;QACjC,2BAAsB,GAAW,gBAAgB,CAAC;QAEjD,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;IAM0E,CAAC;IACtI,QAAQ,KAAI,CAAC;IAEb,4BAA4B,CAAC,MAAM;QACjC,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACzC,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,IAAK,MAAM,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS,CAAC,MAAM,GAAC,CAAC,EAAE,CAAC;gBACtF,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YACpC,CAAC;YACD,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBACnD,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,IAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,eAAe,EAAC,CAAC;oBAC/D,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;gBACrC,CAAC;qBAAI,CAAC;oBACF,OAAO,IAAI,CAAC;gBAChB,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACrD,CAAC;IAED,kBAAkB,CAAC,SAAkB;QACnC,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC;IACxC,CAAC;IAED,mBAAmB,CAAC,KAAK;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;IACpC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACnB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBAC3D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACrD,CAAC;YACD,IAAI,IAAI,CAAC,MAAM;gBAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;;gBACrF,IAAI,CAAC,QAAQ,EAAE,CAAC;QACvB,CAAC,CAAC,CAAA;IACJ,CAAC;IAEO,YAAY,CAAC,QAA8B,EAAE,MAAmB;QACtE,MAAM,eAAe,GAAG;YACtB,IAAI,sBAAsB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;YACjH,IAAI,sBAAsB,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;SAC9G,CAAC;QACF,MAAM,YAAY,GAAG;YACnB,IAAI,sBAAsB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAClH,IAAI,sBAAsB,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;SAC/G,CAAC;QACF,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO;aAClC,QAAQ,EAAE;aACV,mBAAmB,CAAC,MAAM,CAAC;aAC3B,aAAa,CAAC;YACb,GAAG,CAAC,IAAI,CAAC,oBAAoB,KAAK,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC;YACxF,GAAG,CAAC,IAAI,CAAC,oBAAoB,KAAK,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC;SACnF,CAAC;aACD,QAAQ,CAAC,IAAI,CAAC,CAAC;QAClB,MAAM,OAAO,GAAG,IAAI,aAAa,CAAC;YAChC,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;YACjD,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC1D,gBAAgB;YAChB,KAAK,EAAE,MAAM,CAAC,WAAW;SAC1B,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,IAAI,CAAC,iBAAiB;YAAE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QAC1F,IAAI,IAAI,CAAC,kBAAkB;YAAE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAC7F,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAC9C,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAgC,EAAE,MAAc;QAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IACjF,CAAC;IAED,mBAAmB,CAAC,QAAQ;QAC1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC5B,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACjE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IAED,YAAY,CAAC,KAAgC;QAC3C,IAAI,WAAW,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;YAC5B,MAAM,aAAa,GAAG,KAAK;iBACxB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;iBACtB,IAAI,CAAC,CAAC,CAA0B,EAAE,CAA0B,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1H,MAAM,eAAe,GAAG,KAAK;iBAC1B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;iBACvB,IAAI,CAAC,CAAC,CAA0B,EAAE,CAA0B,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1H,WAAW,GAAG,CAAC,GAAG,aAAa,EAAE,GAAG,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC,CAAC;QACrG,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,eAAe,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzH,WAAW,CAAC,OAAO,CAAC;gBAClB,KAAK,EAAE,YAAY;gBACnB,KAAK,EAAE,IAAI,CAAC,eAAe;gBAC3B,OAAO,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;aAC3C,CAAC,CAAC;QACL,CAAC;QACD,OAAO,WAAW,CAAC;IACrB,CAAC;IAED,mBAAmB,CAAC,KAAK,EAAE,IAA6B;QACtD,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC;YAChE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACxC,GAAG,CAAC;gBACJ,OAAO,EAAE,CAAC,IAAI,CAAC,OAAO;aACvB,CAAC,CAAC,CAAC;YACJ,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACzB,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,CAAC;YACD,OAAO;QACT,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,SAAS,GAAG;gBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACxB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC;wBAC/D,OAAO;4BACL,GAAG,CAAC;4BACJ,OAAO,EAAE,KAAK;yBACf,CAAC;oBACJ,CAAC;oBACD,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC;aACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG;gBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACxB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;wBAC3B,OAAO;4BACL,GAAG,CAAC;4BACJ,OAAO,EAAE,IAAI;yBACd,CAAC;oBACJ,CAAC;oBACD,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC;aACH,CAAC;YACF,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC/G,IAAI,CAAC,SAAS,GAAG;oBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;wBACxB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC;4BACrC,OAAO;gCACL,GAAG,CAAC;gCACJ,OAAO,EAAE,IAAI;6BACd,CAAC;wBACJ,CAAC;wBACD,OAAO,CAAC,CAAC;oBACX,CAAC,CAAC;iBACH,CAAC;YACJ,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,CAAC,SAAS;aACX,MAAM,CAAC,CAAC,CAAC,EAAE;YACV,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC;QACvD,CAAC,CAAC;aACD,GAAG,CAAC,IAAI,CAAC,EAAE;YACV,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,IAAI,CAAC;YAClC,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CACL,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YACtC,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;gBACtG,OAAO,CAAC,CAAC;YACX,CAAC;iBAAM,CAAC;gBACN,IAAG,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,EAAC,CAAC;oBAC3D,OAAO;wBACL,GAAG,CAAC;wBACJ,OAAO,EAAE,KAAK;qBACf,CAAC;gBACJ,CAAC;gBACD,OAAO,CAAC,CAAC;YACX,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC;QAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;6HA1PU,4BAA4B;oEAA5B,4BAA4B;;;;;;;;;YCDvC,AAPF,8BAMC,gBAQE;YAFC,AADA,wJAAe,oBAAgB,KAAC,+HACvB,oBAAgB,KAAC;YAG1B,8BAAmB;YAOnB,AANE,+FAA2C,kFAMH;YAI1C,iBAAM;;YACN,8BAQC;YACC,0BAKE;YAGR,AADE,AADE,iBAAM,EACF,EACF;YACN,+HAA6B;;YA3C3B,oIAGE;YAQA,cAAmD;YAAnD,iFAAmD;YAGlC,eAA0B;YAA1B,+CAA0B;YAM5B,cAAyB;YAAzB,8CAAyB;YAOtC,cAAqE;YAArE,qGAAqE;;;iFDrB9D,4BAA4B;cALxC,SAAS;2BACE,2BAA2B;qHAYxB,IAAI;kBAAhB,KAAK;YAKG,KAAK;kBAAb,KAAK;YACG,MAAM;kBAAd,KAAK;YACG,KAAK;kBAAb,KAAK;YACG,kBAAkB;kBAA1B,KAAK;YACG,iBAAiB;kBAAzB,KAAK;YACG,oBAAoB;kBAA5B,KAAK;YACG,eAAe;kBAAvB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,iBAAiB;kBAAzB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,OAAO;kBAAf,KAAK;YAGO,aAAa;kBAAzB,KAAK;YAGG,eAAe;kBAAvB,KAAK;YACG,sBAAsB;kBAA9B,KAAK;YACG,mBAAmB;kBAA3B,KAAK;YACI,QAAQ;kBAAjB,MAAM;YAEiC,aAAa;kBAApD,SAAS;mBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACU,cAAc;kBAA7D,SAAS;mBAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;;kFAnCnC,4BAA4B","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, NgZone, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef } from \"@angular/core\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { OverlayRef, Overlay, ConnectionPositionPair, OverlayConfig } from \"@angular/cdk/overlay\";\n@Component({\n  selector: \"mis-multi-select-dropdown\",\n  templateUrl: \"./multi-select-dropdown.component.html\",\n  styleUrls: [\"./multi-select-dropdown.component.scss\"]\n})\nexport class MultiSelectDropdownComponent implements OnInit {\n  searchInput: string = \"\";\n  isOpen = false;\n  localSelectedItems: MultiSelectDropdownItem[] = [];\n  localData: MultiSelectDropdownItem[] = [];\n  searchData: MultiSelectDropdownItem[] = [];\n  isSearchInputFocused: boolean = false;\n  SELECT_ALL_ENUM = \"SELECT_ALL_ENABLED\";\n  @Input() set data(values: MultiSelectDropdownItem[]) {\n    this.localData = values.map(item => {\n      return { ...item, checked: false };\n    });\n  }\n  @Input() label: string = \"Select\";\n  @Input() height: string = \"\";\n  @Input() width: string = \"\";\n  @Input() dropdownListHeight: string = \"\";\n  @Input() dropdownListWidth: string = \"\";\n  @Input() dropdownListPosition: \"Left\" | \"Right\" = \"Left\";\n  @Input() enableSelectAll: boolean = false;\n  @Input() searchEnabled: boolean = true;\n  @Input() showSelectedCount: boolean = false;\n  @Input() noDataMessage: string = \"No Data\";\n  @Input() options: OPTIONS = {\n    sortLabels: true\n  };\n  @Input() set selectedItems(values: MultiSelectDropdownItem[]) {\n    this.handlerSetLocalSelectedItems(values);\n  }\n  @Input() hideApplyButton: boolean = false;\n  @Input() searchInputPlaceholder: string = \"Search Keyword\";\n  @Input() customLabelTemplate : TemplateRef<any>;\n  @Output() onChange: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild(\"select\", { static: false }) selectElement: ElementRef;\n  @ViewChild(\"popupContainer\", { static: false }) popupContainer: TemplateRef<Element>;\n  private overlayRef: OverlayRef;\n\n  constructor(private eRef: ElementRef, private overlay: Overlay, private viewContainerRef: ViewContainerRef, private ngZone: NgZone) {}\n  ngOnInit() {}\n\n  handlerSetLocalSelectedItems(values) {\n    this.localSelectedItems = values;\n    this.localData = this.localData.map(item => {\n      if (item.value === this.SELECT_ALL_ENUM  && values.length === this.localData.length-1) {\n        return { ...item, checked: true };\n      }\n      if (values.some(base => base.value === item.value)) {\n        return { ...item, checked: true };\n      } else {\n        if(item.value !== this.SELECT_ALL_ENUM || !this.hideApplyButton){\n          return { ...item, checked: false };\n        }else{\n            return item;\n        }\n      }\n    });\n    this.localData = this.formatValues(this.localData);\n  }\n\n  searchInputFocused(isFocused: boolean) {\n    this.isSearchInputFocused = isFocused;\n  }\n\n  searchInputCanceled(event) {\n    event.stopPropagation();\n    this.searchInput = \"\";\n    this.isSearchInputFocused = false;\n  }\n\n  toggleDropdown() {\n    this.ngZone.run(() => {\n      this.isOpen = !this.isOpen;\n      if (this.isOpen) {\n        this.handlerSetLocalSelectedItems(this.localSelectedItems);\n        this.localData = this.formatValues(this.localData);\n      }\n      if (this.isOpen) this.openDropdown(this.popupContainer, this.selectElement.nativeElement);\n      else this.onCancel();\n    })\n  }\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement): void {\n    const positionsBottom = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"bottom\" }, { overlayX: \"start\", overlayY: \"top\" }, 0, 4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"bottom\" }, { overlayX: \"end\", overlayY: \"top\" }, 0, 4)\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"top\" }, { overlayX: \"start\", overlayY: \"bottom\" }, 0, -4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"top\" }, { overlayX: \"end\", overlayY: \"bottom\" }, 0, -4)\n    ];\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition === \"Right\" ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition === \"Right\" ? positionsTop.reverse() : positionsTop)\n      ])\n      .withPush(true);\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: \"cdk-overlay-transparent-backdrop\",\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin.clientWidth\n    });\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth) this.overlayRef.updateSize({ width: this.dropdownListWidth });\n    if (this.dropdownListHeight) this.overlayRef.updateSize({ height: this.dropdownListHeight });\n    this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef.backdropClick().subscribe(res => {\n      this.onCancel();\n    });\n  }\n\n  filterByValue(array: MultiSelectDropdownItem[], string: string) {\n    return array.filter(o => o.label.toLowerCase().includes(string.toLowerCase()));\n  }\n\n  searchInputOnChange(newValue) {\n    this.searchInput = newValue;\n    if (newValue) {\n      this.searchData = this.filterByValue(this.localData, newValue);\n    } else {\n      this.searchData = [];\n      this.searchInput = \"\";\n    }\n  }\n\n  formatValues(array: MultiSelectDropdownItem[]) {\n    let sortedArray = array;\n    if (this.options.sortLabels) {\n      const checkedValues = array\n        .filter(a => a.checked)\n        .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));\n      const unCheckedValues = array\n        .filter(a => !a.checked)\n        .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));\n      sortedArray = [...checkedValues, ...unCheckedValues].filter(t => t.value !== this.SELECT_ALL_ENUM);\n    }\n    if (!sortedArray.some(option => option.value === this.SELECT_ALL_ENUM) && this.enableSelectAll && sortedArray.length > 0) {\n      sortedArray.unshift({\n        label: \"Select all\",\n        value: this.SELECT_ALL_ENUM,\n        checked: sortedArray.every(y => y.checked)\n      });\n    }\n    return sortedArray;\n  }\n\n  toggleSelectedItems(event, item: MultiSelectDropdownItem) {\n    event.stopPropagation();\n    if (this.enableSelectAll && item.value === this.SELECT_ALL_ENUM) {\n      this.localData = this.localData.map(t => ({\n        ...t,\n        checked: !item.checked\n      }));\n      if (this.hideApplyButton) {\n        this.applyFilters();\n      }\n      return;\n    }\n    if (item.checked) {\n      this.localData = [\n        ...this.localData.map(a => {\n          if (a.value === item.value || a.value === this.SELECT_ALL_ENUM) {\n            return {\n              ...a,\n              checked: false\n            };\n          }\n          return a;\n        })\n      ];\n    } else {\n      this.localData = [\n        ...this.localData.map(a => {\n          if (a.value === item.value) {\n            return {\n              ...a,\n              checked: true\n            };\n          }\n          return a;\n        })\n      ];\n      if (this.enableSelectAll && this.localData.filter(r => r.value !== this.SELECT_ALL_ENUM).every(t => t.checked)) {\n        this.localData = [\n          ...this.localData.map(a => {\n            if (a.value === this.SELECT_ALL_ENUM) {\n              return {\n                ...a,\n                checked: true\n              };\n            }\n            return a;\n          })\n        ];\n      }\n    }\n    if (this.searchEnabled) {\n      this.searchInputOnChange(this.searchInput);\n    }\n    if (this.hideApplyButton) {\n      this.applyFilters();\n    }\n  }\n\n  applyFilters() {\n    this.onChange.emit(\n      this.localData\n        .filter(a => {\n          return a.checked && a.value !== this.SELECT_ALL_ENUM;\n        })\n        .map(item => {\n          const { checked, ...data } = item;\n          return data;\n        })\n    );\n    if (!this.hideApplyButton) {\n      this.onCancel();\n    }\n  }\n\n  onReset() {\n    this.isSearchInputFocused = false;\n    this.onChange.emit([]);\n    this.isOpen = false;\n    this.searchInput = \"\";\n  }\n\n  onCancel() {\n    this.isSearchInputFocused = false;\n    this.localData = this.localData.map(a => {\n      if (this.localSelectedItems.some(b => b.value === a.value && String(b.checked) !== String(a.checked))) {\n        return a;\n      } else {\n        if(a.value !== this.SELECT_ALL_ENUM && this.hideApplyButton){\n          return {\n            ...a,\n            checked: false\n          };\n        }\n        return a;\n      }\n    });\n    this.isOpen = false;\n    this.searchInput = \"\";\n    this.overlayRef?.detach();\n    this.searchInput = \"\";\n  }\n}\nexport interface MultiSelectDropdownItem {\n  label: string;\n  value: string;\n  checked?: boolean;\n  icon?: string;\n  disabled?:boolean\n}\nexport interface OPTIONS {\n  sortLabels: boolean;\n}\n","<div\n  class=\"container\"\n  [ngStyle]=\"{\n    height: height.length > 0 ? height : '',\n    width: width.length > 0 ? width : ''\n  }\"\n>\n  <div\n    class=\"dropdown\"\n    #select\n    tabindex=\"0\"\n    (keyup.enter)=\"toggleDropdown()\"\n    (click)=\"toggleDropdown()\"\n    [ngStyle]=\"{ background: isOpen ? '#E6EBF7' : '' }\"\n  >\n    <div class=\"label\">\n      <ng-container *ngIf=\"!customLabelTemplate\">\n      <p class=\"text\">{{ label }}</p>\n      <p *ngIf=\"showSelectedCount && localSelectedItems?.length > 0\" class=\"count\">\n        {{ localSelectedItems?.length }}\n      </p>\n    </ng-container>\n    <ng-container *ngIf=\"customLabelTemplate\">\n      <ng-container *ngTemplateOutlet=\"customLabelTemplate\">\n      </ng-container>\n    </ng-container>\n    </div>\n    <svg\n      class=\"handle\"\n      [ngStyle]=\"{ transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)' }\"\n      width=\"20\"\n      height=\"20\"\n      viewBox=\"0 0 20 20\"\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.825 7.15845L10 10.9751L6.175 7.15845L5 8.33345L10 13.3334L15 8.33345L13.825 7.15845Z\"\n        fill=\"#181F33\"\n      />\n    </svg>\n  </div>\n</div>\n<ng-template #popupContainer>\n  <div\n    class=\"popup-container\"\n    [ngStyle]=\"{\n      'height': dropdownListHeight,\n      width: dropdownListWidth\n    }\"\n    [ngClass]=\"{\n      'position-left': dropdownListPosition === 'Left',\n      'position-right': dropdownListPosition === 'Right'\n    }\"\n  >\n      <div *ngIf=\"searchEnabled\" class=\"search-container\">\n        <svg\n          *ngIf=\"!isSearchInputFocused\"\n          class=\"search-icon\"\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=\"M4.21508 11.1456C4.21508 7.3179 7.33722 4.21165 11.1926 4.21165C15.048 4.21165 18.1702 7.3179 18.1702 11.1456C18.1702 12.6931 17.6599 14.1226 16.7972 15.2767L15.3685 16.7013C14.2044 17.5668 12.759 18.0796 11.1926 18.0796C7.33722 18.0796 4.21508 14.9734 4.21508 11.1456ZM15.9421 17.7835C14.6021 18.7329 12.9627 19.2913 11.1926 19.2913C6.66977 19.2913 3 15.6461 3 11.1456C3 6.64512 6.66977 3 11.1926 3C15.7155 3 19.3852 6.64512 19.3852 11.1456C19.3852 12.9371 18.8037 14.5931 17.8184 15.9375L19.8361 17.4048C20.6705 17.912 21.7554 18.6543 20.2454 20.215C18.7353 21.7756 18.0099 20.6663 17.4991 19.8364L15.9421 17.7835Z\"\n            fill=\"#6A737D\"\n          />\n        </svg>\n        <input\n          [ngModel]=\"searchInput\"\n          [ngStyle]=\"{\n            paddingLeft: isSearchInputFocused ? '12px' : '45px',\n            border: isSearchInputFocused ? '1px solid #0937B2' : '1px solid #e0e0e0',\n            paddingRight: isSearchInputFocused ? '45px' : '10px'\n          }\"\n          (ngModelChange)=\"searchInputOnChange($event)\"\n          [placeholder]=\"isSearchInputFocused ? '' : searchInputPlaceholder\"\n          (focus)=\"searchInputFocused(true)\"\n          class=\"search-input\"\n        />\n        <svg\n          *ngIf=\"isSearchInputFocused\"\n          class=\"cancel-icon\"\n          (click)=\"searchInputCanceled($event)\"\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=\"M8.87446 7.32144C8.44588 6.89285 7.751 6.89285 7.32242 7.32144C6.89383 7.75002 6.89383 8.4449 7.32242 8.87349L10.4488 11.9999L7.32357 15.1252C6.89498 15.5538 6.89498 16.2486 7.32357 16.6772C7.75215 17.1058 8.44703 17.1058 8.87561 16.6772L12.0009 13.552L15.1261 16.6772C15.5547 17.1058 16.2496 17.1058 16.6781 16.6772C17.1067 16.2486 17.1067 15.5537 16.6781 15.1251L13.5529 11.9999L16.6793 8.87354C17.1079 8.44496 17.1079 7.75008 16.6793 7.3215C16.2507 6.89291 15.5558 6.89291 15.1273 7.3215L12.0009 10.4479L8.87446 7.32144Z\"\n            fill=\"#6A737D\"\n          />\n        </svg>\n      </div>\n      <div class=\"items\">\n        <div\n          class=\"item\"\n          tabindex=\"0\"\n          (keyup.enter)=\"toggleSelectedItems($event, item)\"\n          (click)=\"toggleSelectedItems($event, item)\"\n          *ngFor=\"let item of searchInput ? searchData : localData\"\n          [ngClass]=\"{'disabled':item.disabled}\"\n        >\n          <div class=\"checkbox-container-wrapper\">\n            <div class=\"checkbox-container\">\n              <mis-checkbox [checked]=\"item.checked\" tabindex=\"-1\"></mis-checkbox>\n            </div>\n            <p class=\"label\">\n              {{ item.label }}\n            </p>\n          </div>\n          <div class=\"icon-container\" *ngIf=\"item.icon\">\n            <img class=\"icon\" [src]=\"item.icon\" alt=\"no img\" />\n          </div>\n        </div>\n        <div class=\"noData\" *ngIf=\"(searchInput ? searchData : localData).length === 0\">\n          {{ searchInput === \"\" ? noDataMessage : \"No results\" }}\n        </div>\n      </div>\n    <div *ngIf=\"localData.length !== 0 && !hideApplyButton\" class=\"actions-container\">\n      <div [ngStyle]=\"{'width': 'calc(50% - 4px)'}\" (click)=\"onReset()\">\n        <mis-button [name]=\"'Reset'\" [type]=\"'Text'\" [width]=\"'100%'\" ></mis-button>\n      </div>\n      <div [ngStyle]=\"{'width': 'calc(50% - 4px)'}\" (click)=\"applyFilters()\">\n        <mis-button [name]=\"'Apply'\" [type]=\"'Solid'\" [width]=\"'100%'\" ></mis-button>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
489
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-dropdown.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.ts","../../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, NgZone, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef } from \"@angular/core\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { OverlayRef, Overlay, ConnectionPositionPair, OverlayConfig } from \"@angular/cdk/overlay\";\n@Component({\n  selector: \"mis-multi-select-dropdown\",\n  templateUrl: \"./multi-select-dropdown.component.html\",\n  styleUrls: [\"./multi-select-dropdown.component.scss\"]\n})\nexport class MultiSelectDropdownComponent implements OnInit {\n  searchInput: string = \"\";\n  isOpen = false;\n  localSelectedItems: MultiSelectDropdownItem[] = [];\n  localData: MultiSelectDropdownItem[] = [];\n  searchData: MultiSelectDropdownItem[] = [];\n  isSearchInputFocused: boolean = false;\n  SELECT_ALL_ENUM = \"SELECT_ALL_ENABLED\";\n  @Input() set data(values: MultiSelectDropdownItem[]) {\n    this.localData = values?.map(item => {\n      return { ...item, checked: false };\n    }) || [];\n  }\n  @Input() label: string = \"Select\";\n  @Input() height: string = \"\";\n  @Input() width: string = \"\";\n  @Input() dropdownListHeight: string = \"\";\n  @Input() dropdownListWidth: string = \"\";\n  @Input() dropdownListPosition: \"Left\" | \"Right\" = \"Left\";\n  @Input() enableSelectAll: boolean = false;\n  @Input() searchEnabled: boolean = true;\n  @Input() showSelectedCount: boolean = false;\n  @Input() noDataMessage: string = \"No Data\";\n  @Input() options: OPTIONS = {\n    sortLabels: true\n  };\n  @Input() set selectedItems(values: MultiSelectDropdownItem[]) {\n    this.handlerSetLocalSelectedItems(values);\n  }\n  @Input() hideApplyButton: boolean = false;\n  @Input() searchInputPlaceholder: string = \"Search Keyword\";\n  @Input() customLabelTemplate : TemplateRef<any>;\n  @Output() onChange: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild(\"select\", { static: false }) selectElement: ElementRef;\n  @ViewChild(\"popupContainer\", { static: false }) popupContainer: TemplateRef<Element>;\n  private overlayRef: OverlayRef;\n\n  constructor(private eRef: ElementRef, private overlay: Overlay, private viewContainerRef: ViewContainerRef, private ngZone: NgZone) {}\n  ngOnInit() {}\n\n  handlerSetLocalSelectedItems(values) {\n    this.localSelectedItems = values || [];\n    this.localData = this.localData?.map(item => {\n      if (item?.value === this.SELECT_ALL_ENUM  && values?.length === this.localData?.length-1) {\n        return { ...item, checked: true };\n      }\n      if (values?.some(base => base?.value === item?.value)) {\n        return { ...item, checked: true };\n      } else {\n        if(item?.value !== this.SELECT_ALL_ENUM || !this.hideApplyButton){\n          return { ...item, checked: false };\n        }else{\n            return item;\n        }\n      }\n    }) || [];\n    this.localData = this.formatValues(this.localData);\n  }\n\n  searchInputFocused(isFocused: boolean) {\n    this.isSearchInputFocused = isFocused;\n  }\n\n  searchInputCanceled(event) {\n    event?.stopPropagation();\n    this.searchInput = \"\";\n    this.isSearchInputFocused = false;\n  }\n\n  toggleDropdown() {\n    this.ngZone.run(() => {\n      this.isOpen = !this.isOpen;\n      if (this.isOpen) {\n        this.handlerSetLocalSelectedItems(this.localSelectedItems);\n        this.localData = this.formatValues(this.localData);\n      }\n      if (this.isOpen) this.openDropdown(this.popupContainer, this.selectElement?.nativeElement);\n      else this.onCancel();\n    })\n  }\n\n  private openDropdown(template: TemplateRef<Element>, origin: HTMLElement): void {\n    const positionsBottom = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"bottom\" }, { overlayX: \"start\", overlayY: \"top\" }, 0, 4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"bottom\" }, { overlayX: \"end\", overlayY: \"top\" }, 0, 4)\n    ];\n    const positionsTop = [\n      new ConnectionPositionPair({ originX: \"start\", originY: \"top\" }, { overlayX: \"start\", overlayY: \"bottom\" }, 0, -4),\n      new ConnectionPositionPair({ originX: \"end\", originY: \"top\" }, { overlayX: \"end\", overlayY: \"bottom\" }, 0, -4)\n    ];\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(origin)\n      .withPositions([\n        ...(this.dropdownListPosition === \"Right\" ? positionsBottom.reverse() : positionsBottom),\n        ...(this.dropdownListPosition === \"Right\" ? positionsTop.reverse() : positionsTop)\n      ])\n      .withPush(true);\n    const configs = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: \"cdk-overlay-transparent-backdrop\",\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n      positionStrategy,\n      width: origin?.clientWidth\n    });\n    this.overlayRef = this.overlay.create(configs);\n    if (this.dropdownListWidth) this.overlayRef?.updateSize({ width: this.dropdownListWidth });\n    if (this.dropdownListHeight) this.overlayRef?.updateSize({ height: this.dropdownListHeight });\n    this.overlayRef?.attach(new TemplatePortal(template, this.viewContainerRef));\n    this.overlayRef?.backdropClick()?.subscribe(res => {\n      this.onCancel();\n    });\n  }\n\n  filterByValue(array: MultiSelectDropdownItem[], string: string) {\n    return array?.filter(o => o?.label?.toLowerCase()?.includes(string?.toLowerCase())) || [];\n  }\n\n  searchInputOnChange(newValue) {\n    this.searchInput = newValue;\n    if (newValue) {\n      this.searchData = this.filterByValue(this.localData, newValue);\n    } else {\n      this.searchData = [];\n      this.searchInput = \"\";\n    }\n  }\n\n  formatValues(array: MultiSelectDropdownItem[]) {\n    let sortedArray = array || [];\n    if (this.options?.sortLabels) {\n      const checkedValues = array\n        ?.filter(a => a?.checked)\n        ?.sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a?.label > b?.label ? 1 : b?.label > a?.label ? -1 : 0)) || [];\n      const unCheckedValues = array\n        ?.filter(a => !a?.checked)\n        ?.sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a?.label > b?.label ? 1 : b?.label > a?.label ? -1 : 0)) || [];\n      sortedArray = [...checkedValues, ...unCheckedValues]?.filter(t => t?.value !== this.SELECT_ALL_ENUM) || [];\n    }\n    if (!sortedArray?.some(option => option?.value === this.SELECT_ALL_ENUM) && this.enableSelectAll && sortedArray?.length > 0) {\n      sortedArray?.unshift({\n        label: \"Select all\",\n        value: this.SELECT_ALL_ENUM,\n        checked: sortedArray?.every(y => y?.checked)\n      });\n    }\n    return sortedArray;\n  }\n\n  toggleSelectedItems(event, item: MultiSelectDropdownItem) {\n    event?.stopPropagation();\n    if (this.enableSelectAll && item?.value === this.SELECT_ALL_ENUM) {\n      this.localData = this.localData?.map(t => ({\n        ...t,\n        checked: !item?.checked\n      })) || [];\n      if (this.hideApplyButton) {\n        this.applyFilters();\n      }\n      return;\n    }\n    if (item?.checked) {\n      this.localData = [\n        ...this.localData?.map(a => {\n          if (a?.value === item?.value || a?.value === this.SELECT_ALL_ENUM) {\n            return {\n              ...a,\n              checked: false\n            };\n          }\n          return a;\n        }) || []\n      ];\n    } else {\n      this.localData = [\n        ...this.localData?.map(a => {\n          if (a?.value === item?.value) {\n            return {\n              ...a,\n              checked: true\n            };\n          }\n          return a;\n        }) || []\n      ];\n      if (this.enableSelectAll && this.localData?.filter(r => r?.value !== this.SELECT_ALL_ENUM)?.every(t => t?.checked)) {\n        this.localData = [\n          ...this.localData?.map(a => {\n            if (a?.value === this.SELECT_ALL_ENUM) {\n              return {\n                ...a,\n                checked: true\n              };\n            }\n            return a;\n          }) || []\n        ];\n      }\n    }\n    if (this.searchEnabled) {\n      this.searchInputOnChange(this.searchInput);\n    }\n    if (this.hideApplyButton) {\n      this.applyFilters();\n    }\n  }\n\n  applyFilters() {\n    this.onChange?.emit(\n      this.localData\n        ?.filter(a => {\n          return a?.checked && a?.value !== this.SELECT_ALL_ENUM;\n        })\n        ?.map(item => {\n          const { checked, ...data } = item || {};\n          return data;\n        }) || []\n    );\n    if (!this.hideApplyButton) {\n      this.onCancel();\n    }\n  }\n\n  onReset() {\n    this.isSearchInputFocused = false;\n    this.onChange?.emit([]);\n    this.isOpen = false;\n    this.searchInput = \"\";\n  }\n\n  onCancel() {\n    this.isSearchInputFocused = false;\n    this.localData = this.localData?.map(a => {\n      if (this.localSelectedItems?.some(b => b?.value === a?.value && String(b?.checked) !== String(a?.checked))) {\n        return a;\n      } else {\n        if(a?.value !== this.SELECT_ALL_ENUM && this.hideApplyButton){\n          return {\n            ...a,\n            checked: false\n          };\n        }\n        return a;\n      }\n    }) || [];\n    this.isOpen = false;\n    this.searchInput = \"\";\n    this.overlayRef?.detach();\n    this.searchInput = \"\";\n  }\n}\nexport interface MultiSelectDropdownItem {\n  label: string;\n  value: string;\n  checked?: boolean;\n  icon?: string;\n  disabled?:boolean\n}\nexport interface OPTIONS {\n  sortLabels: boolean;\n}\n","<div\n  class=\"container\"\n  [ngStyle]=\"{\n    height: height.length > 0 ? height : '',\n    width: width.length > 0 ? width : ''\n  }\"\n>\n  <div\n    class=\"dropdown\"\n    #select\n    tabindex=\"0\"\n    (keyup.enter)=\"toggleDropdown()\"\n    (click)=\"toggleDropdown()\"\n    [ngStyle]=\"{ background: isOpen ? '#E6EBF7' : '' }\"\n  >\n    <div class=\"label\">\n      <ng-container *ngIf=\"!customLabelTemplate\">\n      <p class=\"text\">{{ label }}</p>\n      <p *ngIf=\"showSelectedCount && localSelectedItems?.length > 0\" class=\"count\">\n        {{ localSelectedItems?.length }}\n      </p>\n    </ng-container>\n    <ng-container *ngIf=\"customLabelTemplate\">\n      <ng-container *ngTemplateOutlet=\"customLabelTemplate\">\n      </ng-container>\n    </ng-container>\n    </div>\n    <svg\n      class=\"handle\"\n      [ngStyle]=\"{ transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)' }\"\n      width=\"20\"\n      height=\"20\"\n      viewBox=\"0 0 20 20\"\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.825 7.15845L10 10.9751L6.175 7.15845L5 8.33345L10 13.3334L15 8.33345L13.825 7.15845Z\"\n        fill=\"#181F33\"\n      />\n    </svg>\n  </div>\n</div>\n<ng-template #popupContainer>\n  <div\n    class=\"popup-container\"\n    [ngStyle]=\"{\n      'height': dropdownListHeight,\n      width: dropdownListWidth\n    }\"\n    [ngClass]=\"{\n      'position-left': dropdownListPosition === 'Left',\n      'position-right': dropdownListPosition === 'Right'\n    }\"\n  >\n      <div *ngIf=\"searchEnabled\" class=\"search-container\">\n        <svg\n          *ngIf=\"!isSearchInputFocused\"\n          class=\"search-icon\"\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=\"M4.21508 11.1456C4.21508 7.3179 7.33722 4.21165 11.1926 4.21165C15.048 4.21165 18.1702 7.3179 18.1702 11.1456C18.1702 12.6931 17.6599 14.1226 16.7972 15.2767L15.3685 16.7013C14.2044 17.5668 12.759 18.0796 11.1926 18.0796C7.33722 18.0796 4.21508 14.9734 4.21508 11.1456ZM15.9421 17.7835C14.6021 18.7329 12.9627 19.2913 11.1926 19.2913C6.66977 19.2913 3 15.6461 3 11.1456C3 6.64512 6.66977 3 11.1926 3C15.7155 3 19.3852 6.64512 19.3852 11.1456C19.3852 12.9371 18.8037 14.5931 17.8184 15.9375L19.8361 17.4048C20.6705 17.912 21.7554 18.6543 20.2454 20.215C18.7353 21.7756 18.0099 20.6663 17.4991 19.8364L15.9421 17.7835Z\"\n            fill=\"#6A737D\"\n          />\n        </svg>\n        <input\n          [ngModel]=\"searchInput\"\n          [ngStyle]=\"{\n            paddingLeft: isSearchInputFocused ? '12px' : '45px',\n            border: isSearchInputFocused ? '1px solid #0937B2' : '1px solid #e0e0e0',\n            paddingRight: isSearchInputFocused ? '45px' : '10px'\n          }\"\n          (ngModelChange)=\"searchInputOnChange($event)\"\n          [placeholder]=\"isSearchInputFocused ? '' : searchInputPlaceholder\"\n          (focus)=\"searchInputFocused(true)\"\n          class=\"search-input\"\n        />\n        <svg\n          *ngIf=\"isSearchInputFocused\"\n          class=\"cancel-icon\"\n          (click)=\"searchInputCanceled($event)\"\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=\"M8.87446 7.32144C8.44588 6.89285 7.751 6.89285 7.32242 7.32144C6.89383 7.75002 6.89383 8.4449 7.32242 8.87349L10.4488 11.9999L7.32357 15.1252C6.89498 15.5538 6.89498 16.2486 7.32357 16.6772C7.75215 17.1058 8.44703 17.1058 8.87561 16.6772L12.0009 13.552L15.1261 16.6772C15.5547 17.1058 16.2496 17.1058 16.6781 16.6772C17.1067 16.2486 17.1067 15.5537 16.6781 15.1251L13.5529 11.9999L16.6793 8.87354C17.1079 8.44496 17.1079 7.75008 16.6793 7.3215C16.2507 6.89291 15.5558 6.89291 15.1273 7.3215L12.0009 10.4479L8.87446 7.32144Z\"\n            fill=\"#6A737D\"\n          />\n        </svg>\n      </div>\n      <div class=\"items\">\n        <div\n          class=\"item\"\n          tabindex=\"0\"\n          (keyup.enter)=\"toggleSelectedItems($event, item)\"\n          (click)=\"toggleSelectedItems($event, item)\"\n          *ngFor=\"let item of searchInput ? searchData : localData\"\n          [ngClass]=\"{'disabled':item.disabled}\"\n        >\n          <div class=\"checkbox-container-wrapper\">\n            <div class=\"checkbox-container\">\n              <mis-checkbox [checked]=\"item.checked\" tabindex=\"-1\"></mis-checkbox>\n            </div>\n            <p class=\"label\">\n              {{ item.label }}\n            </p>\n          </div>\n          <div class=\"icon-container\" *ngIf=\"item.icon\">\n            <img class=\"icon\" [src]=\"item.icon\" alt=\"no img\" />\n          </div>\n        </div>\n        <div class=\"noData\" *ngIf=\"(searchInput ? searchData : localData).length === 0\">\n          {{ searchInput === \"\" ? noDataMessage : \"No results\" }}\n        </div>\n      </div>\n    <div *ngIf=\"localData.length !== 0 && !hideApplyButton\" class=\"actions-container\">\n      <div [ngStyle]=\"{'width': 'calc(50% - 4px)'}\" (click)=\"onReset()\">\n        <mis-button [name]=\"'Reset'\" [type]=\"'Text'\" [width]=\"'100%'\" ></mis-button>\n      </div>\n      <div [ngStyle]=\"{'width': 'calc(50% - 4px)'}\" (click)=\"applyFilters()\">\n        <mis-button [name]=\"'Apply'\" [type]=\"'Solid'\" [width]=\"'100%'\" ></mis-button>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -159,23 +159,32 @@ function ActionsCellComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
|
159
159
|
} if (rf & 2) {
|
|
160
160
|
const ctx_r2 = i0.ɵɵnextContext();
|
|
161
161
|
i0.ɵɵadvance();
|
|
162
|
-
i0.ɵɵproperty("checked", ctx_r2.isChecked);
|
|
162
|
+
i0.ɵɵproperty("checked", ctx_r2.isChecked)("disabled", ctx_r2.disable ? ctx_r2.disable(ctx_r2.data) : false);
|
|
163
163
|
} }
|
|
164
164
|
export class ActionsCellComponent {
|
|
165
165
|
constructor() {
|
|
166
166
|
this.isChecked = false;
|
|
167
|
+
this.actionClick = new EventEmitter();
|
|
168
|
+
this.dropdownToggled = new EventEmitter();
|
|
169
|
+
this.isDropdownOpen = false;
|
|
167
170
|
this.actionItems = [];
|
|
168
171
|
this.actionType = "inline";
|
|
169
172
|
this.submenuAlign = "right";
|
|
170
173
|
this.menuAlign = "left";
|
|
171
|
-
this.actionClick = new EventEmitter();
|
|
172
|
-
this.isDropdownOpen = false;
|
|
173
174
|
this._style = {};
|
|
174
175
|
this.containerStyle = {};
|
|
175
176
|
}
|
|
176
177
|
set rowData(value) {
|
|
177
|
-
this.
|
|
178
|
-
|
|
178
|
+
if (this.actionType === 'checkbox') {
|
|
179
|
+
// For checkbox, keep the rowData structure
|
|
180
|
+
this.data = value?.rowData ?? {};
|
|
181
|
+
this.isChecked = value?.isChecked ?? false;
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
// For other actions (dropdown, inline), use the value directly
|
|
185
|
+
this.data = value;
|
|
186
|
+
this.isChecked = false;
|
|
187
|
+
}
|
|
179
188
|
}
|
|
180
189
|
set config(config) {
|
|
181
190
|
this.actionItems = config?.actionItems,
|
|
@@ -184,6 +193,7 @@ export class ActionsCellComponent {
|
|
|
184
193
|
this.menuAlign = config.menuAlign;
|
|
185
194
|
this._style = config.style;
|
|
186
195
|
this.action = config.action;
|
|
196
|
+
this.disable = config.disable;
|
|
187
197
|
this.processStyle();
|
|
188
198
|
}
|
|
189
199
|
ngOnInit() { }
|
|
@@ -216,8 +226,19 @@ export class ActionsCellComponent {
|
|
|
216
226
|
this.isDropdownOpen = false;
|
|
217
227
|
}
|
|
218
228
|
}
|
|
229
|
+
// method to close dropdown
|
|
230
|
+
closeDropdown() {
|
|
231
|
+
if (this.isDropdownOpen) {
|
|
232
|
+
this.isDropdownOpen = false;
|
|
233
|
+
this.actionItems.forEach((item) => (item.showSubmenu = false));
|
|
234
|
+
}
|
|
235
|
+
}
|
|
219
236
|
toggleDropdown(event) {
|
|
220
237
|
event.stopPropagation();
|
|
238
|
+
// Emit self when opening dropdown
|
|
239
|
+
if (!this.isDropdownOpen) {
|
|
240
|
+
this.dropdownToggled.emit(this);
|
|
241
|
+
}
|
|
221
242
|
this.isDropdownOpen = !this.isDropdownOpen;
|
|
222
243
|
// Close all submenus when opening/closing main menu
|
|
223
244
|
this.actionItems.forEach((item) => (item.showSubmenu = false));
|
|
@@ -259,9 +280,9 @@ export class ActionsCellComponent {
|
|
|
259
280
|
static { this.ɵfac = function ActionsCellComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ActionsCellComponent)(); }; }
|
|
260
281
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ActionsCellComponent, selectors: [["mis-actions-cell"]], hostBindings: function ActionsCellComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
261
282
|
i0.ɵɵlistener("click", function ActionsCellComponent_click_HostBindingHandler() { return ctx.onDocumentClick(); }, false, i0.ɵɵresolveDocument);
|
|
262
|
-
} }, inputs: { rowData: "rowData", isChecked: "isChecked", config: "config" }, outputs: { actionClick: "actionClick" }, decls: 4, vars: 4, consts: [["noChildren", ""], [1, "actions-cell-container", 3, "ngStyle"], ["class", "inline-actions", 4, "ngIf"], ["class", "dropdown-actions", 4, "ngIf"], ["class", "checkbox-actions", 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"], ["class", "dropdown-menu", 3, "ngClass", 4, "ngIf"], [1, "dropdown-menu", 3, "ngClass"], ["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", 3, "ngClass", 4, "ngIf"], [1, "dropdown-icon"], [3, "src"], [1, "dropdown-submenu", 3, "ngClass"], [1, "checkbox-actions"], [3, "valueChange", "checked"]], template: function ActionsCellComponent_Template(rf, ctx) { if (rf & 1) {
|
|
283
|
+
} }, inputs: { rowData: "rowData", isChecked: "isChecked", config: "config" }, outputs: { actionClick: "actionClick", dropdownToggled: "dropdownToggled" }, decls: 4, vars: 4, consts: [["noChildren", ""], [1, "actions-cell-container", 3, "ngStyle"], ["class", "inline-actions", 4, "ngIf"], ["class", "dropdown-actions", 4, "ngIf"], ["class", "checkbox-actions", 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"], ["class", "dropdown-menu", 3, "ngClass", 4, "ngIf"], [1, "dropdown-menu", 3, "ngClass"], ["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", 3, "ngClass", 4, "ngIf"], [1, "dropdown-icon"], [3, "src"], [1, "dropdown-submenu", 3, "ngClass"], [1, "checkbox-actions"], [3, "valueChange", "checked", "disabled"]], template: function ActionsCellComponent_Template(rf, ctx) { if (rf & 1) {
|
|
263
284
|
i0.ɵɵelementStart(0, "div", 1);
|
|
264
|
-
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_Template, 2, 2, "div", 2)(2, ActionsCellComponent_div_2_Template, 7, 1, "div", 3)(3, ActionsCellComponent_div_3_Template, 2,
|
|
285
|
+
i0.ɵɵtemplate(1, ActionsCellComponent_div_1_Template, 2, 2, "div", 2)(2, ActionsCellComponent_div_2_Template, 7, 1, "div", 3)(3, ActionsCellComponent_div_3_Template, 2, 2, "div", 4);
|
|
265
286
|
i0.ɵɵelementEnd();
|
|
266
287
|
} if (rf & 2) {
|
|
267
288
|
i0.ɵɵproperty("ngStyle", ctx.containerStyle);
|
|
@@ -275,7 +296,7 @@ export class ActionsCellComponent {
|
|
|
275
296
|
}
|
|
276
297
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ActionsCellComponent, [{
|
|
277
298
|
type: Component,
|
|
278
|
-
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 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\n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\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\" [ngClass]=\"item.submenuAlign\" *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 </div>\n\n <!-- Checkbox Actions -->\n <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\"> </mis-checkbox>\n </div>\n</div>\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}.dropdown-actions{position:relative}.dropdown-trigger{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-menu{position:absolute;top:100%;width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;z-index:1000;padding:8px 0}.dropdown-menu.left{right:0!important;left:auto!important}.dropdown-menu.right{left:0!important;right:auto!important}.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}.submenu-container{position:absolute;top:0;left:100%;margin-left:4px;background:#fff;box-shadow:0 4px 8px #0000001a;border-radius:8px;z-index:1000;white-space:nowrap}.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.right{left:100%;margin-left:4px}.dropdown-submenu.left{left:auto;right:100%;background-color:#fff;border:1px solid #ddd;z-index:9999;position:absolute;margin-right: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}\n"] }]
|
|
299
|
+
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 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\n <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\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\" [ngClass]=\"item.submenuAlign\" *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 </div>\n\n <!-- Checkbox Actions -->\n <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\" [disabled]=\"disable ? disable(data) : false\"\n > </mis-checkbox>\n </div>\n</div>\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}.dropdown-actions{position:relative}.dropdown-trigger{cursor:pointer;display:flex;align-items:center;justify-content:center}.dropdown-menu{position:absolute;top:100%;width:232px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001f;z-index:1000;padding:8px 0}.dropdown-menu.left{right:0!important;left:auto!important}.dropdown-menu.right{left:0!important;right:auto!important}.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}.submenu-container{position:absolute;top:0;left:100%;margin-left:4px;background:#fff;box-shadow:0 4px 8px #0000001a;border-radius:8px;z-index:1000;white-space:nowrap}.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.right{left:100%;margin-left:4px}.dropdown-submenu.left{left:auto;right:100%;background-color:#fff;border:1px solid #ddd;z-index:9999;position:absolute;margin-right: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}\n"] }]
|
|
279
300
|
}], null, { rowData: [{
|
|
280
301
|
type: Input
|
|
281
302
|
}], isChecked: [{
|
|
@@ -284,9 +305,11 @@ export class ActionsCellComponent {
|
|
|
284
305
|
type: Input
|
|
285
306
|
}], actionClick: [{
|
|
286
307
|
type: Output
|
|
308
|
+
}], dropdownToggled: [{
|
|
309
|
+
type: Output
|
|
287
310
|
}], onDocumentClick: [{
|
|
288
311
|
type: HostListener,
|
|
289
312
|
args: ["document:click"]
|
|
290
313
|
}] }); })();
|
|
291
314
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
292
|
-
//# 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 } from \"@angular/core\";\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 {\n  @Input() set rowData(value: any){\n    this.data = value?.rowData ?? {};\n    this.isChecked = value?.isChecked ?? false;\n  }\n  data: any;\n  @Input() isChecked: boolean = false;\n  @Input() set config(config: any){\n    this.actionItems = config?.actionItems,\n    this.actionType = config.actionType,\n    this.submenuAlign = config.submenuAlign,\n    this.menuAlign = config.menuAlign\n    this._style = config.style;\n    this.action = config.action;\n    this.processStyle();\n  }\n\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" = \"inline\";\n  submenuAlign: \"left\" | \"right\" = \"right\";\n  menuAlign: \"left\" | \"right\" = \"left\";\n  action?: (data: any) => void;\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data: any; isChecked?: any }>();\n\n  isDropdownOpen: boolean = false;\n  private _style: any = {};\n  containerStyle: any = {};\n\n  ngOnInit(): void {}\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, data: this.data });\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.isDropdownOpen = false;\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    this.isDropdownOpen = !this.isDropdownOpen;\n    // Close all submenus when opening/closing main menu\n    this.actionItems.forEach((item: any) => (item.showSubmenu = false));\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.isDropdownOpen = false; // Only close if action was executed\n    }\n  }\n\n  onCheckboxChange(event: any): void {\n    this.isChecked = event?.value ?? false;\n    this.actionClick.emit({ \n      isChecked: this.isChecked, \n      data: this.data \n    });\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","<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 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\n    <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\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\" [ngClass]=\"item.submenuAlign\" *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  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\"> </mis-checkbox>\n  </div>\n</div>\n"]}
|
|
315
|
+
//# 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 } from \"@angular/core\";\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 {\n  @Input() set rowData(value: any){\n    if (this.actionType === 'checkbox') {\n      // For checkbox, keep the rowData structure\n      this.data = value?.rowData ?? {};\n      this.isChecked = value?.isChecked ?? false;\n    } else {\n      // For other actions (dropdown, inline), use the value directly\n      this.data = value;\n      this.isChecked = false;\n    }\n  }\n  @Input() isChecked: boolean = false;\n  @Input() set config(config: any){\n    this.actionItems = config?.actionItems,\n    this.actionType = config.actionType,\n    this.submenuAlign = config.submenuAlign,\n    this.menuAlign = config.menuAlign\n    this._style = config.style;\n    this.action = config.action;\n    this.disable = config.disable;\n    this.processStyle();\n  }\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data: any; isChecked?: any }>();\n  @Output() dropdownToggled = new EventEmitter<ActionsCellComponent>();\n\n\n  isDropdownOpen: boolean = false;\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" = \"inline\";\n  submenuAlign: \"left\" | \"right\" = \"right\";\n  menuAlign: \"left\" | \"right\" = \"left\";\n  action?: (data: any) => void;\n  data: any;\n  disable: (data: any) => boolean;\n  private _style: any = {};\n  containerStyle: any = {};\n\n  ngOnInit(): void {}\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, data: this.data });\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.isDropdownOpen = false;\n    }\n  }\n\n  // method to close dropdown\n  closeDropdown() {\n    if (this.isDropdownOpen) {\n      this.isDropdownOpen = false;\n      this.actionItems.forEach((item: any) => (item.showSubmenu = false));\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    \n    // Emit self when opening dropdown\n    if (!this.isDropdownOpen) {\n      this.dropdownToggled.emit(this);\n    }\n    \n    this.isDropdownOpen = !this.isDropdownOpen;\n    // Close all submenus when opening/closing main menu\n    this.actionItems.forEach((item: any) => (item.showSubmenu = false));\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.isDropdownOpen = false; // Only close if action was executed\n    }\n  }\n\n  onCheckboxChange(event: any): void {\n    this.isChecked = event?.value ?? false;\n    this.actionClick.emit({ \n      isChecked: this.isChecked, \n      data: this.data \n    });\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","<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 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\n    <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\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\" [ngClass]=\"item.submenuAlign\" *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  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\"  [disabled]=\"disable ? disable(data) : false\"\n    > </mis-checkbox>\n  </div>\n</div>\n"]}
|