@itilite/lumina-ui 1.1.5 → 1.1.7

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 (164) hide show
  1. package/dist/atom/LoadingSpinner/LoadingSpinner.d.mts +19 -0
  2. package/dist/atom/LoadingSpinner/LoadingSpinner.d.ts +19 -0
  3. package/dist/atom/LoadingSpinner/LoadingSpinner.js +90 -0
  4. package/dist/atom/LoadingSpinner/LoadingSpinner.mjs +9 -0
  5. package/dist/atom/RangePicker/RangePicker.js +266 -136
  6. package/dist/atom/RangePicker/RangePicker.mjs +4 -2
  7. package/dist/atom/Select/Select.d.mts +6 -3
  8. package/dist/atom/Select/Select.d.ts +6 -3
  9. package/dist/atom/Select/Select.js +214 -91
  10. package/dist/atom/Select/Select.mjs +3 -1
  11. package/dist/atom/Slider/Slider.d.mts +34 -0
  12. package/dist/atom/Slider/Slider.d.ts +34 -0
  13. package/dist/atom/Slider/Slider.js +107 -0
  14. package/dist/atom/Slider/Slider.mjs +9 -0
  15. package/dist/chunk-22VF7AVT.mjs +618 -0
  16. package/dist/chunk-2BNAAOBU.mjs +670 -0
  17. package/dist/chunk-2IMRLK6M.mjs +44 -0
  18. package/dist/chunk-2JIINZEK.mjs +618 -0
  19. package/dist/chunk-2LBFKQDZ.mjs +660 -0
  20. package/dist/chunk-2ZJBF5C4.mjs +618 -0
  21. package/dist/chunk-3IMCN4K3.mjs +670 -0
  22. package/dist/chunk-3KBQQCET.mjs +674 -0
  23. package/dist/chunk-3KUHXNFH.mjs +678 -0
  24. package/dist/chunk-3PPNOIXN.mjs +618 -0
  25. package/dist/chunk-3XFY3TXJ.mjs +611 -0
  26. package/dist/chunk-3XW7HS5W.mjs +618 -0
  27. package/dist/chunk-447HZYZ4.mjs +612 -0
  28. package/dist/chunk-46F3B4U6.mjs +618 -0
  29. package/dist/chunk-4K5RZHL4.mjs +618 -0
  30. package/dist/chunk-4QHFP4YD.mjs +666 -0
  31. package/dist/chunk-4TFX4DHY.mjs +702 -0
  32. package/dist/chunk-4TWO6JES.mjs +666 -0
  33. package/dist/chunk-4UQVJ3ZU.mjs +666 -0
  34. package/dist/chunk-5247J65D.mjs +670 -0
  35. package/dist/chunk-66H5WSEJ.mjs +618 -0
  36. package/dist/chunk-6OC6URNL.mjs +73 -0
  37. package/dist/chunk-6OGEXG5U.mjs +618 -0
  38. package/dist/chunk-6ROQXYVN.mjs +672 -0
  39. package/dist/chunk-6WNI6X5Q.mjs +618 -0
  40. package/dist/chunk-72PPCN6D.mjs +675 -0
  41. package/dist/chunk-74EGXFNN.mjs +618 -0
  42. package/dist/chunk-77NCDGJA.mjs +707 -0
  43. package/dist/chunk-7L3WTWF3.mjs +677 -0
  44. package/dist/chunk-7NGBIPZT.mjs +618 -0
  45. package/dist/chunk-7NM4FNMQ.mjs +666 -0
  46. package/dist/chunk-7YBBSVUA.mjs +672 -0
  47. package/dist/chunk-7Z52UP7P.mjs +618 -0
  48. package/dist/chunk-B3LDL3KD.mjs +670 -0
  49. package/dist/chunk-B63IXC6M.mjs +618 -0
  50. package/dist/chunk-B65LGQ47.mjs +666 -0
  51. package/dist/chunk-B6MTRO54.mjs +618 -0
  52. package/dist/chunk-BJBP5XYB.mjs +618 -0
  53. package/dist/chunk-BLLSWPCC.mjs +618 -0
  54. package/dist/chunk-BOYB7REJ.mjs +670 -0
  55. package/dist/chunk-BP2D64XI.mjs +618 -0
  56. package/dist/chunk-BRT5IPGQ.mjs +618 -0
  57. package/dist/chunk-C2J3VBFZ.mjs +670 -0
  58. package/dist/chunk-CDOR7GQP.mjs +618 -0
  59. package/dist/chunk-CI2RMA4V.mjs +612 -0
  60. package/dist/chunk-CNUIZOQJ.mjs +669 -0
  61. package/dist/chunk-CPBXPEST.mjs +672 -0
  62. package/dist/chunk-CVOLXLMU.mjs +618 -0
  63. package/dist/chunk-CWUCNC36.mjs +666 -0
  64. package/dist/chunk-CZBGN6GS.mjs +612 -0
  65. package/dist/chunk-D3APB62N.mjs +618 -0
  66. package/dist/chunk-D3N7VFER.mjs +73 -0
  67. package/dist/chunk-D7TWXVL2.mjs +674 -0
  68. package/dist/chunk-DAZ53AD7.mjs +671 -0
  69. package/dist/chunk-DBY5U6IU.mjs +618 -0
  70. package/dist/chunk-DXTVU4M5.mjs +618 -0
  71. package/dist/chunk-DZBTD6QK.mjs +666 -0
  72. package/dist/chunk-EAK2IMM4.mjs +37 -0
  73. package/dist/chunk-EQT2Q2LW.mjs +610 -0
  74. package/dist/chunk-EWMCELQV.mjs +670 -0
  75. package/dist/chunk-EYKWBEHX.mjs +612 -0
  76. package/dist/chunk-FHLCFUP6.mjs +666 -0
  77. package/dist/chunk-FMPFLQZV.mjs +670 -0
  78. package/dist/chunk-G25YXZ74.mjs +618 -0
  79. package/dist/chunk-GSG6ZC3R.mjs +37 -0
  80. package/dist/chunk-H3MQUFTJ.mjs +618 -0
  81. package/dist/chunk-HKZRLVBX.mjs +618 -0
  82. package/dist/chunk-HQALJGVT.mjs +618 -0
  83. package/dist/chunk-I5GBZ3UX.mjs +676 -0
  84. package/dist/chunk-IQHBVGA4.mjs +677 -0
  85. package/dist/chunk-IV4V55OA.mjs +672 -0
  86. package/dist/chunk-J2RAFKAD.mjs +618 -0
  87. package/dist/chunk-JL34UFI7.mjs +670 -0
  88. package/dist/chunk-JTKSGGQM.mjs +611 -0
  89. package/dist/chunk-JZC2RRDH.mjs +618 -0
  90. package/dist/chunk-K3Y7VKT6.mjs +670 -0
  91. package/dist/chunk-KEVXNUFG.mjs +672 -0
  92. package/dist/chunk-KRYAP7NG.mjs +670 -0
  93. package/dist/chunk-KU655POK.mjs +657 -0
  94. package/dist/chunk-L55SLVNX.mjs +618 -0
  95. package/dist/chunk-LCRYOZEV.mjs +618 -0
  96. package/dist/chunk-LH7PP6V2.mjs +618 -0
  97. package/dist/chunk-LJMMYKE2.mjs +618 -0
  98. package/dist/chunk-LK5TROLL.mjs +666 -0
  99. package/dist/chunk-MDR7DAKM.mjs +618 -0
  100. package/dist/chunk-MJZLCWZ5.mjs +666 -0
  101. package/dist/chunk-MKZTEJLS.mjs +612 -0
  102. package/dist/chunk-MOD7MLCD.mjs +64 -0
  103. package/dist/chunk-MQCOQHHP.mjs +618 -0
  104. package/dist/chunk-MSM4KUBM.mjs +618 -0
  105. package/dist/chunk-MTIUER63.mjs +676 -0
  106. package/dist/chunk-NBLV3UX5.mjs +618 -0
  107. package/dist/chunk-NLADSOJS.mjs +618 -0
  108. package/dist/chunk-NPMTWR3Y.mjs +618 -0
  109. package/dist/chunk-NQ6GKEO7.mjs +670 -0
  110. package/dist/chunk-NZSFYNUK.mjs +618 -0
  111. package/dist/chunk-OANBDTKG.mjs +73 -0
  112. package/dist/chunk-OCNF4O5U.mjs +612 -0
  113. package/dist/chunk-OCW5QSWA.mjs +618 -0
  114. package/dist/chunk-OQF7JZFS.mjs +670 -0
  115. package/dist/chunk-OT675HGC.mjs +670 -0
  116. package/dist/chunk-P47TCYKN.mjs +618 -0
  117. package/dist/chunk-P7TOGXPI.mjs +672 -0
  118. package/dist/chunk-PCAXXEEQ.mjs +618 -0
  119. package/dist/chunk-PDHMG7OZ.mjs +672 -0
  120. package/dist/chunk-PFGVOZGM.mjs +618 -0
  121. package/dist/chunk-PQSSDK3E.mjs +618 -0
  122. package/dist/chunk-PST7W3NG.mjs +618 -0
  123. package/dist/chunk-QGPBZ2YV.mjs +664 -0
  124. package/dist/chunk-QKTMWS4J.mjs +43 -0
  125. package/dist/chunk-QOPCJITC.mjs +618 -0
  126. package/dist/chunk-QSE52CRC.mjs +618 -0
  127. package/dist/chunk-QTP2QMPL.mjs +669 -0
  128. package/dist/chunk-R47XX6IW.mjs +611 -0
  129. package/dist/chunk-RL6AEU6E.mjs +612 -0
  130. package/dist/chunk-T7T4HCHH.mjs +618 -0
  131. package/dist/chunk-TED2WCDG.mjs +618 -0
  132. package/dist/chunk-TJLIMMMB.mjs +612 -0
  133. package/dist/chunk-TNOJDLON.mjs +611 -0
  134. package/dist/chunk-TOR67IHH.mjs +672 -0
  135. package/dist/chunk-TOV7NVKM.mjs +618 -0
  136. package/dist/chunk-TSYMIRRN.mjs +618 -0
  137. package/dist/chunk-TTSRI4V7.mjs +708 -0
  138. package/dist/chunk-UBS3DTE5.mjs +672 -0
  139. package/dist/chunk-UBW6RYVF.mjs +670 -0
  140. package/dist/chunk-UJNUFKR5.mjs +43 -0
  141. package/dist/chunk-VAZZJOSJ.mjs +618 -0
  142. package/dist/chunk-VCWXOX2B.mjs +618 -0
  143. package/dist/chunk-VHCLEOHZ.mjs +618 -0
  144. package/dist/chunk-VTZSCGME.mjs +666 -0
  145. package/dist/chunk-W33KZ2XR.mjs +618 -0
  146. package/dist/chunk-WOVMTYDV.mjs +612 -0
  147. package/dist/chunk-WR3USBWK.mjs +672 -0
  148. package/dist/chunk-WXYQARQ6.mjs +618 -0
  149. package/dist/chunk-XSDANHCE.mjs +618 -0
  150. package/dist/chunk-Y6XKW4NG.mjs +618 -0
  151. package/dist/chunk-YQSNJFZE.mjs +618 -0
  152. package/dist/chunk-Z6VG6AG7.mjs +678 -0
  153. package/dist/chunk-ZAPKQ4C3.mjs +678 -0
  154. package/dist/chunk-ZCWDQNHL.mjs +618 -0
  155. package/dist/chunk-ZF5JBNCI.mjs +618 -0
  156. package/dist/chunk-ZN7BHWOF.mjs +672 -0
  157. package/dist/chunk-ZUQJKA5J.mjs +666 -0
  158. package/dist/chunk-ZWHWIGYQ.mjs +618 -0
  159. package/dist/index.d.mts +3 -0
  160. package/dist/index.d.ts +3 -0
  161. package/dist/index.js +299 -136
  162. package/dist/index.mjs +21 -13
  163. package/dist/styles.css +288 -181
  164. package/package.json +3 -2
@@ -0,0 +1,618 @@
1
+ import {
2
+ Chevron
3
+ } from "./chunk-ZTRM4HZJ.mjs";
4
+ import {
5
+ Select_default
6
+ } from "./chunk-2LBFKQDZ.mjs";
7
+
8
+ // src/atom/RangePicker/RangePicker.tsx
9
+ import { memo, useEffect, useRef, useState } from "react";
10
+ import clsx from "clsx";
11
+ import dayjs from "dayjs";
12
+
13
+ // src/atom/RangePicker/RangePicker.module.scss
14
+ var RangePicker_module_default = { "range_start": "RangePicker-module__range_start___hGQp-", "range_end": "RangePicker-module__range_end___JJNib" };
15
+
16
+ // src/atom/RangePicker/RangePicker.tsx
17
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
18
+ function CustomRangePicker(props) {
19
+ var _a, _b;
20
+ const {
21
+ id = "",
22
+ footer,
23
+ onChange = () => {
24
+ },
25
+ dateRange = ["", ""],
26
+ showNightCount = false,
27
+ isRange = true,
28
+ showYearDropdown = false,
29
+ showSingleCalendar = false,
30
+ disablePastDates = false,
31
+ // New prop to control past date restriction
32
+ minDate = null,
33
+ // New prop for minimum allowed date
34
+ maxDate = null,
35
+ // New prop for maximum allowed date
36
+ minYear = 1900,
37
+ // Minimum year for dropdown
38
+ maxYear = (/* @__PURE__ */ new Date()).getFullYear() + 10,
39
+ // Maximum year for dropdown
40
+ experience = "business",
41
+ showToastError = () => {
42
+ }
43
+ } = props;
44
+ const onChangeRef = useRef(onChange);
45
+ useEffect(() => {
46
+ onChangeRef.current = onChange;
47
+ }, [onChange]);
48
+ const getInitialDate = () => {
49
+ if (dateRange[0]) {
50
+ return new Date(dateRange[0]);
51
+ }
52
+ if (!minDate && !maxDate && !minYear && !maxYear) {
53
+ return /* @__PURE__ */ new Date();
54
+ }
55
+ if (maxYear && maxYear !== (/* @__PURE__ */ new Date()).getFullYear()) {
56
+ let targetDate = new Date(maxYear, 7, 1);
57
+ if (maxDate) {
58
+ const maxDateTime = new Date(maxDate);
59
+ if (targetDate > maxDateTime) {
60
+ targetDate = new Date(
61
+ maxDateTime.getFullYear(),
62
+ maxDateTime.getMonth(),
63
+ 1
64
+ );
65
+ }
66
+ }
67
+ return targetDate;
68
+ }
69
+ if (minDate) {
70
+ const minDateTime = new Date(minDate);
71
+ minDateTime.setHours(0, 0, 0, 0);
72
+ return minDateTime;
73
+ }
74
+ return /* @__PURE__ */ new Date();
75
+ };
76
+ const [currentDate, setCurrentDate] = useState(() => getInitialDate());
77
+ const [startDate, setStartDate] = useState(
78
+ dateRange[0] ? new Date(dateRange[0]) : null
79
+ );
80
+ const [endDate, setEndDate] = useState(
81
+ dateRange[0] && dateRange[1] ? new Date(dateRange[1]) : null
82
+ );
83
+ const [hoverDate, setHoverDate] = useState(null);
84
+ const [isSelectingEnd, setIsSelectingEnd] = useState(
85
+ dateRange[0] && !dateRange[1] ? true : false
86
+ );
87
+ const [selectedDate, setSelectedDate] = useState(
88
+ !isRange && dateRange[0] ? new Date(dateRange[0]) : null
89
+ );
90
+ const getDaysBetween = (start, end) => {
91
+ if (!start || !end) return 0;
92
+ const startDay = dayjs(start).startOf("day");
93
+ const endDay = dayjs(end).startOf("day");
94
+ return endDay.diff(startDay, "day");
95
+ };
96
+ const nightCount = Math.abs(getDaysBetween(startDate || endDate, hoverDate));
97
+ const nightCountText = nightCount > 1 ? `${nightCount} nights` : "1 night";
98
+ const today = /* @__PURE__ */ new Date();
99
+ today.setHours(0, 0, 0, 0);
100
+ const firstMonth = new Date(
101
+ currentDate.getFullYear(),
102
+ currentDate.getMonth(),
103
+ 1
104
+ );
105
+ const secondMonth = new Date(
106
+ currentDate.getFullYear(),
107
+ currentDate.getMonth() + 1,
108
+ 1
109
+ );
110
+ const monthNames = [
111
+ "January",
112
+ "February",
113
+ "March",
114
+ "April",
115
+ "May",
116
+ "June",
117
+ "July",
118
+ "August",
119
+ "September",
120
+ "October",
121
+ "November",
122
+ "December"
123
+ ];
124
+ const dayNames = ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"];
125
+ const generateYearOptions = () => {
126
+ const years = [];
127
+ for (let i = minYear; i <= maxYear; i++) {
128
+ const isYearDisabled = isYearCompletelyDisabled(i);
129
+ years.push({
130
+ label: i.toString(),
131
+ value: i,
132
+ disabled: isYearDisabled
133
+ });
134
+ }
135
+ return years;
136
+ };
137
+ const isYearCompletelyDisabled = (year) => {
138
+ const firstDayOfYear = new Date(year, 0, 1);
139
+ const lastDayOfYear = new Date(year, 11, 31);
140
+ if (minDate) {
141
+ const minDateTime = new Date(minDate);
142
+ minDateTime.setHours(0, 0, 0, 0);
143
+ if (minDateTime > lastDayOfYear) {
144
+ return true;
145
+ }
146
+ }
147
+ if (maxDate) {
148
+ const maxDateTime = new Date(maxDate);
149
+ maxDateTime.setHours(0, 0, 0, 0);
150
+ if (maxDateTime < firstDayOfYear) {
151
+ return true;
152
+ }
153
+ }
154
+ if (disablePastDates) {
155
+ const today2 = /* @__PURE__ */ new Date();
156
+ today2.setHours(0, 0, 0, 0);
157
+ if (lastDayOfYear < today2) {
158
+ return true;
159
+ }
160
+ }
161
+ return false;
162
+ };
163
+ const yearOptions = generateYearOptions();
164
+ const generateCalendarDays = (monthDate) => {
165
+ const year = monthDate.getFullYear();
166
+ const month = monthDate.getMonth();
167
+ const firstDay = new Date(year, month, 1);
168
+ const lastDay = new Date(year, month + 1, 0);
169
+ const daysInMonth = lastDay.getDate();
170
+ const startingDayOfWeek = firstDay.getDay();
171
+ const days = [];
172
+ for (let i = 0; i < startingDayOfWeek; i++) {
173
+ days.push(null);
174
+ }
175
+ for (let day = 1; day <= daysInMonth; day++) {
176
+ days.push(new Date(year, month, day));
177
+ }
178
+ return days;
179
+ };
180
+ const formatDateKey = (date) => {
181
+ if (!date) return "";
182
+ return `${date.getFullYear()}-${date.getMonth()}-${date.getDate()}`;
183
+ };
184
+ const isSameDate = (date1, date2) => {
185
+ if (!date1 || !date2) return false;
186
+ return formatDateKey(date1) === formatDateKey(date2);
187
+ };
188
+ const isDateDisabled = (date) => {
189
+ if (!date) return false;
190
+ const checkDate = new Date(date);
191
+ checkDate.setHours(0, 0, 0, 0);
192
+ if (disablePastDates && checkDate < today) {
193
+ return true;
194
+ }
195
+ if (minDate) {
196
+ const minDateTime = new Date(minDate);
197
+ minDateTime.setHours(0, 0, 0, 0);
198
+ if (checkDate < minDateTime) {
199
+ return true;
200
+ }
201
+ }
202
+ if (maxDate) {
203
+ const maxDateTime = new Date(maxDate);
204
+ maxDateTime.setHours(0, 0, 0, 0);
205
+ if (checkDate > maxDateTime) {
206
+ return true;
207
+ }
208
+ }
209
+ return false;
210
+ };
211
+ const isDateInRange = (date) => {
212
+ if (!isRange || !startDate || !date) return false;
213
+ const compareDate = endDate || hoverDate;
214
+ if (!compareDate) return false;
215
+ const start = startDate < compareDate ? startDate : compareDate;
216
+ const end = startDate < compareDate ? compareDate : startDate;
217
+ return date >= start && date <= end;
218
+ };
219
+ const isDateBetweenRange = (date) => {
220
+ if (!isRange || !startDate || !date) return false;
221
+ const compareDate = endDate || hoverDate;
222
+ if (!compareDate) return false;
223
+ const start = startDate < compareDate ? startDate : compareDate;
224
+ const end = startDate < compareDate ? compareDate : startDate;
225
+ return date > start && date < end;
226
+ };
227
+ const handleDateClick = (date) => {
228
+ if (isDateDisabled(date)) return;
229
+ if (!isRange) {
230
+ setSelectedDate(date);
231
+ return;
232
+ }
233
+ const isCheckinCheckoutSame = dayjs(date).format("D MMM, YYYY") === dayjs(startDate).format("D MMM, YYYY");
234
+ if (showNightCount && isCheckinCheckoutSame) {
235
+ setStartDate(null);
236
+ setEndDate(null);
237
+ setIsSelectingEnd(false);
238
+ setHoverDate(null);
239
+ showToastError("Check-in and check-out dates cannot be the same.");
240
+ return;
241
+ }
242
+ if (!startDate || startDate && endDate) {
243
+ setStartDate(date);
244
+ setEndDate(null);
245
+ setIsSelectingEnd(true);
246
+ setHoverDate(null);
247
+ } else if (startDate && !endDate) {
248
+ if (date < startDate) {
249
+ setEndDate(startDate);
250
+ setStartDate(date);
251
+ } else {
252
+ setEndDate(date);
253
+ }
254
+ setIsSelectingEnd(false);
255
+ setHoverDate(null);
256
+ }
257
+ };
258
+ useEffect(() => {
259
+ if (isRange) {
260
+ sessionStorage.removeItem("rangePickerStartDate");
261
+ onChangeRef.current(null, [
262
+ startDate ? dayjs(startDate).format("D MMM, YYYY") : "",
263
+ endDate ? dayjs(endDate).format("D MMM, YYYY") : ""
264
+ ]);
265
+ }
266
+ if (isRange && startDate && !endDate) {
267
+ sessionStorage.setItem(
268
+ "rangePickerStartDate",
269
+ dayjs(startDate).format("D MMM, YYYY")
270
+ );
271
+ }
272
+ }, [startDate, endDate, isRange]);
273
+ useEffect(() => {
274
+ if (!isRange && selectedDate) {
275
+ onChangeRef.current(null, dayjs(selectedDate).format("D MMM, YYYY"));
276
+ }
277
+ }, [selectedDate, isRange]);
278
+ const handleDateHover = (date) => {
279
+ if (isDateDisabled(date) || !isRange) return;
280
+ if (isSelectingEnd && startDate && !endDate) {
281
+ setHoverDate(date);
282
+ }
283
+ };
284
+ const navigateMonth = (direction) => {
285
+ const newDate = new Date(currentDate);
286
+ newDate.setMonth(currentDate.getMonth() + direction);
287
+ setCurrentDate(newDate);
288
+ };
289
+ const isPreviousMonthDisabled = () => {
290
+ const previousMonth = new Date(currentDate);
291
+ previousMonth.setMonth(currentDate.getMonth() - 1);
292
+ const lastDayOfPreviousMonth = new Date(
293
+ previousMonth.getFullYear(),
294
+ previousMonth.getMonth() + 1,
295
+ 0
296
+ );
297
+ return isDateDisabled(lastDayOfPreviousMonth);
298
+ };
299
+ const isNextMonthDisabled = () => {
300
+ const nextMonth = new Date(currentDate);
301
+ nextMonth.setMonth(currentDate.getMonth() + 1);
302
+ const firstDayOfNextMonth = new Date(
303
+ nextMonth.getFullYear(),
304
+ nextMonth.getMonth(),
305
+ 1
306
+ );
307
+ return isDateDisabled(firstDayOfNextMonth);
308
+ };
309
+ const handleYearChange = (selectedYear) => {
310
+ const newDate = new Date(currentDate);
311
+ newDate.setFullYear(selectedYear);
312
+ const targetMonth = newDate.getMonth();
313
+ if (!isMonthDisabled(selectedYear, targetMonth)) {
314
+ setCurrentDate(newDate);
315
+ } else {
316
+ const firstAvailableMonth = findFirstAvailableMonth(selectedYear);
317
+ if (firstAvailableMonth !== -1) {
318
+ newDate.setMonth(firstAvailableMonth);
319
+ setCurrentDate(newDate);
320
+ }
321
+ }
322
+ };
323
+ const isMonthDisabled = (year, month) => {
324
+ const lastDayOfMonth = new Date(year, month + 1, 0);
325
+ const firstDayOfMonth = new Date(year, month, 1);
326
+ return isDateDisabled(lastDayOfMonth) && isDateDisabled(firstDayOfMonth);
327
+ };
328
+ const findFirstAvailableMonth = (year) => {
329
+ for (let month = 0; month < 12; month++) {
330
+ if (!isMonthDisabled(year, month)) {
331
+ return month;
332
+ }
333
+ }
334
+ return -1;
335
+ };
336
+ const isSameDay = ((_a = dayjs(startDate)) == null ? void 0 : _a.format("D MMM, YYYY")) === ((_b = dayjs(endDate)) == null ? void 0 : _b.format("D MMM, YYYY"));
337
+ const NightCountTooltip = () => {
338
+ const TooltipArrow = memo(() => {
339
+ return /* @__PURE__ */ jsx("div", { className: "tw-w-3 tw-h-3 tw-flex tw-items-center tw-justify-center tw-rounded tw-bg-transparent tw-rotate-90", children: /* @__PURE__ */ jsx(
340
+ "div",
341
+ {
342
+ style: {
343
+ borderTop: "5px solid transparent",
344
+ borderBottom: "5px solid transparent",
345
+ borderLeft: "8px solid black"
346
+ }
347
+ }
348
+ ) });
349
+ });
350
+ return /* @__PURE__ */ jsxs("div", { className: "tw-absolute tw-bottom-11 tw-py-2 tw-bg-black tw-text-white tw-px-2 tw-rounded-lg tw-z-50 tw-text-xs tw-whitespace-nowrap tw-opacity-0 tw-pointer-events-none group-hover:tw-opacity-100 tw-transition-opacity tw-duration-200", children: [
351
+ nightCountText,
352
+ /* @__PURE__ */ jsx("div", { className: "tw-absolute tw-right-[42%] tw-bottom-[-7px]", children: /* @__PURE__ */ jsx(TooltipArrow, {}) })
353
+ ] });
354
+ };
355
+ const renderCalendar = (monthDate, isSecondCalendar = false) => {
356
+ const days = generateCalendarDays(monthDate);
357
+ const monthName = monthNames[monthDate.getMonth()];
358
+ const year = monthDate.getFullYear();
359
+ return /* @__PURE__ */ jsxs(
360
+ "div",
361
+ {
362
+ className: clsx("tw-flex-1 tw-max-w-[83vw] tw-mb-2", {
363
+ "tw-h-[320px]": showYearDropdown || days.length > 35,
364
+ "tw-h-[290px]": !showYearDropdown || days.length <= 35
365
+ }),
366
+ children: [
367
+ /* @__PURE__ */ jsx("div", { className: "tw-text-center tw-mb-4 sm:tw-mt-0", children: /* @__PURE__ */ jsxs("div", { className: " tw-flex tw-justify-center tw-items-center tw-gap-4 ", children: [
368
+ /* @__PURE__ */ jsxs("h3", { className: "tw-typography-footNoteBold tw-text-color-text-default tw-m-0", children: [
369
+ monthName,
370
+ " ",
371
+ !showYearDropdown && ` ${year}`
372
+ ] }),
373
+ showYearDropdown && /* @__PURE__ */ jsx(
374
+ Select_default,
375
+ {
376
+ options: yearOptions,
377
+ value: currentDate.getFullYear(),
378
+ valueSelected: currentDate.getFullYear(),
379
+ onChange: (selectedYear) => {
380
+ if (typeof selectedYear === "number") {
381
+ handleYearChange(selectedYear);
382
+ }
383
+ },
384
+ className: "tw-min-w-fit tw-bg-transparent tw-typography-footNoteBold tw-text-color-text-default",
385
+ size: "small",
386
+ variant: "filled",
387
+ style: { width: "80px" },
388
+ id: `${id}-year-select`,
389
+ allowClear: false,
390
+ enableSearch: false,
391
+ experience
392
+ }
393
+ )
394
+ ] }) }),
395
+ /* @__PURE__ */ jsx("div", { className: "tw-grid tw-grid-cols-7 tw-mb-2", children: dayNames.map((day) => /* @__PURE__ */ jsx(
396
+ "div",
397
+ {
398
+ className: "tw-py-2 tw-px-0 tw-text-center tw-typography-caption2 tw-text-[#6B7280]",
399
+ children: day
400
+ },
401
+ day
402
+ )) }),
403
+ /* @__PURE__ */ jsx("div", { className: "tw-grid tw-grid-cols-7", children: days.map((date, index) => {
404
+ if (!date) {
405
+ return /* @__PURE__ */ jsx("div", { className: "tw-h-10" }, index);
406
+ }
407
+ const isStart = isRange ? isSameDate(date, startDate) : false;
408
+ const isEnd = isRange ? isSameDate(date, endDate) : false;
409
+ const isSelected = !isRange ? isSameDate(date, selectedDate) : false;
410
+ const isInRange = isRange ? isDateBetweenRange(date) : false;
411
+ const isHovering = isRange && isSelectingEnd && hoverDate && isDateInRange(date) && !isStart && !isEnd;
412
+ const isDisabled = isDateDisabled(date);
413
+ let className = "tw-relative tw-z-20 tw-h-10 tw-w-10 tw-flex tw-items-center tw-justify-center tw-typography-caption1Bold ";
414
+ const isFirstInRow = index % 7 === 0;
415
+ const isLastInRow = index % 7 === 6;
416
+ let pseudoClass = "";
417
+ if (isDisabled) {
418
+ className += "tw-text-gray-300 tw-cursor-not-allowed ";
419
+ } else {
420
+ className += "tw-cursor-pointer ";
421
+ if (isStart || isEnd || isSelected) {
422
+ className += "tw-bg-black tw-z-[21] tw-text-white tw-font-medium tw-rounded-full ";
423
+ } else if (isInRange) {
424
+ className += "tw-text-gray-900";
425
+ if (window.innerWidth < 640) {
426
+ className = className.replace(
427
+ "tw-w-10",
428
+ "tw-pr-2 tw-w-[50px] sm:tw-w-10 sm:tw-pr-0"
429
+ );
430
+ }
431
+ pseudoClass = clsx(RangePicker_module_default.range_start, RangePicker_module_default.range_end);
432
+ } else {
433
+ className += "tw-text-gray-700 hover:tw-border-2 hover:tw-border-black tw-rounded-full hover:tw-border-solid ";
434
+ }
435
+ if (isHovering) {
436
+ className += "tw-border-2 tw-border-gray-400 tw-bg-white tw-z-[22]";
437
+ }
438
+ }
439
+ const titleDate = dayjs(date).format("YYYY-MM-DD");
440
+ const hoverDateFormatted = dayjs(hoverDate || null).format(
441
+ "YYYY-MM-DD"
442
+ );
443
+ const isHoveringDate = dayjs(hoverDateFormatted).isSame(
444
+ dayjs(date),
445
+ "day"
446
+ );
447
+ const isHoverDateGreater = dayjs(hoverDate).isAfter(
448
+ dayjs(startDate),
449
+ "day"
450
+ );
451
+ const isHoverDateLess = dayjs(hoverDate).isBefore(
452
+ dayjs(startDate),
453
+ "day"
454
+ );
455
+ return /* @__PURE__ */ jsxs("div", { className: "tw-relative", children: [
456
+ (isStart || isEnd) && startDate && endDate && !isSameDay && isRange && /* @__PURE__ */ jsx(
457
+ "div",
458
+ {
459
+ className: clsx(
460
+ "tw-w-9 tw-h-8 tw-bg-[#F2EFEC] tw-rotate-90 tw-absolute tw-z-10 tw-top-1",
461
+ {
462
+ "tw-left-5": isStart,
463
+ "tw-right-5": isEnd,
464
+ "tw-invisible": isFirstInRow && isEnd || isLastInRow && isStart
465
+ }
466
+ )
467
+ }
468
+ ),
469
+ isHoveringDate && isHovering && /* @__PURE__ */ jsxs(Fragment, { children: [
470
+ /* @__PURE__ */ jsx(
471
+ "div",
472
+ {
473
+ className: clsx(
474
+ "tw-w-9 tw-h-8 tw-bg-[#F2EFEC] tw-rotate-90 tw-absolute tw-z-10 tw-top-1",
475
+ {
476
+ "tw-right-5": isHoverDateGreater,
477
+ "tw-left-5": isHoverDateLess,
478
+ "tw-invisible": isFirstInRow && isHoverDateGreater || isLastInRow && isHoverDateLess
479
+ }
480
+ )
481
+ }
482
+ ),
483
+ /* @__PURE__ */ jsx(
484
+ "div",
485
+ {
486
+ className: clsx(
487
+ "tw-w-[18px] tw-h-[40px] tw-bg-white tw-rounded-r-full tw-absolute tw-z-20",
488
+ {
489
+ "tw-left-5": isHoverDateLess,
490
+ "tw-right-5 tw-rotate-180": isHoverDateGreater
491
+ }
492
+ )
493
+ }
494
+ )
495
+ ] }),
496
+ isStart && /* @__PURE__ */ jsxs(Fragment, { children: [
497
+ /* @__PURE__ */ jsx(
498
+ "div",
499
+ {
500
+ className: clsx(
501
+ "tw-w-9 tw-h-8 tw-bg-[#F2EFEC] tw-rotate-90 tw-absolute tw-z-10 tw-top-1",
502
+ {
503
+ "tw-right-5": isHoverDateLess,
504
+ "tw-left-5": isHoverDateGreater,
505
+ "tw-invisible": isLastInRow
506
+ }
507
+ )
508
+ }
509
+ ),
510
+ /* @__PURE__ */ jsx(
511
+ "div",
512
+ {
513
+ className: clsx(
514
+ "tw-w-[18px] tw-h-[40px] tw-bg-white tw-rounded-r-full tw-absolute tw-z-20",
515
+ {
516
+ "tw-left-5": isHoverDateGreater,
517
+ "tw-right-5 tw-rotate-180": isHoverDateLess
518
+ }
519
+ )
520
+ }
521
+ )
522
+ ] }),
523
+ /* @__PURE__ */ jsxs(
524
+ "div",
525
+ {
526
+ className: clsx(className, pseudoClass, "tw-group", {
527
+ "tw-border-2 !tw-border-black tw-rounded-full tw-border-solid": dayjs(date).isSame(dayjs(hoverDate), "day")
528
+ }),
529
+ onClick: () => handleDateClick(date),
530
+ onMouseEnter: () => handleDateHover(date),
531
+ "data-date": titleDate,
532
+ children: [
533
+ showNightCount && isRange && isHovering && /* @__PURE__ */ jsx(NightCountTooltip, {}),
534
+ date.getDate()
535
+ ]
536
+ }
537
+ )
538
+ ] }, formatDateKey(date));
539
+ }) })
540
+ ]
541
+ }
542
+ );
543
+ };
544
+ const arrowClasses = "tw-relative tw-top-3 sm:tw-top-0 tw-cursor-pointer tw-rounded-full tw-w-10 tw-h-10 tw-flex tw-justify-center hover:tw-bg-gray-100 tw-items-center";
545
+ return /* @__PURE__ */ jsxs(
546
+ "div",
547
+ {
548
+ className: clsx(
549
+ "custom-range-picker tw-relative tw-bg-white tw-rounded-xl tw-pt-1 tw-px-0 tw-max-w-4xl tw-mx-auto tw-border tw-border-gray-200 tw-border-solid tw-w-full tw-max-h-[90vh] tw-overflow-y-auto",
550
+ {
551
+ "sm:tw-w-[640px]": !showSingleCalendar,
552
+ "sm:tw-w-[330px]": showSingleCalendar
553
+ }
554
+ ),
555
+ children: [
556
+ /* @__PURE__ */ jsxs("div", { className: "tw-flex tw-items-center tw-px-4 tw-justify-between tw-mb-4 tw-absolute tw-right-0 tw-left-0 tw-top-0.5 sm:tw-top-4 tw-w-auto", children: [
557
+ !isPreviousMonthDisabled() && /* @__PURE__ */ jsx(
558
+ "div",
559
+ {
560
+ className: clsx(arrowClasses, "tw-left-1"),
561
+ onClick: () => navigateMonth(-1),
562
+ id: "calendar-previous-month-button",
563
+ children: /* @__PURE__ */ jsx(
564
+ Chevron,
565
+ {
566
+ size: "medium",
567
+ className: "tw-relative -tw-top-0.5 tw-right-0.5"
568
+ }
569
+ )
570
+ }
571
+ ),
572
+ isPreviousMonthDisabled() && /* @__PURE__ */ jsx("div", { className: "tw-w-10 tw-h-10" }),
573
+ !isNextMonthDisabled() && /* @__PURE__ */ jsx(
574
+ "div",
575
+ {
576
+ className: clsx(arrowClasses, "tw-mt-[1px] tw-right-1"),
577
+ onClick: () => navigateMonth(1),
578
+ id: "calendar-next-month-button",
579
+ children: /* @__PURE__ */ jsx(
580
+ Chevron,
581
+ {
582
+ size: "medium",
583
+ onClick: () => navigateMonth(1),
584
+ className: "tw-rotate-180 tw-relative tw-top-0.5 tw-left-0.5"
585
+ }
586
+ )
587
+ }
588
+ ),
589
+ isNextMonthDisabled() && /* @__PURE__ */ jsx("div", { className: "tw-w-10 tw-h-10" })
590
+ ] }),
591
+ /* @__PURE__ */ jsx("div", { className: "tw-flex tw-items-center tw-justify-between tw-px-6 tw-border-solid tw-border-color-gray-100 tw-border-b tw-border-t-0 tw-border-l-0 tw-border-r-0 tw-w-auto", children: /* @__PURE__ */ jsxs(
592
+ "div",
593
+ {
594
+ className: clsx("tw-flex tw-w-full", {
595
+ "tw-flex-col sm:tw-space-x-8 sm:tw-flex-row": isRange || !showSingleCalendar,
596
+ "tw-justify-center": !isRange || showSingleCalendar,
597
+ "tw-pt-4": showYearDropdown,
598
+ // More space when year dropdown is visible
599
+ "tw-pt-6": !showYearDropdown
600
+ }),
601
+ children: [
602
+ renderCalendar(firstMonth),
603
+ !showSingleCalendar && renderCalendar(secondMonth, true)
604
+ ]
605
+ }
606
+ ) }),
607
+ footer
608
+ ]
609
+ }
610
+ );
611
+ }
612
+ CustomRangePicker.displayName = "RangePicker";
613
+ var RangePicker_default = CustomRangePicker;
614
+
615
+ export {
616
+ CustomRangePicker,
617
+ RangePicker_default
618
+ };