@itilite/lumina-ui 1.0.1 → 1.0.3-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 (122) hide show
  1. package/README.md +43 -10
  2. package/dist/AdvancedDateRangePicker-D7xn4So6.d.mts +59 -0
  3. package/dist/AdvancedDateRangePicker-D7xn4So6.d.ts +59 -0
  4. package/dist/AdvancedDateRangePicker-ozItnkhp.d.mts +57 -0
  5. package/dist/AdvancedDateRangePicker-ozItnkhp.d.ts +57 -0
  6. package/dist/Table-BOq-_9Nr.d.mts +121 -0
  7. package/dist/Table-BOq-_9Nr.d.ts +121 -0
  8. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.d.mts +2 -0
  9. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.d.ts +2 -0
  10. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.js +1610 -0
  11. package/dist/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.mjs +15 -0
  12. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.d.mts +17 -0
  13. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.d.ts +17 -0
  14. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.js +370 -0
  15. package/dist/atom/AdvancedDateRangePicker/InternalCalendar.mjs +8 -0
  16. package/dist/{Avatar.d.mts → atom/Avatar/Avatar.d.mts} +1 -9
  17. package/dist/{Avatar.d.ts → atom/Avatar/Avatar.d.ts} +1 -9
  18. package/dist/{Avatar.js → atom/Avatar/Avatar.js} +4 -2
  19. package/dist/{Avatar.mjs → atom/Avatar/Avatar.mjs} +2 -2
  20. package/dist/{Button.js → atom/Button/Button.js} +1 -1
  21. package/dist/{Button.mjs → atom/Button/Button.mjs} +2 -2
  22. package/dist/{Checkbox.mjs → atom/Checkbox/Checkbox.mjs} +2 -2
  23. package/dist/atom/LoadingSpinner/LoadingSpinner.d.mts +19 -0
  24. package/dist/atom/LoadingSpinner/LoadingSpinner.d.ts +19 -0
  25. package/dist/atom/LoadingSpinner/LoadingSpinner.js +90 -0
  26. package/dist/atom/LoadingSpinner/LoadingSpinner.mjs +9 -0
  27. package/dist/{Modal.d.mts → atom/Modal/Modal.d.mts} +1 -1
  28. package/dist/{Modal.d.ts → atom/Modal/Modal.d.ts} +1 -1
  29. package/dist/{Modal.js → atom/Modal/Modal.js} +1 -1
  30. package/dist/atom/Modal/Modal.mjs +10 -0
  31. package/dist/{Radio.mjs → atom/Radio/Radio.mjs} +2 -2
  32. package/dist/atom/RangePicker/Chevron.d.mts +13 -0
  33. package/dist/atom/RangePicker/Chevron.d.ts +13 -0
  34. package/dist/atom/RangePicker/Chevron.js +110 -0
  35. package/dist/atom/RangePicker/Chevron.mjs +7 -0
  36. package/dist/atom/RangePicker/RangePicker.d.mts +26 -0
  37. package/dist/atom/RangePicker/RangePicker.d.ts +26 -0
  38. package/dist/atom/RangePicker/RangePicker.js +1465 -0
  39. package/dist/atom/RangePicker/RangePicker.mjs +13 -0
  40. package/dist/atom/Select/Select.d.mts +40 -0
  41. package/dist/atom/Select/Select.d.ts +40 -0
  42. package/dist/atom/Select/Select.js +805 -0
  43. package/dist/atom/Select/Select.mjs +11 -0
  44. package/dist/atom/Slider/Slider.d.mts +34 -0
  45. package/dist/atom/Slider/Slider.d.ts +34 -0
  46. package/dist/atom/Slider/Slider.js +107 -0
  47. package/dist/atom/Slider/Slider.mjs +9 -0
  48. package/dist/{Switch.mjs → atom/Switch/Switch.mjs} +2 -2
  49. package/dist/atom/Table/Table.d.mts +3 -0
  50. package/dist/atom/Table/Table.d.ts +3 -0
  51. package/dist/atom/Table/Table.js +307 -0
  52. package/dist/atom/Table/Table.mjs +9 -0
  53. package/dist/atom/Tag/Tag.d.mts +6 -0
  54. package/dist/atom/Tag/Tag.d.ts +6 -0
  55. package/dist/atom/Tag/Tag.js +108 -0
  56. package/dist/atom/Tag/Tag.mjs +9 -0
  57. package/dist/{Tooltip.mjs → atom/Tooltip/Tooltip.mjs} +2 -2
  58. package/dist/chunk-27LRL4RO.mjs +428 -0
  59. package/dist/chunk-3HXZIFV6.mjs +438 -0
  60. package/dist/chunk-4JX54OKI.mjs +627 -0
  61. package/dist/chunk-4VZB2KR2.mjs +51 -0
  62. package/dist/chunk-53O7JM5I.mjs +424 -0
  63. package/dist/chunk-62VAYFZA.mjs +437 -0
  64. package/dist/chunk-6ON32H2N.mjs +431 -0
  65. package/dist/chunk-6XIT27XY.mjs +269 -0
  66. package/dist/chunk-772C454L.mjs +438 -0
  67. package/dist/chunk-7L267Y4P.mjs +429 -0
  68. package/dist/chunk-7WSVCE2C.mjs +269 -0
  69. package/dist/{chunk-HISCHZ5H.mjs → chunk-AF2RKLH6.mjs} +1 -1
  70. package/dist/chunk-BFFLWW7N.mjs +250 -0
  71. package/dist/chunk-D3N7VFER.mjs +73 -0
  72. package/dist/chunk-FTL3PFC2.mjs +438 -0
  73. package/dist/chunk-GU5F7Z7I.mjs +681 -0
  74. package/dist/chunk-GZ4P7OL3.mjs +429 -0
  75. package/dist/{chunk-X76GNSBB.mjs → chunk-IWO2Y5QX.mjs} +4 -2
  76. package/dist/chunk-J4YYP4IZ.mjs +0 -0
  77. package/dist/chunk-K2A4TWA3.mjs +430 -0
  78. package/dist/chunk-L3L42SIL.mjs +429 -0
  79. package/dist/chunk-MA23J4WQ.mjs +430 -0
  80. package/dist/chunk-N2WTNCQU.mjs +66 -0
  81. package/dist/chunk-N4DPPZVJ.mjs +269 -0
  82. package/dist/chunk-PQ3B2FEB.mjs +249 -0
  83. package/dist/chunk-QKTMWS4J.mjs +43 -0
  84. package/dist/chunk-QRGHJP7U.mjs +437 -0
  85. package/dist/chunk-RC6IGURJ.mjs +428 -0
  86. package/dist/chunk-TQDZWJZP.mjs +269 -0
  87. package/dist/{chunk-N355RJGH.mjs → chunk-UQJ3BDM4.mjs} +1 -1
  88. package/dist/chunk-V3CHJHUX.mjs +424 -0
  89. package/dist/chunk-ZGV6QMVM.mjs +437 -0
  90. package/dist/chunk-ZTRM4HZJ.mjs +53 -0
  91. package/dist/index.d.mts +18 -7
  92. package/dist/index.d.ts +18 -7
  93. package/dist/index.js +2470 -8
  94. package/dist/index.mjs +44 -10
  95. package/dist/molecules/UserProfile/UserProfile.d.mts +23 -0
  96. package/dist/molecules/UserProfile/UserProfile.d.ts +23 -0
  97. package/dist/molecules/UserProfile/UserProfile.js +243 -0
  98. package/dist/molecules/UserProfile/UserProfile.mjs +11 -0
  99. package/dist/styles.css +1891 -907
  100. package/dist/types-D4MD2w3_.d.mts +9 -0
  101. package/dist/types-D4MD2w3_.d.ts +9 -0
  102. package/dist/types-mhQmqhsR.d.mts +10 -0
  103. package/dist/types-mhQmqhsR.d.ts +10 -0
  104. package/package.json +9 -32
  105. package/dist/Modal.mjs +0 -10
  106. package/dist/chunk-2O2IH2FG.mjs +0 -83
  107. package/dist/styles.d.mts +0 -2
  108. package/dist/styles.d.ts +0 -2
  109. /package/dist/{Button.d.mts → atom/Button/Button.d.mts} +0 -0
  110. /package/dist/{Button.d.ts → atom/Button/Button.d.ts} +0 -0
  111. /package/dist/{Checkbox.d.mts → atom/Checkbox/Checkbox.d.mts} +0 -0
  112. /package/dist/{Checkbox.d.ts → atom/Checkbox/Checkbox.d.ts} +0 -0
  113. /package/dist/{Checkbox.js → atom/Checkbox/Checkbox.js} +0 -0
  114. /package/dist/{Radio.d.mts → atom/Radio/Radio.d.mts} +0 -0
  115. /package/dist/{Radio.d.ts → atom/Radio/Radio.d.ts} +0 -0
  116. /package/dist/{Radio.js → atom/Radio/Radio.js} +0 -0
  117. /package/dist/{Switch.d.mts → atom/Switch/Switch.d.mts} +0 -0
  118. /package/dist/{Switch.d.ts → atom/Switch/Switch.d.ts} +0 -0
  119. /package/dist/{Switch.js → atom/Switch/Switch.js} +0 -0
  120. /package/dist/{Tooltip.d.mts → atom/Tooltip/Tooltip.d.mts} +0 -0
  121. /package/dist/{Tooltip.d.ts → atom/Tooltip/Tooltip.d.ts} +0 -0
  122. /package/dist/{Tooltip.js → atom/Tooltip/Tooltip.js} +0 -0
@@ -0,0 +1,437 @@
1
+ import {
2
+ Select_default
3
+ } from "./chunk-GU5F7Z7I.mjs";
4
+ import {
5
+ InternalCalendar_default
6
+ } from "./chunk-N4DPPZVJ.mjs";
7
+ import {
8
+ Button_default
9
+ } from "./chunk-AF2RKLH6.mjs";
10
+
11
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.tsx
12
+ import { memo, useCallback, useEffect, useMemo, useState } from "react";
13
+ import clsx from "clsx";
14
+ import dayjs from "dayjs";
15
+ import customParseFormat from "dayjs/plugin/customParseFormat.js";
16
+ import isSameOrBefore from "dayjs/plugin/isSameOrBefore.js";
17
+
18
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.module.scss
19
+ 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", "timezoneWrapper": "AdvancedDateRangePicker-module__timezoneWrapper___886Qm", "dateTimeWrapper": "AdvancedDateRangePicker-module__dateTimeWrapper___unDQJ", "headerGroup": "AdvancedDateRangePicker-module__headerGroup___J7mJB", "headerLabel": "AdvancedDateRangePicker-module__headerLabel___Yvhkr", "headerSeparator": "AdvancedDateRangePicker-module__headerSeparator___Vwx6P", "timezoneSelect": "AdvancedDateRangePicker-module__timezoneSelect___f4oln", "timezoneSelectContainer": "AdvancedDateRangePicker-module__timezoneSelectContainer___8SMc4", "timezoneDisabledBadge": "AdvancedDateRangePicker-module__timezoneDisabledBadge___VBxOd", "inputWrapper": "AdvancedDateRangePicker-module__inputWrapper___bFFNF", "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" };
20
+
21
+ // src/atom/AdvancedDateRangePicker/AdvancedDateRangePicker.tsx
22
+ import { jsx, jsxs } from "react/jsx-runtime";
23
+ dayjs.extend(customParseFormat);
24
+ dayjs.extend(isSameOrBefore);
25
+ var DEFAULT_TIME = { hour: "12", minute: "00", period: "PM" };
26
+ function getPresets() {
27
+ const today = /* @__PURE__ */ new Date();
28
+ today.setHours(0, 0, 0, 0);
29
+ return [
30
+ {
31
+ label: "Custom",
32
+ key: "custom",
33
+ getRange: () => [null, null]
34
+ },
35
+ {
36
+ label: "Yesterday",
37
+ key: "yesterday",
38
+ getRange: () => {
39
+ const d = new Date(today);
40
+ d.setDate(d.getDate() - 1);
41
+ return [d, d];
42
+ }
43
+ },
44
+ {
45
+ label: "Previous week",
46
+ key: "previous-week",
47
+ getRange: () => {
48
+ const dayOfWeek = today.getDay();
49
+ const start = new Date(today);
50
+ start.setDate(today.getDate() - dayOfWeek - 6);
51
+ const end = new Date(today);
52
+ return [start, end];
53
+ }
54
+ },
55
+ {
56
+ label: "This month",
57
+ key: "this-month",
58
+ getRange: () => {
59
+ const start = new Date(today.getFullYear(), today.getMonth(), 1);
60
+ const end = new Date(today.getFullYear(), today.getMonth() + 1, 0);
61
+ return [start, end];
62
+ }
63
+ },
64
+ {
65
+ label: "Previous month",
66
+ key: "previous-month",
67
+ getRange: () => {
68
+ const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);
69
+ const end = new Date(today.getFullYear(), today.getMonth(), 0);
70
+ return [start, end];
71
+ }
72
+ },
73
+ {
74
+ label: "Previous quarter",
75
+ key: "previous-quarter",
76
+ getRange: () => {
77
+ const month = today.getMonth();
78
+ const quarter = Math.floor(month / 3);
79
+ const startMonth = (quarter - 1) * 3;
80
+ const start = new Date(today.getFullYear(), startMonth, 1);
81
+ const end = new Date(today.getFullYear(), startMonth + 3, 0);
82
+ return [start, end];
83
+ }
84
+ }
85
+ ];
86
+ }
87
+ function applyDateMask(v, prev) {
88
+ if (v.length < prev.length) return v;
89
+ const digits = v.replace(/[^\d]/g, "").slice(0, 8);
90
+ if (digits.length >= 2) {
91
+ const d = Number(digits.slice(0, 2));
92
+ if (d < 1 || d > 31) return prev;
93
+ }
94
+ if (digits.length >= 4) {
95
+ const m = Number(digits.slice(2, 4));
96
+ if (m < 1 || m > 12) return prev;
97
+ }
98
+ let result = "";
99
+ if (digits.length > 0) result += digits.slice(0, 2);
100
+ if (digits.length >= 2) result += "-";
101
+ if (digits.length > 2) result += digits.slice(2, 4);
102
+ if (digits.length >= 4) result += "-";
103
+ if (digits.length > 4) result += digits.slice(4, 8);
104
+ return result.slice(0, 10);
105
+ }
106
+ function applyTimeMask(v, prev) {
107
+ if (v.length < prev.length) return v;
108
+ const digits = v.replace(/[^\d]/g, "").slice(0, 4);
109
+ if (digits.length >= 2) {
110
+ const h = Number(digits.slice(0, 2));
111
+ if (h < 1 || h > 12) return prev;
112
+ }
113
+ if (digits.length >= 4) {
114
+ const m = Number(digits.slice(2, 4));
115
+ if (m > 59) return prev;
116
+ }
117
+ let result = "";
118
+ if (digits.length > 0) result += digits.slice(0, 2);
119
+ if (digits.length >= 2) result += ":";
120
+ if (digits.length > 2) result += digits.slice(2, 4);
121
+ if (v.toUpperCase().includes("A")) result += " AM";
122
+ else if (v.toUpperCase().includes("P")) result += " PM";
123
+ else if (digits.length === 4) result += " ";
124
+ return result.slice(0, 8);
125
+ }
126
+ function formatForDisplay(date) {
127
+ if (!date) return "";
128
+ return dayjs(date).format("DD-MM-YYYY");
129
+ }
130
+ function validateDateString(raw) {
131
+ const regex = /^(0[1-9]|[12][0-9]|3[01])-(0[1-9]|1[0-2])-\d{4}$/;
132
+ if (!regex.test(raw)) return false;
133
+ const [d, m, y] = raw.split("-").map(Number);
134
+ const date = new Date(y, m - 1, d);
135
+ return date.getFullYear() === y && date.getMonth() === m - 1 && date.getDate() === d;
136
+ }
137
+ function validateTimeString(raw) {
138
+ const regex = /^(0[1-9]|1[0-2]):(0[0-9]|[1-5][0-9])\s(AM|PM)$/i;
139
+ return regex.test(raw);
140
+ }
141
+ function parseDateInput(raw) {
142
+ if (!validateDateString(raw)) return null;
143
+ return dayjs(raw, "DD-MM-YYYY", true).toDate();
144
+ }
145
+ function parseTimeInput(raw) {
146
+ if (!validateTimeString(raw)) return null;
147
+ const match = raw.match(/^(\d{1,2}):(\d{2})\s*(AM|PM)$/i);
148
+ if (!match) return null;
149
+ return {
150
+ hour: match[1].padStart(2, "0"),
151
+ minute: match[2].padStart(2, "0"),
152
+ period: match[3].toUpperCase()
153
+ };
154
+ }
155
+ function formatTime(t) {
156
+ return `${t.hour}:${t.minute} ${t.period}`;
157
+ }
158
+ var DateTimeInputGroup = memo(function DateTimeInputGroup2({
159
+ label,
160
+ dateValue,
161
+ timeValue,
162
+ dateError,
163
+ timeError,
164
+ onDateChange,
165
+ onTimeChange
166
+ }) {
167
+ const [isDateFocused, setIsDateFocused] = useState(false);
168
+ const [isTimeFocused, setIsTimeFocused] = useState(false);
169
+ const showDateError = dateError && !isDateFocused;
170
+ const showTimeError = timeError && !isTimeFocused;
171
+ return /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.headerGroup, children: [
172
+ /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.headerLabel, children: label }),
173
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.dateTimeColumn, children: /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.dateTimeGroup, children: [
174
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.inputWrapper, children: [
175
+ /* @__PURE__ */ jsx(
176
+ "input",
177
+ {
178
+ type: "text",
179
+ placeholder: "dd-mm-yyyy",
180
+ value: dateValue,
181
+ onFocus: () => setIsDateFocused(true),
182
+ onBlur: () => setIsDateFocused(false),
183
+ onChange: (e) => onDateChange(e.target.value),
184
+ className: clsx(AdvancedDateRangePicker_module_default.dateInput, { [AdvancedDateRangePicker_module_default.inputError]: showDateError })
185
+ }
186
+ ),
187
+ showDateError && /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.errorMessage, children: "Enter valid date" })
188
+ ] }),
189
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.inputWrapper, children: [
190
+ /* @__PURE__ */ jsx(
191
+ "input",
192
+ {
193
+ type: "text",
194
+ placeholder: "12:00 PM",
195
+ value: timeValue,
196
+ onFocus: () => setIsTimeFocused(true),
197
+ onBlur: () => setIsTimeFocused(false),
198
+ onChange: (e) => onTimeChange(e.target.value),
199
+ className: clsx(AdvancedDateRangePicker_module_default.timeInput, { [AdvancedDateRangePicker_module_default.inputError]: showTimeError })
200
+ }
201
+ ),
202
+ showTimeError && /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.errorMessage, children: "Enter valid time" })
203
+ ] })
204
+ ] }) })
205
+ ] });
206
+ });
207
+ function AdvancedDateRangePicker({
208
+ value,
209
+ onChange,
210
+ confirmLabel = "Done",
211
+ className = "",
212
+ disabled = false,
213
+ disablePastDates = false,
214
+ minDate = null,
215
+ maxDate = null,
216
+ showSingleCalendar = false,
217
+ id = "adv-drp",
218
+ defaultTimezone = "UTC",
219
+ isTimezoneDisabled = false,
220
+ timezoneOptions = [],
221
+ defaultPreset = "custom"
222
+ }) {
223
+ var _a, _b, _c;
224
+ const PRESETS = useMemo(() => getPresets(), []);
225
+ const [startDate, setStartDate] = useState((_a = value == null ? void 0 : value.startDate) != null ? _a : null);
226
+ const [endDate, setEndDate] = useState((_b = value == null ? void 0 : value.endDate) != null ? _b : null);
227
+ const [timezone, setTimezone] = useState((_c = value == null ? void 0 : value.timezone) != null ? _c : defaultTimezone);
228
+ const [fromDateStr, setFromDateStr] = useState(formatForDisplay(startDate));
229
+ const [toDateStr, setToDateStr] = useState(formatForDisplay(endDate));
230
+ const [fromTimeStr, setFromTimeStr] = useState(
231
+ (value == null ? void 0 : value.startTime) ? formatTime(value.startTime) : "12:00 PM"
232
+ );
233
+ const [toTimeStr, setToTimeStr] = useState(
234
+ (value == null ? void 0 : value.endTime) ? formatTime(value.endTime) : "12:00 PM"
235
+ );
236
+ const [activePreset, setActivePreset] = useState(defaultPreset);
237
+ const fromDateError = useMemo(() => fromDateStr.length > 0 && (fromDateStr.length < 10 || !validateDateString(fromDateStr)), [fromDateStr]);
238
+ const toDateError = useMemo(() => toDateStr.length > 0 && (toDateStr.length < 10 || !validateDateString(toDateStr)), [toDateStr]);
239
+ const fromTimeError = useMemo(() => fromTimeStr.length > 0 && (fromTimeStr.length < 8 || !validateTimeString(fromTimeStr)), [fromTimeStr]);
240
+ const toTimeError = useMemo(() => toTimeStr.length > 0 && (toTimeStr.length < 8 || !validateTimeString(toTimeStr)), [toTimeStr]);
241
+ const isReady = useMemo(() => {
242
+ return startDate !== null && endDate !== null && validateDateString(fromDateStr) && validateDateString(toDateStr) && validateTimeString(fromTimeStr) && validateTimeString(toTimeStr) && dayjs(startDate).isSameOrBefore(dayjs(endDate), "day");
243
+ }, [startDate, endDate, fromDateStr, toDateStr, fromTimeStr, toTimeStr]);
244
+ useEffect(() => {
245
+ var _a2, _b2, _c2;
246
+ if (value) {
247
+ setStartDate((_a2 = value.startDate) != null ? _a2 : null);
248
+ setEndDate((_b2 = value.endDate) != null ? _b2 : null);
249
+ setTimezone((_c2 = value.timezone) != null ? _c2 : defaultTimezone);
250
+ if (value.startTime) setFromTimeStr(formatTime(value.startTime));
251
+ if (value.endTime) setToTimeStr(formatTime(value.endTime));
252
+ }
253
+ }, [value, defaultTimezone]);
254
+ useEffect(() => {
255
+ setFromDateStr(formatForDisplay(startDate));
256
+ }, [startDate]);
257
+ useEffect(() => {
258
+ setToDateStr(formatForDisplay(endDate));
259
+ }, [endDate]);
260
+ const rangeValue = useMemo(() => [
261
+ startDate ? startDate.toISOString() : "",
262
+ endDate ? endDate.toISOString() : ""
263
+ ], [startDate, endDate]);
264
+ const handleRangeChange = useCallback(
265
+ (range) => {
266
+ const [s, e] = range;
267
+ if (s) {
268
+ const sDateByDayjs = dayjs(s, "D MMM, YYYY").toDate();
269
+ setStartDate(sDateByDayjs);
270
+ } else {
271
+ setStartDate(null);
272
+ }
273
+ if (e) {
274
+ const eDateByDayjs = dayjs(e, "D MMM, YYYY").toDate();
275
+ setEndDate(eDateByDayjs);
276
+ } else {
277
+ setEndDate(null);
278
+ }
279
+ setActivePreset("custom");
280
+ },
281
+ []
282
+ );
283
+ const handlePreset = useCallback(
284
+ (preset) => {
285
+ const [s, e] = preset.getRange();
286
+ setStartDate(s);
287
+ setEndDate(e);
288
+ setActivePreset(preset.key);
289
+ },
290
+ []
291
+ );
292
+ const handleFromDateChange = useCallback((v) => {
293
+ const masked = applyDateMask(v, fromDateStr);
294
+ setFromDateStr(masked);
295
+ setActivePreset("custom");
296
+ if (masked.length === 10) {
297
+ const parsed = parseDateInput(masked);
298
+ if (parsed) {
299
+ setStartDate(parsed);
300
+ if (endDate && dayjs(parsed).isAfter(dayjs(endDate), "day")) {
301
+ setEndDate(null);
302
+ }
303
+ }
304
+ }
305
+ }, [fromDateStr, endDate]);
306
+ const handleToDateChange = useCallback((v) => {
307
+ const masked = applyDateMask(v, toDateStr);
308
+ setToDateStr(masked);
309
+ setActivePreset("custom");
310
+ if (masked.length === 10) {
311
+ const parsed = parseDateInput(masked);
312
+ if (parsed) {
313
+ setEndDate(parsed);
314
+ if (startDate && dayjs(parsed).isBefore(dayjs(startDate), "day")) {
315
+ setStartDate(null);
316
+ }
317
+ }
318
+ }
319
+ }, [toDateStr, startDate]);
320
+ const handleFromTimeChange = useCallback((v) => {
321
+ const masked = applyTimeMask(v, fromTimeStr);
322
+ setFromTimeStr(masked);
323
+ setActivePreset("custom");
324
+ }, [fromTimeStr]);
325
+ const handleToTimeChange = useCallback((v) => {
326
+ const masked = applyTimeMask(v, toTimeStr);
327
+ setToTimeStr(masked);
328
+ setActivePreset("custom");
329
+ }, [toTimeStr]);
330
+ const handleDone = useCallback(() => {
331
+ var _a2, _b2;
332
+ if (!isReady) return;
333
+ const fromTime = (_a2 = parseTimeInput(fromTimeStr)) != null ? _a2 : DEFAULT_TIME;
334
+ const toTime = (_b2 = parseTimeInput(toTimeStr)) != null ? _b2 : DEFAULT_TIME;
335
+ onChange == null ? void 0 : onChange({
336
+ startDate,
337
+ endDate,
338
+ startTime: fromTime,
339
+ endTime: toTime,
340
+ timezone
341
+ });
342
+ }, [isReady, onChange, startDate, endDate, fromTimeStr, toTimeStr, timezone]);
343
+ return /* @__PURE__ */ jsxs("div", { className: clsx(AdvancedDateRangePicker_module_default.root, className), id, children: [
344
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.inner, children: [
345
+ /* @__PURE__ */ jsx("aside", { className: AdvancedDateRangePicker_module_default.left, children: PRESETS.map((p) => /* @__PURE__ */ jsx(
346
+ "button",
347
+ {
348
+ type: "button",
349
+ onClick: () => handlePreset(p),
350
+ className: clsx(AdvancedDateRangePicker_module_default.sidebarItem, {
351
+ [AdvancedDateRangePicker_module_default.sidebarItemActive]: activePreset === p.key
352
+ }),
353
+ children: p.label
354
+ },
355
+ p.key
356
+ )) }),
357
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.main, children: [
358
+ /* @__PURE__ */ jsxs("header", { className: AdvancedDateRangePicker_module_default.header, children: [
359
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.timezoneWrapper, children: [
360
+ /* @__PURE__ */ jsx("span", { className: AdvancedDateRangePicker_module_default.headerLabel, children: "Timezone" }),
361
+ isTimezoneDisabled ? (
362
+ /* Disabled state: plain text badge instead of empty dropdown */
363
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.timezoneDisabledBadge, children: timezone })
364
+ ) : /* @__PURE__ */ jsx(
365
+ Select_default,
366
+ {
367
+ value: timezone,
368
+ onChange: (val) => {
369
+ if (val) setTimezone(String(val));
370
+ },
371
+ options: timezoneOptions,
372
+ size: "small",
373
+ allowClear: false,
374
+ enableSearch: false,
375
+ wrapperClassName: AdvancedDateRangePicker_module_default.timezoneSelectContainer
376
+ }
377
+ )
378
+ ] }),
379
+ /* @__PURE__ */ jsxs("div", { className: AdvancedDateRangePicker_module_default.dateTimeWrapper, children: [
380
+ /* @__PURE__ */ jsx(
381
+ DateTimeInputGroup,
382
+ {
383
+ label: "From",
384
+ dateValue: fromDateStr,
385
+ timeValue: fromTimeStr,
386
+ dateError: fromDateError,
387
+ timeError: fromTimeError,
388
+ onDateChange: handleFromDateChange,
389
+ onTimeChange: handleFromTimeChange
390
+ }
391
+ ),
392
+ /* @__PURE__ */ jsx(
393
+ DateTimeInputGroup,
394
+ {
395
+ label: "To",
396
+ dateValue: toDateStr,
397
+ timeValue: toTimeStr,
398
+ dateError: toDateError,
399
+ timeError: toTimeError,
400
+ onDateChange: handleToDateChange,
401
+ onTimeChange: handleToTimeChange
402
+ }
403
+ )
404
+ ] })
405
+ ] }),
406
+ /* @__PURE__ */ jsx("div", { className: AdvancedDateRangePicker_module_default.body, children: /* @__PURE__ */ jsx(
407
+ InternalCalendar_default,
408
+ {
409
+ id: `${id}-calendar`,
410
+ dateRange: rangeValue,
411
+ onChange: handleRangeChange,
412
+ disablePastDates,
413
+ minDate,
414
+ maxDate,
415
+ showSingleCalendar
416
+ }
417
+ ) })
418
+ ] })
419
+ ] }),
420
+ /* @__PURE__ */ jsx("footer", { className: AdvancedDateRangePicker_module_default.footer, children: /* @__PURE__ */ jsx(
421
+ Button_default,
422
+ {
423
+ onClick: handleDone,
424
+ disabled: disabled || !isReady,
425
+ shape: "round",
426
+ children: confirmLabel
427
+ }
428
+ ) })
429
+ ] });
430
+ }
431
+ AdvancedDateRangePicker.displayName = "AdvancedDateRangePicker";
432
+ var AdvancedDateRangePicker_default = AdvancedDateRangePicker;
433
+
434
+ export {
435
+ AdvancedDateRangePicker,
436
+ AdvancedDateRangePicker_default
437
+ };