@itilite/lumina-ui 0.0.323 → 1.0.0-alpha

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 (273) hide show
  1. package/README.md +43 -10
  2. package/dist/AdvancedDateRangePicker-CN9WN0rH.d.mts +56 -0
  3. package/dist/AdvancedDateRangePicker-CN9WN0rH.d.ts +56 -0
  4. package/dist/AdvancedDateRangePicker-CzN1HGsC.d.mts +57 -0
  5. package/dist/AdvancedDateRangePicker-CzN1HGsC.d.ts +57 -0
  6. package/dist/AdvancedDateRangePicker-DAPxgRl3.d.mts +54 -0
  7. package/dist/AdvancedDateRangePicker-DAPxgRl3.d.ts +54 -0
  8. package/dist/AdvancedDateRangePicker-DW94285G.d.mts +56 -0
  9. package/dist/AdvancedDateRangePicker-DW94285G.d.ts +56 -0
  10. package/dist/AdvancedDateRangePicker-Eh6n4ne0.d.mts +57 -0
  11. package/dist/AdvancedDateRangePicker-Eh6n4ne0.d.ts +57 -0
  12. package/dist/Avatar-DX2JwvAs.d.mts +17 -0
  13. package/dist/Avatar-DX2JwvAs.d.ts +17 -0
  14. package/dist/Table-BA0D3p1m.d.mts +78 -0
  15. package/dist/Table-BA0D3p1m.d.ts +78 -0
  16. package/dist/Table-BLZ6c46U.d.mts +77 -0
  17. package/dist/Table-BLZ6c46U.d.ts +77 -0
  18. package/dist/Table-BMqYnFi4.d.mts +25 -0
  19. package/dist/Table-BMqYnFi4.d.ts +25 -0
  20. package/dist/Table-BOq-_9Nr.d.mts +121 -0
  21. package/dist/Table-BOq-_9Nr.d.ts +121 -0
  22. package/dist/Table-BRcthrYV.d.mts +98 -0
  23. package/dist/Table-BRcthrYV.d.ts +98 -0
  24. package/dist/Table-BWlFCfBG.d.mts +106 -0
  25. package/dist/Table-BWlFCfBG.d.ts +106 -0
  26. package/dist/Table-CHFmNrme.d.mts +77 -0
  27. package/dist/Table-CHFmNrme.d.ts +77 -0
  28. package/dist/Table-CX6UwQiD.d.mts +116 -0
  29. package/dist/Table-CX6UwQiD.d.ts +116 -0
  30. package/dist/Table-Chud2XSq.d.mts +99 -0
  31. package/dist/Table-Chud2XSq.d.ts +99 -0
  32. package/dist/Table-D5QRe_j3.d.mts +121 -0
  33. package/dist/Table-D5QRe_j3.d.ts +121 -0
  34. package/dist/Table-DAgFGahx.d.mts +39 -0
  35. package/dist/Table-DAgFGahx.d.ts +39 -0
  36. package/dist/Table-DWniK7At.d.mts +87 -0
  37. package/dist/Table-DWniK7At.d.ts +87 -0
  38. package/dist/Table-PyFlnUDu.d.mts +47 -0
  39. package/dist/Table-PyFlnUDu.d.ts +47 -0
  40. package/dist/Table-wqyg13Y9.d.mts +77 -0
  41. package/dist/Table-wqyg13Y9.d.ts +77 -0
  42. package/dist/Tag-l7I5oeyk.d.mts +13 -0
  43. package/dist/Tag-l7I5oeyk.d.ts +13 -0
  44. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.d.mts +2 -0
  45. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.d.ts +2 -0
  46. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.js +791 -0
  47. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.mjs +11 -0
  48. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.d.mts +18 -0
  49. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.d.ts +18 -0
  50. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.js +370 -0
  51. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.mjs +8 -0
  52. package/dist/atom/Avatar/Avatar.d.mts +9 -0
  53. package/dist/atom/Avatar/Avatar.d.ts +9 -0
  54. package/dist/atom/Avatar/Avatar.js +123 -0
  55. package/dist/atom/Avatar/Avatar.mjs +9 -0
  56. package/dist/{Button.js → atom/Button/Button.js} +4 -4
  57. package/dist/{Button.mjs → atom/Button/Button.mjs} +2 -2
  58. package/dist/{Checkbox.js → atom/Checkbox/Checkbox.js} +4 -4
  59. package/dist/{Checkbox.mjs → atom/Checkbox/Checkbox.mjs} +2 -2
  60. package/dist/atom/LoadingSpinner/LoadingSpinner.d.mts +19 -0
  61. package/dist/atom/LoadingSpinner/LoadingSpinner.d.ts +19 -0
  62. package/dist/atom/LoadingSpinner/LoadingSpinner.js +90 -0
  63. package/dist/atom/LoadingSpinner/LoadingSpinner.mjs +9 -0
  64. package/dist/atom/Modal/Modal.d.mts +25 -0
  65. package/dist/atom/Modal/Modal.d.ts +25 -0
  66. package/dist/atom/Modal/Modal.js +267 -0
  67. package/dist/atom/Modal/Modal.mjs +10 -0
  68. package/dist/atom/Radio/Radio.d.mts +17 -0
  69. package/dist/atom/Radio/Radio.d.ts +17 -0
  70. package/dist/atom/Radio/Radio.js +122 -0
  71. package/dist/atom/Radio/Radio.mjs +9 -0
  72. package/dist/atom/RangePicker/Chevron.d.mts +13 -0
  73. package/dist/atom/RangePicker/Chevron.d.ts +13 -0
  74. package/dist/atom/RangePicker/Chevron.js +110 -0
  75. package/dist/atom/RangePicker/Chevron.mjs +7 -0
  76. package/dist/atom/RangePicker/RangePicker.d.mts +26 -0
  77. package/dist/atom/RangePicker/RangePicker.d.ts +26 -0
  78. package/dist/atom/RangePicker/RangePicker.js +1465 -0
  79. package/dist/atom/RangePicker/RangePicker.mjs +13 -0
  80. package/dist/atom/Select/Select.d.mts +40 -0
  81. package/dist/atom/Select/Select.d.ts +40 -0
  82. package/dist/atom/Select/Select.js +805 -0
  83. package/dist/atom/Select/Select.mjs +11 -0
  84. package/dist/atom/Slider/Slider.d.mts +34 -0
  85. package/dist/atom/Slider/Slider.d.ts +34 -0
  86. package/dist/atom/Slider/Slider.js +107 -0
  87. package/dist/atom/Slider/Slider.mjs +9 -0
  88. package/dist/atom/Switch/Switch.d.mts +13 -0
  89. package/dist/atom/Switch/Switch.d.ts +13 -0
  90. package/dist/atom/Switch/Switch.js +102 -0
  91. package/dist/atom/Switch/Switch.mjs +9 -0
  92. package/dist/atom/Table/LuminaPagination.d.mts +7 -0
  93. package/dist/atom/Table/LuminaPagination.d.ts +7 -0
  94. package/dist/atom/Table/LuminaPagination.js +153 -0
  95. package/dist/atom/Table/LuminaPagination.mjs +9 -0
  96. package/dist/atom/Table/Table.d.mts +3 -0
  97. package/dist/atom/Table/Table.d.ts +3 -0
  98. package/dist/atom/Table/Table.js +306 -0
  99. package/dist/atom/Table/Table.mjs +9 -0
  100. package/dist/atom/Table/TableAccordion.d.mts +9 -0
  101. package/dist/atom/Table/TableAccordion.d.ts +9 -0
  102. package/dist/atom/Table/TableAccordion.js +91 -0
  103. package/dist/atom/Table/TableAccordion.mjs +10 -0
  104. package/dist/atom/Table/TableColumnHeader.d.mts +7 -0
  105. package/dist/atom/Table/TableColumnHeader.d.ts +7 -0
  106. package/dist/atom/Table/TableColumnHeader.js +151 -0
  107. package/dist/atom/Table/TableColumnHeader.mjs +10 -0
  108. package/dist/atom/Table/TableToolbar.d.mts +9 -0
  109. package/dist/atom/Table/TableToolbar.d.ts +9 -0
  110. package/dist/atom/Table/TableToolbar.js +114 -0
  111. package/dist/atom/Table/TableToolbar.mjs +10 -0
  112. package/dist/atom/Table/__tests__/Table.test.d.mts +2 -0
  113. package/dist/atom/Table/__tests__/Table.test.d.ts +2 -0
  114. package/dist/atom/Table/__tests__/Table.test.js +61133 -0
  115. package/dist/atom/Table/__tests__/Table.test.mjs +59522 -0
  116. package/dist/atom/TableAccordion/index.d.mts +17 -0
  117. package/dist/atom/TableAccordion/index.d.ts +17 -0
  118. package/dist/atom/TableAccordion/index.js +91 -0
  119. package/dist/atom/TableAccordion/index.mjs +9 -0
  120. package/dist/atom/TableToolbar/index.d.mts +23 -0
  121. package/dist/atom/TableToolbar/index.d.ts +23 -0
  122. package/dist/atom/TableToolbar/index.js +114 -0
  123. package/dist/atom/TableToolbar/index.mjs +9 -0
  124. package/dist/atom/Tag/Tag.d.mts +6 -0
  125. package/dist/atom/Tag/Tag.d.ts +6 -0
  126. package/dist/atom/Tag/Tag.js +108 -0
  127. package/dist/atom/Tag/Tag.mjs +9 -0
  128. package/dist/atom/Tooltip/Tooltip.d.mts +12 -0
  129. package/dist/atom/Tooltip/Tooltip.d.ts +12 -0
  130. package/dist/atom/Tooltip/Tooltip.js +97 -0
  131. package/dist/atom/Tooltip/Tooltip.mjs +9 -0
  132. package/dist/chunk-2EBPXGRY.mjs +65 -0
  133. package/dist/chunk-2PIFDGVK.mjs +420 -0
  134. package/dist/chunk-35KDS27M.mjs +618 -0
  135. package/dist/chunk-3S4X3YO2.mjs +64 -0
  136. package/dist/chunk-3XUHGVYA.mjs +77 -0
  137. package/dist/chunk-4JX54OKI.mjs +627 -0
  138. package/dist/chunk-4VZB2KR2.mjs +51 -0
  139. package/dist/chunk-5HF6Y37C.mjs +642 -0
  140. package/dist/chunk-5OGQ4YIR.mjs +238 -0
  141. package/dist/chunk-6FCSXN7R.mjs +388 -0
  142. package/dist/chunk-7W72LPSU.mjs +66 -0
  143. package/dist/chunk-A66QDQHK.mjs +627 -0
  144. package/dist/chunk-ABLIL47F.mjs +618 -0
  145. package/dist/chunk-AEPDEUGY.mjs +627 -0
  146. package/dist/chunk-AF2RKLH6.mjs +77 -0
  147. package/dist/chunk-AFLEGUF3.mjs +232 -0
  148. package/dist/chunk-APCEITHQ.mjs +232 -0
  149. package/dist/chunk-AVQBFGBT.mjs +141 -0
  150. package/dist/chunk-B5BOBELW.mjs +213 -0
  151. package/dist/chunk-BQ4PVLJ4.mjs +262 -0
  152. package/dist/chunk-D3N7VFER.mjs +73 -0
  153. package/dist/{chunk-OMYHSSPQ.mjs → chunk-DBNLBCQK.mjs} +5 -5
  154. package/dist/chunk-DLLT6V65.mjs +141 -0
  155. package/dist/chunk-DOQQRYTS.mjs +73 -0
  156. package/dist/chunk-DSVR2DVF.mjs +660 -0
  157. package/dist/chunk-DXUPULDI.mjs +424 -0
  158. package/dist/chunk-E465D6OH.mjs +644 -0
  159. package/dist/chunk-E4FCLHYA.mjs +678 -0
  160. package/dist/chunk-ENQN5BAN.mjs +225 -0
  161. package/dist/chunk-F6VMSH4N.mjs +79 -0
  162. package/dist/chunk-FKGGN3FA.mjs +412 -0
  163. package/dist/chunk-GFTO2N3Q.mjs +432 -0
  164. package/dist/chunk-GM6H6RPJ.mjs +232 -0
  165. package/dist/chunk-GU5F7Z7I.mjs +681 -0
  166. package/dist/chunk-HF3VJBMY.mjs +244 -0
  167. package/dist/{chunk-ME35H7QC.mjs → chunk-HISCHZ5H.mjs} +4 -4
  168. package/dist/chunk-HWQBE6PT.mjs +99 -0
  169. package/dist/chunk-HXM657YW.mjs +115 -0
  170. package/dist/chunk-I5VHKSQR.mjs +64 -0
  171. package/dist/chunk-ICSZZNTY.mjs +384 -0
  172. package/dist/chunk-IWO2Y5QX.mjs +89 -0
  173. package/dist/chunk-IZGLD7U3.mjs +667 -0
  174. package/dist/chunk-J7X2PZG6.mjs +232 -0
  175. package/dist/chunk-JUXBLRMQ.mjs +50 -0
  176. package/dist/chunk-JXFSGADI.mjs +678 -0
  177. package/dist/chunk-KGKRSR6D.mjs +388 -0
  178. package/dist/chunk-KQKNFGWZ.mjs +388 -0
  179. package/dist/chunk-LCH4DXJY.mjs +92 -0
  180. package/dist/chunk-LCXU3K57.mjs +232 -0
  181. package/dist/chunk-LRN4XOIR.mjs +71 -0
  182. package/dist/chunk-LROMXY35.mjs +116 -0
  183. package/dist/chunk-LUNPHYAR.mjs +681 -0
  184. package/dist/chunk-LVOTEPLC.mjs +64 -0
  185. package/dist/chunk-M2ZM3X5Y.mjs +56 -0
  186. package/dist/chunk-M4MIYHAV.mjs +43 -0
  187. package/dist/chunk-M7F7DOC4.mjs +41 -0
  188. package/dist/chunk-MHWFVML4.mjs +115 -0
  189. package/dist/chunk-MLCMZRUC.mjs +50 -0
  190. package/dist/chunk-MNARBWAJ.mjs +47 -0
  191. package/dist/chunk-MPTVYTYS.mjs +0 -0
  192. package/dist/chunk-MQFW3LZR.mjs +111 -0
  193. package/dist/chunk-N2WTNCQU.mjs +66 -0
  194. package/dist/chunk-N355RJGH.mjs +141 -0
  195. package/dist/chunk-N3YFQDW7.mjs +77 -0
  196. package/dist/chunk-N4DPPZVJ.mjs +269 -0
  197. package/dist/chunk-NGCBOOIE.mjs +225 -0
  198. package/dist/chunk-NWQQYJSP.mjs +688 -0
  199. package/dist/chunk-NYQV556V.mjs +667 -0
  200. package/dist/chunk-O5C3355V.mjs +246 -0
  201. package/dist/chunk-OCP43S7U.mjs +241 -0
  202. package/dist/chunk-OHLFRULE.mjs +432 -0
  203. package/dist/chunk-PLO46EKV.mjs +65 -0
  204. package/dist/chunk-PQ3B2FEB.mjs +249 -0
  205. package/dist/chunk-PSBEYGD4.mjs +618 -0
  206. package/dist/chunk-PWIBJI6Z.mjs +115 -0
  207. package/dist/chunk-Q5KPXEH5.mjs +223 -0
  208. package/dist/chunk-QC34HHAY.mjs +57 -0
  209. package/dist/chunk-QKTMWS4J.mjs +43 -0
  210. package/dist/chunk-QVWV36BK.mjs +73 -0
  211. package/dist/chunk-QWK3MYDM.mjs +64 -0
  212. package/dist/chunk-RE44YAMD.mjs +47 -0
  213. package/dist/chunk-RH6DAYBU.mjs +369 -0
  214. package/dist/chunk-RSSEJENT.mjs +269 -0
  215. package/dist/chunk-SJBS5QCJ.mjs +225 -0
  216. package/dist/chunk-SWRFCTJW.mjs +77 -0
  217. package/dist/chunk-T4XNCAIB.mjs +231 -0
  218. package/dist/chunk-TCX5IFQ4.mjs +627 -0
  219. package/dist/chunk-TSAUBT2F.mjs +74 -0
  220. package/dist/chunk-U7Q7ILSE.mjs +690 -0
  221. package/dist/chunk-UHTUJJH7.mjs +112 -0
  222. package/dist/chunk-UOHYCMUS.mjs +53 -0
  223. package/dist/chunk-UQJ3BDM4.mjs +141 -0
  224. package/dist/chunk-UQZBL3F7.mjs +0 -0
  225. package/dist/chunk-UQZNUEZE.mjs +64 -0
  226. package/dist/chunk-URGYNKJM.mjs +229 -0
  227. package/dist/chunk-UTMZY37A.mjs +141 -0
  228. package/dist/chunk-UUEPD2FH.mjs +141 -0
  229. package/dist/chunk-V3CHJHUX.mjs +424 -0
  230. package/dist/chunk-VQOUJQIF.mjs +249 -0
  231. package/dist/chunk-VY3QH43W.mjs +6 -0
  232. package/dist/chunk-W2N3AWY6.mjs +80 -0
  233. package/dist/chunk-WUVS6S7N.mjs +119 -0
  234. package/dist/chunk-WZS2K7X3.mjs +688 -0
  235. package/dist/chunk-X76GNSBB.mjs +87 -0
  236. package/dist/chunk-XG7CZXBW.mjs +244 -0
  237. package/dist/chunk-XXKIBYXD.mjs +109 -0
  238. package/dist/chunk-XXTUVMAY.mjs +51 -0
  239. package/dist/chunk-Y3BIY4DW.mjs +618 -0
  240. package/dist/chunk-Y7FP6ZMW.mjs +225 -0
  241. package/dist/chunk-YELLXCMY.mjs +265 -0
  242. package/dist/chunk-YQEEM26W.mjs +232 -0
  243. package/dist/chunk-ZGFE3OPJ.mjs +678 -0
  244. package/dist/chunk-ZMJ3KDDY.mjs +618 -0
  245. package/dist/chunk-ZTRM4HZJ.mjs +53 -0
  246. package/dist/chunk-ZYPWQ53U.mjs +6 -0
  247. package/dist/dist-U2IPN4FB.mjs +567 -0
  248. package/dist/index.d.mts +20 -2
  249. package/dist/index.d.ts +20 -2
  250. package/dist/index.js +2820 -13
  251. package/dist/index.mjs +59 -5
  252. package/dist/magic-string.es-XOWQCRDO.mjs +1311 -0
  253. package/dist/molecules/UserProfile/UserProfile.d.mts +23 -0
  254. package/dist/molecules/UserProfile/UserProfile.d.ts +23 -0
  255. package/dist/molecules/UserProfile/UserProfile.js +243 -0
  256. package/dist/molecules/UserProfile/UserProfile.mjs +11 -0
  257. package/dist/styles.css +1802 -1067
  258. package/dist/types-CA0Wby2L.d.mts +67 -0
  259. package/dist/types-CA0Wby2L.d.ts +67 -0
  260. package/dist/types-CncMmuJM.d.mts +44 -0
  261. package/dist/types-CncMmuJM.d.ts +44 -0
  262. package/dist/types-D4MD2w3_.d.mts +9 -0
  263. package/dist/types-D4MD2w3_.d.ts +9 -0
  264. package/dist/types-D4fdeMWQ.d.mts +62 -0
  265. package/dist/types-D4fdeMWQ.d.ts +62 -0
  266. package/dist/types-mhQmqhsR.d.mts +10 -0
  267. package/dist/types-mhQmqhsR.d.ts +10 -0
  268. package/package.json +10 -18
  269. /package/dist/{Button.d.mts → atom/Button/Button.d.mts} +0 -0
  270. /package/dist/{Button.d.ts → atom/Button/Button.d.ts} +0 -0
  271. /package/dist/{Checkbox.d.mts → atom/Checkbox/Checkbox.d.mts} +0 -0
  272. /package/dist/{Checkbox.d.ts → atom/Checkbox/Checkbox.d.ts} +0 -0
  273. /package/dist/{chunk-FUJQIYOF.mjs → chunk-FWCSY2DS.mjs} +0 -0
@@ -0,0 +1,424 @@
1
+ import {
2
+ InternalCalendar_default
3
+ } from "./chunk-N4DPPZVJ.mjs";
4
+
5
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.tsx
6
+ import { memo, useCallback, useEffect, useMemo, useState } from "react";
7
+ import clsx from "clsx";
8
+ import dayjs from "dayjs";
9
+ import customParseFormat from "dayjs/plugin/customParseFormat";
10
+ import isSameOrBefore from "dayjs/plugin/isSameOrBefore";
11
+
12
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.module.scss
13
+ var AdvancedDateRangePicker_module_default = { "root": "AdvancedDateRangePicker-module__root___udir8", "inner": "AdvancedDateRangePicker-module__inner___P4OHa", "left": "AdvancedDateRangePicker-module__left___T6E84", "sidebarItem": "AdvancedDateRangePicker-module__sidebarItem___-NXPm", "sidebarItemActive": "AdvancedDateRangePicker-module__sidebarItemActive___5GmBY", "main": "AdvancedDateRangePicker-module__main___G4MU9", "header": "AdvancedDateRangePicker-module__header___mxXEE", "headerGroup": "AdvancedDateRangePicker-module__headerGroup___J7mJB", "headerLabel": "AdvancedDateRangePicker-module__headerLabel___Yvhkr", "timezoneWrapper": "AdvancedDateRangePicker-module__timezoneWrapper___886Qm", "dateTimeWrapper": "AdvancedDateRangePicker-module__dateTimeWrapper___unDQJ", "headerSeparator": "AdvancedDateRangePicker-module__headerSeparator___Vwx6P", "timezoneSelect": "AdvancedDateRangePicker-module__timezoneSelect___f4oln", "dateTimeColumn": "AdvancedDateRangePicker-module__dateTimeColumn___tdDV3", "dateTimeGroup": "AdvancedDateRangePicker-module__dateTimeGroup___azF09", "dateInput": "AdvancedDateRangePicker-module__dateInput___0t9ww", "inputError": "AdvancedDateRangePicker-module__inputError___A5hid", "timeInput": "AdvancedDateRangePicker-module__timeInput___Jalr9", "errorMessage": "AdvancedDateRangePicker-module__errorMessage___gx7ag", "body": "AdvancedDateRangePicker-module__body___f8XYj", "footer": "AdvancedDateRangePicker-module__footer___rsJ2w", "doneBtn": "AdvancedDateRangePicker-module__doneBtn___mt-Sv" };
14
+
15
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.tsx
16
+ import { jsx, jsxs } from "react/jsx-runtime";
17
+ dayjs.extend(customParseFormat);
18
+ dayjs.extend(isSameOrBefore);
19
+ var DEFAULT_TIME = { hour: "12", minute: "00", period: "PM" };
20
+ function getPresets() {
21
+ const today = /* @__PURE__ */ new Date();
22
+ today.setHours(0, 0, 0, 0);
23
+ return [
24
+ {
25
+ label: "Custom",
26
+ key: "custom",
27
+ getRange: () => [null, null]
28
+ },
29
+ {
30
+ label: "Yesterday",
31
+ key: "yesterday",
32
+ getRange: () => {
33
+ const d = new Date(today);
34
+ d.setDate(d.getDate() - 1);
35
+ return [d, d];
36
+ }
37
+ },
38
+ {
39
+ label: "Previous week",
40
+ key: "previous-week",
41
+ getRange: () => {
42
+ const dayOfWeek = today.getDay();
43
+ const start = new Date(today);
44
+ start.setDate(today.getDate() - dayOfWeek - 6);
45
+ const end = new Date(today);
46
+ return [start, end];
47
+ }
48
+ },
49
+ {
50
+ label: "This month",
51
+ key: "this-month",
52
+ getRange: () => {
53
+ const start = new Date(today.getFullYear(), today.getMonth(), 1);
54
+ const end = new Date(today.getFullYear(), today.getMonth() + 1, 0);
55
+ return [start, end];
56
+ }
57
+ },
58
+ {
59
+ label: "Previous month",
60
+ key: "previous-month",
61
+ getRange: () => {
62
+ const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);
63
+ const end = new Date(today.getFullYear(), today.getMonth(), 0);
64
+ return [start, end];
65
+ }
66
+ },
67
+ {
68
+ label: "Previous quarter",
69
+ key: "previous-quarter",
70
+ getRange: () => {
71
+ const month = today.getMonth();
72
+ const quarter = Math.floor(month / 3);
73
+ const startMonth = (quarter - 1) * 3;
74
+ const start = new Date(today.getFullYear(), startMonth, 1);
75
+ const end = new Date(today.getFullYear(), startMonth + 3, 0);
76
+ return [start, end];
77
+ }
78
+ }
79
+ ];
80
+ }
81
+ function applyDateMask(v, prev) {
82
+ if (v.length < prev.length) return v;
83
+ const digits = v.replace(/[^\d]/g, "").slice(0, 8);
84
+ if (digits.length >= 2) {
85
+ const d = Number(digits.slice(0, 2));
86
+ if (d < 1 || d > 31) return prev;
87
+ }
88
+ if (digits.length >= 4) {
89
+ const m = Number(digits.slice(2, 4));
90
+ if (m < 1 || m > 12) return prev;
91
+ }
92
+ let result = "";
93
+ if (digits.length > 0) result += digits.slice(0, 2);
94
+ if (digits.length >= 2) result += "-";
95
+ if (digits.length > 2) result += digits.slice(2, 4);
96
+ if (digits.length >= 4) result += "-";
97
+ if (digits.length > 4) result += digits.slice(4, 8);
98
+ return result.slice(0, 10);
99
+ }
100
+ function applyTimeMask(v, prev) {
101
+ if (v.length < prev.length) return v;
102
+ const digits = v.replace(/[^\d]/g, "").slice(0, 4);
103
+ if (digits.length >= 2) {
104
+ const h = Number(digits.slice(0, 2));
105
+ if (h < 1 || h > 12) return prev;
106
+ }
107
+ if (digits.length >= 4) {
108
+ const m = Number(digits.slice(2, 4));
109
+ if (m > 59) return prev;
110
+ }
111
+ let result = "";
112
+ if (digits.length > 0) result += digits.slice(0, 2);
113
+ if (digits.length >= 2) result += ":";
114
+ if (digits.length > 2) result += digits.slice(2, 4);
115
+ if (v.toUpperCase().includes("A")) result += " AM";
116
+ else if (v.toUpperCase().includes("P")) result += " PM";
117
+ else if (digits.length === 4) result += " ";
118
+ return result.slice(0, 8);
119
+ }
120
+ function formatForDisplay(date) {
121
+ if (!date) return "";
122
+ return dayjs(date).format("DD-MM-YYYY");
123
+ }
124
+ function validateDateString(raw) {
125
+ const regex = /^(0[1-9]|[12][0-9]|3[01])-(0[1-9]|1[0-2])-\d{4}$/;
126
+ if (!regex.test(raw)) return false;
127
+ const [d, m, y] = raw.split("-").map(Number);
128
+ const date = new Date(y, m - 1, d);
129
+ return date.getFullYear() === y && date.getMonth() === m - 1 && date.getDate() === d;
130
+ }
131
+ function validateTimeString(raw) {
132
+ const regex = /^(0[1-9]|1[0-2]):(0[0-9]|[1-5][0-9])\s(AM|PM)$/i;
133
+ return regex.test(raw);
134
+ }
135
+ function parseDateInput(raw) {
136
+ if (!validateDateString(raw)) return null;
137
+ return dayjs(raw, "DD-MM-YYYY", true).toDate();
138
+ }
139
+ function parseTimeInput(raw) {
140
+ if (!validateTimeString(raw)) return null;
141
+ const match = raw.match(/^(\d{1,2}):(\d{2})\s*(AM|PM)$/i);
142
+ if (!match) return null;
143
+ return {
144
+ hour: match[1].padStart(2, "0"),
145
+ minute: match[2].padStart(2, "0"),
146
+ period: match[3].toUpperCase()
147
+ };
148
+ }
149
+ function formatTime(t) {
150
+ return `${t.hour}:${t.minute} ${t.period}`;
151
+ }
152
+ var DateTimeInputGroup = memo(function DateTimeInputGroup2({
153
+ label,
154
+ dateValue,
155
+ timeValue,
156
+ dateError,
157
+ timeError,
158
+ onDateChange,
159
+ onTimeChange
160
+ }) {
161
+ const [isDateFocused, setIsDateFocused] = useState(false);
162
+ const [isTimeFocused, setIsTimeFocused] = useState(false);
163
+ const showDateError = dateError && !isDateFocused;
164
+ const showTimeError = timeError && !isTimeFocused && !showDateError;
165
+ return /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.headerGroup, children: [
166
+ /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.headerLabel, children: label }),
167
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.dateTimeColumn, children: [
168
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.dateTimeGroup, children: [
169
+ /* @__PURE__ */ jsx(
170
+ "input",
171
+ {
172
+ type: "text",
173
+ placeholder: "DD-MM-YYYY",
174
+ value: dateValue,
175
+ onFocus: () => setIsDateFocused(true),
176
+ onBlur: () => setIsDateFocused(false),
177
+ onChange: (e) => onDateChange(e.target.value),
178
+ className: clsx(AdvancedDateRangePicker_module_default.dateInput, { [AdvancedDateRangePicker_module_default.inputError]: showDateError })
179
+ }
180
+ ),
181
+ /* @__PURE__ */ jsx(
182
+ "input",
183
+ {
184
+ type: "text",
185
+ placeholder: "12:00 PM",
186
+ value: timeValue,
187
+ onFocus: () => setIsTimeFocused(true),
188
+ onBlur: () => setIsTimeFocused(false),
189
+ onChange: (e) => onTimeChange(e.target.value),
190
+ className: clsx(AdvancedDateRangePicker_module_default.timeInput, { [AdvancedDateRangePicker_module_default.inputError]: showTimeError })
191
+ }
192
+ )
193
+ ] }),
194
+ showDateError && /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.errorMessage, children: "Enter valid date" }),
195
+ showTimeError && /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.errorMessage, children: "Enter valid time" })
196
+ ] })
197
+ ] });
198
+ });
199
+ function AdvancedDateRangePicker({
200
+ value,
201
+ onChange,
202
+ confirmLabel = "Done",
203
+ className = "",
204
+ disabled = false,
205
+ disablePastDates = false,
206
+ minDate = null,
207
+ maxDate = null,
208
+ showSingleCalendar = false,
209
+ id = "adv-drp",
210
+ defaultTimezone = "UTC",
211
+ isTimezoneDisabled = false,
212
+ timezoneOptions = []
213
+ }) {
214
+ var _a, _b, _c;
215
+ const PRESETS = useMemo(() => getPresets(), []);
216
+ const [startDate, setStartDate] = useState((_a = value == null ? void 0 : value.startDate) != null ? _a : null);
217
+ const [endDate, setEndDate] = useState((_b = value == null ? void 0 : value.endDate) != null ? _b : null);
218
+ const [timezone, setTimezone] = useState((_c = value == null ? void 0 : value.timezone) != null ? _c : defaultTimezone);
219
+ const [fromDateStr, setFromDateStr] = useState(formatForDisplay(startDate));
220
+ const [toDateStr, setToDateStr] = useState(formatForDisplay(endDate));
221
+ const [fromTimeStr, setFromTimeStr] = useState(
222
+ (value == null ? void 0 : value.startTime) ? formatTime(value.startTime) : "12:00 PM"
223
+ );
224
+ const [toTimeStr, setToTimeStr] = useState(
225
+ (value == null ? void 0 : value.endTime) ? formatTime(value.endTime) : "12:00 PM"
226
+ );
227
+ const [activePreset, setActivePreset] = useState("custom");
228
+ const fromDateError = useMemo(() => fromDateStr.length > 0 && (fromDateStr.length < 10 || !validateDateString(fromDateStr)), [fromDateStr]);
229
+ const toDateError = useMemo(() => toDateStr.length > 0 && (toDateStr.length < 10 || !validateDateString(toDateStr)), [toDateStr]);
230
+ const fromTimeError = useMemo(() => fromTimeStr.length > 0 && (fromTimeStr.length < 8 || !validateTimeString(fromTimeStr)), [fromTimeStr]);
231
+ const toTimeError = useMemo(() => toTimeStr.length > 0 && (toTimeStr.length < 8 || !validateTimeString(toTimeStr)), [toTimeStr]);
232
+ const isReady = useMemo(() => {
233
+ return startDate !== null && endDate !== null && validateDateString(fromDateStr) && validateDateString(toDateStr) && validateTimeString(fromTimeStr) && validateTimeString(toTimeStr) && dayjs(startDate).isSameOrBefore(dayjs(endDate), "day");
234
+ }, [startDate, endDate, fromDateStr, toDateStr, fromTimeStr, toTimeStr]);
235
+ useEffect(() => {
236
+ var _a2, _b2, _c2;
237
+ if (value) {
238
+ setStartDate((_a2 = value.startDate) != null ? _a2 : null);
239
+ setEndDate((_b2 = value.endDate) != null ? _b2 : null);
240
+ setTimezone((_c2 = value.timezone) != null ? _c2 : defaultTimezone);
241
+ if (value.startTime) setFromTimeStr(formatTime(value.startTime));
242
+ if (value.endTime) setToTimeStr(formatTime(value.endTime));
243
+ }
244
+ }, [value, defaultTimezone]);
245
+ useEffect(() => {
246
+ setFromDateStr(formatForDisplay(startDate));
247
+ }, [startDate]);
248
+ useEffect(() => {
249
+ setToDateStr(formatForDisplay(endDate));
250
+ }, [endDate]);
251
+ const rangeValue = useMemo(() => [
252
+ startDate ? startDate.toISOString() : "",
253
+ endDate ? endDate.toISOString() : ""
254
+ ], [startDate, endDate]);
255
+ const handleRangeChange = useCallback(
256
+ (range) => {
257
+ const [s, e] = range;
258
+ if (s) {
259
+ const sDateByDayjs = dayjs(s, "D MMM, YYYY").toDate();
260
+ setStartDate(sDateByDayjs);
261
+ } else {
262
+ setStartDate(null);
263
+ }
264
+ if (e) {
265
+ const eDateByDayjs = dayjs(e, "D MMM, YYYY").toDate();
266
+ setEndDate(eDateByDayjs);
267
+ } else {
268
+ setEndDate(null);
269
+ }
270
+ setActivePreset("custom");
271
+ },
272
+ []
273
+ );
274
+ const handlePreset = useCallback(
275
+ (preset) => {
276
+ const [s, e] = preset.getRange();
277
+ setStartDate(s);
278
+ setEndDate(e);
279
+ setActivePreset(preset.key);
280
+ },
281
+ []
282
+ );
283
+ const handleFromDateChange = useCallback((v) => {
284
+ const masked = applyDateMask(v, fromDateStr);
285
+ setFromDateStr(masked);
286
+ setActivePreset("custom");
287
+ if (masked.length === 10) {
288
+ const parsed = parseDateInput(masked);
289
+ if (parsed) {
290
+ setStartDate(parsed);
291
+ if (endDate && dayjs(parsed).isAfter(dayjs(endDate), "day")) {
292
+ setEndDate(null);
293
+ }
294
+ }
295
+ }
296
+ }, [fromDateStr, endDate]);
297
+ const handleToDateChange = useCallback((v) => {
298
+ const masked = applyDateMask(v, toDateStr);
299
+ setToDateStr(masked);
300
+ setActivePreset("custom");
301
+ if (masked.length === 10) {
302
+ const parsed = parseDateInput(masked);
303
+ if (parsed) {
304
+ setEndDate(parsed);
305
+ if (startDate && dayjs(parsed).isBefore(dayjs(startDate), "day")) {
306
+ setStartDate(null);
307
+ }
308
+ }
309
+ }
310
+ }, [toDateStr, startDate]);
311
+ const handleFromTimeChange = useCallback((v) => {
312
+ const masked = applyTimeMask(v, fromTimeStr);
313
+ setFromTimeStr(masked);
314
+ setActivePreset("custom");
315
+ }, [fromTimeStr]);
316
+ const handleToTimeChange = useCallback((v) => {
317
+ const masked = applyTimeMask(v, toTimeStr);
318
+ setToTimeStr(masked);
319
+ setActivePreset("custom");
320
+ }, [toTimeStr]);
321
+ const handleDone = useCallback(() => {
322
+ var _a2, _b2;
323
+ if (!isReady) return;
324
+ const fromTime = (_a2 = parseTimeInput(fromTimeStr)) != null ? _a2 : DEFAULT_TIME;
325
+ const toTime = (_b2 = parseTimeInput(toTimeStr)) != null ? _b2 : DEFAULT_TIME;
326
+ onChange == null ? void 0 : onChange({
327
+ startDate,
328
+ endDate,
329
+ startTime: fromTime,
330
+ endTime: toTime,
331
+ timezone
332
+ });
333
+ }, [isReady, onChange, startDate, endDate, fromTimeStr, toTimeStr, timezone]);
334
+ return /* @__PURE__ */ jsxs("div", { className: clsx(AdvancedDateRangePicker_module_default.root, className), id, children: [
335
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.inner, children: [
336
+ /* @__PURE__ */ jsx("aside", { className: AdvancedDateRangePicker_module_default.left, children: PRESETS.map((p) => /* @__PURE__ */ jsx(
337
+ "button",
338
+ {
339
+ type: "button",
340
+ onClick: () => handlePreset(p),
341
+ className: clsx(AdvancedDateRangePicker_module_default.sidebarItem, {
342
+ [AdvancedDateRangePicker_module_default.sidebarItemActive]: activePreset === p.key
343
+ }),
344
+ children: p.label
345
+ },
346
+ p.key
347
+ )) }),
348
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.main, children: [
349
+ /* @__PURE__ */ jsxs("header", { className: AdvancedDateRangePicker_module_default.header, children: [
350
+ /* @__PURE__ */ jsxs("div", { className: clsx(AdvancedDateRangePicker_module_default.headerGroup, AdvancedDateRangePicker_module_default.timezoneWrapper), children: [
351
+ /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.headerLabel, children: "Timezone" }),
352
+ /* @__PURE__ */ jsx(
353
+ "select",
354
+ {
355
+ value: timezone,
356
+ onChange: (e) => setTimezone(e.target.value),
357
+ className: AdvancedDateRangePicker_module_default.timezoneSelect,
358
+ disabled: isTimezoneDisabled,
359
+ children: timezoneOptions.map((tz) => /* @__PURE__ */ jsx("option", { value: tz.value, children: tz.label }, tz.value))
360
+ }
361
+ )
362
+ ] }),
363
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.headerSeparator }),
364
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.dateTimeWrapper, children: [
365
+ /* @__PURE__ */ jsx(
366
+ DateTimeInputGroup,
367
+ {
368
+ label: "From",
369
+ dateValue: fromDateStr,
370
+ timeValue: fromTimeStr,
371
+ dateError: fromDateError,
372
+ timeError: fromTimeError,
373
+ onDateChange: handleFromDateChange,
374
+ onTimeChange: handleFromTimeChange
375
+ }
376
+ ),
377
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.headerSeparator }),
378
+ /* @__PURE__ */ jsx(
379
+ DateTimeInputGroup,
380
+ {
381
+ label: "To",
382
+ dateValue: toDateStr,
383
+ timeValue: toTimeStr,
384
+ dateError: toDateError,
385
+ timeError: toTimeError,
386
+ onDateChange: handleToDateChange,
387
+ onTimeChange: handleToTimeChange
388
+ }
389
+ )
390
+ ] })
391
+ ] }),
392
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.body, children: /* @__PURE__ */ jsx(
393
+ InternalCalendar_default,
394
+ {
395
+ id: `${id}-calendar`,
396
+ dateRange: rangeValue,
397
+ onChange: handleRangeChange,
398
+ disablePastDates,
399
+ minDate,
400
+ maxDate,
401
+ showSingleCalendar
402
+ }
403
+ ) })
404
+ ] })
405
+ ] }),
406
+ /* @__PURE__ */ jsx("footer", { className: AdvancedDateRangePicker_module_default.footer, children: /* @__PURE__ */ jsx(
407
+ "button",
408
+ {
409
+ type: "button",
410
+ onClick: handleDone,
411
+ disabled: disabled || !isReady,
412
+ className: AdvancedDateRangePicker_module_default.doneBtn,
413
+ children: confirmLabel
414
+ }
415
+ ) })
416
+ ] });
417
+ }
418
+ AdvancedDateRangePicker.displayName = "AdvancedDateRangePicker";
419
+ var AdvancedDateRangePicker_default = AdvancedDateRangePicker;
420
+
421
+ export {
422
+ AdvancedDateRangePicker,
423
+ AdvancedDateRangePicker_default
424
+ };
@@ -0,0 +1,249 @@
1
+ import {
2
+ __objRest,
3
+ __spreadProps,
4
+ __spreadValues
5
+ } from "./chunk-FWCSY2DS.mjs";
6
+
7
+ // src/atom/Table/Table.tsx
8
+ import * as React from "react";
9
+ import { Table as AntTable } from "antd";
10
+ import clsx from "clsx";
11
+
12
+ // src/atom/Table/Table.module.scss
13
+ var Table_module_default = { "tableWrapper": "Table-module__tableWrapper___3cqiD", "isAccordion": "Table-module__isAccordion___-uIs6", "isToolbar": "Table-module__isToolbar___LdS-m", "table": "Table-module__table___5d7g0", "firstRow": "Table-module__firstRow___Xq-Hi", "lastRow": "Table-module__lastRow___ahv4g", "showHoverEffect": "Table-module__showHoverEffect___IyKyO", "columnHeader": "Table-module__columnHeader___Unr6d", "columnHeaderLeft": "Table-module__columnHeaderLeft___mp7pK", "columnHeaderSortArea": "Table-module__columnHeaderSortArea___jrIYo", "columnHeaderLabel": "Table-module__columnHeaderLabel___A-mRu", "columnHeaderSortIcon": "Table-module__columnHeaderSortIcon___mWVZN", "columnHeaderSortIconActive": "Table-module__columnHeaderSortIconActive___wHAqC", "columnHeaderFilterWrapper": "Table-module__columnHeaderFilterWrapper___DnSve", "columnHeaderFilterBtn": "Table-module__columnHeaderFilterBtn___NR7DY", "columnHeaderFilterBtnActive": "Table-module__columnHeaderFilterBtnActive___JdO11", "columnHeaderFilterBadge": "Table-module__columnHeaderFilterBadge___-Q2T2", "columnHeaderFilterDropdown": "Table-module__columnHeaderFilterDropdown___M-fD4" };
14
+
15
+ // src/atom/Table/Table.tsx
16
+ import { jsx, jsxs } from "react/jsx-runtime";
17
+ function buildPagination(pagination, overrides = {}) {
18
+ var _a, _b, _c, _d;
19
+ if (pagination === false) {
20
+ return false;
21
+ }
22
+ const defaults = {
23
+ showSizeChanger: true,
24
+ pageSizeOptions: ["10", "25", "50"],
25
+ locale: { items_per_page: "" },
26
+ // Removes "/ page" text
27
+ showTotal: (total, range) => `${range[0]}\u2013${range[1]} of ${total} items`
28
+ };
29
+ const baseConfig = pagination === true || pagination === void 0 ? defaults : __spreadValues(__spreadValues({}, defaults), pagination);
30
+ return __spreadProps(__spreadValues({}, baseConfig), {
31
+ total: (_a = overrides.total) != null ? _a : baseConfig.total,
32
+ current: (_b = overrides.current) != null ? _b : baseConfig.current,
33
+ pageSize: (_c = overrides.pageSize) != null ? _c : baseConfig.pageSize,
34
+ onChange: (_d = overrides.onChange) != null ? _d : baseConfig.onChange
35
+ });
36
+ }
37
+ function nextSortOrder(current) {
38
+ if (current === void 0) return "ascend";
39
+ if (current === "ascend") return "descend";
40
+ return void 0;
41
+ }
42
+ function ColumnHeader({
43
+ label,
44
+ sortable = false,
45
+ sortOrder,
46
+ onSortChange,
47
+ sortIcon,
48
+ filterCount = 0,
49
+ filterIcon,
50
+ filterContent,
51
+ className = ""
52
+ }) {
53
+ const [filterOpen, setFilterOpen] = React.useState(false);
54
+ const wrapperRef = React.useRef(null);
55
+ const filterActive = filterCount > 0;
56
+ const hasFilter = filterContent !== void 0 && filterIcon !== void 0;
57
+ const hasSort = sortable && sortIcon !== void 0;
58
+ React.useEffect(() => {
59
+ if (!filterOpen) return;
60
+ const onOutside = (e) => {
61
+ if (wrapperRef.current && !wrapperRef.current.contains(e.target)) {
62
+ setFilterOpen(false);
63
+ }
64
+ };
65
+ document.addEventListener("mousedown", onOutside);
66
+ return () => document.removeEventListener("mousedown", onOutside);
67
+ }, [filterOpen]);
68
+ return /* @__PURE__ */ jsxs("div", { className: Table_module_default.columnHeader, ref: wrapperRef, children: [
69
+ /* @__PURE__ */ jsx("div", { className: Table_module_default.columnHeaderLeft, children: hasSort ? /* @__PURE__ */ jsxs(
70
+ "button",
71
+ {
72
+ type: "button",
73
+ className: Table_module_default.columnHeaderSortArea,
74
+ onClick: () => onSortChange == null ? void 0 : onSortChange(nextSortOrder(sortOrder)),
75
+ "aria-label": typeof label === "string" ? `Sort by ${label}` : "Sort",
76
+ children: [
77
+ /* @__PURE__ */ jsx("span", { className: clsx(Table_module_default.columnHeaderLabel, "tw-typography-caption2Bold tw-text-color-text-weak", className), children: label }),
78
+ /* @__PURE__ */ jsx(
79
+ "span",
80
+ {
81
+ className: clsx(Table_module_default.columnHeaderSortIcon, {
82
+ [Table_module_default.columnHeaderSortIconActive]: sortOrder !== void 0
83
+ }),
84
+ children: sortIcon
85
+ }
86
+ )
87
+ ]
88
+ }
89
+ ) : /* @__PURE__ */ jsx("span", { className: clsx(Table_module_default.columnHeaderLabel, "tw-typography-caption2Bold tw-text-color-text-weak", className), children: label }) }),
90
+ hasFilter && /* @__PURE__ */ jsxs("div", { className: Table_module_default.columnHeaderFilterWrapper, children: [
91
+ /* @__PURE__ */ jsxs(
92
+ "button",
93
+ {
94
+ type: "button",
95
+ className: clsx(Table_module_default.columnHeaderFilterBtn, {
96
+ [Table_module_default.columnHeaderFilterBtnActive]: filterActive
97
+ }),
98
+ onClick: () => setFilterOpen((v) => !v),
99
+ "aria-label": typeof label === "string" ? `Filter ${label}` : "Filter",
100
+ "aria-expanded": filterOpen,
101
+ "aria-haspopup": "dialog",
102
+ children: [
103
+ filterIcon,
104
+ filterActive && /* @__PURE__ */ jsx("span", { className: Table_module_default.columnHeaderFilterBadge, children: filterCount })
105
+ ]
106
+ }
107
+ ),
108
+ filterOpen && /* @__PURE__ */ jsx("div", { className: Table_module_default.columnHeaderFilterDropdown, role: "dialog", children: filterContent })
109
+ ] })
110
+ ] });
111
+ }
112
+ function processColumns(columns) {
113
+ if (!columns) return void 0;
114
+ return columns.map((col) => {
115
+ const _a = col, { headerProps, title } = _a, rest = __objRest(_a, ["headerProps", "title"]);
116
+ if (!headerProps) return __spreadValues({ title }, rest);
117
+ return __spreadProps(__spreadValues({}, rest), {
118
+ title: /* @__PURE__ */ jsx(ColumnHeader, __spreadValues({ label: title }, headerProps))
119
+ });
120
+ });
121
+ }
122
+ function Table(props) {
123
+ const _a = props, {
124
+ size = "middle",
125
+ variant = "default",
126
+ isAccordion = false,
127
+ isToolbar = false,
128
+ className = "",
129
+ pagination,
130
+ loading,
131
+ total,
132
+ current,
133
+ pageSize,
134
+ onPaginationChange,
135
+ columns,
136
+ rowSelection,
137
+ rowKey = "key",
138
+ onRow,
139
+ dataSource,
140
+ emptyState,
141
+ hideHeader,
142
+ loadingIndicator,
143
+ style
144
+ } = _a, rest = __objRest(_a, [
145
+ "size",
146
+ "variant",
147
+ "isAccordion",
148
+ "isToolbar",
149
+ "className",
150
+ "pagination",
151
+ "loading",
152
+ "total",
153
+ "current",
154
+ "pageSize",
155
+ "onPaginationChange",
156
+ "columns",
157
+ "rowSelection",
158
+ "rowKey",
159
+ "onRow",
160
+ "dataSource",
161
+ "emptyState",
162
+ "hideHeader",
163
+ "loadingIndicator",
164
+ "style"
165
+ ]);
166
+ const isChildVariant = isAccordion || isToolbar;
167
+ const resolvedPagination = buildPagination(pagination, {
168
+ total,
169
+ current,
170
+ pageSize,
171
+ onChange: onPaginationChange
172
+ });
173
+ const processedColumns = React.useMemo(
174
+ () => processColumns(columns),
175
+ // eslint-disable-next-line react-hooks/exhaustive-deps
176
+ [columns]
177
+ );
178
+ const resolvedOnRow = React.useMemo(() => {
179
+ const onChange = rowSelection == null ? void 0 : rowSelection.onChange;
180
+ if (variant !== "selectable" || !onChange) return onRow;
181
+ return (record, index) => {
182
+ var _a2;
183
+ const base = (_a2 = onRow == null ? void 0 : onRow(record, index)) != null ? _a2 : {};
184
+ const getKey = (r, i) => typeof rowKey === "function" ? rowKey(r, i) : r[rowKey];
185
+ return __spreadProps(__spreadValues({}, base), {
186
+ style: __spreadValues({ cursor: "pointer" }, base.style),
187
+ onClick: (e) => {
188
+ var _a3, _b;
189
+ (_a3 = base.onClick) == null ? void 0 : _a3.call(base, e);
190
+ const key = getKey(record, index);
191
+ const current2 = (_b = rowSelection.selectedRowKeys) != null ? _b : [];
192
+ const isSelected = current2.some((k) => k === key);
193
+ const newKeys = isSelected ? current2.filter((k) => k !== key) : [...current2, key];
194
+ const newRows = (dataSource != null ? dataSource : []).filter(
195
+ (r) => newKeys.some((k) => k === getKey(r))
196
+ );
197
+ onChange(newKeys, newRows, { type: "single" });
198
+ }
199
+ });
200
+ };
201
+ }, [variant, rowSelection, rowKey, onRow, dataSource]);
202
+ return /* @__PURE__ */ jsx(
203
+ "div",
204
+ {
205
+ className: clsx(
206
+ Table_module_default.tableWrapper,
207
+ Table_module_default.showHoverEffect,
208
+ { [Table_module_default.isAccordion]: isAccordion },
209
+ { [Table_module_default.isToolbar]: isToolbar },
210
+ className
211
+ ),
212
+ style,
213
+ "data-testid": "lumina-table",
214
+ children: /* @__PURE__ */ jsx(
215
+ AntTable,
216
+ __spreadProps(__spreadValues({
217
+ className: Table_module_default.table,
218
+ size,
219
+ pagination: resolvedPagination,
220
+ columns: processedColumns,
221
+ rowSelection,
222
+ rowKey,
223
+ onRow: resolvedOnRow,
224
+ dataSource,
225
+ showHeader: !hideHeader,
226
+ locale: {
227
+ emptyText: loading ? " " : emptyState
228
+ }
229
+ }, rest), {
230
+ loading: loadingIndicator ? { spinning: !!loading, indicator: loadingIndicator } : loading,
231
+ rowClassName: (_, index) => {
232
+ var _a2;
233
+ return clsx({
234
+ [Table_module_default.firstRow]: index === 0,
235
+ [Table_module_default.lastRow]: index === ((_a2 = dataSource == null ? void 0 : dataSource.length) != null ? _a2 : 0) - 1
236
+ });
237
+ }
238
+ })
239
+ )
240
+ }
241
+ );
242
+ }
243
+ Table.displayName = "Table";
244
+ var Table_default = Table;
245
+
246
+ export {
247
+ Table,
248
+ Table_default
249
+ };
@@ -0,0 +1,6 @@
1
+ // src/atom/Table/Table.module.scss
2
+ var Table_module_default = { "tableWrapper": "Table-module__tableWrapper___3cqiD", "childVariant": "Table-module__childVariant___z8tqO", "table": "Table-module__table___5d7g0", "showHoverEffect": "Table-module__showHoverEffect___IyKyO", "columnHeader": "Table-module__columnHeader___Unr6d", "columnHeaderSortArea": "Table-module__columnHeaderSortArea___jrIYo", "columnHeaderLabel": "Table-module__columnHeaderLabel___A-mRu", "columnHeaderSortIcon": "Table-module__columnHeaderSortIcon___mWVZN", "columnHeaderSortIconActive": "Table-module__columnHeaderSortIconActive___wHAqC", "columnHeaderFilterWrapper": "Table-module__columnHeaderFilterWrapper___DnSve", "columnHeaderFilterBtn": "Table-module__columnHeaderFilterBtn___NR7DY", "columnHeaderFilterBtnActive": "Table-module__columnHeaderFilterBtnActive___JdO11", "columnHeaderFilterBadge": "Table-module__columnHeaderFilterBadge___-Q2T2", "columnHeaderFilterDropdown": "Table-module__columnHeaderFilterDropdown___M-fD4" };
3
+
4
+ export {
5
+ Table_module_default
6
+ };