react-restyle-components 0.4.22 → 0.4.24

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 (201) hide show
  1. package/lib/src/core-components/src/components/AlertBanner/AlertBanner.d.ts +4 -0
  2. package/lib/src/core-components/src/components/AlertBanner/AlertBanner.d.ts.map +1 -0
  3. package/lib/src/core-components/src/components/AlertBanner/AlertBanner.js +45 -0
  4. package/lib/src/core-components/src/components/AlertBanner/elements.d.ts +27 -0
  5. package/lib/src/core-components/src/components/AlertBanner/elements.d.ts.map +1 -0
  6. package/lib/src/core-components/src/components/AlertBanner/elements.js +233 -0
  7. package/lib/src/core-components/src/components/AlertBanner/index.d.ts +3 -0
  8. package/lib/src/core-components/src/components/AlertBanner/index.d.ts.map +1 -0
  9. package/lib/src/core-components/src/components/AlertBanner/index.js +2 -0
  10. package/lib/src/core-components/src/components/AlertBanner/types.d.ts +46 -0
  11. package/lib/src/core-components/src/components/AlertBanner/types.d.ts.map +1 -0
  12. package/lib/src/core-components/src/components/AlertBanner/types.js +10 -0
  13. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-selected-top-display/auto-complete-filter-multi-select-selected-top-display.component.d.ts.map +1 -1
  14. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-selected-top-display/auto-complete-filter-multi-select-selected-top-display.component.js +40 -3
  15. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.d.ts +1 -1
  16. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.d.ts.map +1 -1
  17. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.js +26 -1
  18. package/lib/src/core-components/src/components/Badge/Badge.d.ts +33 -33
  19. package/lib/src/core-components/src/components/Breadcrumb/Breadcrumb.d.ts +28 -0
  20. package/lib/src/core-components/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -0
  21. package/lib/src/core-components/src/components/Breadcrumb/Breadcrumb.js +83 -0
  22. package/lib/src/core-components/src/components/Breadcrumb/elements.d.ts +44 -0
  23. package/lib/src/core-components/src/components/Breadcrumb/elements.d.ts.map +1 -0
  24. package/lib/src/core-components/src/components/Breadcrumb/elements.js +370 -0
  25. package/lib/src/core-components/src/components/Breadcrumb/index.d.ts +4 -0
  26. package/lib/src/core-components/src/components/Breadcrumb/index.d.ts.map +1 -0
  27. package/lib/src/core-components/src/components/Breadcrumb/index.js +3 -0
  28. package/lib/src/core-components/src/components/Breadcrumb/types.d.ts +14 -0
  29. package/lib/src/core-components/src/components/Breadcrumb/types.d.ts.map +1 -0
  30. package/lib/src/core-components/src/components/Breadcrumb/types.js +3 -0
  31. package/lib/src/core-components/src/components/Button/Button.spec.js +1 -1
  32. package/lib/src/core-components/src/components/Button/button.component.js +1 -1
  33. package/lib/src/core-components/src/components/Chip/Chip.d.ts +5 -0
  34. package/lib/src/core-components/src/components/Chip/Chip.d.ts.map +1 -0
  35. package/lib/src/core-components/src/components/Chip/Chip.js +64 -0
  36. package/lib/src/core-components/src/components/Chip/elements.d.ts +27 -0
  37. package/lib/src/core-components/src/components/Chip/elements.d.ts.map +1 -0
  38. package/lib/src/core-components/src/components/Chip/elements.js +253 -0
  39. package/lib/src/core-components/src/components/Chip/index.d.ts +3 -0
  40. package/lib/src/core-components/src/components/Chip/index.d.ts.map +1 -0
  41. package/lib/src/core-components/src/components/Chip/index.js +2 -0
  42. package/lib/src/core-components/src/components/Chip/types.d.ts +54 -0
  43. package/lib/src/core-components/src/components/Chip/types.d.ts.map +1 -0
  44. package/lib/src/core-components/src/components/Chip/types.js +4 -0
  45. package/lib/src/core-components/src/components/Divider/Divider.d.ts +4 -0
  46. package/lib/src/core-components/src/components/Divider/Divider.d.ts.map +1 -0
  47. package/lib/src/core-components/src/components/Divider/Divider.js +25 -0
  48. package/lib/src/core-components/src/components/Divider/elements.d.ts +22 -0
  49. package/lib/src/core-components/src/components/Divider/elements.d.ts.map +1 -0
  50. package/lib/src/core-components/src/components/Divider/elements.js +103 -0
  51. package/lib/src/core-components/src/components/Divider/index.d.ts +3 -0
  52. package/lib/src/core-components/src/components/Divider/index.d.ts.map +1 -0
  53. package/lib/src/core-components/src/components/Divider/index.js +2 -0
  54. package/lib/src/core-components/src/components/Divider/types.d.ts +30 -0
  55. package/lib/src/core-components/src/components/Divider/types.d.ts.map +1 -0
  56. package/lib/src/core-components/src/components/Divider/types.js +4 -0
  57. package/lib/src/core-components/src/components/DynamicGrid/DynamicGrid.d.ts +6 -0
  58. package/lib/src/core-components/src/components/DynamicGrid/DynamicGrid.d.ts.map +1 -0
  59. package/lib/src/core-components/src/components/DynamicGrid/DynamicGrid.js +147 -0
  60. package/lib/src/core-components/src/components/DynamicGrid/GridContainer.d.ts +12 -0
  61. package/lib/src/core-components/src/components/DynamicGrid/GridContainer.d.ts.map +1 -0
  62. package/lib/src/core-components/src/components/DynamicGrid/GridContainer.js +89 -0
  63. package/lib/src/core-components/src/components/DynamicGrid/elements.d.ts +49 -0
  64. package/lib/src/core-components/src/components/DynamicGrid/elements.d.ts.map +1 -0
  65. package/lib/src/core-components/src/components/DynamicGrid/elements.js +409 -0
  66. package/lib/src/core-components/src/components/DynamicGrid/index.d.ts +4 -0
  67. package/lib/src/core-components/src/components/DynamicGrid/index.d.ts.map +1 -0
  68. package/lib/src/core-components/src/components/DynamicGrid/index.js +3 -0
  69. package/lib/src/core-components/src/components/DynamicGrid/types.d.ts +173 -0
  70. package/lib/src/core-components/src/components/DynamicGrid/types.d.ts.map +1 -0
  71. package/lib/src/core-components/src/components/DynamicGrid/types.js +28 -0
  72. package/lib/src/core-components/src/components/DynamicGrid/utils.d.ts +65 -0
  73. package/lib/src/core-components/src/components/DynamicGrid/utils.d.ts.map +1 -0
  74. package/lib/src/core-components/src/components/DynamicGrid/utils.js +193 -0
  75. package/lib/src/core-components/src/components/FormField/FormField.d.ts +1 -1
  76. package/lib/src/core-components/src/components/Icon/Icon.js +1 -1
  77. package/lib/src/core-components/src/components/Masonry/Masonry.d.ts +7 -0
  78. package/lib/src/core-components/src/components/Masonry/Masonry.d.ts.map +1 -0
  79. package/lib/src/core-components/src/components/Masonry/Masonry.js +73 -0
  80. package/lib/src/core-components/src/components/Masonry/elements.d.ts +31 -0
  81. package/lib/src/core-components/src/components/Masonry/elements.d.ts.map +1 -0
  82. package/lib/src/core-components/src/components/Masonry/elements.js +122 -0
  83. package/lib/src/core-components/src/components/Masonry/hooks.d.ts +21 -0
  84. package/lib/src/core-components/src/components/Masonry/hooks.d.ts.map +1 -0
  85. package/lib/src/core-components/src/components/Masonry/hooks.js +100 -0
  86. package/lib/src/core-components/src/components/Masonry/index.d.ts +4 -0
  87. package/lib/src/core-components/src/components/Masonry/index.d.ts.map +1 -0
  88. package/lib/src/core-components/src/components/Masonry/index.js +3 -0
  89. package/lib/src/core-components/src/components/Masonry/types.d.ts +117 -0
  90. package/lib/src/core-components/src/components/Masonry/types.d.ts.map +1 -0
  91. package/lib/src/core-components/src/components/Masonry/types.js +1 -0
  92. package/lib/src/core-components/src/components/Modal/modal-confirm/modal-confirm.component.d.ts +3 -3
  93. package/lib/src/core-components/src/components/Modal/modal-confirm/modal-confirm.component.d.ts.map +1 -1
  94. package/lib/src/core-components/src/components/Modal/modal-confirm/modal-confirm.component.js +1 -1
  95. package/lib/src/core-components/src/components/Picker/color-picker-modal/color-picker-modal.component.js +1 -1
  96. package/lib/src/core-components/src/components/Skeleton/Skeleton.d.ts +8 -0
  97. package/lib/src/core-components/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  98. package/lib/src/core-components/src/components/Skeleton/Skeleton.js +51 -0
  99. package/lib/src/core-components/src/components/Skeleton/elements.d.ts +33 -0
  100. package/lib/src/core-components/src/components/Skeleton/elements.d.ts.map +1 -0
  101. package/lib/src/core-components/src/components/Skeleton/elements.js +238 -0
  102. package/lib/src/core-components/src/components/Skeleton/index.d.ts +3 -0
  103. package/lib/src/core-components/src/components/Skeleton/index.d.ts.map +1 -0
  104. package/lib/src/core-components/src/components/Skeleton/index.js +2 -0
  105. package/lib/src/core-components/src/components/Skeleton/types.d.ts +80 -0
  106. package/lib/src/core-components/src/components/Skeleton/types.d.ts.map +1 -0
  107. package/lib/src/core-components/src/components/Skeleton/types.js +4 -0
  108. package/lib/src/core-components/src/components/SpeedDial/SpeedDial.d.ts +4 -0
  109. package/lib/src/core-components/src/components/SpeedDial/SpeedDial.d.ts.map +1 -0
  110. package/lib/src/core-components/src/components/SpeedDial/SpeedDial.js +128 -0
  111. package/lib/src/core-components/src/components/SpeedDial/elements.d.ts +57 -0
  112. package/lib/src/core-components/src/components/SpeedDial/elements.d.ts.map +1 -0
  113. package/lib/src/core-components/src/components/SpeedDial/elements.js +299 -0
  114. package/lib/src/core-components/src/components/SpeedDial/index.d.ts +3 -0
  115. package/lib/src/core-components/src/components/SpeedDial/index.d.ts.map +1 -0
  116. package/lib/src/core-components/src/components/SpeedDial/index.js +2 -0
  117. package/lib/src/core-components/src/components/SpeedDial/types.d.ts +149 -0
  118. package/lib/src/core-components/src/components/SpeedDial/types.d.ts.map +1 -0
  119. package/lib/src/core-components/src/components/SpeedDial/types.js +3 -0
  120. package/lib/src/core-components/src/components/Switch/Switch.d.ts +4 -0
  121. package/lib/src/core-components/src/components/Switch/Switch.d.ts.map +1 -0
  122. package/lib/src/core-components/src/components/Switch/Switch.js +26 -0
  123. package/lib/src/core-components/src/components/Switch/elements.d.ts +33 -0
  124. package/lib/src/core-components/src/components/Switch/elements.d.ts.map +1 -0
  125. package/lib/src/core-components/src/components/Switch/elements.js +167 -0
  126. package/lib/src/core-components/src/components/Switch/index.d.ts +3 -0
  127. package/lib/src/core-components/src/components/Switch/index.d.ts.map +1 -0
  128. package/lib/src/core-components/src/components/Switch/index.js +2 -0
  129. package/lib/src/core-components/src/components/Switch/types.d.ts +32 -0
  130. package/lib/src/core-components/src/components/Switch/types.d.ts.map +1 -0
  131. package/lib/src/core-components/src/components/Switch/types.js +3 -0
  132. package/lib/src/core-components/src/components/Table/Table.d.ts +7 -0
  133. package/lib/src/core-components/src/components/Table/Table.d.ts.map +1 -0
  134. package/lib/src/core-components/src/components/Table/Table.js +357 -0
  135. package/lib/src/core-components/src/components/Table/elements.d.ts +89 -0
  136. package/lib/src/core-components/src/components/Table/elements.d.ts.map +1 -0
  137. package/lib/src/core-components/src/components/Table/elements.js +604 -0
  138. package/lib/src/core-components/src/components/Table/filters.d.ts +23 -0
  139. package/lib/src/core-components/src/components/Table/filters.d.ts.map +1 -0
  140. package/lib/src/core-components/src/components/Table/filters.js +181 -0
  141. package/lib/src/core-components/src/components/Table/hooks.d.ts +107 -0
  142. package/lib/src/core-components/src/components/Table/hooks.d.ts.map +1 -0
  143. package/lib/src/core-components/src/components/Table/hooks.js +451 -0
  144. package/lib/src/core-components/src/components/Table/index.d.ts +5 -0
  145. package/lib/src/core-components/src/components/Table/index.d.ts.map +1 -0
  146. package/lib/src/core-components/src/components/Table/index.js +4 -0
  147. package/lib/src/core-components/src/components/Table/types.d.ts +358 -0
  148. package/lib/src/core-components/src/components/Table/types.d.ts.map +1 -0
  149. package/lib/src/core-components/src/components/Table/types.js +1 -0
  150. package/lib/src/core-components/src/components/Toast/Toast.d.ts +5 -0
  151. package/lib/src/core-components/src/components/Toast/Toast.d.ts.map +1 -0
  152. package/lib/src/core-components/src/components/Toast/Toast.js +50 -0
  153. package/lib/src/core-components/src/components/Toast/elements.d.ts +28 -0
  154. package/lib/src/core-components/src/components/Toast/elements.d.ts.map +1 -0
  155. package/lib/src/core-components/src/components/Toast/elements.js +272 -0
  156. package/lib/src/core-components/src/components/Toast/index.d.ts +3 -0
  157. package/lib/src/core-components/src/components/Toast/index.d.ts.map +1 -0
  158. package/lib/src/core-components/src/components/Toast/index.js +2 -0
  159. package/lib/src/core-components/src/components/Toast/types.d.ts +52 -0
  160. package/lib/src/core-components/src/components/Toast/types.d.ts.map +1 -0
  161. package/lib/src/core-components/src/components/Toast/types.js +9 -0
  162. package/lib/src/core-components/src/components/Tooltip/Tooltip.d.ts +7 -0
  163. package/lib/src/core-components/src/components/Tooltip/Tooltip.d.ts.map +1 -0
  164. package/lib/src/core-components/src/components/Tooltip/Tooltip.js +200 -0
  165. package/lib/src/core-components/src/components/Tooltip/elements.d.ts +19 -0
  166. package/lib/src/core-components/src/components/Tooltip/elements.d.ts.map +1 -0
  167. package/lib/src/core-components/src/components/Tooltip/elements.js +195 -0
  168. package/lib/src/core-components/src/components/Tooltip/index.d.ts +3 -0
  169. package/lib/src/core-components/src/components/Tooltip/index.d.ts.map +1 -0
  170. package/lib/src/core-components/src/components/Tooltip/index.js +2 -0
  171. package/lib/src/core-components/src/components/Tooltip/types.d.ts +81 -17
  172. package/lib/src/core-components/src/components/Tooltip/types.d.ts.map +1 -1
  173. package/lib/src/core-components/src/components/Tooltip/types.js +17 -1
  174. package/lib/src/core-components/src/components/Tooltip/utils.d.ts +26 -0
  175. package/lib/src/core-components/src/components/Tooltip/utils.d.ts.map +1 -0
  176. package/lib/src/core-components/src/components/Tooltip/utils.js +140 -0
  177. package/lib/src/core-components/src/components/TreeSelect/TreeSelect.d.ts +5 -0
  178. package/lib/src/core-components/src/components/TreeSelect/TreeSelect.d.ts.map +1 -0
  179. package/lib/src/core-components/src/components/TreeSelect/TreeSelect.js +303 -0
  180. package/lib/src/core-components/src/components/TreeSelect/elements.d.ts +74 -0
  181. package/lib/src/core-components/src/components/TreeSelect/elements.d.ts.map +1 -0
  182. package/lib/src/core-components/src/components/TreeSelect/elements.js +494 -0
  183. package/lib/src/core-components/src/components/TreeSelect/hooks.d.ts +57 -0
  184. package/lib/src/core-components/src/components/TreeSelect/hooks.d.ts.map +1 -0
  185. package/lib/src/core-components/src/components/TreeSelect/hooks.js +252 -0
  186. package/lib/src/core-components/src/components/TreeSelect/index.d.ts +4 -0
  187. package/lib/src/core-components/src/components/TreeSelect/index.d.ts.map +1 -0
  188. package/lib/src/core-components/src/components/TreeSelect/index.js +3 -0
  189. package/lib/src/core-components/src/components/TreeSelect/types.d.ts +205 -0
  190. package/lib/src/core-components/src/components/TreeSelect/types.d.ts.map +1 -0
  191. package/lib/src/core-components/src/components/TreeSelect/types.js +1 -0
  192. package/lib/src/core-components/src/components/index.d.ts +13 -1
  193. package/lib/src/core-components/src/components/index.d.ts.map +1 -1
  194. package/lib/src/core-components/src/components/index.js +14 -1
  195. package/lib/src/core-components/src/core-components/CoreButton/CoreButton.d.ts +2 -2
  196. package/lib/src/core-components/src/tc.global.css +13 -3
  197. package/lib/src/core-components/src/tc.module.css +2 -2
  198. package/package.json +1 -1
  199. package/lib/src/core-components/src/components/Tooltip/tooltip.component.d.ts +0 -29
  200. package/lib/src/core-components/src/components/Tooltip/tooltip.component.d.ts.map +0 -1
  201. package/lib/src/core-components/src/components/Tooltip/tooltip.component.js +0 -10
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { AlertBannerProps } from './types';
3
+ export declare const AlertBanner: React.ForwardRefExoticComponent<AlertBannerProps & React.RefAttributes<HTMLDivElement>>;
4
+ //# sourceMappingURL=AlertBanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AlertBanner.d.ts","sourceRoot":"","sources":["../../../../../../src/core-components/src/components/AlertBanner/AlertBanner.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA2C,MAAM,OAAO,CAAC;AAahE,OAAO,EAAC,gBAAgB,EAAkB,MAAM,SAAS,CAAC;AAwD1D,eAAO,MAAM,WAAW,yFA6FvB,CAAC"}
@@ -0,0 +1,45 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { forwardRef, useEffect, useCallback } from 'react';
4
+ import { AlertBannerContainer, IconWrapper, ContentWrapper, Title, Message, ActionsWrapper, ActionButton, DismissButton, } from './elements';
5
+ // Default icons for each type
6
+ const InfoIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: [_jsx("circle", { cx: "12", cy: "12", r: "10" }), _jsx("line", { x1: "12", y1: "16", x2: "12", y2: "12" }), _jsx("line", { x1: "12", y1: "8", x2: "12.01", y2: "8" })] }));
7
+ const SuccessIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: [_jsx("path", { d: "M22 11.08V12a10 10 0 1 1-5.93-9.14" }), _jsx("polyline", { points: "22 4 12 14.01 9 11.01" })] }));
8
+ const WarningIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: [_jsx("path", { d: "M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z" }), _jsx("line", { x1: "12", y1: "9", x2: "12", y2: "13" }), _jsx("line", { x1: "12", y1: "17", x2: "12.01", y2: "17" })] }));
9
+ const ErrorIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: [_jsx("circle", { cx: "12", cy: "12", r: "10" }), _jsx("line", { x1: "15", y1: "9", x2: "9", y2: "15" }), _jsx("line", { x1: "9", y1: "9", x2: "15", y2: "15" })] }));
10
+ const CloseIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", children: [_jsx("line", { x1: "18", y1: "6", x2: "6", y2: "18" }), _jsx("line", { x1: "6", y1: "6", x2: "18", y2: "18" })] }));
11
+ const getDefaultIcon = (type) => {
12
+ switch (type) {
13
+ case 'info':
14
+ return _jsx(InfoIcon, {});
15
+ case 'success':
16
+ return _jsx(SuccessIcon, {});
17
+ case 'warning':
18
+ return _jsx(WarningIcon, {});
19
+ case 'error':
20
+ return _jsx(ErrorIcon, {});
21
+ default:
22
+ return _jsx(InfoIcon, {});
23
+ }
24
+ };
25
+ export const AlertBanner = forwardRef(function AlertBannerComponent(props, ref) {
26
+ const { children, type = 'info', variant = 'inline', size = 'medium', isOpen = true, onClose, hideDismissButton = false, icon, showIcon = true, action, title, autoDismiss, animated = true, className, ...rest } = props;
27
+ // Auto dismiss
28
+ useEffect(() => {
29
+ if (autoDismiss && isOpen && onClose) {
30
+ const timer = setTimeout(() => {
31
+ onClose();
32
+ }, autoDismiss);
33
+ return () => clearTimeout(timer);
34
+ }
35
+ }, [autoDismiss, isOpen, onClose]);
36
+ const handleClose = useCallback((e) => {
37
+ onClose?.(e);
38
+ }, [onClose]);
39
+ const handleAction = useCallback(() => {
40
+ action?.onClick?.();
41
+ }, [action]);
42
+ const displayIcon = icon || (showIcon ? getDefaultIcon(type) : null);
43
+ return (_jsxs(AlertBannerContainer, { ref: ref, "$type": type, "$variant": variant, "$size": size, "$isOpen": isOpen, "$animated": animated, role: "alert", "aria-live": "polite", "data-aui": "alert-banner", className: className, ...rest, children: [displayIcon && (_jsx(IconWrapper, { "$type": type, "$size": size, "aria-hidden": "true", children: displayIcon })), _jsxs(ContentWrapper, { children: [title && _jsx(Title, { "$size": size, children: title }), _jsx(Message, { children: children })] }), _jsxs(ActionsWrapper, { children: [action && (_jsx(ActionButton, { "$type": type, onClick: handleAction, "aria-label": action.ariaLabel || action.text, children: action.text })), !hideDismissButton && onClose && (_jsx(DismissButton, { "$type": type, "$size": size, onClick: handleClose, "aria-label": "Dismiss alert", children: _jsx(CloseIcon, {}) }))] })] }));
44
+ });
45
+ AlertBanner.displayName = 'AlertBanner';
@@ -0,0 +1,27 @@
1
+ /// <reference types="react" />
2
+ import { AlertBannerType, AlertBannerVariant, AlertBannerSize } from './types';
3
+ export declare const AlertBannerContainer: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {
4
+ $type: AlertBannerType;
5
+ $variant: AlertBannerVariant;
6
+ $size: AlertBannerSize;
7
+ $isOpen: boolean;
8
+ $animated: boolean;
9
+ }>> & string;
10
+ export declare const IconWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, {
11
+ $type: AlertBannerType;
12
+ $size: AlertBannerSize;
13
+ }>> & string;
14
+ export declare const ContentWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
15
+ export declare const Title: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, {
16
+ $size: AlertBannerSize;
17
+ }>> & string;
18
+ export declare const Message: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
19
+ export declare const ActionsWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
20
+ export declare const ActionButton: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {
21
+ $type: AlertBannerType;
22
+ }>> & string;
23
+ export declare const DismissButton: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {
24
+ $type: AlertBannerType;
25
+ $size: AlertBannerSize;
26
+ }>> & string;
27
+ //# sourceMappingURL=elements.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"elements.d.ts","sourceRoot":"","sources":["../../../../../../src/core-components/src/components/AlertBanner/elements.tsx"],"names":[],"mappings":";AAGA,OAAO,EAAC,eAAe,EAAE,kBAAkB,EAAE,eAAe,EAAC,MAAM,SAAS,CAAC;AAoF7E,eAAO,MAAM,oBAAoB;WACxB,eAAe;cACZ,kBAAkB;WACrB,eAAe;aACb,OAAO;eACL,OAAO;YA6DnB,CAAC;AAEF,eAAO,MAAM,WAAW;WACf,eAAe;WACf,eAAe;YAcvB,CAAC;AAEF,eAAO,MAAM,cAAc,6NAM1B,CAAC;AAEF,eAAO,MAAM,KAAK;WACT,eAAe;YAOvB,CAAC;AAEF,eAAO,MAAM,OAAO,6NAEnB,CAAC;AAEF,eAAO,MAAM,cAAc,6NAY1B,CAAC;AAEF,eAAO,MAAM,YAAY;WAChB,eAAe;YAqBvB,CAAC;AAEF,eAAO,MAAM,aAAa;WACjB,eAAe;WACf,eAAe;YA+BvB,CAAC"}
@@ -0,0 +1,233 @@
1
+ import { styled, css, keyframes } from 'styled-components';
2
+ import { tokens } from '../../utils/designTokens';
3
+ import { breakpoints } from '../../utils/abstracts';
4
+ // Animations
5
+ const slideIn = keyframes `
6
+ from {
7
+ opacity: 0;
8
+ transform: translateY(-100%);
9
+ }
10
+ to {
11
+ opacity: 1;
12
+ transform: translateY(0);
13
+ }
14
+ `;
15
+ const slideOut = keyframes `
16
+ from {
17
+ opacity: 1;
18
+ transform: translateY(0);
19
+ }
20
+ to {
21
+ opacity: 0;
22
+ transform: translateY(-100%);
23
+ }
24
+ `;
25
+ // Type colors
26
+ const typeStyles = {
27
+ info: {
28
+ bg: '#e7f3ff',
29
+ border: '#3b82f6',
30
+ text: '#1e40af',
31
+ icon: '#3b82f6',
32
+ },
33
+ success: {
34
+ bg: '#ecfdf5',
35
+ border: '#10b981',
36
+ text: '#065f46',
37
+ icon: '#10b981',
38
+ },
39
+ warning: {
40
+ bg: '#fffbeb',
41
+ border: '#f59e0b',
42
+ text: '#92400e',
43
+ icon: '#f59e0b',
44
+ },
45
+ error: {
46
+ bg: '#fef2f2',
47
+ border: '#ef4444',
48
+ text: '#991b1b',
49
+ icon: '#ef4444',
50
+ },
51
+ default: {
52
+ bg: tokens.surface || '#f8f9fa',
53
+ border: tokens.outline || '#e9ecef',
54
+ text: tokens.onSurface || '#1a1a2e',
55
+ icon: tokens.primary || '#454cbf',
56
+ },
57
+ dark: {
58
+ bg: '#1f2937',
59
+ border: '#374151',
60
+ text: '#f9fafb',
61
+ icon: '#9ca3af',
62
+ },
63
+ };
64
+ // Size styles
65
+ const sizeStyles = {
66
+ small: {
67
+ padding: '0.5rem 0.75rem',
68
+ fontSize: '0.8125rem',
69
+ iconSize: '16px',
70
+ },
71
+ medium: {
72
+ padding: '0.75rem 1rem',
73
+ fontSize: '0.875rem',
74
+ iconSize: '20px',
75
+ },
76
+ large: {
77
+ padding: '1rem 1.25rem',
78
+ fontSize: '1rem',
79
+ iconSize: '24px',
80
+ },
81
+ };
82
+ export const AlertBannerContainer = styled.div `
83
+ display: ${({ $isOpen }) => ($isOpen ? 'flex' : 'none')};
84
+ align-items: flex-start;
85
+ gap: ${tokens.spacing100 || '0.5rem'};
86
+ width: 100%;
87
+ box-sizing: border-box;
88
+
89
+ /* Type colors */
90
+ background: ${({ $type }) => typeStyles[$type].bg};
91
+ border: 1px solid ${({ $type }) => typeStyles[$type].border};
92
+ color: ${({ $type }) => typeStyles[$type].text};
93
+
94
+ /* Size styles */
95
+ padding: ${({ $size }) => sizeStyles[$size].padding};
96
+ font-size: ${({ $size }) => sizeStyles[$size].fontSize};
97
+
98
+ /* Variant styles */
99
+ ${({ $variant }) => $variant === 'banner' &&
100
+ css `
101
+ border-radius: 0;
102
+ border-left: none;
103
+ border-right: none;
104
+ `}
105
+
106
+ ${({ $variant }) => $variant === 'inline' &&
107
+ css `
108
+ border-radius: ${tokens.borderRadius100 || '8px'};
109
+ `}
110
+
111
+ ${({ $variant }) => $variant === 'floating' &&
112
+ css `
113
+ border-radius: ${tokens.borderRadius100 || '8px'};
114
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
115
+ position: fixed;
116
+ top: 1rem;
117
+ left: 50%;
118
+ transform: translateX(-50%);
119
+ max-width: calc(100% - 2rem);
120
+ z-index: 1000;
121
+
122
+ ${breakpoints.md} {
123
+ max-width: 600px;
124
+ }
125
+ `}
126
+
127
+ /* Animation */
128
+ ${({ $animated, $isOpen }) => $animated &&
129
+ css `
130
+ animation: ${$isOpen ? slideIn : slideOut} 0.3s ease-out;
131
+ `}
132
+
133
+ /* Responsive */
134
+ ${breakpoints.xs} {
135
+ flex-direction: column;
136
+ align-items: stretch;
137
+ }
138
+ `;
139
+ export const IconWrapper = styled.span `
140
+ display: flex;
141
+ align-items: center;
142
+ justify-content: center;
143
+ flex-shrink: 0;
144
+ color: ${({ $type }) => typeStyles[$type].icon};
145
+ width: ${({ $size }) => sizeStyles[$size].iconSize};
146
+ height: ${({ $size }) => sizeStyles[$size].iconSize};
147
+
148
+ svg {
149
+ width: 100%;
150
+ height: 100%;
151
+ }
152
+ `;
153
+ export const ContentWrapper = styled.div `
154
+ flex: 1;
155
+ display: flex;
156
+ flex-direction: column;
157
+ gap: ${tokens.spacing050 || '0.25rem'};
158
+ min-width: 0;
159
+ `;
160
+ export const Title = styled.strong `
161
+ font-weight: 600;
162
+ font-size: ${({ $size }) => $size === 'small' ? '0.875rem' :
163
+ $size === 'large' ? '1.125rem' : '1rem'};
164
+ line-height: 1.4;
165
+ `;
166
+ export const Message = styled.div `
167
+ line-height: 1.5;
168
+ `;
169
+ export const ActionsWrapper = styled.div `
170
+ display: flex;
171
+ align-items: center;
172
+ gap: ${tokens.spacing100 || '0.5rem'};
173
+ flex-shrink: 0;
174
+ margin-left: auto;
175
+
176
+ ${breakpoints.xs} {
177
+ margin-left: 0;
178
+ margin-top: ${tokens.spacing100 || '0.5rem'};
179
+ justify-content: flex-end;
180
+ }
181
+ `;
182
+ export const ActionButton = styled.button `
183
+ background: transparent;
184
+ border: 1px solid ${({ $type }) => typeStyles[$type].border};
185
+ color: ${({ $type }) => typeStyles[$type].text};
186
+ padding: 0.375rem 0.75rem;
187
+ border-radius: ${tokens.borderRadius050 || '4px'};
188
+ font-size: 0.8125rem;
189
+ font-weight: 500;
190
+ cursor: pointer;
191
+ transition: all 0.2s ease;
192
+ white-space: nowrap;
193
+
194
+ &:hover {
195
+ background: ${({ $type }) => typeStyles[$type].border}20;
196
+ }
197
+
198
+ &:focus-visible {
199
+ outline: 2px solid ${({ $type }) => typeStyles[$type].border};
200
+ outline-offset: 2px;
201
+ }
202
+ `;
203
+ export const DismissButton = styled.button `
204
+ display: flex;
205
+ align-items: center;
206
+ justify-content: center;
207
+ background: transparent;
208
+ border: none;
209
+ color: ${({ $type }) => typeStyles[$type].text};
210
+ padding: 0.25rem;
211
+ border-radius: ${tokens.borderRadius050 || '4px'};
212
+ cursor: pointer;
213
+ transition: all 0.2s ease;
214
+ opacity: 0.7;
215
+ flex-shrink: 0;
216
+ width: ${({ $size }) => sizeStyles[$size].iconSize};
217
+ height: ${({ $size }) => sizeStyles[$size].iconSize};
218
+
219
+ &:hover {
220
+ opacity: 1;
221
+ background: ${({ $type }) => typeStyles[$type].border}20;
222
+ }
223
+
224
+ &:focus-visible {
225
+ outline: 2px solid ${({ $type }) => typeStyles[$type].border};
226
+ outline-offset: 2px;
227
+ }
228
+
229
+ svg {
230
+ width: 100%;
231
+ height: 100%;
232
+ }
233
+ `;
@@ -0,0 +1,3 @@
1
+ export { AlertBanner } from './AlertBanner';
2
+ export * from './types';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/core-components/src/components/AlertBanner/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAC,MAAM,eAAe,CAAC;AAC1C,cAAc,SAAS,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { AlertBanner } from './AlertBanner';
2
+ export * from './types';
@@ -0,0 +1,46 @@
1
+ import React from 'react';
2
+ export declare const ALERT_BANNER_TYPES: readonly ["info", "success", "warning", "error", "default", "dark"];
3
+ export type AlertBannerType = (typeof ALERT_BANNER_TYPES)[number];
4
+ export declare const ALERT_BANNER_VARIANTS: readonly ["banner", "inline", "floating"];
5
+ export type AlertBannerVariant = (typeof ALERT_BANNER_VARIANTS)[number];
6
+ export declare const ALERT_BANNER_SIZES: readonly ["small", "medium", "large"];
7
+ export type AlertBannerSize = (typeof ALERT_BANNER_SIZES)[number];
8
+ export interface AlertBannerActionProps {
9
+ /** Action button text */
10
+ text: string;
11
+ /** Action button click handler */
12
+ onClick?: () => void;
13
+ /** ARIA label for the action button */
14
+ ariaLabel?: string;
15
+ }
16
+ export interface AlertBannerProps extends React.HTMLAttributes<HTMLDivElement> {
17
+ /** Children content */
18
+ children?: React.ReactNode;
19
+ /** Alert type determines colors and default icon */
20
+ type?: AlertBannerType;
21
+ /** Display variant */
22
+ variant?: AlertBannerVariant;
23
+ /** Size of the alert */
24
+ size?: AlertBannerSize;
25
+ /** Whether the alert is visible */
26
+ isOpen?: boolean;
27
+ /** Dismiss button click handler */
28
+ onClose?: (e?: React.MouseEvent<HTMLButtonElement>) => void;
29
+ /** Hide the dismiss button */
30
+ hideDismissButton?: boolean;
31
+ /** Custom icon element */
32
+ icon?: React.ReactNode;
33
+ /** Show default icon based on type */
34
+ showIcon?: boolean;
35
+ /** Action button configuration */
36
+ action?: AlertBannerActionProps;
37
+ /** Title text */
38
+ title?: string;
39
+ /** Auto dismiss after duration (ms) */
40
+ autoDismiss?: number;
41
+ /** Animation on enter/exit */
42
+ animated?: boolean;
43
+ /** Additional class names */
44
+ className?: string;
45
+ }
46
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/core-components/src/components/AlertBanner/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,eAAO,MAAM,kBAAkB,qEAOrB,CAAC;AACX,MAAM,MAAM,eAAe,GAAG,CAAC,OAAO,kBAAkB,CAAC,CAAC,MAAM,CAAC,CAAC;AAElE,eAAO,MAAM,qBAAqB,2CAA4C,CAAC;AAC/E,MAAM,MAAM,kBAAkB,GAAG,CAAC,OAAO,qBAAqB,CAAC,CAAC,MAAM,CAAC,CAAC;AAExE,eAAO,MAAM,kBAAkB,uCAAwC,CAAC;AACxE,MAAM,MAAM,eAAe,GAAG,CAAC,OAAO,kBAAkB,CAAC,CAAC,MAAM,CAAC,CAAC;AAElE,MAAM,WAAW,sBAAsB;IACrC,yBAAyB;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,kCAAkC;IAClC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,uCAAuC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,gBAAiB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5E,uBAAuB;IACvB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,oDAAoD;IACpD,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,sBAAsB;IACtB,OAAO,CAAC,EAAE,kBAAkB,CAAC;IAC7B,wBAAwB;IACxB,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,mCAAmC;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,mCAAmC;IACnC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC5D,8BAA8B;IAC9B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,0BAA0B;IAC1B,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,sCAAsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kCAAkC;IAClC,MAAM,CAAC,EAAE,sBAAsB,CAAC;IAChC,iBAAiB;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,uCAAuC;IACvC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,8BAA8B;IAC9B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,6BAA6B;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB"}
@@ -0,0 +1,10 @@
1
+ export const ALERT_BANNER_TYPES = [
2
+ 'info',
3
+ 'success',
4
+ 'warning',
5
+ 'error',
6
+ 'default',
7
+ 'dark',
8
+ ];
9
+ export const ALERT_BANNER_VARIANTS = ['banner', 'inline', 'floating'];
10
+ export const ALERT_BANNER_SIZES = ['small', 'medium', 'large'];
@@ -1 +1 @@
1
- {"version":3,"file":"auto-complete-filter-multi-select-selected-top-display.component.d.ts","sourceRoot":"","sources":["../../../../../../../src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-selected-top-display/auto-complete-filter-multi-select-selected-top-display.component.tsx"],"names":[],"mappings":"AAQA,MAAM,WAAW,oDAAoD;IACnE,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,GAAG,CAAC;IACV,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC;IACxC,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;IAC/B,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,eAAO,MAAM,+CAA+C,gKAezD,oDAAoD,4CAsftD,CAAC"}
1
+ {"version":3,"file":"auto-complete-filter-multi-select-selected-top-display.component.d.ts","sourceRoot":"","sources":["../../../../../../../src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-selected-top-display/auto-complete-filter-multi-select-selected-top-display.component.tsx"],"names":[],"mappings":"AAQA,MAAM,WAAW,oDAAoD;IACnE,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,GAAG,CAAC;IACV,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC;IACxC,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;IAC/B,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,eAAO,MAAM,+CAA+C,gKAezD,oDAAoD,4CA2iBtD,CAAC"}
@@ -16,7 +16,26 @@ export const AutoCompleteFilterMultiSelectSelectedTopDisplay = ({ uniqueField =
16
16
  if (ref.current && !ref.current.contains(event.target) && isListOpen) {
17
17
  if (originalOptions && options) {
18
18
  if (isListOpen) {
19
- onUpdate && onUpdate(options.filter((item) => item.selected));
19
+ const newSelectedItems = options.filter((item) => item.selected);
20
+ // Merge: combine new selected with existing selected that are not in current options
21
+ const existingSelected = data.selected || [];
22
+ const mergedMap = new Map();
23
+ // Add new selected items from options
24
+ newSelectedItems.forEach((item) => {
25
+ mergedMap.set(item[uniqueField], item);
26
+ });
27
+ // Add existing selected items that are NOT in the current options list
28
+ // (these are filtered out items that should remain selected)
29
+ existingSelected.forEach((item) => {
30
+ const existsInOptions = options.some((opt) => opt[uniqueField] === item[uniqueField]);
31
+ // Only keep if this item is not in the current options
32
+ // (if it's in options, user already decided whether to select/unselect it)
33
+ if (!existsInOptions) {
34
+ mergedMap.set(item[uniqueField], item);
35
+ }
36
+ });
37
+ const finalSelectedItems = Array.from(mergedMap.values());
38
+ onUpdate && onUpdate(finalSelectedItems);
20
39
  }
21
40
  }
22
41
  setIsListOpen(false);
@@ -111,8 +130,26 @@ export const AutoCompleteFilterMultiSelectSelectedTopDisplay = ({ uniqueField =
111
130
  size: 16,
112
131
  color: '#000000',
113
132
  } }))] }), isListOpen && (_jsxs("div", { className: cn(s['mt-1'], s['absolute'], s['rounded-md'], s['bg-white'], s['border'], s['border-gray-300'], s['shadow-lg'], s['z-50'], s['w-full'], s['max-h-96'], s['overflow-hidden']), style: { zIndex: 1000 }, children: [_jsx("div", { className: cn(s['p-3'], s['border-b'], s['border-gray-200'], s['bg-gray-50'], s['text-sm'], s['font-medium'], s['text-gray-700']), children: _jsxs("div", { className: cn(s['flex'], s['justify-between'], s['items-center']), children: [_jsxs("span", { children: ["Total Items: ", getTotalItemsCount()] }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsxs("span", { className: cn(s['text-blue-600']), children: [getSelectedCount(), " Selected"] }), _jsx("div", { className: cn(s['flex'], s['gap-2']), children: _jsx("button", { type: "button", className: cn(s['text-xs'], s['px-3'], s['py-1'], s['bg-blue-600'], s['text-white'], s['rounded'], s['hover:bg-blue-700'], s['transition-colors']), onClick: () => {
114
- onUpdate &&
115
- onUpdate(options.filter((item) => item.selected));
133
+ const newSelectedItems = options.filter((item) => item.selected);
134
+ // Merge: combine new selected with existing selected that are not in current options
135
+ const existingSelected = data.selected || [];
136
+ const mergedMap = new Map();
137
+ // Add new selected items from options
138
+ newSelectedItems.forEach((item) => {
139
+ mergedMap.set(item[uniqueField], item);
140
+ });
141
+ // Add existing selected items that are NOT in the current options list
142
+ // (these are filtered out items that should remain selected)
143
+ existingSelected.forEach((item) => {
144
+ const existsInOptions = options.some((opt) => opt[uniqueField] === item[uniqueField]);
145
+ // Only keep if this item is not in the current options
146
+ // (if it's in options, user already decided whether to select/unselect it)
147
+ if (!existsInOptions) {
148
+ mergedMap.set(item[uniqueField], item);
149
+ }
150
+ });
151
+ const finalSelectedItems = Array.from(mergedMap.values());
152
+ onUpdate && onUpdate(finalSelectedItems);
116
153
  setIsListOpen(false);
117
154
  setValue('');
118
155
  }, children: "OK" }) })] })] }) }), showSelectAllSection && (_jsxs("div", { className: cn(s['p-3'], s['border-b'], s['border-gray-200'], s['bg-gray-50'], s['flex'], s['justify-between'], s['items-center']), children: [_jsx("span", { className: cn(s['text-sm'], s['font-medium'], s['text-gray-700']), children: "Quick Actions" }), _jsxs("div", { className: cn(s['flex'], s['gap-2']), children: [_jsx("button", { type: "button", onClick: () => handleSelect(true), className: cn(s['text-xs'], s['px-3'], s['py-1'], s['bg-green-500'], s['text-white'], s['rounded'], s['hover:bg-green-600'], s['transition-colors'], getAvailableItemsCount() === 0 && s['opacity-50'], getAvailableItemsCount() === 0 && s['cursor-not-allowed']), disabled: getAvailableItemsCount() === 0, title: "Select all available items", children: "Select All" }), _jsx("button", { type: "button", onClick: () => handleSelect(false), className: cn(s['text-xs'], s['px-3'], s['py-1'], s['bg-gray-500'], s['text-white'], s['rounded'], s['hover:bg-gray-600'], s['transition-colors'], getSelectedCount() === 0 && s['opacity-50'], getSelectedCount() === 0 && s['cursor-not-allowed']), disabled: getSelectedCount() === 0, title: "Deselect all selected items", children: "Clear All" })] })] })), _jsxs("div", { className: cn(s['max-h-80'], s['overflow-y-auto']), children: [data.selected && data.selected.length > 0 && (_jsxs("div", { className: cn(s['border-b'], s['border-gray-200']), children: [_jsx("div", { className: cn(s['p-3'], s['bg-blue-50'], s['border-b'], s['border-blue-200'], s['font-semibold'], s['text-sm'], s['text-blue-700']), children: _jsxs("div", { className: cn(s['flex'], s['items-center'], s['gap-2']), children: [_jsx(Icon, { nameIcon: "FaCheck", propsIcon: {
@@ -70,7 +70,7 @@ export interface AutoCompleteFilterMultipleSelectMultipleFieldsDisplayProps {
70
70
  /** Maximum height for dropdown (e.g., '200px', '300px'). Shows scrollbar when content exceeds this height */
71
71
  maxHeight?: string;
72
72
  onFilter?: (value: string) => void;
73
- onUpdate: (item: any) => void;
73
+ onUpdate: (selectedItems: any[]) => void;
74
74
  onSelect: (item: any) => any;
75
75
  onBlur?: (e: any) => void;
76
76
  }
@@ -1 +1 @@
1
- {"version":3,"file":"auto-complete-filter-multiple-select-multiple-fields-display.component.d.ts","sourceRoot":"","sources":["../../../../../../../src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.tsx"],"names":[],"mappings":"AACA,OAAc,EAA8B,aAAa,EAAC,MAAM,OAAO,CAAC;AAMxE,MAAM,WAAW,+DAA+D;IAC9E,8CAA8C;IAC9C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qEAAqE;IACrE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,2CAA2C;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kDAAkD;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,0DAA0D;IAC1D,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,6CAA6C;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wCAAwC;IACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,qDAAqD;IACrD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gDAAgD;IAChD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,4CAA4C;IAC5C,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,2DAA2D;IAC1E,0CAA0C;IAC1C,SAAS,CAAC,EAAE,aAAa,CAAC;IAC1B,iEAAiE;IACjE,YAAY,CAAC,EAAE,aAAa,CAAC;IAC7B,uCAAuC;IACvC,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,sDAAsD;IACtD,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,mDAAmD;IACnD,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,yCAAyC;IACzC,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,oCAAoC;IACpC,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,0CAA0C;IAC1C,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,iDAAiD;IACjD,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,4CAA4C;IAC5C,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,gDAAgD;IAChD,WAAW,CAAC,EAAE,aAAa,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,0DAA0D;IACzE,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,GAAG,CAAC;IACV,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,4CAA4C;IAC5C,UAAU,CAAC,EAAE,+DAA+D,CAAC;IAC7E,+CAA+C;IAC/C,MAAM,CAAC,EAAE,2DAA2D,CAAC;IACrE,6GAA6G;IAC7G,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;IAC9B,QAAQ,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,GAAG,CAAC;IAC7B,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;CAC3B;AAED,eAAO,MAAM,qDAAqD,kLAiB/D,0DAA0D,4CA0P5D,CAAC"}
1
+ {"version":3,"file":"auto-complete-filter-multiple-select-multiple-fields-display.component.d.ts","sourceRoot":"","sources":["../../../../../../../src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.tsx"],"names":[],"mappings":"AACA,OAAc,EAA8B,aAAa,EAAC,MAAM,OAAO,CAAC;AAMxE,MAAM,WAAW,+DAA+D;IAC9E,8CAA8C;IAC9C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qEAAqE;IACrE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,2CAA2C;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kDAAkD;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,0DAA0D;IAC1D,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,6CAA6C;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wCAAwC;IACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,qDAAqD;IACrD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gDAAgD;IAChD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,4CAA4C;IAC5C,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,2DAA2D;IAC1E,0CAA0C;IAC1C,SAAS,CAAC,EAAE,aAAa,CAAC;IAC1B,iEAAiE;IACjE,YAAY,CAAC,EAAE,aAAa,CAAC;IAC7B,uCAAuC;IACvC,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,sDAAsD;IACtD,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,mDAAmD;IACnD,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,yCAAyC;IACzC,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,oCAAoC;IACpC,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,0CAA0C;IAC1C,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,iDAAiD;IACjD,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,4CAA4C;IAC5C,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,gDAAgD;IAChD,WAAW,CAAC,EAAE,aAAa,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,0DAA0D;IACzE,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,GAAG,CAAC;IACV,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,4CAA4C;IAC5C,UAAU,CAAC,EAAE,+DAA+D,CAAC;IAC7E,+CAA+C;IAC/C,MAAM,CAAC,EAAE,2DAA2D,CAAC;IACrE,6GAA6G;IAC7G,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,QAAQ,EAAE,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC;IACzC,QAAQ,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,GAAG,CAAC;IAC7B,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;CAC3B;AAED,eAAO,MAAM,qDAAqD,kLAiB/D,0DAA0D,4CAoR5D,CAAC"}
@@ -16,7 +16,32 @@ export const AutoCompleteFilterMultipleSelectMultipleFieldsDisplay = ({ uniqueFi
16
16
  if (ref.current && !ref.current.contains(event.target) && isListOpen) {
17
17
  if (originalOptions && options) {
18
18
  if (isListOpen) {
19
- onUpdate && onUpdate(data.selected);
19
+ const newSelectedItems = options.filter((item) => item.selected);
20
+ // Merge: combine new selected with existing selected that are not in current options
21
+ const existingSelected = data.selected || [];
22
+ const mergedMap = new Map();
23
+ // Add new selected items from options
24
+ newSelectedItems.forEach((item) => {
25
+ mergedMap.set(item[uniqueField], item);
26
+ });
27
+ // Add existing selected items that are NOT in the current options list
28
+ // (these are filtered out items that should remain selected)
29
+ existingSelected.forEach((item) => {
30
+ const key = isSelectedStringArray ? item : item[uniqueField];
31
+ const existsInOptions = options.some((opt) => {
32
+ if (isSelectedStringArray) {
33
+ return opt[uniqueField] === item;
34
+ }
35
+ return opt[uniqueField] === item[uniqueField];
36
+ });
37
+ // Only keep if this item is not in the current options
38
+ // (if it's in options, user already decided whether to select/unselect it)
39
+ if (!existsInOptions) {
40
+ mergedMap.set(key, item);
41
+ }
42
+ });
43
+ const finalSelectedItems = Array.from(mergedMap.values());
44
+ onUpdate && onUpdate(finalSelectedItems);
20
45
  }
21
46
  }
22
47
  setIsListOpen(false);