mis-crystal-design-system 17.0.3 → 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.
Files changed (70) hide show
  1. package/analytics/analytics.service.d.ts +1 -1
  2. package/esm2022/analytics/analytics.service.mjs +3 -3
  3. package/esm2022/filter/filter-panel/filter-panel.component.mjs +19 -19
  4. package/esm2022/slider/slider.component.mjs +2 -2
  5. package/esm2022/table/actions-cell/actions-cell.component.mjs +389 -0
  6. package/esm2022/table/public_api.mjs +5 -3
  7. package/esm2022/table/sort-icons.directive.mjs +139 -0
  8. package/esm2022/table/table.component.mjs +286 -109
  9. package/esm2022/table/table.module.mjs +41 -6
  10. package/esm2022/toast/public_api.mjs +3 -1
  11. package/esm2022/toast/toast.component.mjs +73 -16
  12. package/esm2022/toast/toast.constants.mjs +7 -0
  13. package/esm2022/toast/toast.data.service.mjs +1 -1
  14. package/esm2022/toast/toast.interface.mjs +2 -0
  15. package/esm2022/toast/toast.service.mjs +14 -7
  16. package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
  17. package/fesm2022/mis-crystal-design-system-analytics.mjs +2 -2
  18. package/fesm2022/mis-crystal-design-system-analytics.mjs.map +1 -1
  19. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
  20. package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
  21. package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
  22. package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
  23. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  24. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  25. package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
  26. package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
  27. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  28. package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
  29. package/fesm2022/mis-crystal-design-system-filter.mjs +18 -18
  30. package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
  31. package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
  32. package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
  33. package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
  34. package/fesm2022/mis-crystal-design-system-menu.mjs.map +1 -1
  35. package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
  36. package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
  37. package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
  38. package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
  39. package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
  40. package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
  41. package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
  42. package/fesm2022/mis-crystal-design-system-slider.mjs +2 -2
  43. package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
  44. package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
  45. package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
  46. package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
  47. package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
  48. package/fesm2022/mis-crystal-design-system-table.mjs +1143 -411
  49. package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
  50. package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
  51. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  52. package/fesm2022/mis-crystal-design-system-toast.mjs +93 -22
  53. package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
  54. package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
  55. package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
  56. package/fesm2022/mis-crystal-design-system-widgets.mjs.map +1 -1
  57. package/filter/filter-panel/filter-panel.component.d.ts +4 -3
  58. package/package.json +35 -35
  59. package/table/actions-cell/actions-cell.component.d.ts +45 -0
  60. package/table/filter/filter.component.d.ts +1 -1
  61. package/table/public_api.d.ts +4 -2
  62. package/table/sort-icons.directive.d.ts +36 -0
  63. package/table/table.component.d.ts +56 -10
  64. package/table/table.module.d.ts +8 -4
  65. package/toast/public_api.d.ts +2 -0
  66. package/toast/toast.component.d.ts +13 -1
  67. package/toast/toast.constants.d.ts +5 -0
  68. package/toast/toast.data.service.d.ts +3 -2
  69. package/toast/toast.interface.d.ts +6 -0
  70. package/toast/toast.service.d.ts +2 -1
@@ -0,0 +1,139 @@
1
+ import { Directive, input, output, signal, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SortIconsDirective {
4
+ constructor(el, renderer) {
5
+ this.el = el;
6
+ this.renderer = renderer;
7
+ // Convert inputs to signals
8
+ this.column = input();
9
+ this.activeSort = input();
10
+ this.activeSorts = input();
11
+ this.multiColumnSort = input(false);
12
+ // Convert output to signal
13
+ this.sortChange = output();
14
+ this.multiSortChange = output();
15
+ // Internal state as signals
16
+ this.currentDirection = signal('');
17
+ }
18
+ ngOnInit() {
19
+ // Create a container for the icons
20
+ const container = this.renderer.createElement('div');
21
+ this.renderer?.setStyle(container, 'display', 'inline-flex');
22
+ this.renderer?.setStyle(container, 'align-items', 'center');
23
+ const iconContainer = this.renderer.createElement('div');
24
+ this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');
25
+ this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');
26
+ this.renderer?.setStyle(iconContainer, 'align-items', 'center');
27
+ this.upIcon = this.renderer.createElement('img');
28
+ this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);
29
+ this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');
30
+ this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');
31
+ this.renderer?.setStyle(this.upIcon, 'width', '9px');
32
+ this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');
33
+ this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));
34
+ this.downIcon = this.renderer.createElement('img');
35
+ this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);
36
+ this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');
37
+ this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');
38
+ this.renderer?.setStyle(this.downIcon, 'width', '9px');
39
+ this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');
40
+ this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));
41
+ this.renderer?.appendChild(iconContainer, this.upIcon);
42
+ this.renderer?.appendChild(iconContainer, this.downIcon);
43
+ this.renderer?.appendChild(container, iconContainer);
44
+ if (this.multiColumnSort()) {
45
+ this.sortOrderElement = this.renderer.createElement('span');
46
+ this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');
47
+ this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');
48
+ this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');
49
+ this.renderer?.appendChild(container, this.sortOrderElement);
50
+ }
51
+ this.renderer?.appendChild(this.el.nativeElement, container);
52
+ this.updateIconStyles();
53
+ }
54
+ ngOnChanges(changes) {
55
+ if (changes['activeSort'] || changes['activeSorts']) {
56
+ this.updateIconStyles();
57
+ }
58
+ }
59
+ setSortDirection(direction) {
60
+ if (this.multiColumnSort()) {
61
+ this.handleMultiColumnSort(direction);
62
+ }
63
+ else {
64
+ this.handleSingleColumnSort(direction);
65
+ }
66
+ }
67
+ handleSingleColumnSort(direction) {
68
+ if (this.currentDirection() === direction) {
69
+ this.currentDirection.set(''); // Reset sorting if the same direction is clicked
70
+ }
71
+ else {
72
+ this.currentDirection.set(direction);
73
+ }
74
+ this.sortChange.emit({
75
+ column: this.column()?.data || '',
76
+ direction: this.currentDirection()
77
+ });
78
+ this.updateIconStyles();
79
+ }
80
+ handleMultiColumnSort(direction) {
81
+ const existingSortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);
82
+ if (existingSortIndex !== -1) {
83
+ if (this.activeSorts()[existingSortIndex].direction !== direction) {
84
+ this.activeSorts()[existingSortIndex].direction = direction;
85
+ }
86
+ else {
87
+ return;
88
+ }
89
+ }
90
+ else {
91
+ this.activeSorts().push({
92
+ column: this.column()?.data || '',
93
+ direction
94
+ });
95
+ }
96
+ this.multiSortChange.emit([...this.activeSorts()]);
97
+ this.updateIconStyles();
98
+ }
99
+ updateIconStyles() {
100
+ if (this.multiColumnSort()) {
101
+ this.updateMultiColumnIconStyles();
102
+ }
103
+ else {
104
+ this.updateSingleColumnIconStyles();
105
+ }
106
+ }
107
+ updateSingleColumnIconStyles() {
108
+ const isActiveColumn = this.activeSort()?.column === this.column()?.data;
109
+ setTimeout(() => {
110
+ this.renderer?.setStyle(this.upIcon, 'opacity', isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5');
111
+ this.renderer?.setStyle(this.downIcon, 'opacity', isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5');
112
+ }, 0);
113
+ }
114
+ updateMultiColumnIconStyles() {
115
+ const columnSort = this.activeSorts().find(sort => sort.column === this.column()?.data);
116
+ setTimeout(() => {
117
+ this.renderer?.setStyle(this.upIcon, 'opacity', columnSort?.direction === 'ASC' ? '1' : '0.5');
118
+ this.renderer?.setStyle(this.downIcon, 'opacity', columnSort?.direction === 'DESC' ? '1' : '0.5');
119
+ if (this.sortOrderElement) {
120
+ const sortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);
121
+ if (sortIndex !== -1) {
122
+ this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());
123
+ }
124
+ else {
125
+ this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');
126
+ }
127
+ }
128
+ }, 0);
129
+ }
130
+ static { this.ɵfac = function SortIconsDirective_Factory(t) { return new (t || SortIconsDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2)); }; }
131
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SortIconsDirective, selectors: [["", "appSortIcons", ""]], inputs: { column: [i0.ɵɵInputFlags.SignalBased, "column"], activeSort: [i0.ɵɵInputFlags.SignalBased, "activeSort"], activeSorts: [i0.ɵɵInputFlags.SignalBased, "activeSorts"], multiColumnSort: [i0.ɵɵInputFlags.SignalBased, "multiColumnSort"] }, outputs: { sortChange: "sortChange", multiSortChange: "multiSortChange" }, features: [i0.ɵɵNgOnChangesFeature] }); }
132
+ }
133
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SortIconsDirective, [{
134
+ type: Directive,
135
+ args: [{
136
+ selector: '[appSortIcons]',
137
+ }]
138
+ }], () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], null); })();
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-icons.directive.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/sort-icons.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAST,KAAK,EACL,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;;AAgBvB,MAAM,OAAO,kBAAkB;IAmB7B,YAAoB,EAAc,EAAU,QAAmB;QAA3C,OAAE,GAAF,EAAE,CAAY;QAAU,aAAQ,GAAR,QAAQ,CAAW;QAlB/D,4BAA4B;QAC5B,WAAM,GAAG,KAAK,EAAc,CAAC;QAC7B,eAAU,GAAG,KAAK,EAAa,CAAC;QAChC,gBAAW,GAAG,KAAK,EAAe,CAAC;QACnC,oBAAe,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAExC,2BAA2B;QAC3B,eAAU,GAAG,MAAM,EAAa,CAAC;QACjC,oBAAe,GAAG,MAAM,EAAe,CAAC;QAExC,4BAA4B;QAC5B,qBAAgB,GAAG,MAAM,CAAsB,EAAE,CAAC,CAAC;IAOe,CAAC;IAEnE,QAAQ;QAEN,mCAAmC;QACnC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;QAC7D,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,SAAS,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;QAE5D,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;QACjE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,EAAE,gBAAgB,EAAE,QAAQ,CAAC,CAAC;QACnE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,aAAa,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;QAEhE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,WAAW,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,YAAY,EAAE,mBAAmB,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC1D,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;QAEhF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,YAAY,CAAC,CAAC;QAC/E,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,YAAY,EAAE,mBAAmB,CAAC,CAAC;QAC1E,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;QAEnF,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;YAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC5D,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;YACtE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;YAChE,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC9D;QAED,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;QAC7D,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,YAAY,CAAC,IAAI,OAAO,CAAC,aAAa,CAAC,EAAE;YACnD,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAEO,gBAAgB,CAAC,SAAyB;QAChD,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;YAC1B,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;SACvC;aAAM;YACL,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAC;SACxC;IACH,CAAC;IAEO,sBAAsB,CAAC,SAAyB;QACtD,IAAI,IAAI,CAAC,gBAAgB,EAAE,KAAK,SAAS,EAAE;YACzC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,iDAAiD;SACjF;aAAM;YACL,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;SACtC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,IAAI,EAAE;YACjC,SAAS,EAAE,IAAI,CAAC,gBAAgB,EAAE;SACnC,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEO,qBAAqB,CAAC,SAAyB;QACrD,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,CAAC;QAEpG,IAAI,iBAAiB,KAAK,CAAC,CAAC,EAAE;YAC5B,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,iBAAiB,CAAC,CAAC,SAAS,KAAK,SAAS,EAAE;gBACjE,IAAI,CAAC,WAAW,EAAE,CAAC,iBAAiB,CAAC,CAAC,SAAS,GAAG,SAAS,CAAC;aAC7D;iBAAM;gBACL,OAAO;aACR;SACF;aAAM;YACL,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC;gBACtB,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,IAAI,EAAE;gBACjC,SAAS;aACV,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE;YAC1B,IAAI,CAAC,2BAA2B,EAAE,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,4BAA4B,EAAE,CAAC;SACrC;IACH,CAAC;IAEO,4BAA4B;QAClC,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC;QAEzE,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,QAAQ,EAAE,QAAQ,CACrB,IAAI,CAAC,MAAM,EACX,SAAS,EACT,cAAc,IAAI,IAAI,CAAC,gBAAgB,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAClE,CAAC;YACF,IAAI,CAAC,QAAQ,EAAE,QAAQ,CACrB,IAAI,CAAC,QAAQ,EACb,SAAS,EACT,cAAc,IAAI,IAAI,CAAC,gBAAgB,EAAE,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CACnE,CAAC;QACJ,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAEO,2BAA2B;QACjC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,CAAC;QAExF,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,QAAQ,EAAE,QAAQ,CACrB,IAAI,CAAC,MAAM,EACX,SAAS,EACT,UAAU,EAAE,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAC9C,CAAC;YACF,IAAI,CAAC,QAAQ,EAAE,QAAQ,CACrB,IAAI,CAAC,QAAQ,EACb,SAAS,EACT,UAAU,EAAE,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAC/C,CAAC;YAEF,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACzB,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,CAAC;gBAC5F,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;oBACpB,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,gBAAgB,EAAE,aAAa,EAAE,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;iBAC9F;qBAAM;oBACL,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,IAAI,CAAC,gBAAgB,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;iBACtE;aACF;QACH,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;mFAjKU,kBAAkB;oEAAlB,kBAAkB;;iFAAlB,kBAAkB;cAH9B,SAAS;eAAC;gBACT,QAAQ,EAAE,gBAAgB;aAC3B","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  input,\n  output,\n  signal,\n} from '@angular/core';\n\nexport interface SortState {\n  column: string;\n  direction: 'ASC' | 'DESC' | '';\n}\n\nexport interface SortColumn {\n  data: string;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\n\n@Directive({\n  selector: '[appSortIcons]',\n})\nexport class SortIconsDirective implements OnInit, OnChanges {\n  // Convert inputs to signals\n  column = input<SortColumn>();\n  activeSort = input<SortState>();\n  activeSorts = input<SortState[]>();\n  multiColumnSort = input<boolean>(false);\n  \n  // Convert output to signal\n  sortChange = output<SortState>();\n  multiSortChange = output<SortState[]>();\n\n  // Internal state as signals\n  currentDirection = signal<'ASC' | 'DESC' | ''>('');\n\n  // Assets\n  private upIcon!: HTMLImageElement;\n  private downIcon!: HTMLImageElement;\n  private sortOrderElement?: HTMLSpanElement;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  ngOnInit() {\n    \n    // Create a container for the icons\n    const container = this.renderer.createElement('div');\n    this.renderer?.setStyle(container, 'display', 'inline-flex');\n    this.renderer?.setStyle(container, 'align-items', 'center');\n\n    const iconContainer = this.renderer.createElement('div');\n    this.renderer?.setStyle(iconContainer, 'display', 'inline-flex');\n    this.renderer?.setStyle(iconContainer, 'flex-direction', 'column');\n    this.renderer?.setStyle(iconContainer, 'align-items', 'center');\n\n    this.upIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.upIcon, 'src', this.column()?.sortAscIcon);\n    this.renderer?.setStyle(this.upIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.upIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.upIcon, 'width', '9px');\n    this.renderer?.setStyle(this.upIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.upIcon, 'click', () => this.setSortDirection('ASC'));\n\n    this.downIcon = this.renderer.createElement('img');\n    this.renderer?.setAttribute(this.downIcon, 'src', this.column()?.sortDescIcon);\n    this.renderer?.setStyle(this.downIcon, 'opacity', '0.5');\n    this.renderer?.setStyle(this.downIcon, 'transition', 'opacity 0.3s ease');\n    this.renderer?.setStyle(this.downIcon, 'width', '9px');\n    this.renderer?.setStyle(this.downIcon, 'cursor', 'pointer');\n    this.renderer?.listen(this.downIcon, 'click', () => this.setSortDirection('DESC'));\n\n    this.renderer?.appendChild(iconContainer, this.upIcon);\n    this.renderer?.appendChild(iconContainer, this.downIcon);\n    this.renderer?.appendChild(container, iconContainer);\n\n    if (this.multiColumnSort()) {\n      this.sortOrderElement = this.renderer.createElement('span');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-size', '12px');\n      this.renderer?.setStyle(this.sortOrderElement, 'font-weight', 'bold');\n      this.renderer?.setStyle(this.sortOrderElement, 'color', '#000');\n      this.renderer?.appendChild(container, this.sortOrderElement);\n    }\n\n    this.renderer?.appendChild(this.el.nativeElement, container);\n    this.updateIconStyles();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['activeSort'] || changes['activeSorts']) {\n      this.updateIconStyles();\n    }\n  }\n\n  private setSortDirection(direction: 'ASC' | 'DESC'): void {\n    if (this.multiColumnSort()) {\n      this.handleMultiColumnSort(direction);\n    } else {\n      this.handleSingleColumnSort(direction);\n    }\n  }\n\n  private handleSingleColumnSort(direction: 'ASC' | 'DESC'): void {\n    if (this.currentDirection() === direction) {\n      this.currentDirection.set(''); // Reset sorting if the same direction is clicked\n    } else {\n      this.currentDirection.set(direction);\n    }\n\n    this.sortChange.emit({ \n      column: this.column()?.data || '', \n      direction: this.currentDirection()\n    });\n    this.updateIconStyles();\n  }\n\n  private handleMultiColumnSort(direction: 'ASC' | 'DESC'): void {\n    const existingSortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);\n    \n    if (existingSortIndex !== -1) {\n      if (this.activeSorts()[existingSortIndex].direction !== direction) {\n        this.activeSorts()[existingSortIndex].direction = direction;\n      } else {\n        return;\n      }\n    } else {\n      this.activeSorts().push({ \n        column: this.column()?.data || '', \n        direction\n      });\n    }\n    this.multiSortChange.emit([...this.activeSorts()]);\n    this.updateIconStyles();\n  }\n\n  private updateIconStyles(): void {\n    if (this.multiColumnSort()) {\n      this.updateMultiColumnIconStyles();\n    } else {\n      this.updateSingleColumnIconStyles();\n    }\n  }\n\n  private updateSingleColumnIconStyles(): void {\n    const isActiveColumn = this.activeSort()?.column === this.column()?.data;\n\n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        isActiveColumn && this.currentDirection() === 'DESC' ? '1' : '0.5'\n      );\n    }, 0);\n  }\n\n  private updateMultiColumnIconStyles(): void {\n    const columnSort = this.activeSorts().find(sort => sort.column === this.column()?.data);\n    \n    setTimeout(() => {\n      this.renderer?.setStyle(\n        this.upIcon,\n        'opacity',\n        columnSort?.direction === 'ASC' ? '1' : '0.5'\n      );\n      this.renderer?.setStyle(\n        this.downIcon,\n        'opacity',\n        columnSort?.direction === 'DESC' ? '1' : '0.5'\n      );\n\n      if (this.sortOrderElement) {\n        const sortIndex = this.activeSorts().findIndex(sort => sort.column === this.column()?.data);\n        if (sortIndex !== -1) {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', (sortIndex + 1).toString());\n        } else {\n          this.renderer?.setProperty(this.sortOrderElement, 'textContent', '');\n        }\n      }\n    }, 0);\n  }\n}"]}