@ilamy/calendar 0.1.2 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -41
- package/dist/index.cjs +377 -361
- package/dist/index.d.cts +39 -35
- package/dist/index.d.ts +39 -35
- package/dist/index.js +291 -280
- package/package.json +16 -13
package/dist/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
// src/features/month-view/components/month-view.tsx
|
|
3
3
|
import { AnimatePresence as AnimatePresence3, motion as motion3 } from "motion/react";
|
|
4
|
-
import
|
|
4
|
+
import React6, { useMemo as useMemo2 } from "react";
|
|
5
5
|
|
|
6
6
|
// src/contexts/calendar-context/context.ts
|
|
7
7
|
import { createContext, useContext } from "react";
|
|
@@ -46,7 +46,173 @@ import { ChevronDownIcon } from "lucide-react";
|
|
|
46
46
|
|
|
47
47
|
// src/lib/utils.ts
|
|
48
48
|
import { clsx } from "clsx";
|
|
49
|
+
|
|
50
|
+
// src/lib/dayjs-config.ts
|
|
49
51
|
import dayjs from "dayjs";
|
|
52
|
+
import weekday from "dayjs/plugin/weekday.js";
|
|
53
|
+
import weekOfYear from "dayjs/plugin/weekOfYear.js";
|
|
54
|
+
import isSameOrAfter from "dayjs/plugin/isSameOrAfter.js";
|
|
55
|
+
import isSameOrBefore from "dayjs/plugin/isSameOrBefore.js";
|
|
56
|
+
import isBetween from "dayjs/plugin/isBetween.js";
|
|
57
|
+
import minMax from "dayjs/plugin/minMax.js";
|
|
58
|
+
import timezone from "dayjs/plugin/timezone.js";
|
|
59
|
+
import utc from "dayjs/plugin/utc.js";
|
|
60
|
+
import localeData from "dayjs/plugin/localeData.js";
|
|
61
|
+
import"dayjs/locale/af.js";
|
|
62
|
+
import"dayjs/locale/am.js";
|
|
63
|
+
import"dayjs/locale/ar-dz.js";
|
|
64
|
+
import"dayjs/locale/ar-iq.js";
|
|
65
|
+
import"dayjs/locale/ar-kw.js";
|
|
66
|
+
import"dayjs/locale/ar-ly.js";
|
|
67
|
+
import"dayjs/locale/ar-ma.js";
|
|
68
|
+
import"dayjs/locale/ar-sa.js";
|
|
69
|
+
import"dayjs/locale/ar-tn.js";
|
|
70
|
+
import"dayjs/locale/ar.js";
|
|
71
|
+
import"dayjs/locale/az.js";
|
|
72
|
+
import"dayjs/locale/be.js";
|
|
73
|
+
import"dayjs/locale/bg.js";
|
|
74
|
+
import"dayjs/locale/bi.js";
|
|
75
|
+
import"dayjs/locale/bm.js";
|
|
76
|
+
import"dayjs/locale/bn-bd.js";
|
|
77
|
+
import"dayjs/locale/bn.js";
|
|
78
|
+
import"dayjs/locale/bo.js";
|
|
79
|
+
import"dayjs/locale/br.js";
|
|
80
|
+
import"dayjs/locale/bs.js";
|
|
81
|
+
import"dayjs/locale/ca.js";
|
|
82
|
+
import"dayjs/locale/cs.js";
|
|
83
|
+
import"dayjs/locale/cv.js";
|
|
84
|
+
import"dayjs/locale/cy.js";
|
|
85
|
+
import"dayjs/locale/da.js";
|
|
86
|
+
import"dayjs/locale/de-at.js";
|
|
87
|
+
import"dayjs/locale/de-ch.js";
|
|
88
|
+
import"dayjs/locale/de.js";
|
|
89
|
+
import"dayjs/locale/dv.js";
|
|
90
|
+
import"dayjs/locale/el.js";
|
|
91
|
+
import"dayjs/locale/en-au.js";
|
|
92
|
+
import"dayjs/locale/en-ca.js";
|
|
93
|
+
import"dayjs/locale/en-gb.js";
|
|
94
|
+
import"dayjs/locale/en-ie.js";
|
|
95
|
+
import"dayjs/locale/en-il.js";
|
|
96
|
+
import"dayjs/locale/en-in.js";
|
|
97
|
+
import"dayjs/locale/en-nz.js";
|
|
98
|
+
import"dayjs/locale/en-sg.js";
|
|
99
|
+
import"dayjs/locale/en-tt.js";
|
|
100
|
+
import"dayjs/locale/en.js";
|
|
101
|
+
import"dayjs/locale/eo.js";
|
|
102
|
+
import"dayjs/locale/es-do.js";
|
|
103
|
+
import"dayjs/locale/es-mx.js";
|
|
104
|
+
import"dayjs/locale/es-pr.js";
|
|
105
|
+
import"dayjs/locale/es-us.js";
|
|
106
|
+
import"dayjs/locale/es.js";
|
|
107
|
+
import"dayjs/locale/et.js";
|
|
108
|
+
import"dayjs/locale/eu.js";
|
|
109
|
+
import"dayjs/locale/fa.js";
|
|
110
|
+
import"dayjs/locale/fi.js";
|
|
111
|
+
import"dayjs/locale/fo.js";
|
|
112
|
+
import"dayjs/locale/fr-ca.js";
|
|
113
|
+
import"dayjs/locale/fr-ch.js";
|
|
114
|
+
import"dayjs/locale/fr.js";
|
|
115
|
+
import"dayjs/locale/fy.js";
|
|
116
|
+
import"dayjs/locale/ga.js";
|
|
117
|
+
import"dayjs/locale/gd.js";
|
|
118
|
+
import"dayjs/locale/gl.js";
|
|
119
|
+
import"dayjs/locale/gom-latn.js";
|
|
120
|
+
import"dayjs/locale/gu.js";
|
|
121
|
+
import"dayjs/locale/he.js";
|
|
122
|
+
import"dayjs/locale/hi.js";
|
|
123
|
+
import"dayjs/locale/hr.js";
|
|
124
|
+
import"dayjs/locale/ht.js";
|
|
125
|
+
import"dayjs/locale/hu.js";
|
|
126
|
+
import"dayjs/locale/hy-am.js";
|
|
127
|
+
import"dayjs/locale/id.js";
|
|
128
|
+
import"dayjs/locale/is.js";
|
|
129
|
+
import"dayjs/locale/it-ch.js";
|
|
130
|
+
import"dayjs/locale/it.js";
|
|
131
|
+
import"dayjs/locale/ja.js";
|
|
132
|
+
import"dayjs/locale/jv.js";
|
|
133
|
+
import"dayjs/locale/ka.js";
|
|
134
|
+
import"dayjs/locale/kk.js";
|
|
135
|
+
import"dayjs/locale/km.js";
|
|
136
|
+
import"dayjs/locale/kn.js";
|
|
137
|
+
import"dayjs/locale/ko.js";
|
|
138
|
+
import"dayjs/locale/ku.js";
|
|
139
|
+
import"dayjs/locale/ky.js";
|
|
140
|
+
import"dayjs/locale/lb.js";
|
|
141
|
+
import"dayjs/locale/lo.js";
|
|
142
|
+
import"dayjs/locale/lt.js";
|
|
143
|
+
import"dayjs/locale/lv.js";
|
|
144
|
+
import"dayjs/locale/me.js";
|
|
145
|
+
import"dayjs/locale/mi.js";
|
|
146
|
+
import"dayjs/locale/mk.js";
|
|
147
|
+
import"dayjs/locale/ml.js";
|
|
148
|
+
import"dayjs/locale/mn.js";
|
|
149
|
+
import"dayjs/locale/mr.js";
|
|
150
|
+
import"dayjs/locale/ms-my.js";
|
|
151
|
+
import"dayjs/locale/ms.js";
|
|
152
|
+
import"dayjs/locale/mt.js";
|
|
153
|
+
import"dayjs/locale/my.js";
|
|
154
|
+
import"dayjs/locale/nb.js";
|
|
155
|
+
import"dayjs/locale/ne.js";
|
|
156
|
+
import"dayjs/locale/nl-be.js";
|
|
157
|
+
import"dayjs/locale/nl.js";
|
|
158
|
+
import"dayjs/locale/nn.js";
|
|
159
|
+
import"dayjs/locale/oc-lnc.js";
|
|
160
|
+
import"dayjs/locale/pa-in.js";
|
|
161
|
+
import"dayjs/locale/pl.js";
|
|
162
|
+
import"dayjs/locale/pt-br.js";
|
|
163
|
+
import"dayjs/locale/pt.js";
|
|
164
|
+
import"dayjs/locale/rn.js";
|
|
165
|
+
import"dayjs/locale/ro.js";
|
|
166
|
+
import"dayjs/locale/ru.js";
|
|
167
|
+
import"dayjs/locale/rw.js";
|
|
168
|
+
import"dayjs/locale/sd.js";
|
|
169
|
+
import"dayjs/locale/se.js";
|
|
170
|
+
import"dayjs/locale/si.js";
|
|
171
|
+
import"dayjs/locale/sk.js";
|
|
172
|
+
import"dayjs/locale/sl.js";
|
|
173
|
+
import"dayjs/locale/sq.js";
|
|
174
|
+
import"dayjs/locale/sr-cyrl.js";
|
|
175
|
+
import"dayjs/locale/sr.js";
|
|
176
|
+
import"dayjs/locale/ss.js";
|
|
177
|
+
import"dayjs/locale/sv-fi.js";
|
|
178
|
+
import"dayjs/locale/sv.js";
|
|
179
|
+
import"dayjs/locale/sw.js";
|
|
180
|
+
import"dayjs/locale/ta.js";
|
|
181
|
+
import"dayjs/locale/te.js";
|
|
182
|
+
import"dayjs/locale/tet.js";
|
|
183
|
+
import"dayjs/locale/tg.js";
|
|
184
|
+
import"dayjs/locale/th.js";
|
|
185
|
+
import"dayjs/locale/tk.js";
|
|
186
|
+
import"dayjs/locale/tl-ph.js";
|
|
187
|
+
import"dayjs/locale/tlh.js";
|
|
188
|
+
import"dayjs/locale/tr.js";
|
|
189
|
+
import"dayjs/locale/tzl.js";
|
|
190
|
+
import"dayjs/locale/tzm-latn.js";
|
|
191
|
+
import"dayjs/locale/tzm.js";
|
|
192
|
+
import"dayjs/locale/ug-cn.js";
|
|
193
|
+
import"dayjs/locale/uk.js";
|
|
194
|
+
import"dayjs/locale/ur.js";
|
|
195
|
+
import"dayjs/locale/uz-latn.js";
|
|
196
|
+
import"dayjs/locale/uz.js";
|
|
197
|
+
import"dayjs/locale/vi.js";
|
|
198
|
+
import"dayjs/locale/x-pseudo.js";
|
|
199
|
+
import"dayjs/locale/yo.js";
|
|
200
|
+
import"dayjs/locale/zh-cn.js";
|
|
201
|
+
import"dayjs/locale/zh-hk.js";
|
|
202
|
+
import"dayjs/locale/zh-tw.js";
|
|
203
|
+
import"dayjs/locale/zh.js";
|
|
204
|
+
dayjs.extend(weekday);
|
|
205
|
+
dayjs.extend(weekOfYear);
|
|
206
|
+
dayjs.extend(isSameOrAfter);
|
|
207
|
+
dayjs.extend(isSameOrBefore);
|
|
208
|
+
dayjs.extend(isBetween);
|
|
209
|
+
dayjs.extend(minMax);
|
|
210
|
+
dayjs.extend(timezone);
|
|
211
|
+
dayjs.extend(utc);
|
|
212
|
+
dayjs.extend(localeData);
|
|
213
|
+
var dayjs_config_default = dayjs;
|
|
214
|
+
|
|
215
|
+
// src/lib/utils.ts
|
|
50
216
|
import { twMerge } from "tailwind-merge";
|
|
51
217
|
function cn(...inputs) {
|
|
52
218
|
return twMerge(clsx(inputs));
|
|
@@ -204,7 +370,6 @@ function Checkbox({
|
|
|
204
370
|
// src/components/ui/card.tsx
|
|
205
371
|
import { jsxDEV as jsxDEV7 } from "react/jsx-dev-runtime";
|
|
206
372
|
// src/components/ui/date-picker.tsx
|
|
207
|
-
import dayjs2 from "dayjs";
|
|
208
373
|
import { Calendar as CalendarIcon } from "lucide-react";
|
|
209
374
|
|
|
210
375
|
// src/components/ui/popover.tsx
|
|
@@ -274,7 +439,7 @@ function DatePicker({
|
|
|
274
439
|
/* @__PURE__ */ jsxDEV9(CalendarIcon, {
|
|
275
440
|
className: "mr-2 h-4 w-4"
|
|
276
441
|
}, undefined, false, undefined, this),
|
|
277
|
-
date ?
|
|
442
|
+
date ? dayjs_config_default(date).format("MMM D, YYYY") : /* @__PURE__ */ jsxDEV9("span", {
|
|
278
443
|
children: label
|
|
279
444
|
}, undefined, false, undefined, this)
|
|
280
445
|
]
|
|
@@ -398,14 +563,27 @@ import * as DropdownMenuPrimitive from "@radix-ui/react-dropdown-menu";
|
|
|
398
563
|
import { CheckIcon as CheckIcon2, ChevronRightIcon, CircleIcon } from "lucide-react";
|
|
399
564
|
import { jsxDEV as jsxDEV11 } from "react/jsx-dev-runtime";
|
|
400
565
|
// src/components/ui/form.tsx
|
|
401
|
-
import * as
|
|
566
|
+
import * as React2 from "react";
|
|
402
567
|
import { Slot as Slot3 } from "@radix-ui/react-slot";
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
568
|
+
|
|
569
|
+
// node_modules/react-hook-form/dist/index.esm.mjs
|
|
570
|
+
import * as React from "react";
|
|
571
|
+
import React__default from "react";
|
|
572
|
+
var isWeb = typeof window !== "undefined" && typeof window.HTMLElement !== "undefined" && typeof document !== "undefined";
|
|
573
|
+
var VALIDATION_MODE = {
|
|
574
|
+
onBlur: "onBlur",
|
|
575
|
+
onChange: "onChange",
|
|
576
|
+
onSubmit: "onSubmit",
|
|
577
|
+
onTouched: "onTouched",
|
|
578
|
+
all: "all"
|
|
579
|
+
};
|
|
580
|
+
var HookFormContext = React__default.createContext(null);
|
|
581
|
+
HookFormContext.displayName = "HookFormContext";
|
|
582
|
+
var defaultOptions = {
|
|
583
|
+
mode: VALIDATION_MODE.onSubmit,
|
|
584
|
+
reValidateMode: VALIDATION_MODE.onChange,
|
|
585
|
+
shouldFocusError: true
|
|
586
|
+
};
|
|
409
587
|
|
|
410
588
|
// src/components/ui/label.tsx
|
|
411
589
|
import * as LabelPrimitive from "@radix-ui/react-label";
|
|
@@ -424,8 +602,8 @@ function Label2({
|
|
|
424
602
|
|
|
425
603
|
// src/components/ui/form.tsx
|
|
426
604
|
import { jsxDEV as jsxDEV13 } from "react/jsx-dev-runtime";
|
|
427
|
-
var FormFieldContext =
|
|
428
|
-
var FormItemContext =
|
|
605
|
+
var FormFieldContext = React2.createContext({});
|
|
606
|
+
var FormItemContext = React2.createContext({});
|
|
429
607
|
// src/components/ui/input.tsx
|
|
430
608
|
import { jsxDEV as jsxDEV14 } from "react/jsx-dev-runtime";
|
|
431
609
|
function Input({ className, type, ...props }) {
|
|
@@ -647,173 +825,8 @@ var AllEventDialog = ({ ref }) => {
|
|
|
647
825
|
}, undefined, false, undefined, this);
|
|
648
826
|
};
|
|
649
827
|
|
|
650
|
-
// src/lib/dayjs-config.ts
|
|
651
|
-
import dayjs3 from "dayjs";
|
|
652
|
-
import weekday from "dayjs/plugin/weekday.js";
|
|
653
|
-
import weekOfYear from "dayjs/plugin/weekOfYear.js";
|
|
654
|
-
import isSameOrAfter from "dayjs/plugin/isSameOrAfter.js";
|
|
655
|
-
import isSameOrBefore from "dayjs/plugin/isSameOrBefore.js";
|
|
656
|
-
import isBetween from "dayjs/plugin/isBetween.js";
|
|
657
|
-
import minMax from "dayjs/plugin/minMax.js";
|
|
658
|
-
import timezone from "dayjs/plugin/timezone.js";
|
|
659
|
-
import utc from "dayjs/plugin/utc.js";
|
|
660
|
-
import localeData from "dayjs/plugin/localeData.js";
|
|
661
|
-
import"dayjs/locale/af";
|
|
662
|
-
import"dayjs/locale/am";
|
|
663
|
-
import"dayjs/locale/ar-dz";
|
|
664
|
-
import"dayjs/locale/ar-iq";
|
|
665
|
-
import"dayjs/locale/ar-kw";
|
|
666
|
-
import"dayjs/locale/ar-ly";
|
|
667
|
-
import"dayjs/locale/ar-ma";
|
|
668
|
-
import"dayjs/locale/ar-sa";
|
|
669
|
-
import"dayjs/locale/ar-tn";
|
|
670
|
-
import"dayjs/locale/ar";
|
|
671
|
-
import"dayjs/locale/az";
|
|
672
|
-
import"dayjs/locale/be";
|
|
673
|
-
import"dayjs/locale/bg";
|
|
674
|
-
import"dayjs/locale/bi";
|
|
675
|
-
import"dayjs/locale/bm";
|
|
676
|
-
import"dayjs/locale/bn-bd";
|
|
677
|
-
import"dayjs/locale/bn";
|
|
678
|
-
import"dayjs/locale/bo";
|
|
679
|
-
import"dayjs/locale/br";
|
|
680
|
-
import"dayjs/locale/bs";
|
|
681
|
-
import"dayjs/locale/ca";
|
|
682
|
-
import"dayjs/locale/cs";
|
|
683
|
-
import"dayjs/locale/cv";
|
|
684
|
-
import"dayjs/locale/cy";
|
|
685
|
-
import"dayjs/locale/da";
|
|
686
|
-
import"dayjs/locale/de-at";
|
|
687
|
-
import"dayjs/locale/de-ch";
|
|
688
|
-
import"dayjs/locale/de";
|
|
689
|
-
import"dayjs/locale/dv";
|
|
690
|
-
import"dayjs/locale/el";
|
|
691
|
-
import"dayjs/locale/en-au";
|
|
692
|
-
import"dayjs/locale/en-ca";
|
|
693
|
-
import"dayjs/locale/en-gb";
|
|
694
|
-
import"dayjs/locale/en-ie";
|
|
695
|
-
import"dayjs/locale/en-il";
|
|
696
|
-
import"dayjs/locale/en-in";
|
|
697
|
-
import"dayjs/locale/en-nz";
|
|
698
|
-
import"dayjs/locale/en-sg";
|
|
699
|
-
import"dayjs/locale/en-tt";
|
|
700
|
-
import"dayjs/locale/en";
|
|
701
|
-
import"dayjs/locale/eo";
|
|
702
|
-
import"dayjs/locale/es-do";
|
|
703
|
-
import"dayjs/locale/es-mx";
|
|
704
|
-
import"dayjs/locale/es-pr";
|
|
705
|
-
import"dayjs/locale/es-us";
|
|
706
|
-
import"dayjs/locale/es";
|
|
707
|
-
import"dayjs/locale/et";
|
|
708
|
-
import"dayjs/locale/eu";
|
|
709
|
-
import"dayjs/locale/fa";
|
|
710
|
-
import"dayjs/locale/fi";
|
|
711
|
-
import"dayjs/locale/fo";
|
|
712
|
-
import"dayjs/locale/fr-ca";
|
|
713
|
-
import"dayjs/locale/fr-ch";
|
|
714
|
-
import"dayjs/locale/fr";
|
|
715
|
-
import"dayjs/locale/fy";
|
|
716
|
-
import"dayjs/locale/ga";
|
|
717
|
-
import"dayjs/locale/gd";
|
|
718
|
-
import"dayjs/locale/gl";
|
|
719
|
-
import"dayjs/locale/gom-latn";
|
|
720
|
-
import"dayjs/locale/gu";
|
|
721
|
-
import"dayjs/locale/he";
|
|
722
|
-
import"dayjs/locale/hi";
|
|
723
|
-
import"dayjs/locale/hr";
|
|
724
|
-
import"dayjs/locale/ht";
|
|
725
|
-
import"dayjs/locale/hu";
|
|
726
|
-
import"dayjs/locale/hy-am";
|
|
727
|
-
import"dayjs/locale/id";
|
|
728
|
-
import"dayjs/locale/is";
|
|
729
|
-
import"dayjs/locale/it-ch";
|
|
730
|
-
import"dayjs/locale/it";
|
|
731
|
-
import"dayjs/locale/ja";
|
|
732
|
-
import"dayjs/locale/jv";
|
|
733
|
-
import"dayjs/locale/ka";
|
|
734
|
-
import"dayjs/locale/kk";
|
|
735
|
-
import"dayjs/locale/km";
|
|
736
|
-
import"dayjs/locale/kn";
|
|
737
|
-
import"dayjs/locale/ko";
|
|
738
|
-
import"dayjs/locale/ku";
|
|
739
|
-
import"dayjs/locale/ky";
|
|
740
|
-
import"dayjs/locale/lb";
|
|
741
|
-
import"dayjs/locale/lo";
|
|
742
|
-
import"dayjs/locale/lt";
|
|
743
|
-
import"dayjs/locale/lv";
|
|
744
|
-
import"dayjs/locale/me";
|
|
745
|
-
import"dayjs/locale/mi";
|
|
746
|
-
import"dayjs/locale/mk";
|
|
747
|
-
import"dayjs/locale/ml";
|
|
748
|
-
import"dayjs/locale/mn";
|
|
749
|
-
import"dayjs/locale/mr";
|
|
750
|
-
import"dayjs/locale/ms-my";
|
|
751
|
-
import"dayjs/locale/ms";
|
|
752
|
-
import"dayjs/locale/mt";
|
|
753
|
-
import"dayjs/locale/my";
|
|
754
|
-
import"dayjs/locale/nb";
|
|
755
|
-
import"dayjs/locale/ne";
|
|
756
|
-
import"dayjs/locale/nl-be";
|
|
757
|
-
import"dayjs/locale/nl";
|
|
758
|
-
import"dayjs/locale/nn";
|
|
759
|
-
import"dayjs/locale/oc-lnc";
|
|
760
|
-
import"dayjs/locale/pa-in";
|
|
761
|
-
import"dayjs/locale/pl";
|
|
762
|
-
import"dayjs/locale/pt-br";
|
|
763
|
-
import"dayjs/locale/pt";
|
|
764
|
-
import"dayjs/locale/rn";
|
|
765
|
-
import"dayjs/locale/ro";
|
|
766
|
-
import"dayjs/locale/ru";
|
|
767
|
-
import"dayjs/locale/rw";
|
|
768
|
-
import"dayjs/locale/sd";
|
|
769
|
-
import"dayjs/locale/se";
|
|
770
|
-
import"dayjs/locale/si";
|
|
771
|
-
import"dayjs/locale/sk";
|
|
772
|
-
import"dayjs/locale/sl";
|
|
773
|
-
import"dayjs/locale/sq";
|
|
774
|
-
import"dayjs/locale/sr-cyrl";
|
|
775
|
-
import"dayjs/locale/sr";
|
|
776
|
-
import"dayjs/locale/ss";
|
|
777
|
-
import"dayjs/locale/sv-fi";
|
|
778
|
-
import"dayjs/locale/sv";
|
|
779
|
-
import"dayjs/locale/sw";
|
|
780
|
-
import"dayjs/locale/ta";
|
|
781
|
-
import"dayjs/locale/te";
|
|
782
|
-
import"dayjs/locale/tet";
|
|
783
|
-
import"dayjs/locale/tg";
|
|
784
|
-
import"dayjs/locale/th";
|
|
785
|
-
import"dayjs/locale/tk";
|
|
786
|
-
import"dayjs/locale/tl-ph";
|
|
787
|
-
import"dayjs/locale/tlh";
|
|
788
|
-
import"dayjs/locale/tr";
|
|
789
|
-
import"dayjs/locale/tzl";
|
|
790
|
-
import"dayjs/locale/tzm-latn";
|
|
791
|
-
import"dayjs/locale/tzm";
|
|
792
|
-
import"dayjs/locale/ug-cn";
|
|
793
|
-
import"dayjs/locale/uk";
|
|
794
|
-
import"dayjs/locale/ur";
|
|
795
|
-
import"dayjs/locale/uz-latn";
|
|
796
|
-
import"dayjs/locale/uz";
|
|
797
|
-
import"dayjs/locale/vi";
|
|
798
|
-
import"dayjs/locale/x-pseudo";
|
|
799
|
-
import"dayjs/locale/yo";
|
|
800
|
-
import"dayjs/locale/zh-cn";
|
|
801
|
-
import"dayjs/locale/zh-hk";
|
|
802
|
-
import"dayjs/locale/zh-tw";
|
|
803
|
-
import"dayjs/locale/zh";
|
|
804
|
-
dayjs3.extend(weekday);
|
|
805
|
-
dayjs3.extend(weekOfYear);
|
|
806
|
-
dayjs3.extend(isSameOrAfter);
|
|
807
|
-
dayjs3.extend(isSameOrBefore);
|
|
808
|
-
dayjs3.extend(isBetween);
|
|
809
|
-
dayjs3.extend(minMax);
|
|
810
|
-
dayjs3.extend(timezone);
|
|
811
|
-
dayjs3.extend(utc);
|
|
812
|
-
dayjs3.extend(localeData);
|
|
813
|
-
var dayjs_config_default = dayjs3;
|
|
814
|
-
|
|
815
828
|
// src/features/month-view/components/day-cell.tsx
|
|
816
|
-
import
|
|
829
|
+
import React4 from "react";
|
|
817
830
|
|
|
818
831
|
// src/features/droppable-cell/droppable-cell.tsx
|
|
819
832
|
import { useDroppable } from "@dnd-kit/core";
|
|
@@ -872,7 +885,7 @@ var DayCell = ({
|
|
|
872
885
|
day,
|
|
873
886
|
className = ""
|
|
874
887
|
}) => {
|
|
875
|
-
const allEventsDialogRef =
|
|
888
|
+
const allEventsDialogRef = React4.useRef(null);
|
|
876
889
|
const {
|
|
877
890
|
events,
|
|
878
891
|
currentDate,
|
|
@@ -946,13 +959,17 @@ var DayCell = ({
|
|
|
946
959
|
// src/features/month-view/components/month-header.tsx
|
|
947
960
|
import { AnimatePresence as AnimatePresence2, motion as motion2 } from "motion/react";
|
|
948
961
|
import { useMemo } from "react";
|
|
949
|
-
import dayjs4 from "dayjs";
|
|
950
962
|
import { jsxDEV as jsxDEV28 } from "react/jsx-dev-runtime";
|
|
951
963
|
var MonthHeader = () => {
|
|
952
|
-
const {
|
|
964
|
+
const {
|
|
965
|
+
firstDayOfWeek,
|
|
966
|
+
currentLocale,
|
|
967
|
+
stickyViewHeader,
|
|
968
|
+
viewHeaderClassName
|
|
969
|
+
} = useCalendarContext();
|
|
953
970
|
const weekDays = useMemo(() => {
|
|
954
|
-
const days =
|
|
955
|
-
const shortDays =
|
|
971
|
+
const days = dayjs_config_default.weekdays().map((day) => day.toLowerCase());
|
|
972
|
+
const shortDays = dayjs_config_default.weekdaysShort().map((day) => day.toLowerCase());
|
|
956
973
|
for (let i = 0;i < firstDayOfWeek; i++) {
|
|
957
974
|
const dayToMove = days.shift();
|
|
958
975
|
const shortDayToMove = shortDays.shift();
|
|
@@ -964,7 +981,7 @@ var MonthHeader = () => {
|
|
|
964
981
|
return { days, shortDays };
|
|
965
982
|
}, [firstDayOfWeek, currentLocale]);
|
|
966
983
|
return /* @__PURE__ */ jsxDEV28("div", {
|
|
967
|
-
className: cn("grid grid-cols-7 border-b
|
|
984
|
+
className: cn("grid grid-cols-7 border-b", stickyViewHeader && "sticky top-0 z-100", viewHeaderClassName),
|
|
968
985
|
"data-testid": "month-header",
|
|
969
986
|
children: weekDays.days.map((weekDay, index) => /* @__PURE__ */ jsxDEV28(AnimatePresence2, {
|
|
970
987
|
mode: "wait",
|
|
@@ -996,7 +1013,7 @@ var MonthHeader = () => {
|
|
|
996
1013
|
|
|
997
1014
|
// src/lib/constants.ts
|
|
998
1015
|
var GAP_BETWEEN_ELEMENTS = 1;
|
|
999
|
-
var DAY_NUMBER_HEIGHT =
|
|
1016
|
+
var DAY_NUMBER_HEIGHT = 28;
|
|
1000
1017
|
var EVENT_BAR_HEIGHT = 24;
|
|
1001
1018
|
|
|
1002
1019
|
// src/features/month-view/components/week-events-layer.tsx
|
|
@@ -1144,7 +1161,7 @@ var WeekEventsLayer = ({ days }) => {
|
|
|
1144
1161
|
// src/features/month-view/components/month-view.tsx
|
|
1145
1162
|
import { jsxDEV as jsxDEV30 } from "react/jsx-dev-runtime";
|
|
1146
1163
|
var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
1147
|
-
const allEventsDialogRef =
|
|
1164
|
+
const allEventsDialogRef = React6.useRef(null);
|
|
1148
1165
|
const { currentDate, firstDayOfWeek } = useCalendarContext();
|
|
1149
1166
|
const firstDayOfMonth = currentDate.startOf("month");
|
|
1150
1167
|
let adjustedFirstDayOfCalendar = firstDayOfMonth.clone();
|
|
@@ -1168,8 +1185,8 @@ var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
|
1168
1185
|
"data-testid": "month-view",
|
|
1169
1186
|
children: [
|
|
1170
1187
|
/* @__PURE__ */ jsxDEV30(MonthHeader, {}, undefined, false, undefined, this),
|
|
1171
|
-
/* @__PURE__ */ jsxDEV30(
|
|
1172
|
-
className: "flex-1 overflow-auto",
|
|
1188
|
+
/* @__PURE__ */ jsxDEV30("div", {
|
|
1189
|
+
className: "flex-1 overflow-auto h-full",
|
|
1173
1190
|
"data-testid": "month-scroll-area",
|
|
1174
1191
|
children: /* @__PURE__ */ jsxDEV30(AnimatePresence3, {
|
|
1175
1192
|
mode: "wait",
|
|
@@ -1178,7 +1195,7 @@ var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
|
1178
1195
|
animate: { opacity: 1 },
|
|
1179
1196
|
exit: { opacity: 0 },
|
|
1180
1197
|
transition: { duration: 0.25, ease: "easeInOut" },
|
|
1181
|
-
className: "relative grid
|
|
1198
|
+
className: "relative grid h-full grid-cols-7 grid-rows-6 overflow-auto",
|
|
1182
1199
|
"data-testid": "month-calendar-grid",
|
|
1183
1200
|
children: calendarDays.map((days, index) => {
|
|
1184
1201
|
return /* @__PURE__ */ jsxDEV30("div", {
|
|
@@ -1213,7 +1230,6 @@ var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
|
1213
1230
|
};
|
|
1214
1231
|
|
|
1215
1232
|
// src/features/week-view/week-view.tsx
|
|
1216
|
-
import dayjs9 from "dayjs";
|
|
1217
1233
|
import weekOfYear2 from "dayjs/plugin/weekOfYear";
|
|
1218
1234
|
|
|
1219
1235
|
// src/features/week-view/week-all-day-row.tsx
|
|
@@ -1234,7 +1250,7 @@ var WeekAllDayRow = () => {
|
|
|
1234
1250
|
const weekEvents = allEvents.filter((event) => {
|
|
1235
1251
|
return event.start.isSameOrAfter(adjustedStartOfWeek) && event.start.isSameOrBefore(endOfWeek) || event.end.isSameOrAfter(adjustedStartOfWeek) && event.end.isSameOrBefore(endOfWeek) || event.start.isBefore(adjustedStartOfWeek) && event.end.isAfter(endOfWeek);
|
|
1236
1252
|
});
|
|
1237
|
-
const allDayEvents = weekEvents.filter((event) => event.
|
|
1253
|
+
const allDayEvents = weekEvents.filter((event) => event.allDay);
|
|
1238
1254
|
const { processedAllDayEvents } = useMemo3(() => {
|
|
1239
1255
|
const sortedEvents = [...allDayEvents].sort((a, b) => {
|
|
1240
1256
|
const startDiff = a.start.diff(b.start);
|
|
@@ -1278,7 +1294,7 @@ var WeekAllDayRow = () => {
|
|
|
1278
1294
|
width,
|
|
1279
1295
|
top: rowIndex * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),
|
|
1280
1296
|
height: EVENT_BAR_HEIGHT,
|
|
1281
|
-
|
|
1297
|
+
allDay: true
|
|
1282
1298
|
});
|
|
1283
1299
|
});
|
|
1284
1300
|
return {
|
|
@@ -1325,7 +1341,6 @@ var WeekAllDayRow = () => {
|
|
|
1325
1341
|
};
|
|
1326
1342
|
|
|
1327
1343
|
// src/features/week-view/week-header.tsx
|
|
1328
|
-
import dayjs5 from "dayjs";
|
|
1329
1344
|
import { AnimatePresence as AnimatePresence4, motion as motion4 } from "motion/react";
|
|
1330
1345
|
import { jsxDEV as jsxDEV32 } from "react/jsx-dev-runtime";
|
|
1331
1346
|
var WeekHeader = () => {
|
|
@@ -1334,7 +1349,8 @@ var WeekHeader = () => {
|
|
|
1334
1349
|
selectDate,
|
|
1335
1350
|
openEventForm,
|
|
1336
1351
|
firstDayOfWeek,
|
|
1337
|
-
|
|
1352
|
+
stickyViewHeader,
|
|
1353
|
+
viewHeaderClassName
|
|
1338
1354
|
} = useCalendarContext();
|
|
1339
1355
|
const startOfWeek = currentDate.startOf("week").day(firstDayOfWeek);
|
|
1340
1356
|
const adjustedStartOfWeek = currentDate.isBefore(startOfWeek) ? startOfWeek.subtract(1, "week") : startOfWeek;
|
|
@@ -1343,7 +1359,7 @@ var WeekHeader = () => {
|
|
|
1343
1359
|
weekDays.push(adjustedStartOfWeek.add(i, "day"));
|
|
1344
1360
|
}
|
|
1345
1361
|
return /* @__PURE__ */ jsxDEV32("div", {
|
|
1346
|
-
className: cn("grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1
|
|
1362
|
+
className: cn("grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1", stickyViewHeader && "sticky top-0 z-100", viewHeaderClassName),
|
|
1347
1363
|
"data-testid": "week-header",
|
|
1348
1364
|
children: [
|
|
1349
1365
|
/* @__PURE__ */ jsxDEV32("div", {
|
|
@@ -1363,7 +1379,7 @@ var WeekHeader = () => {
|
|
|
1363
1379
|
}, undefined, true, undefined, this)
|
|
1364
1380
|
}, undefined, false, undefined, this),
|
|
1365
1381
|
weekDays.map((day, index) => {
|
|
1366
|
-
const isToday = day.isSame(
|
|
1382
|
+
const isToday = day.isSame(dayjs_config_default(), "day");
|
|
1367
1383
|
return /* @__PURE__ */ jsxDEV32(AnimatePresence4, {
|
|
1368
1384
|
mode: "wait",
|
|
1369
1385
|
children: /* @__PURE__ */ jsxDEV32(motion4.div, {
|
|
@@ -1398,20 +1414,13 @@ var WeekHeader = () => {
|
|
|
1398
1414
|
}, undefined, true, undefined, this);
|
|
1399
1415
|
};
|
|
1400
1416
|
|
|
1401
|
-
// src/features/week-view/week-time-grid.tsx
|
|
1402
|
-
import dayjs8 from "dayjs";
|
|
1403
|
-
|
|
1404
|
-
// src/features/week-view/week-day-col.tsx
|
|
1405
|
-
import dayjs7 from "dayjs";
|
|
1406
|
-
|
|
1407
1417
|
// src/hooks/useProcessedDayEvents.ts
|
|
1408
|
-
import dayjs6 from "dayjs";
|
|
1409
1418
|
import { useMemo as useMemo4 } from "react";
|
|
1410
1419
|
var useProcessedDayEvents = ({ day }) => {
|
|
1411
1420
|
const { getEventsForDateRange } = useCalendarContext();
|
|
1412
1421
|
const todayEvents = useMemo4(() => {
|
|
1413
1422
|
let eventsForDay = getEventsForDateRange(day.startOf("day"), day.endOf("day"));
|
|
1414
|
-
eventsForDay = eventsForDay.filter((e) => !e.
|
|
1423
|
+
eventsForDay = eventsForDay.filter((e) => !e.allDay).toSorted((a, b) => a.start.diff(b.start));
|
|
1415
1424
|
if (eventsForDay.length === 0) {
|
|
1416
1425
|
return [];
|
|
1417
1426
|
}
|
|
@@ -1426,7 +1435,7 @@ var useProcessedDayEvents = ({ day }) => {
|
|
|
1426
1435
|
currentCluster = [];
|
|
1427
1436
|
}
|
|
1428
1437
|
currentCluster.push(event);
|
|
1429
|
-
lastEventEnd = lastEventEnd ?
|
|
1438
|
+
lastEventEnd = lastEventEnd ? dayjs_config_default.max(lastEventEnd, event.end) : event.end;
|
|
1430
1439
|
}
|
|
1431
1440
|
if (currentCluster.length > 0) {
|
|
1432
1441
|
clusters.push(currentCluster);
|
|
@@ -1538,7 +1547,7 @@ var DayEventsLayer = ({
|
|
|
1538
1547
|
|
|
1539
1548
|
// src/features/week-view/week-day-col.tsx
|
|
1540
1549
|
import { jsxDEV as jsxDEV34 } from "react/jsx-dev-runtime";
|
|
1541
|
-
var hours = Array.from({ length: 24 }, (_, i) => i).map((hour) =>
|
|
1550
|
+
var hours = Array.from({ length: 24 }, (_, i) => i).map((hour) => dayjs_config_default().hour(hour).minute(0));
|
|
1542
1551
|
var WeekDayCol = ({ day }) => {
|
|
1543
1552
|
return /* @__PURE__ */ jsxDEV34("div", {
|
|
1544
1553
|
"data-testid": `week-day-col-${day.format("YYYY-MM-DD")}`,
|
|
@@ -1566,7 +1575,7 @@ var WeekDayCol = ({ day }) => {
|
|
|
1566
1575
|
|
|
1567
1576
|
// src/features/week-view/week-time-grid.tsx
|
|
1568
1577
|
import { jsxDEV as jsxDEV35 } from "react/jsx-dev-runtime";
|
|
1569
|
-
var hours2 = Array.from({ length: 24 }, (_, i) => i).map((hour) =>
|
|
1578
|
+
var hours2 = Array.from({ length: 24 }, (_, i) => i).map((hour) => dayjs_config_default().hour(hour).minute(0));
|
|
1570
1579
|
var WeekTimeGrid = () => {
|
|
1571
1580
|
const { currentDate, firstDayOfWeek } = useCalendarContext();
|
|
1572
1581
|
const startOfWeek = currentDate.startOf("week").day(firstDayOfWeek);
|
|
@@ -1575,7 +1584,7 @@ var WeekTimeGrid = () => {
|
|
|
1575
1584
|
for (let i = 0;i < 7; i++) {
|
|
1576
1585
|
weekDays.push(adjustedStartOfWeek.add(i, "day"));
|
|
1577
1586
|
}
|
|
1578
|
-
const todayIndex = weekDays.findIndex((day) => day.isSame(
|
|
1587
|
+
const todayIndex = weekDays.findIndex((day) => day.isSame(dayjs_config_default(), "day"));
|
|
1579
1588
|
const isCurrentWeek = todayIndex !== -1;
|
|
1580
1589
|
return /* @__PURE__ */ jsxDEV35("div", {
|
|
1581
1590
|
"data-testid": "week-time-grid",
|
|
@@ -1600,7 +1609,7 @@ var WeekTimeGrid = () => {
|
|
|
1600
1609
|
"data-testid": "week-current-time-indicator",
|
|
1601
1610
|
className: "pointer-events-none absolute z-20",
|
|
1602
1611
|
style: {
|
|
1603
|
-
top: `${(
|
|
1612
|
+
top: `${(dayjs_config_default().hour() + dayjs_config_default().minute() / 60) * 60}px`,
|
|
1604
1613
|
left: `${todayIndex * (100 / 7)}%`,
|
|
1605
1614
|
width: `${100 / 7}%`
|
|
1606
1615
|
},
|
|
@@ -1617,7 +1626,7 @@ var WeekTimeGrid = () => {
|
|
|
1617
1626
|
|
|
1618
1627
|
// src/features/week-view/week-view.tsx
|
|
1619
1628
|
import { jsxDEV as jsxDEV36 } from "react/jsx-dev-runtime";
|
|
1620
|
-
|
|
1629
|
+
dayjs_config_default.extend(weekOfYear2);
|
|
1621
1630
|
var WeekView = () => {
|
|
1622
1631
|
return /* @__PURE__ */ jsxDEV36("div", {
|
|
1623
1632
|
className: "flex h-full flex-col",
|
|
@@ -1638,7 +1647,6 @@ var WeekView = () => {
|
|
|
1638
1647
|
var week_view_default = WeekView;
|
|
1639
1648
|
|
|
1640
1649
|
// src/features/day-view/day-view.tsx
|
|
1641
|
-
import dayjs12 from "dayjs";
|
|
1642
1650
|
import { Fragment as Fragment2 } from "react";
|
|
1643
1651
|
|
|
1644
1652
|
// src/features/day-view/day-all-day-row.tsx
|
|
@@ -1648,8 +1656,8 @@ var DayAllDayRow = () => {
|
|
|
1648
1656
|
const { currentDate, getEventsForDate } = useCalendarContext();
|
|
1649
1657
|
const dayEvents = getEventsForDate(currentDate);
|
|
1650
1658
|
const { allDayEvents } = useMemo5(() => {
|
|
1651
|
-
const allDayEvts = dayEvents.filter((event) => event.
|
|
1652
|
-
const regularEvts = dayEvents.filter((event) => !event.
|
|
1659
|
+
const allDayEvts = dayEvents.filter((event) => event.allDay);
|
|
1660
|
+
const regularEvts = dayEvents.filter((event) => !event.allDay);
|
|
1653
1661
|
return { allDayEvents: allDayEvts, regularEvents: regularEvts };
|
|
1654
1662
|
}, [dayEvents]);
|
|
1655
1663
|
const { processedAllDayEvents } = useMemo5(() => {
|
|
@@ -1675,7 +1683,7 @@ var DayAllDayRow = () => {
|
|
|
1675
1683
|
width: 100,
|
|
1676
1684
|
top: rowIndex * EVENT_BAR_HEIGHT,
|
|
1677
1685
|
height: EVENT_BAR_HEIGHT,
|
|
1678
|
-
|
|
1686
|
+
allDay: true
|
|
1679
1687
|
});
|
|
1680
1688
|
});
|
|
1681
1689
|
return {
|
|
@@ -1720,14 +1728,13 @@ var DayAllDayRow = () => {
|
|
|
1720
1728
|
|
|
1721
1729
|
// src/features/day-view/day-header.tsx
|
|
1722
1730
|
import { AnimatePresence as AnimatePresence5, motion as motion5 } from "motion/react";
|
|
1723
|
-
import dayjs10 from "dayjs";
|
|
1724
1731
|
import { jsxDEV as jsxDEV38 } from "react/jsx-dev-runtime";
|
|
1725
1732
|
var DayHeader = () => {
|
|
1726
|
-
const { currentDate,
|
|
1727
|
-
const isToday = currentDate.isSame(
|
|
1733
|
+
const { currentDate, stickyViewHeader, viewHeaderClassName } = useCalendarContext();
|
|
1734
|
+
const isToday = currentDate.isSame(dayjs_config_default(), "day");
|
|
1728
1735
|
return /* @__PURE__ */ jsxDEV38("div", {
|
|
1729
1736
|
"data-testid": "day-header",
|
|
1730
|
-
className: cn("flex items-center justify-center border-b p-2 border-x
|
|
1737
|
+
className: cn("flex items-center justify-center border-b p-2 border-x", stickyViewHeader && "sticky top-0 z-100", viewHeaderClassName),
|
|
1731
1738
|
children: /* @__PURE__ */ jsxDEV38(AnimatePresence5, {
|
|
1732
1739
|
mode: "wait",
|
|
1733
1740
|
children: /* @__PURE__ */ jsxDEV38(motion5.div, {
|
|
@@ -1753,10 +1760,9 @@ var DayHeader = () => {
|
|
|
1753
1760
|
};
|
|
1754
1761
|
|
|
1755
1762
|
// src/features/day-view/day-time-col.tsx
|
|
1756
|
-
import dayjs11 from "dayjs";
|
|
1757
1763
|
import { jsxDEV as jsxDEV39 } from "react/jsx-dev-runtime";
|
|
1758
1764
|
var hours3 = Array.from({ length: 24 }, (_, i) => i).map((hour) => {
|
|
1759
|
-
return
|
|
1765
|
+
return dayjs_config_default().hour(hour).minute(0);
|
|
1760
1766
|
});
|
|
1761
1767
|
var DayTimeCol = ({ className }) => {
|
|
1762
1768
|
return /* @__PURE__ */ jsxDEV39("div", {
|
|
@@ -1778,10 +1784,10 @@ import { jsxDEV as jsxDEV40 } from "react/jsx-dev-runtime";
|
|
|
1778
1784
|
var DayView = () => {
|
|
1779
1785
|
const { currentDate } = useCalendarContext();
|
|
1780
1786
|
const hours4 = Array.from({ length: 24 }, (_, i) => i).map((hour) => {
|
|
1781
|
-
return
|
|
1787
|
+
return dayjs_config_default().hour(hour).minute(0);
|
|
1782
1788
|
});
|
|
1783
1789
|
const timeSegments = [0, 15, 30, 45];
|
|
1784
|
-
const isToday = currentDate.isSame(
|
|
1790
|
+
const isToday = currentDate.isSame(dayjs_config_default(), "day");
|
|
1785
1791
|
const cellDate = currentDate.format("YYYY-MM-DD");
|
|
1786
1792
|
return /* @__PURE__ */ jsxDEV40("div", {
|
|
1787
1793
|
"data-testid": "day-view",
|
|
@@ -1866,7 +1872,7 @@ var DayView = () => {
|
|
|
1866
1872
|
"data-testid": "day-current-time-indicator",
|
|
1867
1873
|
className: "absolute right-0 left-0 z-40 border-t border-red-500",
|
|
1868
1874
|
style: {
|
|
1869
|
-
top: `${(
|
|
1875
|
+
top: `${(dayjs_config_default().hour() + dayjs_config_default().minute() / 60) * 60}px`
|
|
1870
1876
|
},
|
|
1871
1877
|
children: /* @__PURE__ */ jsxDEV40("div", {
|
|
1872
1878
|
className: "-mt-1 -ml-1 h-2 w-2 rounded-full bg-red-500"
|
|
@@ -1884,8 +1890,7 @@ var DayView = () => {
|
|
|
1884
1890
|
var day_view_default = DayView;
|
|
1885
1891
|
|
|
1886
1892
|
// src/components/event-form/event-form.tsx
|
|
1887
|
-
import
|
|
1888
|
-
import { useEffect, useState as useState2 } from "react";
|
|
1893
|
+
import { useEffect as useEffect2, useState as useState2 } from "react";
|
|
1889
1894
|
import { jsxDEV as jsxDEV41 } from "react/jsx-dev-runtime";
|
|
1890
1895
|
var colorOptions = [
|
|
1891
1896
|
{ value: "bg-blue-100 text-blue-800", label: "Blue" },
|
|
@@ -1914,13 +1919,13 @@ var EventForm = ({
|
|
|
1914
1919
|
const start = selectedEvent?.originalStart ?? selectedEvent?.start;
|
|
1915
1920
|
const end = selectedEvent?.originalEnd ?? selectedEvent?.end;
|
|
1916
1921
|
const defaultStartDate = selectedDate?.toDate() || new Date;
|
|
1917
|
-
const defaultEndDate = selectedDate?.add(1, "hour").toDate() ||
|
|
1922
|
+
const defaultEndDate = selectedDate?.add(1, "hour").toDate() || dayjs_config_default().add(1, "hour").toDate();
|
|
1918
1923
|
const [startDate, setStartDate] = useState2(start?.toDate() || defaultStartDate);
|
|
1919
1924
|
const [endDate, setEndDate] = useState2(end?.toDate() || defaultEndDate);
|
|
1920
|
-
const [isAllDay, setIsAllDay] = useState2(selectedEvent?.
|
|
1925
|
+
const [isAllDay, setIsAllDay] = useState2(selectedEvent?.allDay || false);
|
|
1921
1926
|
const [selectedColor, setSelectedColor] = useState2(selectedEvent?.color || colorOptions[0].value);
|
|
1922
|
-
const [startTime, setStartTime] = useState2(selectedEvent ? selectedEvent.start.format("HH:mm") :
|
|
1923
|
-
const [endTime, setEndTime] = useState2(selectedEvent ? selectedEvent.end.format("HH:mm") :
|
|
1927
|
+
const [startTime, setStartTime] = useState2(selectedEvent ? selectedEvent.start.format("HH:mm") : dayjs_config_default(defaultStartDate).format("HH:mm"));
|
|
1928
|
+
const [endTime, setEndTime] = useState2(selectedEvent ? selectedEvent.end.format("HH:mm") : dayjs_config_default(defaultEndDate).format("HH:mm"));
|
|
1924
1929
|
const [formValues, setFormValues] = useState2({
|
|
1925
1930
|
title: selectedEvent?.title || "",
|
|
1926
1931
|
description: selectedEvent?.description || "",
|
|
@@ -1946,7 +1951,7 @@ var EventForm = ({
|
|
|
1946
1951
|
setEndTime(timeValue);
|
|
1947
1952
|
}
|
|
1948
1953
|
};
|
|
1949
|
-
|
|
1954
|
+
useEffect2(() => {
|
|
1950
1955
|
if (isAllDay) {
|
|
1951
1956
|
setEndTime("23:59");
|
|
1952
1957
|
}
|
|
@@ -1955,20 +1960,20 @@ var EventForm = ({
|
|
|
1955
1960
|
e.preventDefault();
|
|
1956
1961
|
const [startHours, startMinutes] = startTime.split(":").map(Number);
|
|
1957
1962
|
const [endHours, endMinutes] = endTime.split(":").map(Number);
|
|
1958
|
-
let startDateTime =
|
|
1959
|
-
let endDateTime =
|
|
1963
|
+
let startDateTime = dayjs_config_default(startDate).hour(startHours).minute(startMinutes);
|
|
1964
|
+
let endDateTime = dayjs_config_default(endDate).hour(endHours).minute(endMinutes);
|
|
1960
1965
|
if (isAllDay) {
|
|
1961
1966
|
startDateTime = startDateTime.hour(0).minute(0);
|
|
1962
1967
|
endDateTime = endDateTime.hour(23).minute(59);
|
|
1963
1968
|
}
|
|
1964
1969
|
const eventData = {
|
|
1965
|
-
id: selectedEvent?.id ||
|
|
1970
|
+
id: selectedEvent?.id || dayjs_config_default().format("YYYYMMDDHHmmss"),
|
|
1966
1971
|
title: formValues.title,
|
|
1967
1972
|
start: startDateTime,
|
|
1968
1973
|
end: endDateTime,
|
|
1969
1974
|
description: formValues.description,
|
|
1970
1975
|
location: formValues.location,
|
|
1971
|
-
|
|
1976
|
+
allDay: isAllDay,
|
|
1972
1977
|
color: selectedColor
|
|
1973
1978
|
};
|
|
1974
1979
|
if (selectedEvent.id) {
|
|
@@ -1984,8 +1989,8 @@ var EventForm = ({
|
|
|
1984
1989
|
onClose();
|
|
1985
1990
|
}
|
|
1986
1991
|
};
|
|
1987
|
-
|
|
1988
|
-
if (
|
|
1992
|
+
useEffect2(() => {
|
|
1993
|
+
if (dayjs_config_default(startDate).isAfter(dayjs_config_default(endDate))) {
|
|
1989
1994
|
setEndDate(startDate);
|
|
1990
1995
|
}
|
|
1991
1996
|
}, [startDate, endDate]);
|
|
@@ -2037,12 +2042,12 @@ var EventForm = ({
|
|
|
2037
2042
|
className: "flex items-center space-x-2",
|
|
2038
2043
|
children: [
|
|
2039
2044
|
/* @__PURE__ */ jsxDEV41(Checkbox, {
|
|
2040
|
-
id: "
|
|
2045
|
+
id: "allDay",
|
|
2041
2046
|
checked: isAllDay,
|
|
2042
2047
|
onCheckedChange: (checked) => setIsAllDay(checked === true)
|
|
2043
2048
|
}, undefined, false, undefined, this),
|
|
2044
2049
|
/* @__PURE__ */ jsxDEV41(Label2, {
|
|
2045
|
-
htmlFor: "
|
|
2050
|
+
htmlFor: "allDay",
|
|
2046
2051
|
className: "text-xs sm:text-sm",
|
|
2047
2052
|
children: "All day"
|
|
2048
2053
|
}, undefined, false, undefined, this)
|
|
@@ -2233,7 +2238,6 @@ import { Calendar as CalendarIcon2, Menu, Plus } from "lucide-react";
|
|
|
2233
2238
|
import { useCallback, useState as useState4 } from "react";
|
|
2234
2239
|
|
|
2235
2240
|
// src/components/header/title-content.tsx
|
|
2236
|
-
import dayjs14 from "dayjs";
|
|
2237
2241
|
import { AnimatePresence as AnimatePresence6, motion as motion6 } from "motion/react";
|
|
2238
2242
|
import { ChevronDown } from "lucide-react";
|
|
2239
2243
|
import { useState as useState3 } from "react";
|
|
@@ -2457,7 +2461,7 @@ var TitleContent = () => {
|
|
|
2457
2461
|
return Array.from({ length: daysInMonth }, (_, i) => {
|
|
2458
2462
|
const dayDate = firstDayOfMonth.date(i + 1);
|
|
2459
2463
|
const isCurrentDay = dayDate.isSame(currentDate, "day");
|
|
2460
|
-
const isToday = dayDate.isSame(
|
|
2464
|
+
const isToday = dayDate.isSame(dayjs_config_default(), "day");
|
|
2461
2465
|
return /* @__PURE__ */ jsxDEV42(Button, {
|
|
2462
2466
|
variant: "ghost",
|
|
2463
2467
|
className: cn("justify-start font-normal", isCurrentDay && "bg-primary/10"),
|
|
@@ -2704,14 +2708,13 @@ var Header2 = () => {
|
|
|
2704
2708
|
};
|
|
2705
2709
|
var base_header_default = Header2;
|
|
2706
2710
|
// src/features/year-view/year-view.tsx
|
|
2707
|
-
import dayjs15 from "dayjs";
|
|
2708
2711
|
import { AnimatePresence as AnimatePresence7, motion as motion7 } from "motion/react";
|
|
2709
2712
|
import { jsxDEV as jsxDEV45 } from "react/jsx-dev-runtime";
|
|
2710
2713
|
var YearView = () => {
|
|
2711
2714
|
const { currentDate, selectDate, events, setView, getEventsForDate } = useCalendarContext();
|
|
2712
2715
|
const year = currentDate.year();
|
|
2713
2716
|
const months2 = Array.from({ length: 12 }, (_, i) => {
|
|
2714
|
-
const monthDate =
|
|
2717
|
+
const monthDate = dayjs_config_default().year(year).month(i).startOf("month");
|
|
2715
2718
|
return {
|
|
2716
2719
|
date: monthDate,
|
|
2717
2720
|
name: monthDate.format("MMMM"),
|
|
@@ -2740,7 +2743,7 @@ var YearView = () => {
|
|
|
2740
2743
|
const daysArray = Array.from({ length: 42 }, (_, i) => {
|
|
2741
2744
|
const day = firstDayOfCalendar.add(i, "day");
|
|
2742
2745
|
const isCurrentMonth = day.month() === month.date.month();
|
|
2743
|
-
const isToday = day.isSame(
|
|
2746
|
+
const isToday = day.isSame(dayjs_config_default(), "day");
|
|
2744
2747
|
const isCurrentDate = day.isSame(currentDate, "day");
|
|
2745
2748
|
const dayEvents = getEventsForDate(day);
|
|
2746
2749
|
const hasEvents = dayEvents.length > 0;
|
|
@@ -2853,13 +2856,12 @@ import {
|
|
|
2853
2856
|
useSensor,
|
|
2854
2857
|
useSensors
|
|
2855
2858
|
} from "@dnd-kit/core";
|
|
2856
|
-
import
|
|
2857
|
-
import React9 from "react";
|
|
2859
|
+
import React10 from "react";
|
|
2858
2860
|
import { snapCenterToCursor } from "@dnd-kit/modifiers";
|
|
2859
2861
|
import { jsxDEV as jsxDEV46 } from "react/jsx-dev-runtime";
|
|
2860
2862
|
function CalendarDndContext({ children }) {
|
|
2861
2863
|
const { updateEvent, view, disableDragAndDrop } = useCalendarContext();
|
|
2862
|
-
const [activeEvent, setActiveEvent] =
|
|
2864
|
+
const [activeEvent, setActiveEvent] = React10.useState(null);
|
|
2863
2865
|
const mouseSensor = useSensor(MouseSensor, {
|
|
2864
2866
|
activationConstraint: {
|
|
2865
2867
|
distance: 2
|
|
@@ -2889,7 +2891,7 @@ function CalendarDndContext({ children }) {
|
|
|
2889
2891
|
const originalStart = activeEvent.originalStart ?? activeEvent.start;
|
|
2890
2892
|
const originalEnd = activeEvent.originalEnd ?? activeEvent.end;
|
|
2891
2893
|
const durationMinutes = originalEnd.diff(originalStart, "minute");
|
|
2892
|
-
const newStart =
|
|
2894
|
+
const newStart = dayjs_config_default(date).hour(hour).minute(minute || 0);
|
|
2893
2895
|
let newEnd = newStart.add(durationMinutes, "minute");
|
|
2894
2896
|
if (newEnd.isSame(newEnd.startOf("day"))) {
|
|
2895
2897
|
newEnd = newEnd.subtract(1, "day").endOf("day");
|
|
@@ -2900,7 +2902,7 @@ function CalendarDndContext({ children }) {
|
|
|
2900
2902
|
});
|
|
2901
2903
|
} else if (over.data.current?.type === "day-cell") {
|
|
2902
2904
|
const { date } = over.data.current;
|
|
2903
|
-
const newDate =
|
|
2905
|
+
const newDate = dayjs_config_default(date);
|
|
2904
2906
|
const isMultiDayEvent = !activeEvent.start.isSame(activeEvent.end, "day");
|
|
2905
2907
|
const originalStart = activeEvent.originalStart ?? activeEvent.start;
|
|
2906
2908
|
const originalEnd = activeEvent.originalEnd ?? activeEvent.end;
|
|
@@ -2970,17 +2972,16 @@ function CalendarDndContext({ children }) {
|
|
|
2970
2972
|
}
|
|
2971
2973
|
|
|
2972
2974
|
// src/contexts/calendar-context/provider.tsx
|
|
2973
|
-
import dayjs17 from "dayjs";
|
|
2974
2975
|
import {
|
|
2975
2976
|
useCallback as useCallback2,
|
|
2976
|
-
useEffect as
|
|
2977
|
+
useEffect as useEffect3,
|
|
2977
2978
|
useMemo as useMemo6,
|
|
2978
2979
|
useState as useState5
|
|
2979
2980
|
} from "react";
|
|
2980
2981
|
import { jsxDEV as jsxDEV47 } from "react/jsx-dev-runtime";
|
|
2981
2982
|
var CalendarProvider = ({
|
|
2982
2983
|
children,
|
|
2983
|
-
|
|
2984
|
+
events = [],
|
|
2984
2985
|
firstDayOfWeek = 0,
|
|
2985
2986
|
renderEvent,
|
|
2986
2987
|
onEventClick,
|
|
@@ -2992,29 +2993,32 @@ var CalendarProvider = ({
|
|
|
2992
2993
|
disableEventClick,
|
|
2993
2994
|
disableDragAndDrop,
|
|
2994
2995
|
dayMaxEvents,
|
|
2995
|
-
|
|
2996
|
+
stickyViewHeader,
|
|
2997
|
+
viewHeaderClassName
|
|
2996
2998
|
}) => {
|
|
2997
|
-
const [currentDate, setCurrentDate] = useState5(
|
|
2999
|
+
const [currentDate, setCurrentDate] = useState5(dayjs_config_default());
|
|
2998
3000
|
const [view, setView] = useState5("month");
|
|
2999
|
-
const [
|
|
3001
|
+
const [currentEvents, setCurrentEvents] = useState5(events);
|
|
3000
3002
|
const [isEventFormOpen, setIsEventFormOpen] = useState5(false);
|
|
3001
3003
|
const [selectedEvent, setSelectedEvent] = useState5(null);
|
|
3002
3004
|
const [selectedDate, setSelectedDate] = useState5(null);
|
|
3003
3005
|
const [currentLocale, setCurrentLocale] = useState5(locale || "en");
|
|
3004
|
-
|
|
3005
|
-
|
|
3006
|
-
|
|
3006
|
+
const [currentTimezone, setCurrentTimezone] = useState5(timezone2 || "");
|
|
3007
|
+
useEffect3(() => {
|
|
3008
|
+
if (events) {
|
|
3009
|
+
setCurrentEvents(events);
|
|
3007
3010
|
}
|
|
3008
|
-
}, [
|
|
3009
|
-
|
|
3011
|
+
}, [events]);
|
|
3012
|
+
useEffect3(() => {
|
|
3010
3013
|
if (locale) {
|
|
3011
3014
|
setCurrentLocale(locale);
|
|
3012
|
-
|
|
3015
|
+
dayjs_config_default.locale(locale);
|
|
3013
3016
|
}
|
|
3014
3017
|
}, [locale]);
|
|
3015
|
-
|
|
3018
|
+
useEffect3(() => {
|
|
3016
3019
|
if (timezone2) {
|
|
3017
|
-
|
|
3020
|
+
setCurrentTimezone(timezone2);
|
|
3021
|
+
dayjs_config_default.tz.setDefault(timezone2);
|
|
3018
3022
|
}
|
|
3019
3023
|
}, [timezone2]);
|
|
3020
3024
|
const selectDate = useCallback2((date) => {
|
|
@@ -3053,16 +3057,16 @@ var CalendarProvider = ({
|
|
|
3053
3057
|
}
|
|
3054
3058
|
}, [view]);
|
|
3055
3059
|
const today = useCallback2(() => {
|
|
3056
|
-
setCurrentDate(
|
|
3060
|
+
setCurrentDate(dayjs_config_default());
|
|
3057
3061
|
}, []);
|
|
3058
3062
|
const addEvent = useCallback2((event) => {
|
|
3059
|
-
|
|
3063
|
+
setCurrentEvents((prevEvents) => [...prevEvents, event]);
|
|
3060
3064
|
}, []);
|
|
3061
3065
|
const updateEvent = useCallback2((eventId, updatedEvent) => {
|
|
3062
|
-
|
|
3066
|
+
setCurrentEvents((prevEvents) => prevEvents.map((event) => event.id === eventId ? { ...event, ...updatedEvent } : event));
|
|
3063
3067
|
}, []);
|
|
3064
3068
|
const deleteEvent = useCallback2((eventId) => {
|
|
3065
|
-
|
|
3069
|
+
setCurrentEvents((prevEvents) => prevEvents.filter((event) => event.id !== eventId));
|
|
3066
3070
|
}, []);
|
|
3067
3071
|
const editEvent = useCallback2((event) => {
|
|
3068
3072
|
setSelectedEvent(event);
|
|
@@ -3098,7 +3102,7 @@ var CalendarProvider = ({
|
|
|
3098
3102
|
start: startDate,
|
|
3099
3103
|
end: endDate,
|
|
3100
3104
|
description: "",
|
|
3101
|
-
|
|
3105
|
+
allDay: false,
|
|
3102
3106
|
isRecurring: false,
|
|
3103
3107
|
recurrence: null,
|
|
3104
3108
|
parentEventId: null
|
|
@@ -3234,10 +3238,10 @@ var CalendarProvider = ({
|
|
|
3234
3238
|
return getEventsForDateRange(day, nextDay);
|
|
3235
3239
|
}, [getEventsForDateRange]);
|
|
3236
3240
|
const addRecurringEvent = useCallback2((event) => {
|
|
3237
|
-
|
|
3241
|
+
setCurrentEvents((prevEvents) => [...prevEvents, event]);
|
|
3238
3242
|
}, []);
|
|
3239
3243
|
const deleteRecurringEvent = useCallback2((eventId, deleteAll) => {
|
|
3240
|
-
|
|
3244
|
+
setCurrentEvents((prevEvents) => {
|
|
3241
3245
|
const event = prevEvents.find((e) => e.id === eventId);
|
|
3242
3246
|
if (!event)
|
|
3243
3247
|
return prevEvents;
|
|
@@ -3270,7 +3274,7 @@ var CalendarProvider = ({
|
|
|
3270
3274
|
});
|
|
3271
3275
|
}, []);
|
|
3272
3276
|
const updateRecurringEvent = useCallback2((eventId, updatedEvent, updateAll) => {
|
|
3273
|
-
|
|
3277
|
+
setCurrentEvents((prevEvents) => {
|
|
3274
3278
|
const event = prevEvents.find((e) => e.id === eventId);
|
|
3275
3279
|
if (!event)
|
|
3276
3280
|
return prevEvents;
|
|
@@ -3321,7 +3325,7 @@ var CalendarProvider = ({
|
|
|
3321
3325
|
});
|
|
3322
3326
|
}, []);
|
|
3323
3327
|
const createExceptionForRecurringEvent = useCallback2((eventId, date) => {
|
|
3324
|
-
|
|
3328
|
+
setCurrentEvents((prevEvents) => {
|
|
3325
3329
|
const event = prevEvents.find((e) => e.id === eventId);
|
|
3326
3330
|
if (!event || !event.recurrence)
|
|
3327
3331
|
return prevEvents;
|
|
@@ -3345,7 +3349,7 @@ var CalendarProvider = ({
|
|
|
3345
3349
|
const contextValue = useMemo6(() => ({
|
|
3346
3350
|
currentDate,
|
|
3347
3351
|
view,
|
|
3348
|
-
events,
|
|
3352
|
+
events: currentEvents,
|
|
3349
3353
|
currentLocale,
|
|
3350
3354
|
isEventFormOpen,
|
|
3351
3355
|
selectedEvent,
|
|
@@ -3373,16 +3377,17 @@ var CalendarProvider = ({
|
|
|
3373
3377
|
onEventClick: handleEventClick,
|
|
3374
3378
|
onCellClick: handleDateClick,
|
|
3375
3379
|
locale,
|
|
3376
|
-
timezone:
|
|
3380
|
+
timezone: currentTimezone,
|
|
3377
3381
|
disableCellClick,
|
|
3378
3382
|
disableEventClick,
|
|
3379
3383
|
disableDragAndDrop,
|
|
3380
3384
|
dayMaxEvents,
|
|
3381
|
-
|
|
3385
|
+
stickyViewHeader,
|
|
3386
|
+
viewHeaderClassName
|
|
3382
3387
|
}), [
|
|
3383
3388
|
currentDate,
|
|
3384
3389
|
view,
|
|
3385
|
-
|
|
3390
|
+
currentEvents,
|
|
3386
3391
|
currentLocale,
|
|
3387
3392
|
isEventFormOpen,
|
|
3388
3393
|
selectedEvent,
|
|
@@ -3408,12 +3413,13 @@ var CalendarProvider = ({
|
|
|
3408
3413
|
handleEventClick,
|
|
3409
3414
|
handleDateClick,
|
|
3410
3415
|
locale,
|
|
3411
|
-
|
|
3416
|
+
currentTimezone,
|
|
3412
3417
|
disableCellClick,
|
|
3413
3418
|
disableEventClick,
|
|
3414
3419
|
disableDragAndDrop,
|
|
3415
3420
|
dayMaxEvents,
|
|
3416
|
-
|
|
3421
|
+
stickyViewHeader,
|
|
3422
|
+
viewHeaderClassName
|
|
3417
3423
|
]);
|
|
3418
3424
|
return /* @__PURE__ */ jsxDEV47(CalendarContext.Provider, {
|
|
3419
3425
|
value: contextValue,
|
|
@@ -3500,10 +3506,11 @@ var IlamyCalendar = ({
|
|
|
3500
3506
|
disableEventClick,
|
|
3501
3507
|
disableDragAndDrop,
|
|
3502
3508
|
dayMaxEvents = DEFAULT_DAY_MAX_EVENTS,
|
|
3503
|
-
|
|
3509
|
+
stickyViewHeader = true,
|
|
3510
|
+
viewHeaderClassName = ""
|
|
3504
3511
|
}) => {
|
|
3505
3512
|
return /* @__PURE__ */ jsxDEV48(CalendarProvider, {
|
|
3506
|
-
|
|
3513
|
+
events,
|
|
3507
3514
|
firstDayOfWeek: dayNumberMap[firstDayOfWeek],
|
|
3508
3515
|
renderEvent,
|
|
3509
3516
|
onEventClick,
|
|
@@ -3515,7 +3522,8 @@ var IlamyCalendar = ({
|
|
|
3515
3522
|
disableEventClick,
|
|
3516
3523
|
disableDragAndDrop,
|
|
3517
3524
|
dayMaxEvents,
|
|
3518
|
-
|
|
3525
|
+
stickyViewHeader,
|
|
3526
|
+
viewHeaderClassName,
|
|
3519
3527
|
children: /* @__PURE__ */ jsxDEV48(CalendarContent, {}, undefined, false, undefined, this)
|
|
3520
3528
|
}, undefined, false, undefined, this);
|
|
3521
3529
|
};
|
|
@@ -3523,3 +3531,6 @@ export {
|
|
|
3523
3531
|
usePublicCalendarContext as useIlamyCalendarContext,
|
|
3524
3532
|
IlamyCalendar
|
|
3525
3533
|
};
|
|
3534
|
+
|
|
3535
|
+
//# debugId=6116CC68B191B54164756E2164756E21
|
|
3536
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/features/month-view/components/month-view.tsx", "../src/contexts/calendar-context/context.ts", "../src/components/ui/accordion.tsx", "../src/lib/utils.ts", "../src/lib/dayjs-config.ts", "../src/components/ui/alert.tsx", "../src/components/ui/badge.tsx", "../src/components/ui/button.tsx", "../src/components/ui/calendar.tsx", "../src/components/ui/checkbox.tsx", "../src/components/ui/date-picker.tsx", "../src/components/ui/popover.tsx", "../src/components/ui/dialog.tsx", "../src/components/ui/dropdown-menu.tsx", "../src/components/ui/form.tsx", "../node_modules/react-hook-form/dist/index.esm.mjs", "../src/components/ui/label.tsx", "../src/components/ui/input.tsx", "../src/components/ui/scroll-area.tsx", "../src/components/ui/select.tsx", "../src/components/ui/separator.tsx", "../src/components/ui/sheet.tsx", "../src/components/ui/tabs.tsx", "../src/components/ui/tooltip.tsx", "../src/features/month-view/components/all-events-dialog.tsx", "../src/features/draggable-event/draggable-event.tsx", "../src/features/month-view/components/day-cell.tsx", "../src/features/droppable-cell/droppable-cell.tsx", "../src/features/month-view/components/month-header.tsx", "../src/lib/constants.ts", "../src/features/month-view/components/week-events-layer.tsx", "../src/features/week-view/week-view.tsx", "../src/features/week-view/week-all-day-row.tsx", "../src/features/week-view/week-header.tsx", "../src/hooks/useProcessedDayEvents.ts", "../src/features/day-view/day-events-layer.tsx", "../src/features/week-view/week-day-col.tsx", "../src/features/week-view/week-time-grid.tsx", "../src/features/day-view/day-view.tsx", "../src/features/day-view/day-all-day-row.tsx", "../src/features/day-view/day-header.tsx", "../src/features/day-view/day-time-col.tsx", "../src/components/event-form/event-form.tsx", "../src/components/header/base-header.tsx", "../src/components/header/title-content.tsx", "../src/components/header/view-controls.tsx", "../src/features/year-view/year-view.tsx", "../src/components/ilamy-calendar/ilamy-calendar.tsx", "../src/features/drag-and-drop/calendar-dnd-context.tsx", "../src/contexts/calendar-context/provider.tsx"],
  "sourcesContent": [
    "import type dayjs from '@/lib/dayjs-config'\nimport { AnimatePresence, motion } from 'motion/react'\nimport React, { useMemo } from 'react'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { AllEventDialog } from './all-events-dialog'\nimport { DayCell } from './day-cell'\nimport type { MonthViewProps, SelectedDayEvents } from '../types'\nimport { MonthHeader } from './month-header'\nimport { WeekEventsLayer } from './week-events-layer'\n\nexport const MonthView: React.FC<MonthViewProps> = ({ dayMaxEvents = 3 }) => {\n  const allEventsDialogRef = React.useRef<{\n    open: () => void\n    close: () => void\n    setSelectedDayEvents: (dayEvents: SelectedDayEvents) => void\n  }>(null)\n  const { currentDate, firstDayOfWeek } = useCalendarContext()\n\n  // Get start date for the current month view based on firstDayOfWeek\n  const firstDayOfMonth = currentDate.startOf('month')\n\n  // Calculate the first day of the calendar grid correctly\n  // Find the first day of week (e.g. Sunday or Monday) that comes before or on the first day of the month\n  let adjustedFirstDayOfCalendar = firstDayOfMonth.clone()\n  while (adjustedFirstDayOfCalendar.day() !== firstDayOfWeek) {\n    adjustedFirstDayOfCalendar = adjustedFirstDayOfCalendar.subtract(1, 'day')\n  }\n\n  // Always generate 6 weeks (42 days) regardless of the month length\n  // This ensures we always have 6 rows of days\n  const calendarDays = useMemo(() => {\n    // 6 weeks × 7 days = 42 days\n    const days: dayjs.Dayjs[][] = [[]]\n    let day = adjustedFirstDayOfCalendar.clone() // Clone to avoid mutation\n    for (let i = 0; i < 42; i++) {\n      if (days[days.length - 1].length === 7) {\n        days.push([]) // Start a new week\n      }\n      days[days.length - 1].push(day)\n      day = day.add(1, 'day') // Move to the next day\n    }\n    return days\n  }, [adjustedFirstDayOfCalendar])\n\n  return (\n    <div className=\"flex h-full flex-col\" data-testid=\"month-view\">\n      {/* Week days header */}\n      <MonthHeader />\n\n      {/* Calendar grid - added fixed height */}\n      <div\n        className=\"flex-1 overflow-auto h-full\"\n        data-testid=\"month-scroll-area\"\n      >\n        <AnimatePresence mode=\"wait\">\n          <motion.div\n            key={currentDate.format('YYYY-MM-DD')}\n            initial={{ opacity: 0 }}\n            animate={{ opacity: 1 }}\n            exit={{ opacity: 0 }}\n            transition={{ duration: 0.25, ease: 'easeInOut' }}\n            className=\"relative grid h-full grid-cols-7 grid-rows-6 overflow-auto\"\n            data-testid=\"month-calendar-grid\"\n          >\n            {/* Day cells */}\n            {calendarDays.map((days, index) => {\n              return (\n                <div\n                  key={`week-${index}`}\n                  className=\"relative col-span-7 grid grid-cols-7\"\n                  data-testid={`week-row-${index}`}\n                >\n                  {days.map((day, dayIndex) => {\n                    return (\n                      <DayCell\n                        index={dayIndex}\n                        day={day}\n                        dayMaxEvents={dayMaxEvents}\n                        key={day.format('YYYY-MM-DD')}\n                        className=\"border-r border-b first:border-l\"\n                      />\n                    )\n                  })}\n\n                  <div className=\"absolute inset-0 z-10 pointer-events-none\">\n                    <WeekEventsLayer days={days} />\n                  </div>\n                </div>\n              )\n            })}\n          </motion.div>\n        </AnimatePresence>\n      </div>\n\n      {/* Dialog for showing all events */}\n      <AllEventDialog ref={allEventsDialogRef} />\n    </div>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport type dayjs from '@/lib/dayjs-config'\nimport { createContext, useContext } from 'react'\n\nexport interface CalendarContextType {\n  currentDate: dayjs.Dayjs\n  view: 'month' | 'week' | 'day' | 'year'\n  events: CalendarEvent[]\n  isEventFormOpen: boolean\n  selectedEvent: CalendarEvent | null\n  selectedDate: dayjs.Dayjs | null\n  firstDayOfWeek: number // 0 for Sunday, 1 for Monday, etc.\n  setCurrentDate: (date: dayjs.Dayjs) => void\n  selectDate: (date: dayjs.Dayjs) => void\n  setView: (view: 'month' | 'week' | 'day' | 'year') => void\n  nextPeriod: () => void\n  prevPeriod: () => void\n  today: () => void\n  addEvent: (event: CalendarEvent) => void\n  updateEvent: (eventId: string, event: Partial<CalendarEvent>) => void\n  deleteEvent: (eventId: string) => void\n  openEventForm: (date?: dayjs.Dayjs, event?: CalendarEvent) => void\n  closeEventForm: () => void\n  getEventsForDate: (date: dayjs.Dayjs) => CalendarEvent[]\n  getEventsForDateRange: (\n    start: dayjs.Dayjs,\n    end: dayjs.Dayjs\n  ) => CalendarEvent[]\n  expandRecurringEvent: (\n    baseEvent: CalendarEvent,\n    startDate: dayjs.Dayjs,\n    endDate: dayjs.Dayjs\n  ) => CalendarEvent[]\n  addRecurringEvent: (event: CalendarEvent) => void\n  deleteRecurringEvent: (eventId: string, deleteAll: boolean) => void\n  updateRecurringEvent: (\n    eventId: string,\n    updatedEvent: Partial<CalendarEvent>,\n    updateAll: boolean\n  ) => void\n  createExceptionForRecurringEvent: (eventId: string, date: dayjs.Dayjs) => void\n  renderEvent?: (event: CalendarEvent) => React.ReactNode\n  onEventClick: (event: CalendarEvent) => void\n  onCellClick: (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs) => void\n  currentLocale?: string\n  disableCellClick?: boolean\n  disableEventClick?: boolean\n  disableDragAndDrop?: boolean\n  dayMaxEvents: number\n  stickyViewHeader: boolean\n  viewHeaderClassName: string\n}\n\nexport const CalendarContext = createContext<CalendarContextType | undefined>(\n  undefined\n)\n\nexport const useCalendarContext = () => {\n  const context = useContext(CalendarContext)\n  if (context === undefined) {\n    throw new Error('useCalendarContext must be used within a CalendarProvider')\n  }\n  return context\n}\n\nexport const usePublicCalendarContext = () => {\n  const context = useContext(CalendarContext)\n  if (context === undefined) {\n    throw new Error('useCalendarContext must be used within ilamy calendar')\n  }\n  return {\n    currentDate: context.currentDate,\n    view: context.view,\n    events: context.events,\n    isEventFormOpen: context.isEventFormOpen,\n    selectedEvent: context.selectedEvent,\n    selectedDate: context.selectedDate,\n    firstDayOfWeek: context.firstDayOfWeek,\n    setCurrentDate: context.setCurrentDate,\n    selectDate: context.selectDate,\n    setView: context.setView,\n    nextPeriod: context.nextPeriod,\n    prevPeriod: context.prevPeriod,\n    today: context.today,\n    addEvent: context.addEvent,\n    updateEvent: context.updateEvent,\n    deleteEvent: context.deleteEvent,\n    openEventForm: context.openEventForm,\n    closeEventForm: context.closeEventForm,\n  }\n}\n",
    "import * as React from 'react'\nimport * as AccordionPrimitive from '@radix-ui/react-accordion'\nimport { ChevronDownIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Accordion({\n  ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Root>) {\n  return <AccordionPrimitive.Root data-slot=\"accordion\" {...props} />\n}\n\nfunction AccordionItem({\n  className,\n  ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Item>) {\n  return (\n    <AccordionPrimitive.Item\n      data-slot=\"accordion-item\"\n      className={cn('border-b last:border-b-0', className)}\n      {...props}\n    />\n  )\n}\n\nfunction AccordionTrigger({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Trigger>) {\n  return (\n    <AccordionPrimitive.Header className=\"flex\">\n      <AccordionPrimitive.Trigger\n        data-slot=\"accordion-trigger\"\n        className={cn(\n          'focus-visible:border-ring focus-visible:ring-ring/50 flex flex-1 items-start justify-between gap-4 rounded-md py-4 text-left text-sm font-medium transition-all outline-none hover:underline focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 [&[data-state=open]>svg]:rotate-180',\n          className\n        )}\n        {...props}\n      >\n        {children}\n        <ChevronDownIcon className=\"text-muted-foreground pointer-events-none size-4 shrink-0 translate-y-0.5 transition-transform duration-200\" />\n      </AccordionPrimitive.Trigger>\n    </AccordionPrimitive.Header>\n  )\n}\n\nfunction AccordionContent({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof AccordionPrimitive.Content>) {\n  return (\n    <AccordionPrimitive.Content\n      data-slot=\"accordion-content\"\n      className=\"data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down overflow-clip text-sm\"\n      {...props}\n    >\n      <div className={cn('pt-0 pb-4', className)}>{children}</div>\n    </AccordionPrimitive.Content>\n  )\n}\n\nexport { Accordion, AccordionItem, AccordionTrigger, AccordionContent }\n",
    "import type { CalendarEvent } from '@/components'\nimport { type ClassValue, clsx } from 'clsx'\nimport dayjs from '@/lib/dayjs-config'\nimport { twMerge } from 'tailwind-merge'\n\nexport function cn(...inputs: ClassValue[]) {\n  return twMerge(clsx(inputs))\n}\n\nexport function generateMockEvents({ count = 5 } = {}) {\n  const events: CalendarEvent[] = []\n  for (let i = 0; i < count; i++) {\n    events.push({\n      id: i.toString(),\n      title: `Mock Event ${i + 1}`,\n      start: dayjs().add(i, 'day').startOf('day'),\n      end: dayjs().add(i, 'day').endOf('day'),\n      color: 'bg-gray-100 text-gray-800',\n    })\n  }\n  return events\n}\n",
    "import dayjs from 'dayjs'\nimport weekday from 'dayjs/plugin/weekday.js'\nimport weekOfYear from 'dayjs/plugin/weekOfYear.js'\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter.js'\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore.js'\nimport isBetween from 'dayjs/plugin/isBetween.js'\nimport minMax from 'dayjs/plugin/minMax.js'\nimport timezone from 'dayjs/plugin/timezone.js'\nimport utc from 'dayjs/plugin/utc.js'\nimport localeData from 'dayjs/plugin/localeData.js'\n\n// Import all dayjs locales alphabetically\n// locale.json file: [{\"key\":\"af\",\"name\":\"Afrikaans\"},{\"key\":\"am\",\"name\":\"Amharic\"},{\"key\":\"ar-dz\",\"name\":\"Arabic (Algeria)\"},{\"key\":\"ar-iq\",\"name\":\" Arabic (Iraq)\"},{\"key\":\"ar-kw\",\"name\":\"Arabic (Kuwait)\"},{\"key\":\"ar-ly\",\"name\":\"Arabic (Lybia)\"},{\"key\":\"ar-ma\",\"name\":\"Arabic (Morocco)\"},{\"key\":\"ar-sa\",\"name\":\"Arabic (Saudi Arabia)\"},{\"key\":\"ar-tn\",\"name\":\" Arabic (Tunisia)\"},{\"key\":\"ar\",\"name\":\"Arabic\"},{\"key\":\"az\",\"name\":\"Azerbaijani\"},{\"key\":\"be\",\"name\":\"Belarusian\"},{\"key\":\"bg\",\"name\":\"Bulgarian\"},{\"key\":\"bi\",\"name\":\"Bislama\"},{\"key\":\"bm\",\"name\":\"Bambara\"},{\"key\":\"bn-bd\",\"name\":\"Bengali (Bangladesh)\"},{\"key\":\"bn\",\"name\":\"Bengali\"},{\"key\":\"bo\",\"name\":\"Tibetan\"},{\"key\":\"br\",\"name\":\"Breton\"},{\"key\":\"bs\",\"name\":\"Bosnian\"},{\"key\":\"ca\",\"name\":\"Catalan\"},{\"key\":\"cs\",\"name\":\"Czech\"},{\"key\":\"cv\",\"name\":\"Chuvash\"},{\"key\":\"cy\",\"name\":\"Welsh\"},{\"key\":\"de-at\",\"name\":\"German (Austria)\"},{\"key\":\"da\",\"name\":\"Danish\"},{\"key\":\"de-ch\",\"name\":\"German (Switzerland)\"},{\"key\":\"de\",\"name\":\"German\"},{\"key\":\"dv\",\"name\":\"Maldivian\"},{\"key\":\"el\",\"name\":\"Greek\"},{\"key\":\"en-au\",\"name\":\"English (Australia)\"},{\"key\":\"en-ca\",\"name\":\"English (Canada)\"},{\"key\":\"en-gb\",\"name\":\"English (United Kingdom)\"},{\"key\":\"en-ie\",\"name\":\"English (Ireland)\"},{\"key\":\"en-il\",\"name\":\"English (Israel)\"},{\"key\":\"en-in\",\"name\":\"English (India)\"},{\"key\":\"en-nz\",\"name\":\"English (New Zealand)\"},{\"key\":\"en-sg\",\"name\":\"English (Singapore)\"},{\"key\":\"en-tt\",\"name\":\"English (Trinidad & Tobago)\"},{\"key\":\"eo\",\"name\":\"Esperanto\"},{\"key\":\"en\",\"name\":\"English\"},{\"key\":\"es-do\",\"name\":\"Spanish (Dominican Republic)\"},{\"key\":\"es-mx\",\"name\":\"Spanish (Mexico)\"},{\"key\":\"es-pr\",\"name\":\"Spanish (Puerto Rico)\"},{\"key\":\"es-us\",\"name\":\"Spanish (United States)\"},{\"key\":\"et\",\"name\":\"Estonian\"},{\"key\":\"es\",\"name\":\"Spanish\"},{\"key\":\"eu\",\"name\":\"Basque\"},{\"key\":\"fa\",\"name\":\"Persian\"},{\"key\":\"fo\",\"name\":\"Faroese\"},{\"key\":\"fi\",\"name\":\"Finnish\"},{\"key\":\"fr-ca\",\"name\":\"French (Canada)\"},{\"key\":\"fr-ch\",\"name\":\"French (Switzerland)\"},{\"key\":\"fr\",\"name\":\"French\"},{\"key\":\"fy\",\"name\":\"Frisian\"},{\"key\":\"ga\",\"name\":\"Irish or Irish Gaelic\"},{\"key\":\"gd\",\"name\":\"Scottish Gaelic\"},{\"key\":\"gom-latn\",\"name\":\"Konkani Latin script\"},{\"key\":\"gl\",\"name\":\"Galician\"},{\"key\":\"gu\",\"name\":\"Gujarati\"},{\"key\":\"he\",\"name\":\"Hebrew\"},{\"key\":\"hi\",\"name\":\"Hindi\"},{\"key\":\"hr\",\"name\":\"Croatian\"},{\"key\":\"hu\",\"name\":\"Hungarian\"},{\"key\":\"ht\",\"name\":\"Haitian Creole (Haiti)\"},{\"key\":\"hy-am\",\"name\":\"Armenian\"},{\"key\":\"id\",\"name\":\"Indonesian\"},{\"key\":\"is\",\"name\":\"Icelandic\"},{\"key\":\"it-ch\",\"name\":\"Italian (Switzerland)\"},{\"key\":\"it\",\"name\":\"Italian\"},{\"key\":\"ja\",\"name\":\"Japanese\"},{\"key\":\"jv\",\"name\":\"Javanese\"},{\"key\":\"ka\",\"name\":\"Georgian\"},{\"key\":\"kk\",\"name\":\"Kazakh\"},{\"key\":\"km\",\"name\":\"Cambodian\"},{\"key\":\"kn\",\"name\":\"Kannada\"},{\"key\":\"ko\",\"name\":\"Korean\"},{\"key\":\"ku\",\"name\":\"Kurdish\"},{\"key\":\"ky\",\"name\":\"Kyrgyz\"},{\"key\":\"lb\",\"name\":\"Luxembourgish\"},{\"key\":\"lo\",\"name\":\"Lao\"},{\"key\":\"lt\",\"name\":\"Lithuanian\"},{\"key\":\"lv\",\"name\":\"Latvian\"},{\"key\":\"me\",\"name\":\"Montenegrin\"},{\"key\":\"mi\",\"name\":\"Maori\"},{\"key\":\"mk\",\"name\":\"Macedonian\"},{\"key\":\"ml\",\"name\":\"Malayalam\"},{\"key\":\"mn\",\"name\":\"Mongolian\"},{\"key\":\"mr\",\"name\":\"Marathi\"},{\"key\":\"ms-my\",\"name\":\"Malay\"},{\"key\":\"ms\",\"name\":\"Malay\"},{\"key\":\"mt\",\"name\":\"Maltese (Malta)\"},{\"key\":\"my\",\"name\":\"Burmese\"},{\"key\":\"nb\",\"name\":\"Norwegian Bokmål\"},{\"key\":\"ne\",\"name\":\"Nepalese\"},{\"key\":\"nl-be\",\"name\":\"Dutch (Belgium)\"},{\"key\":\"nl\",\"name\":\"Dutch\"},{\"key\":\"pl\",\"name\":\"Polish\"},{\"key\":\"pt-br\",\"name\":\"Portuguese (Brazil)\"},{\"key\":\"pt\",\"name\":\"Portuguese\"},{\"key\":\"rn\",\"name\":\"Kirundi\"},{\"key\":\"ro\",\"name\":\"Romanian\"},{\"key\":\"ru\",\"name\":\"Russian\"},{\"key\":\"rw\",\"name\":\"Kinyarwanda (Rwanda)\"},{\"key\":\"sd\",\"name\":\"Sindhi\"},{\"key\":\"se\",\"name\":\"Northern Sami\"},{\"key\":\"si\",\"name\":\"Sinhalese\"},{\"key\":\"sk\",\"name\":\"Slovak\"},{\"key\":\"sl\",\"name\":\"Slovenian\"},{\"key\":\"sq\",\"name\":\"Albanian\"},{\"key\":\"sr-cyrl\",\"name\":\"Serbian Cyrillic\"},{\"key\":\"ss\",\"name\":\"siSwati\"},{\"key\":\"sv-fi\",\"name\":\"Finland Swedish\"},{\"key\":\"sr\",\"name\":\"Serbian\"},{\"key\":\"sv\",\"name\":\"Swedish\"},{\"key\":\"sw\",\"name\":\"Swahili\"},{\"key\":\"ta\",\"name\":\"Tamil\"},{\"key\":\"te\",\"name\":\"Telugu\"},{\"key\":\"tet\",\"name\":\"Tetun Dili (East Timor)\"},{\"key\":\"tg\",\"name\":\"Tajik\"},{\"key\":\"th\",\"name\":\"Thai\"},{\"key\":\"tk\",\"name\":\"Turkmen\"},{\"key\":\"tl-ph\",\"name\":\"Tagalog (Philippines)\"},{\"key\":\"tlh\",\"name\":\"Klingon\"},{\"key\":\"tr\",\"name\":\"Turkish\"},{\"key\":\"tzl\",\"name\":\"Talossan\"},{\"key\":\"tzm-latn\",\"name\":\"Central Atlas Tamazight Latin\"},{\"key\":\"tzm\",\"name\":\"Central Atlas Tamazight\"},{\"key\":\"ug-cn\",\"name\":\"Uyghur (China)\"},{\"key\":\"uk\",\"name\":\"Ukrainian\"},{\"key\":\"ur\",\"name\":\"Urdu\"},{\"key\":\"uz-latn\",\"name\":\"Uzbek Latin\"},{\"key\":\"uz\",\"name\":\"Uzbek\"},{\"key\":\"vi\",\"name\":\"Vietnamese\"},{\"key\":\"x-pseudo\",\"name\":\"Pseudo\"},{\"key\":\"yo\",\"name\":\"Yoruba Nigeria\"},{\"key\":\"zh-cn\",\"name\":\"Chinese (China)\"},{\"key\":\"zh-hk\",\"name\":\"Chinese (Hong Kong)\"},{\"key\":\"zh-tw\",\"name\":\"Chinese (Taiwan)\"},{\"key\":\"zh\",\"name\":\"Chinese\"},{\"key\":\"oc-lnc\",\"name\":\"Occitan, lengadocian dialecte\"},{\"key\":\"nn\",\"name\":\"Nynorsk\"},{\"key\":\"pa-in\",\"name\":\"Punjabi (India)\"}]\nimport 'dayjs/locale/af.js'\nimport 'dayjs/locale/am.js'\nimport 'dayjs/locale/ar-dz.js'\nimport 'dayjs/locale/ar-iq.js'\nimport 'dayjs/locale/ar-kw.js'\nimport 'dayjs/locale/ar-ly.js'\nimport 'dayjs/locale/ar-ma.js'\nimport 'dayjs/locale/ar-sa.js'\nimport 'dayjs/locale/ar-tn.js'\nimport 'dayjs/locale/ar.js'\nimport 'dayjs/locale/az.js'\nimport 'dayjs/locale/be.js'\nimport 'dayjs/locale/bg.js'\nimport 'dayjs/locale/bi.js'\nimport 'dayjs/locale/bm.js'\nimport 'dayjs/locale/bn-bd.js'\nimport 'dayjs/locale/bn.js'\nimport 'dayjs/locale/bo.js'\nimport 'dayjs/locale/br.js'\nimport 'dayjs/locale/bs.js'\nimport 'dayjs/locale/ca.js'\nimport 'dayjs/locale/cs.js'\nimport 'dayjs/locale/cv.js'\nimport 'dayjs/locale/cy.js'\nimport 'dayjs/locale/da.js'\nimport 'dayjs/locale/de-at.js'\nimport 'dayjs/locale/de-ch.js'\nimport 'dayjs/locale/de.js'\nimport 'dayjs/locale/dv.js'\nimport 'dayjs/locale/el.js'\nimport 'dayjs/locale/en-au.js'\nimport 'dayjs/locale/en-ca.js'\nimport 'dayjs/locale/en-gb.js'\nimport 'dayjs/locale/en-ie.js'\nimport 'dayjs/locale/en-il.js'\nimport 'dayjs/locale/en-in.js'\nimport 'dayjs/locale/en-nz.js'\nimport 'dayjs/locale/en-sg.js'\nimport 'dayjs/locale/en-tt.js'\nimport 'dayjs/locale/en.js'\nimport 'dayjs/locale/eo.js'\nimport 'dayjs/locale/es-do.js'\nimport 'dayjs/locale/es-mx.js'\nimport 'dayjs/locale/es-pr.js'\nimport 'dayjs/locale/es-us.js'\nimport 'dayjs/locale/es.js'\nimport 'dayjs/locale/et.js'\nimport 'dayjs/locale/eu.js'\nimport 'dayjs/locale/fa.js'\nimport 'dayjs/locale/fi.js'\nimport 'dayjs/locale/fo.js'\nimport 'dayjs/locale/fr-ca.js'\nimport 'dayjs/locale/fr-ch.js'\nimport 'dayjs/locale/fr.js'\nimport 'dayjs/locale/fy.js'\nimport 'dayjs/locale/ga.js'\nimport 'dayjs/locale/gd.js'\nimport 'dayjs/locale/gl.js'\nimport 'dayjs/locale/gom-latn.js'\nimport 'dayjs/locale/gu.js'\nimport 'dayjs/locale/he.js'\nimport 'dayjs/locale/hi.js'\nimport 'dayjs/locale/hr.js'\nimport 'dayjs/locale/ht.js'\nimport 'dayjs/locale/hu.js'\nimport 'dayjs/locale/hy-am.js'\nimport 'dayjs/locale/id.js'\nimport 'dayjs/locale/is.js'\nimport 'dayjs/locale/it-ch.js'\nimport 'dayjs/locale/it.js'\nimport 'dayjs/locale/ja.js'\nimport 'dayjs/locale/jv.js'\nimport 'dayjs/locale/ka.js'\nimport 'dayjs/locale/kk.js'\nimport 'dayjs/locale/km.js'\nimport 'dayjs/locale/kn.js'\nimport 'dayjs/locale/ko.js'\nimport 'dayjs/locale/ku.js'\nimport 'dayjs/locale/ky.js'\nimport 'dayjs/locale/lb.js'\nimport 'dayjs/locale/lo.js'\nimport 'dayjs/locale/lt.js'\nimport 'dayjs/locale/lv.js'\nimport 'dayjs/locale/me.js'\nimport 'dayjs/locale/mi.js'\nimport 'dayjs/locale/mk.js'\nimport 'dayjs/locale/ml.js'\nimport 'dayjs/locale/mn.js'\nimport 'dayjs/locale/mr.js'\nimport 'dayjs/locale/ms-my.js'\nimport 'dayjs/locale/ms.js'\nimport 'dayjs/locale/mt.js'\nimport 'dayjs/locale/my.js'\nimport 'dayjs/locale/nb.js'\nimport 'dayjs/locale/ne.js'\nimport 'dayjs/locale/nl-be.js'\nimport 'dayjs/locale/nl.js'\nimport 'dayjs/locale/nn.js'\nimport 'dayjs/locale/oc-lnc.js'\nimport 'dayjs/locale/pa-in.js'\nimport 'dayjs/locale/pl.js'\nimport 'dayjs/locale/pt-br.js'\nimport 'dayjs/locale/pt.js'\nimport 'dayjs/locale/rn.js'\nimport 'dayjs/locale/ro.js'\nimport 'dayjs/locale/ru.js'\nimport 'dayjs/locale/rw.js'\nimport 'dayjs/locale/sd.js'\nimport 'dayjs/locale/se.js'\nimport 'dayjs/locale/si.js'\nimport 'dayjs/locale/sk.js'\nimport 'dayjs/locale/sl.js'\nimport 'dayjs/locale/sq.js'\nimport 'dayjs/locale/sr-cyrl.js'\nimport 'dayjs/locale/sr.js'\nimport 'dayjs/locale/ss.js'\nimport 'dayjs/locale/sv-fi.js'\nimport 'dayjs/locale/sv.js'\nimport 'dayjs/locale/sw.js'\nimport 'dayjs/locale/ta.js'\nimport 'dayjs/locale/te.js'\nimport 'dayjs/locale/tet.js'\nimport 'dayjs/locale/tg.js'\nimport 'dayjs/locale/th.js'\nimport 'dayjs/locale/tk.js'\nimport 'dayjs/locale/tl-ph.js'\nimport 'dayjs/locale/tlh.js'\nimport 'dayjs/locale/tr.js'\nimport 'dayjs/locale/tzl.js'\nimport 'dayjs/locale/tzm-latn.js'\nimport 'dayjs/locale/tzm.js'\nimport 'dayjs/locale/ug-cn.js'\nimport 'dayjs/locale/uk.js'\nimport 'dayjs/locale/ur.js'\nimport 'dayjs/locale/uz-latn.js'\nimport 'dayjs/locale/uz.js'\nimport 'dayjs/locale/vi.js'\nimport 'dayjs/locale/x-pseudo.js'\nimport 'dayjs/locale/yo.js'\nimport 'dayjs/locale/zh-cn.js'\nimport 'dayjs/locale/zh-hk.js'\nimport 'dayjs/locale/zh-tw.js'\nimport 'dayjs/locale/zh.js'\n\n// Extend dayjs with plugins\ndayjs.extend(weekday)\ndayjs.extend(weekOfYear)\ndayjs.extend(isSameOrAfter)\ndayjs.extend(isSameOrBefore)\ndayjs.extend(isBetween)\ndayjs.extend(minMax)\ndayjs.extend(timezone)\ndayjs.extend(utc)\ndayjs.extend(localeData)\n\nexport default dayjs\n",
    "import * as React from 'react'\nimport { cva, type VariantProps } from 'class-variance-authority'\n\nimport { cn } from '@/lib/utils'\n\nconst alertVariants = cva(\n  'relative w-full rounded-lg border px-4 py-3 text-sm grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] grid-cols-[0_1fr] has-[>svg]:gap-x-3 gap-y-0.5 items-start [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current',\n  {\n    variants: {\n      variant: {\n        default: 'bg-card text-card-foreground',\n        destructive:\n          'text-destructive bg-card [&>svg]:text-current *:data-[slot=alert-description]:text-destructive/90',\n        primary:\n          'bg-blue-50 dark:bg-blue-950/20 border-blue-200 dark:border-blue-800 text-blue-900 dark:text-blue-100 [&>svg]:text-blue-600 dark:[&>svg]:text-blue-400 *:data-[slot=alert-description]:text-blue-800 dark:*:data-[slot=alert-description]:text-blue-200',\n        secondary:\n          'bg-gray-50 dark:bg-gray-950/20 border-gray-200 dark:border-gray-800 text-gray-900 dark:text-gray-100 [&>svg]:text-gray-600 dark:[&>svg]:text-gray-400 *:data-[slot=alert-description]:text-gray-800 dark:*:data-[slot=alert-description]:text-gray-200',\n        success:\n          'bg-green-50 dark:bg-green-950/20 border-green-200 dark:border-green-800 text-green-900 dark:text-green-100 [&>svg]:text-green-600 dark:[&>svg]:text-green-400 *:data-[slot=alert-description]:text-green-800 dark:*:data-[slot=alert-description]:text-green-200',\n        warning:\n          'bg-yellow-50 dark:bg-yellow-950/20 border-yellow-200 dark:border-yellow-800 text-yellow-900 dark:text-yellow-100 [&>svg]:text-yellow-600 dark:[&>svg]:text-yellow-400 *:data-[slot=alert-description]:text-yellow-800 dark:*:data-[slot=alert-description]:text-yellow-200',\n      },\n    },\n    defaultVariants: {\n      variant: 'default',\n    },\n  }\n)\n\nfunction Alert({\n  className,\n  variant,\n  ...props\n}: React.ComponentProps<'div'> & VariantProps<typeof alertVariants>) {\n  return (\n    <div\n      data-slot=\"alert\"\n      role=\"alert\"\n      className={cn(alertVariants({ variant }), className)}\n      {...props}\n    />\n  )\n}\n\nfunction AlertTitle({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"alert-title\"\n      className={cn(\n        'col-start-2 line-clamp-1 min-h-4 font-medium tracking-tight',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction AlertDescription({\n  className,\n  ...props\n}: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"alert-description\"\n      className={cn(\n        'text-muted-foreground col-start-2 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Alert, AlertTitle, AlertDescription }\n",
    "import * as React from 'react'\nimport { Slot } from '@radix-ui/react-slot'\nimport { cva, type VariantProps } from 'class-variance-authority'\n\nimport { cn } from '@/lib/utils'\n\nconst badgeVariants = cva(\n  'inline-flex items-center justify-center rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive transition-[color,box-shadow] overflow-clip',\n  {\n    variants: {\n      variant: {\n        default:\n          'border-transparent bg-primary text-primary-foreground [a&]:hover:bg-primary/90',\n        secondary:\n          'border-transparent bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90',\n        destructive:\n          'border-transparent bg-destructive text-white [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60',\n        outline:\n          'text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground',\n      },\n    },\n    defaultVariants: {\n      variant: 'default',\n    },\n  }\n)\n\nfunction Badge({\n  className,\n  variant,\n  asChild = false,\n  ...props\n}: React.ComponentProps<'span'> &\n  VariantProps<typeof badgeVariants> & { asChild?: boolean }) {\n  const Comp = asChild ? Slot : 'span'\n\n  return (\n    <Comp\n      data-slot=\"badge\"\n      className={cn(badgeVariants({ variant }), className)}\n      {...props}\n    />\n  )\n}\n\nexport { Badge, badgeVariants }\n",
    "import * as React from 'react'\nimport { Slot } from '@radix-ui/react-slot'\nimport { cva, type VariantProps } from 'class-variance-authority'\n\nimport { cn } from '@/lib/utils'\n\nconst buttonVariants = cva(\n  \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n  {\n    variants: {\n      variant: {\n        default:\n          'bg-primary text-primary-foreground shadow-xs hover:bg-primary/90',\n        destructive:\n          'bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60',\n        outline:\n          'border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50',\n        secondary:\n          'bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80',\n        ghost:\n          'hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50',\n        link: 'text-primary underline-offset-4 hover:underline',\n      },\n      size: {\n        default: 'h-9 px-4 py-2 has-[>svg]:px-3',\n        sm: 'h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5',\n        lg: 'h-10 rounded-md px-6 has-[>svg]:px-4',\n        icon: 'size-9',\n      },\n    },\n    defaultVariants: {\n      variant: 'default',\n      size: 'default',\n    },\n  }\n)\n\nfunction Button({\n  className,\n  variant,\n  size,\n  asChild = false,\n  ...props\n}: React.ComponentProps<'button'> &\n  VariantProps<typeof buttonVariants> & {\n    asChild?: boolean\n  }) {\n  const Comp = asChild ? Slot : 'button'\n\n  return (\n    <Comp\n      data-slot=\"button\"\n      className={cn(buttonVariants({ variant, size, className }))}\n      {...props}\n    />\n  )\n}\n\nexport { Button, buttonVariants }\n",
    "import * as React from 'react'\nimport { ChevronLeft, ChevronRight } from 'lucide-react'\nimport { DayPicker } from 'react-day-picker'\n\nimport { cn } from '@/lib/utils'\nimport { buttonVariants } from '@/components/ui/button'\n\nfunction Calendar({\n  className,\n  classNames,\n  showOutsideDays = true,\n  ...props\n}: React.ComponentProps<typeof DayPicker>) {\n  return (\n    <DayPicker\n      showOutsideDays={showOutsideDays}\n      className={cn('p-3', className)}\n      classNames={{\n        months: 'flex flex-col sm:flex-row gap-2',\n        month: 'flex flex-col gap-4',\n        caption: 'flex justify-center pt-1 relative items-center w-full',\n        caption_label: 'text-sm font-medium',\n        nav: 'flex items-center gap-1',\n        nav_button: cn(\n          buttonVariants({ variant: 'outline' }),\n          'size-7 bg-transparent p-0 opacity-50 hover:opacity-100'\n        ),\n        nav_button_previous: 'absolute left-1',\n        nav_button_next: 'absolute right-1',\n        table: 'w-full border-collapse space-x-1',\n        head_row: 'flex',\n        head_cell:\n          'text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]',\n        row: 'flex w-full mt-2',\n        cell: cn(\n          'relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-range-end)]:rounded-r-md',\n          props.mode === 'range'\n            ? '[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md'\n            : '[&:has([aria-selected])]:rounded-md'\n        ),\n        day: cn(\n          buttonVariants({ variant: 'ghost' }),\n          'size-8 p-0 font-normal aria-selected:opacity-100'\n        ),\n        day_range_start:\n          'day-range-start aria-selected:bg-primary aria-selected:text-primary-foreground',\n        day_range_end:\n          'day-range-end aria-selected:bg-primary aria-selected:text-primary-foreground',\n        day_selected:\n          'bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground',\n        day_today: 'bg-accent text-accent-foreground',\n        day_outside:\n          'day-outside text-muted-foreground aria-selected:text-muted-foreground',\n        day_disabled: 'text-muted-foreground opacity-50',\n        day_range_middle:\n          'aria-selected:bg-accent aria-selected:text-accent-foreground',\n        day_hidden: 'invisible',\n        ...classNames,\n      }}\n      components={{\n        IconLeft: ({ className, ...props }) => (\n          <ChevronLeft className={cn('size-4', className)} {...props} />\n        ),\n        IconRight: ({ className, ...props }) => (\n          <ChevronRight className={cn('size-4', className)} {...props} />\n        ),\n      }}\n      {...props}\n    />\n  )\n}\n\nexport { Calendar }\n",
    "import * as React from 'react'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { CheckIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Checkbox({\n  className,\n  ...props\n}: React.ComponentProps<typeof CheckboxPrimitive.Root>) {\n  return (\n    <CheckboxPrimitive.Root\n      data-slot=\"checkbox\"\n      className={cn(\n        'peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50',\n        className\n      )}\n      {...props}\n    >\n      <CheckboxPrimitive.Indicator\n        data-slot=\"checkbox-indicator\"\n        className=\"flex items-center justify-center text-current transition-none\"\n      >\n        <CheckIcon className=\"size-3.5\" />\n      </CheckboxPrimitive.Indicator>\n    </CheckboxPrimitive.Root>\n  )\n}\n\nexport { Checkbox }\n",
    "import dayjs from '@/lib/dayjs-config'\nimport { Calendar as CalendarIcon } from 'lucide-react'\nimport { cn } from '@/lib/utils'\nimport { Button } from '@/components/ui/button'\nimport { Calendar } from '@/components/ui/calendar'\nimport {\n  Popover,\n  PopoverContent,\n  PopoverTrigger,\n} from '@/components/ui/popover'\nimport { useRef } from 'react'\nimport { PopoverClose } from '@radix-ui/react-popover'\n\ninterface DatePickerProps {\n  date: Date | undefined\n  setDate: (date: Date | undefined) => void\n  label?: string\n  className?: string\n  closeOnSelect?: boolean\n}\n\nexport function DatePicker({\n  date,\n  closeOnSelect,\n  setDate,\n  label = 'Pick a date',\n  className,\n}: DatePickerProps) {\n  const popOverRef = useRef<HTMLButtonElement | null>(null)\n\n  const onSelect = (date: Date | undefined) => {\n    setDate(date)\n    if (closeOnSelect) {\n      popOverRef.current?.click()\n    }\n  }\n\n  return (\n    <div className={className}>\n      <Popover>\n        <PopoverTrigger asChild>\n          <Button\n            variant=\"outline\"\n            className={cn(\n              'w-full justify-start text-left font-normal',\n              !date && 'text-muted-foreground'\n            )}\n          >\n            <CalendarIcon className=\"mr-2 h-4 w-4\" />\n            {date ? dayjs(date).format('MMM D, YYYY') : <span>{label}</span>}\n          </Button>\n        </PopoverTrigger>\n        <PopoverContent className=\"w-auto p-0\" align=\"start\">\n          <PopoverClose ref={popOverRef} />\n          <Calendar\n            mode=\"single\"\n            selected={date}\n            onSelect={onSelect}\n            initialFocus\n          />\n        </PopoverContent>\n      </Popover>\n    </div>\n  )\n}\n",
    "import * as React from 'react'\nimport * as PopoverPrimitive from '@radix-ui/react-popover'\n\nimport { cn } from '@/lib/utils'\n\nfunction Popover({\n  ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Root>) {\n  return <PopoverPrimitive.Root data-slot=\"popover\" {...props} />\n}\n\nfunction PopoverTrigger({\n  ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Trigger>) {\n  return <PopoverPrimitive.Trigger data-slot=\"popover-trigger\" {...props} />\n}\n\nfunction PopoverContent({\n  className,\n  align = 'center',\n  sideOffset = 4,\n  ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Content>) {\n  return (\n    <PopoverPrimitive.Portal>\n      <PopoverPrimitive.Content\n        data-slot=\"popover-content\"\n        align={align}\n        sideOffset={sideOffset}\n        className={cn(\n          'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden',\n          className\n        )}\n        {...props}\n      />\n    </PopoverPrimitive.Portal>\n  )\n}\n\nfunction PopoverAnchor({\n  ...props\n}: React.ComponentProps<typeof PopoverPrimitive.Anchor>) {\n  return <PopoverPrimitive.Anchor data-slot=\"popover-anchor\" {...props} />\n}\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n",
    "import * as React from 'react'\nimport * as DialogPrimitive from '@radix-ui/react-dialog'\nimport { XIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Dialog({\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Root>) {\n  return <DialogPrimitive.Root data-slot=\"dialog\" {...props} />\n}\n\nfunction DialogTrigger({\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Trigger>) {\n  return <DialogPrimitive.Trigger data-slot=\"dialog-trigger\" {...props} />\n}\n\nfunction DialogPortal({\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Portal>) {\n  return <DialogPrimitive.Portal data-slot=\"dialog-portal\" {...props} />\n}\n\nfunction DialogClose({\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Close>) {\n  return <DialogPrimitive.Close data-slot=\"dialog-close\" {...props} />\n}\n\nfunction DialogOverlay({\n  className,\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Overlay>) {\n  return (\n    <DialogPrimitive.Overlay\n      data-slot=\"dialog-overlay\"\n      className={cn(\n        'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction DialogContent({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Content>) {\n  return (\n    <DialogPortal data-slot=\"dialog-portal\">\n      <DialogOverlay />\n      <DialogPrimitive.Content\n        data-slot=\"dialog-content\"\n        className={cn(\n          'bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg',\n          className\n        )}\n        {...props}\n      >\n        {children}\n        <DialogPrimitive.Close className=\"ring-offset-background focus:ring-ring data-[state=open]:bg-accent data-[state=open]:text-muted-foreground absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\">\n          <XIcon />\n          <span className=\"sr-only\">Close</span>\n        </DialogPrimitive.Close>\n      </DialogPrimitive.Content>\n    </DialogPortal>\n  )\n}\n\nfunction DialogHeader({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"dialog-header\"\n      className={cn('flex flex-col gap-2 text-center sm:text-left', className)}\n      {...props}\n    />\n  )\n}\n\nfunction DialogFooter({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"dialog-footer\"\n      className={cn(\n        'flex flex-col-reverse gap-2 sm:flex-row sm:justify-end',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction DialogTitle({\n  className,\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Title>) {\n  return (\n    <DialogPrimitive.Title\n      data-slot=\"dialog-title\"\n      className={cn('text-lg leading-none font-semibold', className)}\n      {...props}\n    />\n  )\n}\n\nfunction DialogDescription({\n  className,\n  ...props\n}: React.ComponentProps<typeof DialogPrimitive.Description>) {\n  return (\n    <DialogPrimitive.Description\n      data-slot=\"dialog-description\"\n      className={cn('text-muted-foreground text-sm', className)}\n      {...props}\n    />\n  )\n}\n\nexport {\n  Dialog,\n  DialogClose,\n  DialogContent,\n  DialogDescription,\n  DialogFooter,\n  DialogHeader,\n  DialogOverlay,\n  DialogPortal,\n  DialogTitle,\n  DialogTrigger,\n}\n",
    "import * as React from 'react'\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu'\nimport { CheckIcon, ChevronRightIcon, CircleIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction DropdownMenu({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Root>) {\n  return <DropdownMenuPrimitive.Root data-slot=\"dropdown-menu\" {...props} />\n}\n\nfunction DropdownMenuPortal({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Portal>) {\n  return (\n    <DropdownMenuPrimitive.Portal data-slot=\"dropdown-menu-portal\" {...props} />\n  )\n}\n\nfunction DropdownMenuTrigger({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Trigger>) {\n  return (\n    <DropdownMenuPrimitive.Trigger\n      data-slot=\"dropdown-menu-trigger\"\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuContent({\n  className,\n  sideOffset = 4,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Content>) {\n  return (\n    <DropdownMenuPrimitive.Portal>\n      <DropdownMenuPrimitive.Content\n        data-slot=\"dropdown-menu-content\"\n        sideOffset={sideOffset}\n        className={cn(\n          'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md',\n          className\n        )}\n        {...props}\n      />\n    </DropdownMenuPrimitive.Portal>\n  )\n}\n\nfunction DropdownMenuGroup({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Group>) {\n  return (\n    <DropdownMenuPrimitive.Group data-slot=\"dropdown-menu-group\" {...props} />\n  )\n}\n\nfunction DropdownMenuItem({\n  className,\n  inset,\n  variant = 'default',\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Item> & {\n  inset?: boolean\n  variant?: 'default' | 'destructive'\n}) {\n  return (\n    <DropdownMenuPrimitive.Item\n      data-slot=\"dropdown-menu-item\"\n      data-inset={inset}\n      data-variant={variant}\n      className={cn(\n        \"focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuCheckboxItem({\n  className,\n  children,\n  checked,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.CheckboxItem>) {\n  return (\n    <DropdownMenuPrimitive.CheckboxItem\n      data-slot=\"dropdown-menu-checkbox-item\"\n      className={cn(\n        \"focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n        className\n      )}\n      checked={checked}\n      {...props}\n    >\n      <span className=\"pointer-events-none absolute left-2 flex size-3.5 items-center justify-center\">\n        <DropdownMenuPrimitive.ItemIndicator>\n          <CheckIcon className=\"size-4\" />\n        </DropdownMenuPrimitive.ItemIndicator>\n      </span>\n      {children}\n    </DropdownMenuPrimitive.CheckboxItem>\n  )\n}\n\nfunction DropdownMenuRadioGroup({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.RadioGroup>) {\n  return (\n    <DropdownMenuPrimitive.RadioGroup\n      data-slot=\"dropdown-menu-radio-group\"\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuRadioItem({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.RadioItem>) {\n  return (\n    <DropdownMenuPrimitive.RadioItem\n      data-slot=\"dropdown-menu-radio-item\"\n      className={cn(\n        \"focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n        className\n      )}\n      {...props}\n    >\n      <span className=\"pointer-events-none absolute left-2 flex size-3.5 items-center justify-center\">\n        <DropdownMenuPrimitive.ItemIndicator>\n          <CircleIcon className=\"size-2 fill-current\" />\n        </DropdownMenuPrimitive.ItemIndicator>\n      </span>\n      {children}\n    </DropdownMenuPrimitive.RadioItem>\n  )\n}\n\nfunction DropdownMenuLabel({\n  className,\n  inset,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Label> & {\n  inset?: boolean\n}) {\n  return (\n    <DropdownMenuPrimitive.Label\n      data-slot=\"dropdown-menu-label\"\n      data-inset={inset}\n      className={cn(\n        'px-2 py-1.5 text-sm font-medium data-[inset]:pl-8',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuSeparator({\n  className,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Separator>) {\n  return (\n    <DropdownMenuPrimitive.Separator\n      data-slot=\"dropdown-menu-separator\"\n      className={cn('bg-border -mx-1 my-1 h-px', className)}\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuShortcut({\n  className,\n  ...props\n}: React.ComponentProps<'span'>) {\n  return (\n    <span\n      data-slot=\"dropdown-menu-shortcut\"\n      className={cn(\n        'text-muted-foreground ml-auto text-xs tracking-widest',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction DropdownMenuSub({\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.Sub>) {\n  return <DropdownMenuPrimitive.Sub data-slot=\"dropdown-menu-sub\" {...props} />\n}\n\nfunction DropdownMenuSubTrigger({\n  className,\n  inset,\n  children,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.SubTrigger> & {\n  inset?: boolean\n}) {\n  return (\n    <DropdownMenuPrimitive.SubTrigger\n      data-slot=\"dropdown-menu-sub-trigger\"\n      data-inset={inset}\n      className={cn(\n        'focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground flex cursor-default items-center rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[inset]:pl-8',\n        className\n      )}\n      {...props}\n    >\n      {children}\n      <ChevronRightIcon className=\"ml-auto size-4\" />\n    </DropdownMenuPrimitive.SubTrigger>\n  )\n}\n\nfunction DropdownMenuSubContent({\n  className,\n  ...props\n}: React.ComponentProps<typeof DropdownMenuPrimitive.SubContent>) {\n  return (\n    <DropdownMenuPrimitive.SubContent\n      data-slot=\"dropdown-menu-sub-content\"\n      className={cn(\n        'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-clip rounded-md border p-1 shadow-lg',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport {\n  DropdownMenu,\n  DropdownMenuPortal,\n  DropdownMenuTrigger,\n  DropdownMenuContent,\n  DropdownMenuGroup,\n  DropdownMenuLabel,\n  DropdownMenuItem,\n  DropdownMenuCheckboxItem,\n  DropdownMenuRadioGroup,\n  DropdownMenuRadioItem,\n  DropdownMenuSeparator,\n  DropdownMenuShortcut,\n  DropdownMenuSub,\n  DropdownMenuSubTrigger,\n  DropdownMenuSubContent,\n}\n",
    "import * as React from 'react'\nimport type * as LabelPrimitive from '@radix-ui/react-label'\nimport { Slot } from '@radix-ui/react-slot'\nimport {\n  Controller,\n  FormProvider,\n  useFormContext,\n  useFormState,\n  type ControllerProps,\n  type FieldPath,\n  type FieldValues,\n} from 'react-hook-form'\n\nimport { cn } from '@/lib/utils'\nimport { Label } from '@/components/ui/label'\n\nconst Form = FormProvider\n\ntype FormFieldContextValue<\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n> = {\n  name: TName\n}\n\nconst FormFieldContext = React.createContext<FormFieldContextValue>(\n  {} as FormFieldContextValue\n)\n\nconst FormField = <\n  TFieldValues extends FieldValues = FieldValues,\n  TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,\n>({\n  ...props\n}: ControllerProps<TFieldValues, TName>) => {\n  return (\n    <FormFieldContext.Provider value={{ name: props.name }}>\n      <Controller {...props} />\n    </FormFieldContext.Provider>\n  )\n}\n\nconst useFormField = () => {\n  const fieldContext = React.useContext(FormFieldContext)\n  const itemContext = React.useContext(FormItemContext)\n  const { getFieldState } = useFormContext()\n  const formState = useFormState({ name: fieldContext.name })\n  const fieldState = getFieldState(fieldContext.name, formState)\n\n  if (!fieldContext) {\n    throw new Error('useFormField should be used within <FormField>')\n  }\n\n  const { id } = itemContext\n\n  return {\n    id,\n    name: fieldContext.name,\n    formItemId: `${id}-form-item`,\n    formDescriptionId: `${id}-form-item-description`,\n    formMessageId: `${id}-form-item-message`,\n    ...fieldState,\n  }\n}\n\ntype FormItemContextValue = {\n  id: string\n}\n\nconst FormItemContext = React.createContext<FormItemContextValue>(\n  {} as FormItemContextValue\n)\n\nfunction FormItem({ className, ...props }: React.ComponentProps<'div'>) {\n  const id = React.useId()\n\n  return (\n    <FormItemContext.Provider value={{ id }}>\n      <div\n        data-slot=\"form-item\"\n        className={cn('grid gap-2', className)}\n        {...props}\n      />\n    </FormItemContext.Provider>\n  )\n}\n\nfunction FormLabel({\n  className,\n  ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n  const { error, formItemId } = useFormField()\n\n  return (\n    <Label\n      data-slot=\"form-label\"\n      data-error={!!error}\n      className={cn('data-[error=true]:text-destructive', className)}\n      htmlFor={formItemId}\n      {...props}\n    />\n  )\n}\n\nfunction FormControl({ ...props }: React.ComponentProps<typeof Slot>) {\n  const { error, formItemId, formDescriptionId, formMessageId } = useFormField()\n\n  return (\n    <Slot\n      data-slot=\"form-control\"\n      id={formItemId}\n      aria-describedby={\n        !error\n          ? `${formDescriptionId}`\n          : `${formDescriptionId} ${formMessageId}`\n      }\n      aria-invalid={!!error}\n      {...props}\n    />\n  )\n}\n\nfunction FormDescription({ className, ...props }: React.ComponentProps<'p'>) {\n  const { formDescriptionId } = useFormField()\n\n  return (\n    <p\n      data-slot=\"form-description\"\n      id={formDescriptionId}\n      className={cn('text-muted-foreground text-sm', className)}\n      {...props}\n    />\n  )\n}\n\nfunction FormMessage({ className, ...props }: React.ComponentProps<'p'>) {\n  const { error, formMessageId } = useFormField()\n  const body = error ? String(error?.message ?? '') : props.children\n\n  if (!body) {\n    return null\n  }\n\n  return (\n    <p\n      data-slot=\"form-message\"\n      id={formMessageId}\n      className={cn('text-destructive text-sm', className)}\n      {...props}\n    >\n      {body}\n    </p>\n  )\n}\n\nexport {\n  useFormField,\n  Form,\n  FormItem,\n  FormLabel,\n  FormControl,\n  FormDescription,\n  FormMessage,\n  FormField,\n}\n",
    "import * as React from 'react';\nimport React__default from 'react';\n\nvar isCheckBoxInput = (element) => element.type === 'checkbox';\n\nvar isDateObject = (value) => value instanceof Date;\n\nvar isNullOrUndefined = (value) => value == null;\n\nconst isObjectType = (value) => typeof value === 'object';\nvar isObject = (value) => !isNullOrUndefined(value) &&\n    !Array.isArray(value) &&\n    isObjectType(value) &&\n    !isDateObject(value);\n\nvar getEventValue = (event) => isObject(event) && event.target\n    ? isCheckBoxInput(event.target)\n        ? event.target.checked\n        : event.target.value\n    : event;\n\nvar getNodeParentName = (name) => name.substring(0, name.search(/\\.\\d+(\\.|$)/)) || name;\n\nvar isNameInFieldArray = (names, name) => names.has(getNodeParentName(name));\n\nvar isPlainObject = (tempObject) => {\n    const prototypeCopy = tempObject.constructor && tempObject.constructor.prototype;\n    return (isObject(prototypeCopy) && prototypeCopy.hasOwnProperty('isPrototypeOf'));\n};\n\nvar isWeb = typeof window !== 'undefined' &&\n    typeof window.HTMLElement !== 'undefined' &&\n    typeof document !== 'undefined';\n\nfunction cloneObject(data) {\n    let copy;\n    const isArray = Array.isArray(data);\n    const isFileListInstance = typeof FileList !== 'undefined' ? data instanceof FileList : false;\n    if (data instanceof Date) {\n        copy = new Date(data);\n    }\n    else if (!(isWeb && (data instanceof Blob || isFileListInstance)) &&\n        (isArray || isObject(data))) {\n        copy = isArray ? [] : {};\n        if (!isArray && !isPlainObject(data)) {\n            copy = data;\n        }\n        else {\n            for (const key in data) {\n                if (data.hasOwnProperty(key)) {\n                    copy[key] = cloneObject(data[key]);\n                }\n            }\n        }\n    }\n    else {\n        return data;\n    }\n    return copy;\n}\n\nvar isKey = (value) => /^\\w*$/.test(value);\n\nvar isUndefined = (val) => val === undefined;\n\nvar compact = (value) => Array.isArray(value) ? value.filter(Boolean) : [];\n\nvar stringToPath = (input) => compact(input.replace(/[\"|']|\\]/g, '').split(/\\.|\\[/));\n\nvar get = (object, path, defaultValue) => {\n    if (!path || !isObject(object)) {\n        return defaultValue;\n    }\n    const result = (isKey(path) ? [path] : stringToPath(path)).reduce((result, key) => isNullOrUndefined(result) ? result : result[key], object);\n    return isUndefined(result) || result === object\n        ? isUndefined(object[path])\n            ? defaultValue\n            : object[path]\n        : result;\n};\n\nvar isBoolean = (value) => typeof value === 'boolean';\n\nvar set = (object, path, value) => {\n    let index = -1;\n    const tempPath = isKey(path) ? [path] : stringToPath(path);\n    const length = tempPath.length;\n    const lastIndex = length - 1;\n    while (++index < length) {\n        const key = tempPath[index];\n        let newValue = value;\n        if (index !== lastIndex) {\n            const objValue = object[key];\n            newValue =\n                isObject(objValue) || Array.isArray(objValue)\n                    ? objValue\n                    : !isNaN(+tempPath[index + 1])\n                        ? []\n                        : {};\n        }\n        if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n            return;\n        }\n        object[key] = newValue;\n        object = object[key];\n    }\n};\n\nconst EVENTS = {\n    BLUR: 'blur',\n    FOCUS_OUT: 'focusout',\n    CHANGE: 'change',\n};\nconst VALIDATION_MODE = {\n    onBlur: 'onBlur',\n    onChange: 'onChange',\n    onSubmit: 'onSubmit',\n    onTouched: 'onTouched',\n    all: 'all',\n};\nconst INPUT_VALIDATION_RULES = {\n    max: 'max',\n    min: 'min',\n    maxLength: 'maxLength',\n    minLength: 'minLength',\n    pattern: 'pattern',\n    required: 'required',\n    validate: 'validate',\n};\n\nconst HookFormContext = React__default.createContext(null);\nHookFormContext.displayName = 'HookFormContext';\n/**\n * This custom hook allows you to access the form context. useFormContext is intended to be used in deeply nested structures, where it would become inconvenient to pass the context as a prop. To be used with {@link FormProvider}.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @returns return all useForm methods\n *\n * @example\n * ```tsx\n * function App() {\n *   const methods = useForm();\n *   const onSubmit = data => console.log(data);\n *\n *   return (\n *     <FormProvider {...methods} >\n *       <form onSubmit={methods.handleSubmit(onSubmit)}>\n *         <NestedInput />\n *         <input type=\"submit\" />\n *       </form>\n *     </FormProvider>\n *   );\n * }\n *\n *  function NestedInput() {\n *   const { register } = useFormContext(); // retrieve all hook methods\n *   return <input {...register(\"test\")} />;\n * }\n * ```\n */\nconst useFormContext = () => React__default.useContext(HookFormContext);\n/**\n * A provider component that propagates the `useForm` methods to all children components via [React Context](https://reactjs.org/docs/context.html) API. To be used with {@link useFormContext}.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @param props - all useForm methods\n *\n * @example\n * ```tsx\n * function App() {\n *   const methods = useForm();\n *   const onSubmit = data => console.log(data);\n *\n *   return (\n *     <FormProvider {...methods} >\n *       <form onSubmit={methods.handleSubmit(onSubmit)}>\n *         <NestedInput />\n *         <input type=\"submit\" />\n *       </form>\n *     </FormProvider>\n *   );\n * }\n *\n *  function NestedInput() {\n *   const { register } = useFormContext(); // retrieve all hook methods\n *   return <input {...register(\"test\")} />;\n * }\n * ```\n */\nconst FormProvider = (props) => {\n    const { children, ...data } = props;\n    return (React__default.createElement(HookFormContext.Provider, { value: data }, children));\n};\n\nvar getProxyFormState = (formState, control, localProxyFormState, isRoot = true) => {\n    const result = {\n        defaultValues: control._defaultValues,\n    };\n    for (const key in formState) {\n        Object.defineProperty(result, key, {\n            get: () => {\n                const _key = key;\n                if (control._proxyFormState[_key] !== VALIDATION_MODE.all) {\n                    control._proxyFormState[_key] = !isRoot || VALIDATION_MODE.all;\n                }\n                localProxyFormState && (localProxyFormState[_key] = true);\n                return formState[_key];\n            },\n        });\n    }\n    return result;\n};\n\nconst useIsomorphicLayoutEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n\n/**\n * This custom hook allows you to subscribe to each form state, and isolate the re-render at the custom hook level. It has its scope in terms of form state subscription, so it would not affect other useFormState and useForm. Using this hook can reduce the re-render impact on large and complex form application.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformstate) • [Demo](https://codesandbox.io/s/useformstate-75xly)\n *\n * @param props - include options on specify fields to subscribe. {@link UseFormStateReturn}\n *\n * @example\n * ```tsx\n * function App() {\n *   const { register, handleSubmit, control } = useForm({\n *     defaultValues: {\n *     firstName: \"firstName\"\n *   }});\n *   const { dirtyFields } = useFormState({\n *     control\n *   });\n *   const onSubmit = (data) => console.log(data);\n *\n *   return (\n *     <form onSubmit={handleSubmit(onSubmit)}>\n *       <input {...register(\"firstName\")} placeholder=\"First Name\" />\n *       {dirtyFields.firstName && <p>Field is dirty.</p>}\n *       <input type=\"submit\" />\n *     </form>\n *   );\n * }\n * ```\n */\nfunction useFormState(props) {\n    const methods = useFormContext();\n    const { control = methods.control, disabled, name, exact } = props || {};\n    const [formState, updateFormState] = React__default.useState(control._formState);\n    const _localProxyFormState = React__default.useRef({\n        isDirty: false,\n        isLoading: false,\n        dirtyFields: false,\n        touchedFields: false,\n        validatingFields: false,\n        isValidating: false,\n        isValid: false,\n        errors: false,\n    });\n    useIsomorphicLayoutEffect(() => control._subscribe({\n        name,\n        formState: _localProxyFormState.current,\n        exact,\n        callback: (formState) => {\n            !disabled &&\n                updateFormState({\n                    ...control._formState,\n                    ...formState,\n                });\n        },\n    }), [name, disabled, exact]);\n    React__default.useEffect(() => {\n        _localProxyFormState.current.isValid && control._setValid(true);\n    }, [control]);\n    return React__default.useMemo(() => getProxyFormState(formState, control, _localProxyFormState.current, false), [formState, control]);\n}\n\nvar isString = (value) => typeof value === 'string';\n\nvar generateWatchOutput = (names, _names, formValues, isGlobal, defaultValue) => {\n    if (isString(names)) {\n        isGlobal && _names.watch.add(names);\n        return get(formValues, names, defaultValue);\n    }\n    if (Array.isArray(names)) {\n        return names.map((fieldName) => (isGlobal && _names.watch.add(fieldName),\n            get(formValues, fieldName)));\n    }\n    isGlobal && (_names.watchAll = true);\n    return formValues;\n};\n\n/**\n * Custom hook to subscribe to field change and isolate re-rendering at the component level.\n *\n * @remarks\n *\n * [API](https://react-hook-form.com/docs/usewatch) • [Demo](https://codesandbox.io/s/react-hook-form-v7-ts-usewatch-h9i5e)\n *\n * @example\n * ```tsx\n * const { control } = useForm();\n * const values = useWatch({\n *   name: \"fieldName\"\n *   control,\n * })\n * ```\n */\nfunction useWatch(props) {\n    const methods = useFormContext();\n    const { control = methods.control, name, defaultValue, disabled, exact, } = props || {};\n    const _defaultValue = React__default.useRef(defaultValue);\n    const [value, updateValue] = React__default.useState(control._getWatch(name, _defaultValue.current));\n    useIsomorphicLayoutEffect(() => control._subscribe({\n        name,\n        formState: {\n            values: true,\n        },\n        exact,\n        callback: (formState) => !disabled &&\n            updateValue(generateWatchOutput(name, control._names, formState.values || control._formValues, false, _defaultValue.current)),\n    }), [name, control, disabled, exact]);\n    React__default.useEffect(() => control._removeUnmounted());\n    return value;\n}\n\n/**\n * Custom hook to work with controlled component, this function provide you with both form and field level state. Re-render is isolated at the hook level.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usecontroller) • [Demo](https://codesandbox.io/s/usecontroller-0o8px)\n *\n * @param props - the path name to the form field value, and validation rules.\n *\n * @returns field properties, field and form state. {@link UseControllerReturn}\n *\n * @example\n * ```tsx\n * function Input(props) {\n *   const { field, fieldState, formState } = useController(props);\n *   return (\n *     <div>\n *       <input {...field} placeholder={props.name} />\n *       <p>{fieldState.isTouched && \"Touched\"}</p>\n *       <p>{formState.isSubmitted ? \"submitted\" : \"\"}</p>\n *     </div>\n *   );\n * }\n * ```\n */\nfunction useController(props) {\n    const methods = useFormContext();\n    const { name, disabled, control = methods.control, shouldUnregister } = props;\n    const isArrayField = isNameInFieldArray(control._names.array, name);\n    const value = useWatch({\n        control,\n        name,\n        defaultValue: get(control._formValues, name, get(control._defaultValues, name, props.defaultValue)),\n        exact: true,\n    });\n    const formState = useFormState({\n        control,\n        name,\n        exact: true,\n    });\n    const _props = React__default.useRef(props);\n    const _registerProps = React__default.useRef(control.register(name, {\n        ...props.rules,\n        value,\n        ...(isBoolean(props.disabled) ? { disabled: props.disabled } : {}),\n    }));\n    const fieldState = React__default.useMemo(() => Object.defineProperties({}, {\n        invalid: {\n            enumerable: true,\n            get: () => !!get(formState.errors, name),\n        },\n        isDirty: {\n            enumerable: true,\n            get: () => !!get(formState.dirtyFields, name),\n        },\n        isTouched: {\n            enumerable: true,\n            get: () => !!get(formState.touchedFields, name),\n        },\n        isValidating: {\n            enumerable: true,\n            get: () => !!get(formState.validatingFields, name),\n        },\n        error: {\n            enumerable: true,\n            get: () => get(formState.errors, name),\n        },\n    }), [formState, name]);\n    const onChange = React__default.useCallback((event) => _registerProps.current.onChange({\n        target: {\n            value: getEventValue(event),\n            name: name,\n        },\n        type: EVENTS.CHANGE,\n    }), [name]);\n    const onBlur = React__default.useCallback(() => _registerProps.current.onBlur({\n        target: {\n            value: get(control._formValues, name),\n            name: name,\n        },\n        type: EVENTS.BLUR,\n    }), [name, control._formValues]);\n    const ref = React__default.useCallback((elm) => {\n        const field = get(control._fields, name);\n        if (field && elm) {\n            field._f.ref = {\n                focus: () => elm.focus && elm.focus(),\n                select: () => elm.select && elm.select(),\n                setCustomValidity: (message) => elm.setCustomValidity(message),\n                reportValidity: () => elm.reportValidity(),\n            };\n        }\n    }, [control._fields, name]);\n    const field = React__default.useMemo(() => ({\n        name,\n        value,\n        ...(isBoolean(disabled) || formState.disabled\n            ? { disabled: formState.disabled || disabled }\n            : {}),\n        onChange,\n        onBlur,\n        ref,\n    }), [name, disabled, formState.disabled, onChange, onBlur, ref, value]);\n    React__default.useEffect(() => {\n        const _shouldUnregisterField = control._options.shouldUnregister || shouldUnregister;\n        control.register(name, {\n            ..._props.current.rules,\n            ...(isBoolean(_props.current.disabled)\n                ? { disabled: _props.current.disabled }\n                : {}),\n        });\n        const updateMounted = (name, value) => {\n            const field = get(control._fields, name);\n            if (field && field._f) {\n                field._f.mount = value;\n            }\n        };\n        updateMounted(name, true);\n        if (_shouldUnregisterField) {\n            const value = cloneObject(get(control._options.defaultValues, name));\n            set(control._defaultValues, name, value);\n            if (isUndefined(get(control._formValues, name))) {\n                set(control._formValues, name, value);\n            }\n        }\n        !isArrayField && control.register(name);\n        return () => {\n            (isArrayField\n                ? _shouldUnregisterField && !control._state.action\n                : _shouldUnregisterField)\n                ? control.unregister(name)\n                : updateMounted(name, false);\n        };\n    }, [name, control, isArrayField, shouldUnregister]);\n    React__default.useEffect(() => {\n        control._setDisabledField({\n            disabled,\n            name,\n        });\n    }, [disabled, name, control]);\n    return React__default.useMemo(() => ({\n        field,\n        formState,\n        fieldState,\n    }), [field, formState, fieldState]);\n}\n\n/**\n * Component based on `useController` hook to work with controlled component.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usecontroller/controller) • [Demo](https://codesandbox.io/s/react-hook-form-v6-controller-ts-jwyzw) • [Video](https://www.youtube.com/watch?v=N2UNk_UCVyA)\n *\n * @param props - the path name to the form field value, and validation rules.\n *\n * @returns provide field handler functions, field and form state.\n *\n * @example\n * ```tsx\n * function App() {\n *   const { control } = useForm<FormValues>({\n *     defaultValues: {\n *       test: \"\"\n *     }\n *   });\n *\n *   return (\n *     <form>\n *       <Controller\n *         control={control}\n *         name=\"test\"\n *         render={({ field: { onChange, onBlur, value, ref }, formState, fieldState }) => (\n *           <>\n *             <input\n *               onChange={onChange} // send value to hook form\n *               onBlur={onBlur} // notify when input is touched\n *               value={value} // return updated value\n *               ref={ref} // set ref for focus management\n *             />\n *             <p>{formState.isSubmitted ? \"submitted\" : \"\"}</p>\n *             <p>{fieldState.isTouched ? \"touched\" : \"\"}</p>\n *           </>\n *         )}\n *       />\n *     </form>\n *   );\n * }\n * ```\n */\nconst Controller = (props) => props.render(useController(props));\n\nconst flatten = (obj) => {\n    const output = {};\n    for (const key of Object.keys(obj)) {\n        if (isObjectType(obj[key]) && obj[key] !== null) {\n            const nested = flatten(obj[key]);\n            for (const nestedKey of Object.keys(nested)) {\n                output[`${key}.${nestedKey}`] = nested[nestedKey];\n            }\n        }\n        else {\n            output[key] = obj[key];\n        }\n    }\n    return output;\n};\n\nconst POST_REQUEST = 'post';\n/**\n * Form component to manage submission.\n *\n * @param props - to setup submission detail. {@link FormProps}\n *\n * @returns form component or headless render prop.\n *\n * @example\n * ```tsx\n * function App() {\n *   const { control, formState: { errors } } = useForm();\n *\n *   return (\n *     <Form action=\"/api\" control={control}>\n *       <input {...register(\"name\")} />\n *       <p>{errors?.root?.server && 'Server error'}</p>\n *       <button>Submit</button>\n *     </Form>\n *   );\n * }\n * ```\n */\nfunction Form(props) {\n    const methods = useFormContext();\n    const [mounted, setMounted] = React__default.useState(false);\n    const { control = methods.control, onSubmit, children, action, method = POST_REQUEST, headers, encType, onError, render, onSuccess, validateStatus, ...rest } = props;\n    const submit = async (event) => {\n        let hasError = false;\n        let type = '';\n        await control.handleSubmit(async (data) => {\n            const formData = new FormData();\n            let formDataJson = '';\n            try {\n                formDataJson = JSON.stringify(data);\n            }\n            catch (_a) { }\n            const flattenFormValues = flatten(control._formValues);\n            for (const key in flattenFormValues) {\n                formData.append(key, flattenFormValues[key]);\n            }\n            if (onSubmit) {\n                await onSubmit({\n                    data,\n                    event,\n                    method,\n                    formData,\n                    formDataJson,\n                });\n            }\n            if (action) {\n                try {\n                    const shouldStringifySubmissionData = [\n                        headers && headers['Content-Type'],\n                        encType,\n                    ].some((value) => value && value.includes('json'));\n                    const response = await fetch(String(action), {\n                        method,\n                        headers: {\n                            ...headers,\n                            ...(encType ? { 'Content-Type': encType } : {}),\n                        },\n                        body: shouldStringifySubmissionData ? formDataJson : formData,\n                    });\n                    if (response &&\n                        (validateStatus\n                            ? !validateStatus(response.status)\n                            : response.status < 200 || response.status >= 300)) {\n                        hasError = true;\n                        onError && onError({ response });\n                        type = String(response.status);\n                    }\n                    else {\n                        onSuccess && onSuccess({ response });\n                    }\n                }\n                catch (error) {\n                    hasError = true;\n                    onError && onError({ error });\n                }\n            }\n        })(event);\n        if (hasError && props.control) {\n            props.control._subjects.state.next({\n                isSubmitSuccessful: false,\n            });\n            props.control.setError('root.server', {\n                type,\n            });\n        }\n    };\n    React__default.useEffect(() => {\n        setMounted(true);\n    }, []);\n    return render ? (React__default.createElement(React__default.Fragment, null, render({\n        submit,\n    }))) : (React__default.createElement(\"form\", { noValidate: mounted, action: action, method: method, encType: encType, onSubmit: submit, ...rest }, children));\n}\n\nvar appendErrors = (name, validateAllFieldCriteria, errors, type, message) => validateAllFieldCriteria\n    ? {\n        ...errors[name],\n        types: {\n            ...(errors[name] && errors[name].types ? errors[name].types : {}),\n            [type]: message || true,\n        },\n    }\n    : {};\n\nvar convertToArrayPayload = (value) => (Array.isArray(value) ? value : [value]);\n\nvar createSubject = () => {\n    let _observers = [];\n    const next = (value) => {\n        for (const observer of _observers) {\n            observer.next && observer.next(value);\n        }\n    };\n    const subscribe = (observer) => {\n        _observers.push(observer);\n        return {\n            unsubscribe: () => {\n                _observers = _observers.filter((o) => o !== observer);\n            },\n        };\n    };\n    const unsubscribe = () => {\n        _observers = [];\n    };\n    return {\n        get observers() {\n            return _observers;\n        },\n        next,\n        subscribe,\n        unsubscribe,\n    };\n};\n\nvar isPrimitive = (value) => isNullOrUndefined(value) || !isObjectType(value);\n\nfunction deepEqual(object1, object2, _internal_visited = new WeakSet()) {\n    if (isPrimitive(object1) || isPrimitive(object2)) {\n        return object1 === object2;\n    }\n    if (isDateObject(object1) && isDateObject(object2)) {\n        return object1.getTime() === object2.getTime();\n    }\n    const keys1 = Object.keys(object1);\n    const keys2 = Object.keys(object2);\n    if (keys1.length !== keys2.length) {\n        return false;\n    }\n    if (_internal_visited.has(object1) || _internal_visited.has(object2)) {\n        return true;\n    }\n    _internal_visited.add(object1);\n    _internal_visited.add(object2);\n    for (const key of keys1) {\n        const val1 = object1[key];\n        if (!keys2.includes(key)) {\n            return false;\n        }\n        if (key !== 'ref') {\n            const val2 = object2[key];\n            if ((isDateObject(val1) && isDateObject(val2)) ||\n                (isObject(val1) && isObject(val2)) ||\n                (Array.isArray(val1) && Array.isArray(val2))\n                ? !deepEqual(val1, val2, _internal_visited)\n                : val1 !== val2) {\n                return false;\n            }\n        }\n    }\n    return true;\n}\n\nvar isEmptyObject = (value) => isObject(value) && !Object.keys(value).length;\n\nvar isFileInput = (element) => element.type === 'file';\n\nvar isFunction = (value) => typeof value === 'function';\n\nvar isHTMLElement = (value) => {\n    if (!isWeb) {\n        return false;\n    }\n    const owner = value ? value.ownerDocument : 0;\n    return (value instanceof\n        (owner && owner.defaultView ? owner.defaultView.HTMLElement : HTMLElement));\n};\n\nvar isMultipleSelect = (element) => element.type === `select-multiple`;\n\nvar isRadioInput = (element) => element.type === 'radio';\n\nvar isRadioOrCheckbox = (ref) => isRadioInput(ref) || isCheckBoxInput(ref);\n\nvar live = (ref) => isHTMLElement(ref) && ref.isConnected;\n\nfunction baseGet(object, updatePath) {\n    const length = updatePath.slice(0, -1).length;\n    let index = 0;\n    while (index < length) {\n        object = isUndefined(object) ? index++ : object[updatePath[index++]];\n    }\n    return object;\n}\nfunction isEmptyArray(obj) {\n    for (const key in obj) {\n        if (obj.hasOwnProperty(key) && !isUndefined(obj[key])) {\n            return false;\n        }\n    }\n    return true;\n}\nfunction unset(object, path) {\n    const paths = Array.isArray(path)\n        ? path\n        : isKey(path)\n            ? [path]\n            : stringToPath(path);\n    const childObject = paths.length === 1 ? object : baseGet(object, paths);\n    const index = paths.length - 1;\n    const key = paths[index];\n    if (childObject) {\n        delete childObject[key];\n    }\n    if (index !== 0 &&\n        ((isObject(childObject) && isEmptyObject(childObject)) ||\n            (Array.isArray(childObject) && isEmptyArray(childObject)))) {\n        unset(object, paths.slice(0, -1));\n    }\n    return object;\n}\n\nvar objectHasFunction = (data) => {\n    for (const key in data) {\n        if (isFunction(data[key])) {\n            return true;\n        }\n    }\n    return false;\n};\n\nfunction markFieldsDirty(data, fields = {}) {\n    const isParentNodeArray = Array.isArray(data);\n    if (isObject(data) || isParentNodeArray) {\n        for (const key in data) {\n            if (Array.isArray(data[key]) ||\n                (isObject(data[key]) && !objectHasFunction(data[key]))) {\n                fields[key] = Array.isArray(data[key]) ? [] : {};\n                markFieldsDirty(data[key], fields[key]);\n            }\n            else if (!isNullOrUndefined(data[key])) {\n                fields[key] = true;\n            }\n        }\n    }\n    return fields;\n}\nfunction getDirtyFieldsFromDefaultValues(data, formValues, dirtyFieldsFromValues) {\n    const isParentNodeArray = Array.isArray(data);\n    if (isObject(data) || isParentNodeArray) {\n        for (const key in data) {\n            if (Array.isArray(data[key]) ||\n                (isObject(data[key]) && !objectHasFunction(data[key]))) {\n                if (isUndefined(formValues) ||\n                    isPrimitive(dirtyFieldsFromValues[key])) {\n                    dirtyFieldsFromValues[key] = Array.isArray(data[key])\n                        ? markFieldsDirty(data[key], [])\n                        : { ...markFieldsDirty(data[key]) };\n                }\n                else {\n                    getDirtyFieldsFromDefaultValues(data[key], isNullOrUndefined(formValues) ? {} : formValues[key], dirtyFieldsFromValues[key]);\n                }\n            }\n            else {\n                dirtyFieldsFromValues[key] = !deepEqual(data[key], formValues[key]);\n            }\n        }\n    }\n    return dirtyFieldsFromValues;\n}\nvar getDirtyFields = (defaultValues, formValues) => getDirtyFieldsFromDefaultValues(defaultValues, formValues, markFieldsDirty(formValues));\n\nconst defaultResult = {\n    value: false,\n    isValid: false,\n};\nconst validResult = { value: true, isValid: true };\nvar getCheckboxValue = (options) => {\n    if (Array.isArray(options)) {\n        if (options.length > 1) {\n            const values = options\n                .filter((option) => option && option.checked && !option.disabled)\n                .map((option) => option.value);\n            return { value: values, isValid: !!values.length };\n        }\n        return options[0].checked && !options[0].disabled\n            ? // @ts-expect-error expected to work in the browser\n                options[0].attributes && !isUndefined(options[0].attributes.value)\n                    ? isUndefined(options[0].value) || options[0].value === ''\n                        ? validResult\n                        : { value: options[0].value, isValid: true }\n                    : validResult\n            : defaultResult;\n    }\n    return defaultResult;\n};\n\nvar getFieldValueAs = (value, { valueAsNumber, valueAsDate, setValueAs }) => isUndefined(value)\n    ? value\n    : valueAsNumber\n        ? value === ''\n            ? NaN\n            : value\n                ? +value\n                : value\n        : valueAsDate && isString(value)\n            ? new Date(value)\n            : setValueAs\n                ? setValueAs(value)\n                : value;\n\nconst defaultReturn = {\n    isValid: false,\n    value: null,\n};\nvar getRadioValue = (options) => Array.isArray(options)\n    ? options.reduce((previous, option) => option && option.checked && !option.disabled\n        ? {\n            isValid: true,\n            value: option.value,\n        }\n        : previous, defaultReturn)\n    : defaultReturn;\n\nfunction getFieldValue(_f) {\n    const ref = _f.ref;\n    if (isFileInput(ref)) {\n        return ref.files;\n    }\n    if (isRadioInput(ref)) {\n        return getRadioValue(_f.refs).value;\n    }\n    if (isMultipleSelect(ref)) {\n        return [...ref.selectedOptions].map(({ value }) => value);\n    }\n    if (isCheckBoxInput(ref)) {\n        return getCheckboxValue(_f.refs).value;\n    }\n    return getFieldValueAs(isUndefined(ref.value) ? _f.ref.value : ref.value, _f);\n}\n\nvar getResolverOptions = (fieldsNames, _fields, criteriaMode, shouldUseNativeValidation) => {\n    const fields = {};\n    for (const name of fieldsNames) {\n        const field = get(_fields, name);\n        field && set(fields, name, field._f);\n    }\n    return {\n        criteriaMode,\n        names: [...fieldsNames],\n        fields,\n        shouldUseNativeValidation,\n    };\n};\n\nvar isRegex = (value) => value instanceof RegExp;\n\nvar getRuleValue = (rule) => isUndefined(rule)\n    ? rule\n    : isRegex(rule)\n        ? rule.source\n        : isObject(rule)\n            ? isRegex(rule.value)\n                ? rule.value.source\n                : rule.value\n            : rule;\n\nvar getValidationModes = (mode) => ({\n    isOnSubmit: !mode || mode === VALIDATION_MODE.onSubmit,\n    isOnBlur: mode === VALIDATION_MODE.onBlur,\n    isOnChange: mode === VALIDATION_MODE.onChange,\n    isOnAll: mode === VALIDATION_MODE.all,\n    isOnTouch: mode === VALIDATION_MODE.onTouched,\n});\n\nconst ASYNC_FUNCTION = 'AsyncFunction';\nvar hasPromiseValidation = (fieldReference) => !!fieldReference &&\n    !!fieldReference.validate &&\n    !!((isFunction(fieldReference.validate) &&\n        fieldReference.validate.constructor.name === ASYNC_FUNCTION) ||\n        (isObject(fieldReference.validate) &&\n            Object.values(fieldReference.validate).find((validateFunction) => validateFunction.constructor.name === ASYNC_FUNCTION)));\n\nvar hasValidation = (options) => options.mount &&\n    (options.required ||\n        options.min ||\n        options.max ||\n        options.maxLength ||\n        options.minLength ||\n        options.pattern ||\n        options.validate);\n\nvar isWatched = (name, _names, isBlurEvent) => !isBlurEvent &&\n    (_names.watchAll ||\n        _names.watch.has(name) ||\n        [..._names.watch].some((watchName) => name.startsWith(watchName) &&\n            /^\\.\\w+/.test(name.slice(watchName.length))));\n\nconst iterateFieldsByAction = (fields, action, fieldsNames, abortEarly) => {\n    for (const key of fieldsNames || Object.keys(fields)) {\n        const field = get(fields, key);\n        if (field) {\n            const { _f, ...currentField } = field;\n            if (_f) {\n                if (_f.refs && _f.refs[0] && action(_f.refs[0], key) && !abortEarly) {\n                    return true;\n                }\n                else if (_f.ref && action(_f.ref, _f.name) && !abortEarly) {\n                    return true;\n                }\n                else {\n                    if (iterateFieldsByAction(currentField, action)) {\n                        break;\n                    }\n                }\n            }\n            else if (isObject(currentField)) {\n                if (iterateFieldsByAction(currentField, action)) {\n                    break;\n                }\n            }\n        }\n    }\n    return;\n};\n\nfunction schemaErrorLookup(errors, _fields, name) {\n    const error = get(errors, name);\n    if (error || isKey(name)) {\n        return {\n            error,\n            name,\n        };\n    }\n    const names = name.split('.');\n    while (names.length) {\n        const fieldName = names.join('.');\n        const field = get(_fields, fieldName);\n        const foundError = get(errors, fieldName);\n        if (field && !Array.isArray(field) && name !== fieldName) {\n            return { name };\n        }\n        if (foundError && foundError.type) {\n            return {\n                name: fieldName,\n                error: foundError,\n            };\n        }\n        if (foundError && foundError.root && foundError.root.type) {\n            return {\n                name: `${fieldName}.root`,\n                error: foundError.root,\n            };\n        }\n        names.pop();\n    }\n    return {\n        name,\n    };\n}\n\nvar shouldRenderFormState = (formStateData, _proxyFormState, updateFormState, isRoot) => {\n    updateFormState(formStateData);\n    const { name, ...formState } = formStateData;\n    return (isEmptyObject(formState) ||\n        Object.keys(formState).length >= Object.keys(_proxyFormState).length ||\n        Object.keys(formState).find((key) => _proxyFormState[key] ===\n            (!isRoot || VALIDATION_MODE.all)));\n};\n\nvar shouldSubscribeByName = (name, signalName, exact) => !name ||\n    !signalName ||\n    name === signalName ||\n    convertToArrayPayload(name).some((currentName) => currentName &&\n        (exact\n            ? currentName === signalName\n            : currentName.startsWith(signalName) ||\n                signalName.startsWith(currentName)));\n\nvar skipValidation = (isBlurEvent, isTouched, isSubmitted, reValidateMode, mode) => {\n    if (mode.isOnAll) {\n        return false;\n    }\n    else if (!isSubmitted && mode.isOnTouch) {\n        return !(isTouched || isBlurEvent);\n    }\n    else if (isSubmitted ? reValidateMode.isOnBlur : mode.isOnBlur) {\n        return !isBlurEvent;\n    }\n    else if (isSubmitted ? reValidateMode.isOnChange : mode.isOnChange) {\n        return isBlurEvent;\n    }\n    return true;\n};\n\nvar unsetEmptyArray = (ref, name) => !compact(get(ref, name)).length && unset(ref, name);\n\nvar updateFieldArrayRootError = (errors, error, name) => {\n    const fieldArrayErrors = convertToArrayPayload(get(errors, name));\n    set(fieldArrayErrors, 'root', error[name]);\n    set(errors, name, fieldArrayErrors);\n    return errors;\n};\n\nvar isMessage = (value) => isString(value);\n\nfunction getValidateError(result, ref, type = 'validate') {\n    if (isMessage(result) ||\n        (Array.isArray(result) && result.every(isMessage)) ||\n        (isBoolean(result) && !result)) {\n        return {\n            type,\n            message: isMessage(result) ? result : '',\n            ref,\n        };\n    }\n}\n\nvar getValueAndMessage = (validationData) => isObject(validationData) && !isRegex(validationData)\n    ? validationData\n    : {\n        value: validationData,\n        message: '',\n    };\n\nvar validateField = async (field, disabledFieldNames, formValues, validateAllFieldCriteria, shouldUseNativeValidation, isFieldArray) => {\n    const { ref, refs, required, maxLength, minLength, min, max, pattern, validate, name, valueAsNumber, mount, } = field._f;\n    const inputValue = get(formValues, name);\n    if (!mount || disabledFieldNames.has(name)) {\n        return {};\n    }\n    const inputRef = refs ? refs[0] : ref;\n    const setCustomValidity = (message) => {\n        if (shouldUseNativeValidation && inputRef.reportValidity) {\n            inputRef.setCustomValidity(isBoolean(message) ? '' : message || '');\n            inputRef.reportValidity();\n        }\n    };\n    const error = {};\n    const isRadio = isRadioInput(ref);\n    const isCheckBox = isCheckBoxInput(ref);\n    const isRadioOrCheckbox = isRadio || isCheckBox;\n    const isEmpty = ((valueAsNumber || isFileInput(ref)) &&\n        isUndefined(ref.value) &&\n        isUndefined(inputValue)) ||\n        (isHTMLElement(ref) && ref.value === '') ||\n        inputValue === '' ||\n        (Array.isArray(inputValue) && !inputValue.length);\n    const appendErrorsCurry = appendErrors.bind(null, name, validateAllFieldCriteria, error);\n    const getMinMaxMessage = (exceedMax, maxLengthMessage, minLengthMessage, maxType = INPUT_VALIDATION_RULES.maxLength, minType = INPUT_VALIDATION_RULES.minLength) => {\n        const message = exceedMax ? maxLengthMessage : minLengthMessage;\n        error[name] = {\n            type: exceedMax ? maxType : minType,\n            message,\n            ref,\n            ...appendErrorsCurry(exceedMax ? maxType : minType, message),\n        };\n    };\n    if (isFieldArray\n        ? !Array.isArray(inputValue) || !inputValue.length\n        : required &&\n            ((!isRadioOrCheckbox && (isEmpty || isNullOrUndefined(inputValue))) ||\n                (isBoolean(inputValue) && !inputValue) ||\n                (isCheckBox && !getCheckboxValue(refs).isValid) ||\n                (isRadio && !getRadioValue(refs).isValid))) {\n        const { value, message } = isMessage(required)\n            ? { value: !!required, message: required }\n            : getValueAndMessage(required);\n        if (value) {\n            error[name] = {\n                type: INPUT_VALIDATION_RULES.required,\n                message,\n                ref: inputRef,\n                ...appendErrorsCurry(INPUT_VALIDATION_RULES.required, message),\n            };\n            if (!validateAllFieldCriteria) {\n                setCustomValidity(message);\n                return error;\n            }\n        }\n    }\n    if (!isEmpty && (!isNullOrUndefined(min) || !isNullOrUndefined(max))) {\n        let exceedMax;\n        let exceedMin;\n        const maxOutput = getValueAndMessage(max);\n        const minOutput = getValueAndMessage(min);\n        if (!isNullOrUndefined(inputValue) && !isNaN(inputValue)) {\n            const valueNumber = ref.valueAsNumber ||\n                (inputValue ? +inputValue : inputValue);\n            if (!isNullOrUndefined(maxOutput.value)) {\n                exceedMax = valueNumber > maxOutput.value;\n            }\n            if (!isNullOrUndefined(minOutput.value)) {\n                exceedMin = valueNumber < minOutput.value;\n            }\n        }\n        else {\n            const valueDate = ref.valueAsDate || new Date(inputValue);\n            const convertTimeToDate = (time) => new Date(new Date().toDateString() + ' ' + time);\n            const isTime = ref.type == 'time';\n            const isWeek = ref.type == 'week';\n            if (isString(maxOutput.value) && inputValue) {\n                exceedMax = isTime\n                    ? convertTimeToDate(inputValue) > convertTimeToDate(maxOutput.value)\n                    : isWeek\n                        ? inputValue > maxOutput.value\n                        : valueDate > new Date(maxOutput.value);\n            }\n            if (isString(minOutput.value) && inputValue) {\n                exceedMin = isTime\n                    ? convertTimeToDate(inputValue) < convertTimeToDate(minOutput.value)\n                    : isWeek\n                        ? inputValue < minOutput.value\n                        : valueDate < new Date(minOutput.value);\n            }\n        }\n        if (exceedMax || exceedMin) {\n            getMinMaxMessage(!!exceedMax, maxOutput.message, minOutput.message, INPUT_VALIDATION_RULES.max, INPUT_VALIDATION_RULES.min);\n            if (!validateAllFieldCriteria) {\n                setCustomValidity(error[name].message);\n                return error;\n            }\n        }\n    }\n    if ((maxLength || minLength) &&\n        !isEmpty &&\n        (isString(inputValue) || (isFieldArray && Array.isArray(inputValue)))) {\n        const maxLengthOutput = getValueAndMessage(maxLength);\n        const minLengthOutput = getValueAndMessage(minLength);\n        const exceedMax = !isNullOrUndefined(maxLengthOutput.value) &&\n            inputValue.length > +maxLengthOutput.value;\n        const exceedMin = !isNullOrUndefined(minLengthOutput.value) &&\n            inputValue.length < +minLengthOutput.value;\n        if (exceedMax || exceedMin) {\n            getMinMaxMessage(exceedMax, maxLengthOutput.message, minLengthOutput.message);\n            if (!validateAllFieldCriteria) {\n                setCustomValidity(error[name].message);\n                return error;\n            }\n        }\n    }\n    if (pattern && !isEmpty && isString(inputValue)) {\n        const { value: patternValue, message } = getValueAndMessage(pattern);\n        if (isRegex(patternValue) && !inputValue.match(patternValue)) {\n            error[name] = {\n                type: INPUT_VALIDATION_RULES.pattern,\n                message,\n                ref,\n                ...appendErrorsCurry(INPUT_VALIDATION_RULES.pattern, message),\n            };\n            if (!validateAllFieldCriteria) {\n                setCustomValidity(message);\n                return error;\n            }\n        }\n    }\n    if (validate) {\n        if (isFunction(validate)) {\n            const result = await validate(inputValue, formValues);\n            const validateError = getValidateError(result, inputRef);\n            if (validateError) {\n                error[name] = {\n                    ...validateError,\n                    ...appendErrorsCurry(INPUT_VALIDATION_RULES.validate, validateError.message),\n                };\n                if (!validateAllFieldCriteria) {\n                    setCustomValidity(validateError.message);\n                    return error;\n                }\n            }\n        }\n        else if (isObject(validate)) {\n            let validationResult = {};\n            for (const key in validate) {\n                if (!isEmptyObject(validationResult) && !validateAllFieldCriteria) {\n                    break;\n                }\n                const validateError = getValidateError(await validate[key](inputValue, formValues), inputRef, key);\n                if (validateError) {\n                    validationResult = {\n                        ...validateError,\n                        ...appendErrorsCurry(key, validateError.message),\n                    };\n                    setCustomValidity(validateError.message);\n                    if (validateAllFieldCriteria) {\n                        error[name] = validationResult;\n                    }\n                }\n            }\n            if (!isEmptyObject(validationResult)) {\n                error[name] = {\n                    ref: inputRef,\n                    ...validationResult,\n                };\n                if (!validateAllFieldCriteria) {\n                    return error;\n                }\n            }\n        }\n    }\n    setCustomValidity(true);\n    return error;\n};\n\nconst defaultOptions = {\n    mode: VALIDATION_MODE.onSubmit,\n    reValidateMode: VALIDATION_MODE.onChange,\n    shouldFocusError: true,\n};\nfunction createFormControl(props = {}) {\n    let _options = {\n        ...defaultOptions,\n        ...props,\n    };\n    let _formState = {\n        submitCount: 0,\n        isDirty: false,\n        isReady: false,\n        isLoading: isFunction(_options.defaultValues),\n        isValidating: false,\n        isSubmitted: false,\n        isSubmitting: false,\n        isSubmitSuccessful: false,\n        isValid: false,\n        touchedFields: {},\n        dirtyFields: {},\n        validatingFields: {},\n        errors: _options.errors || {},\n        disabled: _options.disabled || false,\n    };\n    let _fields = {};\n    let _defaultValues = isObject(_options.defaultValues) || isObject(_options.values)\n        ? cloneObject(_options.defaultValues || _options.values) || {}\n        : {};\n    let _formValues = _options.shouldUnregister\n        ? {}\n        : cloneObject(_defaultValues);\n    let _state = {\n        action: false,\n        mount: false,\n        watch: false,\n    };\n    let _names = {\n        mount: new Set(),\n        disabled: new Set(),\n        unMount: new Set(),\n        array: new Set(),\n        watch: new Set(),\n    };\n    let delayErrorCallback;\n    let timer = 0;\n    const _proxyFormState = {\n        isDirty: false,\n        dirtyFields: false,\n        validatingFields: false,\n        touchedFields: false,\n        isValidating: false,\n        isValid: false,\n        errors: false,\n    };\n    let _proxySubscribeFormState = {\n        ..._proxyFormState,\n    };\n    const _subjects = {\n        array: createSubject(),\n        state: createSubject(),\n    };\n    const shouldDisplayAllAssociatedErrors = _options.criteriaMode === VALIDATION_MODE.all;\n    const debounce = (callback) => (wait) => {\n        clearTimeout(timer);\n        timer = setTimeout(callback, wait);\n    };\n    const _setValid = async (shouldUpdateValid) => {\n        if (!_options.disabled &&\n            (_proxyFormState.isValid ||\n                _proxySubscribeFormState.isValid ||\n                shouldUpdateValid)) {\n            const isValid = _options.resolver\n                ? isEmptyObject((await _runSchema()).errors)\n                : await executeBuiltInValidation(_fields, true);\n            if (isValid !== _formState.isValid) {\n                _subjects.state.next({\n                    isValid,\n                });\n            }\n        }\n    };\n    const _updateIsValidating = (names, isValidating) => {\n        if (!_options.disabled &&\n            (_proxyFormState.isValidating ||\n                _proxyFormState.validatingFields ||\n                _proxySubscribeFormState.isValidating ||\n                _proxySubscribeFormState.validatingFields)) {\n            (names || Array.from(_names.mount)).forEach((name) => {\n                if (name) {\n                    isValidating\n                        ? set(_formState.validatingFields, name, isValidating)\n                        : unset(_formState.validatingFields, name);\n                }\n            });\n            _subjects.state.next({\n                validatingFields: _formState.validatingFields,\n                isValidating: !isEmptyObject(_formState.validatingFields),\n            });\n        }\n    };\n    const _setFieldArray = (name, values = [], method, args, shouldSetValues = true, shouldUpdateFieldsAndState = true) => {\n        if (args && method && !_options.disabled) {\n            _state.action = true;\n            if (shouldUpdateFieldsAndState && Array.isArray(get(_fields, name))) {\n                const fieldValues = method(get(_fields, name), args.argA, args.argB);\n                shouldSetValues && set(_fields, name, fieldValues);\n            }\n            if (shouldUpdateFieldsAndState &&\n                Array.isArray(get(_formState.errors, name))) {\n                const errors = method(get(_formState.errors, name), args.argA, args.argB);\n                shouldSetValues && set(_formState.errors, name, errors);\n                unsetEmptyArray(_formState.errors, name);\n            }\n            if ((_proxyFormState.touchedFields ||\n                _proxySubscribeFormState.touchedFields) &&\n                shouldUpdateFieldsAndState &&\n                Array.isArray(get(_formState.touchedFields, name))) {\n                const touchedFields = method(get(_formState.touchedFields, name), args.argA, args.argB);\n                shouldSetValues && set(_formState.touchedFields, name, touchedFields);\n            }\n            if (_proxyFormState.dirtyFields || _proxySubscribeFormState.dirtyFields) {\n                _formState.dirtyFields = getDirtyFields(_defaultValues, _formValues);\n            }\n            _subjects.state.next({\n                name,\n                isDirty: _getDirty(name, values),\n                dirtyFields: _formState.dirtyFields,\n                errors: _formState.errors,\n                isValid: _formState.isValid,\n            });\n        }\n        else {\n            set(_formValues, name, values);\n        }\n    };\n    const updateErrors = (name, error) => {\n        set(_formState.errors, name, error);\n        _subjects.state.next({\n            errors: _formState.errors,\n        });\n    };\n    const _setErrors = (errors) => {\n        _formState.errors = errors;\n        _subjects.state.next({\n            errors: _formState.errors,\n            isValid: false,\n        });\n    };\n    const updateValidAndValue = (name, shouldSkipSetValueAs, value, ref) => {\n        const field = get(_fields, name);\n        if (field) {\n            const defaultValue = get(_formValues, name, isUndefined(value) ? get(_defaultValues, name) : value);\n            isUndefined(defaultValue) ||\n                (ref && ref.defaultChecked) ||\n                shouldSkipSetValueAs\n                ? set(_formValues, name, shouldSkipSetValueAs ? defaultValue : getFieldValue(field._f))\n                : setFieldValue(name, defaultValue);\n            _state.mount && _setValid();\n        }\n    };\n    const updateTouchAndDirty = (name, fieldValue, isBlurEvent, shouldDirty, shouldRender) => {\n        let shouldUpdateField = false;\n        let isPreviousDirty = false;\n        const output = {\n            name,\n        };\n        if (!_options.disabled) {\n            if (!isBlurEvent || shouldDirty) {\n                if (_proxyFormState.isDirty || _proxySubscribeFormState.isDirty) {\n                    isPreviousDirty = _formState.isDirty;\n                    _formState.isDirty = output.isDirty = _getDirty();\n                    shouldUpdateField = isPreviousDirty !== output.isDirty;\n                }\n                const isCurrentFieldPristine = deepEqual(get(_defaultValues, name), fieldValue);\n                isPreviousDirty = !!get(_formState.dirtyFields, name);\n                isCurrentFieldPristine\n                    ? unset(_formState.dirtyFields, name)\n                    : set(_formState.dirtyFields, name, true);\n                output.dirtyFields = _formState.dirtyFields;\n                shouldUpdateField =\n                    shouldUpdateField ||\n                        ((_proxyFormState.dirtyFields ||\n                            _proxySubscribeFormState.dirtyFields) &&\n                            isPreviousDirty !== !isCurrentFieldPristine);\n            }\n            if (isBlurEvent) {\n                const isPreviousFieldTouched = get(_formState.touchedFields, name);\n                if (!isPreviousFieldTouched) {\n                    set(_formState.touchedFields, name, isBlurEvent);\n                    output.touchedFields = _formState.touchedFields;\n                    shouldUpdateField =\n                        shouldUpdateField ||\n                            ((_proxyFormState.touchedFields ||\n                                _proxySubscribeFormState.touchedFields) &&\n                                isPreviousFieldTouched !== isBlurEvent);\n                }\n            }\n            shouldUpdateField && shouldRender && _subjects.state.next(output);\n        }\n        return shouldUpdateField ? output : {};\n    };\n    const shouldRenderByError = (name, isValid, error, fieldState) => {\n        const previousFieldError = get(_formState.errors, name);\n        const shouldUpdateValid = (_proxyFormState.isValid || _proxySubscribeFormState.isValid) &&\n            isBoolean(isValid) &&\n            _formState.isValid !== isValid;\n        if (_options.delayError && error) {\n            delayErrorCallback = debounce(() => updateErrors(name, error));\n            delayErrorCallback(_options.delayError);\n        }\n        else {\n            clearTimeout(timer);\n            delayErrorCallback = null;\n            error\n                ? set(_formState.errors, name, error)\n                : unset(_formState.errors, name);\n        }\n        if ((error ? !deepEqual(previousFieldError, error) : previousFieldError) ||\n            !isEmptyObject(fieldState) ||\n            shouldUpdateValid) {\n            const updatedFormState = {\n                ...fieldState,\n                ...(shouldUpdateValid && isBoolean(isValid) ? { isValid } : {}),\n                errors: _formState.errors,\n                name,\n            };\n            _formState = {\n                ..._formState,\n                ...updatedFormState,\n            };\n            _subjects.state.next(updatedFormState);\n        }\n    };\n    const _runSchema = async (name) => {\n        _updateIsValidating(name, true);\n        const result = await _options.resolver(_formValues, _options.context, getResolverOptions(name || _names.mount, _fields, _options.criteriaMode, _options.shouldUseNativeValidation));\n        _updateIsValidating(name);\n        return result;\n    };\n    const executeSchemaAndUpdateState = async (names) => {\n        const { errors } = await _runSchema(names);\n        if (names) {\n            for (const name of names) {\n                const error = get(errors, name);\n                error\n                    ? set(_formState.errors, name, error)\n                    : unset(_formState.errors, name);\n            }\n        }\n        else {\n            _formState.errors = errors;\n        }\n        return errors;\n    };\n    const executeBuiltInValidation = async (fields, shouldOnlyCheckValid, context = {\n        valid: true,\n    }) => {\n        for (const name in fields) {\n            const field = fields[name];\n            if (field) {\n                const { _f, ...fieldValue } = field;\n                if (_f) {\n                    const isFieldArrayRoot = _names.array.has(_f.name);\n                    const isPromiseFunction = field._f && hasPromiseValidation(field._f);\n                    if (isPromiseFunction && _proxyFormState.validatingFields) {\n                        _updateIsValidating([name], true);\n                    }\n                    const fieldError = await validateField(field, _names.disabled, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation && !shouldOnlyCheckValid, isFieldArrayRoot);\n                    if (isPromiseFunction && _proxyFormState.validatingFields) {\n                        _updateIsValidating([name]);\n                    }\n                    if (fieldError[_f.name]) {\n                        context.valid = false;\n                        if (shouldOnlyCheckValid) {\n                            break;\n                        }\n                    }\n                    !shouldOnlyCheckValid &&\n                        (get(fieldError, _f.name)\n                            ? isFieldArrayRoot\n                                ? updateFieldArrayRootError(_formState.errors, fieldError, _f.name)\n                                : set(_formState.errors, _f.name, fieldError[_f.name])\n                            : unset(_formState.errors, _f.name));\n                }\n                !isEmptyObject(fieldValue) &&\n                    (await executeBuiltInValidation(fieldValue, shouldOnlyCheckValid, context));\n            }\n        }\n        return context.valid;\n    };\n    const _removeUnmounted = () => {\n        for (const name of _names.unMount) {\n            const field = get(_fields, name);\n            field &&\n                (field._f.refs\n                    ? field._f.refs.every((ref) => !live(ref))\n                    : !live(field._f.ref)) &&\n                unregister(name);\n        }\n        _names.unMount = new Set();\n    };\n    const _getDirty = (name, data) => !_options.disabled &&\n        (name && data && set(_formValues, name, data),\n            !deepEqual(getValues(), _defaultValues));\n    const _getWatch = (names, defaultValue, isGlobal) => generateWatchOutput(names, _names, {\n        ...(_state.mount\n            ? _formValues\n            : isUndefined(defaultValue)\n                ? _defaultValues\n                : isString(names)\n                    ? { [names]: defaultValue }\n                    : defaultValue),\n    }, isGlobal, defaultValue);\n    const _getFieldArray = (name) => compact(get(_state.mount ? _formValues : _defaultValues, name, _options.shouldUnregister ? get(_defaultValues, name, []) : []));\n    const setFieldValue = (name, value, options = {}) => {\n        const field = get(_fields, name);\n        let fieldValue = value;\n        if (field) {\n            const fieldReference = field._f;\n            if (fieldReference) {\n                !fieldReference.disabled &&\n                    set(_formValues, name, getFieldValueAs(value, fieldReference));\n                fieldValue =\n                    isHTMLElement(fieldReference.ref) && isNullOrUndefined(value)\n                        ? ''\n                        : value;\n                if (isMultipleSelect(fieldReference.ref)) {\n                    [...fieldReference.ref.options].forEach((optionRef) => (optionRef.selected = fieldValue.includes(optionRef.value)));\n                }\n                else if (fieldReference.refs) {\n                    if (isCheckBoxInput(fieldReference.ref)) {\n                        fieldReference.refs.forEach((checkboxRef) => {\n                            if (!checkboxRef.defaultChecked || !checkboxRef.disabled) {\n                                if (Array.isArray(fieldValue)) {\n                                    checkboxRef.checked = !!fieldValue.find((data) => data === checkboxRef.value);\n                                }\n                                else {\n                                    checkboxRef.checked =\n                                        fieldValue === checkboxRef.value || !!fieldValue;\n                                }\n                            }\n                        });\n                    }\n                    else {\n                        fieldReference.refs.forEach((radioRef) => (radioRef.checked = radioRef.value === fieldValue));\n                    }\n                }\n                else if (isFileInput(fieldReference.ref)) {\n                    fieldReference.ref.value = '';\n                }\n                else {\n                    fieldReference.ref.value = fieldValue;\n                    if (!fieldReference.ref.type) {\n                        _subjects.state.next({\n                            name,\n                            values: cloneObject(_formValues),\n                        });\n                    }\n                }\n            }\n        }\n        (options.shouldDirty || options.shouldTouch) &&\n            updateTouchAndDirty(name, fieldValue, options.shouldTouch, options.shouldDirty, true);\n        options.shouldValidate && trigger(name);\n    };\n    const setValues = (name, value, options) => {\n        for (const fieldKey in value) {\n            if (!value.hasOwnProperty(fieldKey)) {\n                return;\n            }\n            const fieldValue = value[fieldKey];\n            const fieldName = name + '.' + fieldKey;\n            const field = get(_fields, fieldName);\n            (_names.array.has(name) ||\n                isObject(fieldValue) ||\n                (field && !field._f)) &&\n                !isDateObject(fieldValue)\n                ? setValues(fieldName, fieldValue, options)\n                : setFieldValue(fieldName, fieldValue, options);\n        }\n    };\n    const setValue = (name, value, options = {}) => {\n        const field = get(_fields, name);\n        const isFieldArray = _names.array.has(name);\n        const cloneValue = cloneObject(value);\n        set(_formValues, name, cloneValue);\n        if (isFieldArray) {\n            _subjects.array.next({\n                name,\n                values: cloneObject(_formValues),\n            });\n            if ((_proxyFormState.isDirty ||\n                _proxyFormState.dirtyFields ||\n                _proxySubscribeFormState.isDirty ||\n                _proxySubscribeFormState.dirtyFields) &&\n                options.shouldDirty) {\n                _subjects.state.next({\n                    name,\n                    dirtyFields: getDirtyFields(_defaultValues, _formValues),\n                    isDirty: _getDirty(name, cloneValue),\n                });\n            }\n        }\n        else {\n            field && !field._f && !isNullOrUndefined(cloneValue)\n                ? setValues(name, cloneValue, options)\n                : setFieldValue(name, cloneValue, options);\n        }\n        isWatched(name, _names) && _subjects.state.next({ ..._formState });\n        _subjects.state.next({\n            name: _state.mount ? name : undefined,\n            values: cloneObject(_formValues),\n        });\n    };\n    const onChange = async (event) => {\n        _state.mount = true;\n        const target = event.target;\n        let name = target.name;\n        let isFieldValueUpdated = true;\n        const field = get(_fields, name);\n        const _updateIsFieldValueUpdated = (fieldValue) => {\n            isFieldValueUpdated =\n                Number.isNaN(fieldValue) ||\n                    (isDateObject(fieldValue) && isNaN(fieldValue.getTime())) ||\n                    deepEqual(fieldValue, get(_formValues, name, fieldValue));\n        };\n        const validationModeBeforeSubmit = getValidationModes(_options.mode);\n        const validationModeAfterSubmit = getValidationModes(_options.reValidateMode);\n        if (field) {\n            let error;\n            let isValid;\n            const fieldValue = target.type\n                ? getFieldValue(field._f)\n                : getEventValue(event);\n            const isBlurEvent = event.type === EVENTS.BLUR || event.type === EVENTS.FOCUS_OUT;\n            const shouldSkipValidation = (!hasValidation(field._f) &&\n                !_options.resolver &&\n                !get(_formState.errors, name) &&\n                !field._f.deps) ||\n                skipValidation(isBlurEvent, get(_formState.touchedFields, name), _formState.isSubmitted, validationModeAfterSubmit, validationModeBeforeSubmit);\n            const watched = isWatched(name, _names, isBlurEvent);\n            set(_formValues, name, fieldValue);\n            if (isBlurEvent) {\n                field._f.onBlur && field._f.onBlur(event);\n                delayErrorCallback && delayErrorCallback(0);\n            }\n            else if (field._f.onChange) {\n                field._f.onChange(event);\n            }\n            const fieldState = updateTouchAndDirty(name, fieldValue, isBlurEvent);\n            const shouldRender = !isEmptyObject(fieldState) || watched;\n            !isBlurEvent &&\n                _subjects.state.next({\n                    name,\n                    type: event.type,\n                    values: cloneObject(_formValues),\n                });\n            if (shouldSkipValidation) {\n                if (_proxyFormState.isValid || _proxySubscribeFormState.isValid) {\n                    if (_options.mode === 'onBlur') {\n                        if (isBlurEvent) {\n                            _setValid();\n                        }\n                    }\n                    else if (!isBlurEvent) {\n                        _setValid();\n                    }\n                }\n                return (shouldRender &&\n                    _subjects.state.next({ name, ...(watched ? {} : fieldState) }));\n            }\n            !isBlurEvent && watched && _subjects.state.next({ ..._formState });\n            if (_options.resolver) {\n                const { errors } = await _runSchema([name]);\n                _updateIsFieldValueUpdated(fieldValue);\n                if (isFieldValueUpdated) {\n                    const previousErrorLookupResult = schemaErrorLookup(_formState.errors, _fields, name);\n                    const errorLookupResult = schemaErrorLookup(errors, _fields, previousErrorLookupResult.name || name);\n                    error = errorLookupResult.error;\n                    name = errorLookupResult.name;\n                    isValid = isEmptyObject(errors);\n                }\n            }\n            else {\n                _updateIsValidating([name], true);\n                error = (await validateField(field, _names.disabled, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation))[name];\n                _updateIsValidating([name]);\n                _updateIsFieldValueUpdated(fieldValue);\n                if (isFieldValueUpdated) {\n                    if (error) {\n                        isValid = false;\n                    }\n                    else if (_proxyFormState.isValid ||\n                        _proxySubscribeFormState.isValid) {\n                        isValid = await executeBuiltInValidation(_fields, true);\n                    }\n                }\n            }\n            if (isFieldValueUpdated) {\n                field._f.deps &&\n                    trigger(field._f.deps);\n                shouldRenderByError(name, isValid, error, fieldState);\n            }\n        }\n    };\n    const _focusInput = (ref, key) => {\n        if (get(_formState.errors, key) && ref.focus) {\n            ref.focus();\n            return 1;\n        }\n        return;\n    };\n    const trigger = async (name, options = {}) => {\n        let isValid;\n        let validationResult;\n        const fieldNames = convertToArrayPayload(name);\n        if (_options.resolver) {\n            const errors = await executeSchemaAndUpdateState(isUndefined(name) ? name : fieldNames);\n            isValid = isEmptyObject(errors);\n            validationResult = name\n                ? !fieldNames.some((name) => get(errors, name))\n                : isValid;\n        }\n        else if (name) {\n            validationResult = (await Promise.all(fieldNames.map(async (fieldName) => {\n                const field = get(_fields, fieldName);\n                return await executeBuiltInValidation(field && field._f ? { [fieldName]: field } : field);\n            }))).every(Boolean);\n            !(!validationResult && !_formState.isValid) && _setValid();\n        }\n        else {\n            validationResult = isValid = await executeBuiltInValidation(_fields);\n        }\n        _subjects.state.next({\n            ...(!isString(name) ||\n                ((_proxyFormState.isValid || _proxySubscribeFormState.isValid) &&\n                    isValid !== _formState.isValid)\n                ? {}\n                : { name }),\n            ...(_options.resolver || !name ? { isValid } : {}),\n            errors: _formState.errors,\n        });\n        options.shouldFocus &&\n            !validationResult &&\n            iterateFieldsByAction(_fields, _focusInput, name ? fieldNames : _names.mount);\n        return validationResult;\n    };\n    const getValues = (fieldNames) => {\n        const values = {\n            ...(_state.mount ? _formValues : _defaultValues),\n        };\n        return isUndefined(fieldNames)\n            ? values\n            : isString(fieldNames)\n                ? get(values, fieldNames)\n                : fieldNames.map((name) => get(values, name));\n    };\n    const getFieldState = (name, formState) => ({\n        invalid: !!get((formState || _formState).errors, name),\n        isDirty: !!get((formState || _formState).dirtyFields, name),\n        error: get((formState || _formState).errors, name),\n        isValidating: !!get(_formState.validatingFields, name),\n        isTouched: !!get((formState || _formState).touchedFields, name),\n    });\n    const clearErrors = (name) => {\n        name &&\n            convertToArrayPayload(name).forEach((inputName) => unset(_formState.errors, inputName));\n        _subjects.state.next({\n            errors: name ? _formState.errors : {},\n        });\n    };\n    const setError = (name, error, options) => {\n        const ref = (get(_fields, name, { _f: {} })._f || {}).ref;\n        const currentError = get(_formState.errors, name) || {};\n        // Don't override existing error messages elsewhere in the object tree.\n        const { ref: currentRef, message, type, ...restOfErrorTree } = currentError;\n        set(_formState.errors, name, {\n            ...restOfErrorTree,\n            ...error,\n            ref,\n        });\n        _subjects.state.next({\n            name,\n            errors: _formState.errors,\n            isValid: false,\n        });\n        options && options.shouldFocus && ref && ref.focus && ref.focus();\n    };\n    const watch = (name, defaultValue) => isFunction(name)\n        ? _subjects.state.subscribe({\n            next: (payload) => name(_getWatch(undefined, defaultValue), payload),\n        })\n        : _getWatch(name, defaultValue, true);\n    const _subscribe = (props) => _subjects.state.subscribe({\n        next: (formState) => {\n            if (shouldSubscribeByName(props.name, formState.name, props.exact) &&\n                shouldRenderFormState(formState, props.formState || _proxyFormState, _setFormState, props.reRenderRoot)) {\n                props.callback({\n                    values: { ..._formValues },\n                    ..._formState,\n                    ...formState,\n                });\n            }\n        },\n    }).unsubscribe;\n    const subscribe = (props) => {\n        _state.mount = true;\n        _proxySubscribeFormState = {\n            ..._proxySubscribeFormState,\n            ...props.formState,\n        };\n        return _subscribe({\n            ...props,\n            formState: _proxySubscribeFormState,\n        });\n    };\n    const unregister = (name, options = {}) => {\n        for (const fieldName of name ? convertToArrayPayload(name) : _names.mount) {\n            _names.mount.delete(fieldName);\n            _names.array.delete(fieldName);\n            if (!options.keepValue) {\n                unset(_fields, fieldName);\n                unset(_formValues, fieldName);\n            }\n            !options.keepError && unset(_formState.errors, fieldName);\n            !options.keepDirty && unset(_formState.dirtyFields, fieldName);\n            !options.keepTouched && unset(_formState.touchedFields, fieldName);\n            !options.keepIsValidating &&\n                unset(_formState.validatingFields, fieldName);\n            !_options.shouldUnregister &&\n                !options.keepDefaultValue &&\n                unset(_defaultValues, fieldName);\n        }\n        _subjects.state.next({\n            values: cloneObject(_formValues),\n        });\n        _subjects.state.next({\n            ..._formState,\n            ...(!options.keepDirty ? {} : { isDirty: _getDirty() }),\n        });\n        !options.keepIsValid && _setValid();\n    };\n    const _setDisabledField = ({ disabled, name, }) => {\n        if ((isBoolean(disabled) && _state.mount) ||\n            !!disabled ||\n            _names.disabled.has(name)) {\n            disabled ? _names.disabled.add(name) : _names.disabled.delete(name);\n        }\n    };\n    const register = (name, options = {}) => {\n        let field = get(_fields, name);\n        const disabledIsDefined = isBoolean(options.disabled) || isBoolean(_options.disabled);\n        set(_fields, name, {\n            ...(field || {}),\n            _f: {\n                ...(field && field._f ? field._f : { ref: { name } }),\n                name,\n                mount: true,\n                ...options,\n            },\n        });\n        _names.mount.add(name);\n        if (field) {\n            _setDisabledField({\n                disabled: isBoolean(options.disabled)\n                    ? options.disabled\n                    : _options.disabled,\n                name,\n            });\n        }\n        else {\n            updateValidAndValue(name, true, options.value);\n        }\n        return {\n            ...(disabledIsDefined\n                ? { disabled: options.disabled || _options.disabled }\n                : {}),\n            ...(_options.progressive\n                ? {\n                    required: !!options.required,\n                    min: getRuleValue(options.min),\n                    max: getRuleValue(options.max),\n                    minLength: getRuleValue(options.minLength),\n                    maxLength: getRuleValue(options.maxLength),\n                    pattern: getRuleValue(options.pattern),\n                }\n                : {}),\n            name,\n            onChange,\n            onBlur: onChange,\n            ref: (ref) => {\n                if (ref) {\n                    register(name, options);\n                    field = get(_fields, name);\n                    const fieldRef = isUndefined(ref.value)\n                        ? ref.querySelectorAll\n                            ? ref.querySelectorAll('input,select,textarea')[0] || ref\n                            : ref\n                        : ref;\n                    const radioOrCheckbox = isRadioOrCheckbox(fieldRef);\n                    const refs = field._f.refs || [];\n                    if (radioOrCheckbox\n                        ? refs.find((option) => option === fieldRef)\n                        : fieldRef === field._f.ref) {\n                        return;\n                    }\n                    set(_fields, name, {\n                        _f: {\n                            ...field._f,\n                            ...(radioOrCheckbox\n                                ? {\n                                    refs: [\n                                        ...refs.filter(live),\n                                        fieldRef,\n                                        ...(Array.isArray(get(_defaultValues, name)) ? [{}] : []),\n                                    ],\n                                    ref: { type: fieldRef.type, name },\n                                }\n                                : { ref: fieldRef }),\n                        },\n                    });\n                    updateValidAndValue(name, false, undefined, fieldRef);\n                }\n                else {\n                    field = get(_fields, name, {});\n                    if (field._f) {\n                        field._f.mount = false;\n                    }\n                    (_options.shouldUnregister || options.shouldUnregister) &&\n                        !(isNameInFieldArray(_names.array, name) && _state.action) &&\n                        _names.unMount.add(name);\n                }\n            },\n        };\n    };\n    const _focusError = () => _options.shouldFocusError &&\n        iterateFieldsByAction(_fields, _focusInput, _names.mount);\n    const _disableForm = (disabled) => {\n        if (isBoolean(disabled)) {\n            _subjects.state.next({ disabled });\n            iterateFieldsByAction(_fields, (ref, name) => {\n                const currentField = get(_fields, name);\n                if (currentField) {\n                    ref.disabled = currentField._f.disabled || disabled;\n                    if (Array.isArray(currentField._f.refs)) {\n                        currentField._f.refs.forEach((inputRef) => {\n                            inputRef.disabled = currentField._f.disabled || disabled;\n                        });\n                    }\n                }\n            }, 0, false);\n        }\n    };\n    const handleSubmit = (onValid, onInvalid) => async (e) => {\n        let onValidError = undefined;\n        if (e) {\n            e.preventDefault && e.preventDefault();\n            e.persist &&\n                e.persist();\n        }\n        let fieldValues = cloneObject(_formValues);\n        _subjects.state.next({\n            isSubmitting: true,\n        });\n        if (_options.resolver) {\n            const { errors, values } = await _runSchema();\n            _formState.errors = errors;\n            fieldValues = cloneObject(values);\n        }\n        else {\n            await executeBuiltInValidation(_fields);\n        }\n        if (_names.disabled.size) {\n            for (const name of _names.disabled) {\n                unset(fieldValues, name);\n            }\n        }\n        unset(_formState.errors, 'root');\n        if (isEmptyObject(_formState.errors)) {\n            _subjects.state.next({\n                errors: {},\n            });\n            try {\n                await onValid(fieldValues, e);\n            }\n            catch (error) {\n                onValidError = error;\n            }\n        }\n        else {\n            if (onInvalid) {\n                await onInvalid({ ..._formState.errors }, e);\n            }\n            _focusError();\n            setTimeout(_focusError);\n        }\n        _subjects.state.next({\n            isSubmitted: true,\n            isSubmitting: false,\n            isSubmitSuccessful: isEmptyObject(_formState.errors) && !onValidError,\n            submitCount: _formState.submitCount + 1,\n            errors: _formState.errors,\n        });\n        if (onValidError) {\n            throw onValidError;\n        }\n    };\n    const resetField = (name, options = {}) => {\n        if (get(_fields, name)) {\n            if (isUndefined(options.defaultValue)) {\n                setValue(name, cloneObject(get(_defaultValues, name)));\n            }\n            else {\n                setValue(name, options.defaultValue);\n                set(_defaultValues, name, cloneObject(options.defaultValue));\n            }\n            if (!options.keepTouched) {\n                unset(_formState.touchedFields, name);\n            }\n            if (!options.keepDirty) {\n                unset(_formState.dirtyFields, name);\n                _formState.isDirty = options.defaultValue\n                    ? _getDirty(name, cloneObject(get(_defaultValues, name)))\n                    : _getDirty();\n            }\n            if (!options.keepError) {\n                unset(_formState.errors, name);\n                _proxyFormState.isValid && _setValid();\n            }\n            _subjects.state.next({ ..._formState });\n        }\n    };\n    const _reset = (formValues, keepStateOptions = {}) => {\n        const updatedValues = formValues ? cloneObject(formValues) : _defaultValues;\n        const cloneUpdatedValues = cloneObject(updatedValues);\n        const isEmptyResetValues = isEmptyObject(formValues);\n        const values = isEmptyResetValues ? _defaultValues : cloneUpdatedValues;\n        if (!keepStateOptions.keepDefaultValues) {\n            _defaultValues = updatedValues;\n        }\n        if (!keepStateOptions.keepValues) {\n            if (keepStateOptions.keepDirtyValues) {\n                const fieldsToCheck = new Set([\n                    ..._names.mount,\n                    ...Object.keys(getDirtyFields(_defaultValues, _formValues)),\n                ]);\n                for (const fieldName of Array.from(fieldsToCheck)) {\n                    get(_formState.dirtyFields, fieldName)\n                        ? set(values, fieldName, get(_formValues, fieldName))\n                        : setValue(fieldName, get(values, fieldName));\n                }\n            }\n            else {\n                if (isWeb && isUndefined(formValues)) {\n                    for (const name of _names.mount) {\n                        const field = get(_fields, name);\n                        if (field && field._f) {\n                            const fieldReference = Array.isArray(field._f.refs)\n                                ? field._f.refs[0]\n                                : field._f.ref;\n                            if (isHTMLElement(fieldReference)) {\n                                const form = fieldReference.closest('form');\n                                if (form) {\n                                    form.reset();\n                                    break;\n                                }\n                            }\n                        }\n                    }\n                }\n                if (keepStateOptions.keepFieldsRef) {\n                    for (const fieldName of _names.mount) {\n                        setValue(fieldName, get(values, fieldName));\n                    }\n                }\n                else {\n                    _fields = {};\n                }\n            }\n            _formValues = _options.shouldUnregister\n                ? keepStateOptions.keepDefaultValues\n                    ? cloneObject(_defaultValues)\n                    : {}\n                : cloneObject(values);\n            _subjects.array.next({\n                values: { ...values },\n            });\n            _subjects.state.next({\n                values: { ...values },\n            });\n        }\n        _names = {\n            mount: keepStateOptions.keepDirtyValues ? _names.mount : new Set(),\n            unMount: new Set(),\n            array: new Set(),\n            disabled: new Set(),\n            watch: new Set(),\n            watchAll: false,\n            focus: '',\n        };\n        _state.mount =\n            !_proxyFormState.isValid ||\n                !!keepStateOptions.keepIsValid ||\n                !!keepStateOptions.keepDirtyValues;\n        _state.watch = !!_options.shouldUnregister;\n        _subjects.state.next({\n            submitCount: keepStateOptions.keepSubmitCount\n                ? _formState.submitCount\n                : 0,\n            isDirty: isEmptyResetValues\n                ? false\n                : keepStateOptions.keepDirty\n                    ? _formState.isDirty\n                    : !!(keepStateOptions.keepDefaultValues &&\n                        !deepEqual(formValues, _defaultValues)),\n            isSubmitted: keepStateOptions.keepIsSubmitted\n                ? _formState.isSubmitted\n                : false,\n            dirtyFields: isEmptyResetValues\n                ? {}\n                : keepStateOptions.keepDirtyValues\n                    ? keepStateOptions.keepDefaultValues && _formValues\n                        ? getDirtyFields(_defaultValues, _formValues)\n                        : _formState.dirtyFields\n                    : keepStateOptions.keepDefaultValues && formValues\n                        ? getDirtyFields(_defaultValues, formValues)\n                        : keepStateOptions.keepDirty\n                            ? _formState.dirtyFields\n                            : {},\n            touchedFields: keepStateOptions.keepTouched\n                ? _formState.touchedFields\n                : {},\n            errors: keepStateOptions.keepErrors ? _formState.errors : {},\n            isSubmitSuccessful: keepStateOptions.keepIsSubmitSuccessful\n                ? _formState.isSubmitSuccessful\n                : false,\n            isSubmitting: false,\n        });\n    };\n    const reset = (formValues, keepStateOptions) => _reset(isFunction(formValues)\n        ? formValues(_formValues)\n        : formValues, keepStateOptions);\n    const setFocus = (name, options = {}) => {\n        const field = get(_fields, name);\n        const fieldReference = field && field._f;\n        if (fieldReference) {\n            const fieldRef = fieldReference.refs\n                ? fieldReference.refs[0]\n                : fieldReference.ref;\n            if (fieldRef.focus) {\n                fieldRef.focus();\n                options.shouldSelect &&\n                    isFunction(fieldRef.select) &&\n                    fieldRef.select();\n            }\n        }\n    };\n    const _setFormState = (updatedFormState) => {\n        _formState = {\n            ..._formState,\n            ...updatedFormState,\n        };\n    };\n    const _resetDefaultValues = () => isFunction(_options.defaultValues) &&\n        _options.defaultValues().then((values) => {\n            reset(values, _options.resetOptions);\n            _subjects.state.next({\n                isLoading: false,\n            });\n        });\n    const methods = {\n        control: {\n            register,\n            unregister,\n            getFieldState,\n            handleSubmit,\n            setError,\n            _subscribe,\n            _runSchema,\n            _focusError,\n            _getWatch,\n            _getDirty,\n            _setValid,\n            _setFieldArray,\n            _setDisabledField,\n            _setErrors,\n            _getFieldArray,\n            _reset,\n            _resetDefaultValues,\n            _removeUnmounted,\n            _disableForm,\n            _subjects,\n            _proxyFormState,\n            get _fields() {\n                return _fields;\n            },\n            get _formValues() {\n                return _formValues;\n            },\n            get _state() {\n                return _state;\n            },\n            set _state(value) {\n                _state = value;\n            },\n            get _defaultValues() {\n                return _defaultValues;\n            },\n            get _names() {\n                return _names;\n            },\n            set _names(value) {\n                _names = value;\n            },\n            get _formState() {\n                return _formState;\n            },\n            get _options() {\n                return _options;\n            },\n            set _options(value) {\n                _options = {\n                    ..._options,\n                    ...value,\n                };\n            },\n        },\n        subscribe,\n        trigger,\n        register,\n        handleSubmit,\n        watch,\n        setValue,\n        getValues,\n        reset,\n        resetField,\n        clearErrors,\n        unregister,\n        setError,\n        setFocus,\n        getFieldState,\n    };\n    return {\n        ...methods,\n        formControl: methods,\n    };\n}\n\nvar generateId = () => {\n    if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n        return crypto.randomUUID();\n    }\n    const d = typeof performance === 'undefined' ? Date.now() : performance.now() * 1000;\n    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n        const r = (Math.random() * 16 + d) % 16 | 0;\n        return (c == 'x' ? r : (r & 0x3) | 0x8).toString(16);\n    });\n};\n\nvar getFocusFieldName = (name, index, options = {}) => options.shouldFocus || isUndefined(options.shouldFocus)\n    ? options.focusName ||\n        `${name}.${isUndefined(options.focusIndex) ? index : options.focusIndex}.`\n    : '';\n\nvar appendAt = (data, value) => [\n    ...data,\n    ...convertToArrayPayload(value),\n];\n\nvar fillEmptyArray = (value) => Array.isArray(value) ? value.map(() => undefined) : undefined;\n\nfunction insert(data, index, value) {\n    return [\n        ...data.slice(0, index),\n        ...convertToArrayPayload(value),\n        ...data.slice(index),\n    ];\n}\n\nvar moveArrayAt = (data, from, to) => {\n    if (!Array.isArray(data)) {\n        return [];\n    }\n    if (isUndefined(data[to])) {\n        data[to] = undefined;\n    }\n    data.splice(to, 0, data.splice(from, 1)[0]);\n    return data;\n};\n\nvar prependAt = (data, value) => [\n    ...convertToArrayPayload(value),\n    ...convertToArrayPayload(data),\n];\n\nfunction removeAtIndexes(data, indexes) {\n    let i = 0;\n    const temp = [...data];\n    for (const index of indexes) {\n        temp.splice(index - i, 1);\n        i++;\n    }\n    return compact(temp).length ? temp : [];\n}\nvar removeArrayAt = (data, index) => isUndefined(index)\n    ? []\n    : removeAtIndexes(data, convertToArrayPayload(index).sort((a, b) => a - b));\n\nvar swapArrayAt = (data, indexA, indexB) => {\n    [data[indexA], data[indexB]] = [data[indexB], data[indexA]];\n};\n\nvar updateAt = (fieldValues, index, value) => {\n    fieldValues[index] = value;\n    return fieldValues;\n};\n\n/**\n * A custom hook that exposes convenient methods to perform operations with a list of dynamic inputs that need to be appended, updated, removed etc. • [Demo](https://codesandbox.io/s/react-hook-form-usefieldarray-ssugn) • [Video](https://youtu.be/4MrbfGSFY2A)\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usefieldarray) • [Demo](https://codesandbox.io/s/react-hook-form-usefieldarray-ssugn)\n *\n * @param props - useFieldArray props\n *\n * @returns methods - functions to manipulate with the Field Arrays (dynamic inputs) {@link UseFieldArrayReturn}\n *\n * @example\n * ```tsx\n * function App() {\n *   const { register, control, handleSubmit, reset, trigger, setError } = useForm({\n *     defaultValues: {\n *       test: []\n *     }\n *   });\n *   const { fields, append } = useFieldArray({\n *     control,\n *     name: \"test\"\n *   });\n *\n *   return (\n *     <form onSubmit={handleSubmit(data => console.log(data))}>\n *       {fields.map((item, index) => (\n *          <input key={item.id} {...register(`test.${index}.firstName`)}  />\n *       ))}\n *       <button type=\"button\" onClick={() => append({ firstName: \"bill\" })}>\n *         append\n *       </button>\n *       <input type=\"submit\" />\n *     </form>\n *   );\n * }\n * ```\n */\nfunction useFieldArray(props) {\n    const methods = useFormContext();\n    const { control = methods.control, name, keyName = 'id', shouldUnregister, rules, } = props;\n    const [fields, setFields] = React__default.useState(control._getFieldArray(name));\n    const ids = React__default.useRef(control._getFieldArray(name).map(generateId));\n    const _fieldIds = React__default.useRef(fields);\n    const _name = React__default.useRef(name);\n    const _actioned = React__default.useRef(false);\n    _name.current = name;\n    _fieldIds.current = fields;\n    control._names.array.add(name);\n    rules &&\n        control.register(name, rules);\n    useIsomorphicLayoutEffect(() => control._subjects.array.subscribe({\n        next: ({ values, name: fieldArrayName, }) => {\n            if (fieldArrayName === _name.current || !fieldArrayName) {\n                const fieldValues = get(values, _name.current);\n                if (Array.isArray(fieldValues)) {\n                    setFields(fieldValues);\n                    ids.current = fieldValues.map(generateId);\n                }\n            }\n        },\n    }).unsubscribe, [control]);\n    const updateValues = React__default.useCallback((updatedFieldArrayValues) => {\n        _actioned.current = true;\n        control._setFieldArray(name, updatedFieldArrayValues);\n    }, [control, name]);\n    const append = (value, options) => {\n        const appendValue = convertToArrayPayload(cloneObject(value));\n        const updatedFieldArrayValues = appendAt(control._getFieldArray(name), appendValue);\n        control._names.focus = getFocusFieldName(name, updatedFieldArrayValues.length - 1, options);\n        ids.current = appendAt(ids.current, appendValue.map(generateId));\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        control._setFieldArray(name, updatedFieldArrayValues, appendAt, {\n            argA: fillEmptyArray(value),\n        });\n    };\n    const prepend = (value, options) => {\n        const prependValue = convertToArrayPayload(cloneObject(value));\n        const updatedFieldArrayValues = prependAt(control._getFieldArray(name), prependValue);\n        control._names.focus = getFocusFieldName(name, 0, options);\n        ids.current = prependAt(ids.current, prependValue.map(generateId));\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        control._setFieldArray(name, updatedFieldArrayValues, prependAt, {\n            argA: fillEmptyArray(value),\n        });\n    };\n    const remove = (index) => {\n        const updatedFieldArrayValues = removeArrayAt(control._getFieldArray(name), index);\n        ids.current = removeArrayAt(ids.current, index);\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        !Array.isArray(get(control._fields, name)) &&\n            set(control._fields, name, undefined);\n        control._setFieldArray(name, updatedFieldArrayValues, removeArrayAt, {\n            argA: index,\n        });\n    };\n    const insert$1 = (index, value, options) => {\n        const insertValue = convertToArrayPayload(cloneObject(value));\n        const updatedFieldArrayValues = insert(control._getFieldArray(name), index, insertValue);\n        control._names.focus = getFocusFieldName(name, index, options);\n        ids.current = insert(ids.current, index, insertValue.map(generateId));\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        control._setFieldArray(name, updatedFieldArrayValues, insert, {\n            argA: index,\n            argB: fillEmptyArray(value),\n        });\n    };\n    const swap = (indexA, indexB) => {\n        const updatedFieldArrayValues = control._getFieldArray(name);\n        swapArrayAt(updatedFieldArrayValues, indexA, indexB);\n        swapArrayAt(ids.current, indexA, indexB);\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        control._setFieldArray(name, updatedFieldArrayValues, swapArrayAt, {\n            argA: indexA,\n            argB: indexB,\n        }, false);\n    };\n    const move = (from, to) => {\n        const updatedFieldArrayValues = control._getFieldArray(name);\n        moveArrayAt(updatedFieldArrayValues, from, to);\n        moveArrayAt(ids.current, from, to);\n        updateValues(updatedFieldArrayValues);\n        setFields(updatedFieldArrayValues);\n        control._setFieldArray(name, updatedFieldArrayValues, moveArrayAt, {\n            argA: from,\n            argB: to,\n        }, false);\n    };\n    const update = (index, value) => {\n        const updateValue = cloneObject(value);\n        const updatedFieldArrayValues = updateAt(control._getFieldArray(name), index, updateValue);\n        ids.current = [...updatedFieldArrayValues].map((item, i) => !item || i === index ? generateId() : ids.current[i]);\n        updateValues(updatedFieldArrayValues);\n        setFields([...updatedFieldArrayValues]);\n        control._setFieldArray(name, updatedFieldArrayValues, updateAt, {\n            argA: index,\n            argB: updateValue,\n        }, true, false);\n    };\n    const replace = (value) => {\n        const updatedFieldArrayValues = convertToArrayPayload(cloneObject(value));\n        ids.current = updatedFieldArrayValues.map(generateId);\n        updateValues([...updatedFieldArrayValues]);\n        setFields([...updatedFieldArrayValues]);\n        control._setFieldArray(name, [...updatedFieldArrayValues], (data) => data, {}, true, false);\n    };\n    React__default.useEffect(() => {\n        control._state.action = false;\n        isWatched(name, control._names) &&\n            control._subjects.state.next({\n                ...control._formState,\n            });\n        if (_actioned.current &&\n            (!getValidationModes(control._options.mode).isOnSubmit ||\n                control._formState.isSubmitted) &&\n            !getValidationModes(control._options.reValidateMode).isOnSubmit) {\n            if (control._options.resolver) {\n                control._runSchema([name]).then((result) => {\n                    const error = get(result.errors, name);\n                    const existingError = get(control._formState.errors, name);\n                    if (existingError\n                        ? (!error && existingError.type) ||\n                            (error &&\n                                (existingError.type !== error.type ||\n                                    existingError.message !== error.message))\n                        : error && error.type) {\n                        error\n                            ? set(control._formState.errors, name, error)\n                            : unset(control._formState.errors, name);\n                        control._subjects.state.next({\n                            errors: control._formState.errors,\n                        });\n                    }\n                });\n            }\n            else {\n                const field = get(control._fields, name);\n                if (field &&\n                    field._f &&\n                    !(getValidationModes(control._options.reValidateMode).isOnSubmit &&\n                        getValidationModes(control._options.mode).isOnSubmit)) {\n                    validateField(field, control._names.disabled, control._formValues, control._options.criteriaMode === VALIDATION_MODE.all, control._options.shouldUseNativeValidation, true).then((error) => !isEmptyObject(error) &&\n                        control._subjects.state.next({\n                            errors: updateFieldArrayRootError(control._formState.errors, error, name),\n                        }));\n                }\n            }\n        }\n        control._subjects.state.next({\n            name,\n            values: cloneObject(control._formValues),\n        });\n        control._names.focus &&\n            iterateFieldsByAction(control._fields, (ref, key) => {\n                if (control._names.focus &&\n                    key.startsWith(control._names.focus) &&\n                    ref.focus) {\n                    ref.focus();\n                    return 1;\n                }\n                return;\n            });\n        control._names.focus = '';\n        control._setValid();\n        _actioned.current = false;\n    }, [fields, name, control]);\n    React__default.useEffect(() => {\n        !get(control._formValues, name) && control._setFieldArray(name);\n        return () => {\n            const updateMounted = (name, value) => {\n                const field = get(control._fields, name);\n                if (field && field._f) {\n                    field._f.mount = value;\n                }\n            };\n            control._options.shouldUnregister || shouldUnregister\n                ? control.unregister(name)\n                : updateMounted(name, false);\n        };\n    }, [name, control, keyName, shouldUnregister]);\n    return {\n        swap: React__default.useCallback(swap, [updateValues, name, control]),\n        move: React__default.useCallback(move, [updateValues, name, control]),\n        prepend: React__default.useCallback(prepend, [updateValues, name, control]),\n        append: React__default.useCallback(append, [updateValues, name, control]),\n        remove: React__default.useCallback(remove, [updateValues, name, control]),\n        insert: React__default.useCallback(insert$1, [updateValues, name, control]),\n        update: React__default.useCallback(update, [updateValues, name, control]),\n        replace: React__default.useCallback(replace, [updateValues, name, control]),\n        fields: React__default.useMemo(() => fields.map((field, index) => ({\n            ...field,\n            [keyName]: ids.current[index] || generateId(),\n        })), [fields, keyName]),\n    };\n}\n\n/**\n * Custom hook to manage the entire form.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useform) • [Demo](https://codesandbox.io/s/react-hook-form-get-started-ts-5ksmm) • [Video](https://www.youtube.com/watch?v=RkXv4AXXC_4)\n *\n * @param props - form configuration and validation parameters.\n *\n * @returns methods - individual functions to manage the form state. {@link UseFormReturn}\n *\n * @example\n * ```tsx\n * function App() {\n *   const { register, handleSubmit, watch, formState: { errors } } = useForm();\n *   const onSubmit = data => console.log(data);\n *\n *   console.log(watch(\"example\"));\n *\n *   return (\n *     <form onSubmit={handleSubmit(onSubmit)}>\n *       <input defaultValue=\"test\" {...register(\"example\")} />\n *       <input {...register(\"exampleRequired\", { required: true })} />\n *       {errors.exampleRequired && <span>This field is required</span>}\n *       <button>Submit</button>\n *     </form>\n *   );\n * }\n * ```\n */\nfunction useForm(props = {}) {\n    const _formControl = React__default.useRef(undefined);\n    const _values = React__default.useRef(undefined);\n    const [formState, updateFormState] = React__default.useState({\n        isDirty: false,\n        isValidating: false,\n        isLoading: isFunction(props.defaultValues),\n        isSubmitted: false,\n        isSubmitting: false,\n        isSubmitSuccessful: false,\n        isValid: false,\n        submitCount: 0,\n        dirtyFields: {},\n        touchedFields: {},\n        validatingFields: {},\n        errors: props.errors || {},\n        disabled: props.disabled || false,\n        isReady: false,\n        defaultValues: isFunction(props.defaultValues)\n            ? undefined\n            : props.defaultValues,\n    });\n    if (!_formControl.current) {\n        if (props.formControl) {\n            _formControl.current = {\n                ...props.formControl,\n                formState,\n            };\n            if (props.defaultValues && !isFunction(props.defaultValues)) {\n                props.formControl.reset(props.defaultValues, props.resetOptions);\n            }\n        }\n        else {\n            const { formControl, ...rest } = createFormControl(props);\n            _formControl.current = {\n                ...rest,\n                formState,\n            };\n        }\n    }\n    const control = _formControl.current.control;\n    control._options = props;\n    useIsomorphicLayoutEffect(() => {\n        const sub = control._subscribe({\n            formState: control._proxyFormState,\n            callback: () => updateFormState({ ...control._formState }),\n            reRenderRoot: true,\n        });\n        updateFormState((data) => ({\n            ...data,\n            isReady: true,\n        }));\n        control._formState.isReady = true;\n        return sub;\n    }, [control]);\n    React__default.useEffect(() => control._disableForm(props.disabled), [control, props.disabled]);\n    React__default.useEffect(() => {\n        if (props.mode) {\n            control._options.mode = props.mode;\n        }\n        if (props.reValidateMode) {\n            control._options.reValidateMode = props.reValidateMode;\n        }\n    }, [control, props.mode, props.reValidateMode]);\n    React__default.useEffect(() => {\n        if (props.errors) {\n            control._setErrors(props.errors);\n            control._focusError();\n        }\n    }, [control, props.errors]);\n    React__default.useEffect(() => {\n        props.shouldUnregister &&\n            control._subjects.state.next({\n                values: control._getWatch(),\n            });\n    }, [control, props.shouldUnregister]);\n    React__default.useEffect(() => {\n        if (control._proxyFormState.isDirty) {\n            const isDirty = control._getDirty();\n            if (isDirty !== formState.isDirty) {\n                control._subjects.state.next({\n                    isDirty,\n                });\n            }\n        }\n    }, [control, formState.isDirty]);\n    React__default.useEffect(() => {\n        if (props.values && !deepEqual(props.values, _values.current)) {\n            control._reset(props.values, {\n                keepFieldsRef: true,\n                ...control._options.resetOptions,\n            });\n            _values.current = props.values;\n            updateFormState((state) => ({ ...state }));\n        }\n        else {\n            control._resetDefaultValues();\n        }\n    }, [control, props.values]);\n    React__default.useEffect(() => {\n        if (!control._state.mount) {\n            control._setValid();\n            control._state.mount = true;\n        }\n        if (control._state.watch) {\n            control._state.watch = false;\n            control._subjects.state.next({ ...control._formState });\n        }\n        control._removeUnmounted();\n    });\n    _formControl.current.formState = getProxyFormState(formState, control);\n    return _formControl.current;\n}\n\nexport { Controller, Form, FormProvider, appendErrors, createFormControl, get, set, useController, useFieldArray, useForm, useFormContext, useFormState, useWatch };\n//# sourceMappingURL=index.esm.mjs.map\n",
    "'use client'\n\nimport * as React from 'react'\nimport * as LabelPrimitive from '@radix-ui/react-label'\n\nimport { cn } from '@/lib/utils'\n\nfunction Label({\n  className,\n  ...props\n}: React.ComponentProps<typeof LabelPrimitive.Root>) {\n  return (\n    <LabelPrimitive.Root\n      data-slot=\"label\"\n      className={cn(\n        'flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Label }\n",
    "import * as React from 'react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Input({ className, type, ...props }: React.ComponentProps<'input'>) {\n  return (\n    <input\n      type={type}\n      data-slot=\"input\"\n      className={cn(\n        'file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm',\n        'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]',\n        'aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Input }\n",
    "import * as React from 'react'\nimport * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area'\n\nimport { cn } from '@/lib/utils'\n\nfunction ScrollArea({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.Root>) {\n  return (\n    <ScrollAreaPrimitive.Root\n      data-slot=\"scroll-area\"\n      className={cn('relative', className)}\n      {...props}\n    >\n      <ScrollAreaPrimitive.Viewport\n        data-slot=\"scroll-area-viewport\"\n        className=\"focus-visible:ring-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:outline-1\"\n      >\n        {children}\n      </ScrollAreaPrimitive.Viewport>\n      <ScrollBar />\n      <ScrollAreaPrimitive.Corner />\n    </ScrollAreaPrimitive.Root>\n  )\n}\n\nfunction ScrollBar({\n  className,\n  orientation = 'vertical',\n  ...props\n}: React.ComponentProps<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>) {\n  return (\n    <ScrollAreaPrimitive.ScrollAreaScrollbar\n      data-slot=\"scroll-area-scrollbar\"\n      orientation={orientation}\n      className={cn(\n        'flex touch-none p-px transition-colors select-none',\n        orientation === 'vertical' &&\n          'h-full w-2.5 border-l border-l-transparent',\n        orientation === 'horizontal' &&\n          'h-2.5 flex-col border-t border-t-transparent',\n        className\n      )}\n      {...props}\n    >\n      <ScrollAreaPrimitive.ScrollAreaThumb\n        data-slot=\"scroll-area-thumb\"\n        className=\"bg-border relative flex-1 rounded-full\"\n      />\n    </ScrollAreaPrimitive.ScrollAreaScrollbar>\n  )\n}\n\nexport { ScrollArea, ScrollBar }\n",
    "import * as React from 'react'\nimport * as SelectPrimitive from '@radix-ui/react-select'\nimport { CheckIcon, ChevronDownIcon, ChevronUpIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Select({\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Root>) {\n  return <SelectPrimitive.Root data-slot=\"select\" {...props} />\n}\n\nfunction SelectGroup({\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Group>) {\n  return <SelectPrimitive.Group data-slot=\"select-group\" {...props} />\n}\n\nfunction SelectValue({\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Value>) {\n  return <SelectPrimitive.Value data-slot=\"select-value\" {...props} />\n}\n\nfunction SelectTrigger({\n  className,\n  size = 'default',\n  children,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Trigger> & {\n  size?: 'sm' | 'default'\n}) {\n  return (\n    <SelectPrimitive.Trigger\n      data-slot=\"select-trigger\"\n      data-size={size}\n      className={cn(\n        \"border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n        className\n      )}\n      {...props}\n    >\n      {children}\n      <SelectPrimitive.Icon asChild>\n        <ChevronDownIcon className=\"size-4 opacity-50\" />\n      </SelectPrimitive.Icon>\n    </SelectPrimitive.Trigger>\n  )\n}\n\nfunction SelectContent({\n  className,\n  children,\n  position = 'popper',\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Content>) {\n  return (\n    <SelectPrimitive.Portal>\n      <SelectPrimitive.Content\n        data-slot=\"select-content\"\n        className={cn(\n          'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md',\n          position === 'popper' &&\n            'data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1',\n          className\n        )}\n        position={position}\n        {...props}\n      >\n        <SelectScrollUpButton />\n        <SelectPrimitive.Viewport\n          className={cn(\n            'p-1',\n            position === 'popper' &&\n              'h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1'\n          )}\n        >\n          {children}\n        </SelectPrimitive.Viewport>\n        <SelectScrollDownButton />\n      </SelectPrimitive.Content>\n    </SelectPrimitive.Portal>\n  )\n}\n\nfunction SelectLabel({\n  className,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Label>) {\n  return (\n    <SelectPrimitive.Label\n      data-slot=\"select-label\"\n      className={cn('text-muted-foreground px-2 py-1.5 text-xs', className)}\n      {...props}\n    />\n  )\n}\n\nfunction SelectItem({\n  className,\n  children,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Item>) {\n  return (\n    <SelectPrimitive.Item\n      data-slot=\"select-item\"\n      className={cn(\n        \"focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2\",\n        className\n      )}\n      {...props}\n    >\n      <span className=\"absolute right-2 flex size-3.5 items-center justify-center\">\n        <SelectPrimitive.ItemIndicator>\n          <CheckIcon className=\"size-4\" />\n        </SelectPrimitive.ItemIndicator>\n      </span>\n      <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n    </SelectPrimitive.Item>\n  )\n}\n\nfunction SelectSeparator({\n  className,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.Separator>) {\n  return (\n    <SelectPrimitive.Separator\n      data-slot=\"select-separator\"\n      className={cn('bg-border pointer-events-none -mx-1 my-1 h-px', className)}\n      {...props}\n    />\n  )\n}\n\nfunction SelectScrollUpButton({\n  className,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollUpButton>) {\n  return (\n    <SelectPrimitive.ScrollUpButton\n      data-slot=\"select-scroll-up-button\"\n      className={cn(\n        'flex cursor-default items-center justify-center py-1',\n        className\n      )}\n      {...props}\n    >\n      <ChevronUpIcon className=\"size-4\" />\n    </SelectPrimitive.ScrollUpButton>\n  )\n}\n\nfunction SelectScrollDownButton({\n  className,\n  ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollDownButton>) {\n  return (\n    <SelectPrimitive.ScrollDownButton\n      data-slot=\"select-scroll-down-button\"\n      className={cn(\n        'flex cursor-default items-center justify-center py-1',\n        className\n      )}\n      {...props}\n    >\n      <ChevronDownIcon className=\"size-4\" />\n    </SelectPrimitive.ScrollDownButton>\n  )\n}\n\nexport {\n  Select,\n  SelectContent,\n  SelectGroup,\n  SelectItem,\n  SelectLabel,\n  SelectScrollDownButton,\n  SelectScrollUpButton,\n  SelectSeparator,\n  SelectTrigger,\n  SelectValue,\n}\n",
    "import * as React from 'react'\nimport * as SeparatorPrimitive from '@radix-ui/react-separator'\n\nimport { cn } from '@/lib/utils'\n\nfunction Separator({\n  className,\n  orientation = 'horizontal',\n  decorative = true,\n  ...props\n}: React.ComponentProps<typeof SeparatorPrimitive.Root>) {\n  return (\n    <SeparatorPrimitive.Root\n      data-slot=\"separator-root\"\n      decorative={decorative}\n      orientation={orientation}\n      className={cn(\n        'bg-border shrink-0 data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Separator }\n",
    "import * as React from 'react'\nimport * as SheetPrimitive from '@radix-ui/react-dialog'\nimport { XIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Sheet({ ...props }: React.ComponentProps<typeof SheetPrimitive.Root>) {\n  return <SheetPrimitive.Root data-slot=\"sheet\" {...props} />\n}\n\nfunction SheetTrigger({\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Trigger>) {\n  return <SheetPrimitive.Trigger data-slot=\"sheet-trigger\" {...props} />\n}\n\nfunction SheetClose({\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Close>) {\n  return <SheetPrimitive.Close data-slot=\"sheet-close\" {...props} />\n}\n\nfunction SheetPortal({\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Portal>) {\n  return <SheetPrimitive.Portal data-slot=\"sheet-portal\" {...props} />\n}\n\nfunction SheetOverlay({\n  className,\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Overlay>) {\n  return (\n    <SheetPrimitive.Overlay\n      data-slot=\"sheet-overlay\"\n      className={cn(\n        'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction SheetContent({\n  className,\n  children,\n  side = 'right',\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Content> & {\n  side?: 'top' | 'right' | 'bottom' | 'left'\n}) {\n  return (\n    <SheetPortal>\n      <SheetOverlay />\n      <SheetPrimitive.Content\n        data-slot=\"sheet-content\"\n        className={cn(\n          'bg-background data-[state=open]:animate-in data-[state=closed]:animate-out fixed z-50 flex flex-col gap-4 shadow-lg transition ease-in-out data-[state=closed]:duration-300 data-[state=open]:duration-500',\n          side === 'right' &&\n            'data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right inset-y-0 right-0 h-full w-3/4 border-l sm:max-w-sm',\n          side === 'left' &&\n            'data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left inset-y-0 left-0 h-full w-3/4 border-r sm:max-w-sm',\n          side === 'top' &&\n            'data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top inset-x-0 top-0 h-auto border-b',\n          side === 'bottom' &&\n            'data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom inset-x-0 bottom-0 h-auto border-t',\n          className\n        )}\n        {...props}\n      >\n        {children}\n        <SheetPrimitive.Close className=\"ring-offset-background focus:ring-ring data-[state=open]:bg-secondary absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none\">\n          <XIcon className=\"size-4\" />\n          <span className=\"sr-only\">Close</span>\n        </SheetPrimitive.Close>\n      </SheetPrimitive.Content>\n    </SheetPortal>\n  )\n}\n\nfunction SheetHeader({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"sheet-header\"\n      className={cn('flex flex-col gap-1.5 p-4', className)}\n      {...props}\n    />\n  )\n}\n\nfunction SheetFooter({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"sheet-footer\"\n      className={cn('mt-auto flex flex-col gap-2 p-4', className)}\n      {...props}\n    />\n  )\n}\n\nfunction SheetTitle({\n  className,\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Title>) {\n  return (\n    <SheetPrimitive.Title\n      data-slot=\"sheet-title\"\n      className={cn('text-foreground font-semibold', className)}\n      {...props}\n    />\n  )\n}\n\nfunction SheetDescription({\n  className,\n  ...props\n}: React.ComponentProps<typeof SheetPrimitive.Description>) {\n  return (\n    <SheetPrimitive.Description\n      data-slot=\"sheet-description\"\n      className={cn('text-muted-foreground text-sm', className)}\n      {...props}\n    />\n  )\n}\n\nexport {\n  Sheet,\n  SheetTrigger,\n  SheetClose,\n  SheetContent,\n  SheetHeader,\n  SheetFooter,\n  SheetTitle,\n  SheetDescription,\n}\n",
    "import * as React from 'react'\nimport * as TabsPrimitive from '@radix-ui/react-tabs'\n\nimport { cn } from '@/lib/utils'\n\nfunction Tabs({\n  className,\n  ...props\n}: React.ComponentProps<typeof TabsPrimitive.Root>) {\n  return (\n    <TabsPrimitive.Root\n      data-slot=\"tabs\"\n      className={cn('flex flex-col gap-2', className)}\n      {...props}\n    />\n  )\n}\n\nfunction TabsList({\n  className,\n  ...props\n}: React.ComponentProps<typeof TabsPrimitive.List>) {\n  return (\n    <TabsPrimitive.List\n      data-slot=\"tabs-list\"\n      className={cn(\n        'bg-muted text-muted-foreground inline-flex h-9 w-fit items-center justify-center rounded-lg p-[3px]',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction TabsTrigger({\n  className,\n  ...props\n}: React.ComponentProps<typeof TabsPrimitive.Trigger>) {\n  return (\n    <TabsPrimitive.Trigger\n      data-slot=\"tabs-trigger\"\n      className={cn(\n        \"data-[state=active]:bg-background dark:data-[state=active]:text-foreground focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring dark:data-[state=active]:border-input dark:data-[state=active]:bg-input/30 text-foreground dark:text-muted-foreground inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction TabsContent({\n  className,\n  ...props\n}: React.ComponentProps<typeof TabsPrimitive.Content>) {\n  return (\n    <TabsPrimitive.Content\n      data-slot=\"tabs-content\"\n      className={cn('flex-1 outline-none', className)}\n      {...props}\n    />\n  )\n}\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent }\n",
    "import * as React from 'react'\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip'\n\nimport { cn } from '@/lib/utils'\n\nfunction TooltipProvider({\n  delayDuration = 0,\n  ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Provider>) {\n  return (\n    <TooltipPrimitive.Provider\n      data-slot=\"tooltip-provider\"\n      delayDuration={delayDuration}\n      {...props}\n    />\n  )\n}\n\nfunction Tooltip({\n  ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Root>) {\n  return (\n    <TooltipProvider>\n      <TooltipPrimitive.Root data-slot=\"tooltip\" {...props} />\n    </TooltipProvider>\n  )\n}\n\nfunction TooltipTrigger({\n  ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {\n  return <TooltipPrimitive.Trigger data-slot=\"tooltip-trigger\" {...props} />\n}\n\nfunction TooltipContent({\n  className,\n  sideOffset = 0,\n  children,\n  ...props\n}: React.ComponentProps<typeof TooltipPrimitive.Content>) {\n  return (\n    <TooltipPrimitive.Portal>\n      <TooltipPrimitive.Content\n        data-slot=\"tooltip-content\"\n        sideOffset={sideOffset}\n        className={cn(\n          'bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance',\n          className\n        )}\n        {...props}\n      >\n        {children}\n        <TooltipPrimitive.Arrow className=\"bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]\" />\n      </TooltipPrimitive.Content>\n    </TooltipPrimitive.Portal>\n  )\n}\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }\n",
    "import {\n  Dialog,\n  DialogContent,\n  DialogHeader,\n  DialogTitle,\n} from '@/components/ui'\nimport React, { useImperativeHandle, useState } from 'react'\nimport { DraggableEvent } from '@/features/draggable-event/draggable-event'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport type { SelectedDayEvents } from '../types'\n\ninterface AllEventDialogProps {\n  ref: React.Ref<{\n    open: () => void\n    close: () => void\n    setSelectedDayEvents: (dayEvents: SelectedDayEvents) => void\n  }>\n}\n\nexport const AllEventDialog: React.FC<AllEventDialogProps> = ({ ref }) => {\n  const [dialogOpen, setDialogOpen] = useState(false)\n  const [selectedDayEvents, setSelectedDayEvents] =\n    useState<SelectedDayEvents | null>(null)\n  const { currentDate, firstDayOfWeek } = useCalendarContext()\n\n  useImperativeHandle(ref, () => ({\n    open: () => setDialogOpen(true),\n    close: () => setDialogOpen(false),\n    setSelectedDayEvents: (dayEvents: SelectedDayEvents) =>\n      setSelectedDayEvents(dayEvents),\n  }))\n\n  // Get start date for the current month view based on firstDayOfWeek\n  const firstDayOfMonth = currentDate.startOf('month')\n\n  // Calculate the first day of the calendar grid correctly\n  // Find the first day of week (e.g. Sunday or Monday) that comes before or on the first day of the month\n  let adjustedFirstDayOfCalendar = firstDayOfMonth.clone()\n  while (adjustedFirstDayOfCalendar.day() !== firstDayOfWeek) {\n    adjustedFirstDayOfCalendar = adjustedFirstDayOfCalendar.subtract(1, 'day')\n  }\n\n  return (\n    <Dialog open={dialogOpen} onOpenChange={setDialogOpen}>\n      <DialogContent className=\"max-h-[80vh] max-w-md overflow-y-auto\">\n        <DialogHeader>\n          <DialogTitle>\n            {selectedDayEvents && selectedDayEvents.day.format('MMMM D, YYYY')}\n          </DialogTitle>\n        </DialogHeader>\n        <div className=\"mt-4 space-y-3\">\n          {selectedDayEvents &&\n            selectedDayEvents.events.map((event) => {\n              return (\n                <DraggableEvent\n                  elementId={event.id} // Use event ID for unique identification\n                  key={event.id}\n                  event={event}\n                  className=\"relative my-1 h-[30px]\"\n                />\n              )\n            })}\n        </div>\n      </DialogContent>\n    </Dialog>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport { useDraggable } from '@dnd-kit/core'\nimport { AnimatePresence, motion } from 'motion/react'\nimport type { CSSProperties } from 'react'\nimport { memo } from 'react'\n\nfunction DraggableEventUnmemoized({\n  elementId,\n  event,\n  className,\n  style,\n  disableDrag = false,\n}: {\n  elementId: string\n  className?: string\n  style?: CSSProperties\n  event: CalendarEvent\n  disableDrag?: boolean\n}) {\n  const { onEventClick, renderEvent, disableEventClick, disableDragAndDrop } =\n    useCalendarContext()\n  const { attributes, listeners, setNodeRef, isDragging } = useDraggable({\n    id: elementId,\n    data: {\n      event,\n      type: 'calendar-event',\n    },\n    disabled: disableDrag || disableDragAndDrop,\n  })\n\n  // Default event content to render if custom renderEvent is not provided\n  const DefaultEventContent = () => (\n    <div\n      className={cn(\n        event.backgroundColor || 'bg-blue-500',\n        event.color || 'text-white',\n        'h-full w-full px-1 border-[1.5px] border-card rounded-md text-left overflow-clip'\n      )}\n      style={{ backgroundColor: event.backgroundColor, color: event.color }}\n    >\n      <p className=\"text-[10px] font-semibold sm:text-xs mt-0.5\">\n        {event.title}\n      </p>\n    </div>\n  )\n\n  return (\n    <AnimatePresence mode=\"wait\">\n      <motion.div\n        key={elementId}\n        ref={setNodeRef}\n        {...attributes}\n        {...listeners}\n        initial={{ opacity: 0, y: -50 }}\n        animate={{ opacity: 1, y: 0 }}\n        exit={{ opacity: 0, y: -50 }}\n        layout\n        layoutId={elementId}\n        transition={{ duration: 0.4, ease: 'easeInOut' }}\n        className={cn(\n          'truncate h-full w-full',\n          disableDrag || disableDragAndDrop\n            ? disableEventClick\n              ? 'cursor-default'\n              : 'cursor-pointer'\n            : 'cursor-grab',\n          isDragging &&\n            !(disableDrag || disableDragAndDrop) &&\n            'cursor-grabbing shadow-lg',\n          className\n        )}\n        style={style}\n        onClick={(e) => {\n          e.stopPropagation()\n          onEventClick(event)\n        }}\n      >\n        {/* Use custom renderEvent from context if available, otherwise use default */}\n        {renderEvent ? renderEvent(event) : <DefaultEventContent />}\n      </motion.div>\n    </AnimatePresence>\n  )\n}\n\nexport const DraggableEvent = memo(\n  DraggableEventUnmemoized,\n  (prevProps, nextProps) => {\n    // Compare the essential props to prevent unnecessary re-renders\n    return (\n      prevProps.elementId === nextProps.elementId &&\n      prevProps.disableDrag === nextProps.disableDrag &&\n      prevProps.className === nextProps.className &&\n      prevProps.event.id === nextProps.event.id &&\n      prevProps.event.height === nextProps.event.height\n    )\n  }\n)\n",
    "import dayjs from '@/lib/dayjs-config'\nimport { cn } from '@/lib/utils'\nimport React from 'react'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { DroppableCell } from '@/features/droppable-cell/droppable-cell'\nimport { AllEventDialog } from './all-events-dialog'\nimport type { SelectedDayEvents } from '../types'\nimport type { CalendarEvent } from '@/components/types'\n\ninterface DayCellProps {\n  index: number // Index of the day in the week (0-6)\n  day: dayjs.Dayjs\n  dayMaxEvents?: number\n  className?: string // Optional className for custom styling\n}\n\nexport const DayCell: React.FC<DayCellProps> = ({\n  index,\n  day,\n  className = '',\n}) => {\n  const allEventsDialogRef = React.useRef<{\n    open: () => void\n    close: () => void\n    setSelectedDayEvents: (dayEvents: SelectedDayEvents) => void\n  }>(null)\n  const {\n    events,\n    currentDate,\n    firstDayOfWeek,\n    dayMaxEvents = 0,\n  } = useCalendarContext()\n  const todayEvents = events.filter((e) => {\n    const startsToday = e.start.isSame(day, 'day')\n    const endsToday = e.end.isSame(day, 'day')\n    const spansToday = e.start.isBefore(day, 'day') && e.end.isAfter(day, 'day')\n\n    return startsToday || endsToday || spansToday\n  })\n\n  // Get start date for the current month view based on firstDayOfWeek\n  const firstDayOfMonth = currentDate.startOf('month')\n\n  // Calculate the first day of the calendar grid correctly\n  // Find the first day of week (e.g. Sunday or Monday) that comes before or on the first day of the month\n  let adjustedFirstDayOfCalendar = firstDayOfMonth.clone()\n  while (adjustedFirstDayOfCalendar.day() !== firstDayOfWeek) {\n    adjustedFirstDayOfCalendar = adjustedFirstDayOfCalendar.subtract(1, 'day')\n  }\n\n  // Handler for showing all events in a dialog\n  const showAllEvents = (day: dayjs.Dayjs, events: CalendarEvent[]) => {\n    allEventsDialogRef.current?.setSelectedDayEvents({\n      day,\n      events,\n    })\n    allEventsDialogRef.current?.open()\n  }\n\n  const isToday = day.isSame(dayjs(), 'day')\n  const isCurrentMonth = day.month() === currentDate.month()\n  const isLastColumn = index === 6 // Saturday is the last column in a week\n\n  const hiddenEventsCount = todayEvents.length - dayMaxEvents\n  const hasHiddenEvents = hiddenEventsCount > 0\n\n  return (\n    <>\n      <DroppableCell\n        id={`day-cell-${day.format('YYYY-MM-DD')}`}\n        type=\"day-cell\"\n        data-testid={`day-cell-${day.format('YYYY-MM-DD')}`}\n        date={day}\n        className={cn(\n          'cursor-pointer overflow-clip p-1 hover:bg-accent',\n          !isCurrentMonth && 'bg-secondary text-muted-foreground',\n          isLastColumn && 'border-r-0',\n          className\n        )}\n      >\n        {/* Absolutely positioned multi-day bars (Google Calendar style) */}\n\n        {/* Single-day events container positioned below multi-day events */}\n        <div className=\"flex flex-col gap-1\">\n          {/* Day number */}\n          <div\n            className={cn(\n              'flex h-5 w-5 items-center justify-center rounded-full text-xs sm:h-6 sm:w-6 sm:text-sm',\n              isToday && 'bg-primary text-primary-foreground font-medium'\n            )}\n          >\n            {day.date()}\n          </div>\n\n          {/* Render placeholders for events that occur today so that the cell height is according to dayMaxEvents. */}\n          {todayEvents.slice(0, dayMaxEvents).map((event, rowIndex) => (\n            <div\n              key={`empty-${rowIndex}`}\n              className=\"h-[20px] w-full\"\n              data-testid={event?.title}\n            />\n          ))}\n\n          {/* Show more events button with accurate count */}\n          {hasHiddenEvents && (\n            <div\n              className=\"text-muted-foreground hover:text-foreground cursor-pointer text-[10px] whitespace-nowrap sm:text-xs mt-1\"\n              onClick={(e) => {\n                e.stopPropagation()\n\n                showAllEvents(day, todayEvents)\n              }}\n            >\n              +{hiddenEventsCount} more\n            </div>\n          )}\n        </div>\n      </DroppableCell>\n\n      {/* Dialog for showing all events */}\n      <AllEventDialog ref={allEventsDialogRef} />\n    </>\n  )\n}\n",
    "import React from 'react'\nimport { useDroppable } from '@dnd-kit/core'\nimport { cn } from '@/lib/utils'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport type dayjs from '@/lib/dayjs-config'\n\ninterface DroppableCellProps {\n  id: string\n  type: 'day-cell' | 'time-cell'\n  date: dayjs.Dayjs\n  hour?: number\n  minute?: number\n  children?: React.ReactNode\n  className?: string\n  style?: React.CSSProperties\n  'data-testid'?: string\n}\n\nexport function DroppableCell({\n  id,\n  type,\n  date,\n  hour,\n  minute,\n  children,\n  className,\n  style,\n  'data-testid': dataTestId,\n}: DroppableCellProps) {\n  const { onCellClick, disableDragAndDrop, disableCellClick } =\n    useCalendarContext()\n  const { isOver, setNodeRef } = useDroppable({\n    id,\n    data: {\n      type,\n      date,\n      hour,\n      minute,\n    },\n    disabled: disableDragAndDrop,\n  })\n\n  const handleCellClick = (e: React.MouseEvent) => {\n    e.stopPropagation()\n    if (disableCellClick) return\n\n    const startDate = date.hour(hour ?? 0).minute(minute ?? 0)\n    let endDate = startDate.clone()\n    if (hour !== undefined && minute !== undefined) {\n      endDate = endDate.hour(hour).minute(minute + 15) // day view time slots are 15 minutes\n    } else if (hour !== undefined) {\n      endDate = endDate.hour(hour + 1).minute(0) // week view time slots are 1 hour\n    } else {\n      endDate = endDate.hour(23).minute(59) // month view full day\n    }\n\n    onCellClick(startDate, endDate)\n  }\n\n  return (\n    <div\n      ref={setNodeRef}\n      data-testid={dataTestId}\n      className={cn(\n        className,\n        isOver && !disableDragAndDrop && 'bg-accent',\n        disableCellClick ? 'cursor-default' : 'cursor-pointer'\n      )}\n      onClick={handleCellClick}\n      style={style}\n    >\n      {children}\n    </div>\n  )\n}\n",
    "import { AnimatePresence, motion } from 'motion/react'\nimport React, { useMemo } from 'react'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport dayjs from '@/lib/dayjs-config'\nimport { cn } from '@/lib/utils'\n\nexport const MonthHeader: React.FC = () => {\n  const {\n    firstDayOfWeek,\n    currentLocale,\n    stickyViewHeader,\n    viewHeaderClassName,\n  } = useCalendarContext()\n\n  // Reorder week days based on firstDayOfWeek\n  const weekDays = useMemo(() => {\n    const days = dayjs.weekdays().map((day) => day.toLowerCase())\n    const shortDays = dayjs.weekdaysShort().map((day) => day.toLowerCase())\n\n    // Rotate the array based on firstDayOfWeek\n    for (let i = 0; i < firstDayOfWeek; i++) {\n      const dayToMove = days.shift()\n      const shortDayToMove = shortDays.shift()\n      if (dayToMove) days.push(dayToMove)\n      if (shortDayToMove) shortDays.push(shortDayToMove)\n    }\n\n    return { days, shortDays }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [firstDayOfWeek, currentLocale])\n\n  return (\n    <div\n      className={cn(\n        'grid grid-cols-7 border-b',\n        stickyViewHeader && 'sticky top-0 z-100',\n        viewHeaderClassName\n      )}\n      data-testid=\"month-header\"\n    >\n      {weekDays.days.map((weekDay, index) => (\n        <AnimatePresence key={weekDay} mode=\"wait\">\n          <motion.div\n            key={weekDay}\n            initial={{ opacity: 0, y: -10 }}\n            animate={{ opacity: 1, y: 0 }}\n            exit={{ opacity: 0, y: -10 }}\n            transition={{\n              duration: 0.25,\n              ease: 'easeInOut',\n              delay: index * 0.05,\n            }}\n            className=\"py-2 text-center font-medium border-r first:border-l\"\n            data-testid={`weekday-header-${weekDay}`}\n          >\n            <span className=\"hidden text-sm sm:inline\">{weekDay}</span>\n            <span className=\"text-xs sm:hidden\">\n              {weekDays.shortDays[index]}\n            </span>\n          </motion.div>\n        </AnimatePresence>\n      ))}\n    </div>\n  )\n}\n",
    "export const GAP_BETWEEN_ELEMENTS = 1 // px (gap-1)\nexport const DAY_NUMBER_HEIGHT = 28 // px (h-7)\nexport const EVENT_BAR_HEIGHT = 24 // px (h-[24px])\n",
    "import type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport dayjs from '@/lib/dayjs-config'\nimport { DraggableEvent } from '@/features/draggable-event/draggable-event'\nimport {\n  DAY_NUMBER_HEIGHT,\n  EVENT_BAR_HEIGHT,\n  GAP_BETWEEN_ELEMENTS,\n} from '@/lib/constants'\n\ninterface ProcessedEvent extends CalendarEvent {\n  left: number // Left position in percentage\n  width: number // Width in percentage\n  top: number // Top position in percentage\n  height: number // Height in percentage\n  position: number // Position in the row (0 for first, 1 for second, etc.)\n}\n\ninterface WeekEventsLayerProps {\n  days: dayjs.Dayjs[]\n}\n\nexport const WeekEventsLayer: React.FC<WeekEventsLayerProps> = ({ days }) => {\n  const { events, dayMaxEvents } = useCalendarContext()\n\n  const weekStart = days[0]\n  const weekEnd = days[6]\n\n  // Get all events that intersect with this week\n  const weekEvents = events.filter((e) => {\n    const startsInWeek =\n      e.start.isSameOrAfter(weekStart.startOf('day')) &&\n      e.start.isSameOrBefore(weekEnd.endOf('day'))\n    const endsInWeek =\n      e.end.isSameOrAfter(weekStart.startOf('day')) &&\n      e.end.isSameOrBefore(weekEnd.endOf('day'))\n    const spansWeek =\n      e.start.isBefore(weekStart.startOf('day')) &&\n      e.end.isAfter(weekEnd.endOf('day'))\n    return startsInWeek || endsInWeek || spansWeek\n  })\n\n  // Separate multi-day and single-day events\n  const multiDayEvents = weekEvents.filter(\n    (e) => e.end.diff(e.start, 'day') > 0\n  )\n  const singleDayEvents = weekEvents.filter(\n    (e) => e.end.diff(e.start, 'day') === 0\n  )\n\n  // Sort multi-day events by start date, then by duration\n  const sortedMultiDay = [...multiDayEvents].sort((a, b) => {\n    const startDiff = a.start.diff(b.start)\n    if (startDiff !== 0) return startDiff\n    return b.end.diff(b.start) - a.end.diff(a.start) // Longer events first\n  })\n\n  // Sort single-day events by start time\n  const sortedSingleDay = [...singleDayEvents].sort((a, b) =>\n    a.start.diff(b.start)\n  )\n\n  // Create 7 x dayMaxEvents grid with flags\n  const grid: Array<Array<{ taken: boolean; event: CalendarEvent | null }>> = []\n  for (let row = 0; row < dayMaxEvents; row++) {\n    grid[row] = []\n    for (let col = 0; col < 7; col++) {\n      grid[row][col] = { taken: false, event: null }\n    }\n  }\n\n  const eventPositions: ProcessedEvent[] = []\n\n  // Step 1: Assign positions to multi-day events first\n  for (const event of sortedMultiDay) {\n    const eventStart = dayjs.max(event.start.startOf('day'), weekStart)\n    const eventEnd = dayjs.min(event.end.startOf('day'), weekEnd)\n    const startCol = Math.max(0, eventStart.diff(weekStart, 'day'))\n    const endCol = Math.min(6, eventEnd.diff(weekStart, 'day'))\n\n    // Try to place the event starting from its original start column\n    let placedSuccessfully = false\n\n    // First try: place from original start position\n    let assignedRow = -1\n    for (let row = 0; row < dayMaxEvents; row++) {\n      let canPlace = true\n      for (let col = startCol; col <= endCol; col++) {\n        if (grid[row][col].taken) {\n          canPlace = false\n          break\n        }\n      }\n      if (canPlace) {\n        assignedRow = row\n        break\n      }\n    }\n\n    // If we found a row, assign the event to all its columns\n    if (assignedRow !== -1) {\n      for (let col = startCol; col <= endCol; col++) {\n        grid[assignedRow][col] = { taken: true, event }\n      }\n\n      // Create position data for rendering\n      const spanDays = endCol - startCol + 1\n      eventPositions.push({\n        left: (startCol / 7) * 100,\n        width: (spanDays / 7) * 100,\n        top:\n          DAY_NUMBER_HEIGHT +\n          GAP_BETWEEN_ELEMENTS +\n          assignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),\n        height: EVENT_BAR_HEIGHT,\n        position: assignedRow,\n        ...event,\n      })\n      placedSuccessfully = true\n    }\n\n    // If couldn't place at original position, try truncated versions starting from later days\n    if (!placedSuccessfully) {\n      for (\n        let tryStartCol = startCol + 1;\n        tryStartCol <= endCol;\n        tryStartCol++\n      ) {\n        // Try to place the truncated event starting from this column\n        let truncatedAssignedRow = -1\n        for (let row = 0; row < dayMaxEvents; row++) {\n          let canPlace = true\n          for (let col = tryStartCol; col <= endCol; col++) {\n            if (grid[row][col].taken) {\n              canPlace = false\n              break\n            }\n          }\n          if (canPlace) {\n            truncatedAssignedRow = row\n            break\n          }\n        }\n\n        // If we found a row for the truncated version, place it\n        if (truncatedAssignedRow !== -1) {\n          for (let col = tryStartCol; col <= endCol; col++) {\n            grid[truncatedAssignedRow][col] = { taken: true, event }\n          }\n\n          // Create position data for the truncated rendering\n          const truncatedSpanDays = endCol - tryStartCol + 1\n          eventPositions.push({\n            left: (tryStartCol / 7) * 100,\n            width: (truncatedSpanDays / 7) * 100,\n            top:\n              DAY_NUMBER_HEIGHT +\n              GAP_BETWEEN_ELEMENTS +\n              truncatedAssignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),\n            height: EVENT_BAR_HEIGHT,\n            position: truncatedAssignedRow,\n            ...event,\n          })\n          placedSuccessfully = true\n          break // Successfully placed, stop trying other start positions\n        }\n      }\n    }\n  }\n\n  // Step 2: Fill gaps with single-day events\n  for (const event of sortedSingleDay) {\n    const eventStart = dayjs.max(event.start.startOf('day'), weekStart)\n    const col = Math.max(0, eventStart.diff(weekStart, 'day'))\n\n    // Find the first available row in this column\n    let assignedRow = -1\n    for (let row = 0; row < dayMaxEvents; row++) {\n      if (!grid[row][col].taken) {\n        assignedRow = row\n        break\n      }\n    }\n\n    // If we found a row, assign the event\n    if (assignedRow !== -1) {\n      grid[assignedRow][col] = { taken: true, event }\n\n      // Create position data for rendering\n      eventPositions.push({\n        left: (col / 7) * 100,\n        width: (1 / 7) * 100,\n        top:\n          DAY_NUMBER_HEIGHT +\n          GAP_BETWEEN_ELEMENTS +\n          assignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),\n        height: EVENT_BAR_HEIGHT,\n        position: assignedRow,\n        ...event,\n      })\n    }\n  }\n\n  return (\n    <div className=\"relative w-full h-full pointer-events-none z-20 overflow-clip\">\n      {eventPositions.map((event) => {\n        return (\n          <div\n            key={`event-${event.id}-${event.position}-${weekStart.format(\n              'YYYY-MM-DD'\n            )}`}\n            className=\"absolute z-10 pointer-events-auto overflow-clip\"\n            style={{\n              left: `calc(${event.left}% + var(--spacing) * 0.25)`,\n              width: `calc(${event.width}% - var(--spacing) * 1)`,\n              top: `${event.top}px`,\n              height: `${EVENT_BAR_HEIGHT}px`,\n            }}\n          >\n            <DraggableEvent\n              elementId={`event-${event.id}-${\n                event.position\n              }-${weekStart.format('YYYY-MM-DD')}`}\n              event={event}\n              className=\"h-full w-full shadow\"\n            />\n          </div>\n        )\n      })}\n    </div>\n  )\n}\n",
    "import { ScrollArea } from '@/components/ui'\nimport dayjs from '@/lib/dayjs-config'\nimport weekOfYear from 'dayjs/plugin/weekOfYear'\nimport React from 'react'\nimport { WeekAllDayRow } from './week-all-day-row'\nimport { WeekHeader } from './week-header'\nimport { WeekTimeGrid } from './week-time-grid'\n// Add weekOfYear plugin to dayjs\ndayjs.extend(weekOfYear)\n\nconst WeekView: React.FC = () => {\n  return (\n    <div className=\"flex h-full flex-col\" data-testid=\"week-view\">\n      {/* Week header row - fixed */}\n      <WeekHeader />\n\n      {/* Scrollable time grid */}\n      <ScrollArea\n        className=\"flex flex-1 overflow-auto\"\n        data-testid=\"week-scroll-area\"\n      >\n        {/* All-day events row - dynamic height based on content */}\n        <WeekAllDayRow />\n        <WeekTimeGrid />\n      </ScrollArea>\n    </div>\n  )\n}\n\nexport default WeekView\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport type dayjs from '@/lib/dayjs-config'\nimport React, { useMemo } from 'react'\nimport { DraggableEvent } from '../draggable-event/draggable-event'\nimport { DroppableCell } from '../droppable-cell/droppable-cell'\nimport type { CalendarEvent, ProcessedCalendarEvent } from '@/components/types'\nimport { EVENT_BAR_HEIGHT, GAP_BETWEEN_ELEMENTS } from '@/lib/constants'\n\nexport const WeekAllDayRow: React.FC = () => {\n  const { currentDate, getEventsForDateRange, firstDayOfWeek } =\n    useCalendarContext()\n\n  // Get start and end of current week based on firstDayOfWeek setting\n  const startOfWeek = currentDate.startOf('week').day(firstDayOfWeek)\n  // If current date is before the start of week, move back one week\n  const adjustedStartOfWeek = currentDate.isBefore(startOfWeek)\n    ? startOfWeek.subtract(1, 'week')\n    : startOfWeek\n  const endOfWeek = adjustedStartOfWeek.add(6, 'day')\n\n  // Create an array of days for the current week\n  const weekDays = []\n  for (let i = 0; i < 7; i++) {\n    weekDays.push(adjustedStartOfWeek.add(i, 'day'))\n  }\n\n  // Get events that might overlap with this week (expand search range)\n  const expandedStartDate = adjustedStartOfWeek.subtract(6, 'day') // Look 6 days before week start\n  const expandedEndDate = endOfWeek.add(6, 'day') // Look 6 days after week end\n  const allEvents = getEventsForDateRange(expandedStartDate, expandedEndDate)\n\n  // Filter events that actually overlap with the current week\n  const weekEvents = allEvents.filter((event) => {\n    // Fixed logic: An event overlaps with this week if:\n    return (\n      // Either the event starts during this week\n      (event.start.isSameOrAfter(adjustedStartOfWeek) &&\n        event.start.isSameOrBefore(endOfWeek)) ||\n      // Or the event ends during this week\n      (event.end.isSameOrAfter(adjustedStartOfWeek) &&\n        event.end.isSameOrBefore(endOfWeek)) ||\n      // Or the event spans the entire week (starts before and ends after)\n      (event.start.isBefore(adjustedStartOfWeek) &&\n        event.end.isAfter(endOfWeek))\n    )\n  })\n\n  // Separate all-day events from regular events (including multi-day events)\n  const allDayEvents = weekEvents.filter((event) => event.allDay)\n\n  // Process and layout all-day events to avoid overlapping\n  const { processedAllDayEvents } = useMemo(() => {\n    // Sort all-day events by start date and then by duration (longer events first)\n    const sortedEvents = [...allDayEvents].sort((a, b) => {\n      // First compare by start date\n      const startDiff = a.start.diff(b.start)\n      if (startDiff !== 0) return startDiff\n\n      // If start dates are the same, longer events come first\n      const aDuration = a.end.diff(a.start)\n      const bDuration = b.end.diff(b.start)\n      return bDuration - aDuration\n    })\n\n    // Track positions in rows\n    const rows: { end: dayjs.Dayjs; event: CalendarEvent }[][] = []\n    const processedEvents: ProcessedCalendarEvent[] = []\n\n    sortedEvents.forEach((event) => {\n      // Calculate which days this event spans\n      const eventStart = event.start.isBefore(adjustedStartOfWeek)\n        ? adjustedStartOfWeek\n        : event.start\n      const eventEnd = event.end.isAfter(endOfWeek) ? endOfWeek : event.end\n\n      // Calculate position as percentage of the week width\n      const startDayIndex = Math.max(\n        0,\n        eventStart.diff(adjustedStartOfWeek, 'day')\n      )\n      const endDayIndex = Math.min(6, eventEnd.diff(adjustedStartOfWeek, 'day'))\n\n      const left = (startDayIndex / 7) * 100\n      const width = ((endDayIndex - startDayIndex + 1) / 7) * 100\n\n      // Find a row where this event can fit\n      let rowIndex = 0\n      let placed = false\n\n      while (!placed) {\n        if (rowIndex >= rows.length) {\n          // Create a new row if needed\n          rows.push([])\n          placed = true\n        } else {\n          // Check if this event can fit in the current row\n          const row = rows[rowIndex]\n          const canFit = row.every((item) => {\n            return (\n              eventStart.isAfter(item.end) ||\n              eventEnd.isBefore(item.event.start)\n            )\n          })\n\n          if (canFit) {\n            placed = true\n          } else {\n            rowIndex++\n          }\n        }\n      }\n\n      // Add event to the row\n      rows[rowIndex].push({ end: eventEnd, event })\n\n      // Add processed event with correct positioning\n      processedEvents.push({\n        ...event,\n        left,\n        width,\n        top: rowIndex * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),\n        height: EVENT_BAR_HEIGHT,\n        allDay: true,\n      })\n    })\n\n    return {\n      processedAllDayEvents: processedEvents,\n      allDayRowsCount: Math.max(1, rows.length), // At least 1 row, even if empty\n    }\n  }, [allDayEvents, adjustedStartOfWeek, endOfWeek])\n\n  return (\n    <div\n      className=\"grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1 relative\"\n      data-testid=\"week-all-day-row\"\n    >\n      {/* Left label for all-day events */}\n      <div className=\"w-14 flex shrink-0 items-center justify-end border-x border-b pr-2 min-h-16\">\n        <span className=\"text-muted-foreground text-[10px] whitespace-nowrap sm:text-xs\">\n          All-day\n        </span>\n      </div>\n\n      {/* Droppable cells for each day */}\n      {weekDays.map((day) => (\n        <DroppableCell\n          key={`all-day-${day.format('YYYY-MM-DD')}`}\n          id={`all-day-cell-${day.format('YYYY-MM-DD')}`}\n          type=\"day-cell\"\n          date={day}\n          className=\"hover:bg-accent h-full flex-1 cursor-pointer border-r border-b\"\n        />\n      ))}\n\n      {/* All-day event blocks */}\n      <div className=\"absolute inset-0 z-10 p-1 col-span-7 col-start-2\">\n        {processedAllDayEvents.map((event, index) => (\n          <div\n            key={`all-day-container-${event.id}`}\n            className=\"absolute\"\n            style={{\n              left: `${event.left}%`,\n              width: `calc(${event.width}% - var(--spacing) * 2)`,\n              top: `${event.top}px`,\n              height: `${event.height}px`,\n            }}\n          >\n            <DraggableEvent\n              elementId={`all-day-${event.id}-${index}`}\n              event={event}\n              key={`all-day-${event.id}-${index}`}\n              className=\"h-full w-full overflow-clip text-xs absolute\"\n            />\n          </div>\n        ))}\n      </div>\n    </div>\n  )\n}\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport dayjs from '@/lib/dayjs-config'\nimport { AnimatePresence, motion } from 'motion/react'\nimport React from 'react'\n\nexport const WeekHeader: React.FC = () => {\n  const {\n    currentDate,\n    selectDate,\n    openEventForm,\n    firstDayOfWeek,\n    stickyViewHeader,\n    viewHeaderClassName,\n  } = useCalendarContext()\n\n  // Get start and end of current week based on firstDayOfWeek setting\n  const startOfWeek = currentDate.startOf('week').day(firstDayOfWeek)\n  // If current date is before the start of week, move back one week\n  const adjustedStartOfWeek = currentDate.isBefore(startOfWeek)\n    ? startOfWeek.subtract(1, 'week')\n    : startOfWeek\n\n  // Create an array of days for the current week\n  const weekDays = []\n  for (let i = 0; i < 7; i++) {\n    weekDays.push(adjustedStartOfWeek.add(i, 'day'))\n  }\n\n  return (\n    // css grid header with lef corner cell shorter than the rest\n    <div\n      className={cn(\n        'grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1',\n        stickyViewHeader && 'sticky top-0 z-100',\n        viewHeaderClassName\n      )}\n      data-testid=\"week-header\"\n    >\n      {/* Corner cell with week number */}\n      <div className=\"col-span-1 w-14 shrink-0 items-center justify-center border-x border-b p-2\">\n        <div className=\"flex flex-col items-center justify-center\">\n          <span className=\"text-muted-foreground text-xs\">Week</span>\n          <span className=\"font-medium\">{currentDate.week()}</span>\n        </div>\n      </div>\n\n      {/* Day header cells */}\n      {weekDays.map((day, index) => {\n        const isToday = day.isSame(dayjs(), 'day')\n\n        return (\n          <AnimatePresence key={day.format('YYYY-MM-DD')} mode=\"wait\">\n            <motion.div\n              key={day.format('YYYY-MM-DD')}\n              initial={{ opacity: 0, y: -10 }}\n              animate={{ opacity: 1, y: 0 }}\n              exit={{ opacity: 0, y: -10 }}\n              transition={{\n                duration: 0.25,\n                ease: 'easeInOut',\n                delay: index * 0.05,\n              }}\n              className={cn(\n                'hover:bg-accent flex-1 cursor-pointer p-1 text-center sm:p-2 border-r border-b',\n                isToday && 'bg-primary/10 font-bold'\n              )}\n              onClick={() => {\n                selectDate(day)\n                openEventForm(day)\n              }}\n              data-testid={`week-day-header-${day.format('dddd').toLowerCase()}`}\n            >\n              <div className=\"text-xs sm:text-sm\">{day.format('ddd')}</div>\n              <div\n                className={cn(\n                  'mx-auto mt-1 flex h-5 w-5 items-center justify-center rounded-full text-xs sm:h-7 sm:w-7 sm:text-sm',\n                  isToday && 'bg-primary text-primary-foreground'\n                )}\n              >\n                {day.date()}\n              </div>\n            </motion.div>\n          </AnimatePresence>\n        )\n      })}\n    </div>\n  )\n}\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport dayjs from '@/lib/dayjs-config'\nimport { useMemo } from 'react'\nimport type { CalendarEvent } from '@/components/types'\n\ninterface ProcessedEvent extends CalendarEvent {\n  left: number // Left position in percentage\n  width: number // Width in percentage\n  top: number // Top position in percentage\n  height: number // Height in percentage\n  zIndex?: number // Z-index for layering overlapping events\n}\n\ninterface UseProcessedDayEventsProps {\n  day: dayjs.Dayjs // The specific day this column represents\n}\n\nexport const useProcessedDayEvents = ({ day }: UseProcessedDayEventsProps) => {\n  const { getEventsForDateRange } = useCalendarContext()\n\n  const todayEvents = useMemo<ProcessedEvent[]>(() => {\n    let eventsForDay = getEventsForDateRange(\n      day.startOf('day'),\n      day.endOf('day')\n    )\n\n    // Filter out all-day events and sort by start time\n    eventsForDay = eventsForDay\n      .filter((e) => !e.allDay)\n      .toSorted((a, b) => a.start.diff(b.start))\n\n    if (eventsForDay.length === 0) {\n      return []\n    }\n\n    // Step 1: Group events into clusters of overlapping events\n    const clusters: CalendarEvent[][] = []\n    let currentCluster: CalendarEvent[] = []\n    let lastEventEnd: dayjs.Dayjs | null = null\n    for (const event of eventsForDay) {\n      if (lastEventEnd && event.start.isSameOrAfter(lastEventEnd)) {\n        if (currentCluster.length > 0) {\n          clusters.push(currentCluster)\n        }\n        currentCluster = []\n      }\n      currentCluster.push(event)\n      lastEventEnd = lastEventEnd\n        ? dayjs.max(lastEventEnd, event.end)\n        : event.end\n    }\n    if (currentCluster.length > 0) {\n      clusters.push(currentCluster)\n    }\n\n    // Step 2: For each cluster, use a more intelligent column assignment\n    const processedEvents: ProcessedEvent[] = []\n    for (const cluster of clusters) {\n      if (cluster.length === 1) {\n        // Single event takes full width\n        const event = cluster[0]\n        const startTime = event.start.hour() + event.start.minute() / 60\n        let endTime = event.end.hour() + event.end.minute() / 60\n        if (endTime < startTime) {\n          // If the event ends on the next day, set end time to 24 hours\n          endTime = 24\n        }\n        const totalDuration = endTime - startTime\n        const top = (startTime / 24) * 100\n        const height = (totalDuration / 24) * 100\n        processedEvents.push({ ...event, left: 0, width: 100, top, height })\n        continue\n      }\n\n      // Multiple events - use layered positioning approach\n      // Sort by duration (longest first), then by start time\n      const sortedEvents = [...cluster].sort((a, b) => {\n        const aDuration = a.end.diff(a.start, 'minute')\n        const bDuration = b.end.diff(b.start, 'minute')\n\n        // Longer events first\n        if (aDuration !== bDuration) {\n          return bDuration - aDuration\n        }\n\n        // If same duration, earlier start time first\n        return a.start.diff(b.start)\n      })\n\n      // Process events with layered positioning\n      const totalEvents = sortedEvents.length\n\n      // Calculate dynamic offset based on number of overlapping events\n      // Fewer events = larger individual offsets, more events = smaller offsets\n      let maxOffset: number\n      if (totalEvents === 2) {\n        maxOffset = 25 // 25% offset for 2 events\n      } else if (totalEvents === 3) {\n        maxOffset = 50 // 50% total for 3 events (25% each)\n      } else if (totalEvents === 4) {\n        maxOffset = 60 // 60% total for 4 events (20% each)\n      } else {\n        maxOffset = 70 // 70% total for 5+ events\n      }\n\n      const offsetPerEvent = totalEvents > 1 ? maxOffset / (totalEvents - 1) : 0\n\n      for (let i = 0; i < sortedEvents.length; i++) {\n        const event = sortedEvents[i]\n        const startTime = event.start.hour() + event.start.minute() / 60\n        let endTime = event.end.hour() + event.end.minute() / 60\n\n        if (endTime < startTime) {\n          // If the event ends on the next day, set end time to 24 hours\n          endTime = 24\n        }\n\n        const totalDuration = endTime - startTime\n        const top = (startTime / 24) * 100\n        const height = (totalDuration / 24) * 100\n\n        // Calculate positioning based on layer and total events\n        let left: number\n        let width: number\n        let zIndex: number\n\n        if (i === 0) {\n          // First event (longest) takes full width at bottom\n          left = 0\n          width = 100\n          zIndex = 1\n        } else {\n          // Subsequent events are offset dynamically based on total event count\n          left = offsetPerEvent * i\n          width = 100 - left // Remaining width\n          zIndex = i + 1 // Higher z-index for events on top\n        }\n\n        processedEvents.push({\n          ...event,\n          left,\n          width,\n          top,\n          height,\n          zIndex,\n        })\n      }\n    }\n\n    return processedEvents\n  }, [day, getEventsForDateRange])\n\n  return todayEvents\n}\n",
    "import { useProcessedDayEvents } from '@/hooks/useProcessedDayEvents'\nimport { DraggableEvent } from '../draggable-event/draggable-event'\nimport type dayjs from '@/lib/dayjs-config'\nimport { cn } from '@/lib/utils'\n\ninterface DayEventsLayerProps {\n  day: dayjs.Dayjs // The specific day this layer represents\n  'data-testid'?: string\n}\n\nexport const DayEventsLayer: React.FC<DayEventsLayerProps> = ({\n  day,\n  'data-testid': dataTestId,\n}) => {\n  const todayEvents = useProcessedDayEvents({ day })\n\n  return (\n    <div\n      data-testid={dataTestId}\n      className=\"pointer-events-none absolute inset-0 z-30\"\n    >\n      {todayEvents.map((event, index) => {\n        const veryVeryUniqueKey = `event-${event.id}-${index}-${day.format(\n          'YYYY-MM-DD'\n        )}`\n        const isShortEvent = event.end.diff(event.start, 'minute') <= 15\n        return (\n          <div\n            key={`container-${veryVeryUniqueKey}`}\n            className=\"absolute\"\n            style={{\n              left: `${event.left}%`,\n              width: `calc(${event.width}% - var(--spacing) * 2)`,\n              top: `${event.top}%`,\n              height: `${event.height}%`,\n            }}\n          >\n            <DraggableEvent\n              elementId={`draggable-${veryVeryUniqueKey}`}\n              event={event}\n              className={cn('pointer-events-auto absolute', {\n                '[&_p]:text-[10px] [&_p]:mt-0': isShortEvent,\n              })}\n            />\n          </div>\n        )\n      })}\n    </div>\n  )\n}\n",
    "import { cn } from '@/lib/utils'\nimport dayjs from '@/lib/dayjs-config'\nimport React from 'react'\nimport { DayEventsLayer } from '../day-view/day-events-layer'\nimport { DroppableCell } from '../droppable-cell/droppable-cell'\n\nconst hours = Array.from({ length: 24 }, (_, i) => i).map((hour) =>\n  dayjs().hour(hour).minute(0)\n)\n\ninterface WeekDayColProps {\n  day: dayjs.Dayjs // The specific day this column represents\n}\n\nexport const WeekDayCol: React.FC<WeekDayColProps> = ({ day }) => {\n  return (\n    <div\n      data-testid={`week-day-col-${day.format('YYYY-MM-DD')}`}\n      className=\"col-span-1 relative grid grid-rows-24 border-r\"\n    >\n      {hours.map((time) => {\n        const hour = time.hour()\n        const cellDate = day.format('YYYY-MM-DD')\n\n        return (\n          <DroppableCell\n            key={`${cellDate}-${time.format('HH')}`}\n            id={`time-cell-${cellDate}-${time.format('HH')}`}\n            type=\"time-cell\"\n            date={day}\n            hour={hour}\n            data-testid={`week-time-cell-${cellDate}-${time.format('HH')}`}\n            className={cn(\n              'hover:bg-accent relative z-20 h-[60px] cursor-pointer border-b'\n            )}\n          />\n        )\n      })}\n\n      {/* Event blocks layer */}\n      <DayEventsLayer\n        data-testid={`week-day-events-${day.format('YYYY-MM-DD')}`}\n        day={day}\n      />\n    </div>\n  )\n}\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport dayjs from '@/lib/dayjs-config'\nimport React from 'react'\nimport { WeekDayCol } from './week-day-col'\n\nconst hours = Array.from({ length: 24 }, (_, i) => i).map((hour) =>\n  dayjs().hour(hour).minute(0)\n)\n\nexport const WeekTimeGrid: React.FC = () => {\n  const { currentDate, firstDayOfWeek } = useCalendarContext()\n\n  // Get start and end of current week based on firstDayOfWeek setting\n  const startOfWeek = currentDate.startOf('week').day(firstDayOfWeek)\n  // If current date is before the start of week, move back one week\n  const adjustedStartOfWeek = currentDate.isBefore(startOfWeek)\n    ? startOfWeek.subtract(1, 'week')\n    : startOfWeek\n\n  // Create an array of days for the current week\n  const weekDays = []\n  for (let i = 0; i < 7; i++) {\n    weekDays.push(adjustedStartOfWeek.add(i, 'day'))\n  }\n\n  // Separate all-day events from regular events (including multi-day events)\n\n  // Find if current day is in the displayed week\n  const todayIndex = weekDays.findIndex((day) => day.isSame(dayjs(), 'day'))\n  const isCurrentWeek = todayIndex !== -1\n\n  return (\n    <div\n      data-testid=\"week-time-grid\"\n      className=\"relative h-full grid grid-cols-[auto_repeat(7,1fr)] grid-rows-[repeat(24,minmax(60px, 1fr))]\"\n    >\n      {/* Time labels column - fixed */}\n      <div\n        data-testid=\"week-time-labels\"\n        className=\"z-10 col-span-1 w-14 grid grid-rows-24 border-x\"\n      >\n        {hours.map((time) => (\n          <div\n            key={time.format('HH:mm')}\n            data-testid={`week-time-hour-${time.format('HH')}`}\n            className=\"h-[60px] border-b text-right\"\n          >\n            <span className=\"text-muted-foreground pr-2 text-right text-[10px] sm:text-xs\">\n              {time.format('h A')}\n            </span>\n          </div>\n        ))}\n      </div>\n\n      {/* Day columns with time slots */}\n      {weekDays.map((day) => (\n        <WeekDayCol key={day.format('YYYY-MM-DD')} day={day} />\n      ))}\n\n      {/* Current time indicator */}\n      {isCurrentWeek && (\n        <div\n          data-testid=\"week-current-time-indicator\"\n          className=\"pointer-events-none absolute z-20\"\n          style={{\n            top: `${(dayjs().hour() + dayjs().minute() / 60) * 60}px`,\n            left: `${todayIndex * (100 / 7)}%`,\n            width: `${100 / 7}%`,\n          }}\n        >\n          <div className=\"w-full border-t border-red-500\">\n            <div className=\"-mt-1 ml-1 h-2 w-2 rounded-full bg-red-500\"></div>\n          </div>\n        </div>\n      )}\n    </div>\n  )\n}\n",
    "import { ScrollArea } from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport dayjs from '@/lib/dayjs-config'\nimport { Fragment } from 'react'\nimport { DroppableCell } from '../droppable-cell/droppable-cell'\nimport { DayAllDayRow } from './day-all-day-row'\nimport { DayEventsLayer } from './day-events-layer'\nimport { DayHeader } from './day-header'\nimport { DayTimeCol } from './day-time-col'\n\nconst DayView = () => {\n  const { currentDate } = useCalendarContext()\n\n  // Hours to display (all 24 hours of the day)\n  const hours = Array.from({ length: 24 }, (_, i) => i).map((hour) => {\n    return dayjs().hour(hour).minute(0)\n  })\n\n  // For more granular time slots, we'll divide each hour into 15-minute segments\n  const timeSegments = [0, 15, 30, 45]\n\n  // Get current day's events - this will refresh automatically when store updates\n  // because getEventsForDate is a selector function from the store that runs whenever events change\n\n  const isToday = currentDate.isSame(dayjs(), 'day')\n  const cellDate = currentDate.format('YYYY-MM-DD')\n\n  return (\n    <div data-testid=\"day-view\" className=\"flex h-full flex-col\">\n      {/* Day header */}\n      <DayHeader />\n\n      {/* Time grid without scrollbar */}\n      <ScrollArea\n        data-testid=\"day-scroll-area\"\n        className=\"relative flex-1 overflow-y-auto\"\n      >\n        {/* All-day events row */}\n        <DayAllDayRow />\n\n        {/* Set a fixed height container that matches exactly the total height of all hour blocks */}\n        <div\n          data-testid=\"day-time-grid\"\n          className=\"grid grid-cols-8 divide-x border-x\"\n          style={{ height: `${hours.length * 60}px` }}\n        >\n          {/* Time labels column */}\n          <DayTimeCol className=\"col-span-2 h-full md:col-span-1\" />\n\n          {/* Day column with events */}\n          <div\n            data-testid=\"day-events-column\"\n            className=\"relative col-span-6 h-full md:col-span-7\"\n          >\n            {/* Background grid for time slots - lowest layer */}\n            <div\n              data-testid=\"day-background-grid\"\n              className=\"absolute inset-0 z-0\"\n            >\n              {hours.map((hour, index) => (\n                <div\n                  key={`bg-${currentDate.format('YYYY-MM-DD')}-${hour.format(\n                    'HH'\n                  )}`}\n                  className=\"h-[60px] border-b\"\n                >\n                  {/* 15-minute marker lines */}\n                  {timeSegments.slice(1).map((minutes) => (\n                    <div\n                      key={`bg-${hour.format('HH')}-${minutes}`}\n                      className=\"border-border absolute w-full border-t border-dashed\"\n                      style={{ top: `${index * 60 + minutes}px` }}\n                    ></div>\n                  ))}\n                </div>\n              ))}\n            </div>\n\n            {/* Interactive layer for time slots - middle layer with no borders */}\n            <div\n              data-testid=\"day-interactive-layer\"\n              className=\"pointer-events-auto absolute inset-0 z-20\"\n            >\n              {hours.map((time) => {\n                const hour = time.hour()\n\n                return (\n                  <Fragment key={`${cellDate}-${time.format('HH')}`}>\n                    <DroppableCell\n                      id={`time-cell-${cellDate}-${time.format('HH')}-00`}\n                      type=\"time-cell\"\n                      date={currentDate}\n                      hour={hour}\n                      minute={0}\n                      className={cn('hover:bg-accent h-[15px] cursor-pointer')}\n                    />\n                    <DroppableCell\n                      id={`time-cell-${cellDate}-${time.format('HH')}-15`}\n                      type=\"time-cell\"\n                      date={currentDate}\n                      hour={hour}\n                      minute={15}\n                      className=\"hover:bg-accent h-[15px] cursor-pointer\"\n                    />\n                    <DroppableCell\n                      id={`time-cell-${cellDate}-${time.format('HH')}-30`}\n                      type=\"time-cell\"\n                      date={currentDate}\n                      hour={hour}\n                      minute={30}\n                      className=\"hover:bg-accent h-[15px] cursor-pointer\"\n                    />\n                    <DroppableCell\n                      id={`time-cell-${cellDate}-${time.format('HH')}-45`}\n                      type=\"time-cell\"\n                      date={currentDate}\n                      hour={hour}\n                      minute={45}\n                      className=\"hover:bg-accent h-[15px] cursor-pointer\"\n                    />\n                  </Fragment>\n                )\n              })}\n            </div>\n\n            {/* Events layer - middle-top layer */}\n            <DayEventsLayer day={currentDate} />\n\n            {/* Current time indicator - top layer */}\n            {isToday && (\n              <div\n                data-testid=\"day-current-time-indicator\"\n                className=\"absolute right-0 left-0 z-40 border-t border-red-500\"\n                style={{\n                  top: `${(dayjs().hour() + dayjs().minute() / 60) * 60}px`,\n                }}\n              >\n                <div className=\"-mt-1 -ml-1 h-2 w-2 rounded-full bg-red-500\"></div>\n              </div>\n            )}\n          </div>\n        </div>\n      </ScrollArea>\n    </div>\n  )\n}\n\nexport default DayView\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { useMemo } from 'react'\nimport { DraggableEvent } from '../draggable-event/draggable-event'\nimport { DroppableCell } from '../droppable-cell/droppable-cell'\nimport type { CalendarEvent, ProcessedCalendarEvent } from '@/components/types'\nimport { EVENT_BAR_HEIGHT } from '@/lib/constants'\n\nexport const DayAllDayRow = () => {\n  const { currentDate, getEventsForDate } = useCalendarContext()\n\n  // Get current day's events - this will refresh automatically when store updates\n  // because getEventsForDate is a selector function from the store that runs whenever events change\n  const dayEvents = getEventsForDate(currentDate)\n\n  // Separate all-day events from regular events\n  const { allDayEvents } = useMemo(() => {\n    // Only events explicitly marked as allDay should be in the all-day section\n    const allDayEvts = dayEvents.filter((event) => event.allDay)\n\n    // Regular events (including multi-day events)\n    const regularEvts = dayEvents.filter((event) => !event.allDay)\n\n    return { allDayEvents: allDayEvts, regularEvents: regularEvts }\n  }, [dayEvents]) // Only depend on the dayEvents which is refreshed automatically\n\n  // Process all-day events for display\n  const { processedAllDayEvents } = useMemo(() => {\n    // Sort all-day events (if needed)\n    const sortedEvents = [...allDayEvents].sort((a, b) => {\n      return a.start.diff(b.start)\n    })\n\n    // Track positions in rows for stacking\n    const rows: { event: CalendarEvent }[][] = []\n    const processedEvents: ProcessedCalendarEvent[] = []\n\n    sortedEvents.forEach((event, rowIndex) => {\n      let placed = false\n\n      while (!placed) {\n        if (rowIndex >= rows.length) {\n          // Create a new row if needed\n          rows.push([])\n          placed = true\n        } else {\n          // In day view, we can place one event per row as they don't overlap horizontally\n          // This is simpler than week view where we needed to check for overlaps\n          placed = true\n        }\n      }\n\n      // Add event to the row\n      rows[rowIndex].push({ event })\n\n      // Add processed event with correct positioning\n      processedEvents.push({\n        ...event,\n        left: 0,\n        width: 100,\n        top: rowIndex * EVENT_BAR_HEIGHT,\n        height: EVENT_BAR_HEIGHT,\n        allDay: true,\n      })\n    })\n\n    return {\n      processedAllDayEvents: processedEvents,\n      allDayRowsCount: Math.max(1, rows.length), // At least 1 row, even if empty\n    }\n  }, [allDayEvents])\n\n  return (\n    <div\n      data-testid=\"day-all-day-row\"\n      className=\"grid grid-cols-8 border-b border-x\"\n    >\n      {/* Left label for all-day events */}\n      <div className=\"col-span-2 flex shrink-0 items-center justify-end border-r pr-2 md:col-span-1\">\n        <span className=\"text-muted-foreground text-[10px] whitespace-nowrap sm:text-xs\">\n          All-day\n        </span>\n      </div>\n\n      {/* All-day events container with dynamic height */}\n      <div className=\"relative col-span-6 md:col-span-7 \">\n        <DroppableCell\n          id={`all-day-${currentDate.format('YYYY-MM-DD')}`}\n          type=\"day-cell\"\n          date={currentDate}\n          className=\"hover:bg-accent w-full cursor-pointer min-h-10 flex flex-col\"\n        >\n          {processedAllDayEvents.map((event, index) => {\n            return (\n              <div\n                key={`all-day-${event.id}-${index}`}\n                style={{ height: EVENT_BAR_HEIGHT + 'px' }}\n              >\n                <DraggableEvent\n                  elementId={`all-day-${event.id}-${index}`}\n                  event={event}\n                  className=\"overflow-clip text-xs\"\n                  style={{ width: `calc(100% - var(--spacing) * 2)` }}\n                />\n              </div>\n            )\n          })}\n        </DroppableCell>\n      </div>\n    </div>\n  )\n}\n",
    "import { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport { AnimatePresence, motion } from 'motion/react'\nimport dayjs from '@/lib/dayjs-config'\n\nexport const DayHeader = () => {\n  const { currentDate, stickyViewHeader, viewHeaderClassName } =\n    useCalendarContext()\n  const isToday = currentDate.isSame(dayjs(), 'day')\n\n  return (\n    <div\n      data-testid=\"day-header\"\n      className={cn(\n        'flex items-center justify-center border-b p-2 border-x',\n        stickyViewHeader && 'sticky top-0 z-100',\n        viewHeaderClassName\n      )}\n    >\n      <AnimatePresence mode=\"wait\">\n        <motion.div\n          key={currentDate.format('YYYY-MM-DD')}\n          initial={{ opacity: 0, y: -10 }}\n          animate={{ opacity: 1, y: 0 }}\n          exit={{ opacity: 0, y: -10 }}\n          transition={{ duration: 0.25, ease: 'easeInOut' }}\n          className={cn(\n            'flex items-center text-center text-base font-semibold sm:text-xl',\n            isToday && 'text-primary'\n          )}\n        >\n          <span className=\"xs:inline hidden\">\n            {currentDate.format('dddd, ')}\n          </span>\n          {currentDate.format('MMMM D, YYYY')}\n          {isToday && (\n            <span className=\"bg-primary text-primary-foreground ml-2 rounded-full px-1 py-0.5 text-xs sm:px-2 sm:text-sm\">\n              Today\n            </span>\n          )}\n        </motion.div>\n      </AnimatePresence>\n    </div>\n  )\n}\n",
    "import dayjs from '@/lib/dayjs-config'\n\n// Hours to display (all 24 hours of the day)\nconst hours = Array.from({ length: 24 }, (_, i) => i).map((hour) => {\n  return dayjs().hour(hour).minute(0)\n})\n\ninterface DayTimeColProps {\n  className?: string\n}\n\nexport const DayTimeCol: React.FC<DayTimeColProps> = ({ className }) => {\n  return (\n    <div\n      data-testid=\"day-time-col\"\n      className={`col-span-2 h-full md:col-span-1 ${className}`}\n    >\n      {hours.map((time) => (\n        <div\n          key={time.format('HH:mm')}\n          data-testid={`day-time-hour-${time.format('HH')}`}\n          className=\"h-[60px] border-b text-right\"\n        >\n          <span className=\"text-muted-foreground pr-2 text-right text-[10px] sm:text-xs\">\n            {time.format('h A')}\n          </span>\n        </div>\n      ))}\n    </div>\n  )\n}\n",
    "import dayjs from '@/lib/dayjs-config'\nimport React, { useEffect, useState } from 'react'\n\nimport {\n  Button,\n  Checkbox,\n  DatePicker,\n  Dialog,\n  DialogContent,\n  DialogDescription,\n  DialogFooter,\n  DialogHeader,\n  DialogTitle,\n  Input,\n  Label,\n  Tooltip,\n  TooltipContent,\n  TooltipProvider,\n  TooltipTrigger,\n} from '@/components/ui'\nimport { cn } from '@/lib/utils'\nimport type { CalendarEvent } from '@/components/types'\n\nconst colorOptions = [\n  { value: 'bg-blue-100 text-blue-800', label: 'Blue' },\n  { value: 'bg-green-100 text-green-800', label: 'Green' },\n  { value: 'bg-purple-100 text-purple-800', label: 'Purple' },\n  { value: 'bg-red-100 text-red-800', label: 'Red' },\n  { value: 'bg-yellow-100 text-yellow-800', label: 'Yellow' },\n  { value: 'bg-pink-100 text-pink-800', label: 'Pink' },\n  { value: 'bg-indigo-100 text-indigo-800', label: 'Indigo' },\n  { value: 'bg-amber-100 text-amber-800', label: 'Amber' },\n  { value: 'bg-emerald-100 text-emerald-800', label: 'Emerald' },\n  { value: 'bg-sky-100 text-sky-800', label: 'Sky' },\n  { value: 'bg-violet-100 text-violet-800', label: 'Violet' },\n  { value: 'bg-rose-100 text-rose-800', label: 'Rose' },\n  { value: 'bg-teal-100 text-teal-800', label: 'Teal' },\n  { value: 'bg-orange-100 text-orange-800', label: 'Orange' },\n]\n\ninterface EventFormProps {\n  selectedEvent?: CalendarEvent | null\n  selectedDate?: dayjs.Dayjs | null\n  onAdd?: (event: CalendarEvent) => void\n  onUpdate?: (event: CalendarEvent) => void\n  onDelete?: (event: CalendarEvent) => void\n  onClose: () => void\n}\n\nexport const EventForm: React.FC<EventFormProps> = ({\n  selectedEvent,\n  selectedDate,\n  onClose,\n  onUpdate,\n  onDelete,\n  onAdd,\n}) => {\n  const start = selectedEvent?.originalStart ?? selectedEvent?.start\n  const end = selectedEvent?.originalEnd ?? selectedEvent?.end\n\n  // Form default values\n  const defaultStartDate = selectedDate?.toDate() || new Date()\n  const defaultEndDate =\n    selectedDate?.add(1, 'hour').toDate() || dayjs().add(1, 'hour').toDate()\n\n  // Form state\n  const [startDate, setStartDate] = useState(\n    start?.toDate() || defaultStartDate\n  )\n  const [endDate, setEndDate] = useState(end?.toDate() || defaultEndDate)\n  const [isAllDay, setIsAllDay] = useState(selectedEvent?.allDay || false)\n  const [selectedColor, setSelectedColor] = useState(\n    selectedEvent?.color || colorOptions[0].value\n  )\n\n  // Time state\n  const [startTime, setStartTime] = useState(\n    selectedEvent\n      ? selectedEvent.start.format('HH:mm')\n      : dayjs(defaultStartDate).format('HH:mm')\n  )\n  const [endTime, setEndTime] = useState(\n    selectedEvent\n      ? selectedEvent.end.format('HH:mm')\n      : dayjs(defaultEndDate).format('HH:mm')\n  )\n\n  // Initialize form values from selected event or defaults\n  const [formValues, setFormValues] = useState({\n    title: selectedEvent?.title || '',\n    description: selectedEvent?.description || '',\n    location: selectedEvent?.location || '',\n  })\n\n  // Create wrapper functions to fix TypeScript errors with DatePicker\n  const handleStartDateChange = (date: Date | undefined) => {\n    if (date) setStartDate(date)\n  }\n\n  const handleEndDateChange = (date: Date | undefined) => {\n    if (date) setEndDate(date)\n  }\n\n  // Update form values when input changes\n  const handleInputChange = (\n    e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>\n  ) => {\n    const { name, value } = e.target\n    setFormValues((prev) => ({ ...prev, [name]: value }))\n  }\n\n  // Handle time changes\n  const handleTimeChange = (\n    e: React.ChangeEvent<HTMLInputElement>,\n    isStart: boolean\n  ) => {\n    const timeValue = e.target.value\n    if (isStart) {\n      setStartTime(timeValue)\n    } else {\n      setEndTime(timeValue)\n    }\n  }\n\n  useEffect(() => {\n    // Reset end time when all day is toggled to on\n    if (isAllDay) {\n      setEndTime('23:59')\n    }\n  }, [isAllDay])\n\n  // Handle form submission\n  const handleSubmit = (e: React.FormEvent) => {\n    e.preventDefault()\n\n    // Create full datetime objects by combining date and time\n    const [startHours, startMinutes] = startTime.split(':').map(Number)\n    const [endHours, endMinutes] = endTime.split(':').map(Number)\n\n    let startDateTime = dayjs(startDate).hour(startHours).minute(startMinutes)\n\n    let endDateTime = dayjs(endDate).hour(endHours).minute(endMinutes)\n\n    // For all-day events, set appropriate times\n    if (isAllDay) {\n      startDateTime = startDateTime.hour(0).minute(0)\n      endDateTime = endDateTime.hour(23).minute(59)\n    }\n\n    const eventData: CalendarEvent = {\n      id: selectedEvent?.id || dayjs().format('YYYYMMDDHHmmss'),\n      title: formValues.title,\n      start: startDateTime,\n      end: endDateTime,\n      description: formValues.description,\n      location: formValues.location,\n      allDay: isAllDay,\n      color: selectedColor,\n    }\n\n    if (selectedEvent.id) {\n      onUpdate?.(eventData)\n    } else {\n      onAdd?.(eventData)\n    }\n\n    onClose()\n  }\n\n  const handleDelete = () => {\n    if (selectedEvent.id) {\n      onDelete?.(selectedEvent)\n      onClose()\n    }\n  }\n\n  // Validate end date is not before start date\n  useEffect(() => {\n    if (dayjs(startDate).isAfter(dayjs(endDate))) {\n      setEndDate(startDate)\n    }\n  }, [startDate, endDate])\n\n  return (\n    <Dialog open={true} onOpenChange={onClose}>\n      <DialogContent className=\"w-[90vw] max-w-[500px] p-4 sm:p-6\">\n        <form onSubmit={handleSubmit}>\n          <DialogHeader className=\"mb-2 sm:mb-4\">\n            <DialogTitle className=\"text-base sm:text-lg\">\n              {selectedEvent.id ? 'Edit Event' : 'Create Event'}\n            </DialogTitle>\n            <DialogDescription className=\"text-xs sm:text-sm\">\n              {selectedEvent.id\n                ? 'Edit your event details'\n                : 'Add a new event to your calendar'}\n            </DialogDescription>\n          </DialogHeader>\n\n          <div className=\"grid gap-3 py-2 sm:gap-4 sm:py-4\">\n            <div className=\"grid gap-2\">\n              <Label htmlFor=\"title\" className=\"text-xs sm:text-sm\">\n                Title\n              </Label>\n              <Input\n                id=\"title\"\n                name=\"title\"\n                value={formValues.title}\n                onChange={handleInputChange}\n                placeholder=\"Event title\"\n                required\n                autoFocus\n                className=\"h-8 text-sm sm:h-9\"\n              />\n            </div>\n\n            <div className=\"flex items-center space-x-2\">\n              <Checkbox\n                id=\"allDay\"\n                checked={isAllDay}\n                onCheckedChange={(checked) => setIsAllDay(checked === true)}\n              />\n              <Label htmlFor=\"allDay\" className=\"text-xs sm:text-sm\">\n                All day\n              </Label>\n            </div>\n\n            <div className=\"grid grid-cols-2 gap-2 sm:gap-4\">\n              <div>\n                <Label className=\"text-xs sm:text-sm\">Start Date</Label>\n                <DatePicker\n                  date={startDate}\n                  setDate={handleStartDateChange}\n                  className=\"mt-1\"\n                  closeOnSelect\n                />\n              </div>\n              <div>\n                <Label className=\"text-xs sm:text-sm\">End Date</Label>\n                <DatePicker\n                  date={endDate}\n                  setDate={handleEndDateChange}\n                  className=\"mt-1\"\n                  closeOnSelect\n                />\n              </div>\n            </div>\n\n            {!isAllDay && (\n              <div className=\"grid grid-cols-2 gap-2 sm:gap-4\">\n                <div>\n                  <Label htmlFor=\"start-time\" className=\"text-xs sm:text-sm\">\n                    Start Time\n                  </Label>\n                  <Input\n                    id=\"start-time\"\n                    type=\"time\"\n                    value={startTime}\n                    onChange={(e) => handleTimeChange(e, true)}\n                    className=\"mt-1 h-8 text-sm sm:h-9\"\n                  />\n                </div>\n                <div>\n                  <Label htmlFor=\"end-time\" className=\"text-xs sm:text-sm\">\n                    End Time\n                  </Label>\n                  <Input\n                    id=\"end-time\"\n                    type=\"time\"\n                    value={endTime}\n                    onChange={(e) => handleTimeChange(e, false)}\n                    className=\"mt-1 h-8 text-sm sm:h-9\"\n                  />\n                </div>\n              </div>\n            )}\n\n            <div className=\"grid gap-1 sm:gap-2\">\n              <Label className=\"text-xs sm:text-sm\">Color</Label>\n              <div className=\"flex flex-wrap gap-2\">\n                <TooltipProvider>\n                  {colorOptions.map((color) => (\n                    <Tooltip key={color.value}>\n                      <TooltipTrigger asChild>\n                        <Button\n                          variant=\"ghost\"\n                          key={color.value}\n                          type=\"button\"\n                          className={cn(\n                            `${color.value} h-6 w-6 rounded-full sm:h-8 sm:w-8`,\n                            selectedColor === color.value &&\n                              'ring-2 ring-black ring-offset-1 sm:ring-offset-2'\n                          )}\n                          onClick={() => setSelectedColor(color.value)}\n                          aria-label={color.label}\n                        />\n                      </TooltipTrigger>\n                      <TooltipContent>\n                        <p className=\"text-xs sm:text-sm\">{color.label}</p>\n                      </TooltipContent>\n                    </Tooltip>\n                  ))}\n                </TooltipProvider>\n              </div>\n            </div>\n\n            <div className=\"grid gap-1 sm:gap-2\">\n              <Label htmlFor=\"location\" className=\"text-xs sm:text-sm\">\n                Location\n              </Label>\n              <Input\n                id=\"location\"\n                name=\"location\"\n                value={formValues.location}\n                onChange={handleInputChange}\n                placeholder=\"Event location (optional)\"\n                className=\"h-8 text-sm sm:h-9\"\n              />\n            </div>\n\n            <div className=\"grid gap-1 sm:gap-2\">\n              <Label htmlFor=\"description\" className=\"text-xs sm:text-sm\">\n                Description\n              </Label>\n              <Input\n                id=\"description\"\n                name=\"description\"\n                value={formValues.description}\n                onChange={handleInputChange}\n                placeholder=\"Event description (optional)\"\n                className=\"h-8 text-sm sm:h-9\"\n              />\n            </div>\n          </div>\n\n          <DialogFooter className=\"mt-2 flex flex-col-reverse gap-2 sm:mt-4 sm:flex-row sm:gap-0\">\n            {selectedEvent.id && (\n              <Button\n                type=\"button\"\n                variant=\"destructive\"\n                onClick={handleDelete}\n                className=\"w-full sm:mr-auto sm:w-auto\"\n                size=\"sm\"\n              >\n                Delete\n              </Button>\n            )}\n            <div className=\"flex w-full gap-2 sm:w-auto\">\n              <Button\n                type=\"button\"\n                variant=\"outline\"\n                onClick={onClose}\n                className=\"flex-1 sm:flex-none\"\n                size=\"sm\"\n              >\n                Cancel\n              </Button>\n              <Button type=\"submit\" className=\"flex-1 sm:flex-none\" size=\"sm\">\n                {selectedEvent.id ? 'Update' : 'Create'}\n              </Button>\n            </div>\n          </DialogFooter>\n        </form>\n      </DialogContent>\n    </Dialog>\n  )\n}\n",
    "import {\n  Button,\n  Popover,\n  PopoverContent,\n  PopoverTrigger,\n} from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { Calendar as CalendarIcon, Menu, Plus } from 'lucide-react'\nimport React, { useCallback, useState } from 'react'\nimport TitleContent from './title-content'\nimport ViewControls from './view-controls'\n\ntype HeaderProps = object\n\nconst Header: React.FC<HeaderProps> = () => {\n  const {\n    currentDate,\n    view,\n    setView,\n    nextPeriod,\n    prevPeriod,\n    today,\n    openEventForm,\n  } = useCalendarContext()\n\n  // State for mobile menu popover\n  const [mobilePopoverOpen, setMobilePopoverOpen] = useState(false)\n\n  // Handle view change with optional popover closing\n  const handleViewChange = (\n    newView: 'day' | 'week' | 'month' | 'year',\n    closePopover = false\n  ) => {\n    setView(newView)\n    if (closePopover) {\n      setMobilePopoverOpen(false)\n    }\n  }\n\n  // Callback for navigation that also closes the mobile popover\n  const handleNavigation = {\n    today: () => {\n      today()\n      setMobilePopoverOpen(false)\n    },\n    previous: () => {\n      prevPeriod()\n      setMobilePopoverOpen(false)\n    },\n    next: () => {\n      nextPeriod()\n      setMobilePopoverOpen(false)\n    },\n  }\n\n  const NewEventButton = useCallback(\n    () => (\n      <div className=\"flex items-center gap-2\">\n        <Button\n          onClick={() => openEventForm(currentDate)}\n          variant=\"default\"\n          size=\"sm\"\n          className=\"flex items-center gap-1\"\n        >\n          <Plus className=\"h-4 w-4\" />\n          <span className=\"hidden md:inline\">New Event</span>\n          <span className=\"md:hidden\">New</span>\n        </Button>\n      </div>\n    ),\n    [currentDate, openEventForm]\n  )\n\n  return (\n    <>\n      {/* Calendar Header with grid layout */}\n      <div className=\"@container grid grid-cols-12 items-center gap-2 border-b p-2 sm:p-4\">\n        {/* Title area - Left section */}\n        <div className=\"col-span-12 flex flex-wrap items-center justify-center gap-2 @4xl:col-span-5 @4xl:justify-start\">\n          <CalendarIcon className=\"h-5 w-5\" />\n          <TitleContent />\n        </div>\n\n        {/* New event button - Mobile & Desktop */}\n        <div className=\"col-span-12 flex flex-wrap justify-center gap-1 @4xl:col-span-7 @4xl:justify-end\">\n          {/* Desktop controls - centralized */}\n          <div className=\"hidden items-center justify-end gap-1 sm:flex\">\n            <ViewControls\n              currentView={view}\n              onChange={setView}\n              onToday={today}\n              onNext={nextPeriod}\n              onPrevious={prevPeriod}\n              variant=\"default\"\n              className=\"justify-end\"\n            />\n\n            {/* New event button - Desktop */}\n            <NewEventButton />\n          </div>\n\n          {/* Mobile navigation menu button - Right aligned */}\n          <div className=\"flex items-center justify-end gap-1 sm:hidden\">\n            {/* New event button - Mobile */}\n            <NewEventButton />\n\n            <Popover\n              open={mobilePopoverOpen}\n              onOpenChange={setMobilePopoverOpen}\n            >\n              <PopoverTrigger asChild>\n                <Button variant=\"outline\" size=\"sm\">\n                  <Menu className=\"h-4 w-4\" />\n                </Button>\n              </PopoverTrigger>\n              <PopoverContent align=\"end\" className=\"w-[240px] p-2\">\n                <div className=\"space-y-2\">\n                  <h3 className=\"mb-1 text-sm font-medium\">\n                    View & Navigation\n                  </h3>\n                  <ViewControls\n                    currentView={view}\n                    onChange={(newView) => handleViewChange(newView, true)}\n                    onToday={handleNavigation.today}\n                    onNext={handleNavigation.next}\n                    onPrevious={handleNavigation.previous}\n                    variant=\"grid\"\n                  />\n                </div>\n              </PopoverContent>\n            </Popover>\n          </div>\n        </div>\n      </div>\n    </>\n  )\n}\n\nexport default Header\n",
    "import {\n  Button,\n  Popover,\n  PopoverContent,\n  PopoverTrigger,\n} from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport dayjs from '@/lib/dayjs-config'\nimport { AnimatePresence, motion } from 'motion/react'\nimport { ChevronDown } from 'lucide-react'\nimport { useState } from 'react'\n\n// Create arrays for month and year options\nconst months = [\n  'January',\n  'February',\n  'March',\n  'April',\n  'May',\n  'June',\n  'July',\n  'August',\n  'September',\n  'October',\n  'November',\n  'December',\n]\n\n// Animation variants for number transitions\nconst animationVariants = {\n  initial: { opacity: 0, y: 10 },\n  animate: { opacity: 1, y: 0 },\n  exit: { opacity: 0, y: -10 },\n}\n\nconst TitleContent = () => {\n  const { currentDate, view, setCurrentDate } = useCalendarContext()\n\n  // State for mobile menu and popovers\n  const [monthPopoverOpen, setMonthPopoverOpen] = useState(false)\n  const [yearPopoverOpen, setYearPopoverOpen] = useState(false)\n  const [weekPopoverOpen, setWeekPopoverOpen] = useState(false)\n  const [dayPopoverOpen, setDayPopoverOpen] = useState(false)\n\n  const currentYear = currentDate.year()\n  const years = Array.from({ length: 11 }, (_, i) => currentYear - 5 + i)\n\n  // Handle month and year selection\n  const handleMonthChange = (month: number) => {\n    const newDate = currentDate.month(month)\n    setCurrentDate(newDate)\n    setMonthPopoverOpen(false)\n  }\n\n  const handleYearChange = (year: number) => {\n    const newDate = currentDate.year(year)\n    setCurrentDate(newDate)\n    setYearPopoverOpen(false)\n  }\n\n  return (\n    <>\n      {view !== 'year' && (\n        <Popover open={monthPopoverOpen} onOpenChange={setMonthPopoverOpen}>\n          <PopoverTrigger asChild>\n            <Button\n              variant=\"ghost\"\n              className=\"flex items-center gap-1 px-2 font-semibold\"\n            >\n              <AnimatePresence mode=\"wait\">\n                <motion.span\n                  key={`month-${currentDate.month()}`}\n                  initial=\"initial\"\n                  animate=\"animate\"\n                  exit=\"exit\"\n                  variants={animationVariants}\n                  transition={{ duration: 0.25, ease: 'easeInOut' }}\n                >\n                  {currentDate.format('MMMM')}\n                </motion.span>\n              </AnimatePresence>\n              <ChevronDown className=\"h-4 w-4\" />\n            </Button>\n          </PopoverTrigger>\n          <PopoverContent className=\"w-40 p-0\">\n            <div className=\"flex max-h-60 flex-col overflow-auto\">\n              {months.map((month, index) => (\n                <Button\n                  key={month}\n                  variant=\"ghost\"\n                  className={cn(\n                    'justify-start font-normal',\n                    currentDate.month() === index && 'bg-primary/10'\n                  )}\n                  onClick={() => handleMonthChange(index)}\n                >\n                  {month}\n                </Button>\n              ))}\n            </div>\n          </PopoverContent>\n        </Popover>\n      )}\n\n      <Popover open={yearPopoverOpen} onOpenChange={setYearPopoverOpen}>\n        <PopoverTrigger asChild>\n          <Button\n            variant=\"ghost\"\n            className=\"flex items-center gap-1 px-2 font-semibold\"\n          >\n            <AnimatePresence mode=\"wait\">\n              <motion.span\n                key={`year-${currentDate.year()}`}\n                initial=\"initial\"\n                animate=\"animate\"\n                exit=\"exit\"\n                variants={animationVariants}\n                transition={{ duration: 0.25, ease: 'easeInOut' }}\n              >\n                {currentDate.format('YYYY')}\n              </motion.span>\n            </AnimatePresence>\n            <ChevronDown className=\"h-4 w-4\" />\n          </Button>\n        </PopoverTrigger>\n        <PopoverContent className=\"w-24 p-0\">\n          <div className=\"flex max-h-60 flex-col overflow-auto\">\n            {years.map((year) => (\n              <Button\n                key={year}\n                variant=\"ghost\"\n                className={cn(\n                  'justify-start font-normal',\n                  currentDate.year() === year && 'bg-primary/10'\n                )}\n                onClick={() => handleYearChange(year)}\n              >\n                {year}\n              </Button>\n            ))}\n          </div>\n        </PopoverContent>\n      </Popover>\n\n      {/* Display additional view-specific information */}\n      {view === 'week' && (\n        <Popover open={weekPopoverOpen} onOpenChange={setWeekPopoverOpen}>\n          <PopoverTrigger asChild>\n            <Button\n              variant=\"ghost\"\n              className=\"flex items-center gap-1 px-2 font-semibold\"\n            >\n              <AnimatePresence mode=\"wait\">\n                <motion.span\n                  key={`week-range-${currentDate.format('YYYY-MM-DD')}`}\n                  initial=\"initial\"\n                  animate=\"animate\"\n                  exit=\"exit\"\n                  variants={animationVariants}\n                  transition={{ duration: 0.25, ease: 'easeInOut' }}\n                >\n                  {`${currentDate\n                    .startOf('week')\n                    .format('MMM D')} - ${currentDate\n                    .endOf('week')\n                    .format('MMM D')}`}\n                </motion.span>\n              </AnimatePresence>\n              <ChevronDown className=\"ml-1 h-3 w-3 opacity-70\" />\n            </Button>\n          </PopoverTrigger>\n          <PopoverContent className=\"w-56 p-0\">\n            <div className=\"flex max-h-60 flex-col overflow-auto\">\n              {/* Show 7 weeks (3 past, current, 3 future) */}\n              {Array.from({ length: 7 }, (_, i) => {\n                const weekDate = currentDate.subtract(3, 'week').add(i, 'week')\n                const startOfWeek = weekDate.startOf('week')\n                const endOfWeek = weekDate.endOf('week')\n                const isCurrentWeek = weekDate.isSame(currentDate, 'week')\n\n                return (\n                  <Button\n                    key={startOfWeek.format('YYYY-MM-DD')}\n                    variant=\"ghost\"\n                    className={cn(\n                      'justify-start font-normal',\n                      isCurrentWeek && 'bg-primary/10'\n                    )}\n                    onClick={() => {\n                      setCurrentDate(startOfWeek)\n                      setWeekPopoverOpen(false)\n                    }}\n                  >\n                    <div className=\"flex w-full items-center justify-between\">\n                      <span>{`${startOfWeek.format(\n                        'MMM D'\n                      )} - ${endOfWeek.format('D')}`}</span>\n                      {startOfWeek.month() !== endOfWeek.month() && (\n                        <span className=\"text-xs opacity-70\">\n                          {`${startOfWeek.format('MMM')}-${endOfWeek.format(\n                            'MMM'\n                          )}`}\n                        </span>\n                      )}\n                    </div>\n                  </Button>\n                )\n              })}\n            </div>\n          </PopoverContent>\n        </Popover>\n      )}\n      {view === 'day' && (\n        <Popover open={dayPopoverOpen} onOpenChange={setDayPopoverOpen}>\n          <PopoverTrigger asChild>\n            <Button\n              variant=\"ghost\"\n              className=\"flex items-center gap-1 px-2 font-semibold\"\n            >\n              <AnimatePresence mode=\"wait\">\n                <motion.span\n                  key={`day-info-${currentDate.format('YYYY-MM-DD')}`}\n                  initial=\"initial\"\n                  animate=\"animate\"\n                  exit=\"exit\"\n                  variants={animationVariants}\n                  transition={{ duration: 0.25, ease: 'easeInOut' }}\n                >\n                  {currentDate.format('dddd, D')}\n                </motion.span>\n              </AnimatePresence>\n              <ChevronDown className=\"ml-1 h-3 w-3 opacity-70\" />\n            </Button>\n          </PopoverTrigger>\n          <PopoverContent className=\"w-56 p-0\">\n            <div className=\"flex max-h-60 flex-col overflow-auto\">\n              {/* Show all days of the current month */}\n              {(() => {\n                // Get first day of month and last day of month\n                const firstDayOfMonth = currentDate.startOf('month')\n                const daysInMonth = currentDate.daysInMonth()\n\n                // Generate array of days in the month\n                return Array.from({ length: daysInMonth }, (_, i) => {\n                  const dayDate = firstDayOfMonth.date(i + 1) // i + 1 because days start at 1\n                  const isCurrentDay = dayDate.isSame(currentDate, 'day')\n                  const isToday = dayDate.isSame(dayjs(), 'day')\n\n                  return (\n                    <Button\n                      key={dayDate.format('YYYY-MM-DD')}\n                      variant=\"ghost\"\n                      className={cn(\n                        'justify-start font-normal',\n                        isCurrentDay && 'bg-primary/10'\n                      )}\n                      onClick={() => {\n                        setCurrentDate(dayDate)\n                        setDayPopoverOpen(false)\n                      }}\n                    >\n                      <div className=\"flex w-full items-center justify-between\">\n                        <span>{dayDate.format('dddd, MMM D')}</span>\n                        {isToday && (\n                          <span className=\"bg-primary text-primary-foreground rounded-sm px-1 text-xs\">\n                            Today\n                          </span>\n                        )}\n                      </div>\n                    </Button>\n                  )\n                })\n              })()}\n            </div>\n          </PopoverContent>\n        </Popover>\n      )}\n    </>\n  )\n}\n\nexport default TitleContent\n",
    "import { Button } from '@/components/ui'\nimport { cn } from '@/lib/utils'\nimport { ChevronLeft, ChevronRight } from 'lucide-react'\nimport React from 'react'\n\ntype ViewControlsProps = {\n  currentView: 'day' | 'week' | 'month' | 'year'\n  onChange: (view: 'day' | 'week' | 'month' | 'year') => void\n  onToday?: () => void\n  onNext?: () => void\n  onPrevious?: () => void\n  variant?: 'default' | 'grid'\n  size?: 'sm' | 'default'\n  className?: string\n}\n\nconst ViewControls: React.FC<ViewControlsProps> = ({\n  currentView,\n  onChange,\n  variant = 'default',\n  size = 'sm',\n  className,\n  onToday,\n  onNext,\n  onPrevious,\n}) => {\n  const isGrid = variant === 'grid'\n\n  // Extract common button className logic to a function\n  const getButtonClassName = (viewType: 'day' | 'week' | 'month' | 'year') => {\n    return cn(\n      // Base width for grid layout\n      isGrid ? 'w-full' : '',\n      // Special case for year button visibility on mobile\n      viewType === 'year' ? (isGrid ? 'w-full' : 'hidden md:inline-flex') : '',\n      // Active view styling\n      currentView === viewType && 'bg-primary/80'\n    )\n  }\n\n  const getBtnVariant = (viewType: 'day' | 'week' | 'month' | 'year') => {\n    return currentView === viewType ? 'default' : 'outline'\n  }\n\n  return (\n    <div\n      className={cn(\n        isGrid ? 'grid grid-cols-2 gap-2' : 'flex gap-1',\n        className\n      )}\n    >\n      <Button onClick={onPrevious} variant=\"outline\" size={size}>\n        <ChevronLeft className=\"h-4 w-4\" />\n      </Button>\n      <Button onClick={onNext} variant=\"outline\" size={size}>\n        <ChevronRight className=\"h-4 w-4\" />\n      </Button>\n\n      <Button\n        onClick={() => onChange('day')}\n        variant={getBtnVariant('day')}\n        size={size}\n        className={getButtonClassName('day')}\n      >\n        Day\n      </Button>\n      <Button\n        onClick={() => onChange('week')}\n        variant={getBtnVariant('week')}\n        size={size}\n        className={getButtonClassName('week')}\n      >\n        Week\n      </Button>\n      <Button\n        onClick={() => onChange('month')}\n        variant={getBtnVariant('month')}\n        size={size}\n        className={getButtonClassName('month')}\n      >\n        Month\n      </Button>\n      <Button\n        onClick={() => onChange('year')}\n        variant={getBtnVariant('year')}\n        size={size}\n        className={getButtonClassName('year')}\n      >\n        Year\n      </Button>\n\n      <Button onClick={onToday} variant=\"outline\" size={size}>\n        Today\n      </Button>\n    </div>\n  )\n}\n\nexport default ViewControls\n",
    "import React from 'react'\nimport dayjs from '@/lib/dayjs-config'\nimport { cn } from '@/lib/utils'\nimport { ScrollArea } from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { AnimatePresence, motion } from 'motion/react'\n\nconst YearView: React.FC = () => {\n  const { currentDate, selectDate, events, setView, getEventsForDate } =\n    useCalendarContext()\n  const year = currentDate.year()\n\n  // Generate an array of 12 months for the current year\n  const months = Array.from({ length: 12 }, (_, i) => {\n    const monthDate = dayjs().year(year).month(i).startOf('month')\n    return {\n      date: monthDate,\n      name: monthDate.format('MMMM'),\n      daysInMonth: monthDate.daysInMonth(),\n      firstDayOfMonth: monthDate.startOf('month').day(), // 0-6, 0 is Sunday\n    }\n  })\n\n  // Calculate events for each month\n  const monthsWithEventCount = months.map((month) => {\n    const eventsInMonth = events.filter(\n      (event) =>\n        event.start.year() === year &&\n        event.start.month() === month.date.month()\n    )\n\n    return {\n      ...month,\n      eventCount: eventsInMonth.length,\n    }\n  })\n\n  // Handle month click to navigate to month view\n  const handleMonthClick = (date: dayjs.Dayjs) => {\n    selectDate(date)\n    setView('month')\n  }\n\n  // Handle day click within the mini calendar\n  const handleDayClick = (date: dayjs.Dayjs, event: React.MouseEvent) => {\n    event.stopPropagation() // Prevent triggering the month click\n    selectDate(date)\n    setView('day') // Navigate directly to day view when clicking on a specific day\n  }\n\n  // Generate days for mini calendar in each month\n  const renderMiniCalendar = (month: (typeof monthsWithEventCount)[0]) => {\n    // Get the first day of the month's calendar (which could be in the previous month)\n    const firstDayOfCalendar = month.date.startOf('month').startOf('week')\n\n    // Create 42 days (6 rows of 7 days) for consistency\n    const daysArray = Array.from({ length: 42 }, (_, i) => {\n      const day = firstDayOfCalendar.add(i, 'day')\n      const isCurrentMonth = day.month() === month.date.month()\n      const isToday = day.isSame(dayjs(), 'day')\n      const isCurrentDate = day.isSame(currentDate, 'day')\n\n      // Get events for this day\n      const dayEvents = getEventsForDate(day)\n      const hasEvents = dayEvents.length > 0\n\n      return {\n        day,\n        isCurrentMonth,\n        isToday,\n        isCurrentDate,\n        hasEvents,\n        eventCount: dayEvents.length,\n        // Group events by their categories to show different colors\n        events: dayEvents,\n      }\n    })\n\n    return (\n      <div\n        data-testid={`year-mini-calendar-${month.date.format('MM')}`}\n        className=\"grid grid-cols-7 gap-[1px] text-[0.6rem]\"\n      >\n        {/* Day names */}\n        {['S', 'M', 'T', 'W', 'T', 'F', 'S'].map((dayName, i) => (\n          <div\n            key={`header-${i}`}\n            className=\"text-muted-foreground h-3 text-center\"\n          >\n            {dayName}\n          </div>\n        ))}\n\n        {/* Calendar days */}\n        {daysArray.map((dayInfo, i) => (\n          <div\n            key={`day-${i}`}\n            data-testid={`year-day-${dayInfo.day.format('YYYY-MM-DD')}`}\n            onClick={(e) => handleDayClick(dayInfo.day, e)}\n            className={cn(\n              'relative flex aspect-square w-full cursor-pointer flex-col items-center justify-center',\n              'hover:bg-accent rounded-sm transition-colors duration-200',\n              !dayInfo.isCurrentMonth && 'text-muted-foreground opacity-50',\n              dayInfo.isToday &&\n                'bg-primary text-primary-foreground rounded-full',\n              dayInfo.isCurrentDate &&\n                !dayInfo.isToday &&\n                'bg-muted rounded-full font-bold',\n              dayInfo.hasEvents &&\n                !dayInfo.isToday &&\n                !dayInfo.isCurrentDate &&\n                'font-medium'\n            )}\n            title={\n              dayInfo.hasEvents\n                ? `${dayInfo.eventCount} event${\n                    dayInfo.eventCount > 1 ? 's' : ''\n                  }`\n                : ''\n            }\n          >\n            <span className=\"text-center leading-none\">\n              {dayInfo.day.date()}\n            </span>\n\n            {/* Enhanced event indicator - show multiple colored dots for different event types */}\n            {dayInfo.hasEvents && (\n              <div\n                className={cn(\n                  'absolute bottom-0 flex w-full justify-center space-x-[1px]',\n                  dayInfo.isToday ? 'bottom-[1px]' : ''\n                )}\n              >\n                {/* Show up to 3 event dots with different colors if available */}\n                {dayInfo.eventCount > 0 && (\n                  <span\n                    className={cn(\n                      'h-[3px] w-[3px] rounded-full',\n                      dayInfo.isToday ? 'bg-primary-foreground' : 'bg-primary'\n                    )}\n                  />\n                )}\n                {dayInfo.eventCount > 1 && (\n                  <span\n                    className={cn(\n                      'h-[3px] w-[3px] rounded-full',\n                      dayInfo.isToday ? 'bg-primary-foreground' : 'bg-blue-500'\n                    )}\n                  />\n                )}\n                {dayInfo.eventCount > 2 && (\n                  <span\n                    className={cn(\n                      'h-[3px] w-[3px] rounded-full',\n                      dayInfo.isToday ? 'bg-primary-foreground' : 'bg-green-500'\n                    )}\n                  />\n                )}\n              </div>\n            )}\n          </div>\n        ))}\n      </div>\n    )\n  }\n\n  return (\n    <ScrollArea data-testid=\"year-view\" className=\"h-full\">\n      <div\n        data-testid=\"year-grid\"\n        className=\"grid auto-rows-fr grid-cols-1 gap-4 p-4 sm:grid-cols-2 lg:grid-cols-3\"\n      >\n        {monthsWithEventCount.map((month, index) => (\n          <div\n            key={month.name}\n            data-testid={`year-month-${month.date.format('MM')}`}\n            onClick={() => handleMonthClick(month.date)}\n            className=\"hover:border-primary flex cursor-pointer flex-col rounded-lg border p-3 transition-all duration-200 hover:scale-[1.01] hover:shadow-md\"\n          >\n            <AnimatePresence mode=\"wait\">\n              <motion.div\n                key={`month-${index}`}\n                initial={{ opacity: 0, y: -10 }}\n                animate={{ opacity: 1, y: 0 }}\n                exit={{ opacity: 0, y: -10 }}\n                transition={{\n                  duration: 0.25,\n                  ease: 'easeInOut',\n                  delay: index * 0.05,\n                }}\n                className=\"mb-2 flex items-center justify-between\"\n              >\n                <h3\n                  data-testid={`year-month-title-${month.date.format('MM')}`}\n                  className=\"text-lg font-medium\"\n                >\n                  {month.name}\n                </h3>\n                {month.eventCount > 0 && (\n                  <span\n                    data-testid={`year-month-event-count-${month.date.format('MM')}`}\n                    className=\"bg-primary text-primary-foreground rounded-full px-2 py-1 text-xs\"\n                  >\n                    {month.eventCount}{' '}\n                    {month.eventCount === 1 ? 'event' : 'events'}\n                  </span>\n                )}\n              </motion.div>\n            </AnimatePresence>\n\n            {renderMiniCalendar(month)}\n          </div>\n        ))}\n      </div>\n    </ScrollArea>\n  )\n}\n\nexport default YearView\n",
    "import React from 'react'\nimport { MonthView } from '@/features/month-view/components/month-view'\nimport WeekView from '@/features/week-view/week-view'\nimport DayView from '@/features/day-view/day-view'\nimport { EventForm } from '../event-form/event-form'\nimport { Header } from '../header'\nimport YearView from '@/features/year-view/year-view'\nimport { AnimatePresence, motion } from 'motion/react'\nimport { CalendarDndContext } from '@/features/drag-and-drop/calendar-dnd-context'\nimport { CalendarProvider } from '@/contexts/calendar-context/provider'\nimport type { CalendarEvent, WeekDays } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport '@/lib/dayjs-config'\nimport type dayjs from '@/lib/dayjs-config'\n\nconst CalendarContent: React.FC = () => {\n  const {\n    view,\n    isEventFormOpen,\n    closeEventForm,\n    selectedEvent,\n    selectedDate,\n    addEvent,\n    updateEvent,\n    deleteEvent,\n    dayMaxEvents,\n  } = useCalendarContext()\n\n  const viewMap = {\n    month: <MonthView key=\"month\" dayMaxEvents={dayMaxEvents} />,\n    week: <WeekView key=\"week\" />,\n    day: <DayView key=\"day\" />,\n    year: <YearView key=\"year\" />,\n  }\n\n  const handleOnUpdate = (event: CalendarEvent) => {\n    updateEvent(event.id, event)\n  }\n\n  const handleOnDelete = (event: CalendarEvent) => {\n    deleteEvent(event.id)\n  }\n\n  return (\n    <div className=\"flex flex-col w-full h-full\">\n      <Header />\n\n      {/* Calendar Body with AnimatePresence for view transitions */}\n      <CalendarDndContext>\n        <AnimatePresence mode=\"wait\">\n          <motion.div\n            key={view}\n            initial={{ opacity: 0, x: 20 }}\n            animate={{ opacity: 1, x: 0 }}\n            exit={{ opacity: 0, x: -20 }}\n            transition={{ duration: 0.1, ease: 'easeInOut' }}\n            className=\"h-full w-full\"\n          >\n            {viewMap[view]}\n          </motion.div>\n        </AnimatePresence>\n      </CalendarDndContext>\n\n      {/* Event Form Dialog */}\n      {isEventFormOpen && (\n        <EventForm\n          onClose={closeEventForm}\n          selectedEvent={selectedEvent}\n          selectedDate={selectedDate}\n          onAdd={addEvent}\n          onUpdate={handleOnUpdate}\n          onDelete={handleOnDelete}\n        />\n      )}\n    </div>\n  )\n}\n\ninterface CalendarProps {\n  events?: CalendarEvent[]\n  firstDayOfWeek?: WeekDays\n  renderEvent?: (event: CalendarEvent) => React.ReactNode\n  onEventClick?: (event: CalendarEvent) => void\n  onCellClick?: (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs) => void\n  onViewChange?: (view: 'month' | 'week' | 'day' | 'year') => void\n  locale?: string\n  timezone?: string\n  disableCellClick?: boolean\n  disableEventClick?: boolean\n  disableDragAndDrop?: boolean\n  dayMaxEvents?: number\n  stickyViewHeader?: boolean\n  viewHeaderClassName?: string\n}\n\nconst dayNumberMap: Record<string, number> = {\n  sunday: 0,\n  monday: 1,\n  tuesday: 2,\n  wednesday: 3,\n  thursday: 4,\n  friday: 5,\n  saturday: 6,\n}\n\nconst DEFAULT_DAY_MAX_EVENTS = 6\nexport const IlamyCalendar: React.FC<CalendarProps> = ({\n  events,\n  firstDayOfWeek = 'sunday',\n  renderEvent,\n  onEventClick,\n  onCellClick,\n  onViewChange,\n  locale,\n  timezone,\n  disableCellClick,\n  disableEventClick,\n  disableDragAndDrop,\n  dayMaxEvents = DEFAULT_DAY_MAX_EVENTS,\n  stickyViewHeader = true,\n  viewHeaderClassName = '',\n}) => {\n  return (\n    <CalendarProvider\n      events={events}\n      firstDayOfWeek={dayNumberMap[firstDayOfWeek]}\n      renderEvent={renderEvent}\n      onEventClick={onEventClick}\n      onCellClick={onCellClick}\n      onViewChange={onViewChange}\n      locale={locale}\n      timezone={timezone}\n      disableCellClick={disableCellClick}\n      disableEventClick={disableEventClick}\n      disableDragAndDrop={disableDragAndDrop}\n      dayMaxEvents={dayMaxEvents}\n      stickyViewHeader={stickyViewHeader}\n      viewHeaderClassName={viewHeaderClassName}\n    >\n      <CalendarContent />\n    </CalendarProvider>\n  )\n}\n",
    "import {\n  DndContext,\n  DragOverlay,\n  MouseSensor,\n  pointerWithin,\n  TouchSensor,\n  useSensor,\n  useSensors,\n} from '@dnd-kit/core'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { cn } from '@/lib/utils'\nimport dayjs from '@/lib/dayjs-config'\nimport React from 'react'\nimport type {\n  DragCancelEvent,\n  DragEndEvent,\n  DragStartEvent,\n} from '@dnd-kit/core'\nimport { snapCenterToCursor } from '@dnd-kit/modifiers'\nimport type { CalendarEvent } from '@/components/types'\n\ninterface CalendarDndContextProps {\n  children: React.ReactNode\n}\n\nexport function CalendarDndContext({ children }: CalendarDndContextProps) {\n  const { updateEvent, view, disableDragAndDrop } = useCalendarContext()\n  const [activeEvent, setActiveEvent] = React.useState<CalendarEvent | null>(\n    null\n  )\n\n  // Configure sensors with reduced activation constraints for easier dragging\n  const mouseSensor = useSensor(MouseSensor, {\n    // Require minimal movement before activating\n    activationConstraint: {\n      distance: 2,\n    },\n  })\n\n  const touchSensor = useSensor(TouchSensor, {\n    // Reduce delay for touch devices\n    activationConstraint: {\n      delay: 100,\n      tolerance: 5,\n    },\n  })\n\n  const sensors = useSensors(mouseSensor, touchSensor)\n\n  const handleDragStart = (event: DragStartEvent) => {\n    const { active } = event\n\n    // Set the active event based on the event data\n    if (active.data.current?.type === 'calendar-event') {\n      setActiveEvent(active.data.current.event)\n    }\n  }\n\n  const handleDragEnd = (event: DragEndEvent) => {\n    const { active, over } = event\n\n    if (!active || !over || !activeEvent) {\n      setActiveEvent(null)\n      return\n    }\n\n    if (over.data.current?.type === 'time-cell') {\n      const { date, hour = 0, minute = 0 } = over.data.current\n\n      // Calculate the event duration in minutes\n      const originalStart = activeEvent.originalStart ?? activeEvent.start\n      const originalEnd = activeEvent.originalEnd ?? activeEvent.end\n      const durationMinutes = originalEnd.diff(originalStart, 'minute')\n\n      // Create new start time based on the drop target\n      const newStart = dayjs(date)\n        .hour(hour)\n        .minute(minute || 0)\n\n      // Create new end time by adding the original duration\n      let newEnd = newStart.add(durationMinutes, 'minute')\n      if (newEnd.isSame(newEnd.startOf('day'))) {\n        // If the new end time is at midnight, set it to 24 hours of partial day\n        newEnd = newEnd.subtract(1, 'day').endOf('day')\n      }\n\n      // Update the event with new times\n      updateEvent(activeEvent.id, {\n        start: newStart,\n        end: newEnd,\n      })\n    } else if (over.data.current?.type === 'day-cell') {\n      const { date } = over.data.current\n      const newDate = dayjs(date)\n\n      // For multi-day events, we need to preserve the duration in days\n      const isMultiDayEvent = !activeEvent.start.isSame(activeEvent.end, 'day')\n      const originalStart = activeEvent.originalStart ?? activeEvent.start\n      const originalEnd = activeEvent.originalEnd ?? activeEvent.end\n\n      if (isMultiDayEvent) {\n        if (view === 'week') {\n          // Get time components to preserve\n          const startHour = originalStart.hour()\n          const startMinute = originalStart.minute()\n          const endHour = originalEnd.hour()\n          const endMinute = originalEnd.minute()\n\n          // Calculate duration in days to preserve\n          const durationDays = originalEnd.diff(originalStart, 'day')\n\n          // Create new start and end dates\n          const newStart = newDate\n            .startOf('day')\n            .hour(startHour)\n            .minute(startMinute)\n          const newEnd = newStart\n            .add(durationDays, 'day')\n            .hour(endHour)\n            .minute(endMinute)\n\n          updateEvent(activeEvent.id, {\n            start: newStart,\n            end: newEnd,\n            originalStart: undefined,\n            originalEnd: undefined,\n          })\n        } else {\n          // For other views like month view\n          // Calculate the date shift (how many days we're moving the event)\n          const daysDifference = newDate.diff(\n            originalStart.startOf('day'),\n            'day'\n          )\n\n          // Calculate new start and end while preserving time components\n          const newStart = originalStart.add(daysDifference, 'day')\n          const newEnd = originalEnd.add(daysDifference, 'day')\n\n          updateEvent(activeEvent.id, {\n            start: newStart,\n            end: newEnd,\n            originalStart: undefined,\n            originalEnd: undefined,\n          })\n        }\n      } else {\n        // For single-day events, maintain the time but change the date\n        const newStart = newDate\n          .hour(activeEvent.start.hour())\n          .minute(activeEvent.start.minute())\n\n        // Calculate event duration and set new end time\n        const durationMinutes = activeEvent.end.diff(\n          activeEvent.start,\n          'minute'\n        )\n        const newEnd = newStart.add(durationMinutes, 'minute')\n\n        updateEvent(activeEvent.id, {\n          start: newStart,\n          end: newEnd,\n          originalStart: undefined,\n          originalEnd: undefined,\n        })\n      }\n    }\n\n    setActiveEvent(null)\n  }\n\n  const handleDragCancel = (_event: DragCancelEvent) => {\n    setActiveEvent(null)\n  }\n\n  // If drag and drop is disabled, just return children without DndContext\n  if (disableDragAndDrop) {\n    return children as React.ReactElement\n  }\n\n  return (\n    <DndContext\n      sensors={sensors}\n      onDragStart={handleDragStart}\n      onDragEnd={handleDragEnd}\n      onDragCancel={handleDragCancel}\n      collisionDetection={pointerWithin}\n    >\n      {children}\n      <DragOverlay modifiers={[snapCenterToCursor]}>\n        {activeEvent && (\n          <div\n            className={cn(\n              'cursor-grab truncate rounded bg-amber-200 p-2 text-[10px] shadow-lg sm:text-xs',\n              activeEvent.backgroundColor || 'bg-blue-500',\n              activeEvent.color || 'text-white'\n            )}\n          >\n            {activeEvent?.title}\n          </div>\n        )}\n      </DragOverlay>\n    </DndContext>\n  )\n}\n",
    "import dayjs from '@/lib/dayjs-config'\nimport React, {\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n  type ReactNode,\n} from 'react'\nimport { CalendarContext } from './context'\nimport type { CalendarEvent } from '@/components/types'\n\ninterface CalendarProviderProps {\n  children: ReactNode\n  events?: CalendarEvent[]\n  firstDayOfWeek?: number // 0 for Sunday, 1 for Monday, etc.\n  renderEvent?: (event: CalendarEvent) => ReactNode\n  onEventClick?: (event: CalendarEvent) => void\n  onCellClick?: (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs) => void\n  onViewChange?: (view: 'month' | 'week' | 'day' | 'year') => void\n  locale?: string\n  timezone?: string\n  disableCellClick?: boolean\n  disableEventClick?: boolean\n  disableDragAndDrop?: boolean\n  dayMaxEvents: number\n  stickyViewHeader: boolean\n  viewHeaderClassName: string\n}\n\nexport const CalendarProvider: React.FC<CalendarProviderProps> = ({\n  children,\n  events = [],\n  firstDayOfWeek = 0, // Default to Sunday,\n  renderEvent,\n  onEventClick,\n  onCellClick,\n  onViewChange,\n  locale,\n  timezone,\n  disableCellClick,\n  disableEventClick,\n  disableDragAndDrop,\n  dayMaxEvents,\n  stickyViewHeader,\n  viewHeaderClassName,\n}) => {\n  // State\n  const [currentDate, setCurrentDate] = useState<dayjs.Dayjs>(dayjs())\n  const [view, setView] = useState<'month' | 'week' | 'day' | 'year'>('month')\n  const [currentEvents, setCurrentEvents] = useState<CalendarEvent[]>(events)\n  const [isEventFormOpen, setIsEventFormOpen] = useState<boolean>(false)\n  const [selectedEvent, setSelectedEvent] = useState<CalendarEvent | null>(null)\n  const [selectedDate, setSelectedDate] = useState<dayjs.Dayjs | null>(null)\n  const [currentLocale, setCurrentLocale] = useState<string>(locale || 'en')\n  const [currentTimezone, setCurrentTimezone] = useState<string>(timezone || '')\n\n  // Update events when events prop changes\n  useEffect(() => {\n    if (events) {\n      setCurrentEvents(events)\n    }\n  }, [events])\n\n  // Configure locale when locale prop changes\n  useEffect(() => {\n    if (locale) {\n      setCurrentLocale(locale)\n      dayjs.locale(locale)\n    }\n  }, [locale])\n\n  // Configure timezone for currentDate when timezone prop changes\n  useEffect(() => {\n    if (timezone) {\n      setCurrentTimezone(timezone)\n      dayjs.tz.setDefault(timezone)\n    }\n  }, [timezone])\n\n  // Handlers\n  const selectDate = useCallback((date: dayjs.Dayjs) => {\n    setCurrentDate(date)\n  }, [])\n\n  const nextPeriod = useCallback(() => {\n    switch (view) {\n      case 'month':\n        setCurrentDate((currentDate) => currentDate.add(1, 'month'))\n        break\n      case 'week':\n        setCurrentDate((currentDate) => currentDate.add(1, 'week'))\n        break\n      case 'day':\n        setCurrentDate((currentDate) => currentDate.add(1, 'day'))\n        break\n      case 'year':\n        setCurrentDate((currentDate) => currentDate.add(1, 'year'))\n        break\n    }\n  }, [view])\n\n  const prevPeriod = useCallback(() => {\n    switch (view) {\n      case 'month':\n        setCurrentDate((currentDate) => currentDate.subtract(1, 'month'))\n        break\n      case 'week':\n        setCurrentDate((currentDate) => currentDate.subtract(1, 'week'))\n        break\n      case 'day':\n        setCurrentDate((currentDate) => currentDate.subtract(1, 'day'))\n        break\n      case 'year':\n        setCurrentDate((currentDate) => currentDate.subtract(1, 'year'))\n        break\n    }\n  }, [view])\n\n  const today = useCallback(() => {\n    setCurrentDate(dayjs())\n  }, [])\n\n  const addEvent = useCallback((event: CalendarEvent) => {\n    setCurrentEvents((prevEvents) => [...prevEvents, event])\n  }, [])\n\n  const updateEvent = useCallback(\n    (eventId: string, updatedEvent: Partial<CalendarEvent>) => {\n      setCurrentEvents((prevEvents) =>\n        prevEvents.map((event) =>\n          event.id === eventId ? { ...event, ...updatedEvent } : event\n        )\n      )\n    },\n    []\n  )\n\n  const deleteEvent = useCallback((eventId: string) => {\n    setCurrentEvents((prevEvents) =>\n      prevEvents.filter((event) => event.id !== eventId)\n    )\n  }, [])\n\n  const editEvent = useCallback((event: CalendarEvent) => {\n    setSelectedEvent(event)\n    setIsEventFormOpen(true)\n  }, [])\n\n  const closeEventForm = useCallback(() => {\n    setSelectedDate(null)\n    setSelectedEvent(null)\n    setIsEventFormOpen(false)\n  }, [])\n\n  // Custom handlers that call external callbacks\n  const handleViewChange = useCallback(\n    (newView: 'month' | 'week' | 'day' | 'year') => {\n      setView(newView)\n      onViewChange?.(newView)\n    },\n    [onViewChange]\n  )\n\n  const handleEventClick = useCallback(\n    (event: CalendarEvent) => {\n      if (disableCellClick) return\n      if (onEventClick) {\n        onEventClick(event)\n      } else {\n        editEvent(event)\n      }\n    },\n    [disableCellClick, onEventClick, editEvent]\n  )\n\n  const handleDateClick = useCallback(\n    (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs) => {\n      if (disableCellClick) return\n\n      if (onCellClick) {\n        onCellClick(startDate, endDate)\n      } else {\n        setSelectedDate(startDate)\n        setSelectedEvent({\n          title: `New Event`,\n          start: startDate,\n          end: endDate,\n          description: '',\n          allDay: false,\n          isRecurring: false,\n          recurrence: null,\n          parentEventId: null,\n        } as CalendarEvent)\n        setIsEventFormOpen(true)\n      }\n    },\n    [onCellClick, disableCellClick]\n  )\n\n  // Helper function to get the next occurrence based on frequency\n  const getNextOccurrence = useCallback(\n    (\n      date: dayjs.Dayjs,\n      freq: 'daily' | 'weekly' | 'monthly' | 'yearly',\n      int: number,\n      days?: number[]\n    ): dayjs.Dayjs => {\n      switch (freq) {\n        case 'daily':\n          return date.add(int, 'day')\n        case 'weekly':\n          if (days && days.length > 0) {\n            // If we have specific days of the week, find the next day in the list\n            let nextDate = date.add(1, 'day')\n            let loopCount = 0\n\n            // Prevent infinite loop - maximum 7 iterations to find the next day\n            while (loopCount < 7) {\n              if (days.includes(nextDate.day())) {\n                return nextDate\n              }\n              nextDate = nextDate.add(1, 'day')\n              loopCount++\n            }\n\n            // If we couldn't find the next day, just add the interval weeks\n            return date.add(int, 'week')\n          } else {\n            // Otherwise, just add the interval weeks\n            return date.add(int, 'week')\n          }\n        case 'monthly':\n          return date.add(int, 'month')\n        case 'yearly':\n          return date.add(int, 'year')\n      }\n    },\n    []\n  )\n\n  // Expand recurring events for a date range\n  const expandRecurringEvent = useCallback(\n    (\n      baseEvent: CalendarEvent,\n      startDate: dayjs.Dayjs,\n      endDate: dayjs.Dayjs\n    ): CalendarEvent[] => {\n      const expandedEvents: CalendarEvent[] = []\n      if (!baseEvent.recurrence) return [baseEvent]\n\n      const {\n        frequency,\n        interval,\n        endDate: recurrenceEndDate,\n        count,\n        daysOfWeek,\n        exceptions = [],\n      } = baseEvent.recurrence\n\n      // Get existing exceptions from the events array\n      const existingExceptions = events.filter(\n        (event) => event.parentEventId === baseEvent.id && event.isException\n      )\n\n      // Calculate the duration of the event\n      const duration = baseEvent.end.diff(baseEvent.start, 'minute')\n\n      // Determine the maximum end date for recurrence\n      const maxEndDate =\n        recurrenceEndDate && recurrenceEndDate.isBefore(endDate)\n          ? recurrenceEndDate\n          : endDate\n\n      let currentDate = baseEvent.start.clone()\n      let occurrences = 0\n\n      // If the recurring event starts after the end of our range, no events to generate\n      if (currentDate.isAfter(maxEndDate)) {\n        return []\n      }\n\n      // If we need to start in the middle of a recurrence pattern,\n      // fast-forward to find the first occurrence in our date range\n      if (currentDate.isBefore(startDate)) {\n        switch (frequency) {\n          case 'daily': {\n            const daysToAdd =\n              Math.floor(startDate.diff(currentDate, 'day') / interval) *\n              interval\n            if (daysToAdd > 0) {\n              currentDate = currentDate.add(daysToAdd, 'day')\n            }\n            break\n          }\n          case 'weekly': {\n            if (!daysOfWeek || daysOfWeek.length === 0) {\n              const weeksToAdd =\n                Math.floor(startDate.diff(currentDate, 'week') / interval) *\n                interval\n              if (weeksToAdd > 0) {\n                currentDate = currentDate.add(weeksToAdd, 'week')\n              }\n            }\n            break\n          }\n          case 'monthly': {\n            const monthsToAdd =\n              Math.floor(startDate.diff(currentDate, 'month') / interval) *\n              interval\n            if (monthsToAdd > 0) {\n              currentDate = currentDate.add(monthsToAdd, 'month')\n            }\n            break\n          }\n          case 'yearly': {\n            const yearsToAdd =\n              Math.floor(startDate.diff(currentDate, 'year') / interval) *\n              interval\n            if (yearsToAdd > 0) {\n              currentDate = currentDate.add(yearsToAdd, 'year')\n            }\n            break\n          }\n        }\n      }\n\n      while (\n        (currentDate.isBefore(maxEndDate) ||\n          currentDate.isSame(maxEndDate, 'day')) &&\n        (count === undefined || occurrences < count)\n      ) {\n        // Format current date for comparison\n        const currentDateStr = currentDate.format('YYYY-MM-DD')\n\n        // Skip if this date is in exceptions\n        if (\n          exceptions.some(\n            (date) => date.format('YYYY-MM-DD') === currentDateStr\n          )\n        ) {\n          // Move to the next occurrence\n          currentDate = getNextOccurrence(\n            currentDate,\n            frequency,\n            interval,\n            daysOfWeek\n          )\n          continue\n        }\n\n        // Skip if it's a weekly recurrence with specified days and current day is not included\n        if (\n          frequency === 'weekly' &&\n          daysOfWeek &&\n          daysOfWeek.length > 0 &&\n          !daysOfWeek.includes(currentDate.day())\n        ) {\n          currentDate = currentDate.add(1, 'day')\n          continue\n        }\n\n        // Check if we have a custom exception for this occurrence\n        const exceptionEvent = existingExceptions.find(\n          (event) => event.start.format('YYYY-MM-DD') === currentDateStr\n        )\n\n        if (exceptionEvent) {\n          // Use the exception instead of generating a new event\n          expandedEvents.push(exceptionEvent)\n        } else if (currentDate.isAfter(startDate.subtract(1, 'day'))) {\n          // Create a new occurrence if it falls within the requested range\n          const eventInstance: CalendarEvent = {\n            ...baseEvent,\n            id: `${baseEvent.id}-${currentDate.format('YYYYMMDD')}`,\n            start: currentDate.clone(),\n            end: currentDate.clone().add(duration, 'minute'),\n            isRecurring: true,\n            parentEventId: baseEvent.id,\n          }\n          expandedEvents.push(eventInstance)\n        }\n\n        occurrences++\n        currentDate = getNextOccurrence(\n          currentDate,\n          frequency,\n          interval,\n          daysOfWeek\n        )\n      }\n\n      return expandedEvents\n    },\n    [events, getNextOccurrence]\n  )\n\n  // Event query functions\n  const getEventsForDateRange = useCallback(\n    (start: dayjs.Dayjs, end: dayjs.Dayjs): CalendarEvent[] => {\n      const startDate = start.startOf('day')\n      const endDate = end.endOf('day')\n\n      // Filter regular events first\n      const regularEvents = events.filter((event) => {\n        // Fixed logic for checking if event overlaps with the date range\n        return (\n          // Case 1: Event starts within the range\n          ((event.start.isAfter(startDate) || event.start.isSame(startDate)) &&\n            (event.start.isBefore(endDate) || event.start.isSame(endDate))) ||\n          // Case 2: Event ends within the range\n          ((event.end.isAfter(startDate) || event.end.isSame(startDate)) &&\n            (event.end.isBefore(endDate) || event.end.isSame(endDate))) ||\n          // Case 3: Event spans across the entire range\n          (event.start.isBefore(startDate) && event.end.isAfter(endDate))\n        )\n      })\n\n      // Find parent recurring events that need to be expanded\n      const recurringParentEvents = events.filter(\n        (event) => event.recurrence && !event.parentEventId\n      )\n\n      // Expand recurring events for this range\n      let recurringEvents: CalendarEvent[] = []\n      recurringParentEvents.forEach((parentEvent) => {\n        const expanded = expandRecurringEvent(parentEvent, startDate, endDate)\n        recurringEvents = [...recurringEvents, ...expanded]\n      })\n\n      // Combine all events and remove any duplicates\n      return [...regularEvents, ...recurringEvents].filter(\n        (event, index, self) =>\n          index === self.findIndex((e) => e.id === event.id)\n      )\n    },\n    [events, expandRecurringEvent]\n  )\n\n  const getEventsForDate = useCallback(\n    (date: dayjs.Dayjs): CalendarEvent[] => {\n      const day = date.startOf('day')\n      const nextDay = day.add(1, 'day')\n      return getEventsForDateRange(day, nextDay)\n    },\n    [getEventsForDateRange]\n  )\n\n  // Recurring event operations\n  const addRecurringEvent = useCallback((event: CalendarEvent) => {\n    setCurrentEvents((prevEvents) => [...prevEvents, event])\n  }, [])\n\n  const deleteRecurringEvent = useCallback(\n    (eventId: string, deleteAll: boolean) => {\n      setCurrentEvents((prevEvents) => {\n        // Find the event by ID\n        const event = prevEvents.find((e) => e.id === eventId)\n        if (!event) return prevEvents\n\n        if (event.parentEventId && !deleteAll) {\n          // This is a recurring instance, and we only want to delete this instance\n\n          // Find the parent event\n          const parentEvent = prevEvents.find(\n            (e) => e.id === event.parentEventId\n          )\n          if (!parentEvent || !parentEvent.recurrence) return prevEvents\n\n          // Add this date to the exceptions list\n          return prevEvents.map((e) => {\n            if (e.id === event.parentEventId) {\n              return {\n                ...e,\n                recurrence: {\n                  ...e.recurrence!,\n                  exceptions: [\n                    ...(e.recurrence!.exceptions || []),\n                    event.start.startOf('day'),\n                  ],\n                },\n              }\n            }\n            return e\n          })\n        } else if (event.parentEventId && deleteAll) {\n          // We want to delete all occurrences of this recurring event\n          // Find the parent ID and delete it and all its children\n          return prevEvents.filter(\n            (e) =>\n              e.id !== event.parentEventId &&\n              e.parentEventId !== event.parentEventId\n          )\n        } else if (event.recurrence) {\n          // This is a parent recurring event, delete it and all its instances\n          return prevEvents.filter(\n            (e) => e.id !== event.id && e.parentEventId !== event.id\n          )\n        } else {\n          // Regular event, just delete it\n          return prevEvents.filter((e) => e.id !== event.id)\n        }\n      })\n    },\n    []\n  )\n\n  const updateRecurringEvent = useCallback(\n    (\n      eventId: string,\n      updatedEvent: Partial<CalendarEvent>,\n      updateAll: boolean\n    ) => {\n      setCurrentEvents((prevEvents) => {\n        // Find the event by ID\n        const event = prevEvents.find((e) => e.id === eventId)\n        if (!event) return prevEvents\n\n        if (event.parentEventId && !updateAll) {\n          // This is a recurring instance being updated individually\n\n          // Create an exception with the updates\n          const exceptionEvent: CalendarEvent = {\n            ...event,\n            ...updatedEvent,\n            isException: true,\n          }\n\n          // Add the exception to the store and add this date to the parent's exceptions list\n          const updatedEvents = prevEvents.map((e) => {\n            if (e.id === event.parentEventId) {\n              return {\n                ...e,\n                recurrence: {\n                  ...e.recurrence!,\n                  exceptions: [\n                    ...(e.recurrence!.exceptions || []),\n                    event.start.startOf('day'),\n                  ],\n                },\n              }\n            }\n            return e\n          })\n\n          return [...updatedEvents, exceptionEvent]\n        } else if (event.parentEventId && updateAll) {\n          // Update all occurrences by updating the parent\n          // Find the parent and update it\n          return prevEvents.map((e) => {\n            if (e.id === event.parentEventId) {\n              return { ...e, ...updatedEvent }\n            }\n            return e\n          })\n        } else if (event.recurrence) {\n          // This is a parent recurring event, update it directly\n          return prevEvents.map((e) => {\n            if (e.id === event.id) {\n              return { ...e, ...updatedEvent }\n            }\n            return e\n          })\n        } else {\n          // Regular event, just update it\n          return prevEvents.map((e) => {\n            if (e.id === event.id) {\n              return { ...e, ...updatedEvent }\n            }\n            return e\n          })\n        }\n      })\n    },\n    []\n  )\n\n  const createExceptionForRecurringEvent = useCallback(\n    (eventId: string, date: dayjs.Dayjs) => {\n      setCurrentEvents((prevEvents) => {\n        // Find the event first\n        const event = prevEvents.find((e) => e.id === eventId)\n        if (!event || !event.recurrence) return prevEvents\n\n        // Add the date to exceptions\n        return prevEvents.map((e) => {\n          if (e.id === eventId) {\n            return {\n              ...e,\n              recurrence: {\n                ...e.recurrence!,\n                exceptions: [\n                  ...(e.recurrence!.exceptions || []),\n                  date.startOf('day'),\n                ],\n              },\n            }\n          }\n          return e\n        })\n      })\n    },\n    []\n  )\n\n  // Create the context value\n  const contextValue = useMemo(\n    () => ({\n      currentDate,\n      view,\n      events: currentEvents,\n      currentLocale,\n      isEventFormOpen,\n      selectedEvent,\n      selectedDate,\n      firstDayOfWeek,\n      setCurrentDate,\n      selectDate,\n      setView: handleViewChange,\n      nextPeriod,\n      prevPeriod,\n      today,\n      addEvent,\n      updateEvent,\n      deleteEvent,\n      openEventForm: () => setIsEventFormOpen(true),\n      closeEventForm,\n      getEventsForDate,\n      getEventsForDateRange,\n      expandRecurringEvent,\n      addRecurringEvent,\n      deleteRecurringEvent,\n      updateRecurringEvent,\n      createExceptionForRecurringEvent,\n      renderEvent,\n      onEventClick: handleEventClick,\n      onCellClick: handleDateClick,\n      locale,\n      timezone: currentTimezone,\n      disableCellClick,\n      disableEventClick,\n      disableDragAndDrop,\n      dayMaxEvents,\n      stickyViewHeader,\n      viewHeaderClassName,\n    }),\n    [\n      currentDate,\n      view,\n      currentEvents,\n      currentLocale,\n      isEventFormOpen,\n      selectedEvent,\n      selectedDate,\n      firstDayOfWeek,\n      selectDate,\n      handleViewChange,\n      nextPeriod,\n      prevPeriod,\n      today,\n      addEvent,\n      updateEvent,\n      deleteEvent,\n      closeEventForm,\n      getEventsForDate,\n      getEventsForDateRange,\n      expandRecurringEvent,\n      addRecurringEvent,\n      deleteRecurringEvent,\n      updateRecurringEvent,\n      createExceptionForRecurringEvent,\n      renderEvent,\n      handleEventClick,\n      handleDateClick,\n      locale,\n      currentTimezone,\n      disableCellClick,\n      disableEventClick,\n      disableDragAndDrop,\n      dayMaxEvents,\n      stickyViewHeader,\n      viewHeaderClassName,\n    ]\n  )\n\n  return (\n    <CalendarContext.Provider value={contextValue}>\n      {children}\n    </CalendarContext.Provider>\n  )\n}\n"
  ],
  "mappings": ";AACA,4BAAS,4BAAiB;AAC1B,4BAAgB;;;ACAhB;AAmDO,IAAM,kBAAkB,cAC7B,SACF;AAEO,IAAM,qBAAqB,MAAM;AAAA,EACtC,MAAM,UAAU,WAAW,eAAe;AAAA,EAC1C,IAAI,YAAY,WAAW;AAAA,IACzB,MAAM,IAAI,MAAM,2DAA2D;AAAA,EAC7E;AAAA,EACA,OAAO;AAAA;AAGF,IAAM,2BAA2B,MAAM;AAAA,EAC5C,MAAM,UAAU,WAAW,eAAe;AAAA,EAC1C,IAAI,YAAY,WAAW;AAAA,IACzB,MAAM,IAAI,MAAM,uDAAuD;AAAA,EACzE;AAAA,EACA,OAAO;AAAA,IACL,aAAa,QAAQ;AAAA,IACrB,MAAM,QAAQ;AAAA,IACd,QAAQ,QAAQ;AAAA,IAChB,iBAAiB,QAAQ;AAAA,IACzB,eAAe,QAAQ;AAAA,IACvB,cAAc,QAAQ;AAAA,IACtB,gBAAgB,QAAQ;AAAA,IACxB,gBAAgB,QAAQ;AAAA,IACxB,YAAY,QAAQ;AAAA,IACpB,SAAS,QAAQ;AAAA,IACjB,YAAY,QAAQ;AAAA,IACpB,YAAY,QAAQ;AAAA,IACpB,OAAO,QAAQ;AAAA,IACf,UAAU,QAAQ;AAAA,IAClB,aAAa,QAAQ;AAAA,IACrB,aAAa,QAAQ;AAAA,IACrB,eAAe,QAAQ;AAAA,IACvB,gBAAgB,QAAQ;AAAA,EAC1B;AAAA;;;ACxFF;AACA;;;ACDA;;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA,MAAM,OAAO,OAAO;AACpB,MAAM,OAAO,UAAU;AACvB,MAAM,OAAO,aAAa;AAC1B,MAAM,OAAO,cAAc;AAC3B,MAAM,OAAO,SAAS;AACtB,MAAM,OAAO,MAAM;AACnB,MAAM,OAAO,QAAQ;AACrB,MAAM,OAAO,GAAG;AAChB,MAAM,OAAO,UAAU;AAEvB,IAAe;;;ADrKf;AAEO,SAAS,EAAE,IAAI,QAAsB;AAAA,EAC1C,OAAO,QAAQ,KAAK,MAAM,CAAC;AAAA;;;;;AEL7B;;AAIA,IAAM,gBAAgB,IACpB,qOACA;AAAA,EACE,UAAU;AAAA,IACR,SAAS;AAAA,MACP,SAAS;AAAA,MACT,aACE;AAAA,MACF,SACE;AAAA,MACF,WACE;AAAA,MACF,SACE;AAAA,MACF,SACE;AAAA,IACJ;AAAA,EACF;AAAA,EACA,iBAAiB;AAAA,IACf,SAAS;AAAA,EACX;AACF,CACF;;AC1BA;AACA,gBAAS;;AAIT,IAAM,gBAAgB,KACpB,gZACA;AAAA,EACE,UAAU;AAAA,IACR,SAAS;AAAA,MACP,SACE;AAAA,MACF,WACE;AAAA,MACF,aACE;AAAA,MACF,SACE;AAAA,IACJ;AAAA,EACF;AAAA,EACA,iBAAiB;AAAA,IACf,SAAS;AAAA,EACX;AACF,CACF;;ACxBA,iBAAS;AACT,gBAAS;;AAIT,IAAM,iBAAiB,KACrB,+bACA;AAAA,EACE,UAAU;AAAA,IACR,SAAS;AAAA,MACP,SACE;AAAA,MACF,aACE;AAAA,MACF,SACE;AAAA,MACF,WACE;AAAA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",
  "debugId": "6116CC68B191B54164756E2164756E21",
  "names": []
}
|