@ilamy/calendar 0.2.0 → 0.3.0
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 +29 -9
- package/dist/index.d.ts +133 -1
- package/dist/index.js +594 -375
- package/package.json +14 -14
package/dist/index.js
CHANGED
|
@@ -884,7 +884,19 @@ import { useImperativeHandle, useState } from "react";
|
|
|
884
884
|
import { useDraggable } from "@dnd-kit/core";
|
|
885
885
|
import { AnimatePresence, motion } from "motion/react";
|
|
886
886
|
import { memo } from "react";
|
|
887
|
-
import { jsx as jsx14 } from "react/jsx-runtime";
|
|
887
|
+
import { jsx as jsx14, jsxs as jsxs6 } from "react/jsx-runtime";
|
|
888
|
+
var getBorderRadiusClass = (isTruncatedStart, isTruncatedEnd) => {
|
|
889
|
+
if (isTruncatedStart && isTruncatedEnd) {
|
|
890
|
+
return "rounded-none";
|
|
891
|
+
}
|
|
892
|
+
if (isTruncatedStart) {
|
|
893
|
+
return "rounded-r-md rounded-l-none";
|
|
894
|
+
}
|
|
895
|
+
if (isTruncatedEnd) {
|
|
896
|
+
return "rounded-l-md rounded-r-none";
|
|
897
|
+
}
|
|
898
|
+
return "rounded-md";
|
|
899
|
+
};
|
|
888
900
|
function DraggableEventUnmemoized({
|
|
889
901
|
elementId,
|
|
890
902
|
event,
|
|
@@ -901,14 +913,27 @@ function DraggableEventUnmemoized({
|
|
|
901
913
|
},
|
|
902
914
|
disabled: disableDrag || disableDragAndDrop
|
|
903
915
|
});
|
|
904
|
-
const DefaultEventContent = () =>
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
916
|
+
const DefaultEventContent = () => {
|
|
917
|
+
const enhancedEvent = event;
|
|
918
|
+
const isTruncatedStart = enhancedEvent.isTruncatedStart;
|
|
919
|
+
const isTruncatedEnd = enhancedEvent.isTruncatedEnd;
|
|
920
|
+
return /* @__PURE__ */ jsxs6("div", {
|
|
921
|
+
className: cn(event.backgroundColor || "bg-blue-500", event.color || "text-white", "h-full w-full px-1 border-[1.5px] border-card text-left overflow-clip relative", getBorderRadiusClass(isTruncatedStart, isTruncatedEnd)),
|
|
922
|
+
style: { backgroundColor: event.backgroundColor, color: event.color },
|
|
923
|
+
children: [
|
|
924
|
+
isTruncatedStart && /* @__PURE__ */ jsx14("div", {
|
|
925
|
+
className: "absolute left-0 top-0 bottom-0 w-0.5 bg-foreground/25"
|
|
926
|
+
}),
|
|
927
|
+
/* @__PURE__ */ jsx14("p", {
|
|
928
|
+
className: cn("text-[10px] font-semibold sm:text-xs mt-0.5", isTruncatedStart && "pl-1", isTruncatedEnd && "pr-1"),
|
|
929
|
+
children: event.title
|
|
930
|
+
}),
|
|
931
|
+
isTruncatedEnd && /* @__PURE__ */ jsx14("div", {
|
|
932
|
+
className: "absolute right-0 top-0 bottom-0 w-0.5 bg-foreground/25"
|
|
933
|
+
})
|
|
934
|
+
]
|
|
935
|
+
});
|
|
936
|
+
};
|
|
912
937
|
return /* @__PURE__ */ jsx14(AnimatePresence, {
|
|
913
938
|
mode: "wait",
|
|
914
939
|
children: /* @__PURE__ */ jsx14(motion.div, {
|
|
@@ -936,7 +961,7 @@ var DraggableEvent = memo(DraggableEventUnmemoized, (prevProps, nextProps) => {
|
|
|
936
961
|
});
|
|
937
962
|
|
|
938
963
|
// src/features/month-view/components/all-events-dialog.tsx
|
|
939
|
-
import { jsx as jsx15, jsxs as
|
|
964
|
+
import { jsx as jsx15, jsxs as jsxs7 } from "react/jsx-runtime";
|
|
940
965
|
var AllEventDialog = ({ ref }) => {
|
|
941
966
|
const [dialogOpen, setDialogOpen] = useState(false);
|
|
942
967
|
const [selectedDayEvents, setSelectedDayEvents] = useState(null);
|
|
@@ -954,7 +979,7 @@ var AllEventDialog = ({ ref }) => {
|
|
|
954
979
|
return /* @__PURE__ */ jsx15(Dialog, {
|
|
955
980
|
open: dialogOpen,
|
|
956
981
|
onOpenChange: setDialogOpen,
|
|
957
|
-
children: /* @__PURE__ */
|
|
982
|
+
children: /* @__PURE__ */ jsxs7(DialogContent, {
|
|
958
983
|
className: "max-h-[80vh] max-w-md overflow-y-auto",
|
|
959
984
|
children: [
|
|
960
985
|
/* @__PURE__ */ jsx15(DialogHeader, {
|
|
@@ -1032,7 +1057,7 @@ function DroppableCell({
|
|
|
1032
1057
|
}
|
|
1033
1058
|
|
|
1034
1059
|
// src/features/month-view/components/day-cell.tsx
|
|
1035
|
-
import { jsx as jsx17, jsxs as
|
|
1060
|
+
import { jsx as jsx17, jsxs as jsxs8, Fragment } from "react/jsx-runtime";
|
|
1036
1061
|
var DayCell = ({
|
|
1037
1062
|
index,
|
|
1038
1063
|
day,
|
|
@@ -1044,7 +1069,8 @@ var DayCell = ({
|
|
|
1044
1069
|
getEventsForDateRange,
|
|
1045
1070
|
currentDate,
|
|
1046
1071
|
firstDayOfWeek,
|
|
1047
|
-
dayMaxEvents = 0
|
|
1072
|
+
dayMaxEvents = 0,
|
|
1073
|
+
t
|
|
1048
1074
|
} = useCalendarContext();
|
|
1049
1075
|
const todayEvents = getEventsForDateRange(day.startOf("day"), day.endOf("day"));
|
|
1050
1076
|
const firstDayOfMonth = currentDate.startOf("month");
|
|
@@ -1064,7 +1090,7 @@ var DayCell = ({
|
|
|
1064
1090
|
const isLastColumn = index === 6;
|
|
1065
1091
|
const hiddenEventsCount = todayEvents.length - dayMaxEvents;
|
|
1066
1092
|
const hasHiddenEvents = hiddenEventsCount > 0;
|
|
1067
|
-
return /* @__PURE__ */
|
|
1093
|
+
return /* @__PURE__ */ jsxs8(Fragment, {
|
|
1068
1094
|
children: [
|
|
1069
1095
|
/* @__PURE__ */ jsx17(DroppableCell, {
|
|
1070
1096
|
id: `day-cell-${day.format("YYYY-MM-DD")}`,
|
|
@@ -1072,7 +1098,7 @@ var DayCell = ({
|
|
|
1072
1098
|
"data-testid": `day-cell-${day.format("YYYY-MM-DD")}`,
|
|
1073
1099
|
date: day,
|
|
1074
1100
|
className: cn("cursor-pointer overflow-clip p-1 hover:bg-accent min-h-[60px]", !isCurrentMonth && "bg-secondary text-muted-foreground", isLastColumn && "border-r-0", className),
|
|
1075
|
-
children: /* @__PURE__ */
|
|
1101
|
+
children: /* @__PURE__ */ jsxs8("div", {
|
|
1076
1102
|
className: "flex flex-col gap-1",
|
|
1077
1103
|
children: [
|
|
1078
1104
|
/* @__PURE__ */ jsx17("div", {
|
|
@@ -1083,7 +1109,7 @@ var DayCell = ({
|
|
|
1083
1109
|
className: "h-[20px] w-full",
|
|
1084
1110
|
"data-testid": event?.title
|
|
1085
1111
|
}, `empty-${rowIndex}`)),
|
|
1086
|
-
hasHiddenEvents && /* @__PURE__ */
|
|
1112
|
+
hasHiddenEvents && /* @__PURE__ */ jsxs8("div", {
|
|
1087
1113
|
className: "text-muted-foreground hover:text-foreground cursor-pointer text-[10px] whitespace-nowrap sm:text-xs mt-1",
|
|
1088
1114
|
onClick: (e) => {
|
|
1089
1115
|
e.stopPropagation();
|
|
@@ -1101,7 +1127,8 @@ var DayCell = ({
|
|
|
1101
1127
|
children: [
|
|
1102
1128
|
"+",
|
|
1103
1129
|
hiddenEventsCount,
|
|
1104
|
-
"
|
|
1130
|
+
" ",
|
|
1131
|
+
t("more")
|
|
1105
1132
|
]
|
|
1106
1133
|
})
|
|
1107
1134
|
]
|
|
@@ -1117,7 +1144,7 @@ var DayCell = ({
|
|
|
1117
1144
|
// src/features/month-view/components/month-header/month-header.tsx
|
|
1118
1145
|
import { AnimatePresence as AnimatePresence2, motion as motion2 } from "motion/react";
|
|
1119
1146
|
import { useMemo } from "react";
|
|
1120
|
-
import { jsx as jsx18, jsxs as
|
|
1147
|
+
import { jsx as jsx18, jsxs as jsxs9 } from "react/jsx-runtime";
|
|
1121
1148
|
var MonthHeader = ({ className }) => {
|
|
1122
1149
|
const {
|
|
1123
1150
|
firstDayOfWeek,
|
|
@@ -1141,11 +1168,11 @@ var MonthHeader = ({ className }) => {
|
|
|
1141
1168
|
return { days, shortDays };
|
|
1142
1169
|
}, [firstDayOfWeek, currentLocale]);
|
|
1143
1170
|
return /* @__PURE__ */ jsx18("div", {
|
|
1144
|
-
className: cn("grid grid-cols-7 border-b", stickyViewHeader && "sticky top-0 z-
|
|
1171
|
+
className: cn("grid grid-cols-7 border-b", stickyViewHeader && "sticky top-0 z-20", viewHeaderClassName, className),
|
|
1145
1172
|
"data-testid": "month-header",
|
|
1146
1173
|
children: weekDays.days.map((weekDay, index) => /* @__PURE__ */ jsx18(AnimatePresence2, {
|
|
1147
1174
|
mode: "wait",
|
|
1148
|
-
children: /* @__PURE__ */
|
|
1175
|
+
children: /* @__PURE__ */ jsxs9(motion2.div, {
|
|
1149
1176
|
initial: { opacity: 0, y: -10 },
|
|
1150
1177
|
animate: { opacity: 1, y: 0 },
|
|
1151
1178
|
exit: { opacity: 0, y: -10 },
|
|
@@ -1216,6 +1243,8 @@ var useProcessedWeekEvents = ({
|
|
|
1216
1243
|
const eventEnd = dayjs_config_default.min(event.end.startOf("day"), weekEnd);
|
|
1217
1244
|
const startCol = Math.max(0, eventStart.diff(weekStart, "day"));
|
|
1218
1245
|
const endCol = Math.min(6, eventEnd.diff(weekStart, "day"));
|
|
1246
|
+
const isTruncatedStart = event.start.startOf("day").isBefore(weekStart);
|
|
1247
|
+
const isTruncatedEnd = event.end.startOf("day").isAfter(weekEnd);
|
|
1219
1248
|
let placedSuccessfully = false;
|
|
1220
1249
|
let assignedRow = -1;
|
|
1221
1250
|
for (let row = 0;row < dayMaxEvents; row++) {
|
|
@@ -1242,7 +1271,9 @@ var useProcessedWeekEvents = ({
|
|
|
1242
1271
|
top: DAY_NUMBER_HEIGHT + GAP_BETWEEN_ELEMENTS + assignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),
|
|
1243
1272
|
height: EVENT_BAR_HEIGHT,
|
|
1244
1273
|
position: assignedRow,
|
|
1245
|
-
...event
|
|
1274
|
+
...event,
|
|
1275
|
+
isTruncatedStart,
|
|
1276
|
+
isTruncatedEnd
|
|
1246
1277
|
});
|
|
1247
1278
|
placedSuccessfully = true;
|
|
1248
1279
|
}
|
|
@@ -1273,7 +1304,9 @@ var useProcessedWeekEvents = ({
|
|
|
1273
1304
|
top: DAY_NUMBER_HEIGHT + GAP_BETWEEN_ELEMENTS + truncatedAssignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),
|
|
1274
1305
|
height: EVENT_BAR_HEIGHT,
|
|
1275
1306
|
position: truncatedAssignedRow,
|
|
1276
|
-
...event
|
|
1307
|
+
...event,
|
|
1308
|
+
isTruncatedStart: true,
|
|
1309
|
+
isTruncatedEnd
|
|
1277
1310
|
});
|
|
1278
1311
|
placedSuccessfully = true;
|
|
1279
1312
|
break;
|
|
@@ -1284,6 +1317,8 @@ var useProcessedWeekEvents = ({
|
|
|
1284
1317
|
for (const event of sortedSingleDay) {
|
|
1285
1318
|
const eventStart = dayjs_config_default.max(event.start.startOf("day"), weekStart);
|
|
1286
1319
|
const col = Math.max(0, eventStart.diff(weekStart, "day"));
|
|
1320
|
+
const isTruncatedStart = false;
|
|
1321
|
+
const isTruncatedEnd = false;
|
|
1287
1322
|
let assignedRow = -1;
|
|
1288
1323
|
for (let row = 0;row < dayMaxEvents; row++) {
|
|
1289
1324
|
if (!grid[row][col].taken) {
|
|
@@ -1299,7 +1334,9 @@ var useProcessedWeekEvents = ({
|
|
|
1299
1334
|
top: DAY_NUMBER_HEIGHT + GAP_BETWEEN_ELEMENTS + assignedRow * (EVENT_BAR_HEIGHT + GAP_BETWEEN_ELEMENTS),
|
|
1300
1335
|
height: EVENT_BAR_HEIGHT,
|
|
1301
1336
|
position: assignedRow,
|
|
1302
|
-
...event
|
|
1337
|
+
...event,
|
|
1338
|
+
isTruncatedStart,
|
|
1339
|
+
isTruncatedEnd
|
|
1303
1340
|
});
|
|
1304
1341
|
}
|
|
1305
1342
|
}
|
|
@@ -1312,7 +1349,7 @@ var WeekEventsLayer = ({ days }) => {
|
|
|
1312
1349
|
const weekStart = days[0];
|
|
1313
1350
|
const processedWeekEvents = useProcessedWeekEvents({ days });
|
|
1314
1351
|
return /* @__PURE__ */ jsx19("div", {
|
|
1315
|
-
className: "relative w-full h-full pointer-events-none z-
|
|
1352
|
+
className: "relative w-full h-full pointer-events-none z-10 overflow-clip",
|
|
1316
1353
|
children: processedWeekEvents.map((event) => {
|
|
1317
1354
|
return /* @__PURE__ */ jsx19("div", {
|
|
1318
1355
|
className: "absolute z-10 pointer-events-auto overflow-clip",
|
|
@@ -1334,7 +1371,7 @@ var WeekEventsLayer = ({ days }) => {
|
|
|
1334
1371
|
};
|
|
1335
1372
|
|
|
1336
1373
|
// src/features/month-view/components/view/month-view.tsx
|
|
1337
|
-
import { jsx as jsx20, jsxs as
|
|
1374
|
+
import { jsx as jsx20, jsxs as jsxs10 } from "react/jsx-runtime";
|
|
1338
1375
|
var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
1339
1376
|
const allEventsDialogRef = React5.useRef(null);
|
|
1340
1377
|
const { currentDate, firstDayOfWeek } = useCalendarContext();
|
|
@@ -1355,7 +1392,7 @@ var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
|
1355
1392
|
}
|
|
1356
1393
|
return days;
|
|
1357
1394
|
}, [adjustedFirstDayOfCalendar]);
|
|
1358
|
-
return /* @__PURE__ */
|
|
1395
|
+
return /* @__PURE__ */ jsxs10("div", {
|
|
1359
1396
|
className: "flex h-full flex-col",
|
|
1360
1397
|
"data-testid": "month-view",
|
|
1361
1398
|
children: [
|
|
@@ -1376,7 +1413,7 @@ var MonthView = ({ dayMaxEvents = 3 }) => {
|
|
|
1376
1413
|
className: "relative grid h-full grid-cols-7 grid-rows-6 overflow-auto flex-1",
|
|
1377
1414
|
"data-testid": "month-calendar-grid",
|
|
1378
1415
|
children: calendarDays.map((days, index) => {
|
|
1379
|
-
return /* @__PURE__ */
|
|
1416
|
+
return /* @__PURE__ */ jsxs10("div", {
|
|
1380
1417
|
className: "relative col-span-7 grid grid-cols-7",
|
|
1381
1418
|
"data-testid": `week-row-${index}`,
|
|
1382
1419
|
children: [
|
|
@@ -1412,7 +1449,7 @@ import weekOfYear2 from "dayjs/plugin/weekOfYear";
|
|
|
1412
1449
|
|
|
1413
1450
|
// src/features/week-view/week-all-day-row.tsx
|
|
1414
1451
|
import { useMemo as useMemo3 } from "react";
|
|
1415
|
-
import { jsx as jsx21, jsxs as
|
|
1452
|
+
import { jsx as jsx21, jsxs as jsxs11 } from "react/jsx-runtime";
|
|
1416
1453
|
var WeekAllDayRow = () => {
|
|
1417
1454
|
const { currentDate, getEventsForDateRange, firstDayOfWeek } = useCalendarContext();
|
|
1418
1455
|
const startOfWeek = currentDate.startOf("week").day(firstDayOfWeek);
|
|
@@ -1478,7 +1515,7 @@ var WeekAllDayRow = () => {
|
|
|
1478
1515
|
allDayRowsCount: Math.max(1, rows.length)
|
|
1479
1516
|
};
|
|
1480
1517
|
}, [allDayEvents, adjustedStartOfWeek, endOfWeek]);
|
|
1481
|
-
return /* @__PURE__ */
|
|
1518
|
+
return /* @__PURE__ */ jsxs11("div", {
|
|
1482
1519
|
className: "grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1 relative",
|
|
1483
1520
|
"data-testid": "week-all-day-row",
|
|
1484
1521
|
children: [
|
|
@@ -1518,7 +1555,7 @@ var WeekAllDayRow = () => {
|
|
|
1518
1555
|
|
|
1519
1556
|
// src/features/week-view/week-header.tsx
|
|
1520
1557
|
import { AnimatePresence as AnimatePresence4, motion as motion4 } from "motion/react";
|
|
1521
|
-
import { jsx as jsx22, jsxs as
|
|
1558
|
+
import { jsx as jsx22, jsxs as jsxs12 } from "react/jsx-runtime";
|
|
1522
1559
|
var WeekHeader = ({ className }) => {
|
|
1523
1560
|
const {
|
|
1524
1561
|
currentDate,
|
|
@@ -1535,13 +1572,13 @@ var WeekHeader = ({ className }) => {
|
|
|
1535
1572
|
for (let i = 0;i < 7; i++) {
|
|
1536
1573
|
weekDays.push(adjustedStartOfWeek.add(i, "day"));
|
|
1537
1574
|
}
|
|
1538
|
-
return /* @__PURE__ */
|
|
1539
|
-
className: cn("grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1", stickyViewHeader && "sticky top-0 z-
|
|
1575
|
+
return /* @__PURE__ */ jsxs12("div", {
|
|
1576
|
+
className: cn("grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1", stickyViewHeader && "sticky top-0 z-20", viewHeaderClassName, className),
|
|
1540
1577
|
"data-testid": "week-header",
|
|
1541
1578
|
children: [
|
|
1542
1579
|
/* @__PURE__ */ jsx22("div", {
|
|
1543
1580
|
className: "col-span-1 w-14 shrink-0 items-center justify-center border-x border-b p-2",
|
|
1544
|
-
children: /* @__PURE__ */
|
|
1581
|
+
children: /* @__PURE__ */ jsxs12("div", {
|
|
1545
1582
|
className: "flex flex-col items-center justify-center",
|
|
1546
1583
|
children: [
|
|
1547
1584
|
/* @__PURE__ */ jsx22("span", {
|
|
@@ -1559,7 +1596,7 @@ var WeekHeader = ({ className }) => {
|
|
|
1559
1596
|
const isToday = day.isSame(dayjs_config_default(), "day");
|
|
1560
1597
|
return /* @__PURE__ */ jsx22(AnimatePresence4, {
|
|
1561
1598
|
mode: "wait",
|
|
1562
|
-
children: /* @__PURE__ */
|
|
1599
|
+
children: /* @__PURE__ */ jsxs12(motion4.div, {
|
|
1563
1600
|
initial: { opacity: 0, y: -10 },
|
|
1564
1601
|
animate: { opacity: 1, y: 0 },
|
|
1565
1602
|
exit: { opacity: 0, y: -10 },
|
|
@@ -1698,7 +1735,7 @@ var DayEventsLayer = ({
|
|
|
1698
1735
|
const todayEvents = useProcessedDayEvents({ day });
|
|
1699
1736
|
return /* @__PURE__ */ jsx23("div", {
|
|
1700
1737
|
"data-testid": dataTestId,
|
|
1701
|
-
className: "pointer-events-none absolute inset-0 z-
|
|
1738
|
+
className: "pointer-events-none absolute inset-0 z-10",
|
|
1702
1739
|
children: todayEvents.map((event, index) => {
|
|
1703
1740
|
const veryVeryUniqueKey = `event-${event.id}-${index}-${day.format("YYYY-MM-DD")}`;
|
|
1704
1741
|
const isShortEvent = event.end.diff(event.start, "minute") <= 15;
|
|
@@ -1723,10 +1760,10 @@ var DayEventsLayer = ({
|
|
|
1723
1760
|
};
|
|
1724
1761
|
|
|
1725
1762
|
// src/features/week-view/week-day-col.tsx
|
|
1726
|
-
import { jsx as jsx24, jsxs as
|
|
1763
|
+
import { jsx as jsx24, jsxs as jsxs13 } from "react/jsx-runtime";
|
|
1727
1764
|
var hours = Array.from({ length: 24 }, (_, i) => i).map((hour) => dayjs_config_default().hour(hour).minute(0));
|
|
1728
1765
|
var WeekDayCol = ({ day }) => {
|
|
1729
|
-
return /* @__PURE__ */
|
|
1766
|
+
return /* @__PURE__ */ jsxs13("div", {
|
|
1730
1767
|
"data-testid": `week-day-col-${day.format("YYYY-MM-DD")}`,
|
|
1731
1768
|
className: "col-span-1 relative grid grid-rows-24 border-r",
|
|
1732
1769
|
children: [
|
|
@@ -1739,7 +1776,7 @@ var WeekDayCol = ({ day }) => {
|
|
|
1739
1776
|
date: day,
|
|
1740
1777
|
hour,
|
|
1741
1778
|
"data-testid": `week-time-cell-${cellDate}-${time.format("HH")}`,
|
|
1742
|
-
className: cn("hover:bg-accent relative z-
|
|
1779
|
+
className: cn("hover:bg-accent relative z-10 h-[60px] cursor-pointer border-b")
|
|
1743
1780
|
}, `${cellDate}-${time.format("HH")}`);
|
|
1744
1781
|
}),
|
|
1745
1782
|
/* @__PURE__ */ jsx24(DayEventsLayer, {
|
|
@@ -1751,7 +1788,7 @@ var WeekDayCol = ({ day }) => {
|
|
|
1751
1788
|
};
|
|
1752
1789
|
|
|
1753
1790
|
// src/features/week-view/week-time-grid.tsx
|
|
1754
|
-
import { jsx as jsx25, jsxs as
|
|
1791
|
+
import { jsx as jsx25, jsxs as jsxs14 } from "react/jsx-runtime";
|
|
1755
1792
|
var hours2 = Array.from({ length: 24 }, (_, i) => i).map((hour) => dayjs_config_default().hour(hour).minute(0));
|
|
1756
1793
|
var WeekTimeGrid = () => {
|
|
1757
1794
|
const { currentDate, firstDayOfWeek, currentLocale } = useCalendarContext();
|
|
@@ -1763,7 +1800,7 @@ var WeekTimeGrid = () => {
|
|
|
1763
1800
|
}
|
|
1764
1801
|
const todayIndex = weekDays.findIndex((day) => day.isSame(dayjs_config_default(), "day"));
|
|
1765
1802
|
const isCurrentWeek = todayIndex !== -1;
|
|
1766
|
-
return /* @__PURE__ */
|
|
1803
|
+
return /* @__PURE__ */ jsxs14("div", {
|
|
1767
1804
|
"data-testid": "week-time-grid",
|
|
1768
1805
|
className: "relative h-full grid grid-cols-[auto_repeat(7,1fr)] grid-rows-[repeat(24,minmax(60px, 1fr))]",
|
|
1769
1806
|
children: [
|
|
@@ -1806,17 +1843,17 @@ var WeekTimeGrid = () => {
|
|
|
1806
1843
|
};
|
|
1807
1844
|
|
|
1808
1845
|
// src/features/week-view/view/week-view.tsx
|
|
1809
|
-
import { jsx as jsx26, jsxs as
|
|
1846
|
+
import { jsx as jsx26, jsxs as jsxs15 } from "react/jsx-runtime";
|
|
1810
1847
|
dayjs_config_default.extend(weekOfYear2);
|
|
1811
1848
|
var WeekView = () => {
|
|
1812
|
-
return /* @__PURE__ */
|
|
1849
|
+
return /* @__PURE__ */ jsxs15("div", {
|
|
1813
1850
|
className: "flex flex-col h-full",
|
|
1814
1851
|
"data-testid": "week-view",
|
|
1815
1852
|
children: [
|
|
1816
1853
|
/* @__PURE__ */ jsx26(WeekHeader, {
|
|
1817
1854
|
className: "h-[5rem]"
|
|
1818
1855
|
}),
|
|
1819
|
-
/* @__PURE__ */
|
|
1856
|
+
/* @__PURE__ */ jsxs15(ScrollArea, {
|
|
1820
1857
|
className: "flex overflow-auto h-[calc(100%-5rem)]",
|
|
1821
1858
|
"data-testid": "week-scroll-area",
|
|
1822
1859
|
children: [
|
|
@@ -1834,7 +1871,7 @@ import { Fragment as Fragment2 } from "react";
|
|
|
1834
1871
|
|
|
1835
1872
|
// src/features/day-view/components/day-all-day-row.tsx
|
|
1836
1873
|
import { useMemo as useMemo5 } from "react";
|
|
1837
|
-
import { jsx as jsx27, jsxs as
|
|
1874
|
+
import { jsx as jsx27, jsxs as jsxs16 } from "react/jsx-runtime";
|
|
1838
1875
|
var DayAllDayRow = () => {
|
|
1839
1876
|
const { currentDate, getEventsForDateRange } = useCalendarContext();
|
|
1840
1877
|
const dayEvents = getEventsForDateRange(currentDate.startOf("day"), currentDate.endOf("day"));
|
|
@@ -1874,7 +1911,7 @@ var DayAllDayRow = () => {
|
|
|
1874
1911
|
allDayRowsCount: Math.max(1, rows.length)
|
|
1875
1912
|
};
|
|
1876
1913
|
}, [allDayEvents]);
|
|
1877
|
-
return /* @__PURE__ */
|
|
1914
|
+
return /* @__PURE__ */ jsxs16("div", {
|
|
1878
1915
|
"data-testid": "day-all-day-row",
|
|
1879
1916
|
className: "grid grid-cols-8 border-b border-x",
|
|
1880
1917
|
children: [
|
|
@@ -1911,16 +1948,16 @@ var DayAllDayRow = () => {
|
|
|
1911
1948
|
|
|
1912
1949
|
// src/features/day-view/components/day-header.tsx
|
|
1913
1950
|
import { AnimatePresence as AnimatePresence5, motion as motion5 } from "motion/react";
|
|
1914
|
-
import { jsx as jsx28, jsxs as
|
|
1951
|
+
import { jsx as jsx28, jsxs as jsxs17 } from "react/jsx-runtime";
|
|
1915
1952
|
var DayHeader = ({ className }) => {
|
|
1916
1953
|
const { currentDate, stickyViewHeader, viewHeaderClassName } = useCalendarContext();
|
|
1917
1954
|
const isToday = currentDate.isSame(dayjs_config_default(), "day");
|
|
1918
1955
|
return /* @__PURE__ */ jsx28("div", {
|
|
1919
1956
|
"data-testid": "day-header",
|
|
1920
|
-
className: cn("flex items-center justify-center border-b p-2 border-x", stickyViewHeader && "sticky top-0 z-
|
|
1957
|
+
className: cn("flex items-center justify-center border-b p-2 border-x", stickyViewHeader && "sticky top-0 z-20", viewHeaderClassName, className),
|
|
1921
1958
|
children: /* @__PURE__ */ jsx28(AnimatePresence5, {
|
|
1922
1959
|
mode: "wait",
|
|
1923
|
-
children: /* @__PURE__ */
|
|
1960
|
+
children: /* @__PURE__ */ jsxs17(motion5.div, {
|
|
1924
1961
|
initial: { opacity: 0, y: -10 },
|
|
1925
1962
|
animate: { opacity: 1, y: 0 },
|
|
1926
1963
|
exit: { opacity: 0, y: -10 },
|
|
@@ -1968,7 +2005,7 @@ var DayTimeCol = ({ className }) => {
|
|
|
1968
2005
|
};
|
|
1969
2006
|
|
|
1970
2007
|
// src/features/day-view/components/view/day-view.tsx
|
|
1971
|
-
import { jsx as jsx30, jsxs as
|
|
2008
|
+
import { jsx as jsx30, jsxs as jsxs18 } from "react/jsx-runtime";
|
|
1972
2009
|
var timeSegments = [0, 15, 30, 45];
|
|
1973
2010
|
var hours4 = Array.from({ length: 24 }, (_, i) => i).map((hour) => {
|
|
1974
2011
|
return dayjs_config_default().hour(hour).minute(0);
|
|
@@ -1977,19 +2014,19 @@ var DayView = () => {
|
|
|
1977
2014
|
const { currentDate } = useCalendarContext();
|
|
1978
2015
|
const isToday = currentDate.isSame(dayjs_config_default(), "day");
|
|
1979
2016
|
const cellDate = currentDate.format("YYYY-MM-DD");
|
|
1980
|
-
return /* @__PURE__ */
|
|
2017
|
+
return /* @__PURE__ */ jsxs18("div", {
|
|
1981
2018
|
"data-testid": "day-view",
|
|
1982
2019
|
className: "flex h-full flex-col",
|
|
1983
2020
|
children: [
|
|
1984
2021
|
/* @__PURE__ */ jsx30(DayHeader, {
|
|
1985
2022
|
className: "h-[3rem]"
|
|
1986
2023
|
}),
|
|
1987
|
-
/* @__PURE__ */
|
|
2024
|
+
/* @__PURE__ */ jsxs18(ScrollArea, {
|
|
1988
2025
|
"data-testid": "day-scroll-area",
|
|
1989
2026
|
className: "relative overflow-y-auto h-[calc(100%-3rem)]",
|
|
1990
2027
|
children: [
|
|
1991
2028
|
/* @__PURE__ */ jsx30(DayAllDayRow, {}),
|
|
1992
|
-
/* @__PURE__ */
|
|
2029
|
+
/* @__PURE__ */ jsxs18("div", {
|
|
1993
2030
|
"data-testid": "day-time-grid",
|
|
1994
2031
|
className: "grid grid-cols-8 divide-x border-x",
|
|
1995
2032
|
style: { height: `${hours4.length * 60}px` },
|
|
@@ -1997,7 +2034,7 @@ var DayView = () => {
|
|
|
1997
2034
|
/* @__PURE__ */ jsx30(DayTimeCol, {
|
|
1998
2035
|
className: "col-span-2 h-full md:col-span-1"
|
|
1999
2036
|
}),
|
|
2000
|
-
/* @__PURE__ */
|
|
2037
|
+
/* @__PURE__ */ jsxs18("div", {
|
|
2001
2038
|
"data-testid": "day-events-column",
|
|
2002
2039
|
className: "relative col-span-6 h-full md:col-span-7",
|
|
2003
2040
|
children: [
|
|
@@ -2014,10 +2051,10 @@ var DayView = () => {
|
|
|
2014
2051
|
}),
|
|
2015
2052
|
/* @__PURE__ */ jsx30("div", {
|
|
2016
2053
|
"data-testid": "day-interactive-layer",
|
|
2017
|
-
className: "pointer-events-auto absolute inset-0 z-
|
|
2054
|
+
className: "pointer-events-auto absolute inset-0 z-10",
|
|
2018
2055
|
children: hours4.map((time) => {
|
|
2019
2056
|
const hour = time.hour();
|
|
2020
|
-
return /* @__PURE__ */
|
|
2057
|
+
return /* @__PURE__ */ jsxs18(Fragment2, {
|
|
2021
2058
|
children: [
|
|
2022
2059
|
/* @__PURE__ */ jsx30(DroppableCell, {
|
|
2023
2060
|
id: `time-cell-${cellDate}-${time.format("HH")}-00`,
|
|
@@ -2103,9 +2140,10 @@ var generateRecurringEvents = ({
|
|
|
2103
2140
|
};
|
|
2104
2141
|
const rule = new RRule(ruleOptions);
|
|
2105
2142
|
const overrides = currentEvents.filter((e) => e.recurrenceId && e.uid === event.uid);
|
|
2106
|
-
const
|
|
2143
|
+
const eventDuration = event.end.diff(event.start);
|
|
2144
|
+
const expandedStartDateTime = startDate.subtract(eventDuration, "millisecond").toDate();
|
|
2107
2145
|
const endDateTime = endDate.toDate();
|
|
2108
|
-
const occurrences = rule.between(
|
|
2146
|
+
const occurrences = rule.between(expandedStartDateTime, endDateTime, true);
|
|
2109
2147
|
const recurringEvents = occurrences.map((occurrence, index) => {
|
|
2110
2148
|
const occurrenceDate = dayjs_config_default(occurrence);
|
|
2111
2149
|
const existingOverride = overrides.find((e) => safeDate(e.recurrenceId).isSame(occurrenceDate));
|
|
@@ -2127,12 +2165,15 @@ var generateRecurringEvents = ({
|
|
|
2127
2165
|
return recurringEvent;
|
|
2128
2166
|
}).filter((recurringEvent) => {
|
|
2129
2167
|
const hasExdates = event.exdates && event.exdates.length > 0;
|
|
2130
|
-
if (
|
|
2131
|
-
|
|
2168
|
+
if (hasExdates) {
|
|
2169
|
+
const eventStartISO = recurringEvent.start.toISOString();
|
|
2170
|
+
const isExcluded = event.exdates.includes(eventStartISO);
|
|
2171
|
+
if (isExcluded) {
|
|
2172
|
+
return false;
|
|
2173
|
+
}
|
|
2132
2174
|
}
|
|
2133
|
-
const
|
|
2134
|
-
|
|
2135
|
-
return !isExcluded;
|
|
2175
|
+
const eventSpansRange = recurringEvent.start.isSameOrBefore(endDate) && recurringEvent.end.isSameOrAfter(startDate);
|
|
2176
|
+
return eventSpansRange;
|
|
2136
2177
|
});
|
|
2137
2178
|
return recurringEvents;
|
|
2138
2179
|
} catch (error) {
|
|
@@ -2269,38 +2310,39 @@ var deleteRecurringEvent = ({
|
|
|
2269
2310
|
};
|
|
2270
2311
|
|
|
2271
2312
|
// src/features/recurrence/components/recurrence-editor/recurrence-editor.tsx
|
|
2272
|
-
import { useState as useState2, useEffect as useEffect2 } from "react";
|
|
2313
|
+
import { useState as useState2, useEffect as useEffect2, useMemo as useMemo6 } from "react";
|
|
2273
2314
|
import { RRule as RRule2 } from "rrule";
|
|
2274
|
-
import { jsx as jsx31, jsxs as
|
|
2275
|
-
function getRRuleDescription(rruleOptions) {
|
|
2315
|
+
import { jsx as jsx31, jsxs as jsxs19 } from "react/jsx-runtime";
|
|
2316
|
+
function getRRuleDescription(rruleOptions, t) {
|
|
2276
2317
|
if (!rruleOptions) {
|
|
2277
|
-
return "
|
|
2318
|
+
return t("customRecurrence");
|
|
2278
2319
|
}
|
|
2279
2320
|
try {
|
|
2280
2321
|
const rule = new RRule2(rruleOptions);
|
|
2281
2322
|
const naturalText = rule.toText();
|
|
2282
2323
|
if (!naturalText || naturalText.includes("RRule error") || naturalText.includes("Unable to fully convert") || naturalText.toLowerCase().includes("error")) {
|
|
2283
|
-
return "
|
|
2324
|
+
return t("customRecurrence");
|
|
2284
2325
|
}
|
|
2285
2326
|
return naturalText.charAt(0).toUpperCase() + naturalText.slice(1);
|
|
2286
2327
|
} catch {
|
|
2287
|
-
return "
|
|
2328
|
+
return t("customRecurrence");
|
|
2288
2329
|
}
|
|
2289
2330
|
}
|
|
2290
|
-
var WEEK_DAYS = [
|
|
2291
|
-
{ value: RRule2.SU, label: "Sunday", short: "Sun" },
|
|
2292
|
-
{ value: RRule2.MO, label: "Monday", short: "Mon" },
|
|
2293
|
-
{ value: RRule2.TU, label: "Tuesday", short: "Tue" },
|
|
2294
|
-
{ value: RRule2.WE, label: "Wednesday", short: "Wed" },
|
|
2295
|
-
{ value: RRule2.TH, label: "Thursday", short: "Thu" },
|
|
2296
|
-
{ value: RRule2.FR, label: "Friday", short: "Fri" },
|
|
2297
|
-
{ value: RRule2.SA, label: "Saturday", short: "Sat" }
|
|
2298
|
-
];
|
|
2299
2331
|
var RecurrenceEditor = ({
|
|
2300
2332
|
value,
|
|
2301
2333
|
onChange
|
|
2302
2334
|
}) => {
|
|
2335
|
+
const { t } = useCalendarContext();
|
|
2303
2336
|
const [showRecurrence, setShowRecurrence] = useState2(!!value);
|
|
2337
|
+
const WEEK_DAYS = useMemo6(() => [
|
|
2338
|
+
{ value: RRule2.SU, label: t("sunday"), short: t("sun") },
|
|
2339
|
+
{ value: RRule2.MO, label: t("monday"), short: t("mon") },
|
|
2340
|
+
{ value: RRule2.TU, label: t("tuesday"), short: t("tue") },
|
|
2341
|
+
{ value: RRule2.WE, label: t("wednesday"), short: t("wed") },
|
|
2342
|
+
{ value: RRule2.TH, label: t("thursday"), short: t("thu") },
|
|
2343
|
+
{ value: RRule2.FR, label: t("friday"), short: t("fri") },
|
|
2344
|
+
{ value: RRule2.SA, label: t("saturday"), short: t("sat") }
|
|
2345
|
+
], [t]);
|
|
2304
2346
|
const getFrequencyString = (freq) => {
|
|
2305
2347
|
const freqMap = {
|
|
2306
2348
|
[RRule2.DAILY]: "DAILY",
|
|
@@ -2413,13 +2455,13 @@ var RecurrenceEditor = ({
|
|
|
2413
2455
|
}
|
|
2414
2456
|
return "never";
|
|
2415
2457
|
};
|
|
2416
|
-
return /* @__PURE__ */
|
|
2458
|
+
return /* @__PURE__ */ jsxs19(Card, {
|
|
2417
2459
|
"data-testid": "recurrence-editor",
|
|
2418
2460
|
children: [
|
|
2419
|
-
/* @__PURE__ */
|
|
2461
|
+
/* @__PURE__ */ jsxs19(CardHeader, {
|
|
2420
2462
|
className: "pb-3",
|
|
2421
2463
|
children: [
|
|
2422
|
-
/* @__PURE__ */
|
|
2464
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2423
2465
|
className: "flex items-center space-x-2",
|
|
2424
2466
|
children: [
|
|
2425
2467
|
/* @__PURE__ */ jsx31(Checkbox, {
|
|
@@ -2430,32 +2472,32 @@ var RecurrenceEditor = ({
|
|
|
2430
2472
|
}),
|
|
2431
2473
|
/* @__PURE__ */ jsx31(CardTitle, {
|
|
2432
2474
|
className: "text-sm",
|
|
2433
|
-
children: "
|
|
2475
|
+
children: t("repeat")
|
|
2434
2476
|
})
|
|
2435
2477
|
]
|
|
2436
2478
|
}),
|
|
2437
2479
|
showRecurrence && value && /* @__PURE__ */ jsx31("p", {
|
|
2438
2480
|
className: "text-xs text-muted-foreground",
|
|
2439
|
-
children: getRRuleDescription(value)
|
|
2481
|
+
children: getRRuleDescription(value, t)
|
|
2440
2482
|
})
|
|
2441
2483
|
]
|
|
2442
2484
|
}),
|
|
2443
2485
|
showRecurrence && /* @__PURE__ */ jsx31(CardContent, {
|
|
2444
2486
|
className: "pt-0",
|
|
2445
|
-
children: /* @__PURE__ */
|
|
2487
|
+
children: /* @__PURE__ */ jsxs19("div", {
|
|
2446
2488
|
className: "space-y-4",
|
|
2447
2489
|
children: [
|
|
2448
|
-
/* @__PURE__ */
|
|
2490
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2449
2491
|
className: "grid grid-cols-2 gap-4",
|
|
2450
2492
|
children: [
|
|
2451
|
-
/* @__PURE__ */
|
|
2493
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2452
2494
|
children: [
|
|
2453
2495
|
/* @__PURE__ */ jsx31(Label, {
|
|
2454
2496
|
htmlFor: "frequency",
|
|
2455
2497
|
className: "text-xs",
|
|
2456
|
-
children: "
|
|
2498
|
+
children: t("repeats")
|
|
2457
2499
|
}),
|
|
2458
|
-
/* @__PURE__ */
|
|
2500
|
+
/* @__PURE__ */ jsxs19(Select, {
|
|
2459
2501
|
value: getFrequencyString(rruleOptions?.freq ?? RRule2.DAILY),
|
|
2460
2502
|
onValueChange: handleFrequencyChange,
|
|
2461
2503
|
children: [
|
|
@@ -2465,23 +2507,23 @@ var RecurrenceEditor = ({
|
|
|
2465
2507
|
"data-testid": "frequency-select",
|
|
2466
2508
|
children: /* @__PURE__ */ jsx31(SelectValue, {})
|
|
2467
2509
|
}),
|
|
2468
|
-
/* @__PURE__ */
|
|
2510
|
+
/* @__PURE__ */ jsxs19(SelectContent, {
|
|
2469
2511
|
children: [
|
|
2470
2512
|
/* @__PURE__ */ jsx31(SelectItem, {
|
|
2471
2513
|
value: "DAILY",
|
|
2472
|
-
children: "
|
|
2514
|
+
children: t("daily")
|
|
2473
2515
|
}),
|
|
2474
2516
|
/* @__PURE__ */ jsx31(SelectItem, {
|
|
2475
2517
|
value: "WEEKLY",
|
|
2476
|
-
children: "
|
|
2518
|
+
children: t("weekly")
|
|
2477
2519
|
}),
|
|
2478
2520
|
/* @__PURE__ */ jsx31(SelectItem, {
|
|
2479
2521
|
value: "MONTHLY",
|
|
2480
|
-
children: "
|
|
2522
|
+
children: t("monthly")
|
|
2481
2523
|
}),
|
|
2482
2524
|
/* @__PURE__ */ jsx31(SelectItem, {
|
|
2483
2525
|
value: "YEARLY",
|
|
2484
|
-
children: "
|
|
2526
|
+
children: t("yearly")
|
|
2485
2527
|
})
|
|
2486
2528
|
]
|
|
2487
2529
|
})
|
|
@@ -2489,12 +2531,12 @@ var RecurrenceEditor = ({
|
|
|
2489
2531
|
})
|
|
2490
2532
|
]
|
|
2491
2533
|
}),
|
|
2492
|
-
/* @__PURE__ */
|
|
2534
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2493
2535
|
children: [
|
|
2494
2536
|
/* @__PURE__ */ jsx31(Label, {
|
|
2495
2537
|
htmlFor: "interval",
|
|
2496
2538
|
className: "text-xs",
|
|
2497
|
-
children: "
|
|
2539
|
+
children: t("every")
|
|
2498
2540
|
}),
|
|
2499
2541
|
/* @__PURE__ */ jsx31(Input, {
|
|
2500
2542
|
id: "interval",
|
|
@@ -2508,18 +2550,18 @@ var RecurrenceEditor = ({
|
|
|
2508
2550
|
})
|
|
2509
2551
|
]
|
|
2510
2552
|
}),
|
|
2511
|
-
rruleOptions?.freq === RRule2.WEEKLY && /* @__PURE__ */
|
|
2553
|
+
rruleOptions?.freq === RRule2.WEEKLY && /* @__PURE__ */ jsxs19("div", {
|
|
2512
2554
|
children: [
|
|
2513
2555
|
/* @__PURE__ */ jsx31(Label, {
|
|
2514
2556
|
className: "text-xs",
|
|
2515
|
-
children: "
|
|
2557
|
+
children: t("repeatOn")
|
|
2516
2558
|
}),
|
|
2517
2559
|
/* @__PURE__ */ jsx31("div", {
|
|
2518
2560
|
className: "flex flex-wrap gap-1 mt-1",
|
|
2519
2561
|
children: WEEK_DAYS.map((day, index) => {
|
|
2520
2562
|
const byweekdayArray = Array.isArray(rruleOptions?.byweekday) ? rruleOptions.byweekday : rruleOptions?.byweekday ? [rruleOptions.byweekday] : [];
|
|
2521
2563
|
const isSelected = byweekdayArray.includes(day.value);
|
|
2522
|
-
return /* @__PURE__ */
|
|
2564
|
+
return /* @__PURE__ */ jsxs19("div", {
|
|
2523
2565
|
className: "flex items-center space-x-1",
|
|
2524
2566
|
children: [
|
|
2525
2567
|
/* @__PURE__ */ jsx31(Checkbox, {
|
|
@@ -2538,16 +2580,16 @@ var RecurrenceEditor = ({
|
|
|
2538
2580
|
})
|
|
2539
2581
|
]
|
|
2540
2582
|
}),
|
|
2541
|
-
/* @__PURE__ */
|
|
2583
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2542
2584
|
children: [
|
|
2543
2585
|
/* @__PURE__ */ jsx31(Label, {
|
|
2544
2586
|
className: "text-xs",
|
|
2545
|
-
children: "
|
|
2587
|
+
children: t("ends")
|
|
2546
2588
|
}),
|
|
2547
|
-
/* @__PURE__ */
|
|
2589
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2548
2590
|
className: "space-y-2 mt-1",
|
|
2549
2591
|
children: [
|
|
2550
|
-
/* @__PURE__ */
|
|
2592
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2551
2593
|
className: "flex items-center space-x-2",
|
|
2552
2594
|
children: [
|
|
2553
2595
|
/* @__PURE__ */ jsx31(Checkbox, {
|
|
@@ -2558,11 +2600,11 @@ var RecurrenceEditor = ({
|
|
|
2558
2600
|
/* @__PURE__ */ jsx31(Label, {
|
|
2559
2601
|
htmlFor: "never",
|
|
2560
2602
|
className: "text-xs",
|
|
2561
|
-
children: "
|
|
2603
|
+
children: t("never")
|
|
2562
2604
|
})
|
|
2563
2605
|
]
|
|
2564
2606
|
}),
|
|
2565
|
-
/* @__PURE__ */
|
|
2607
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2566
2608
|
className: "flex items-center space-x-2",
|
|
2567
2609
|
children: [
|
|
2568
2610
|
/* @__PURE__ */ jsx31(Checkbox, {
|
|
@@ -2573,7 +2615,7 @@ var RecurrenceEditor = ({
|
|
|
2573
2615
|
/* @__PURE__ */ jsx31(Label, {
|
|
2574
2616
|
htmlFor: "after",
|
|
2575
2617
|
className: "text-xs",
|
|
2576
|
-
children: "
|
|
2618
|
+
children: t("after")
|
|
2577
2619
|
}),
|
|
2578
2620
|
getEndType() === "count" && /* @__PURE__ */ jsx31(Input, {
|
|
2579
2621
|
type: "number",
|
|
@@ -2585,11 +2627,11 @@ var RecurrenceEditor = ({
|
|
|
2585
2627
|
}),
|
|
2586
2628
|
/* @__PURE__ */ jsx31("span", {
|
|
2587
2629
|
className: "text-xs",
|
|
2588
|
-
children: "occurrences"
|
|
2630
|
+
children: t("occurrences")
|
|
2589
2631
|
})
|
|
2590
2632
|
]
|
|
2591
2633
|
}),
|
|
2592
|
-
/* @__PURE__ */
|
|
2634
|
+
/* @__PURE__ */ jsxs19("div", {
|
|
2593
2635
|
className: "flex items-center space-x-2",
|
|
2594
2636
|
children: [
|
|
2595
2637
|
/* @__PURE__ */ jsx31(Checkbox, {
|
|
@@ -2600,7 +2642,7 @@ var RecurrenceEditor = ({
|
|
|
2600
2642
|
/* @__PURE__ */ jsx31(Label, {
|
|
2601
2643
|
htmlFor: "on",
|
|
2602
2644
|
className: "text-xs",
|
|
2603
|
-
children: "
|
|
2645
|
+
children: t("on")
|
|
2604
2646
|
}),
|
|
2605
2647
|
getEndType() === "until" && /* @__PURE__ */ jsx31(DatePicker, {
|
|
2606
2648
|
date: rruleOptions?.until,
|
|
@@ -2621,7 +2663,7 @@ var RecurrenceEditor = ({
|
|
|
2621
2663
|
};
|
|
2622
2664
|
|
|
2623
2665
|
// src/features/recurrence/components/recurrence-edit-dialog/recurrence-edit-dialog.tsx
|
|
2624
|
-
import { jsx as jsx32, jsxs as
|
|
2666
|
+
import { jsx as jsx32, jsxs as jsxs20 } from "react/jsx-runtime";
|
|
2625
2667
|
function RecurrenceEditDialog({
|
|
2626
2668
|
isOpen,
|
|
2627
2669
|
onClose,
|
|
@@ -2629,59 +2671,51 @@ function RecurrenceEditDialog({
|
|
|
2629
2671
|
operationType,
|
|
2630
2672
|
eventTitle
|
|
2631
2673
|
}) {
|
|
2674
|
+
const { t } = useCalendarContext();
|
|
2632
2675
|
const handleScopeSelect = (scope) => {
|
|
2633
2676
|
onConfirm(scope);
|
|
2634
2677
|
onClose();
|
|
2635
2678
|
};
|
|
2636
|
-
const
|
|
2637
|
-
const actionVerb = operationType === "edit" ? "Edit" : "Delete";
|
|
2679
|
+
const isEdit = operationType === "edit";
|
|
2638
2680
|
return /* @__PURE__ */ jsx32(Dialog, {
|
|
2639
2681
|
open: isOpen,
|
|
2640
2682
|
onOpenChange: onClose,
|
|
2641
|
-
children: /* @__PURE__ */
|
|
2683
|
+
children: /* @__PURE__ */ jsxs20(DialogContent, {
|
|
2642
2684
|
className: "max-w-md",
|
|
2643
2685
|
children: [
|
|
2644
|
-
/* @__PURE__ */
|
|
2686
|
+
/* @__PURE__ */ jsxs20(DialogHeader, {
|
|
2645
2687
|
children: [
|
|
2646
|
-
/* @__PURE__ */
|
|
2647
|
-
children:
|
|
2648
|
-
actionVerb,
|
|
2649
|
-
" recurring event"
|
|
2650
|
-
]
|
|
2688
|
+
/* @__PURE__ */ jsx32(DialogTitle, {
|
|
2689
|
+
children: isEdit ? t("editRecurringEvent") : t("deleteRecurringEvent")
|
|
2651
2690
|
}),
|
|
2652
|
-
/* @__PURE__ */
|
|
2691
|
+
/* @__PURE__ */ jsxs20(DialogDescription, {
|
|
2653
2692
|
children: [
|
|
2654
2693
|
'"',
|
|
2655
2694
|
eventTitle,
|
|
2656
|
-
'"
|
|
2695
|
+
'"',
|
|
2657
2696
|
" ",
|
|
2658
|
-
|
|
2659
|
-
" it?"
|
|
2697
|
+
isEdit ? t("editRecurringEventQuestion") : t("deleteRecurringEventQuestion")
|
|
2660
2698
|
]
|
|
2661
2699
|
})
|
|
2662
2700
|
]
|
|
2663
2701
|
}),
|
|
2664
|
-
/* @__PURE__ */
|
|
2702
|
+
/* @__PURE__ */ jsxs20("div", {
|
|
2665
2703
|
className: "space-y-3",
|
|
2666
2704
|
children: [
|
|
2667
2705
|
/* @__PURE__ */ jsx32(Button, {
|
|
2668
2706
|
variant: "outline",
|
|
2669
2707
|
className: "w-full justify-start h-auto p-4",
|
|
2670
2708
|
onClick: () => handleScopeSelect("this"),
|
|
2671
|
-
children: /* @__PURE__ */
|
|
2709
|
+
children: /* @__PURE__ */ jsxs20("div", {
|
|
2672
2710
|
className: "text-left",
|
|
2673
2711
|
children: [
|
|
2674
2712
|
/* @__PURE__ */ jsx32("div", {
|
|
2675
2713
|
className: "font-medium",
|
|
2676
|
-
children: "
|
|
2714
|
+
children: t("thisEvent")
|
|
2677
2715
|
}),
|
|
2678
|
-
/* @__PURE__ */
|
|
2716
|
+
/* @__PURE__ */ jsx32("div", {
|
|
2679
2717
|
className: "text-sm text-muted-foreground",
|
|
2680
|
-
children:
|
|
2681
|
-
"Only ",
|
|
2682
|
-
actionText,
|
|
2683
|
-
" this specific occurrence"
|
|
2684
|
-
]
|
|
2718
|
+
children: isEdit ? t("onlyChangeThis") : t("onlyDeleteThis")
|
|
2685
2719
|
})
|
|
2686
2720
|
]
|
|
2687
2721
|
})
|
|
@@ -2690,19 +2724,16 @@ function RecurrenceEditDialog({
|
|
|
2690
2724
|
variant: "outline",
|
|
2691
2725
|
className: "w-full justify-start h-auto p-4",
|
|
2692
2726
|
onClick: () => handleScopeSelect("following"),
|
|
2693
|
-
children: /* @__PURE__ */
|
|
2727
|
+
children: /* @__PURE__ */ jsxs20("div", {
|
|
2694
2728
|
className: "text-left",
|
|
2695
2729
|
children: [
|
|
2696
2730
|
/* @__PURE__ */ jsx32("div", {
|
|
2697
2731
|
className: "font-medium",
|
|
2698
|
-
children: "
|
|
2732
|
+
children: t("thisAndFollowingEvents")
|
|
2699
2733
|
}),
|
|
2700
|
-
/* @__PURE__ */
|
|
2734
|
+
/* @__PURE__ */ jsx32("div", {
|
|
2701
2735
|
className: "text-sm text-muted-foreground",
|
|
2702
|
-
children:
|
|
2703
|
-
actionVerb,
|
|
2704
|
-
" this and all future occurrences"
|
|
2705
|
-
]
|
|
2736
|
+
children: isEdit ? t("changeThisAndFuture") : t("deleteThisAndFuture")
|
|
2706
2737
|
})
|
|
2707
2738
|
]
|
|
2708
2739
|
})
|
|
@@ -2711,19 +2742,16 @@ function RecurrenceEditDialog({
|
|
|
2711
2742
|
variant: "outline",
|
|
2712
2743
|
className: "w-full justify-start h-auto p-4",
|
|
2713
2744
|
onClick: () => handleScopeSelect("all"),
|
|
2714
|
-
children: /* @__PURE__ */
|
|
2745
|
+
children: /* @__PURE__ */ jsxs20("div", {
|
|
2715
2746
|
className: "text-left",
|
|
2716
2747
|
children: [
|
|
2717
2748
|
/* @__PURE__ */ jsx32("div", {
|
|
2718
2749
|
className: "font-medium",
|
|
2719
|
-
children: "
|
|
2750
|
+
children: t("allEvents")
|
|
2720
2751
|
}),
|
|
2721
|
-
/* @__PURE__ */
|
|
2752
|
+
/* @__PURE__ */ jsx32("div", {
|
|
2722
2753
|
className: "text-sm text-muted-foreground",
|
|
2723
|
-
children:
|
|
2724
|
-
actionVerb,
|
|
2725
|
-
" the entire recurring series"
|
|
2726
|
-
]
|
|
2754
|
+
children: isEdit ? t("changeEntireSeries") : t("deleteEntireSeries")
|
|
2727
2755
|
})
|
|
2728
2756
|
]
|
|
2729
2757
|
})
|
|
@@ -2734,7 +2762,7 @@ function RecurrenceEditDialog({
|
|
|
2734
2762
|
children: /* @__PURE__ */ jsx32(Button, {
|
|
2735
2763
|
variant: "outline",
|
|
2736
2764
|
onClick: onClose,
|
|
2737
|
-
children: "
|
|
2765
|
+
children: t("cancel")
|
|
2738
2766
|
})
|
|
2739
2767
|
})
|
|
2740
2768
|
]
|
|
@@ -2801,7 +2829,7 @@ function useRecurringEventActions(onComplete) {
|
|
|
2801
2829
|
}
|
|
2802
2830
|
|
|
2803
2831
|
// src/components/event-form/event-form.tsx
|
|
2804
|
-
import { jsx as jsx33, jsxs as
|
|
2832
|
+
import { jsx as jsx33, jsxs as jsxs21, Fragment as Fragment3 } from "react/jsx-runtime";
|
|
2805
2833
|
var colorOptions = [
|
|
2806
2834
|
{ value: "bg-blue-100 text-blue-800", label: "Blue" },
|
|
2807
2835
|
{ value: "bg-green-100 text-green-800", label: "Green" },
|
|
@@ -2833,7 +2861,7 @@ var EventForm = ({
|
|
|
2833
2861
|
closeDialog,
|
|
2834
2862
|
handleConfirm
|
|
2835
2863
|
} = useRecurringEventActions(onClose);
|
|
2836
|
-
const { findParentRecurringEvent } = useCalendarContext();
|
|
2864
|
+
const { findParentRecurringEvent, t } = useCalendarContext();
|
|
2837
2865
|
const start = selectedEvent?.start;
|
|
2838
2866
|
const end = selectedEvent?.end;
|
|
2839
2867
|
const parentEvent = selectedEvent ? findParentRecurringEvent(selectedEvent) : null;
|
|
@@ -2953,70 +2981,70 @@ var EventForm = ({
|
|
|
2953
2981
|
setEndDate(startDate);
|
|
2954
2982
|
}
|
|
2955
2983
|
}, [startDate, endDate]);
|
|
2956
|
-
return /* @__PURE__ */
|
|
2984
|
+
return /* @__PURE__ */ jsxs21(Fragment3, {
|
|
2957
2985
|
children: [
|
|
2958
2986
|
/* @__PURE__ */ jsx33(Dialog, {
|
|
2959
2987
|
open: true,
|
|
2960
2988
|
onOpenChange: onClose,
|
|
2961
2989
|
children: /* @__PURE__ */ jsx33(DialogContent, {
|
|
2962
2990
|
className: "w-[90vw] max-w-[500px] p-4 sm:p-6",
|
|
2963
|
-
children: /* @__PURE__ */
|
|
2991
|
+
children: /* @__PURE__ */ jsxs21("form", {
|
|
2964
2992
|
onSubmit: handleSubmit,
|
|
2965
2993
|
children: [
|
|
2966
|
-
/* @__PURE__ */
|
|
2994
|
+
/* @__PURE__ */ jsxs21(DialogHeader, {
|
|
2967
2995
|
className: "mb-2 sm:mb-4",
|
|
2968
2996
|
children: [
|
|
2969
2997
|
/* @__PURE__ */ jsx33(DialogTitle, {
|
|
2970
2998
|
className: "text-base sm:text-lg",
|
|
2971
|
-
children: selectedEvent?.id ? "
|
|
2999
|
+
children: selectedEvent?.id ? t("editEvent") : t("createEvent")
|
|
2972
3000
|
}),
|
|
2973
3001
|
/* @__PURE__ */ jsx33(DialogDescription, {
|
|
2974
3002
|
className: "text-xs sm:text-sm",
|
|
2975
|
-
children: selectedEvent?.id ? "
|
|
3003
|
+
children: selectedEvent?.id ? t("editEventDetails") : t("addNewEvent")
|
|
2976
3004
|
})
|
|
2977
3005
|
]
|
|
2978
3006
|
}),
|
|
2979
|
-
/* @__PURE__ */
|
|
3007
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
2980
3008
|
className: "grid gap-3 py-2 sm:gap-4 sm:py-4",
|
|
2981
3009
|
children: [
|
|
2982
|
-
/* @__PURE__ */
|
|
3010
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
2983
3011
|
className: "grid gap-2",
|
|
2984
3012
|
children: [
|
|
2985
3013
|
/* @__PURE__ */ jsx33(Label, {
|
|
2986
3014
|
htmlFor: "title",
|
|
2987
3015
|
className: "text-xs sm:text-sm",
|
|
2988
|
-
children: "
|
|
3016
|
+
children: t("title")
|
|
2989
3017
|
}),
|
|
2990
3018
|
/* @__PURE__ */ jsx33(Input, {
|
|
2991
3019
|
id: "title",
|
|
2992
3020
|
name: "title",
|
|
2993
3021
|
value: formValues.title,
|
|
2994
3022
|
onChange: handleInputChange,
|
|
2995
|
-
placeholder: "
|
|
3023
|
+
placeholder: t("eventTitlePlaceholder"),
|
|
2996
3024
|
required: true,
|
|
2997
3025
|
className: "h-8 text-sm sm:h-9"
|
|
2998
3026
|
})
|
|
2999
3027
|
]
|
|
3000
3028
|
}),
|
|
3001
|
-
/* @__PURE__ */
|
|
3029
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3002
3030
|
className: "grid gap-1 sm:gap-2",
|
|
3003
3031
|
children: [
|
|
3004
3032
|
/* @__PURE__ */ jsx33(Label, {
|
|
3005
3033
|
htmlFor: "description",
|
|
3006
3034
|
className: "text-xs sm:text-sm",
|
|
3007
|
-
children: "
|
|
3035
|
+
children: t("description")
|
|
3008
3036
|
}),
|
|
3009
3037
|
/* @__PURE__ */ jsx33(Input, {
|
|
3010
3038
|
id: "description",
|
|
3011
3039
|
name: "description",
|
|
3012
3040
|
value: formValues.description,
|
|
3013
3041
|
onChange: handleInputChange,
|
|
3014
|
-
placeholder: "
|
|
3042
|
+
placeholder: t("eventDescriptionPlaceholder"),
|
|
3015
3043
|
className: "h-8 text-sm sm:h-9"
|
|
3016
3044
|
})
|
|
3017
3045
|
]
|
|
3018
3046
|
}),
|
|
3019
|
-
/* @__PURE__ */
|
|
3047
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3020
3048
|
className: "flex items-center space-x-2",
|
|
3021
3049
|
children: [
|
|
3022
3050
|
/* @__PURE__ */ jsx33(Checkbox, {
|
|
@@ -3027,18 +3055,18 @@ var EventForm = ({
|
|
|
3027
3055
|
/* @__PURE__ */ jsx33(Label, {
|
|
3028
3056
|
htmlFor: "allDay",
|
|
3029
3057
|
className: "text-xs sm:text-sm",
|
|
3030
|
-
children: "
|
|
3058
|
+
children: t("allDay")
|
|
3031
3059
|
})
|
|
3032
3060
|
]
|
|
3033
3061
|
}),
|
|
3034
|
-
/* @__PURE__ */
|
|
3062
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3035
3063
|
className: "grid grid-cols-2 gap-2 sm:gap-4",
|
|
3036
3064
|
children: [
|
|
3037
|
-
/* @__PURE__ */
|
|
3065
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3038
3066
|
children: [
|
|
3039
3067
|
/* @__PURE__ */ jsx33(Label, {
|
|
3040
3068
|
className: "text-xs sm:text-sm",
|
|
3041
|
-
children: "
|
|
3069
|
+
children: t("startDate")
|
|
3042
3070
|
}),
|
|
3043
3071
|
/* @__PURE__ */ jsx33(DatePicker, {
|
|
3044
3072
|
date: startDate,
|
|
@@ -3048,11 +3076,11 @@ var EventForm = ({
|
|
|
3048
3076
|
})
|
|
3049
3077
|
]
|
|
3050
3078
|
}),
|
|
3051
|
-
/* @__PURE__ */
|
|
3079
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3052
3080
|
children: [
|
|
3053
3081
|
/* @__PURE__ */ jsx33(Label, {
|
|
3054
3082
|
className: "text-xs sm:text-sm",
|
|
3055
|
-
children: "
|
|
3083
|
+
children: t("endDate")
|
|
3056
3084
|
}),
|
|
3057
3085
|
/* @__PURE__ */ jsx33(DatePicker, {
|
|
3058
3086
|
date: endDate,
|
|
@@ -3064,15 +3092,15 @@ var EventForm = ({
|
|
|
3064
3092
|
})
|
|
3065
3093
|
]
|
|
3066
3094
|
}),
|
|
3067
|
-
!isAllDay && /* @__PURE__ */
|
|
3095
|
+
!isAllDay && /* @__PURE__ */ jsxs21("div", {
|
|
3068
3096
|
className: "grid grid-cols-2 gap-2 sm:gap-4",
|
|
3069
3097
|
children: [
|
|
3070
|
-
/* @__PURE__ */
|
|
3098
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3071
3099
|
children: [
|
|
3072
3100
|
/* @__PURE__ */ jsx33(Label, {
|
|
3073
3101
|
htmlFor: "start-time",
|
|
3074
3102
|
className: "text-xs sm:text-sm",
|
|
3075
|
-
children: "
|
|
3103
|
+
children: t("startTime")
|
|
3076
3104
|
}),
|
|
3077
3105
|
/* @__PURE__ */ jsx33(Input, {
|
|
3078
3106
|
id: "start-time",
|
|
@@ -3083,12 +3111,12 @@ var EventForm = ({
|
|
|
3083
3111
|
})
|
|
3084
3112
|
]
|
|
3085
3113
|
}),
|
|
3086
|
-
/* @__PURE__ */
|
|
3114
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3087
3115
|
children: [
|
|
3088
3116
|
/* @__PURE__ */ jsx33(Label, {
|
|
3089
3117
|
htmlFor: "end-time",
|
|
3090
3118
|
className: "text-xs sm:text-sm",
|
|
3091
|
-
children: "
|
|
3119
|
+
children: t("endTime")
|
|
3092
3120
|
}),
|
|
3093
3121
|
/* @__PURE__ */ jsx33(Input, {
|
|
3094
3122
|
id: "end-time",
|
|
@@ -3101,17 +3129,17 @@ var EventForm = ({
|
|
|
3101
3129
|
})
|
|
3102
3130
|
]
|
|
3103
3131
|
}),
|
|
3104
|
-
/* @__PURE__ */
|
|
3132
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3105
3133
|
className: "grid gap-1 sm:gap-2",
|
|
3106
3134
|
children: [
|
|
3107
3135
|
/* @__PURE__ */ jsx33(Label, {
|
|
3108
3136
|
className: "text-xs sm:text-sm",
|
|
3109
|
-
children: "
|
|
3137
|
+
children: t("color")
|
|
3110
3138
|
}),
|
|
3111
3139
|
/* @__PURE__ */ jsx33("div", {
|
|
3112
3140
|
className: "flex flex-wrap gap-2",
|
|
3113
3141
|
children: /* @__PURE__ */ jsx33(TooltipProvider, {
|
|
3114
|
-
children: colorOptions.map((color) => /* @__PURE__ */
|
|
3142
|
+
children: colorOptions.map((color) => /* @__PURE__ */ jsxs21(Tooltip, {
|
|
3115
3143
|
children: [
|
|
3116
3144
|
/* @__PURE__ */ jsx33(TooltipTrigger, {
|
|
3117
3145
|
asChild: true,
|
|
@@ -3135,20 +3163,20 @@ var EventForm = ({
|
|
|
3135
3163
|
})
|
|
3136
3164
|
]
|
|
3137
3165
|
}),
|
|
3138
|
-
/* @__PURE__ */
|
|
3166
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3139
3167
|
className: "grid gap-1 sm:gap-2",
|
|
3140
3168
|
children: [
|
|
3141
3169
|
/* @__PURE__ */ jsx33(Label, {
|
|
3142
3170
|
htmlFor: "location",
|
|
3143
3171
|
className: "text-xs sm:text-sm",
|
|
3144
|
-
children: "
|
|
3172
|
+
children: t("location")
|
|
3145
3173
|
}),
|
|
3146
3174
|
/* @__PURE__ */ jsx33(Input, {
|
|
3147
3175
|
id: "location",
|
|
3148
3176
|
name: "location",
|
|
3149
3177
|
value: formValues.location,
|
|
3150
3178
|
onChange: handleInputChange,
|
|
3151
|
-
placeholder: "
|
|
3179
|
+
placeholder: t("eventLocationPlaceholder"),
|
|
3152
3180
|
className: "h-8 text-sm sm:h-9"
|
|
3153
3181
|
})
|
|
3154
3182
|
]
|
|
@@ -3159,7 +3187,7 @@ var EventForm = ({
|
|
|
3159
3187
|
})
|
|
3160
3188
|
]
|
|
3161
3189
|
}),
|
|
3162
|
-
/* @__PURE__ */
|
|
3190
|
+
/* @__PURE__ */ jsxs21(DialogFooter, {
|
|
3163
3191
|
className: "mt-2 flex flex-col-reverse gap-2 sm:mt-4 sm:flex-row sm:gap-0",
|
|
3164
3192
|
children: [
|
|
3165
3193
|
selectedEvent?.id && /* @__PURE__ */ jsx33(Button, {
|
|
@@ -3168,9 +3196,9 @@ var EventForm = ({
|
|
|
3168
3196
|
onClick: handleDelete,
|
|
3169
3197
|
className: "w-full sm:mr-auto sm:w-auto",
|
|
3170
3198
|
size: "sm",
|
|
3171
|
-
children: "
|
|
3199
|
+
children: t("delete")
|
|
3172
3200
|
}),
|
|
3173
|
-
/* @__PURE__ */
|
|
3201
|
+
/* @__PURE__ */ jsxs21("div", {
|
|
3174
3202
|
className: "flex w-full gap-2 sm:w-auto",
|
|
3175
3203
|
children: [
|
|
3176
3204
|
/* @__PURE__ */ jsx33(Button, {
|
|
@@ -3179,13 +3207,13 @@ var EventForm = ({
|
|
|
3179
3207
|
onClick: onClose,
|
|
3180
3208
|
className: "flex-1 sm:flex-none",
|
|
3181
3209
|
size: "sm",
|
|
3182
|
-
children: "
|
|
3210
|
+
children: t("cancel")
|
|
3183
3211
|
}),
|
|
3184
3212
|
/* @__PURE__ */ jsx33(Button, {
|
|
3185
3213
|
type: "submit",
|
|
3186
3214
|
className: "flex-1 sm:flex-none",
|
|
3187
3215
|
size: "sm",
|
|
3188
|
-
children: selectedEvent?.id ? "
|
|
3216
|
+
children: selectedEvent?.id ? t("update") : t("create")
|
|
3189
3217
|
})
|
|
3190
3218
|
]
|
|
3191
3219
|
})
|
|
@@ -3354,29 +3382,29 @@ import { useCallback as useCallback2, useState as useState6 } from "react";
|
|
|
3354
3382
|
// src/components/header/title-content.tsx
|
|
3355
3383
|
import { AnimatePresence as AnimatePresence6, motion as motion6 } from "motion/react";
|
|
3356
3384
|
import { ChevronDown } from "lucide-react";
|
|
3357
|
-
import { useState as useState5 } from "react";
|
|
3358
|
-
import { jsx as jsx34, jsxs as
|
|
3359
|
-
var months = [
|
|
3360
|
-
"January",
|
|
3361
|
-
"February",
|
|
3362
|
-
"March",
|
|
3363
|
-
"April",
|
|
3364
|
-
"May",
|
|
3365
|
-
"June",
|
|
3366
|
-
"July",
|
|
3367
|
-
"August",
|
|
3368
|
-
"September",
|
|
3369
|
-
"October",
|
|
3370
|
-
"November",
|
|
3371
|
-
"December"
|
|
3372
|
-
];
|
|
3385
|
+
import { useMemo as useMemo7, useState as useState5 } from "react";
|
|
3386
|
+
import { jsx as jsx34, jsxs as jsxs22, Fragment as Fragment4 } from "react/jsx-runtime";
|
|
3373
3387
|
var animationVariants = {
|
|
3374
3388
|
initial: { opacity: 0, y: 10 },
|
|
3375
3389
|
animate: { opacity: 1, y: 0 },
|
|
3376
3390
|
exit: { opacity: 0, y: -10 }
|
|
3377
3391
|
};
|
|
3378
3392
|
var TitleContent = () => {
|
|
3379
|
-
const { currentDate, view, setCurrentDate } = useCalendarContext();
|
|
3393
|
+
const { currentDate, view, setCurrentDate, t } = useCalendarContext();
|
|
3394
|
+
const months = useMemo7(() => [
|
|
3395
|
+
t("january"),
|
|
3396
|
+
t("february"),
|
|
3397
|
+
t("march"),
|
|
3398
|
+
t("april"),
|
|
3399
|
+
t("may"),
|
|
3400
|
+
t("june"),
|
|
3401
|
+
t("july"),
|
|
3402
|
+
t("august"),
|
|
3403
|
+
t("september"),
|
|
3404
|
+
t("october"),
|
|
3405
|
+
t("november"),
|
|
3406
|
+
t("december")
|
|
3407
|
+
], [t]);
|
|
3380
3408
|
const [monthPopoverOpen, setMonthPopoverOpen] = useState5(false);
|
|
3381
3409
|
const [yearPopoverOpen, setYearPopoverOpen] = useState5(false);
|
|
3382
3410
|
const [weekPopoverOpen, setWeekPopoverOpen] = useState5(false);
|
|
@@ -3393,15 +3421,15 @@ var TitleContent = () => {
|
|
|
3393
3421
|
setCurrentDate(newDate);
|
|
3394
3422
|
setYearPopoverOpen(false);
|
|
3395
3423
|
};
|
|
3396
|
-
return /* @__PURE__ */
|
|
3424
|
+
return /* @__PURE__ */ jsxs22(Fragment4, {
|
|
3397
3425
|
children: [
|
|
3398
|
-
view !== "year" && /* @__PURE__ */
|
|
3426
|
+
view !== "year" && /* @__PURE__ */ jsxs22(Popover, {
|
|
3399
3427
|
open: monthPopoverOpen,
|
|
3400
3428
|
onOpenChange: setMonthPopoverOpen,
|
|
3401
3429
|
children: [
|
|
3402
3430
|
/* @__PURE__ */ jsx34(PopoverTrigger, {
|
|
3403
3431
|
asChild: true,
|
|
3404
|
-
children: /* @__PURE__ */
|
|
3432
|
+
children: /* @__PURE__ */ jsxs22(Button, {
|
|
3405
3433
|
variant: "ghost",
|
|
3406
3434
|
className: "flex items-center gap-1 px-1! font-semibold",
|
|
3407
3435
|
children: [
|
|
@@ -3436,13 +3464,13 @@ var TitleContent = () => {
|
|
|
3436
3464
|
})
|
|
3437
3465
|
]
|
|
3438
3466
|
}),
|
|
3439
|
-
/* @__PURE__ */
|
|
3467
|
+
/* @__PURE__ */ jsxs22(Popover, {
|
|
3440
3468
|
open: yearPopoverOpen,
|
|
3441
3469
|
onOpenChange: setYearPopoverOpen,
|
|
3442
3470
|
children: [
|
|
3443
3471
|
/* @__PURE__ */ jsx34(PopoverTrigger, {
|
|
3444
3472
|
asChild: true,
|
|
3445
|
-
children: /* @__PURE__ */
|
|
3473
|
+
children: /* @__PURE__ */ jsxs22(Button, {
|
|
3446
3474
|
variant: "ghost",
|
|
3447
3475
|
className: "flex items-center gap-1 px-1! font-semibold",
|
|
3448
3476
|
children: [
|
|
@@ -3477,13 +3505,13 @@ var TitleContent = () => {
|
|
|
3477
3505
|
})
|
|
3478
3506
|
]
|
|
3479
3507
|
}),
|
|
3480
|
-
view === "week" && /* @__PURE__ */
|
|
3508
|
+
view === "week" && /* @__PURE__ */ jsxs22(Popover, {
|
|
3481
3509
|
open: weekPopoverOpen,
|
|
3482
3510
|
onOpenChange: setWeekPopoverOpen,
|
|
3483
3511
|
children: [
|
|
3484
3512
|
/* @__PURE__ */ jsx34(PopoverTrigger, {
|
|
3485
3513
|
asChild: true,
|
|
3486
|
-
children: /* @__PURE__ */
|
|
3514
|
+
children: /* @__PURE__ */ jsxs22(Button, {
|
|
3487
3515
|
variant: "ghost",
|
|
3488
3516
|
className: "flex items-center gap-1 px-1! font-semibold",
|
|
3489
3517
|
children: [
|
|
@@ -3520,7 +3548,7 @@ var TitleContent = () => {
|
|
|
3520
3548
|
setCurrentDate(startOfWeek);
|
|
3521
3549
|
setWeekPopoverOpen(false);
|
|
3522
3550
|
},
|
|
3523
|
-
children: /* @__PURE__ */
|
|
3551
|
+
children: /* @__PURE__ */ jsxs22("div", {
|
|
3524
3552
|
className: "flex w-full items-center justify-between",
|
|
3525
3553
|
children: [
|
|
3526
3554
|
/* @__PURE__ */ jsx34("span", {
|
|
@@ -3538,13 +3566,13 @@ var TitleContent = () => {
|
|
|
3538
3566
|
})
|
|
3539
3567
|
]
|
|
3540
3568
|
}),
|
|
3541
|
-
view === "day" && /* @__PURE__ */
|
|
3569
|
+
view === "day" && /* @__PURE__ */ jsxs22(Popover, {
|
|
3542
3570
|
open: dayPopoverOpen,
|
|
3543
3571
|
onOpenChange: setDayPopoverOpen,
|
|
3544
3572
|
children: [
|
|
3545
3573
|
/* @__PURE__ */ jsx34(PopoverTrigger, {
|
|
3546
3574
|
asChild: true,
|
|
3547
|
-
children: /* @__PURE__ */
|
|
3575
|
+
children: /* @__PURE__ */ jsxs22(Button, {
|
|
3548
3576
|
variant: "ghost",
|
|
3549
3577
|
className: "flex items-center gap-1 px-1! font-semibold",
|
|
3550
3578
|
children: [
|
|
@@ -3583,7 +3611,7 @@ var TitleContent = () => {
|
|
|
3583
3611
|
setCurrentDate(dayDate);
|
|
3584
3612
|
setDayPopoverOpen(false);
|
|
3585
3613
|
},
|
|
3586
|
-
children: /* @__PURE__ */
|
|
3614
|
+
children: /* @__PURE__ */ jsxs22("div", {
|
|
3587
3615
|
className: "flex w-full items-center justify-between",
|
|
3588
3616
|
children: [
|
|
3589
3617
|
/* @__PURE__ */ jsx34("span", {
|
|
@@ -3591,7 +3619,7 @@ var TitleContent = () => {
|
|
|
3591
3619
|
}),
|
|
3592
3620
|
isToday && /* @__PURE__ */ jsx34("span", {
|
|
3593
3621
|
className: "bg-primary text-primary-foreground rounded-sm px-1! text-xs",
|
|
3594
|
-
children: "
|
|
3622
|
+
children: t("today")
|
|
3595
3623
|
})
|
|
3596
3624
|
]
|
|
3597
3625
|
})
|
|
@@ -3609,7 +3637,7 @@ var title_content_default = TitleContent;
|
|
|
3609
3637
|
|
|
3610
3638
|
// src/components/header/view-controls.tsx
|
|
3611
3639
|
import { ChevronLeft, ChevronRight } from "lucide-react";
|
|
3612
|
-
import { jsx as jsx35, jsxs as
|
|
3640
|
+
import { jsx as jsx35, jsxs as jsxs23 } from "react/jsx-runtime";
|
|
3613
3641
|
var ViewControls = ({
|
|
3614
3642
|
currentView,
|
|
3615
3643
|
onChange,
|
|
@@ -3620,14 +3648,15 @@ var ViewControls = ({
|
|
|
3620
3648
|
onNext,
|
|
3621
3649
|
onPrevious
|
|
3622
3650
|
}) => {
|
|
3651
|
+
const { t } = useCalendarContext();
|
|
3623
3652
|
const isGrid = variant === "grid";
|
|
3624
3653
|
const getButtonClassName = (viewType) => {
|
|
3625
|
-
return cn(isGrid ? "w-full" : "",
|
|
3654
|
+
return cn(isGrid ? "w-full" : "", currentView === viewType && "bg-primary/80");
|
|
3626
3655
|
};
|
|
3627
3656
|
const getBtnVariant = (viewType) => {
|
|
3628
3657
|
return currentView === viewType ? "default" : "outline";
|
|
3629
3658
|
};
|
|
3630
|
-
return /* @__PURE__ */
|
|
3659
|
+
return /* @__PURE__ */ jsxs23("div", {
|
|
3631
3660
|
className: cn(isGrid ? "grid grid-cols-2 gap-2" : "flex gap-1", className),
|
|
3632
3661
|
children: [
|
|
3633
3662
|
/* @__PURE__ */ jsx35(Button, {
|
|
@@ -3651,41 +3680,41 @@ var ViewControls = ({
|
|
|
3651
3680
|
variant: getBtnVariant("day"),
|
|
3652
3681
|
size,
|
|
3653
3682
|
className: getButtonClassName("day"),
|
|
3654
|
-
children: "
|
|
3683
|
+
children: t("day")
|
|
3655
3684
|
}),
|
|
3656
3685
|
/* @__PURE__ */ jsx35(Button, {
|
|
3657
3686
|
onClick: () => onChange("week"),
|
|
3658
3687
|
variant: getBtnVariant("week"),
|
|
3659
3688
|
size,
|
|
3660
3689
|
className: getButtonClassName("week"),
|
|
3661
|
-
children: "
|
|
3690
|
+
children: t("week")
|
|
3662
3691
|
}),
|
|
3663
3692
|
/* @__PURE__ */ jsx35(Button, {
|
|
3664
3693
|
onClick: () => onChange("month"),
|
|
3665
3694
|
variant: getBtnVariant("month"),
|
|
3666
3695
|
size,
|
|
3667
3696
|
className: getButtonClassName("month"),
|
|
3668
|
-
children: "
|
|
3697
|
+
children: t("month")
|
|
3669
3698
|
}),
|
|
3670
3699
|
/* @__PURE__ */ jsx35(Button, {
|
|
3671
3700
|
onClick: () => onChange("year"),
|
|
3672
3701
|
variant: getBtnVariant("year"),
|
|
3673
3702
|
size,
|
|
3674
3703
|
className: getButtonClassName("year"),
|
|
3675
|
-
children: "
|
|
3704
|
+
children: t("year")
|
|
3676
3705
|
}),
|
|
3677
3706
|
/* @__PURE__ */ jsx35(Button, {
|
|
3678
3707
|
onClick: onToday,
|
|
3679
3708
|
variant: "outline",
|
|
3680
3709
|
size,
|
|
3681
|
-
children: "
|
|
3710
|
+
children: t("today")
|
|
3682
3711
|
})
|
|
3683
3712
|
]
|
|
3684
3713
|
});
|
|
3685
3714
|
};
|
|
3686
3715
|
var view_controls_default = ViewControls;
|
|
3687
3716
|
// src/components/header/base-header.tsx
|
|
3688
|
-
import { jsx as jsx36, jsxs as
|
|
3717
|
+
import { jsx as jsx36, jsxs as jsxs24, Fragment as Fragment5 } from "react/jsx-runtime";
|
|
3689
3718
|
var Header = ({ className = "" }) => {
|
|
3690
3719
|
const {
|
|
3691
3720
|
view,
|
|
@@ -3695,6 +3724,7 @@ var Header = ({ className = "" }) => {
|
|
|
3695
3724
|
today,
|
|
3696
3725
|
openEventForm,
|
|
3697
3726
|
headerComponent,
|
|
3727
|
+
headerClassName,
|
|
3698
3728
|
rawEvents
|
|
3699
3729
|
} = useCalendarContext();
|
|
3700
3730
|
const [mobilePopoverOpen, setMobilePopoverOpen] = useState6(false);
|
|
@@ -3725,7 +3755,7 @@ var Header = ({ className = "" }) => {
|
|
|
3725
3755
|
};
|
|
3726
3756
|
const NewEventButton = useCallback2(() => /* @__PURE__ */ jsx36("div", {
|
|
3727
3757
|
className: "flex items-center gap-2",
|
|
3728
|
-
children: /* @__PURE__ */
|
|
3758
|
+
children: /* @__PURE__ */ jsxs24(Button, {
|
|
3729
3759
|
onClick: () => openEventForm(),
|
|
3730
3760
|
variant: "default",
|
|
3731
3761
|
size: "sm",
|
|
@@ -3735,7 +3765,7 @@ var Header = ({ className = "" }) => {
|
|
|
3735
3765
|
className: "h-4 w-4"
|
|
3736
3766
|
}),
|
|
3737
3767
|
/* @__PURE__ */ jsx36("span", {
|
|
3738
|
-
className: "hidden
|
|
3768
|
+
className: "hidden @4xl:inline",
|
|
3739
3769
|
children: "New"
|
|
3740
3770
|
})
|
|
3741
3771
|
]
|
|
@@ -3745,124 +3775,127 @@ var Header = ({ className = "" }) => {
|
|
|
3745
3775
|
return headerComponent;
|
|
3746
3776
|
}
|
|
3747
3777
|
return /* @__PURE__ */ jsx36(Fragment5, {
|
|
3748
|
-
children: /* @__PURE__ */
|
|
3749
|
-
className:
|
|
3778
|
+
children: /* @__PURE__ */ jsx36("div", {
|
|
3779
|
+
className: "@container/base-header w-full",
|
|
3750
3780
|
"data-testid": "calendar-header",
|
|
3751
|
-
children:
|
|
3752
|
-
|
|
3753
|
-
|
|
3754
|
-
|
|
3755
|
-
|
|
3756
|
-
|
|
3757
|
-
|
|
3758
|
-
|
|
3759
|
-
|
|
3760
|
-
|
|
3761
|
-
|
|
3762
|
-
|
|
3763
|
-
|
|
3764
|
-
|
|
3765
|
-
|
|
3766
|
-
|
|
3767
|
-
|
|
3768
|
-
|
|
3769
|
-
|
|
3770
|
-
|
|
3771
|
-
|
|
3772
|
-
|
|
3773
|
-
|
|
3774
|
-
|
|
3775
|
-
|
|
3776
|
-
|
|
3777
|
-
|
|
3778
|
-
|
|
3779
|
-
|
|
3780
|
-
|
|
3781
|
-
|
|
3782
|
-
|
|
3783
|
-
|
|
3784
|
-
|
|
3785
|
-
|
|
3786
|
-
|
|
3787
|
-
|
|
3788
|
-
|
|
3789
|
-
|
|
3790
|
-
|
|
3791
|
-
})
|
|
3792
|
-
]
|
|
3793
|
-
}),
|
|
3794
|
-
/* @__PURE__ */ jsxs23("div", {
|
|
3795
|
-
className: "flex items-center justify-end gap-1 sm:hidden",
|
|
3796
|
-
children: [
|
|
3797
|
-
/* @__PURE__ */ jsx36(NewEventButton, {}),
|
|
3798
|
-
/* @__PURE__ */ jsxs23(Popover, {
|
|
3799
|
-
open: mobilePopoverOpen,
|
|
3800
|
-
onOpenChange: setMobilePopoverOpen,
|
|
3801
|
-
children: [
|
|
3802
|
-
/* @__PURE__ */ jsx36(PopoverTrigger, {
|
|
3803
|
-
asChild: true,
|
|
3804
|
-
children: /* @__PURE__ */ jsx36(Button, {
|
|
3805
|
-
variant: "outline",
|
|
3806
|
-
size: "sm",
|
|
3807
|
-
children: /* @__PURE__ */ jsx36(Menu, {
|
|
3808
|
-
className: "h-4 w-4"
|
|
3809
|
-
})
|
|
3781
|
+
children: /* @__PURE__ */ jsxs24("div", {
|
|
3782
|
+
className: cn("flex justify-center @2xl/base-header:justify-between flex-wrap items-center gap-2 border-b", className, headerClassName),
|
|
3783
|
+
children: [
|
|
3784
|
+
/* @__PURE__ */ jsxs24("div", {
|
|
3785
|
+
className: "flex flex-wrap items-center justify-center gap-1 @2xl/base-header:justify-start",
|
|
3786
|
+
children: [
|
|
3787
|
+
/* @__PURE__ */ jsx36(CalendarIcon2, {
|
|
3788
|
+
className: "h-5 w-5"
|
|
3789
|
+
}),
|
|
3790
|
+
/* @__PURE__ */ jsx36(title_content_default, {})
|
|
3791
|
+
]
|
|
3792
|
+
}),
|
|
3793
|
+
/* @__PURE__ */ jsxs24("div", {
|
|
3794
|
+
className: "flex flex-wrap justify-start @xl/base-header:justify-center gap-1 @4xl/base-header:justify-end overflow-x-auto",
|
|
3795
|
+
children: [
|
|
3796
|
+
/* @__PURE__ */ jsxs24("div", {
|
|
3797
|
+
className: "hidden @md/base-header:flex items-center justify-start gap-1",
|
|
3798
|
+
children: [
|
|
3799
|
+
/* @__PURE__ */ jsx36(view_controls_default, {
|
|
3800
|
+
currentView: view,
|
|
3801
|
+
onChange: setView,
|
|
3802
|
+
onToday: today,
|
|
3803
|
+
onNext: nextPeriod,
|
|
3804
|
+
onPrevious: prevPeriod,
|
|
3805
|
+
variant: "default",
|
|
3806
|
+
className: "justify-end"
|
|
3807
|
+
}),
|
|
3808
|
+
/* @__PURE__ */ jsx36(NewEventButton, {}),
|
|
3809
|
+
/* @__PURE__ */ jsxs24(Button, {
|
|
3810
|
+
onClick: handleExport,
|
|
3811
|
+
variant: "outline",
|
|
3812
|
+
size: "sm",
|
|
3813
|
+
className: "flex items-center gap-1",
|
|
3814
|
+
children: [
|
|
3815
|
+
/* @__PURE__ */ jsx36(Download, {
|
|
3816
|
+
className: "h-4 w-4"
|
|
3817
|
+
}),
|
|
3818
|
+
/* @__PURE__ */ jsx36("span", {
|
|
3819
|
+
className: "hidden @4xl/base-header:inline",
|
|
3820
|
+
children: "Export"
|
|
3810
3821
|
})
|
|
3811
|
-
|
|
3812
|
-
|
|
3813
|
-
|
|
3814
|
-
|
|
3815
|
-
|
|
3816
|
-
|
|
3817
|
-
|
|
3818
|
-
|
|
3819
|
-
|
|
3820
|
-
|
|
3821
|
-
|
|
3822
|
-
|
|
3823
|
-
|
|
3824
|
-
|
|
3825
|
-
|
|
3826
|
-
|
|
3827
|
-
|
|
3828
|
-
|
|
3829
|
-
|
|
3830
|
-
/* @__PURE__ */ jsx36("div", {
|
|
3831
|
-
className: "pt-2 border-t",
|
|
3832
|
-
children: /* @__PURE__ */ jsxs23(Button, {
|
|
3833
|
-
onClick: handleExport,
|
|
3834
|
-
variant: "outline",
|
|
3835
|
-
size: "sm",
|
|
3836
|
-
className: "w-full flex items-center gap-2",
|
|
3837
|
-
children: [
|
|
3838
|
-
/* @__PURE__ */ jsx36(Download, {
|
|
3839
|
-
className: "h-4 w-4"
|
|
3840
|
-
}),
|
|
3841
|
-
"Export Calendar (.ics)"
|
|
3842
|
-
]
|
|
3843
|
-
})
|
|
3822
|
+
]
|
|
3823
|
+
})
|
|
3824
|
+
]
|
|
3825
|
+
}),
|
|
3826
|
+
/* @__PURE__ */ jsxs24("div", {
|
|
3827
|
+
className: "flex items-center justify-end gap-1 @md/base-header:hidden",
|
|
3828
|
+
children: [
|
|
3829
|
+
/* @__PURE__ */ jsx36(NewEventButton, {}),
|
|
3830
|
+
/* @__PURE__ */ jsxs24(Popover, {
|
|
3831
|
+
open: mobilePopoverOpen,
|
|
3832
|
+
onOpenChange: setMobilePopoverOpen,
|
|
3833
|
+
children: [
|
|
3834
|
+
/* @__PURE__ */ jsx36(PopoverTrigger, {
|
|
3835
|
+
asChild: true,
|
|
3836
|
+
children: /* @__PURE__ */ jsx36(Button, {
|
|
3837
|
+
variant: "outline",
|
|
3838
|
+
size: "sm",
|
|
3839
|
+
children: /* @__PURE__ */ jsx36(Menu, {
|
|
3840
|
+
className: "h-4 w-4"
|
|
3844
3841
|
})
|
|
3845
|
-
|
|
3842
|
+
})
|
|
3843
|
+
}),
|
|
3844
|
+
/* @__PURE__ */ jsx36(PopoverContent, {
|
|
3845
|
+
align: "end",
|
|
3846
|
+
className: "w-[240px] p-2",
|
|
3847
|
+
children: /* @__PURE__ */ jsxs24("div", {
|
|
3848
|
+
className: "space-y-2",
|
|
3849
|
+
children: [
|
|
3850
|
+
/* @__PURE__ */ jsx36("h3", {
|
|
3851
|
+
className: "mb-1 text-sm font-medium",
|
|
3852
|
+
children: "View & Navigation"
|
|
3853
|
+
}),
|
|
3854
|
+
/* @__PURE__ */ jsx36(view_controls_default, {
|
|
3855
|
+
currentView: view,
|
|
3856
|
+
onChange: (newView) => handleViewChange(newView, true),
|
|
3857
|
+
onToday: handleNavigation.today,
|
|
3858
|
+
onNext: handleNavigation.next,
|
|
3859
|
+
onPrevious: handleNavigation.previous,
|
|
3860
|
+
variant: "grid"
|
|
3861
|
+
}),
|
|
3862
|
+
/* @__PURE__ */ jsx36("div", {
|
|
3863
|
+
className: "pt-2 border-t",
|
|
3864
|
+
children: /* @__PURE__ */ jsxs24(Button, {
|
|
3865
|
+
onClick: handleExport,
|
|
3866
|
+
variant: "outline",
|
|
3867
|
+
size: "sm",
|
|
3868
|
+
className: "w-full flex items-center gap-2",
|
|
3869
|
+
children: [
|
|
3870
|
+
/* @__PURE__ */ jsx36(Download, {
|
|
3871
|
+
className: "h-4 w-4"
|
|
3872
|
+
}),
|
|
3873
|
+
"Export Calendar (.ics)"
|
|
3874
|
+
]
|
|
3875
|
+
})
|
|
3876
|
+
})
|
|
3877
|
+
]
|
|
3878
|
+
})
|
|
3846
3879
|
})
|
|
3847
|
-
|
|
3848
|
-
|
|
3849
|
-
|
|
3850
|
-
|
|
3851
|
-
|
|
3852
|
-
|
|
3853
|
-
|
|
3854
|
-
|
|
3880
|
+
]
|
|
3881
|
+
})
|
|
3882
|
+
]
|
|
3883
|
+
})
|
|
3884
|
+
]
|
|
3885
|
+
})
|
|
3886
|
+
]
|
|
3887
|
+
})
|
|
3855
3888
|
})
|
|
3856
3889
|
});
|
|
3857
3890
|
};
|
|
3858
3891
|
var base_header_default = Header;
|
|
3859
3892
|
// src/features/year-view/view/year-view.tsx
|
|
3860
3893
|
import { AnimatePresence as AnimatePresence7, motion as motion7 } from "motion/react";
|
|
3861
|
-
import { jsx as jsx37, jsxs as
|
|
3894
|
+
import { jsx as jsx37, jsxs as jsxs25 } from "react/jsx-runtime";
|
|
3862
3895
|
var YearView = () => {
|
|
3863
|
-
const { currentDate, selectDate, events, setView, getEventsForDateRange } = useCalendarContext();
|
|
3896
|
+
const { currentDate, selectDate, events, setView, getEventsForDateRange, t } = useCalendarContext();
|
|
3864
3897
|
const year = currentDate.year();
|
|
3865
|
-
const
|
|
3898
|
+
const months = Array.from({ length: 12 }, (_, i) => {
|
|
3866
3899
|
const monthDate = dayjs_config_default().year(year).month(i).startOf("month");
|
|
3867
3900
|
return {
|
|
3868
3901
|
date: monthDate,
|
|
@@ -3871,7 +3904,7 @@ var YearView = () => {
|
|
|
3871
3904
|
firstDayOfMonth: monthDate.startOf("month").day()
|
|
3872
3905
|
};
|
|
3873
3906
|
});
|
|
3874
|
-
const monthsWithEventCount =
|
|
3907
|
+
const monthsWithEventCount = months.map((month) => {
|
|
3875
3908
|
const eventsInMonth = events.filter((event) => event.start.year() === year && event.start.month() === month.date.month());
|
|
3876
3909
|
return {
|
|
3877
3910
|
...month,
|
|
@@ -3906,7 +3939,7 @@ var YearView = () => {
|
|
|
3906
3939
|
events: dayEvents
|
|
3907
3940
|
};
|
|
3908
3941
|
});
|
|
3909
|
-
return /* @__PURE__ */
|
|
3942
|
+
return /* @__PURE__ */ jsxs25("div", {
|
|
3910
3943
|
"data-testid": `year-mini-calendar-${month.date.format("MM")}`,
|
|
3911
3944
|
className: "grid grid-cols-7 gap-[1px] text-[0.6rem]",
|
|
3912
3945
|
children: [
|
|
@@ -3914,7 +3947,7 @@ var YearView = () => {
|
|
|
3914
3947
|
className: "text-muted-foreground h-3 text-center",
|
|
3915
3948
|
children: dayName
|
|
3916
3949
|
}, `header-${i}`)),
|
|
3917
|
-
daysArray.map((dayInfo, i) => /* @__PURE__ */
|
|
3950
|
+
daysArray.map((dayInfo, i) => /* @__PURE__ */ jsxs25("div", {
|
|
3918
3951
|
"data-testid": `year-day-${month.date.format("YYYY-MM")}-${dayInfo.day.format("YYYY-MM-DD")}`,
|
|
3919
3952
|
onClick: (e) => handleDayClick(dayInfo.day, e),
|
|
3920
3953
|
className: cn("relative flex aspect-square w-full cursor-pointer flex-col items-center justify-center", "hover:bg-accent rounded-sm transition-colors duration-200", !dayInfo.isCurrentMonth && "text-muted-foreground opacity-50", dayInfo.isToday && "bg-primary text-primary-foreground rounded-full", dayInfo.isCurrentDate && !dayInfo.isToday && "bg-muted rounded-full font-bold", dayInfo.hasEvents && !dayInfo.isToday && !dayInfo.isCurrentDate && "font-medium"),
|
|
@@ -3924,7 +3957,7 @@ var YearView = () => {
|
|
|
3924
3957
|
className: "text-center leading-none",
|
|
3925
3958
|
children: dayInfo.day.date()
|
|
3926
3959
|
}),
|
|
3927
|
-
dayInfo.hasEvents && /* @__PURE__ */
|
|
3960
|
+
dayInfo.hasEvents && /* @__PURE__ */ jsxs25("div", {
|
|
3928
3961
|
className: cn("absolute bottom-0 flex w-full justify-center space-x-[1px]", dayInfo.isToday ? "bottom-[1px]" : ""),
|
|
3929
3962
|
children: [
|
|
3930
3963
|
dayInfo.eventCount > 0 && /* @__PURE__ */ jsx37("span", {
|
|
@@ -3949,14 +3982,14 @@ var YearView = () => {
|
|
|
3949
3982
|
children: /* @__PURE__ */ jsx37("div", {
|
|
3950
3983
|
"data-testid": "year-grid",
|
|
3951
3984
|
className: "grid auto-rows-fr grid-cols-1 gap-4 p-4 sm:grid-cols-2 lg:grid-cols-3",
|
|
3952
|
-
children: monthsWithEventCount.map((month, index) => /* @__PURE__ */
|
|
3985
|
+
children: monthsWithEventCount.map((month, index) => /* @__PURE__ */ jsxs25("div", {
|
|
3953
3986
|
"data-testid": `year-month-${month.date.format("MM")}`,
|
|
3954
3987
|
onClick: () => handleMonthClick(month.date),
|
|
3955
3988
|
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",
|
|
3956
3989
|
children: [
|
|
3957
3990
|
/* @__PURE__ */ jsx37(AnimatePresence7, {
|
|
3958
3991
|
mode: "wait",
|
|
3959
|
-
children: /* @__PURE__ */
|
|
3992
|
+
children: /* @__PURE__ */ jsxs25(motion7.div, {
|
|
3960
3993
|
initial: { opacity: 0, y: -10 },
|
|
3961
3994
|
animate: { opacity: 1, y: 0 },
|
|
3962
3995
|
exit: { opacity: 0, y: -10 },
|
|
@@ -3972,13 +4005,13 @@ var YearView = () => {
|
|
|
3972
4005
|
className: "text-lg font-medium",
|
|
3973
4006
|
children: month.name
|
|
3974
4007
|
}),
|
|
3975
|
-
month.eventCount > 0 && /* @__PURE__ */
|
|
4008
|
+
month.eventCount > 0 && /* @__PURE__ */ jsxs25("span", {
|
|
3976
4009
|
"data-testid": `year-month-event-count-${month.date.format("MM")}`,
|
|
3977
4010
|
className: "bg-primary text-primary-foreground rounded-full px-2 py-1 text-xs",
|
|
3978
4011
|
children: [
|
|
3979
4012
|
month.eventCount,
|
|
3980
4013
|
" ",
|
|
3981
|
-
month.eventCount === 1 ? "event" : "events"
|
|
4014
|
+
month.eventCount === 1 ? t("event") : t("events")
|
|
3982
4015
|
]
|
|
3983
4016
|
})
|
|
3984
4017
|
]
|
|
@@ -4007,7 +4040,7 @@ import {
|
|
|
4007
4040
|
} from "@dnd-kit/core";
|
|
4008
4041
|
import React9, { useState as useState7 } from "react";
|
|
4009
4042
|
import { snapCenterToCursor } from "@dnd-kit/modifiers";
|
|
4010
|
-
import { jsx as jsx38, jsxs as
|
|
4043
|
+
import { jsx as jsx38, jsxs as jsxs26, Fragment as Fragment6 } from "react/jsx-runtime";
|
|
4011
4044
|
function CalendarDndContext({ children }) {
|
|
4012
4045
|
const { updateEvent, updateRecurringEvent: updateRecurringEvent2, view, disableDragAndDrop } = useCalendarContext();
|
|
4013
4046
|
const [activeEvent, setActiveEvent] = React9.useState(null);
|
|
@@ -4134,9 +4167,9 @@ function CalendarDndContext({ children }) {
|
|
|
4134
4167
|
if (disableDragAndDrop) {
|
|
4135
4168
|
return children;
|
|
4136
4169
|
}
|
|
4137
|
-
return /* @__PURE__ */
|
|
4170
|
+
return /* @__PURE__ */ jsxs26(Fragment6, {
|
|
4138
4171
|
children: [
|
|
4139
|
-
/* @__PURE__ */
|
|
4172
|
+
/* @__PURE__ */ jsxs26(DndContext, {
|
|
4140
4173
|
sensors,
|
|
4141
4174
|
onDragStart: handleDragStart,
|
|
4142
4175
|
onDragEnd: handleDragEnd,
|
|
@@ -4165,16 +4198,114 @@ function CalendarDndContext({ children }) {
|
|
|
4165
4198
|
}
|
|
4166
4199
|
|
|
4167
4200
|
// src/contexts/calendar-context/provider.tsx
|
|
4168
|
-
import { useCallback as useCallback3, useEffect as useEffect4, useMemo as
|
|
4201
|
+
import { useCallback as useCallback3, useEffect as useEffect4, useMemo as useMemo8, useState as useState8 } from "react";
|
|
4202
|
+
|
|
4203
|
+
// src/lib/translations/default.ts
|
|
4204
|
+
var defaultTranslations = {
|
|
4205
|
+
today: "Today",
|
|
4206
|
+
create: "Create",
|
|
4207
|
+
update: "Update",
|
|
4208
|
+
delete: "Delete",
|
|
4209
|
+
cancel: "Cancel",
|
|
4210
|
+
event: "Event",
|
|
4211
|
+
events: "Events",
|
|
4212
|
+
newEvent: "New Event",
|
|
4213
|
+
title: "Title",
|
|
4214
|
+
description: "Description",
|
|
4215
|
+
location: "Location",
|
|
4216
|
+
allDay: "All day",
|
|
4217
|
+
startDate: "Start Date",
|
|
4218
|
+
endDate: "End Date",
|
|
4219
|
+
startTime: "Start Time",
|
|
4220
|
+
endTime: "End Time",
|
|
4221
|
+
color: "Color",
|
|
4222
|
+
createEvent: "Create Event",
|
|
4223
|
+
editEvent: "Edit Event",
|
|
4224
|
+
addNewEvent: "Add a new event to your calendar",
|
|
4225
|
+
editEventDetails: "Edit your event details",
|
|
4226
|
+
eventTitlePlaceholder: "Event title",
|
|
4227
|
+
eventDescriptionPlaceholder: "Event description (optional)",
|
|
4228
|
+
eventLocationPlaceholder: "Event location (optional)",
|
|
4229
|
+
repeat: "Repeat",
|
|
4230
|
+
repeats: "Repeats",
|
|
4231
|
+
customRecurrence: "Custom recurrence",
|
|
4232
|
+
daily: "Daily",
|
|
4233
|
+
weekly: "Weekly",
|
|
4234
|
+
monthly: "Monthly",
|
|
4235
|
+
yearly: "Yearly",
|
|
4236
|
+
interval: "Interval",
|
|
4237
|
+
repeatOn: "Repeat on",
|
|
4238
|
+
never: "Never",
|
|
4239
|
+
count: "Count",
|
|
4240
|
+
every: "Every",
|
|
4241
|
+
ends: "Ends",
|
|
4242
|
+
after: "After",
|
|
4243
|
+
occurrences: "occurrences",
|
|
4244
|
+
on: "On",
|
|
4245
|
+
editRecurringEvent: "Edit recurring event",
|
|
4246
|
+
deleteRecurringEvent: "Delete recurring event",
|
|
4247
|
+
editRecurringEventQuestion: "is a recurring event. How would you like to edit it?",
|
|
4248
|
+
deleteRecurringEventQuestion: "is a recurring event. How would you like to delete it?",
|
|
4249
|
+
thisEvent: "This event",
|
|
4250
|
+
thisEventDescription: "Only change this specific occurrence",
|
|
4251
|
+
thisAndFollowingEvents: "This and following events",
|
|
4252
|
+
thisAndFollowingEventsDescription: "Edit this and all future occurrences",
|
|
4253
|
+
allEvents: "All events",
|
|
4254
|
+
allEventsDescription: "Edit the entire recurring series",
|
|
4255
|
+
onlyChangeThis: "Only change this specific occurrence",
|
|
4256
|
+
changeThisAndFuture: "Change this and all future occurrences",
|
|
4257
|
+
changeEntireSeries: "Change the entire recurring series",
|
|
4258
|
+
onlyDeleteThis: "Only delete this specific occurrence",
|
|
4259
|
+
deleteThisAndFuture: "Delete this and all future occurrences",
|
|
4260
|
+
deleteEntireSeries: "Delete the entire recurring series",
|
|
4261
|
+
month: "Month",
|
|
4262
|
+
week: "Week",
|
|
4263
|
+
day: "Day",
|
|
4264
|
+
year: "Year",
|
|
4265
|
+
more: "more",
|
|
4266
|
+
sunday: "Sunday",
|
|
4267
|
+
monday: "Monday",
|
|
4268
|
+
tuesday: "Tuesday",
|
|
4269
|
+
wednesday: "Wednesday",
|
|
4270
|
+
thursday: "Thursday",
|
|
4271
|
+
friday: "Friday",
|
|
4272
|
+
saturday: "Saturday",
|
|
4273
|
+
sun: "Sun",
|
|
4274
|
+
mon: "Mon",
|
|
4275
|
+
tue: "Tue",
|
|
4276
|
+
wed: "Wed",
|
|
4277
|
+
thu: "Thu",
|
|
4278
|
+
fri: "Fri",
|
|
4279
|
+
sat: "Sat",
|
|
4280
|
+
january: "January",
|
|
4281
|
+
february: "February",
|
|
4282
|
+
march: "March",
|
|
4283
|
+
april: "April",
|
|
4284
|
+
may: "May",
|
|
4285
|
+
june: "June",
|
|
4286
|
+
july: "July",
|
|
4287
|
+
august: "August",
|
|
4288
|
+
september: "September",
|
|
4289
|
+
october: "October",
|
|
4290
|
+
november: "November",
|
|
4291
|
+
december: "December"
|
|
4292
|
+
};
|
|
4293
|
+
|
|
4294
|
+
// src/contexts/calendar-context/provider.tsx
|
|
4169
4295
|
import { jsx as jsx39 } from "react/jsx-runtime";
|
|
4170
4296
|
var CalendarProvider = ({
|
|
4171
4297
|
children,
|
|
4172
4298
|
events = [],
|
|
4173
4299
|
firstDayOfWeek = 0,
|
|
4300
|
+
initialView = "month",
|
|
4174
4301
|
renderEvent,
|
|
4175
4302
|
onEventClick,
|
|
4176
4303
|
onCellClick,
|
|
4177
4304
|
onViewChange,
|
|
4305
|
+
onEventAdd,
|
|
4306
|
+
onEventUpdate,
|
|
4307
|
+
onEventDelete,
|
|
4308
|
+
onDateChange,
|
|
4178
4309
|
locale,
|
|
4179
4310
|
timezone: timezone2,
|
|
4180
4311
|
disableCellClick,
|
|
@@ -4183,16 +4314,28 @@ var CalendarProvider = ({
|
|
|
4183
4314
|
dayMaxEvents,
|
|
4184
4315
|
stickyViewHeader = true,
|
|
4185
4316
|
viewHeaderClassName = "",
|
|
4186
|
-
headerComponent
|
|
4317
|
+
headerComponent,
|
|
4318
|
+
headerClassName,
|
|
4319
|
+
translations,
|
|
4320
|
+
translator
|
|
4187
4321
|
}) => {
|
|
4188
4322
|
const [currentDate, setCurrentDate] = useState8(dayjs_config_default());
|
|
4189
|
-
const [view, setView] = useState8(
|
|
4323
|
+
const [view, setView] = useState8(initialView);
|
|
4190
4324
|
const [currentEvents, setCurrentEvents] = useState8(events);
|
|
4191
4325
|
const [isEventFormOpen, setIsEventFormOpen] = useState8(false);
|
|
4192
4326
|
const [selectedEvent, setSelectedEvent] = useState8(null);
|
|
4193
4327
|
const [selectedDate, setSelectedDate] = useState8(null);
|
|
4194
4328
|
const [currentLocale, setCurrentLocale] = useState8(locale || "en");
|
|
4195
4329
|
const [currentTimezone, setCurrentTimezone] = useState8(timezone2 || "");
|
|
4330
|
+
const t = useMemo8(() => {
|
|
4331
|
+
if (translator) {
|
|
4332
|
+
return translator;
|
|
4333
|
+
}
|
|
4334
|
+
if (translations) {
|
|
4335
|
+
return (key) => translations[key] || key;
|
|
4336
|
+
}
|
|
4337
|
+
return (key) => defaultTranslations[key] || key;
|
|
4338
|
+
}, [translations, translator]);
|
|
4196
4339
|
const getEventsForDateRange = useCallback3((startDate, endDate) => {
|
|
4197
4340
|
const allEvents = [];
|
|
4198
4341
|
for (const event of currentEvents) {
|
|
@@ -4244,7 +4387,7 @@ var CalendarProvider = ({
|
|
|
4244
4387
|
};
|
|
4245
4388
|
}
|
|
4246
4389
|
}, [currentDate, view, firstDayOfWeek]);
|
|
4247
|
-
const processedEvents =
|
|
4390
|
+
const processedEvents = useMemo8(() => {
|
|
4248
4391
|
const { start, end } = getCurrentViewRange();
|
|
4249
4392
|
return getEventsForDateRange(start, end);
|
|
4250
4393
|
}, [getEventsForDateRange, getCurrentViewRange]);
|
|
@@ -4267,49 +4410,97 @@ var CalendarProvider = ({
|
|
|
4267
4410
|
}, [timezone2]);
|
|
4268
4411
|
const selectDate = useCallback3((date) => {
|
|
4269
4412
|
setCurrentDate(date);
|
|
4270
|
-
|
|
4413
|
+
onDateChange?.(date);
|
|
4414
|
+
}, [onDateChange]);
|
|
4271
4415
|
const nextPeriod = useCallback3(() => {
|
|
4272
4416
|
switch (view) {
|
|
4273
4417
|
case "month":
|
|
4274
|
-
setCurrentDate((currentDate2) =>
|
|
4418
|
+
setCurrentDate((currentDate2) => {
|
|
4419
|
+
const newDate = currentDate2.add(1, "month");
|
|
4420
|
+
onDateChange?.(newDate);
|
|
4421
|
+
return newDate;
|
|
4422
|
+
});
|
|
4275
4423
|
break;
|
|
4276
4424
|
case "week":
|
|
4277
|
-
setCurrentDate((currentDate2) =>
|
|
4425
|
+
setCurrentDate((currentDate2) => {
|
|
4426
|
+
const newDate = currentDate2.add(1, "week");
|
|
4427
|
+
onDateChange?.(newDate);
|
|
4428
|
+
return newDate;
|
|
4429
|
+
});
|
|
4278
4430
|
break;
|
|
4279
4431
|
case "day":
|
|
4280
|
-
setCurrentDate((currentDate2) =>
|
|
4432
|
+
setCurrentDate((currentDate2) => {
|
|
4433
|
+
const newDate = currentDate2.add(1, "day");
|
|
4434
|
+
onDateChange?.(newDate);
|
|
4435
|
+
return newDate;
|
|
4436
|
+
});
|
|
4281
4437
|
break;
|
|
4282
4438
|
case "year":
|
|
4283
|
-
setCurrentDate((currentDate2) =>
|
|
4439
|
+
setCurrentDate((currentDate2) => {
|
|
4440
|
+
const newDate = currentDate2.add(1, "year");
|
|
4441
|
+
onDateChange?.(newDate);
|
|
4442
|
+
return newDate;
|
|
4443
|
+
});
|
|
4284
4444
|
break;
|
|
4285
4445
|
}
|
|
4286
|
-
}, [view]);
|
|
4446
|
+
}, [view, onDateChange]);
|
|
4287
4447
|
const prevPeriod = useCallback3(() => {
|
|
4288
4448
|
switch (view) {
|
|
4289
4449
|
case "month":
|
|
4290
|
-
setCurrentDate((currentDate2) =>
|
|
4450
|
+
setCurrentDate((currentDate2) => {
|
|
4451
|
+
const newDate = currentDate2.subtract(1, "month");
|
|
4452
|
+
onDateChange?.(newDate);
|
|
4453
|
+
return newDate;
|
|
4454
|
+
});
|
|
4291
4455
|
break;
|
|
4292
4456
|
case "week":
|
|
4293
|
-
setCurrentDate((currentDate2) =>
|
|
4457
|
+
setCurrentDate((currentDate2) => {
|
|
4458
|
+
const newDate = currentDate2.subtract(1, "week");
|
|
4459
|
+
onDateChange?.(newDate);
|
|
4460
|
+
return newDate;
|
|
4461
|
+
});
|
|
4294
4462
|
break;
|
|
4295
4463
|
case "day":
|
|
4296
|
-
setCurrentDate((currentDate2) =>
|
|
4464
|
+
setCurrentDate((currentDate2) => {
|
|
4465
|
+
const newDate = currentDate2.subtract(1, "day");
|
|
4466
|
+
onDateChange?.(newDate);
|
|
4467
|
+
return newDate;
|
|
4468
|
+
});
|
|
4297
4469
|
break;
|
|
4298
4470
|
case "year":
|
|
4299
|
-
setCurrentDate((currentDate2) =>
|
|
4471
|
+
setCurrentDate((currentDate2) => {
|
|
4472
|
+
const newDate = currentDate2.subtract(1, "year");
|
|
4473
|
+
onDateChange?.(newDate);
|
|
4474
|
+
return newDate;
|
|
4475
|
+
});
|
|
4300
4476
|
break;
|
|
4301
4477
|
}
|
|
4302
|
-
}, [view]);
|
|
4478
|
+
}, [view, onDateChange]);
|
|
4303
4479
|
const today = useCallback3(() => {
|
|
4304
|
-
|
|
4305
|
-
|
|
4480
|
+
const newDate = dayjs_config_default();
|
|
4481
|
+
setCurrentDate(newDate);
|
|
4482
|
+
onDateChange?.(newDate);
|
|
4483
|
+
}, [onDateChange]);
|
|
4306
4484
|
const addEvent = useCallback3((event) => {
|
|
4307
4485
|
setCurrentEvents((prevEvents) => [...prevEvents, event]);
|
|
4308
|
-
|
|
4486
|
+
onEventAdd?.(event);
|
|
4487
|
+
}, [onEventAdd]);
|
|
4309
4488
|
const updateEvent = useCallback3((eventId, updatedEvent) => {
|
|
4310
|
-
setCurrentEvents((prevEvents) =>
|
|
4311
|
-
|
|
4489
|
+
setCurrentEvents((prevEvents) => {
|
|
4490
|
+
const updated = prevEvents.map((event) => {
|
|
4491
|
+
if (event.id === eventId) {
|
|
4492
|
+
const newEvent = { ...event, ...updatedEvent };
|
|
4493
|
+
onEventUpdate?.(newEvent);
|
|
4494
|
+
return newEvent;
|
|
4495
|
+
}
|
|
4496
|
+
return event;
|
|
4497
|
+
});
|
|
4498
|
+
return updated;
|
|
4499
|
+
});
|
|
4500
|
+
}, [onEventUpdate]);
|
|
4312
4501
|
const updateRecurringEvent2 = useCallback3((event, updates, options) => {
|
|
4502
|
+
const updatedEvent = { ...event, ...updates };
|
|
4503
|
+
onEventUpdate?.(updatedEvent);
|
|
4313
4504
|
const updatedEvents = updateRecurringEvent({
|
|
4314
4505
|
targetEvent: event,
|
|
4315
4506
|
updates,
|
|
@@ -4317,18 +4508,25 @@ var CalendarProvider = ({
|
|
|
4317
4508
|
scope: options.scope
|
|
4318
4509
|
});
|
|
4319
4510
|
setCurrentEvents(updatedEvents);
|
|
4320
|
-
}, [currentEvents]);
|
|
4511
|
+
}, [currentEvents, onEventUpdate]);
|
|
4321
4512
|
const deleteRecurringEvent2 = useCallback3((event, options) => {
|
|
4513
|
+
onEventDelete?.(event);
|
|
4322
4514
|
const updatedEvents = deleteRecurringEvent({
|
|
4323
4515
|
targetEvent: event,
|
|
4324
4516
|
currentEvents,
|
|
4325
4517
|
scope: options.scope
|
|
4326
4518
|
});
|
|
4327
4519
|
setCurrentEvents(updatedEvents);
|
|
4328
|
-
}, [currentEvents]);
|
|
4520
|
+
}, [currentEvents, onEventDelete]);
|
|
4329
4521
|
const deleteEvent = useCallback3((eventId) => {
|
|
4330
|
-
setCurrentEvents((prevEvents) =>
|
|
4331
|
-
|
|
4522
|
+
setCurrentEvents((prevEvents) => {
|
|
4523
|
+
const eventToDelete = prevEvents.find((event) => event.id === eventId);
|
|
4524
|
+
if (eventToDelete) {
|
|
4525
|
+
onEventDelete?.(eventToDelete);
|
|
4526
|
+
}
|
|
4527
|
+
return prevEvents.filter((event) => event.id !== eventId);
|
|
4528
|
+
});
|
|
4529
|
+
}, [onEventDelete]);
|
|
4332
4530
|
const editEvent = useCallback3((event) => {
|
|
4333
4531
|
setSelectedEvent(event);
|
|
4334
4532
|
setIsEventFormOpen(true);
|
|
@@ -4361,7 +4559,7 @@ var CalendarProvider = ({
|
|
|
4361
4559
|
} else {
|
|
4362
4560
|
setSelectedDate(startDate);
|
|
4363
4561
|
setSelectedEvent({
|
|
4364
|
-
title:
|
|
4562
|
+
title: t("newEvent"),
|
|
4365
4563
|
start: startDate,
|
|
4366
4564
|
end: endDate,
|
|
4367
4565
|
description: "",
|
|
@@ -4369,20 +4567,20 @@ var CalendarProvider = ({
|
|
|
4369
4567
|
});
|
|
4370
4568
|
setIsEventFormOpen(true);
|
|
4371
4569
|
}
|
|
4372
|
-
}, [onCellClick, disableCellClick]);
|
|
4570
|
+
}, [onCellClick, disableCellClick, t]);
|
|
4373
4571
|
const handleOpenEventForm = useCallback3((date) => {
|
|
4374
4572
|
if (date) {
|
|
4375
4573
|
setSelectedDate(date);
|
|
4376
4574
|
}
|
|
4377
4575
|
setSelectedEvent({
|
|
4378
|
-
title:
|
|
4576
|
+
title: t("newEvent"),
|
|
4379
4577
|
start: date ?? currentDate,
|
|
4380
4578
|
end: date ?? currentDate.add(1, "hour"),
|
|
4381
4579
|
description: "",
|
|
4382
4580
|
allDay: false
|
|
4383
4581
|
});
|
|
4384
4582
|
setIsEventFormOpen(true);
|
|
4385
|
-
}, [currentDate]);
|
|
4583
|
+
}, [currentDate, t]);
|
|
4386
4584
|
const findParentRecurringEvent = useCallback3((event) => {
|
|
4387
4585
|
const targetUID = event.uid;
|
|
4388
4586
|
const parentEvent = currentEvents.find((e) => {
|
|
@@ -4391,7 +4589,7 @@ var CalendarProvider = ({
|
|
|
4391
4589
|
});
|
|
4392
4590
|
return parentEvent || null;
|
|
4393
4591
|
}, [currentEvents]);
|
|
4394
|
-
const contextValue =
|
|
4592
|
+
const contextValue = useMemo8(() => ({
|
|
4395
4593
|
currentDate,
|
|
4396
4594
|
view,
|
|
4397
4595
|
events: processedEvents,
|
|
@@ -4427,7 +4625,9 @@ var CalendarProvider = ({
|
|
|
4427
4625
|
dayMaxEvents,
|
|
4428
4626
|
stickyViewHeader,
|
|
4429
4627
|
viewHeaderClassName,
|
|
4430
|
-
headerComponent
|
|
4628
|
+
headerComponent,
|
|
4629
|
+
headerClassName,
|
|
4630
|
+
t
|
|
4431
4631
|
}), [
|
|
4432
4632
|
currentDate,
|
|
4433
4633
|
view,
|
|
@@ -4463,7 +4663,9 @@ var CalendarProvider = ({
|
|
|
4463
4663
|
dayMaxEvents,
|
|
4464
4664
|
stickyViewHeader,
|
|
4465
4665
|
viewHeaderClassName,
|
|
4466
|
-
headerComponent
|
|
4666
|
+
headerComponent,
|
|
4667
|
+
headerClassName,
|
|
4668
|
+
t
|
|
4467
4669
|
]);
|
|
4468
4670
|
return /* @__PURE__ */ jsx39(CalendarContext.Provider, {
|
|
4469
4671
|
value: contextValue,
|
|
@@ -4472,7 +4674,7 @@ var CalendarProvider = ({
|
|
|
4472
4674
|
};
|
|
4473
4675
|
|
|
4474
4676
|
// src/components/ilamy-calendar/ilamy-calendar.tsx
|
|
4475
|
-
import { jsx as jsx40, jsxs as
|
|
4677
|
+
import { jsx as jsx40, jsxs as jsxs27 } from "react/jsx-runtime";
|
|
4476
4678
|
var CalendarContent = () => {
|
|
4477
4679
|
const {
|
|
4478
4680
|
view,
|
|
@@ -4499,7 +4701,7 @@ var CalendarContent = () => {
|
|
|
4499
4701
|
const handleOnDelete = (event) => {
|
|
4500
4702
|
deleteEvent(event.id);
|
|
4501
4703
|
};
|
|
4502
|
-
return /* @__PURE__ */
|
|
4704
|
+
return /* @__PURE__ */ jsxs27("div", {
|
|
4503
4705
|
className: "flex flex-col w-full h-full",
|
|
4504
4706
|
children: [
|
|
4505
4707
|
/* @__PURE__ */ jsx40(base_header_default, {
|
|
@@ -4533,11 +4735,18 @@ var DEFAULT_DAY_MAX_EVENTS = 4;
|
|
|
4533
4735
|
var IlamyCalendar = ({
|
|
4534
4736
|
events,
|
|
4535
4737
|
firstDayOfWeek = "sunday",
|
|
4738
|
+
initialView = "month",
|
|
4536
4739
|
renderEvent,
|
|
4537
4740
|
onEventClick,
|
|
4538
4741
|
onCellClick,
|
|
4539
4742
|
onViewChange,
|
|
4743
|
+
onEventAdd,
|
|
4744
|
+
onEventUpdate,
|
|
4745
|
+
onEventDelete,
|
|
4746
|
+
onDateChange,
|
|
4540
4747
|
locale,
|
|
4748
|
+
translations,
|
|
4749
|
+
translator,
|
|
4541
4750
|
timezone: timezone2,
|
|
4542
4751
|
disableCellClick,
|
|
4543
4752
|
disableEventClick,
|
|
@@ -4545,16 +4754,24 @@ var IlamyCalendar = ({
|
|
|
4545
4754
|
dayMaxEvents = DEFAULT_DAY_MAX_EVENTS,
|
|
4546
4755
|
stickyViewHeader = true,
|
|
4547
4756
|
viewHeaderClassName = "",
|
|
4548
|
-
headerComponent
|
|
4757
|
+
headerComponent,
|
|
4758
|
+
headerClassName
|
|
4549
4759
|
}) => {
|
|
4550
4760
|
return /* @__PURE__ */ jsx40(CalendarProvider, {
|
|
4551
4761
|
events: normalizePublicFacingCalendarEvent(events),
|
|
4552
4762
|
firstDayOfWeek: WEEK_DAYS_NUMBER_MAP[firstDayOfWeek],
|
|
4763
|
+
initialView,
|
|
4553
4764
|
renderEvent,
|
|
4554
4765
|
onEventClick,
|
|
4555
4766
|
onCellClick,
|
|
4556
4767
|
onViewChange,
|
|
4768
|
+
onEventAdd,
|
|
4769
|
+
onEventUpdate,
|
|
4770
|
+
onEventDelete,
|
|
4771
|
+
onDateChange,
|
|
4557
4772
|
locale,
|
|
4773
|
+
translations,
|
|
4774
|
+
translator,
|
|
4558
4775
|
timezone: timezone2,
|
|
4559
4776
|
disableCellClick,
|
|
4560
4777
|
disableEventClick,
|
|
@@ -4563,6 +4780,7 @@ var IlamyCalendar = ({
|
|
|
4563
4780
|
stickyViewHeader,
|
|
4564
4781
|
viewHeaderClassName,
|
|
4565
4782
|
headerComponent,
|
|
4783
|
+
headerClassName,
|
|
4566
4784
|
children: /* @__PURE__ */ jsx40(CalendarContent, {})
|
|
4567
4785
|
});
|
|
4568
4786
|
};
|
|
@@ -4573,9 +4791,10 @@ export {
|
|
|
4573
4791
|
useIlamyCalendarContext,
|
|
4574
4792
|
isRecurringEvent,
|
|
4575
4793
|
generateRecurringEvents,
|
|
4794
|
+
defaultTranslations,
|
|
4576
4795
|
RRule4 as RRule,
|
|
4577
4796
|
IlamyCalendar
|
|
4578
4797
|
};
|
|
4579
4798
|
|
|
4580
|
-
//# debugId=
|
|
4581
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/features/month-view/components/view/month-view.tsx", "../src/contexts/calendar-context/context.ts", "../src/components/ui/button.tsx", "../src/lib/utils.ts", "../src/lib/dayjs-config.ts", "../src/components/ui/calendar.tsx", "../src/components/ui/checkbox.tsx", "../src/components/ui/card.tsx", "../src/components/ui/date-picker.tsx", "../src/components/ui/popover.tsx", "../src/components/ui/dialog.tsx", "../src/components/ui/input.tsx", "../src/components/ui/label.tsx", "../src/components/ui/scroll-area.tsx", "../src/components/ui/select.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/month-header.tsx", "../src/lib/constants.ts", "../src/hooks/useProcessedWeekEvents.ts", "../src/features/month-view/components/week-events-layer/week-events-layer.tsx", "../src/features/week-view/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/components/day-events-layer.tsx", "../src/features/week-view/week-day-col.tsx", "../src/features/week-view/week-time-grid.tsx", "../src/features/day-view/components/view/day-view.tsx", "../src/features/day-view/components/day-all-day-row.tsx", "../src/features/day-view/components/day-header.tsx", "../src/features/day-view/components/day-time-col.tsx", "../src/components/event-form/event-form.tsx", "../src/lib/recurrence-handler/index.ts", "../src/features/recurrence/components/recurrence-editor/recurrence-editor.tsx", "../src/features/recurrence/components/recurrence-edit-dialog/recurrence-edit-dialog.tsx", "../src/features/recurrence/hooks/useRecurringEventActions.ts", "../src/lib/export-ical.ts", "../src/components/header/base-header.tsx", "../src/components/header/title-content.tsx", "../src/components/header/view-controls.tsx", "../src/features/year-view/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", "../src/index.ts"],
  "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/month-header'\nimport { WeekEventsLayer } from '../week-events-layer/week-events-layer'\nimport { ScrollArea } from '@/components/ui'\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 className=\"h-[3rem]\" />\n\n      {/* Calendar grid - added fixed height */}\n      <ScrollArea\n        className=\"overflow-auto h-[calc(100%-3rem)]\"\n        data-testid=\"month-scroll-area\"\n        viewPortProps={{ className: '*:flex! *:flex-col *:min-h-full' }}\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 flex-1\"\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      </ScrollArea>\n\n      {/* Dialog for showing all events */}\n      <AllEventDialog ref={allEventsDialogRef} />\n    </div>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport type { RecurrenceEditOptions } from '@/features/recurrence/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  rawEvents: CalendarEvent[] // Unprocessed events for export\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 | number, event: Partial<CalendarEvent>) => void\n  updateRecurringEvent: (\n    event: CalendarEvent,\n    updates: Partial<CalendarEvent>,\n    options: RecurrenceEditOptions\n  ) => void\n  deleteEvent: (eventId: string | number) => void\n  deleteRecurringEvent: (\n    event: CalendarEvent,\n    options: RecurrenceEditOptions\n  ) => void\n  openEventForm: (date?: dayjs.Dayjs) => void\n  closeEventForm: () => void\n  getEventsForDateRange: (\n    startDate: dayjs.Dayjs,\n    endDate: dayjs.Dayjs\n  ) => CalendarEvent[]\n  findParentRecurringEvent: (event: CalendarEvent) => CalendarEvent | null\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  headerComponent?: React.ReactNode // Optional custom header component\n}\n\nexport const CalendarContext: React.Context<CalendarContextType | undefined> =\n  createContext<CalendarContextType | undefined>(undefined)\n\nexport const useCalendarContext = (): CalendarContextType => {\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\n/**\n * Simplified calendar context type for external use\n * Contains only the most commonly used calendar operations\n */\nexport interface UseIlamyCalendarContextReturn {\n  readonly currentDate: dayjs.Dayjs\n  readonly view: 'month' | 'week' | 'day' | 'year'\n  readonly events: CalendarEvent[]\n  readonly isEventFormOpen: boolean\n  readonly selectedEvent: CalendarEvent | null\n  readonly selectedDate: dayjs.Dayjs | null\n  readonly firstDayOfWeek: number\n  readonly setCurrentDate: (date: dayjs.Dayjs) => void\n  readonly selectDate: (date: dayjs.Dayjs) => void\n  readonly setView: (view: 'month' | 'week' | 'day' | 'year') => void\n  readonly nextPeriod: () => void\n  readonly prevPeriod: () => void\n  readonly today: () => void\n  readonly addEvent: (event: CalendarEvent) => void\n  readonly updateEvent: (\n    eventId: string | number,\n    event: Partial<CalendarEvent>\n  ) => void\n  readonly deleteEvent: (eventId: string | number) => void\n  readonly openEventForm: (date?: dayjs.Dayjs) => void\n  readonly closeEventForm: () => void\n}\n\nexport const useIlamyCalendarContext = (): UseIlamyCalendarContextReturn => {\n  const context = useContext(CalendarContext)\n  if (context === undefined) {\n    throw new Error(\n      'useIlamyCalendarContext must be used within a CalendarProvider'\n    )\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  } as const\n}\n",
    "import * as React from 'react'\nimport { Slot } from '@radix-ui/react-slot'\nimport type { VariantProps } from 'class-variance-authority'\nimport { cva } 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 type { CalendarEvent } from '@/components'\nimport type { ClassValue } from 'clsx'\nimport { clsx } from 'clsx'\nimport dayjs from '@/lib/dayjs-config'\nimport { twMerge } from 'tailwind-merge'\nimport type { IlamyCalendarPropEvent } from '@/components/ilamy-calendar/types'\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().startOf('week').add(i, 'day').startOf('day'),\n      end: dayjs().startOf('week').add(i, 'day').endOf('day'),\n      color: 'bg-gray-100 text-gray-800',\n    })\n  }\n  return events\n}\n\nexport function safeDate(date: dayjs.Dayjs | Date | string): dayjs.Dayjs {\n  if (dayjs.isDayjs(date)) {\n    return date\n  }\n\n  const parsedDate = dayjs(date)\n  return parsedDate.isValid() ? parsedDate : dayjs()\n}\n\nexport const omitKeys = <T extends object, K extends keyof T>(\n  obj: T,\n  keys: K[]\n): Omit<T, K> => {\n  const result = { ...obj }\n  for (const key of keys) {\n    delete result[key]\n  }\n  return result\n}\n\nexport function normalizePublicFacingCalendarEvent(\n  events: IlamyCalendarPropEvent[]\n): CalendarEvent[] {\n  if (!events || !events.length) {\n    return []\n  }\n\n  return events.map((event) => {\n    // Events are already in the correct format with RRULE strings\n    return {\n      ...event,\n      start: dayjs.isDayjs(event.start) ? event.start : dayjs(event.start),\n      end: dayjs.isDayjs(event.end) ? event.end : dayjs(event.end),\n    } as CalendarEvent\n  })\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// 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\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\nexport default dayjs\n",
    "import * as React from 'react'\nimport {\n  ChevronDownIcon,\n  ChevronLeftIcon,\n  ChevronRightIcon,\n} from 'lucide-react'\nimport type { DayButton } from 'react-day-picker'\nimport { DayPicker, getDefaultClassNames } from 'react-day-picker'\n\nimport { cn } from '@/lib/utils'\nimport { Button, buttonVariants } from '@/components/ui/button'\n\nfunction Calendar({\n  className,\n  classNames,\n  showOutsideDays = true,\n  captionLayout = 'label',\n  buttonVariant = 'ghost',\n  formatters,\n  components,\n  ...props\n}: React.ComponentProps<typeof DayPicker> & {\n  buttonVariant?: React.ComponentProps<typeof Button>['variant']\n}) {\n  const defaultClassNames = getDefaultClassNames()\n\n  return (\n    <DayPicker\n      showOutsideDays={showOutsideDays}\n      className={cn(\n        'bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',\n        String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n        String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n        className\n      )}\n      captionLayout={captionLayout}\n      formatters={{\n        formatMonthDropdown: (date) =>\n          date.toLocaleString('default', { month: 'short' }),\n        ...formatters,\n      }}\n      classNames={{\n        root: cn('w-fit', defaultClassNames.root),\n        months: cn(\n          'flex gap-4 flex-col md:flex-row relative',\n          defaultClassNames.months\n        ),\n        month: cn('flex flex-col w-full gap-4', defaultClassNames.month),\n        nav: cn(\n          'flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between',\n          defaultClassNames.nav\n        ),\n        button_previous: cn(\n          buttonVariants({ variant: buttonVariant }),\n          'size-(--cell-size) aria-disabled:opacity-50 p-0 select-none',\n          defaultClassNames.button_previous\n        ),\n        button_next: cn(\n          buttonVariants({ variant: buttonVariant }),\n          'size-(--cell-size) aria-disabled:opacity-50 p-0 select-none',\n          defaultClassNames.button_next\n        ),\n        month_caption: cn(\n          'flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)',\n          defaultClassNames.month_caption\n        ),\n        dropdowns: cn(\n          'w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5',\n          defaultClassNames.dropdowns\n        ),\n        dropdown_root: cn(\n          'relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md',\n          defaultClassNames.dropdown_root\n        ),\n        dropdown: cn(\n          'absolute bg-popover inset-0 opacity-0',\n          defaultClassNames.dropdown\n        ),\n        caption_label: cn(\n          'select-none font-medium',\n          captionLayout === 'label'\n            ? 'text-sm'\n            : 'rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5',\n          defaultClassNames.caption_label\n        ),\n        table: 'w-full border-collapse',\n        weekdays: cn('flex', defaultClassNames.weekdays),\n        weekday: cn(\n          'text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none',\n          defaultClassNames.weekday\n        ),\n        week: cn('flex w-full mt-2', defaultClassNames.week),\n        week_number_header: cn(\n          'select-none w-(--cell-size)',\n          defaultClassNames.week_number_header\n        ),\n        week_number: cn(\n          'text-[0.8rem] select-none text-muted-foreground',\n          defaultClassNames.week_number\n        ),\n        day: cn(\n          'relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none',\n          defaultClassNames.day\n        ),\n        range_start: cn(\n          'rounded-l-md bg-accent',\n          defaultClassNames.range_start\n        ),\n        range_middle: cn('rounded-none', defaultClassNames.range_middle),\n        range_end: cn('rounded-r-md bg-accent', defaultClassNames.range_end),\n        today: cn(\n          'bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none',\n          defaultClassNames.today\n        ),\n        outside: cn(\n          'text-muted-foreground aria-selected:text-muted-foreground',\n          defaultClassNames.outside\n        ),\n        disabled: cn(\n          'text-muted-foreground opacity-50',\n          defaultClassNames.disabled\n        ),\n        hidden: cn('invisible', defaultClassNames.hidden),\n        ...classNames,\n      }}\n      components={{\n        Root: ({ className, rootRef, ...props }) => {\n          return (\n            <div\n              data-slot=\"calendar\"\n              ref={rootRef}\n              className={cn(className)}\n              {...props}\n            />\n          )\n        },\n        Chevron: ({ className, orientation, ...props }) => {\n          if (orientation === 'left') {\n            return (\n              <ChevronLeftIcon className={cn('size-4', className)} {...props} />\n            )\n          }\n\n          if (orientation === 'right') {\n            return (\n              <ChevronRightIcon\n                className={cn('size-4', className)}\n                {...props}\n              />\n            )\n          }\n\n          return (\n            <ChevronDownIcon className={cn('size-4', className)} {...props} />\n          )\n        },\n        DayButton: CalendarDayButton,\n        WeekNumber: ({ children, ...props }) => {\n          return (\n            <td {...props}>\n              <div className=\"flex size-(--cell-size) items-center justify-center text-center\">\n                {children}\n              </div>\n            </td>\n          )\n        },\n        ...components,\n      }}\n      {...props}\n    />\n  )\n}\n\nfunction CalendarDayButton({\n  className,\n  day,\n  modifiers,\n  ...props\n}: React.ComponentProps<typeof DayButton>) {\n  const defaultClassNames = getDefaultClassNames()\n\n  const ref = React.useRef<HTMLButtonElement>(null)\n  React.useEffect(() => {\n    if (modifiers.focused) {\n      ref.current?.focus()\n    }\n  }, [modifiers.focused])\n\n  return (\n    <Button\n      ref={ref}\n      variant=\"ghost\"\n      size=\"icon\"\n      data-day={day.date.toLocaleDateString()}\n      data-selected-single={\n        modifiers.selected &&\n        !modifiers.range_start &&\n        !modifiers.range_end &&\n        !modifiers.range_middle\n      }\n      data-range-start={modifiers.range_start}\n      data-range-end={modifiers.range_end}\n      data-range-middle={modifiers.range_middle}\n      className={cn(\n        'data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70',\n        defaultClassNames.day,\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Calendar, CalendarDayButton }\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 * as React from 'react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Card({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card\"\n      className={cn(\n        'text-card-foreground flex flex-col gap-6 rounded-xl border shadow-sm',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-header\"\n      className={cn(\n        '@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 p-4 pb-0 has-data-[slot=card-action]:grid-cols-[1fr_auto]',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-title\"\n      className={cn('leading-none font-semibold', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-description\"\n      className={cn('text-muted-foreground text-sm', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-action\"\n      className={cn(\n        'col-start-2 row-span-2 row-start-1 self-start justify-self-end',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-content\"\n      className={cn('p-4 pt-0', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-footer\"\n      className={cn('flex items-center px-6 [.border-t]:pt-6', className)}\n      {...props}\n    />\n  )\n}\n\nexport {\n  Card,\n  CardHeader,\n  CardFooter,\n  CardTitle,\n  CardAction,\n  CardDescription,\n  CardContent,\n}\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            month={date}\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 max-h-[90%] overflow-y-scroll',\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'\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",
    "'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'\nimport * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area'\n\nimport { cn } from '@/lib/utils'\n\ninterface ScrollAreaProps\n  extends React.ComponentProps<typeof ScrollAreaPrimitive.Root> {\n  viewPortProps?: React.ComponentProps<typeof ScrollAreaPrimitive.Viewport>\n}\n\nfunction ScrollArea({ className, children, ...props }: ScrollAreaProps) {\n  return (\n    <ScrollAreaPrimitive.Root\n      data-slot=\"scroll-area\"\n      className={cn('relative', className)}\n      {...props}\n    >\n      <ScrollAreaPrimitive.Viewport\n        {...props.viewPortProps}\n        data-slot=\"scroll-area-viewport\"\n        className={cn(\n          'focus-visible:ring-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:outline-1',\n          props.viewPortProps?.className\n        )}\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 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={`all-events-dialog-event-$${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 === nextProps.event\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    currentLocale,\n    getEventsForDateRange,\n    currentDate,\n    firstDayOfWeek,\n    dayMaxEvents = 0,\n  } = useCalendarContext()\n  const todayEvents = getEventsForDateRange(\n    day.startOf('day'),\n    day.endOf('day')\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 min-h-[60px]',\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',\n              isToday && 'bg-primary text-primary-foreground font-medium'\n            )}\n          >\n            {Intl.DateTimeFormat(currentLocale, { day: 'numeric' }).format(\n              day.toDate()\n            )}\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              onKeyDown={(e) => {\n                if (e.key === 'Enter' || e.key === ' ') {\n                  e.preventDefault()\n                  e.stopPropagation()\n                  showAllEvents(day, todayEvents)\n                }\n              }}\n              tabIndex={0}\n              // oxlint-disable-next-line prefer-tag-over-role\n              role=\"button\"\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) {\n      return\n    }\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\ninterface MonthHeaderProps {\n  className?: string\n}\n\nexport const MonthHeader: React.FC<MonthHeaderProps> = ({ className }) => {\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) {\n        days.push(dayToMove)\n      }\n      if (shortDayToMove) {\n        shortDays.push(shortDayToMove)\n      }\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        className\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",
    "import type { WeekDays } from '@/components'\n\nexport 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\nexport const WEEK_DAYS_NUMBER_MAP: Record<WeekDays, number> = {\n  sunday: 0,\n  monday: 1,\n  tuesday: 2,\n  wednesday: 3,\n  thursday: 4,\n  friday: 5,\n  saturday: 6,\n}\n\nexport const DAY_NUMBER_TO_WEEK_DAYS: Record<number, WeekDays> = {\n  0: 'sunday',\n  1: 'monday',\n  2: 'tuesday',\n  3: 'wednesday',\n  4: 'thursday',\n  5: 'friday',\n  6: 'saturday',\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport {\n  DAY_NUMBER_HEIGHT,\n  EVENT_BAR_HEIGHT,\n  GAP_BETWEEN_ELEMENTS,\n} from '@/lib/constants'\nimport dayjs from '@/lib/dayjs-config'\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 UseProcessedWeekEventsProps {\n  days: dayjs.Dayjs[]\n}\n\nexport const useProcessedWeekEvents = ({\n  days,\n}: UseProcessedWeekEventsProps) => {\n  const { getEventsForDateRange, dayMaxEvents } = useCalendarContext()\n\n  const weekStart = days[0].startOf('day')\n  const weekEnd = days[6].endOf('day')\n\n  // Get all events that intersect with this week\n  const weekEvents = getEventsForDateRange(weekStart, weekEnd)\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) {\n      return startDiff\n    }\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: { 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 processedEvents: 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      processedEvents.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          processedEvents.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      processedEvents.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 processedEvents\n}\n",
    "import { DraggableEvent } from '@/features/draggable-event/draggable-event'\nimport { useProcessedWeekEvents } from '@/hooks/useProcessedWeekEvents'\nimport { EVENT_BAR_HEIGHT } from '@/lib/constants'\nimport type dayjs from '@/lib/dayjs-config'\n\ninterface WeekEventsLayerProps {\n  days: dayjs.Dayjs[]\n}\n\nexport const WeekEventsLayer: React.FC<WeekEventsLayerProps> = ({ days }) => {\n  const weekStart = days[0]\n  const processedWeekEvents = useProcessedWeekEvents({ days })\n\n  return (\n    <div className=\"relative w-full h-full pointer-events-none z-20 overflow-clip\">\n      {processedWeekEvents.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            data-testid={`week-event-layer-event-${event.id}`}\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 flex-col h-full\" data-testid=\"week-view\">\n      {/* Week header row - fixed */}\n      <WeekHeader className=\"h-[5rem]\" />\n\n      {/* Scrollable time grid */}\n      <ScrollArea\n        className=\"flex overflow-auto h-[calc(100%-5rem)]\"\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 weekEvents = getEventsForDateRange(expandedStartDate, expandedEndDate)\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) {\n        return startDiff\n      }\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\ninterface WeekHeaderProps {\n  className?: string\n}\n\nexport const WeekHeader: React.FC<WeekHeaderProps> = ({ className }) => {\n  const {\n    currentDate,\n    currentLocale,\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        className\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                {Intl.DateTimeFormat(currentLocale, { day: 'numeric' }).format(\n                  day.toDate()\n                )}\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/components/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, currentLocale } = 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              {Intl.DateTimeFormat(currentLocale, {\n                hour: 'numeric',\n                minute: 'numeric',\n                hour12: true,\n              }).format(time.toDate())}\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-40\"\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 '@/features/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\n// For more granular time slots, we'll divide each hour into 15-minute segments\nconst timeSegments = [0, 15, 30, 45]\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\nconst DayView = () => {\n  const { currentDate } = useCalendarContext()\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 className=\"h-[3rem]\" />\n\n      {/* Time grid without scrollbar */}\n      <ScrollArea\n        data-testid=\"day-scroll-area\"\n        className=\"relative overflow-y-auto h-[calc(100%-3rem)]\"\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, getEventsForDateRange } = useCalendarContext()\n\n  // Get current day's events - this will refresh automatically when store updates\n  // because getEventsForDateRange is a selector function from the store that runs whenever events change\n  const dayEvents = getEventsForDateRange(\n    currentDate.startOf('day'),\n    currentDate.endOf('day')\n  )\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\ninterface DayHeaderProps {\n  className?: string\n}\n\nexport const DayHeader: React.FC<DayHeaderProps> = ({ className }) => {\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        className\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 { useCalendarContext } from '@/contexts/calendar-context/context'\nimport 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  const { currentLocale } = useCalendarContext()\n\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            {Intl.DateTimeFormat(currentLocale, {\n              hour: 'numeric',\n              minute: 'numeric',\n              hour12: true,\n            }).format(time.toDate())}\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'\nimport type { RRuleOptions } from '@/lib/recurrence-handler/types'\nimport { isRecurringEvent } from '@/lib/recurrence-handler'\nimport { RecurrenceEditor } from '@/features/recurrence/components/recurrence-editor/recurrence-editor'\nimport { RecurrenceEditDialog } from '@/features/recurrence/components/recurrence-edit-dialog'\nimport { useRecurringEventActions } from '@/features/recurrence/hooks/useRecurringEventActions'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\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 {\n    dialogState,\n    openEditDialog,\n    openDeleteDialog,\n    closeDialog,\n    handleConfirm,\n  } = useRecurringEventActions(onClose)\n\n  const { findParentRecurringEvent } = useCalendarContext()\n\n  const start = selectedEvent?.start\n  const end = selectedEvent?.end\n\n  // Find parent event if this is a recurring event instance\n  const parentEvent = selectedEvent\n    ? findParentRecurringEvent(selectedEvent)\n    : null\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    start ? start.format('HH:mm') : dayjs(defaultStartDate).format('HH:mm')\n  )\n  const [endTime, setEndTime] = useState(\n    end ? end.format('HH:mm') : 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  // Recurrence state - pull RRULE from parent if this is an instance\n  const [rrule, setRrule] = useState<RRuleOptions | null>(() => {\n    const eventRrule = selectedEvent?.rrule || parentEvent?.rrule\n    return eventRrule || null\n  })\n\n  // Create wrapper functions to fix TypeScript errors with DatePicker\n  const handleStartDateChange = (date: Date | undefined) => {\n    if (date) {\n      setStartDate(date)\n    }\n  }\n\n  const handleEndDateChange = (date: Date | undefined) => {\n    if (date) {\n      setEndDate(date)\n    }\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      rrule: rrule || undefined,\n    }\n\n    if (selectedEvent?.id) {\n      // Check if this is a recurring event\n      if (isRecurringEvent(selectedEvent)) {\n        // Show recurring event edit dialog\n        openEditDialog(selectedEvent, {\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          rrule: rrule || undefined,\n        })\n        return // Don't close the form yet, let the dialog handle it\n      }\n      onUpdate?.(eventData)\n    } else {\n      onAdd?.(eventData)\n    }\n\n    onClose()\n  }\n\n  const handleDelete = () => {\n    if (selectedEvent?.id) {\n      // Check if this is a recurring event\n      if (isRecurringEvent(selectedEvent)) {\n        // Show recurring event delete dialog\n        openDeleteDialog(selectedEvent)\n        return // Don't close the form yet, let the dialog handle it\n      }\n      onDelete?.(selectedEvent)\n      onClose()\n    }\n  }\n\n  const handleRRuleChange = (newRRule: RRuleOptions | null) => {\n    if (newRRule) {\n      // Create dtstart with the same logic as in handleSubmit\n      const [startHours, startMinutes] = startTime.split(':').map(Number)\n      let startDateTime = dayjs(startDate).hour(startHours).minute(startMinutes)\n\n      if (isAllDay) {\n        startDateTime = startDateTime.hour(0).minute(0)\n      }\n\n      // Ensure dtstart is always included in RRuleOptions as a Date object\n      const completeRrule: RRuleOptions = {\n        ...newRRule,\n        dtstart: startDateTime.toDate(), // Convert dayjs to Date\n      }\n      setRrule(completeRrule)\n    } else {\n      setRrule(null)\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    <>\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                  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\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              {/* Recurrence Section */}\n              <RecurrenceEditor value={rrule} onChange={handleRRuleChange} />\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      {/* Recurring Event Edit Dialog */}\n      <RecurrenceEditDialog\n        isOpen={dialogState.isOpen}\n        onClose={closeDialog}\n        onConfirm={handleConfirm}\n        operationType={dialogState.operationType}\n        eventTitle={dialogState.event?.title || ''}\n      />\n    </>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components'\nimport dayjs from '@/lib/dayjs-config'\nimport { RRule } from 'rrule'\nimport { omitKeys, safeDate } from '../utils'\nimport type { RRuleOptions } from './types'\n\nexport const isRecurringEvent = (event: CalendarEvent): boolean => {\n  return Boolean(event.rrule || event.recurrenceId || event.uid)\n}\n\ninterface GenerateRecurringEventsProps {\n  event: CalendarEvent\n  currentEvents: CalendarEvent[]\n  startDate: dayjs.Dayjs\n  endDate: dayjs.Dayjs\n}\n\nexport const generateRecurringEvents = ({\n  event,\n  currentEvents,\n  startDate,\n  endDate,\n}: GenerateRecurringEventsProps): CalendarEvent[] => {\n  // If not a recurring event, return empty array\n  if (!event.rrule) {\n    return []\n  }\n\n  try {\n    // Create rule from RRuleOptions ensuring dtstart is always provided\n    // If dtstart is missing from the RRULE, use the event's start time as fallback\n    const ruleOptions: RRuleOptions = {\n      ...event.rrule,\n      dtstart: event.rrule.dtstart || event.start.toDate(),\n    }\n    const rule = new RRule(ruleOptions)\n\n    const overrides = currentEvents.filter(\n      (e) => e.recurrenceId && e.uid === event.uid\n    )\n\n    // Generate occurrences within the date range\n    const startDateTime = startDate.toDate()\n    const endDateTime = endDate.toDate()\n    const occurrences = rule.between(startDateTime, endDateTime, true)\n\n    // Convert occurrences to CalendarEvent instances\n    const recurringEvents: CalendarEvent[] = occurrences\n      .map((occurrence, index) => {\n        const occurrenceDate = dayjs(occurrence)\n        const existingOverride = overrides.find((e) =>\n          safeDate(e.recurrenceId).isSame(occurrenceDate)\n        )\n\n        // If there's an override, use it\n        if (existingOverride) {\n          return { ...event, ...existingOverride }\n        }\n\n        // Calculate the duration from the original event\n        const originalDuration = event.end.diff(event.start)\n        const newEndTime = occurrenceDate.add(originalDuration, 'millisecond')\n        const recurringEventId = `${event.id}_${index}`\n        const parentUID = event.uid || `${event.id}@ilamy.calendar`\n\n        // Create the recurring event instance\n        const recurringEvent: CalendarEvent = {\n          ...event,\n          id: recurringEventId,\n          start: occurrenceDate,\n          end: newEndTime,\n          uid: parentUID, // Same UID as parent for proper grouping\n          rrule: undefined, // Instance events don't have RRULE\n        }\n\n        return recurringEvent\n      })\n      .filter((recurringEvent) => {\n        // Filter out EXDATE exclusions\n        const hasExdates = event.exdates && event.exdates.length > 0\n        if (!hasExdates) {\n          return true\n        }\n\n        const eventStartISO = recurringEvent.start.toISOString()\n        const isExcluded = event.exdates.includes(eventStartISO)\n        return !isExcluded\n      })\n\n    return recurringEvents\n  } catch (error) {\n    // Handle invalid RRULE options\n    throw new Error(\n      `Invalid RRULE options: ${JSON.stringify(event.rrule)}. Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n    )\n  }\n}\n\ninterface UpdateRecurringEventProps {\n  targetEvent: CalendarEvent\n  updates: Partial<CalendarEvent>\n  currentEvents: CalendarEvent[]\n  scope: 'this' | 'following' | 'all'\n}\n\nexport const updateRecurringEvent = ({\n  targetEvent,\n  updates,\n  currentEvents,\n  scope,\n}: UpdateRecurringEventProps): CalendarEvent[] => {\n  const updatedEvents = [...currentEvents]\n\n  // Find the base recurring event\n  const baseEventIndex = updatedEvents.findIndex((e) => {\n    const parentUid = e.uid || `${e.id}@ilamy.calendar`\n    return parentUid === targetEvent.uid && e.rrule && !e.recurrenceId\n  })\n\n  if (baseEventIndex === -1) {\n    throw new Error('Base recurring event not found')\n  }\n\n  const baseEvent = updatedEvents[baseEventIndex]\n\n  switch (scope) {\n    case 'this': {\n      // \"This event only\" - Add EXDATE to base event and create standalone modified event\n      const targetEventStartISO = targetEvent.start.toISOString()\n      const existingExdates = baseEvent.exdates || []\n      const updatedExdates = [...existingExdates, targetEventStartISO]\n\n      const updatedBaseEvent = {\n        ...baseEvent,\n        exdates: updatedExdates,\n      }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n\n      // Create standalone modified event with recurrenceId\n      const modifiedEventId = `${targetEvent.id}_modified_${Date.now()}`\n      const modifiedEvent: CalendarEvent = {\n        // @ts-expect-error TODO: fix the types\n        ...omitKeys(targetEvent, ['width', 'height', 'top', 'left', 'right']),\n        ...updates,\n        id: modifiedEventId,\n        recurrenceId: targetEventStartISO, // This marks it as a modified instance\n        uid: baseEvent.uid || `${baseEvent.id}@ilamy.calendar`, // Keep same UID as base event (iCalendar standard)\n        rrule: undefined, // Standalone events don't have RRULE\n      } as CalendarEvent\n      updatedEvents.push(modifiedEvent)\n      break\n    }\n\n    case 'following': {\n      // \"This and following\" - Terminate original series and create new series\n\n      // Calculate the termination date: day before target with end of day time\n      // This ensures the last occurrence before target is included in the terminated series\n      const dayBeforeTarget = targetEvent.start.subtract(1, 'day')\n      const terminationDate = dayBeforeTarget.endOf('day').toDate()\n\n      // Update original series with UNTIL to end before target date\n      const terminatedEvent = {\n        ...baseEvent,\n        rrule: {\n          ...baseEvent.rrule,\n          until: terminationDate,\n        },\n      }\n      updatedEvents[baseEventIndex] = terminatedEvent\n\n      // Create new series starting from target date\n      const originalDuration = baseEvent.end.diff(baseEvent.start)\n      const newSeriesStartTime = updates.start || targetEvent.start\n      const newSeriesEndTime =\n        updates.end || newSeriesStartTime.add(originalDuration)\n      const newSeriesId = `${baseEvent.id}_following`\n      const newSeriesUID = `${newSeriesId}@ilamy.calendar`\n\n      const newSeriesEvent: CalendarEvent = {\n        ...baseEvent,\n        ...updates,\n        rrule: {\n          ...baseEvent.rrule,\n          ...updates.rrule,\n          dtstart: newSeriesStartTime.toDate(),\n        },\n        id: newSeriesId,\n        uid: newSeriesUID, // New UID for new series\n        start: newSeriesStartTime,\n        end: newSeriesEndTime,\n        recurrenceId: undefined, // This is a new base event, not an instance\n      }\n      updatedEvents.push(newSeriesEvent)\n      break\n    }\n\n    case 'all': {\n      // \"All events\" - Update the base recurring event\n      const updatedBaseEvent = {\n        ...baseEvent,\n        ...updates,\n      }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n      break\n    }\n\n    default:\n      throw new Error(\n        `Invalid scope: ${scope}. Must be 'this', 'following', or 'all'`\n      )\n  }\n\n  return updatedEvents\n}\n\ninterface DeleteRecurringEventProps {\n  targetEvent: CalendarEvent\n  currentEvents: CalendarEvent[]\n  scope: 'this' | 'following' | 'all'\n}\n\nexport const deleteRecurringEvent = ({\n  targetEvent,\n  currentEvents,\n  scope,\n}: DeleteRecurringEventProps): CalendarEvent[] => {\n  const updatedEvents = [...currentEvents]\n\n  // Find the base recurring event\n  const baseEventIndex = updatedEvents.findIndex((e) => {\n    const parentUid = e.uid || `${e.id}@ilamy.calendar`\n    return parentUid === targetEvent.uid && e.rrule && !e.recurrenceId\n  })\n\n  if (baseEventIndex === -1) {\n    throw new Error('Base recurring event not found')\n  }\n\n  const baseEvent = updatedEvents[baseEventIndex]\n\n  switch (scope) {\n    case 'this': {\n      // \"This event only\" - Add EXDATE to exclude this occurrence\n      const targetEventStartISO = targetEvent.start.toISOString()\n      const existingExdates = baseEvent.exdates || []\n      const updatedExdates = [...existingExdates, targetEventStartISO]\n\n      const updatedBaseEvent = { ...baseEvent, exdates: updatedExdates }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n      break\n    }\n\n    case 'following': {\n      // \"This and following\" - Terminate series with UNTIL before target date\n\n      // Calculate the termination date: day before target with end of day time\n      // This ensures the last occurrence before target is included in the terminated series\n      const dayBeforeTarget = targetEvent.start.subtract(1, 'day')\n      const terminationDate = dayBeforeTarget.endOf('day').toDate()\n\n      const terminatedEvent = {\n        ...baseEvent,\n        rrule: {\n          ...baseEvent.rrule,\n          until: terminationDate,\n        },\n      }\n      updatedEvents[baseEventIndex] = terminatedEvent\n      break\n    }\n\n    case 'all': {\n      // \"All events\" - Remove the entire recurring series\n      const eventsWithoutTargetSeries = updatedEvents.filter(\n        (e) => e.uid !== targetEvent.uid\n      )\n      return eventsWithoutTargetSeries\n    }\n\n    default:\n      throw new Error(\n        `Invalid scope: ${scope}. Must be 'this', 'following', or 'all'`\n      )\n  }\n\n  return updatedEvents\n}\n",
    "import {\n  Card,\n  CardContent,\n  CardHeader,\n  CardTitle,\n  Checkbox,\n  DatePicker,\n  Input,\n  Label,\n  Select,\n  SelectContent,\n  SelectItem,\n  SelectTrigger,\n  SelectValue,\n} from '@/components/ui'\nimport dayjs from '@/lib/dayjs-config'\nimport type { RRuleOptions } from '@/lib/recurrence-handler/types'\nimport { useState, useEffect } from 'react'\nimport { RRule } from 'rrule'\nimport type { Weekday } from 'rrule'\n\n// Natural language description function using RRule's built-in helper methods\nfunction getRRuleDescription(rruleOptions: RRuleOptions | null): string {\n  if (!rruleOptions) {\n    return 'Custom recurrence'\n  }\n\n  try {\n    // Create RRule instance directly from options\n    const rule = new RRule(rruleOptions)\n\n    // Use RRule's built-in natural language conversion with toText()\n    const naturalText = rule.toText()\n\n    // Handle cases where RRule can't convert to natural language\n    if (\n      !naturalText ||\n      naturalText.includes('RRule error') ||\n      naturalText.includes('Unable to fully convert') ||\n      naturalText.toLowerCase().includes('error')\n    ) {\n      return 'Custom recurrence'\n    }\n\n    // Capitalize first letter for consistent formatting\n    return naturalText.charAt(0).toUpperCase() + naturalText.slice(1)\n  } catch {\n    // If parsing fails, return fallback\n    return 'Custom recurrence'\n  }\n}\n\ninterface RecurrenceEditorProps {\n  value?: RRuleOptions | null\n  onChange: (rruleOptions: RRuleOptions | null) => void\n}\n\nconst WEEK_DAYS: { value: Weekday; label: string; short: string }[] = [\n  { value: RRule.SU, label: 'Sunday', short: 'Sun' },\n  { value: RRule.MO, label: 'Monday', short: 'Mon' },\n  { value: RRule.TU, label: 'Tuesday', short: 'Tue' },\n  { value: RRule.WE, label: 'Wednesday', short: 'Wed' },\n  { value: RRule.TH, label: 'Thursday', short: 'Thu' },\n  { value: RRule.FR, label: 'Friday', short: 'Fri' },\n  { value: RRule.SA, label: 'Saturday', short: 'Sat' },\n]\n\nexport const RecurrenceEditor: React.FC<RecurrenceEditorProps> = ({\n  value,\n  onChange,\n}) => {\n  const [showRecurrence, setShowRecurrence] = useState(!!value)\n\n  // Helper function to convert RRule frequency to string\n  const getFrequencyString = (freq: RRuleOptions['freq']): string => {\n    const freqMap: Record<number, string> = {\n      [RRule.DAILY]: 'DAILY',\n      [RRule.WEEKLY]: 'WEEKLY',\n      [RRule.MONTHLY]: 'MONTHLY',\n      [RRule.YEARLY]: 'YEARLY',\n    }\n    return freqMap[freq] || 'DAILY'\n  }\n\n  // Work with complete RRuleOptions - dtstart comes from parent EventForm\n  const [rruleOptions, setRRuleOptions] = useState<RRuleOptions | null>(\n    () => value || null\n  )\n\n  // Sync state when value prop changes\n  useEffect(() => {\n    setShowRecurrence(!!value)\n    if (value) {\n      setRRuleOptions(value)\n    }\n  }, [value])\n\n  const updateRRule = (updates: Partial<RRuleOptions>) => {\n    if (!rruleOptions) {\n      return // Can't update if no base options exist\n    }\n\n    const newOptions: RRuleOptions = { ...rruleOptions, ...updates }\n    setRRuleOptions(newOptions)\n\n    if (showRecurrence) {\n      onChange(newOptions)\n    } else {\n      onChange(null)\n    }\n  }\n\n  const handleRecurrenceToggle = (checked: boolean) => {\n    setShowRecurrence(checked)\n    if (checked) {\n      if (rruleOptions) {\n        onChange(rruleOptions)\n      } else {\n        // Create default RRule when toggling on for the first time\n        // Note: dtstart will be set by the parent EventForm\n        const defaultRRule: Partial<RRuleOptions> = {\n          freq: RRule.DAILY,\n          interval: 1,\n        }\n        setRRuleOptions(defaultRRule as RRuleOptions)\n        onChange(defaultRRule as RRuleOptions)\n      }\n    } else {\n      onChange(null)\n    }\n  }\n\n  const handleFrequencyChange = (frequency: string) => {\n    // Convert string to RRule frequency constant\n    const freqMap: Record<string, RRuleOptions['freq']> = {\n      DAILY: RRule.DAILY,\n      WEEKLY: RRule.WEEKLY,\n      MONTHLY: RRule.MONTHLY,\n      YEARLY: RRule.YEARLY,\n    }\n    updateRRule({ freq: freqMap[frequency] || RRule.DAILY })\n  }\n\n  const handleIntervalChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const interval = Math.max(1, Number.parseInt(e.target.value) || 1)\n    updateRRule({ interval })\n  }\n\n  const handleEndTypeChange = (endType: 'never' | 'count' | 'until') => {\n    const updates: Partial<RRuleOptions> = {}\n\n    if (endType === 'never') {\n      // Remove count and until\n      updates.count = undefined\n      updates.until = undefined\n    } else if (endType === 'count') {\n      // Set default count if none exists, remove until\n      updates.count = rruleOptions?.count || 1\n      updates.until = undefined\n    } else if (endType === 'until') {\n      // Set default until date if none exists, remove count\n      updates.until =\n        rruleOptions?.until || dayjs().add(1, 'month').endOf('day').toDate()\n      updates.count = undefined\n    }\n\n    updateRRule(updates)\n  }\n\n  const handleCountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const count = Math.max(1, Number.parseInt(e.target.value) || 1)\n    updateRRule({ count })\n  }\n\n  const handleEndDateChange = (date: Date | undefined) => {\n    const until = date ? dayjs(date).endOf('day').toDate() : undefined\n    updateRRule({ until })\n  }\n\n  const handleDayToggle = (dayIndex: number) => {\n    const weekdayMap = [\n      RRule.SU,\n      RRule.MO,\n      RRule.TU,\n      RRule.WE,\n      RRule.TH,\n      RRule.FR,\n      RRule.SA,\n    ]\n    const currentWeekdays = (rruleOptions?.byweekday as Weekday[]) || []\n    const targetWeekday = weekdayMap[dayIndex]\n\n    const isSelected = currentWeekdays.includes(targetWeekday)\n    let newWeekdays: Weekday[]\n\n    if (isSelected) {\n      newWeekdays = currentWeekdays.filter((day) => day !== targetWeekday)\n    } else {\n      newWeekdays = [...currentWeekdays, targetWeekday]\n    }\n\n    updateRRule({\n      byweekday: newWeekdays.length > 0 ? newWeekdays : undefined,\n    })\n  }\n\n  // Helper to determine end type from current options\n  const getEndType = (): 'never' | 'count' | 'until' => {\n    if (rruleOptions?.until) {\n      return 'until'\n    }\n    if (rruleOptions?.count) {\n      return 'count'\n    }\n    return 'never'\n  }\n\n  return (\n    <Card data-testid=\"recurrence-editor\">\n      <CardHeader className=\"pb-3\">\n        <div className=\"flex items-center space-x-2\">\n          <Checkbox\n            id=\"recurring\"\n            checked={showRecurrence}\n            onCheckedChange={handleRecurrenceToggle}\n            data-testid=\"toggle-recurrence\"\n          />\n          <CardTitle className=\"text-sm\">Repeat</CardTitle>\n        </div>\n        {showRecurrence && value && (\n          <p className=\"text-xs text-muted-foreground\">\n            {getRRuleDescription(value)}\n          </p>\n        )}\n      </CardHeader>\n\n      {showRecurrence && (\n        <CardContent className=\"pt-0\">\n          <div className=\"space-y-4\">\n            {/* Frequency Selection */}\n            <div className=\"grid grid-cols-2 gap-4\">\n              <div>\n                <Label htmlFor=\"frequency\" className=\"text-xs\">\n                  Repeats\n                </Label>\n                <Select\n                  value={getFrequencyString(rruleOptions?.freq ?? RRule.DAILY)}\n                  onValueChange={handleFrequencyChange}\n                >\n                  <SelectTrigger\n                    id=\"frequency\"\n                    className=\"h-8\"\n                    data-testid=\"frequency-select\"\n                  >\n                    <SelectValue />\n                  </SelectTrigger>\n                  <SelectContent>\n                    <SelectItem value=\"DAILY\">Daily</SelectItem>\n                    <SelectItem value=\"WEEKLY\">Weekly</SelectItem>\n                    <SelectItem value=\"MONTHLY\">Monthly</SelectItem>\n                    <SelectItem value=\"YEARLY\">Yearly</SelectItem>\n                  </SelectContent>\n                </Select>\n              </div>\n\n              <div>\n                <Label htmlFor=\"interval\" className=\"text-xs\">\n                  Every\n                </Label>\n                <Input\n                  id=\"interval\"\n                  type=\"number\"\n                  min=\"1\"\n                  value={rruleOptions?.interval || 1}\n                  onChange={handleIntervalChange}\n                  className=\"h-8\"\n                />\n              </div>\n            </div>\n\n            {/* Weekly Day Selection */}\n            {rruleOptions?.freq === RRule.WEEKLY && (\n              <div>\n                <Label className=\"text-xs\">Repeat on</Label>\n                <div className=\"flex flex-wrap gap-1 mt-1\">\n                  {WEEK_DAYS.map((day, index) => {\n                    const byweekdayArray = Array.isArray(\n                      rruleOptions?.byweekday\n                    )\n                      ? rruleOptions.byweekday\n                      : rruleOptions?.byweekday\n                        ? [rruleOptions.byweekday]\n                        : []\n                    const isSelected = byweekdayArray.includes(day.value)\n                    return (\n                      <div\n                        key={`day-${index}`}\n                        className=\"flex items-center space-x-1\"\n                      >\n                        <Checkbox\n                          id={`day-${index}`}\n                          checked={isSelected}\n                          onCheckedChange={() => handleDayToggle(index)}\n                        />\n                        <Label\n                          htmlFor={`day-${index}`}\n                          className=\"text-xs cursor-pointer\"\n                        >\n                          {day.short}\n                        </Label>\n                      </div>\n                    )\n                  })}\n                </div>\n              </div>\n            )}\n\n            {/* End Condition */}\n            <div>\n              <Label className=\"text-xs\">Ends</Label>\n              <div className=\"space-y-2 mt-1\">\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"never\"\n                    checked={getEndType() === 'never'}\n                    onCheckedChange={() => handleEndTypeChange('never')}\n                  />\n                  <Label htmlFor=\"never\" className=\"text-xs\">\n                    Never\n                  </Label>\n                </div>\n\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"after\"\n                    checked={getEndType() === 'count'}\n                    onCheckedChange={() => handleEndTypeChange('count')}\n                  />\n                  <Label htmlFor=\"after\" className=\"text-xs\">\n                    After\n                  </Label>\n                  {getEndType() === 'count' && (\n                    <Input\n                      type=\"number\"\n                      min=\"1\"\n                      value={rruleOptions?.count || 1}\n                      onChange={handleCountChange}\n                      className=\"h-6 w-16 text-xs\"\n                      data-testid=\"count-input\"\n                    />\n                  )}\n                  <span className=\"text-xs\">occurrences</span>\n                </div>\n\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"on\"\n                    checked={getEndType() === 'until'}\n                    onCheckedChange={() => handleEndTypeChange('until')}\n                  />\n                  <Label htmlFor=\"on\" className=\"text-xs\">\n                    On\n                  </Label>\n                  {getEndType() === 'until' && (\n                    <DatePicker\n                      date={rruleOptions?.until}\n                      setDate={handleEndDateChange}\n                      className=\"h-6\"\n                    />\n                  )}\n                </div>\n              </div>\n            </div>\n          </div>\n        </CardContent>\n      )}\n    </Card>\n  )\n}\n",
    "import {\n  Dialog,\n  DialogContent,\n  DialogDescription,\n  DialogFooter,\n  DialogHeader,\n  DialogTitle,\n  Button,\n} from '@/components/ui'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\n\ninterface RecurrenceEditDialogProps {\n  isOpen: boolean\n  onClose: () => void\n  onConfirm: (scope: RecurrenceEditScope) => void\n  operationType: 'edit' | 'delete'\n  eventTitle: string\n}\n\nexport function RecurrenceEditDialog({\n  isOpen,\n  onClose,\n  onConfirm,\n  operationType,\n  eventTitle,\n}: RecurrenceEditDialogProps) {\n  const handleScopeSelect = (scope: RecurrenceEditScope) => {\n    onConfirm(scope)\n    onClose()\n  }\n\n  const actionText = operationType === 'edit' ? 'change' : 'delete'\n  const actionVerb = operationType === 'edit' ? 'Edit' : 'Delete'\n\n  return (\n    <Dialog open={isOpen} onOpenChange={onClose}>\n      <DialogContent className=\"max-w-md\">\n        <DialogHeader>\n          <DialogTitle>{actionVerb} recurring event</DialogTitle>\n          <DialogDescription>\n            \"{eventTitle}\" is a recurring event. How would you like to{' '}\n            {actionText} it?\n          </DialogDescription>\n        </DialogHeader>\n\n        <div className=\"space-y-3\">\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('this')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">This event</div>\n              <div className=\"text-sm text-muted-foreground\">\n                Only {actionText} this specific occurrence\n              </div>\n            </div>\n          </Button>\n\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('following')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">This and following events</div>\n              <div className=\"text-sm text-muted-foreground\">\n                {actionVerb} this and all future occurrences\n              </div>\n            </div>\n          </Button>\n\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('all')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">All events</div>\n              <div className=\"text-sm text-muted-foreground\">\n                {actionVerb} the entire recurring series\n              </div>\n            </div>\n          </Button>\n        </div>\n\n        <DialogFooter>\n          <Button variant=\"outline\" onClick={onClose}>\n            Cancel\n          </Button>\n        </DialogFooter>\n      </DialogContent>\n    </Dialog>\n  )\n}\n",
    "import { useState, useCallback } from 'react'\nimport type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\n\nexport function useRecurringEventActions(onComplete?: () => void) {\n  const { updateRecurringEvent, deleteRecurringEvent } = useCalendarContext()\n\n  const [dialogState, setDialogState] = useState<{\n    isOpen: boolean\n    operationType: 'edit' | 'delete'\n    event: CalendarEvent | null\n    updates?: Partial<CalendarEvent>\n    onConfirm?: (scope: RecurrenceEditScope) => void\n  }>({\n    isOpen: false,\n    operationType: 'edit',\n    event: null,\n  })\n\n  const openEditDialog = useCallback(\n    (event: CalendarEvent, updates: Partial<CalendarEvent>) => {\n      setDialogState({\n        isOpen: true,\n        operationType: 'edit',\n        event,\n        updates,\n        onConfirm: (scope: RecurrenceEditScope) => {\n          updateRecurringEvent(event, updates, {\n            scope,\n            eventDate: event.start,\n          })\n        },\n      })\n    },\n    [updateRecurringEvent]\n  )\n\n  const openDeleteDialog = useCallback(\n    (event: CalendarEvent) => {\n      setDialogState({\n        isOpen: true,\n        operationType: 'delete',\n        event,\n        onConfirm: (scope: RecurrenceEditScope) => {\n          deleteRecurringEvent(event, {\n            scope,\n            eventDate: event.start,\n          })\n        },\n      })\n    },\n    [deleteRecurringEvent]\n  )\n\n  const closeDialog = useCallback(() => {\n    setDialogState({\n      isOpen: false,\n      operationType: 'edit',\n      event: null,\n    })\n  }, [])\n\n  const handleConfirm = useCallback(\n    (scope: RecurrenceEditScope) => {\n      if (dialogState.onConfirm) {\n        dialogState.onConfirm(scope)\n      }\n      closeDialog()\n      // Call onComplete to close the parent form\n      onComplete?.()\n    },\n    [dialogState, closeDialog, onComplete]\n  )\n\n  return {\n    dialogState,\n    openEditDialog,\n    openDeleteDialog,\n    closeDialog,\n    handleConfirm,\n  }\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport dayjs from '@/lib/dayjs-config'\nimport { RRule } from 'rrule'\n\n/**\n * Export calendar events to iCalendar (.ical) format\n * Fully RFC 5545 compliant iCalendar generation\n */\n\n/**\n * Escape special characters in iCalendar text fields\n */\nconst escapeICalText = (text: string): string => {\n  return text\n    .replaceAll('\\\\', '\\\\\\\\') // Escape backslashes\n    .replaceAll(';', '\\\\;') // Escape semicolons\n    .replaceAll(',', '\\\\,') // Escape commas\n    .replaceAll('\\n', '\\\\n') // Escape newlines\n    .replaceAll('\\r', '') // Remove carriage returns\n}\n\n/**\n * Format date for iCalendar format (YYYYMMDDTHHMMSSZ for UTC)\n */\nconst formatICalDate = (date: dayjs.Dayjs, allDay = false): string => {\n  if (allDay) {\n    return date.format('YYYYMMDD')\n  }\n  return date.utc().format('YYYYMMDD[T]HHmmss[Z]')\n}\n\n/**\n * Generate a unique UID for an event if not already present\n */\nconst generateUID = (event: CalendarEvent): string => {\n  if (event.uid) {\n    return event.uid\n  }\n  return `${event.id}@ilamy.calendar`\n}\n\n/**\n * Convert RRuleOptions to iCalendar RRULE string\n */\nconst formatRRule = (rruleOptions: unknown): string => {\n  try {\n    // Create RRule instance with appropriate type casting\n    const rule = new RRule(\n      rruleOptions as ConstructorParameters<typeof RRule>[0]\n    )\n    const rruleString = rule.toString()\n    // Extract just the RRULE part (remove DTSTART if present)\n    const rrulePart = rruleString\n      .split('\\n')\n      .find((line) => line.startsWith('RRULE:'))\n    return rrulePart || ''\n  } catch {\n    return ''\n  }\n}\n\n/**\n * Convert a single CalendarEvent to iCalendar VEVENT string\n */\nconst eventToICalEvent = (event: CalendarEvent): string => {\n  const lines: string[] = []\n\n  lines.push('BEGIN:VEVENT')\n\n  // UID (required)\n  lines.push(`UID:${generateUID(event)}`)\n\n  // DTSTART (required)\n  const dtstart = formatICalDate(event.start, event.allDay)\n  if (event.allDay) {\n    lines.push(`DTSTART;VALUE=DATE:${dtstart}`)\n  } else {\n    lines.push(`DTSTART:${dtstart}`)\n  }\n\n  // DTEND (required for events with duration)\n  const dtend = formatICalDate(event.end, event.allDay)\n  if (event.allDay) {\n    lines.push(`DTEND;VALUE=DATE:${dtend}`)\n  } else {\n    lines.push(`DTEND:${dtend}`)\n  }\n\n  // SUMMARY (title)\n  lines.push(`SUMMARY:${escapeICalText(event.title)}`)\n\n  // DESCRIPTION (optional)\n  if (event.description) {\n    lines.push(`DESCRIPTION:${escapeICalText(event.description)}`)\n  }\n\n  // LOCATION (optional)\n  if (event.location) {\n    lines.push(`LOCATION:${escapeICalText(event.location)}`)\n  }\n\n  // RRULE (recurrence rule)\n  if (event.rrule) {\n    const rruleString = formatRRule(event.rrule)\n    if (rruleString) {\n      lines.push(rruleString)\n    }\n  }\n\n  // EXDATE (exception dates)\n  if (event.exdates && event.exdates.length > 0) {\n    const exdates = event.exdates\n      .map((dateStr) => formatICalDate(dayjs(dateStr), event.allDay))\n      .join(',')\n    lines.push(`EXDATE:${exdates}`)\n  }\n\n  // RECURRENCE-ID (for modified instances)\n  if (event.recurrenceId) {\n    const recurrenceId = formatICalDate(dayjs(event.recurrenceId), event.allDay)\n    lines.push(`RECURRENCE-ID:${recurrenceId}`)\n  }\n\n  // DTSTAMP (required - when this was created/modified)\n  const now = dayjs().utc().format('YYYYMMDD[T]HHmmss[Z]')\n  lines.push(`DTSTAMP:${now}`)\n\n  // CREATED (when event was created)\n  lines.push(`CREATED:${now}`)\n\n  // LAST-MODIFIED (when event was last modified)\n  lines.push(`LAST-MODIFIED:${now}`)\n\n  // STATUS (default to CONFIRMED)\n  lines.push('STATUS:CONFIRMED')\n\n  // SEQUENCE (version number, default to 0)\n  lines.push('SEQUENCE:0')\n\n  // TRANSP (transparency - OPAQUE for busy time)\n  lines.push('TRANSP:OPAQUE')\n\n  lines.push('END:VEVENT')\n\n  return lines.join('\\r\\n')\n}\n\n/**\n * Filter events for proper iCalendar export\n * - Include base recurring events (with RRULE)\n * - Include modified instances (with recurrenceId)\n * - Include non-recurring events\n * - EXCLUDE generated recurring instances (no rrule, no recurrenceId)\n */\nconst filterEventsForExport = (events: CalendarEvent[]): CalendarEvent[] => {\n  const exportEvents: CalendarEvent[] = []\n  const processedUIDs = new Set<string>()\n\n  for (const event of events) {\n    // Get or generate UID for the event\n    const eventUID = event.uid || `${event.id}@ilamy.calendar`\n\n    // Case 1: Base recurring event (has RRULE, no recurrenceId)\n    if (event.rrule && !event.recurrenceId) {\n      exportEvents.push(event)\n      processedUIDs.add(eventUID)\n      continue\n    }\n\n    // Case 2: Modified recurring instance (has recurrenceId, no RRULE)\n    if (event.recurrenceId && !event.rrule) {\n      exportEvents.push(event)\n      continue\n    }\n\n    // Case 3: Non-recurring event (no RRULE, no recurrenceId, no UID pattern)\n    if (!event.rrule && !event.recurrenceId) {\n      // Check if this is a generated instance by UID pattern\n      const isGeneratedInstance = processedUIDs.has(eventUID)\n\n      if (!isGeneratedInstance) {\n        exportEvents.push(event)\n      }\n      // Skip generated instances - they'll be recreated by RRULE\n    }\n  }\n\n  return exportEvents\n}\n\n/**\n * Export events to iCalendar format\n */\nexport const exportToICalendar = (\n  events: CalendarEvent[],\n  calendarName = 'ilamy Calendar'\n): string => {\n  const lines: string[] = []\n\n  // Calendar header\n  lines.push('BEGIN:VCALENDAR')\n  lines.push('VERSION:2.0')\n  lines.push('PRODID:-//ilamy//ilamy Calendar//EN')\n  lines.push('CALSCALE:GREGORIAN')\n  lines.push('METHOD:PUBLISH')\n  lines.push(`X-WR-CALNAME:${escapeICalText(calendarName)}`)\n  lines.push(`X-WR-CALDESC:${escapeICalText(`Exported from ${calendarName}`)}`)\n\n  // Add timezone information (UTC)\n  lines.push('BEGIN:VTIMEZONE')\n  lines.push('TZID:UTC')\n  lines.push('BEGIN:STANDARD')\n  lines.push('DTSTART:19700101T000000')\n  lines.push('TZNAME:UTC')\n  lines.push('TZOFFSETFROM:+0000')\n  lines.push('TZOFFSETTO:+0000')\n  lines.push('END:STANDARD')\n  lines.push('END:VTIMEZONE')\n\n  // Filter events for proper iCalendar export\n  const filteredEvents = filterEventsForExport(events)\n\n  // Add each filtered event\n  filteredEvents.forEach((event) => {\n    lines.push(eventToICalEvent(event))\n  })\n\n  // Calendar footer\n  lines.push('END:VCALENDAR')\n\n  return lines.join('\\r\\n')\n}\n\n/**\n * Download iCalendar file to user's device\n */\nexport const downloadICalendar = (\n  events: CalendarEvent[],\n  filename = 'calendar.ics',\n  calendarName = 'ilamy Calendar'\n): void => {\n  const icalContent = exportToICalendar(events, calendarName)\n\n  // Create blob and download\n  const blob = new Blob([icalContent], {\n    type: 'text/calendar;charset=utf-8',\n  })\n\n  const url = URL.createObjectURL(blob)\n  const link = document.createElement('a')\n  link.href = url\n  link.download = filename.endsWith('.ics') ? filename : `${filename}.ics`\n\n  // Trigger download\n  document.body.append(link)\n  link.click()\n  document.body.removeChild(link)\n\n  // Clean up\n  URL.revokeObjectURL(url)\n}\n",
    "import {\n  Button,\n  Popover,\n  PopoverContent,\n  PopoverTrigger,\n} from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { downloadICalendar } from '@/lib/export-ical'\nimport { Calendar as CalendarIcon, Download, Menu, Plus } from 'lucide-react'\nimport React, { useCallback, useState } from 'react'\nimport TitleContent from './title-content'\nimport ViewControls from './view-controls'\nimport { cn } from '@/lib'\n\ninterface HeaderProps {\n  className?: string\n}\n\nconst Header: React.FC<HeaderProps> = ({ className = '' }) => {\n  const {\n    view,\n    setView,\n    nextPeriod,\n    prevPeriod,\n    today,\n    openEventForm,\n    headerComponent,\n    rawEvents,\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  // Handle iCalendar export\n  const handleExport = useCallback(() => {\n    const filename = `ilamy-calendar-${new Date().toISOString().split('T')[0]}.ics`\n    downloadICalendar(rawEvents, filename, 'ilamy Calendar')\n    setMobilePopoverOpen(false)\n  }, [rawEvents])\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()}\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 lg:inline\">New</span>\n        </Button>\n      </div>\n    ),\n    [openEventForm]\n  )\n\n  if (headerComponent) {\n    // Render custom header component if provided\n    return headerComponent\n  }\n\n  return (\n    <>\n      {/* Calendar Header with grid layout */}\n      <div\n        className={cn(\n          '@container flex justify-center lg:justify-between flex-wrap items-center gap-2 border-b',\n          className\n        )}\n        data-testid=\"calendar-header\"\n      >\n        {/* Title area - Left section */}\n        <div className=\"flex flex-wrap items-center justify-center gap-1 2xl:col-span-5 2xl:justify-start\">\n          <CalendarIcon className=\"h-5 w-5\" />\n          <TitleContent />\n        </div>\n\n        {/* New event button - Mobile & Desktop */}\n        <div className=\"flex flex-wrap justify-center gap-1 2xl:col-span-7 2xl:justify-end\">\n          {/* Desktop controls - centralized */}\n          <div className=\"hidden items-center justify-start lg:justify-center 2xl:justify-end gap-1 sm:flex w-full overflow-x-auto\">\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\n            {/* Export button - Desktop */}\n            <Button\n              onClick={handleExport}\n              variant=\"outline\"\n              size=\"sm\"\n              className=\"flex items-center gap-1\"\n            >\n              <Download className=\"h-4 w-4\" />\n              <span className=\"hidden lg:inline\">Export</span>\n            </Button>\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\n                  {/* Export button - Mobile */}\n                  <div className=\"pt-2 border-t\">\n                    <Button\n                      onClick={handleExport}\n                      variant=\"outline\"\n                      size=\"sm\"\n                      className=\"w-full flex items-center gap-2\"\n                    >\n                      <Download className=\"h-4 w-4\" />\n                      Export Calendar (.ics)\n                    </Button>\n                  </div>\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-1! 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-1! 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-1! 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-1! 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\ninterface 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, getEventsForDateRange } =\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 = getEventsForDateRange(\n        day.startOf('day'),\n        day.endOf('day')\n      )\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-${month.date.format('YYYY-MM')}-${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/view/month-view'\nimport WeekView from '@/features/week-view/view/week-view'\nimport DayView from '@/features/day-view/components/view/day-view'\nimport { EventForm } from '../event-form/event-form'\nimport { Header } from '../header'\nimport YearView from '@/features/year-view/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 } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\n// oxlint-disable-next-line no-duplicates\nimport '@/lib/dayjs-config'\nimport { WEEK_DAYS_NUMBER_MAP } from '@/lib/constants'\nimport { normalizePublicFacingCalendarEvent } from '@/lib'\nimport type { IlamyCalendarProps } from './types'\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 className=\"p-1\" />\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=\"w-full h-[calc(100%-3.5rem)]\"\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\nconst DEFAULT_DAY_MAX_EVENTS = 4\nexport const IlamyCalendar: React.FC<IlamyCalendarProps> = ({\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  headerComponent,\n}) => {\n  return (\n    <CalendarProvider\n      events={normalizePublicFacingCalendarEvent(events)}\n      firstDayOfWeek={WEEK_DAYS_NUMBER_MAP[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      headerComponent={headerComponent}\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, { useState } 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'\nimport { isRecurringEvent } from '@/lib/recurrence-handler'\nimport { RecurrenceEditDialog } from '@/features/recurrence/components/recurrence-edit-dialog'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\n\ninterface CalendarDndContextProps {\n  children: React.ReactNode\n}\n\nexport function CalendarDndContext({ children }: CalendarDndContextProps) {\n  const { updateEvent, updateRecurringEvent, view, disableDragAndDrop } =\n    useCalendarContext()\n  const [activeEvent, setActiveEvent] = React.useState<CalendarEvent | null>(\n    null\n  )\n\n  // State for recurring event dialog\n  const [recurringDialog, setRecurringDialog] = useState<{\n    isOpen: boolean\n    event: CalendarEvent | null\n    updates: Partial<CalendarEvent> | null\n  }>({\n    isOpen: false,\n    event: null,\n    updates: 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  // Helper function to perform the actual event update\n  const performEventUpdate = (\n    event: CalendarEvent,\n    updates: Partial<CalendarEvent>\n  ) => {\n    // Validate inputs\n    if (!event || !event.id) {\n      return\n    }\n\n    if (!updates || Object.keys(updates).length === 0) {\n      return\n    }\n\n    if (isRecurringEvent(event)) {\n      // Show dialog for recurring events\n      setRecurringDialog({\n        isOpen: true,\n        event,\n        updates,\n      })\n    } else {\n      // Directly update regular events\n      updateEvent(event.id, updates)\n    }\n  }\n\n  // Handle recurring event dialog confirmation\n  const handleRecurringEventConfirm = (scope: RecurrenceEditScope) => {\n    if (!recurringDialog.event || !recurringDialog.updates) {\n      setRecurringDialog({ isOpen: false, event: null, updates: null })\n      return\n    }\n\n    try {\n      updateRecurringEvent(recurringDialog.event, recurringDialog.updates, {\n        scope,\n        eventDate: recurringDialog.event.start,\n      })\n    } catch {\n      // Silently handle error and reset dialog state\n    } finally {\n      setRecurringDialog({ isOpen: false, event: null, updates: null })\n    }\n  }\n\n  // Handle recurring event dialog close\n  const handleRecurringEventClose = () => {\n    setRecurringDialog({ isOpen: false, event: null, updates: null })\n  }\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 start = activeEvent.start\n      const end = activeEvent.end\n      const durationMinutes = end.diff(start, '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      performEventUpdate(activeEvent, {\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 start = activeEvent.start\n      const end = activeEvent.end\n\n      if (isMultiDayEvent) {\n        if (view === 'week') {\n          // Get time components to preserve\n          const startHour = start.hour()\n          const startMinute = start.minute()\n          const endHour = end.hour()\n          const endMinute = end.minute()\n\n          // Calculate duration in days to preserve\n          const durationDays = end.diff(start, '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          performEventUpdate(activeEvent, {\n            start: newStart,\n            end: newEnd,\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(start.startOf('day'), 'day')\n\n          // Calculate new start and end while preserving time components\n          const newStart = start.add(daysDifference, 'day')\n          const newEnd = end.add(daysDifference, 'day')\n\n          performEventUpdate(activeEvent, {\n            start: newStart,\n            end: newEnd,\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        performEventUpdate(activeEvent, {\n          start: newStart,\n          end: newEnd,\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    <>\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      {/* Recurring event edit dialog */}\n      <RecurrenceEditDialog\n        isOpen={recurringDialog.isOpen}\n        onClose={handleRecurringEventClose}\n        onConfirm={handleRecurringEventConfirm}\n        operationType=\"edit\"\n        eventTitle={recurringDialog.event?.title || ''}\n      />\n    </>\n  )\n}\n",
    "import dayjs from '@/lib/dayjs-config'\nimport React, { useCallback, useEffect, useMemo, useState } from 'react'\nimport type { ReactNode } from 'react'\nimport { CalendarContext } from './context'\nimport type { CalendarEvent } from '@/components/types'\nimport {\n  generateRecurringEvents,\n  updateRecurringEvent as updateRecurringEventImpl,\n  deleteRecurringEvent as deleteRecurringEventImpl,\n} from '@/lib/recurrence-handler'\nimport type { RecurrenceEditOptions } from '@/features/recurrence/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  headerComponent?: ReactNode // Optional custom header component\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 = true,\n  viewHeaderClassName = '',\n  headerComponent,\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  // Helper function to get events for a specific date range (on-demand generation)\n  const getEventsForDateRange = useCallback(\n    (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs): CalendarEvent[] => {\n      const allEvents: CalendarEvent[] = []\n\n      for (const event of currentEvents) {\n        if (event.rrule) {\n          // Generate recurring instances for the specific range\n          const recurringEvents = generateRecurringEvents({\n            event,\n            currentEvents,\n            startDate,\n            endDate,\n          })\n          allEvents.push(...recurringEvents)\n        } else {\n          // Add non-recurring events with comprehensive range checking\n          const eventStartsInRange =\n            event.start.isSameOrAfter(startDate) &&\n            event.start.isSameOrBefore(endDate)\n\n          const eventEndsInRange =\n            event.end.isSameOrAfter(startDate) &&\n            event.end.isSameOrBefore(endDate)\n\n          const eventSpansRange =\n            event.start.isBefore(startDate) && event.end.isAfter(endDate)\n\n          if (eventStartsInRange || eventEndsInRange || eventSpansRange) {\n            allEvents.push(event)\n          }\n        }\n      }\n\n      return allEvents\n    },\n    [currentEvents]\n  )\n\n  // Get the current view's date range for on-demand event generation\n  const getCurrentViewRange = useCallback(() => {\n    switch (view) {\n      case 'day':\n        return {\n          start: currentDate.startOf('day'),\n          end: currentDate.endOf('day'),\n        }\n      case 'week':\n        return {\n          start: currentDate\n            .startOf('week')\n            .subtract(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n          end: currentDate\n            .endOf('week')\n            .add(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n        }\n      case 'month':\n        return {\n          start: currentDate\n            .startOf('month')\n            .startOf('week')\n            .subtract(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n          end: currentDate\n            .endOf('month')\n            .endOf('week')\n            .add(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n        }\n      case 'year':\n        return {\n          start: currentDate.startOf('year'),\n          end: currentDate.endOf('year'),\n        }\n      default:\n        return {\n          start: currentDate.startOf('month'),\n          end: currentDate.endOf('month'),\n        }\n    }\n  }, [currentDate, view, firstDayOfWeek])\n\n  // Get processed events for the current view (on-demand)\n  const processedEvents = useMemo(() => {\n    const { start, end } = getCurrentViewRange()\n    return getEventsForDateRange(start, end)\n  }, [getEventsForDateRange, getCurrentViewRange])\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 updateRecurringEvent = useCallback(\n    (\n      event: CalendarEvent,\n      updates: Partial<CalendarEvent>,\n      options: RecurrenceEditOptions\n    ) => {\n      // Use our implemented recurring event update function\n      const updatedEvents = updateRecurringEventImpl({\n        targetEvent: event,\n        updates,\n        currentEvents,\n        scope: options.scope,\n      })\n\n      setCurrentEvents(updatedEvents)\n    },\n    [currentEvents]\n  )\n\n  const deleteRecurringEvent = useCallback(\n    (event: CalendarEvent, options: RecurrenceEditOptions) => {\n      // Use our implemented recurring event delete function\n      const updatedEvents = deleteRecurringEventImpl({\n        targetEvent: event,\n        currentEvents,\n        scope: options.scope,\n      })\n\n      setCurrentEvents(updatedEvents)\n    },\n    [currentEvents]\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) {\n        return\n      }\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) {\n        return\n      }\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        } as CalendarEvent)\n        setIsEventFormOpen(true)\n      }\n    },\n    [onCellClick, disableCellClick]\n  )\n\n  const handleOpenEventForm = useCallback(\n    (date?: dayjs.Dayjs) => {\n      if (date) {\n        setSelectedDate(date)\n      }\n      setSelectedEvent({\n        title: `New Event`,\n        start: date ?? currentDate,\n        end: date ?? currentDate.add(1, 'hour'),\n        description: '',\n        allDay: false,\n      } as CalendarEvent)\n      setIsEventFormOpen(true)\n    },\n    [currentDate]\n  )\n\n  // Find parent recurring event for a given event instance\n  const findParentRecurringEvent = useCallback(\n    (event: CalendarEvent): CalendarEvent | null => {\n      // Generate UID if missing (following RFC 5545 compliance)\n      const targetUID = event.uid\n\n      const parentEvent = currentEvents.find((e) => {\n        const parentUID = e.uid || `${e.id}@ilamy.calendar`\n        return parentUID === targetUID && e.rrule\n      })\n\n      return parentEvent || null\n    },\n    [currentEvents]\n  )\n\n  // Create the context value\n  const contextValue = useMemo(\n    () => ({\n      currentDate,\n      view,\n      events: processedEvents,\n      rawEvents: 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      updateRecurringEvent,\n      deleteEvent,\n      deleteRecurringEvent,\n      openEventForm: handleOpenEventForm,\n      closeEventForm,\n      getEventsForDateRange,\n      findParentRecurringEvent,\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      headerComponent,\n    }),\n    [\n      currentDate,\n      view,\n      processedEvents,\n      currentEvents,\n      currentLocale,\n      isEventFormOpen,\n      selectedEvent,\n      selectedDate,\n      firstDayOfWeek,\n      selectDate,\n      handleViewChange,\n      nextPeriod,\n      handleOpenEventForm,\n      prevPeriod,\n      today,\n      addEvent,\n      updateEvent,\n      updateRecurringEvent,\n      deleteEvent,\n      deleteRecurringEvent,\n      closeEventForm,\n      getEventsForDateRange,\n      findParentRecurringEvent,\n      renderEvent,\n      handleEventClick,\n      handleDateClick,\n      locale,\n      currentTimezone,\n      disableCellClick,\n      disableEventClick,\n      disableDragAndDrop,\n      dayMaxEvents,\n      stickyViewHeader,\n      viewHeaderClassName,\n      headerComponent,\n    ]\n  )\n\n  return (\n    <CalendarContext.Provider value={contextValue}>\n      {children}\n    </CalendarContext.Provider>\n  )\n}\n",
    "// Main calendar component\nexport { IlamyCalendar } from './components/ilamy-calendar/ilamy-calendar'\n\n// Public calendar context hook\nexport { useIlamyCalendarContext } from './contexts/calendar-context/context'\n\n// RRULE-based recurrence system\nexport {\n  generateRecurringEvents,\n  isRecurringEvent,\n} from './lib/recurrence-handler'\n\n// Export types\nexport type { RRuleOptions } from './lib/recurrence-handler/types'\nexport type { CalendarEvent } from './components/types'\nexport type { IlamyCalendarProps } from './components/ilamy-calendar/types'\nexport type { WeekDays } from './components/types'\nexport type { UseIlamyCalendarContextReturn } from './contexts/calendar-context/context'\n// Re-export rrule.js types for convenience\nexport type { Frequency, Weekday } from 'rrule'\nexport { RRule } from 'rrule'\n"
  ],
  "mappings": "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",
  "debugId": "7721FF42EA85BA6064756E2164756E21",
  "names": []
}
|
|
4799
|
+
//# debugId=B447EF05B8FF828364756E2164756E21
|
|
4800
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/features/month-view/components/view/month-view.tsx", "../src/contexts/calendar-context/context.ts", "../src/components/ui/button.tsx", "../src/lib/utils.ts", "../src/lib/dayjs-config.ts", "../src/components/ui/calendar.tsx", "../src/components/ui/checkbox.tsx", "../src/components/ui/card.tsx", "../src/components/ui/date-picker.tsx", "../src/components/ui/popover.tsx", "../src/components/ui/dialog.tsx", "../src/components/ui/input.tsx", "../src/components/ui/label.tsx", "../src/components/ui/scroll-area.tsx", "../src/components/ui/select.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/month-header.tsx", "../src/lib/constants.ts", "../src/hooks/useProcessedWeekEvents.ts", "../src/features/month-view/components/week-events-layer/week-events-layer.tsx", "../src/features/week-view/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/components/day-events-layer.tsx", "../src/features/week-view/week-day-col.tsx", "../src/features/week-view/week-time-grid.tsx", "../src/features/day-view/components/view/day-view.tsx", "../src/features/day-view/components/day-all-day-row.tsx", "../src/features/day-view/components/day-header.tsx", "../src/features/day-view/components/day-time-col.tsx", "../src/components/event-form/event-form.tsx", "../src/lib/recurrence-handler/index.ts", "../src/features/recurrence/components/recurrence-editor/recurrence-editor.tsx", "../src/features/recurrence/components/recurrence-edit-dialog/recurrence-edit-dialog.tsx", "../src/features/recurrence/hooks/useRecurringEventActions.ts", "../src/lib/export-ical.ts", "../src/components/header/base-header.tsx", "../src/components/header/title-content.tsx", "../src/components/header/view-controls.tsx", "../src/features/year-view/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", "../src/lib/translations/default.ts", "../src/index.ts"],
  "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/month-header'\nimport { WeekEventsLayer } from '../week-events-layer/week-events-layer'\nimport { ScrollArea } from '@/components/ui'\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 className=\"h-[3rem]\" />\n\n      {/* Calendar grid - added fixed height */}\n      <ScrollArea\n        className=\"overflow-auto h-[calc(100%-3rem)]\"\n        data-testid=\"month-scroll-area\"\n        viewPortProps={{ className: '*:flex! *:flex-col *:min-h-full' }}\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 flex-1\"\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      </ScrollArea>\n\n      {/* Dialog for showing all events */}\n      <AllEventDialog ref={allEventsDialogRef} />\n    </div>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport type { RecurrenceEditOptions } from '@/features/recurrence/types'\nimport type dayjs from '@/lib/dayjs-config'\nimport type { TranslationKey } from '@/lib/translations/types'\nimport { createContext, useContext } from 'react'\n\nexport interface CalendarContextType {\n  currentDate: dayjs.Dayjs\n  view: 'month' | 'week' | 'day' | 'year'\n  events: CalendarEvent[]\n  rawEvents: CalendarEvent[] // Unprocessed events for export\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 | number, event: Partial<CalendarEvent>) => void\n  updateRecurringEvent: (\n    event: CalendarEvent,\n    updates: Partial<CalendarEvent>,\n    options: RecurrenceEditOptions\n  ) => void\n  deleteEvent: (eventId: string | number) => void\n  deleteRecurringEvent: (\n    event: CalendarEvent,\n    options: RecurrenceEditOptions\n  ) => void\n  openEventForm: (date?: dayjs.Dayjs) => void\n  closeEventForm: () => void\n  getEventsForDateRange: (\n    startDate: dayjs.Dayjs,\n    endDate: dayjs.Dayjs\n  ) => CalendarEvent[]\n  findParentRecurringEvent: (event: CalendarEvent) => CalendarEvent | null\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  headerComponent?: React.ReactNode // Optional custom header component\n  headerClassName?: string // Optional custom header class\n  // Translation function\n  t: (key: TranslationKey) => string\n}\n\nexport const CalendarContext: React.Context<CalendarContextType | undefined> =\n  createContext<CalendarContextType | undefined>(undefined)\n\nexport const useCalendarContext = (): CalendarContextType => {\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\n/**\n * Simplified calendar context type for external use\n * Contains only the most commonly used calendar operations\n */\nexport interface UseIlamyCalendarContextReturn {\n  readonly currentDate: dayjs.Dayjs\n  readonly view: 'month' | 'week' | 'day' | 'year'\n  readonly events: CalendarEvent[]\n  readonly isEventFormOpen: boolean\n  readonly selectedEvent: CalendarEvent | null\n  readonly selectedDate: dayjs.Dayjs | null\n  readonly firstDayOfWeek: number\n  readonly setCurrentDate: (date: dayjs.Dayjs) => void\n  readonly selectDate: (date: dayjs.Dayjs) => void\n  readonly setView: (view: 'month' | 'week' | 'day' | 'year') => void\n  readonly nextPeriod: () => void\n  readonly prevPeriod: () => void\n  readonly today: () => void\n  readonly addEvent: (event: CalendarEvent) => void\n  readonly updateEvent: (\n    eventId: string | number,\n    event: Partial<CalendarEvent>\n  ) => void\n  readonly deleteEvent: (eventId: string | number) => void\n  readonly openEventForm: (date?: dayjs.Dayjs) => void\n  readonly closeEventForm: () => void\n}\n\nexport const useIlamyCalendarContext = (): UseIlamyCalendarContextReturn => {\n  const context = useContext(CalendarContext)\n  if (context === undefined) {\n    throw new Error(\n      'useIlamyCalendarContext must be used within a CalendarProvider'\n    )\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  } as const\n}\n",
    "import * as React from 'react'\nimport { Slot } from '@radix-ui/react-slot'\nimport type { VariantProps } from 'class-variance-authority'\nimport { cva } 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 type { CalendarEvent } from '@/components'\nimport type { ClassValue } from 'clsx'\nimport { clsx } from 'clsx'\nimport dayjs from '@/lib/dayjs-config'\nimport { twMerge } from 'tailwind-merge'\nimport type { IlamyCalendarPropEvent } from '@/components/ilamy-calendar/types'\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().startOf('week').add(i, 'day').startOf('day'),\n      end: dayjs().startOf('week').add(i, 'day').endOf('day'),\n      color: 'bg-gray-100 text-gray-800',\n    })\n  }\n  return events\n}\n\nexport function safeDate(date: dayjs.Dayjs | Date | string): dayjs.Dayjs {\n  if (dayjs.isDayjs(date)) {\n    return date\n  }\n\n  const parsedDate = dayjs(date)\n  return parsedDate.isValid() ? parsedDate : dayjs()\n}\n\nexport const omitKeys = <T extends object, K extends keyof T>(\n  obj: T,\n  keys: K[]\n): Omit<T, K> => {\n  const result = { ...obj }\n  for (const key of keys) {\n    delete result[key]\n  }\n  return result\n}\n\nexport function normalizePublicFacingCalendarEvent(\n  events: IlamyCalendarPropEvent[]\n): CalendarEvent[] {\n  if (!events || !events.length) {\n    return []\n  }\n\n  return events.map((event) => {\n    // Events are already in the correct format with RRULE strings\n    return {\n      ...event,\n      start: dayjs.isDayjs(event.start) ? event.start : dayjs(event.start),\n      end: dayjs.isDayjs(event.end) ? event.end : dayjs(event.end),\n    } as CalendarEvent\n  })\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// 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\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\nexport default dayjs\n",
    "import * as React from 'react'\nimport {\n  ChevronDownIcon,\n  ChevronLeftIcon,\n  ChevronRightIcon,\n} from 'lucide-react'\nimport type { DayButton } from 'react-day-picker'\nimport { DayPicker, getDefaultClassNames } from 'react-day-picker'\n\nimport { cn } from '@/lib/utils'\nimport { Button, buttonVariants } from '@/components/ui/button'\n\nfunction Calendar({\n  className,\n  classNames,\n  showOutsideDays = true,\n  captionLayout = 'label',\n  buttonVariant = 'ghost',\n  formatters,\n  components,\n  ...props\n}: React.ComponentProps<typeof DayPicker> & {\n  buttonVariant?: React.ComponentProps<typeof Button>['variant']\n}) {\n  const defaultClassNames = getDefaultClassNames()\n\n  return (\n    <DayPicker\n      showOutsideDays={showOutsideDays}\n      className={cn(\n        'bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',\n        String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n        String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n        className\n      )}\n      captionLayout={captionLayout}\n      formatters={{\n        formatMonthDropdown: (date) =>\n          date.toLocaleString('default', { month: 'short' }),\n        ...formatters,\n      }}\n      classNames={{\n        root: cn('w-fit', defaultClassNames.root),\n        months: cn(\n          'flex gap-4 flex-col md:flex-row relative',\n          defaultClassNames.months\n        ),\n        month: cn('flex flex-col w-full gap-4', defaultClassNames.month),\n        nav: cn(\n          'flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between',\n          defaultClassNames.nav\n        ),\n        button_previous: cn(\n          buttonVariants({ variant: buttonVariant }),\n          'size-(--cell-size) aria-disabled:opacity-50 p-0 select-none',\n          defaultClassNames.button_previous\n        ),\n        button_next: cn(\n          buttonVariants({ variant: buttonVariant }),\n          'size-(--cell-size) aria-disabled:opacity-50 p-0 select-none',\n          defaultClassNames.button_next\n        ),\n        month_caption: cn(\n          'flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)',\n          defaultClassNames.month_caption\n        ),\n        dropdowns: cn(\n          'w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5',\n          defaultClassNames.dropdowns\n        ),\n        dropdown_root: cn(\n          'relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md',\n          defaultClassNames.dropdown_root\n        ),\n        dropdown: cn(\n          'absolute bg-popover inset-0 opacity-0',\n          defaultClassNames.dropdown\n        ),\n        caption_label: cn(\n          'select-none font-medium',\n          captionLayout === 'label'\n            ? 'text-sm'\n            : 'rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5',\n          defaultClassNames.caption_label\n        ),\n        table: 'w-full border-collapse',\n        weekdays: cn('flex', defaultClassNames.weekdays),\n        weekday: cn(\n          'text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none',\n          defaultClassNames.weekday\n        ),\n        week: cn('flex w-full mt-2', defaultClassNames.week),\n        week_number_header: cn(\n          'select-none w-(--cell-size)',\n          defaultClassNames.week_number_header\n        ),\n        week_number: cn(\n          'text-[0.8rem] select-none text-muted-foreground',\n          defaultClassNames.week_number\n        ),\n        day: cn(\n          'relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none',\n          defaultClassNames.day\n        ),\n        range_start: cn(\n          'rounded-l-md bg-accent',\n          defaultClassNames.range_start\n        ),\n        range_middle: cn('rounded-none', defaultClassNames.range_middle),\n        range_end: cn('rounded-r-md bg-accent', defaultClassNames.range_end),\n        today: cn(\n          'bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none',\n          defaultClassNames.today\n        ),\n        outside: cn(\n          'text-muted-foreground aria-selected:text-muted-foreground',\n          defaultClassNames.outside\n        ),\n        disabled: cn(\n          'text-muted-foreground opacity-50',\n          defaultClassNames.disabled\n        ),\n        hidden: cn('invisible', defaultClassNames.hidden),\n        ...classNames,\n      }}\n      components={{\n        Root: ({ className, rootRef, ...props }) => {\n          return (\n            <div\n              data-slot=\"calendar\"\n              ref={rootRef}\n              className={cn(className)}\n              {...props}\n            />\n          )\n        },\n        Chevron: ({ className, orientation, ...props }) => {\n          if (orientation === 'left') {\n            return (\n              <ChevronLeftIcon className={cn('size-4', className)} {...props} />\n            )\n          }\n\n          if (orientation === 'right') {\n            return (\n              <ChevronRightIcon\n                className={cn('size-4', className)}\n                {...props}\n              />\n            )\n          }\n\n          return (\n            <ChevronDownIcon className={cn('size-4', className)} {...props} />\n          )\n        },\n        DayButton: CalendarDayButton,\n        WeekNumber: ({ children, ...props }) => {\n          return (\n            <td {...props}>\n              <div className=\"flex size-(--cell-size) items-center justify-center text-center\">\n                {children}\n              </div>\n            </td>\n          )\n        },\n        ...components,\n      }}\n      {...props}\n    />\n  )\n}\n\nfunction CalendarDayButton({\n  className,\n  day,\n  modifiers,\n  ...props\n}: React.ComponentProps<typeof DayButton>) {\n  const defaultClassNames = getDefaultClassNames()\n\n  const ref = React.useRef<HTMLButtonElement>(null)\n  React.useEffect(() => {\n    if (modifiers.focused) {\n      ref.current?.focus()\n    }\n  }, [modifiers.focused])\n\n  return (\n    <Button\n      ref={ref}\n      variant=\"ghost\"\n      size=\"icon\"\n      data-day={day.date.toLocaleDateString()}\n      data-selected-single={\n        modifiers.selected &&\n        !modifiers.range_start &&\n        !modifiers.range_end &&\n        !modifiers.range_middle\n      }\n      data-range-start={modifiers.range_start}\n      data-range-end={modifiers.range_end}\n      data-range-middle={modifiers.range_middle}\n      className={cn(\n        'data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70',\n        defaultClassNames.day,\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nexport { Calendar, CalendarDayButton }\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 * as React from 'react'\n\nimport { cn } from '@/lib/utils'\n\nfunction Card({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card\"\n      className={cn(\n        'text-card-foreground flex flex-col gap-6 rounded-xl border shadow-sm',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-header\"\n      className={cn(\n        '@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 p-4 pb-0 has-data-[slot=card-action]:grid-cols-[1fr_auto]',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-title\"\n      className={cn('leading-none font-semibold', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-description\"\n      className={cn('text-muted-foreground text-sm', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-action\"\n      className={cn(\n        'col-start-2 row-span-2 row-start-1 self-start justify-self-end',\n        className\n      )}\n      {...props}\n    />\n  )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-content\"\n      className={cn('p-4 pt-0', className)}\n      {...props}\n    />\n  )\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<'div'>) {\n  return (\n    <div\n      data-slot=\"card-footer\"\n      className={cn('flex items-center px-6 [.border-t]:pt-6', className)}\n      {...props}\n    />\n  )\n}\n\nexport {\n  Card,\n  CardHeader,\n  CardFooter,\n  CardTitle,\n  CardAction,\n  CardDescription,\n  CardContent,\n}\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            month={date}\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 max-h-[90%] overflow-y-scroll',\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'\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",
    "'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'\nimport * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area'\n\nimport { cn } from '@/lib/utils'\n\ninterface ScrollAreaProps\n  extends React.ComponentProps<typeof ScrollAreaPrimitive.Root> {\n  viewPortProps?: React.ComponentProps<typeof ScrollAreaPrimitive.Viewport>\n}\n\nfunction ScrollArea({ className, children, ...props }: ScrollAreaProps) {\n  return (\n    <ScrollAreaPrimitive.Root\n      data-slot=\"scroll-area\"\n      className={cn('relative', className)}\n      {...props}\n    >\n      <ScrollAreaPrimitive.Viewport\n        {...props.viewPortProps}\n        data-slot=\"scroll-area-viewport\"\n        className={cn(\n          'focus-visible:ring-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:outline-1',\n          props.viewPortProps?.className\n        )}\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 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={`all-events-dialog-event-$${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\nconst getBorderRadiusClass = (\n  isTruncatedStart: boolean,\n  isTruncatedEnd: boolean\n) => {\n  if (isTruncatedStart && isTruncatedEnd) {\n    return 'rounded-none'\n  }\n  if (isTruncatedStart) {\n    return 'rounded-r-md rounded-l-none'\n  }\n  if (isTruncatedEnd) {\n    return 'rounded-l-md rounded-r-none'\n  }\n  return 'rounded-md'\n}\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    // Check if this event has truncation information\n    const enhancedEvent = event as unknown as {\n      isTruncatedStart?: boolean\n      isTruncatedEnd?: boolean\n    }\n    const isTruncatedStart = enhancedEvent.isTruncatedStart\n    const isTruncatedEnd = enhancedEvent.isTruncatedEnd\n\n    return (\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 text-left overflow-clip relative',\n          getBorderRadiusClass(isTruncatedStart, isTruncatedEnd)\n        )}\n        style={{ backgroundColor: event.backgroundColor, color: event.color }}\n      >\n        {/* Left continuation indicator */}\n        {isTruncatedStart && (\n          <div className=\"absolute left-0 top-0 bottom-0 w-0.5 bg-foreground/25\"></div>\n        )}\n\n        {/* Event title */}\n        <p\n          className={cn(\n            'text-[10px] font-semibold sm:text-xs mt-0.5',\n            // Add slight padding to avoid overlap with indicators\n            isTruncatedStart && 'pl-1',\n            isTruncatedEnd && 'pr-1'\n          )}\n        >\n          {event.title}\n        </p>\n\n        {/* Right continuation indicator */}\n        {isTruncatedEnd && (\n          <div className=\"absolute right-0 top-0 bottom-0 w-0.5 bg-foreground/25\"></div>\n        )}\n      </div>\n    )\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 === nextProps.event\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    currentLocale,\n    getEventsForDateRange,\n    currentDate,\n    firstDayOfWeek,\n    dayMaxEvents = 0,\n    t,\n  } = useCalendarContext()\n  const todayEvents = getEventsForDateRange(\n    day.startOf('day'),\n    day.endOf('day')\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 min-h-[60px]',\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',\n              isToday && 'bg-primary text-primary-foreground font-medium'\n            )}\n          >\n            {Intl.DateTimeFormat(currentLocale, { day: 'numeric' }).format(\n              day.toDate()\n            )}\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              onKeyDown={(e) => {\n                if (e.key === 'Enter' || e.key === ' ') {\n                  e.preventDefault()\n                  e.stopPropagation()\n                  showAllEvents(day, todayEvents)\n                }\n              }}\n              tabIndex={0}\n              // oxlint-disable-next-line prefer-tag-over-role\n              role=\"button\"\n            >\n              +{hiddenEventsCount} {t('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) {\n      return\n    }\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\ninterface MonthHeaderProps {\n  className?: string\n}\n\nexport const MonthHeader: React.FC<MonthHeaderProps> = ({ className }) => {\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) {\n        days.push(dayToMove)\n      }\n      if (shortDayToMove) {\n        shortDays.push(shortDayToMove)\n      }\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-20',\n        viewHeaderClassName,\n        className\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",
    "import type { WeekDays } from '@/components'\n\nexport 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\nexport const WEEK_DAYS_NUMBER_MAP: Record<WeekDays, number> = {\n  sunday: 0,\n  monday: 1,\n  tuesday: 2,\n  wednesday: 3,\n  thursday: 4,\n  friday: 5,\n  saturday: 6,\n}\n\nexport const DAY_NUMBER_TO_WEEK_DAYS: Record<number, WeekDays> = {\n  0: 'sunday',\n  1: 'monday',\n  2: 'tuesday',\n  3: 'wednesday',\n  4: 'thursday',\n  5: 'friday',\n  6: 'saturday',\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport {\n  DAY_NUMBER_HEIGHT,\n  EVENT_BAR_HEIGHT,\n  GAP_BETWEEN_ELEMENTS,\n} from '@/lib/constants'\nimport dayjs from '@/lib/dayjs-config'\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 UseProcessedWeekEventsProps {\n  days: dayjs.Dayjs[]\n}\n\nexport const useProcessedWeekEvents = ({\n  days,\n}: UseProcessedWeekEventsProps) => {\n  const { getEventsForDateRange, dayMaxEvents } = useCalendarContext()\n\n  const weekStart = days[0].startOf('day')\n  const weekEnd = days[6].endOf('day')\n\n  // Get all events that intersect with this week\n  const weekEvents = getEventsForDateRange(weekStart, weekEnd)\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) {\n      return startDiff\n    }\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: { 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 processedEvents: 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    // Detect if event is truncated at the boundaries\n    const isTruncatedStart = event.start.startOf('day').isBefore(weekStart)\n    const isTruncatedEnd = event.end.startOf('day').isAfter(weekEnd)\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      processedEvents.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        isTruncatedStart,\n        isTruncatedEnd,\n      } as ProcessedEvent)\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          processedEvents.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            isTruncatedStart: true, // Always truncated at start when using this fallback logic\n            isTruncatedEnd,\n          } as ProcessedEvent)\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    // Single-day events are not truncated by definition\n    const isTruncatedStart = false\n    const isTruncatedEnd = false\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      processedEvents.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        isTruncatedStart,\n        isTruncatedEnd,\n      } as ProcessedEvent)\n    }\n  }\n\n  return processedEvents\n}\n",
    "import { DraggableEvent } from '@/features/draggable-event/draggable-event'\nimport { useProcessedWeekEvents } from '@/hooks/useProcessedWeekEvents'\nimport { EVENT_BAR_HEIGHT } from '@/lib/constants'\nimport type dayjs from '@/lib/dayjs-config'\n\ninterface WeekEventsLayerProps {\n  days: dayjs.Dayjs[]\n}\n\nexport const WeekEventsLayer: React.FC<WeekEventsLayerProps> = ({ days }) => {\n  const weekStart = days[0]\n  const processedWeekEvents = useProcessedWeekEvents({ days })\n\n  return (\n    <div className=\"relative w-full h-full pointer-events-none z-10 overflow-clip\">\n      {processedWeekEvents.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            data-testid={`week-event-layer-event-${event.id}`}\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 flex-col h-full\" data-testid=\"week-view\">\n      {/* Week header row - fixed */}\n      <WeekHeader className=\"h-[5rem]\" />\n\n      {/* Scrollable time grid */}\n      <ScrollArea\n        className=\"flex overflow-auto h-[calc(100%-5rem)]\"\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 weekEvents = getEventsForDateRange(expandedStartDate, expandedEndDate)\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) {\n        return startDiff\n      }\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\ninterface WeekHeaderProps {\n  className?: string\n}\n\nexport const WeekHeader: React.FC<WeekHeaderProps> = ({ className }) => {\n  const {\n    currentDate,\n    currentLocale,\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-20',\n        viewHeaderClassName,\n        className\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                {Intl.DateTimeFormat(currentLocale, { day: 'numeric' }).format(\n                  day.toDate()\n                )}\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-10\"\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/components/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-10 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, currentLocale } = 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              {Intl.DateTimeFormat(currentLocale, {\n                hour: 'numeric',\n                minute: 'numeric',\n                hour12: true,\n              }).format(time.toDate())}\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-40\"\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 '@/features/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\n// For more granular time slots, we'll divide each hour into 15-minute segments\nconst timeSegments = [0, 15, 30, 45]\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\nconst DayView = () => {\n  const { currentDate } = useCalendarContext()\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 className=\"h-[3rem]\" />\n\n      {/* Time grid without scrollbar */}\n      <ScrollArea\n        data-testid=\"day-scroll-area\"\n        className=\"relative overflow-y-auto h-[calc(100%-3rem)]\"\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-10\"\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, getEventsForDateRange } = useCalendarContext()\n\n  // Get current day's events - this will refresh automatically when store updates\n  // because getEventsForDateRange is a selector function from the store that runs whenever events change\n  const dayEvents = getEventsForDateRange(\n    currentDate.startOf('day'),\n    currentDate.endOf('day')\n  )\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\ninterface DayHeaderProps {\n  className?: string\n}\n\nexport const DayHeader: React.FC<DayHeaderProps> = ({ className }) => {\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-20',\n        viewHeaderClassName,\n        className\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 { useCalendarContext } from '@/contexts/calendar-context/context'\nimport 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  const { currentLocale } = useCalendarContext()\n\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            {Intl.DateTimeFormat(currentLocale, {\n              hour: 'numeric',\n              minute: 'numeric',\n              hour12: true,\n            }).format(time.toDate())}\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'\nimport type { RRuleOptions } from '@/lib/recurrence-handler/types'\nimport { isRecurringEvent } from '@/lib/recurrence-handler'\nimport { RecurrenceEditor } from '@/features/recurrence/components/recurrence-editor/recurrence-editor'\nimport { RecurrenceEditDialog } from '@/features/recurrence/components/recurrence-edit-dialog'\nimport { useRecurringEventActions } from '@/features/recurrence/hooks/useRecurringEventActions'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\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 {\n    dialogState,\n    openEditDialog,\n    openDeleteDialog,\n    closeDialog,\n    handleConfirm,\n  } = useRecurringEventActions(onClose)\n\n  const { findParentRecurringEvent, t } = useCalendarContext()\n\n  const start = selectedEvent?.start\n  const end = selectedEvent?.end\n\n  // Find parent event if this is a recurring event instance\n  const parentEvent = selectedEvent\n    ? findParentRecurringEvent(selectedEvent)\n    : null\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    start ? start.format('HH:mm') : dayjs(defaultStartDate).format('HH:mm')\n  )\n  const [endTime, setEndTime] = useState(\n    end ? end.format('HH:mm') : 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  // Recurrence state - pull RRULE from parent if this is an instance\n  const [rrule, setRrule] = useState<RRuleOptions | null>(() => {\n    const eventRrule = selectedEvent?.rrule || parentEvent?.rrule\n    return eventRrule || null\n  })\n\n  // Create wrapper functions to fix TypeScript errors with DatePicker\n  const handleStartDateChange = (date: Date | undefined) => {\n    if (date) {\n      setStartDate(date)\n    }\n  }\n\n  const handleEndDateChange = (date: Date | undefined) => {\n    if (date) {\n      setEndDate(date)\n    }\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      rrule: rrule || undefined,\n    }\n\n    if (selectedEvent?.id) {\n      // Check if this is a recurring event\n      if (isRecurringEvent(selectedEvent)) {\n        // Show recurring event edit dialog\n        openEditDialog(selectedEvent, {\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          rrule: rrule || undefined,\n        })\n        return // Don't close the form yet, let the dialog handle it\n      }\n      onUpdate?.(eventData)\n    } else {\n      onAdd?.(eventData)\n    }\n\n    onClose()\n  }\n\n  const handleDelete = () => {\n    if (selectedEvent?.id) {\n      // Check if this is a recurring event\n      if (isRecurringEvent(selectedEvent)) {\n        // Show recurring event delete dialog\n        openDeleteDialog(selectedEvent)\n        return // Don't close the form yet, let the dialog handle it\n      }\n      onDelete?.(selectedEvent)\n      onClose()\n    }\n  }\n\n  const handleRRuleChange = (newRRule: RRuleOptions | null) => {\n    if (newRRule) {\n      // Create dtstart with the same logic as in handleSubmit\n      const [startHours, startMinutes] = startTime.split(':').map(Number)\n      let startDateTime = dayjs(startDate).hour(startHours).minute(startMinutes)\n\n      if (isAllDay) {\n        startDateTime = startDateTime.hour(0).minute(0)\n      }\n\n      // Ensure dtstart is always included in RRuleOptions as a Date object\n      const completeRrule: RRuleOptions = {\n        ...newRRule,\n        dtstart: startDateTime.toDate(), // Convert dayjs to Date\n      }\n      setRrule(completeRrule)\n    } else {\n      setRrule(null)\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    <>\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 ? t('editEvent') : t('createEvent')}\n              </DialogTitle>\n              <DialogDescription className=\"text-xs sm:text-sm\">\n                {selectedEvent?.id ? t('editEventDetails') : t('addNewEvent')}\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                  {t('title')}\n                </Label>\n                <Input\n                  id=\"title\"\n                  name=\"title\"\n                  value={formValues.title}\n                  onChange={handleInputChange}\n                  placeholder={t('eventTitlePlaceholder')}\n                  required\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                  {t('description')}\n                </Label>\n                <Input\n                  id=\"description\"\n                  name=\"description\"\n                  value={formValues.description}\n                  onChange={handleInputChange}\n                  placeholder={t('eventDescriptionPlaceholder')}\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                  {t('allDay')}\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\">{t('startDate')}</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\">{t('endDate')}</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                      {t('startTime')}\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                      {t('endTime')}\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\">{t('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                  {t('location')}\n                </Label>\n                <Input\n                  id=\"location\"\n                  name=\"location\"\n                  value={formValues.location}\n                  onChange={handleInputChange}\n                  placeholder={t('eventLocationPlaceholder')}\n                  className=\"h-8 text-sm sm:h-9\"\n                />\n              </div>\n\n              {/* Recurrence Section */}\n              <RecurrenceEditor value={rrule} onChange={handleRRuleChange} />\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                  {t('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                  {t('cancel')}\n                </Button>\n                <Button type=\"submit\" className=\"flex-1 sm:flex-none\" size=\"sm\">\n                  {selectedEvent?.id ? t('update') : t('create')}\n                </Button>\n              </div>\n            </DialogFooter>\n          </form>\n        </DialogContent>\n      </Dialog>\n\n      {/* Recurring Event Edit Dialog */}\n      <RecurrenceEditDialog\n        isOpen={dialogState.isOpen}\n        onClose={closeDialog}\n        onConfirm={handleConfirm}\n        operationType={dialogState.operationType}\n        eventTitle={dialogState.event?.title || ''}\n      />\n    </>\n  )\n}\n",
    "import type { CalendarEvent } from '@/components'\nimport dayjs from '@/lib/dayjs-config'\nimport { RRule } from 'rrule'\nimport { omitKeys, safeDate } from '../utils'\nimport type { RRuleOptions } from './types'\n\nexport const isRecurringEvent = (event: CalendarEvent): boolean => {\n  return Boolean(event.rrule || event.recurrenceId || event.uid)\n}\n\ninterface GenerateRecurringEventsProps {\n  event: CalendarEvent\n  currentEvents: CalendarEvent[]\n  startDate: dayjs.Dayjs\n  endDate: dayjs.Dayjs\n}\n\nexport const generateRecurringEvents = ({\n  event,\n  currentEvents,\n  startDate,\n  endDate,\n}: GenerateRecurringEventsProps): CalendarEvent[] => {\n  // If not a recurring event, return empty array\n  if (!event.rrule) {\n    return []\n  }\n\n  try {\n    // Create rule from RRuleOptions ensuring dtstart is always provided\n    // If dtstart is missing from the RRULE, use the event's start time as fallback\n    const ruleOptions: RRuleOptions = {\n      ...event.rrule,\n      dtstart: event.rrule.dtstart || event.start.toDate(),\n    }\n    const rule = new RRule(ruleOptions)\n\n    const overrides = currentEvents.filter(\n      (e) => e.recurrenceId && e.uid === event.uid\n    )\n\n    // Calculate event duration to expand search window for events that span the range\n    const eventDuration = event.end.diff(event.start)\n\n    // Expand search window backward by event duration to catch events that start before\n    // the range but span into it\n    const expandedStartDateTime = startDate\n      .subtract(eventDuration, 'millisecond')\n      .toDate()\n    const endDateTime = endDate.toDate()\n\n    // Get all occurrences in the expanded range\n    const occurrences = rule.between(expandedStartDateTime, endDateTime, true)\n\n    // Convert occurrences to CalendarEvent instances\n    const recurringEvents: CalendarEvent[] = occurrences\n      .map((occurrence, index) => {\n        const occurrenceDate = dayjs(occurrence)\n        const existingOverride = overrides.find((e) =>\n          safeDate(e.recurrenceId).isSame(occurrenceDate)\n        )\n\n        // If there's an override, use it\n        if (existingOverride) {\n          return { ...event, ...existingOverride }\n        }\n\n        // Calculate the duration from the original event\n        const originalDuration = event.end.diff(event.start)\n        const newEndTime = occurrenceDate.add(originalDuration, 'millisecond')\n        const recurringEventId = `${event.id}_${index}`\n        const parentUID = event.uid || `${event.id}@ilamy.calendar`\n\n        // Create the recurring event instance\n        const recurringEvent: CalendarEvent = {\n          ...event,\n          id: recurringEventId,\n          start: occurrenceDate,\n          end: newEndTime,\n          uid: parentUID, // Same UID as parent for proper grouping\n          rrule: undefined, // Instance events don't have RRULE\n        }\n\n        return recurringEvent\n      })\n      .filter((recurringEvent) => {\n        // Filter out EXDATE exclusions\n        const hasExdates = event.exdates && event.exdates.length > 0\n        if (hasExdates) {\n          const eventStartISO = recurringEvent.start.toISOString()\n          const isExcluded = event.exdates.includes(eventStartISO)\n          if (isExcluded) {\n            return false\n          }\n        }\n\n        // Filter to only include events that span through the original requested date range\n        // An event spans the range if: event_start < range_end AND event_end > range_start\n        // Use isSameOrBefore/isSameOrAfter to include boundary cases\n        const eventSpansRange =\n          recurringEvent.start.isSameOrBefore(endDate) &&\n          recurringEvent.end.isSameOrAfter(startDate)\n\n        return eventSpansRange\n      })\n\n    return recurringEvents\n  } catch (error) {\n    // Handle invalid RRULE options\n    throw new Error(\n      `Invalid RRULE options: ${JSON.stringify(event.rrule)}. Error: ${error instanceof Error ? error.message : 'Unknown error'}`\n    )\n  }\n}\n\ninterface UpdateRecurringEventProps {\n  targetEvent: CalendarEvent\n  updates: Partial<CalendarEvent>\n  currentEvents: CalendarEvent[]\n  scope: 'this' | 'following' | 'all'\n}\n\nexport const updateRecurringEvent = ({\n  targetEvent,\n  updates,\n  currentEvents,\n  scope,\n}: UpdateRecurringEventProps): CalendarEvent[] => {\n  const updatedEvents = [...currentEvents]\n\n  // Find the base recurring event\n  const baseEventIndex = updatedEvents.findIndex((e) => {\n    const parentUid = e.uid || `${e.id}@ilamy.calendar`\n    return parentUid === targetEvent.uid && e.rrule && !e.recurrenceId\n  })\n\n  if (baseEventIndex === -1) {\n    throw new Error('Base recurring event not found')\n  }\n\n  const baseEvent = updatedEvents[baseEventIndex]\n\n  switch (scope) {\n    case 'this': {\n      // \"This event only\" - Add EXDATE to base event and create standalone modified event\n      const targetEventStartISO = targetEvent.start.toISOString()\n      const existingExdates = baseEvent.exdates || []\n      const updatedExdates = [...existingExdates, targetEventStartISO]\n\n      const updatedBaseEvent = {\n        ...baseEvent,\n        exdates: updatedExdates,\n      }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n\n      // Create standalone modified event with recurrenceId\n      const modifiedEventId = `${targetEvent.id}_modified_${Date.now()}`\n      const modifiedEvent: CalendarEvent = {\n        // @ts-expect-error TODO: fix the types\n        ...omitKeys(targetEvent, ['width', 'height', 'top', 'left', 'right']),\n        ...updates,\n        id: modifiedEventId,\n        recurrenceId: targetEventStartISO, // This marks it as a modified instance\n        uid: baseEvent.uid || `${baseEvent.id}@ilamy.calendar`, // Keep same UID as base event (iCalendar standard)\n        rrule: undefined, // Standalone events don't have RRULE\n      } as CalendarEvent\n      updatedEvents.push(modifiedEvent)\n      break\n    }\n\n    case 'following': {\n      // \"This and following\" - Terminate original series and create new series\n\n      // Calculate the termination date: day before target with end of day time\n      // This ensures the last occurrence before target is included in the terminated series\n      const dayBeforeTarget = targetEvent.start.subtract(1, 'day')\n      const terminationDate = dayBeforeTarget.endOf('day').toDate()\n\n      // Update original series with UNTIL to end before target date\n      const terminatedEvent = {\n        ...baseEvent,\n        rrule: {\n          ...baseEvent.rrule,\n          until: terminationDate,\n        },\n      }\n      updatedEvents[baseEventIndex] = terminatedEvent\n\n      // Create new series starting from target date\n      const originalDuration = baseEvent.end.diff(baseEvent.start)\n      const newSeriesStartTime = updates.start || targetEvent.start\n      const newSeriesEndTime =\n        updates.end || newSeriesStartTime.add(originalDuration)\n      const newSeriesId = `${baseEvent.id}_following`\n      const newSeriesUID = `${newSeriesId}@ilamy.calendar`\n\n      const newSeriesEvent: CalendarEvent = {\n        ...baseEvent,\n        ...updates,\n        rrule: {\n          ...baseEvent.rrule,\n          ...updates.rrule,\n          dtstart: newSeriesStartTime.toDate(),\n        },\n        id: newSeriesId,\n        uid: newSeriesUID, // New UID for new series\n        start: newSeriesStartTime,\n        end: newSeriesEndTime,\n        recurrenceId: undefined, // This is a new base event, not an instance\n      }\n      updatedEvents.push(newSeriesEvent)\n      break\n    }\n\n    case 'all': {\n      // \"All events\" - Update the base recurring event\n      const updatedBaseEvent = {\n        ...baseEvent,\n        ...updates,\n      }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n      break\n    }\n\n    default:\n      throw new Error(\n        `Invalid scope: ${scope}. Must be 'this', 'following', or 'all'`\n      )\n  }\n\n  return updatedEvents\n}\n\ninterface DeleteRecurringEventProps {\n  targetEvent: CalendarEvent\n  currentEvents: CalendarEvent[]\n  scope: 'this' | 'following' | 'all'\n}\n\nexport const deleteRecurringEvent = ({\n  targetEvent,\n  currentEvents,\n  scope,\n}: DeleteRecurringEventProps): CalendarEvent[] => {\n  const updatedEvents = [...currentEvents]\n\n  // Find the base recurring event\n  const baseEventIndex = updatedEvents.findIndex((e) => {\n    const parentUid = e.uid || `${e.id}@ilamy.calendar`\n    return parentUid === targetEvent.uid && e.rrule && !e.recurrenceId\n  })\n\n  if (baseEventIndex === -1) {\n    throw new Error('Base recurring event not found')\n  }\n\n  const baseEvent = updatedEvents[baseEventIndex]\n\n  switch (scope) {\n    case 'this': {\n      // \"This event only\" - Add EXDATE to exclude this occurrence\n      const targetEventStartISO = targetEvent.start.toISOString()\n      const existingExdates = baseEvent.exdates || []\n      const updatedExdates = [...existingExdates, targetEventStartISO]\n\n      const updatedBaseEvent = { ...baseEvent, exdates: updatedExdates }\n      updatedEvents[baseEventIndex] = updatedBaseEvent\n      break\n    }\n\n    case 'following': {\n      // \"This and following\" - Terminate series with UNTIL before target date\n\n      // Calculate the termination date: day before target with end of day time\n      // This ensures the last occurrence before target is included in the terminated series\n      const dayBeforeTarget = targetEvent.start.subtract(1, 'day')\n      const terminationDate = dayBeforeTarget.endOf('day').toDate()\n\n      const terminatedEvent = {\n        ...baseEvent,\n        rrule: {\n          ...baseEvent.rrule,\n          until: terminationDate,\n        },\n      }\n      updatedEvents[baseEventIndex] = terminatedEvent\n      break\n    }\n\n    case 'all': {\n      // \"All events\" - Remove the entire recurring series\n      const eventsWithoutTargetSeries = updatedEvents.filter(\n        (e) => e.uid !== targetEvent.uid\n      )\n      return eventsWithoutTargetSeries\n    }\n\n    default:\n      throw new Error(\n        `Invalid scope: ${scope}. Must be 'this', 'following', or 'all'`\n      )\n  }\n\n  return updatedEvents\n}\n",
    "import {\n  Card,\n  CardContent,\n  CardHeader,\n  CardTitle,\n  Checkbox,\n  DatePicker,\n  Input,\n  Label,\n  Select,\n  SelectContent,\n  SelectItem,\n  SelectTrigger,\n  SelectValue,\n} from '@/components/ui'\nimport dayjs from '@/lib/dayjs-config'\nimport type { RRuleOptions } from '@/lib/recurrence-handler/types'\nimport { useState, useEffect, useMemo } from 'react'\nimport { RRule } from 'rrule'\nimport type { Weekday } from 'rrule'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\n\n// Natural language description function using RRule's built-in helper methods\nfunction getRRuleDescription(\n  rruleOptions: RRuleOptions | null,\n  t: (key: string) => string\n): string {\n  if (!rruleOptions) {\n    return t('customRecurrence')\n  }\n\n  try {\n    // Create RRule instance directly from options\n    const rule = new RRule(rruleOptions)\n\n    // Use RRule's built-in natural language conversion with toText()\n    const naturalText = rule.toText()\n\n    // Handle cases where RRule can't convert to natural language\n    if (\n      !naturalText ||\n      naturalText.includes('RRule error') ||\n      naturalText.includes('Unable to fully convert') ||\n      naturalText.toLowerCase().includes('error')\n    ) {\n      return t('customRecurrence')\n    }\n\n    // Capitalize first letter for consistent formatting\n    return naturalText.charAt(0).toUpperCase() + naturalText.slice(1)\n  } catch {\n    // If parsing fails, return fallback\n    return t('customRecurrence')\n  }\n}\n\ninterface RecurrenceEditorProps {\n  value?: RRuleOptions | null\n  onChange: (rruleOptions: RRuleOptions | null) => void\n}\n\nexport const RecurrenceEditor: React.FC<RecurrenceEditorProps> = ({\n  value,\n  onChange,\n}) => {\n  const { t } = useCalendarContext()\n  const [showRecurrence, setShowRecurrence] = useState(!!value)\n\n  // Create WEEK_DAYS array with translations\n  const WEEK_DAYS = useMemo(\n    () => [\n      { value: RRule.SU, label: t('sunday'), short: t('sun') },\n      { value: RRule.MO, label: t('monday'), short: t('mon') },\n      { value: RRule.TU, label: t('tuesday'), short: t('tue') },\n      { value: RRule.WE, label: t('wednesday'), short: t('wed') },\n      { value: RRule.TH, label: t('thursday'), short: t('thu') },\n      { value: RRule.FR, label: t('friday'), short: t('fri') },\n      { value: RRule.SA, label: t('saturday'), short: t('sat') },\n    ],\n    [t]\n  )\n\n  // Helper function to convert RRule frequency to string\n  const getFrequencyString = (freq: RRuleOptions['freq']): string => {\n    const freqMap: Record<number, string> = {\n      [RRule.DAILY]: 'DAILY',\n      [RRule.WEEKLY]: 'WEEKLY',\n      [RRule.MONTHLY]: 'MONTHLY',\n      [RRule.YEARLY]: 'YEARLY',\n    }\n    return freqMap[freq] || 'DAILY'\n  }\n\n  // Work with complete RRuleOptions - dtstart comes from parent EventForm\n  const [rruleOptions, setRRuleOptions] = useState<RRuleOptions | null>(\n    () => value || null\n  )\n\n  // Sync state when value prop changes\n  useEffect(() => {\n    setShowRecurrence(!!value)\n    if (value) {\n      setRRuleOptions(value)\n    }\n  }, [value])\n\n  const updateRRule = (updates: Partial<RRuleOptions>) => {\n    if (!rruleOptions) {\n      return // Can't update if no base options exist\n    }\n\n    const newOptions: RRuleOptions = { ...rruleOptions, ...updates }\n    setRRuleOptions(newOptions)\n\n    if (showRecurrence) {\n      onChange(newOptions)\n    } else {\n      onChange(null)\n    }\n  }\n\n  const handleRecurrenceToggle = (checked: boolean) => {\n    setShowRecurrence(checked)\n    if (checked) {\n      if (rruleOptions) {\n        onChange(rruleOptions)\n      } else {\n        // Create default RRule when toggling on for the first time\n        // Note: dtstart will be set by the parent EventForm\n        const defaultRRule: Partial<RRuleOptions> = {\n          freq: RRule.DAILY,\n          interval: 1,\n        }\n        setRRuleOptions(defaultRRule as RRuleOptions)\n        onChange(defaultRRule as RRuleOptions)\n      }\n    } else {\n      onChange(null)\n    }\n  }\n\n  const handleFrequencyChange = (frequency: string) => {\n    // Convert string to RRule frequency constant\n    const freqMap: Record<string, RRuleOptions['freq']> = {\n      DAILY: RRule.DAILY,\n      WEEKLY: RRule.WEEKLY,\n      MONTHLY: RRule.MONTHLY,\n      YEARLY: RRule.YEARLY,\n    }\n    updateRRule({ freq: freqMap[frequency] || RRule.DAILY })\n  }\n\n  const handleIntervalChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const interval = Math.max(1, Number.parseInt(e.target.value) || 1)\n    updateRRule({ interval })\n  }\n\n  const handleEndTypeChange = (endType: 'never' | 'count' | 'until') => {\n    const updates: Partial<RRuleOptions> = {}\n\n    if (endType === 'never') {\n      // Remove count and until\n      updates.count = undefined\n      updates.until = undefined\n    } else if (endType === 'count') {\n      // Set default count if none exists, remove until\n      updates.count = rruleOptions?.count || 1\n      updates.until = undefined\n    } else if (endType === 'until') {\n      // Set default until date if none exists, remove count\n      updates.until =\n        rruleOptions?.until || dayjs().add(1, 'month').endOf('day').toDate()\n      updates.count = undefined\n    }\n\n    updateRRule(updates)\n  }\n\n  const handleCountChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const count = Math.max(1, Number.parseInt(e.target.value) || 1)\n    updateRRule({ count })\n  }\n\n  const handleEndDateChange = (date: Date | undefined) => {\n    const until = date ? dayjs(date).endOf('day').toDate() : undefined\n    updateRRule({ until })\n  }\n\n  const handleDayToggle = (dayIndex: number) => {\n    const weekdayMap = [\n      RRule.SU,\n      RRule.MO,\n      RRule.TU,\n      RRule.WE,\n      RRule.TH,\n      RRule.FR,\n      RRule.SA,\n    ]\n    const currentWeekdays = (rruleOptions?.byweekday as Weekday[]) || []\n    const targetWeekday = weekdayMap[dayIndex]\n\n    const isSelected = currentWeekdays.includes(targetWeekday)\n    let newWeekdays: Weekday[]\n\n    if (isSelected) {\n      newWeekdays = currentWeekdays.filter((day) => day !== targetWeekday)\n    } else {\n      newWeekdays = [...currentWeekdays, targetWeekday]\n    }\n\n    updateRRule({\n      byweekday: newWeekdays.length > 0 ? newWeekdays : undefined,\n    })\n  }\n\n  // Helper to determine end type from current options\n  const getEndType = (): 'never' | 'count' | 'until' => {\n    if (rruleOptions?.until) {\n      return 'until'\n    }\n    if (rruleOptions?.count) {\n      return 'count'\n    }\n    return 'never'\n  }\n\n  return (\n    <Card data-testid=\"recurrence-editor\">\n      <CardHeader className=\"pb-3\">\n        <div className=\"flex items-center space-x-2\">\n          <Checkbox\n            id=\"recurring\"\n            checked={showRecurrence}\n            onCheckedChange={handleRecurrenceToggle}\n            data-testid=\"toggle-recurrence\"\n          />\n          <CardTitle className=\"text-sm\">{t('repeat')}</CardTitle>\n        </div>\n        {showRecurrence && value && (\n          <p className=\"text-xs text-muted-foreground\">\n            {getRRuleDescription(value, t)}\n          </p>\n        )}\n      </CardHeader>\n\n      {showRecurrence && (\n        <CardContent className=\"pt-0\">\n          <div className=\"space-y-4\">\n            {/* Frequency Selection */}\n            <div className=\"grid grid-cols-2 gap-4\">\n              <div>\n                <Label htmlFor=\"frequency\" className=\"text-xs\">\n                  {t('repeats')}\n                </Label>\n                <Select\n                  value={getFrequencyString(rruleOptions?.freq ?? RRule.DAILY)}\n                  onValueChange={handleFrequencyChange}\n                >\n                  <SelectTrigger\n                    id=\"frequency\"\n                    className=\"h-8\"\n                    data-testid=\"frequency-select\"\n                  >\n                    <SelectValue />\n                  </SelectTrigger>\n                  <SelectContent>\n                    <SelectItem value=\"DAILY\">{t('daily')}</SelectItem>\n                    <SelectItem value=\"WEEKLY\">{t('weekly')}</SelectItem>\n                    <SelectItem value=\"MONTHLY\">{t('monthly')}</SelectItem>\n                    <SelectItem value=\"YEARLY\">{t('yearly')}</SelectItem>\n                  </SelectContent>\n                </Select>\n              </div>\n\n              <div>\n                <Label htmlFor=\"interval\" className=\"text-xs\">\n                  {t('every')}\n                </Label>\n                <Input\n                  id=\"interval\"\n                  type=\"number\"\n                  min=\"1\"\n                  value={rruleOptions?.interval || 1}\n                  onChange={handleIntervalChange}\n                  className=\"h-8\"\n                />\n              </div>\n            </div>\n\n            {/* Weekly Day Selection */}\n            {rruleOptions?.freq === RRule.WEEKLY && (\n              <div>\n                <Label className=\"text-xs\">{t('repeatOn')}</Label>\n                <div className=\"flex flex-wrap gap-1 mt-1\">\n                  {WEEK_DAYS.map((day, index) => {\n                    const byweekdayArray = Array.isArray(\n                      rruleOptions?.byweekday\n                    )\n                      ? rruleOptions.byweekday\n                      : rruleOptions?.byweekday\n                        ? [rruleOptions.byweekday]\n                        : []\n                    const isSelected = byweekdayArray.includes(day.value)\n                    return (\n                      <div\n                        key={`day-${index}`}\n                        className=\"flex items-center space-x-1\"\n                      >\n                        <Checkbox\n                          id={`day-${index}`}\n                          checked={isSelected}\n                          onCheckedChange={() => handleDayToggle(index)}\n                        />\n                        <Label\n                          htmlFor={`day-${index}`}\n                          className=\"text-xs cursor-pointer\"\n                        >\n                          {day.short}\n                        </Label>\n                      </div>\n                    )\n                  })}\n                </div>\n              </div>\n            )}\n\n            {/* End Condition */}\n            <div>\n              <Label className=\"text-xs\">{t('ends')}</Label>\n              <div className=\"space-y-2 mt-1\">\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"never\"\n                    checked={getEndType() === 'never'}\n                    onCheckedChange={() => handleEndTypeChange('never')}\n                  />\n                  <Label htmlFor=\"never\" className=\"text-xs\">\n                    {t('never')}\n                  </Label>\n                </div>\n\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"after\"\n                    checked={getEndType() === 'count'}\n                    onCheckedChange={() => handleEndTypeChange('count')}\n                  />\n                  <Label htmlFor=\"after\" className=\"text-xs\">\n                    {t('after')}\n                  </Label>\n                  {getEndType() === 'count' && (\n                    <Input\n                      type=\"number\"\n                      min=\"1\"\n                      value={rruleOptions?.count || 1}\n                      onChange={handleCountChange}\n                      className=\"h-6 w-16 text-xs\"\n                      data-testid=\"count-input\"\n                    />\n                  )}\n                  <span className=\"text-xs\">{t('occurrences')}</span>\n                </div>\n\n                <div className=\"flex items-center space-x-2\">\n                  <Checkbox\n                    id=\"on\"\n                    checked={getEndType() === 'until'}\n                    onCheckedChange={() => handleEndTypeChange('until')}\n                  />\n                  <Label htmlFor=\"on\" className=\"text-xs\">\n                    {t('on')}\n                  </Label>\n                  {getEndType() === 'until' && (\n                    <DatePicker\n                      date={rruleOptions?.until}\n                      setDate={handleEndDateChange}\n                      className=\"h-6\"\n                    />\n                  )}\n                </div>\n              </div>\n            </div>\n          </div>\n        </CardContent>\n      )}\n    </Card>\n  )\n}\n",
    "import {\n  Dialog,\n  DialogContent,\n  DialogDescription,\n  DialogFooter,\n  DialogHeader,\n  DialogTitle,\n  Button,\n} from '@/components/ui'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\n\ninterface RecurrenceEditDialogProps {\n  isOpen: boolean\n  onClose: () => void\n  onConfirm: (scope: RecurrenceEditScope) => void\n  operationType: 'edit' | 'delete'\n  eventTitle: string\n}\n\nexport function RecurrenceEditDialog({\n  isOpen,\n  onClose,\n  onConfirm,\n  operationType,\n  eventTitle,\n}: RecurrenceEditDialogProps) {\n  const { t } = useCalendarContext()\n\n  const handleScopeSelect = (scope: RecurrenceEditScope) => {\n    onConfirm(scope)\n    onClose()\n  }\n\n  const isEdit = operationType === 'edit'\n\n  return (\n    <Dialog open={isOpen} onOpenChange={onClose}>\n      <DialogContent className=\"max-w-md\">\n        <DialogHeader>\n          <DialogTitle>\n            {isEdit ? t('editRecurringEvent') : t('deleteRecurringEvent')}\n          </DialogTitle>\n          <DialogDescription>\n            \"{eventTitle}\"{' '}\n            {isEdit\n              ? t('editRecurringEventQuestion')\n              : t('deleteRecurringEventQuestion')}\n          </DialogDescription>\n        </DialogHeader>\n\n        <div className=\"space-y-3\">\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('this')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">{t('thisEvent')}</div>\n              <div className=\"text-sm text-muted-foreground\">\n                {isEdit ? t('onlyChangeThis') : t('onlyDeleteThis')}\n              </div>\n            </div>\n          </Button>\n\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('following')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">{t('thisAndFollowingEvents')}</div>\n              <div className=\"text-sm text-muted-foreground\">\n                {isEdit ? t('changeThisAndFuture') : t('deleteThisAndFuture')}\n              </div>\n            </div>\n          </Button>\n\n          <Button\n            variant=\"outline\"\n            className=\"w-full justify-start h-auto p-4\"\n            onClick={() => handleScopeSelect('all')}\n          >\n            <div className=\"text-left\">\n              <div className=\"font-medium\">{t('allEvents')}</div>\n              <div className=\"text-sm text-muted-foreground\">\n                {isEdit ? t('changeEntireSeries') : t('deleteEntireSeries')}\n              </div>\n            </div>\n          </Button>\n        </div>\n\n        <DialogFooter>\n          <Button variant=\"outline\" onClick={onClose}>\n            {t('cancel')}\n          </Button>\n        </DialogFooter>\n      </DialogContent>\n    </Dialog>\n  )\n}\n",
    "import { useState, useCallback } from 'react'\nimport type { CalendarEvent } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\n\nexport function useRecurringEventActions(onComplete?: () => void) {\n  const { updateRecurringEvent, deleteRecurringEvent } = useCalendarContext()\n\n  const [dialogState, setDialogState] = useState<{\n    isOpen: boolean\n    operationType: 'edit' | 'delete'\n    event: CalendarEvent | null\n    updates?: Partial<CalendarEvent>\n    onConfirm?: (scope: RecurrenceEditScope) => void\n  }>({\n    isOpen: false,\n    operationType: 'edit',\n    event: null,\n  })\n\n  const openEditDialog = useCallback(\n    (event: CalendarEvent, updates: Partial<CalendarEvent>) => {\n      setDialogState({\n        isOpen: true,\n        operationType: 'edit',\n        event,\n        updates,\n        onConfirm: (scope: RecurrenceEditScope) => {\n          updateRecurringEvent(event, updates, {\n            scope,\n            eventDate: event.start,\n          })\n        },\n      })\n    },\n    [updateRecurringEvent]\n  )\n\n  const openDeleteDialog = useCallback(\n    (event: CalendarEvent) => {\n      setDialogState({\n        isOpen: true,\n        operationType: 'delete',\n        event,\n        onConfirm: (scope: RecurrenceEditScope) => {\n          deleteRecurringEvent(event, {\n            scope,\n            eventDate: event.start,\n          })\n        },\n      })\n    },\n    [deleteRecurringEvent]\n  )\n\n  const closeDialog = useCallback(() => {\n    setDialogState({\n      isOpen: false,\n      operationType: 'edit',\n      event: null,\n    })\n  }, [])\n\n  const handleConfirm = useCallback(\n    (scope: RecurrenceEditScope) => {\n      if (dialogState.onConfirm) {\n        dialogState.onConfirm(scope)\n      }\n      closeDialog()\n      // Call onComplete to close the parent form\n      onComplete?.()\n    },\n    [dialogState, closeDialog, onComplete]\n  )\n\n  return {\n    dialogState,\n    openEditDialog,\n    openDeleteDialog,\n    closeDialog,\n    handleConfirm,\n  }\n}\n",
    "import type { CalendarEvent } from '@/components/types'\nimport dayjs from '@/lib/dayjs-config'\nimport { RRule } from 'rrule'\n\n/**\n * Export calendar events to iCalendar (.ical) format\n * Fully RFC 5545 compliant iCalendar generation\n */\n\n/**\n * Escape special characters in iCalendar text fields\n */\nconst escapeICalText = (text: string): string => {\n  return text\n    .replaceAll('\\\\', '\\\\\\\\') // Escape backslashes\n    .replaceAll(';', '\\\\;') // Escape semicolons\n    .replaceAll(',', '\\\\,') // Escape commas\n    .replaceAll('\\n', '\\\\n') // Escape newlines\n    .replaceAll('\\r', '') // Remove carriage returns\n}\n\n/**\n * Format date for iCalendar format (YYYYMMDDTHHMMSSZ for UTC)\n */\nconst formatICalDate = (date: dayjs.Dayjs, allDay = false): string => {\n  if (allDay) {\n    return date.format('YYYYMMDD')\n  }\n  return date.utc().format('YYYYMMDD[T]HHmmss[Z]')\n}\n\n/**\n * Generate a unique UID for an event if not already present\n */\nconst generateUID = (event: CalendarEvent): string => {\n  if (event.uid) {\n    return event.uid\n  }\n  return `${event.id}@ilamy.calendar`\n}\n\n/**\n * Convert RRuleOptions to iCalendar RRULE string\n */\nconst formatRRule = (rruleOptions: unknown): string => {\n  try {\n    // Create RRule instance with appropriate type casting\n    const rule = new RRule(\n      rruleOptions as ConstructorParameters<typeof RRule>[0]\n    )\n    const rruleString = rule.toString()\n    // Extract just the RRULE part (remove DTSTART if present)\n    const rrulePart = rruleString\n      .split('\\n')\n      .find((line) => line.startsWith('RRULE:'))\n    return rrulePart || ''\n  } catch {\n    return ''\n  }\n}\n\n/**\n * Convert a single CalendarEvent to iCalendar VEVENT string\n */\nconst eventToICalEvent = (event: CalendarEvent): string => {\n  const lines: string[] = []\n\n  lines.push('BEGIN:VEVENT')\n\n  // UID (required)\n  lines.push(`UID:${generateUID(event)}`)\n\n  // DTSTART (required)\n  const dtstart = formatICalDate(event.start, event.allDay)\n  if (event.allDay) {\n    lines.push(`DTSTART;VALUE=DATE:${dtstart}`)\n  } else {\n    lines.push(`DTSTART:${dtstart}`)\n  }\n\n  // DTEND (required for events with duration)\n  const dtend = formatICalDate(event.end, event.allDay)\n  if (event.allDay) {\n    lines.push(`DTEND;VALUE=DATE:${dtend}`)\n  } else {\n    lines.push(`DTEND:${dtend}`)\n  }\n\n  // SUMMARY (title)\n  lines.push(`SUMMARY:${escapeICalText(event.title)}`)\n\n  // DESCRIPTION (optional)\n  if (event.description) {\n    lines.push(`DESCRIPTION:${escapeICalText(event.description)}`)\n  }\n\n  // LOCATION (optional)\n  if (event.location) {\n    lines.push(`LOCATION:${escapeICalText(event.location)}`)\n  }\n\n  // RRULE (recurrence rule)\n  if (event.rrule) {\n    const rruleString = formatRRule(event.rrule)\n    if (rruleString) {\n      lines.push(rruleString)\n    }\n  }\n\n  // EXDATE (exception dates)\n  if (event.exdates && event.exdates.length > 0) {\n    const exdates = event.exdates\n      .map((dateStr) => formatICalDate(dayjs(dateStr), event.allDay))\n      .join(',')\n    lines.push(`EXDATE:${exdates}`)\n  }\n\n  // RECURRENCE-ID (for modified instances)\n  if (event.recurrenceId) {\n    const recurrenceId = formatICalDate(dayjs(event.recurrenceId), event.allDay)\n    lines.push(`RECURRENCE-ID:${recurrenceId}`)\n  }\n\n  // DTSTAMP (required - when this was created/modified)\n  const now = dayjs().utc().format('YYYYMMDD[T]HHmmss[Z]')\n  lines.push(`DTSTAMP:${now}`)\n\n  // CREATED (when event was created)\n  lines.push(`CREATED:${now}`)\n\n  // LAST-MODIFIED (when event was last modified)\n  lines.push(`LAST-MODIFIED:${now}`)\n\n  // STATUS (default to CONFIRMED)\n  lines.push('STATUS:CONFIRMED')\n\n  // SEQUENCE (version number, default to 0)\n  lines.push('SEQUENCE:0')\n\n  // TRANSP (transparency - OPAQUE for busy time)\n  lines.push('TRANSP:OPAQUE')\n\n  lines.push('END:VEVENT')\n\n  return lines.join('\\r\\n')\n}\n\n/**\n * Filter events for proper iCalendar export\n * - Include base recurring events (with RRULE)\n * - Include modified instances (with recurrenceId)\n * - Include non-recurring events\n * - EXCLUDE generated recurring instances (no rrule, no recurrenceId)\n */\nconst filterEventsForExport = (events: CalendarEvent[]): CalendarEvent[] => {\n  const exportEvents: CalendarEvent[] = []\n  const processedUIDs = new Set<string>()\n\n  for (const event of events) {\n    // Get or generate UID for the event\n    const eventUID = event.uid || `${event.id}@ilamy.calendar`\n\n    // Case 1: Base recurring event (has RRULE, no recurrenceId)\n    if (event.rrule && !event.recurrenceId) {\n      exportEvents.push(event)\n      processedUIDs.add(eventUID)\n      continue\n    }\n\n    // Case 2: Modified recurring instance (has recurrenceId, no RRULE)\n    if (event.recurrenceId && !event.rrule) {\n      exportEvents.push(event)\n      continue\n    }\n\n    // Case 3: Non-recurring event (no RRULE, no recurrenceId, no UID pattern)\n    if (!event.rrule && !event.recurrenceId) {\n      // Check if this is a generated instance by UID pattern\n      const isGeneratedInstance = processedUIDs.has(eventUID)\n\n      if (!isGeneratedInstance) {\n        exportEvents.push(event)\n      }\n      // Skip generated instances - they'll be recreated by RRULE\n    }\n  }\n\n  return exportEvents\n}\n\n/**\n * Export events to iCalendar format\n */\nexport const exportToICalendar = (\n  events: CalendarEvent[],\n  calendarName = 'ilamy Calendar'\n): string => {\n  const lines: string[] = []\n\n  // Calendar header\n  lines.push('BEGIN:VCALENDAR')\n  lines.push('VERSION:2.0')\n  lines.push('PRODID:-//ilamy//ilamy Calendar//EN')\n  lines.push('CALSCALE:GREGORIAN')\n  lines.push('METHOD:PUBLISH')\n  lines.push(`X-WR-CALNAME:${escapeICalText(calendarName)}`)\n  lines.push(`X-WR-CALDESC:${escapeICalText(`Exported from ${calendarName}`)}`)\n\n  // Add timezone information (UTC)\n  lines.push('BEGIN:VTIMEZONE')\n  lines.push('TZID:UTC')\n  lines.push('BEGIN:STANDARD')\n  lines.push('DTSTART:19700101T000000')\n  lines.push('TZNAME:UTC')\n  lines.push('TZOFFSETFROM:+0000')\n  lines.push('TZOFFSETTO:+0000')\n  lines.push('END:STANDARD')\n  lines.push('END:VTIMEZONE')\n\n  // Filter events for proper iCalendar export\n  const filteredEvents = filterEventsForExport(events)\n\n  // Add each filtered event\n  filteredEvents.forEach((event) => {\n    lines.push(eventToICalEvent(event))\n  })\n\n  // Calendar footer\n  lines.push('END:VCALENDAR')\n\n  return lines.join('\\r\\n')\n}\n\n/**\n * Download iCalendar file to user's device\n */\nexport const downloadICalendar = (\n  events: CalendarEvent[],\n  filename = 'calendar.ics',\n  calendarName = 'ilamy Calendar'\n): void => {\n  const icalContent = exportToICalendar(events, calendarName)\n\n  // Create blob and download\n  const blob = new Blob([icalContent], {\n    type: 'text/calendar;charset=utf-8',\n  })\n\n  const url = URL.createObjectURL(blob)\n  const link = document.createElement('a')\n  link.href = url\n  link.download = filename.endsWith('.ics') ? filename : `${filename}.ics`\n\n  // Trigger download\n  document.body.append(link)\n  link.click()\n  document.body.removeChild(link)\n\n  // Clean up\n  URL.revokeObjectURL(url)\n}\n",
    "import {\n  Button,\n  Popover,\n  PopoverContent,\n  PopoverTrigger,\n} from '@/components/ui'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\nimport { downloadICalendar } from '@/lib/export-ical'\nimport { Calendar as CalendarIcon, Download, Menu, Plus } from 'lucide-react'\nimport React, { useCallback, useState } from 'react'\nimport TitleContent from './title-content'\nimport ViewControls from './view-controls'\nimport { cn } from '@/lib'\n\ninterface HeaderProps {\n  className?: string\n}\n\nconst Header: React.FC<HeaderProps> = ({ className = '' }) => {\n  const {\n    view,\n    setView,\n    nextPeriod,\n    prevPeriod,\n    today,\n    openEventForm,\n    headerComponent,\n    headerClassName,\n    rawEvents,\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  // Handle iCalendar export\n  const handleExport = useCallback(() => {\n    const filename = `ilamy-calendar-${new Date().toISOString().split('T')[0]}.ics`\n    downloadICalendar(rawEvents, filename, 'ilamy Calendar')\n    setMobilePopoverOpen(false)\n  }, [rawEvents])\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()}\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 @4xl:inline\">New</span>\n        </Button>\n      </div>\n    ),\n    [openEventForm]\n  )\n\n  if (headerComponent) {\n    // Render custom header component if provided\n    return headerComponent\n  }\n\n  return (\n    <>\n      {/* Calendar Header with grid layout */}\n      <div\n        className=\"@container/base-header w-full\"\n        data-testid=\"calendar-header\"\n      >\n        <div\n          className={cn(\n            'flex justify-center @2xl/base-header:justify-between flex-wrap items-center gap-2 border-b',\n            className,\n            headerClassName\n          )}\n        >\n          {/* Title area - Left section */}\n          <div className=\"flex flex-wrap items-center justify-center gap-1 @2xl/base-header:justify-start\">\n            <CalendarIcon className=\"h-5 w-5\" />\n            <TitleContent />\n          </div>\n\n          {/* New event button - Mobile & Desktop */}\n          <div className=\"flex flex-wrap justify-start @xl/base-header:justify-center gap-1 @4xl/base-header:justify-end overflow-x-auto\">\n            {/* Desktop controls - centralized */}\n            <div className=\"hidden @md/base-header:flex items-center justify-start gap-1\">\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\n              {/* Export button - Desktop */}\n              <Button\n                onClick={handleExport}\n                variant=\"outline\"\n                size=\"sm\"\n                className=\"flex items-center gap-1\"\n              >\n                <Download className=\"h-4 w-4\" />\n                <span className=\"hidden @4xl/base-header:inline\">Export</span>\n              </Button>\n            </div>\n\n            {/* Mobile navigation menu button - Right aligned */}\n            <div className=\"flex items-center justify-end gap-1 @md/base-header: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\n                    {/* Export button - Mobile */}\n                    <div className=\"pt-2 border-t\">\n                      <Button\n                        onClick={handleExport}\n                        variant=\"outline\"\n                        size=\"sm\"\n                        className=\"w-full flex items-center gap-2\"\n                      >\n                        <Download className=\"h-4 w-4\" />\n                        Export Calendar (.ics)\n                      </Button>\n                    </div>\n                  </div>\n                </PopoverContent>\n              </Popover>\n            </div>\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 { useMemo, useState } from 'react'\n\n// Months array is now created dynamically in the component using translations\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, t } = useCalendarContext()\n\n  // Create months array using translations\n  const months = useMemo(\n    () => [\n      t('january'),\n      t('february'),\n      t('march'),\n      t('april'),\n      t('may'),\n      t('june'),\n      t('july'),\n      t('august'),\n      t('september'),\n      t('october'),\n      t('november'),\n      t('december'),\n    ],\n    [t]\n  )\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-1! 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-1! 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-1! 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-1! 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                            {t('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'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\n\ninterface 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 { t } = useCalendarContext()\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      // 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        {t('day')}\n      </Button>\n      <Button\n        onClick={() => onChange('week')}\n        variant={getBtnVariant('week')}\n        size={size}\n        className={getButtonClassName('week')}\n      >\n        {t('week')}\n      </Button>\n      <Button\n        onClick={() => onChange('month')}\n        variant={getBtnVariant('month')}\n        size={size}\n        className={getButtonClassName('month')}\n      >\n        {t('month')}\n      </Button>\n      <Button\n        onClick={() => onChange('year')}\n        variant={getBtnVariant('year')}\n        size={size}\n        className={getButtonClassName('year')}\n      >\n        {t('year')}\n      </Button>\n\n      <Button onClick={onToday} variant=\"outline\" size={size}>\n        {t('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, getEventsForDateRange, t } =\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 = getEventsForDateRange(\n        day.startOf('day'),\n        day.endOf('day')\n      )\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-${month.date.format('YYYY-MM')}-${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 ? t('event') : t('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/view/month-view'\nimport WeekView from '@/features/week-view/view/week-view'\nimport DayView from '@/features/day-view/components/view/day-view'\nimport { EventForm } from '../event-form/event-form'\nimport { Header } from '../header'\nimport YearView from '@/features/year-view/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 } from '@/components/types'\nimport { useCalendarContext } from '@/contexts/calendar-context/context'\n// oxlint-disable-next-line no-duplicates\nimport '@/lib/dayjs-config'\nimport { WEEK_DAYS_NUMBER_MAP } from '@/lib/constants'\nimport { normalizePublicFacingCalendarEvent } from '@/lib'\nimport type { IlamyCalendarProps } from './types'\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 className=\"p-1\" />\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=\"w-full h-[calc(100%-3.5rem)]\"\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\nconst DEFAULT_DAY_MAX_EVENTS = 4\nexport const IlamyCalendar: React.FC<IlamyCalendarProps> = ({\n  events,\n  firstDayOfWeek = 'sunday',\n  initialView = 'month',\n  renderEvent,\n  onEventClick,\n  onCellClick,\n  onViewChange,\n  onEventAdd,\n  onEventUpdate,\n  onEventDelete,\n  onDateChange,\n  locale,\n  translations,\n  translator,\n  timezone,\n  disableCellClick,\n  disableEventClick,\n  disableDragAndDrop,\n  dayMaxEvents = DEFAULT_DAY_MAX_EVENTS,\n  stickyViewHeader = true,\n  viewHeaderClassName = '',\n  headerComponent,\n  headerClassName,\n}) => {\n  return (\n    <CalendarProvider\n      events={normalizePublicFacingCalendarEvent(events)}\n      firstDayOfWeek={WEEK_DAYS_NUMBER_MAP[firstDayOfWeek]}\n      initialView={initialView}\n      renderEvent={renderEvent}\n      onEventClick={onEventClick}\n      onCellClick={onCellClick}\n      onViewChange={onViewChange}\n      onEventAdd={onEventAdd}\n      onEventUpdate={onEventUpdate}\n      onEventDelete={onEventDelete}\n      onDateChange={onDateChange}\n      locale={locale}\n      translations={translations}\n      translator={translator}\n      timezone={timezone}\n      disableCellClick={disableCellClick}\n      disableEventClick={disableEventClick}\n      disableDragAndDrop={disableDragAndDrop}\n      dayMaxEvents={dayMaxEvents}\n      stickyViewHeader={stickyViewHeader}\n      viewHeaderClassName={viewHeaderClassName}\n      headerComponent={headerComponent}\n      headerClassName={headerClassName}\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, { useState } 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'\nimport { isRecurringEvent } from '@/lib/recurrence-handler'\nimport { RecurrenceEditDialog } from '@/features/recurrence/components/recurrence-edit-dialog'\nimport type { RecurrenceEditScope } from '@/features/recurrence/types'\n\ninterface CalendarDndContextProps {\n  children: React.ReactNode\n}\n\nexport function CalendarDndContext({ children }: CalendarDndContextProps) {\n  const { updateEvent, updateRecurringEvent, view, disableDragAndDrop } =\n    useCalendarContext()\n  const [activeEvent, setActiveEvent] = React.useState<CalendarEvent | null>(\n    null\n  )\n\n  // State for recurring event dialog\n  const [recurringDialog, setRecurringDialog] = useState<{\n    isOpen: boolean\n    event: CalendarEvent | null\n    updates: Partial<CalendarEvent> | null\n  }>({\n    isOpen: false,\n    event: null,\n    updates: 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  // Helper function to perform the actual event update\n  const performEventUpdate = (\n    event: CalendarEvent,\n    updates: Partial<CalendarEvent>\n  ) => {\n    // Validate inputs\n    if (!event || !event.id) {\n      return\n    }\n\n    if (!updates || Object.keys(updates).length === 0) {\n      return\n    }\n\n    if (isRecurringEvent(event)) {\n      // Show dialog for recurring events\n      setRecurringDialog({\n        isOpen: true,\n        event,\n        updates,\n      })\n    } else {\n      // Directly update regular events\n      updateEvent(event.id, updates)\n    }\n  }\n\n  // Handle recurring event dialog confirmation\n  const handleRecurringEventConfirm = (scope: RecurrenceEditScope) => {\n    if (!recurringDialog.event || !recurringDialog.updates) {\n      setRecurringDialog({ isOpen: false, event: null, updates: null })\n      return\n    }\n\n    try {\n      updateRecurringEvent(recurringDialog.event, recurringDialog.updates, {\n        scope,\n        eventDate: recurringDialog.event.start,\n      })\n    } catch {\n      // Silently handle error and reset dialog state\n    } finally {\n      setRecurringDialog({ isOpen: false, event: null, updates: null })\n    }\n  }\n\n  // Handle recurring event dialog close\n  const handleRecurringEventClose = () => {\n    setRecurringDialog({ isOpen: false, event: null, updates: null })\n  }\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 start = activeEvent.start\n      const end = activeEvent.end\n      const durationMinutes = end.diff(start, '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      performEventUpdate(activeEvent, {\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 start = activeEvent.start\n      const end = activeEvent.end\n\n      if (isMultiDayEvent) {\n        if (view === 'week') {\n          // Get time components to preserve\n          const startHour = start.hour()\n          const startMinute = start.minute()\n          const endHour = end.hour()\n          const endMinute = end.minute()\n\n          // Calculate duration in days to preserve\n          const durationDays = end.diff(start, '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          performEventUpdate(activeEvent, {\n            start: newStart,\n            end: newEnd,\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(start.startOf('day'), 'day')\n\n          // Calculate new start and end while preserving time components\n          const newStart = start.add(daysDifference, 'day')\n          const newEnd = end.add(daysDifference, 'day')\n\n          performEventUpdate(activeEvent, {\n            start: newStart,\n            end: newEnd,\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        performEventUpdate(activeEvent, {\n          start: newStart,\n          end: newEnd,\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    <>\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      {/* Recurring event edit dialog */}\n      <RecurrenceEditDialog\n        isOpen={recurringDialog.isOpen}\n        onClose={handleRecurringEventClose}\n        onConfirm={handleRecurringEventConfirm}\n        operationType=\"edit\"\n        eventTitle={recurringDialog.event?.title || ''}\n      />\n    </>\n  )\n}\n",
    "import dayjs from '@/lib/dayjs-config'\nimport React, { useCallback, useEffect, useMemo, useState } from 'react'\nimport type { ReactNode } from 'react'\nimport { CalendarContext } from './context'\nimport type { CalendarEvent } from '@/components/types'\nimport {\n  generateRecurringEvents,\n  updateRecurringEvent as updateRecurringEventImpl,\n  deleteRecurringEvent as deleteRecurringEventImpl,\n} from '@/lib/recurrence-handler'\nimport type { RecurrenceEditOptions } from '@/features/recurrence/types'\nimport type { Translations, TranslatorFunction } from '@/lib/translations/types'\nimport { defaultTranslations } from '@/lib/translations/default'\n\ninterface CalendarProviderProps {\n  children: ReactNode\n  events?: CalendarEvent[]\n  firstDayOfWeek?: number // 0 for Sunday, 1 for Monday, etc.\n  initialView?: 'month' | 'week' | 'day' | 'year'\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  onEventAdd?: (event: CalendarEvent) => void\n  onEventUpdate?: (event: CalendarEvent) => void\n  onEventDelete?: (event: CalendarEvent) => void\n  onDateChange?: (date: dayjs.Dayjs) => 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  headerComponent?: ReactNode // Optional custom header component\n  headerClassName?: string // Optional custom header class\n  // Translation options - provide either translations object OR translator function\n  translations?: Translations\n  translator?: TranslatorFunction\n}\n\nexport const CalendarProvider: React.FC<CalendarProviderProps> = ({\n  children,\n  events = [],\n  firstDayOfWeek = 0, // Default to Sunday,\n  initialView = 'month',\n  renderEvent,\n  onEventClick,\n  onCellClick,\n  onViewChange,\n  onEventAdd,\n  onEventUpdate,\n  onEventDelete,\n  onDateChange,\n  locale,\n  timezone,\n  disableCellClick,\n  disableEventClick,\n  disableDragAndDrop,\n  dayMaxEvents,\n  stickyViewHeader = true,\n  viewHeaderClassName = '',\n  headerComponent,\n  headerClassName,\n  translations,\n  translator,\n}) => {\n  // State\n  const [currentDate, setCurrentDate] = useState<dayjs.Dayjs>(dayjs())\n  const [view, setView] = useState<'month' | 'week' | 'day' | 'year'>(\n    initialView\n  )\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  // Create translation function\n  const t = useMemo(() => {\n    if (translator) {\n      // Use provided translator function\n      return translator\n    }\n\n    if (translations) {\n      // Use provided translations object\n      return (key: keyof Translations) => translations[key] || key\n    }\n    // Use default translations\n    return (key: keyof Translations) => defaultTranslations[key] || key\n  }, [translations, translator])\n\n  // Helper function to get events for a specific date range (on-demand generation)\n  const getEventsForDateRange = useCallback(\n    (startDate: dayjs.Dayjs, endDate: dayjs.Dayjs): CalendarEvent[] => {\n      const allEvents: CalendarEvent[] = []\n\n      for (const event of currentEvents) {\n        if (event.rrule) {\n          // Generate recurring instances for the specific range\n          const recurringEvents = generateRecurringEvents({\n            event,\n            currentEvents,\n            startDate,\n            endDate,\n          })\n          allEvents.push(...recurringEvents)\n        } else {\n          // Add non-recurring events with comprehensive range checking\n          const eventStartsInRange =\n            event.start.isSameOrAfter(startDate) &&\n            event.start.isSameOrBefore(endDate)\n\n          const eventEndsInRange =\n            event.end.isSameOrAfter(startDate) &&\n            event.end.isSameOrBefore(endDate)\n\n          const eventSpansRange =\n            event.start.isBefore(startDate) && event.end.isAfter(endDate)\n\n          if (eventStartsInRange || eventEndsInRange || eventSpansRange) {\n            allEvents.push(event)\n          }\n        }\n      }\n\n      return allEvents\n    },\n    [currentEvents]\n  )\n\n  // Get the current view's date range for on-demand event generation\n  const getCurrentViewRange = useCallback(() => {\n    switch (view) {\n      case 'day':\n        return {\n          start: currentDate.startOf('day'),\n          end: currentDate.endOf('day'),\n        }\n      case 'week':\n        return {\n          start: currentDate\n            .startOf('week')\n            .subtract(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n          end: currentDate\n            .endOf('week')\n            .add(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n        }\n      case 'month':\n        return {\n          start: currentDate\n            .startOf('month')\n            .startOf('week')\n            .subtract(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n          end: currentDate\n            .endOf('month')\n            .endOf('week')\n            .add(firstDayOfWeek === 1 ? 1 : 0, 'day'),\n        }\n      case 'year':\n        return {\n          start: currentDate.startOf('year'),\n          end: currentDate.endOf('year'),\n        }\n      default:\n        return {\n          start: currentDate.startOf('month'),\n          end: currentDate.endOf('month'),\n        }\n    }\n  }, [currentDate, view, firstDayOfWeek])\n\n  // Get processed events for the current view (on-demand)\n  const processedEvents = useMemo(() => {\n    const { start, end } = getCurrentViewRange()\n    return getEventsForDateRange(start, end)\n  }, [getEventsForDateRange, getCurrentViewRange])\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(\n    (date: dayjs.Dayjs) => {\n      setCurrentDate(date)\n      onDateChange?.(date)\n    },\n    [onDateChange]\n  )\n\n  const nextPeriod = useCallback(() => {\n    switch (view) {\n      case 'month':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.add(1, 'month')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'week':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.add(1, 'week')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'day':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.add(1, 'day')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'year':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.add(1, 'year')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n    }\n  }, [view, onDateChange])\n\n  const prevPeriod = useCallback(() => {\n    switch (view) {\n      case 'month':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.subtract(1, 'month')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'week':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.subtract(1, 'week')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'day':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.subtract(1, 'day')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n      case 'year':\n        setCurrentDate((currentDate) => {\n          const newDate = currentDate.subtract(1, 'year')\n          onDateChange?.(newDate)\n          return newDate\n        })\n        break\n    }\n  }, [view, onDateChange])\n\n  const today = useCallback(() => {\n    const newDate = dayjs()\n    setCurrentDate(newDate)\n    onDateChange?.(newDate)\n  }, [onDateChange])\n\n  const addEvent = useCallback(\n    (event: CalendarEvent) => {\n      setCurrentEvents((prevEvents) => [...prevEvents, event])\n      onEventAdd?.(event)\n    },\n    [onEventAdd]\n  )\n\n  const updateEvent = useCallback(\n    (eventId: string, updatedEvent: Partial<CalendarEvent>) => {\n      setCurrentEvents((prevEvents) => {\n        const updated = prevEvents.map((event) => {\n          if (event.id === eventId) {\n            const newEvent = { ...event, ...updatedEvent }\n            onEventUpdate?.(newEvent)\n            return newEvent\n          }\n          return event\n        })\n        return updated\n      })\n    },\n    [onEventUpdate]\n  )\n\n  const updateRecurringEvent = useCallback(\n    (\n      event: CalendarEvent,\n      updates: Partial<CalendarEvent>,\n      options: RecurrenceEditOptions\n    ) => {\n      // Create the updated event with the updates applied\n      const updatedEvent = { ...event, ...updates }\n\n      // Call the regular update callback with the updated event\n      onEventUpdate?.(updatedEvent)\n\n      // Use our implemented recurring event update function\n      const updatedEvents = updateRecurringEventImpl({\n        targetEvent: event,\n        updates,\n        currentEvents,\n        scope: options.scope,\n      })\n\n      setCurrentEvents(updatedEvents)\n    },\n    [currentEvents, onEventUpdate]\n  )\n\n  const deleteRecurringEvent = useCallback(\n    (event: CalendarEvent, options: RecurrenceEditOptions) => {\n      // Call the regular delete callback with the event being deleted\n      onEventDelete?.(event)\n\n      // Use our implemented recurring event delete function\n      const updatedEvents = deleteRecurringEventImpl({\n        targetEvent: event,\n        currentEvents,\n        scope: options.scope,\n      })\n\n      setCurrentEvents(updatedEvents)\n    },\n    [currentEvents, onEventDelete]\n  )\n\n  const deleteEvent = useCallback(\n    (eventId: string) => {\n      setCurrentEvents((prevEvents) => {\n        const eventToDelete = prevEvents.find((event) => event.id === eventId)\n        if (eventToDelete) {\n          onEventDelete?.(eventToDelete)\n        }\n        return prevEvents.filter((event) => event.id !== eventId)\n      })\n    },\n    [onEventDelete]\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) {\n        return\n      }\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) {\n        return\n      }\n\n      if (onCellClick) {\n        onCellClick(startDate, endDate)\n      } else {\n        setSelectedDate(startDate)\n        setSelectedEvent({\n          title: t('newEvent'),\n          start: startDate,\n          end: endDate,\n          description: '',\n          allDay: false,\n        } as CalendarEvent)\n        setIsEventFormOpen(true)\n      }\n    },\n    [onCellClick, disableCellClick, t]\n  )\n\n  const handleOpenEventForm = useCallback(\n    (date?: dayjs.Dayjs) => {\n      if (date) {\n        setSelectedDate(date)\n      }\n      setSelectedEvent({\n        title: t('newEvent'),\n        start: date ?? currentDate,\n        end: date ?? currentDate.add(1, 'hour'),\n        description: '',\n        allDay: false,\n      } as CalendarEvent)\n      setIsEventFormOpen(true)\n    },\n    [currentDate, t]\n  )\n\n  // Find parent recurring event for a given event instance\n  const findParentRecurringEvent = useCallback(\n    (event: CalendarEvent): CalendarEvent | null => {\n      // Generate UID if missing (following RFC 5545 compliance)\n      const targetUID = event.uid\n\n      const parentEvent = currentEvents.find((e) => {\n        const parentUID = e.uid || `${e.id}@ilamy.calendar`\n        return parentUID === targetUID && e.rrule\n      })\n\n      return parentEvent || null\n    },\n    [currentEvents]\n  )\n\n  // Create the context value\n  const contextValue = useMemo(\n    () => ({\n      currentDate,\n      view,\n      events: processedEvents,\n      rawEvents: 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      updateRecurringEvent,\n      deleteEvent,\n      deleteRecurringEvent,\n      openEventForm: handleOpenEventForm,\n      closeEventForm,\n      getEventsForDateRange,\n      findParentRecurringEvent,\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      headerComponent,\n      headerClassName,\n      // Translation function\n      t,\n    }),\n    [\n      currentDate,\n      view,\n      processedEvents,\n      currentEvents,\n      currentLocale,\n      isEventFormOpen,\n      selectedEvent,\n      selectedDate,\n      firstDayOfWeek,\n      selectDate,\n      handleViewChange,\n      nextPeriod,\n      handleOpenEventForm,\n      prevPeriod,\n      today,\n      addEvent,\n      updateEvent,\n      updateRecurringEvent,\n      deleteEvent,\n      deleteRecurringEvent,\n      closeEventForm,\n      getEventsForDateRange,\n      findParentRecurringEvent,\n      renderEvent,\n      handleEventClick,\n      handleDateClick,\n      locale,\n      currentTimezone,\n      disableCellClick,\n      disableEventClick,\n      disableDragAndDrop,\n      dayMaxEvents,\n      stickyViewHeader,\n      viewHeaderClassName,\n      headerComponent,\n      headerClassName,\n      // Translation dependencies\n      t,\n    ]\n  )\n\n  return (\n    <CalendarContext.Provider value={contextValue}>\n      {children}\n    </CalendarContext.Provider>\n  )\n}\n",
    "import type { Translations } from './types'\n\nexport const defaultTranslations: Translations = {\n  // Common actions\n  today: 'Today',\n  create: 'Create',\n  update: 'Update',\n  delete: 'Delete',\n  cancel: 'Cancel',\n\n  // Event related\n  event: 'Event',\n  events: 'Events',\n  newEvent: 'New Event',\n  title: 'Title',\n  description: 'Description',\n  location: 'Location',\n  allDay: 'All day',\n  startDate: 'Start Date',\n  endDate: 'End Date',\n  startTime: 'Start Time',\n  endTime: 'End Time',\n  color: 'Color',\n\n  // Event form\n  createEvent: 'Create Event',\n  editEvent: 'Edit Event',\n  addNewEvent: 'Add a new event to your calendar',\n  editEventDetails: 'Edit your event details',\n  eventTitlePlaceholder: 'Event title',\n  eventDescriptionPlaceholder: 'Event description (optional)',\n  eventLocationPlaceholder: 'Event location (optional)',\n\n  // Recurrence\n  repeat: 'Repeat',\n  repeats: 'Repeats',\n  customRecurrence: 'Custom recurrence',\n  daily: 'Daily',\n  weekly: 'Weekly',\n  monthly: 'Monthly',\n  yearly: 'Yearly',\n  interval: 'Interval',\n  repeatOn: 'Repeat on',\n  never: 'Never',\n  count: 'Count',\n  every: 'Every',\n  ends: 'Ends',\n  after: 'After',\n  occurrences: 'occurrences',\n  on: 'On',\n\n  // Recurrence edit dialog\n  editRecurringEvent: 'Edit recurring event',\n  deleteRecurringEvent: 'Delete recurring event',\n  editRecurringEventQuestion:\n    'is a recurring event. How would you like to edit it?',\n  deleteRecurringEventQuestion:\n    'is a recurring event. How would you like to delete it?',\n  thisEvent: 'This event',\n  thisEventDescription: 'Only change this specific occurrence',\n  thisAndFollowingEvents: 'This and following events',\n  thisAndFollowingEventsDescription: 'Edit this and all future occurrences',\n  allEvents: 'All events',\n  allEventsDescription: 'Edit the entire recurring series',\n  onlyChangeThis: 'Only change this specific occurrence',\n  changeThisAndFuture: 'Change this and all future occurrences',\n  changeEntireSeries: 'Change the entire recurring series',\n  onlyDeleteThis: 'Only delete this specific occurrence',\n  deleteThisAndFuture: 'Delete this and all future occurrences',\n  deleteEntireSeries: 'Delete the entire recurring series',\n\n  // View types\n  month: 'Month',\n  week: 'Week',\n  day: 'Day',\n  year: 'Year',\n  more: 'more',\n\n  // Days of week\n  sunday: 'Sunday',\n  monday: 'Monday',\n  tuesday: 'Tuesday',\n  wednesday: 'Wednesday',\n  thursday: 'Thursday',\n  friday: 'Friday',\n  saturday: 'Saturday',\n\n  // Days short\n  sun: 'Sun',\n  mon: 'Mon',\n  tue: 'Tue',\n  wed: 'Wed',\n  thu: 'Thu',\n  fri: 'Fri',\n  sat: 'Sat',\n\n  // Months\n  january: 'January',\n  february: 'February',\n  march: 'March',\n  april: 'April',\n  may: 'May',\n  june: 'June',\n  july: 'July',\n  august: 'August',\n  september: 'September',\n  october: 'October',\n  november: 'November',\n  december: 'December',\n}\n",
    "// Main calendar component\nexport { IlamyCalendar } from './components/ilamy-calendar/ilamy-calendar'\n\n// Public calendar context hook\nexport { useIlamyCalendarContext } from './contexts/calendar-context/context'\n\n// RRULE-based recurrence system\nexport {\n  generateRecurringEvents,\n  isRecurringEvent,\n} from './lib/recurrence-handler'\n\n// Export types\nexport type { RRuleOptions } from './lib/recurrence-handler/types'\nexport type { CalendarEvent } from './components/types'\nexport type { IlamyCalendarProps } from './components/ilamy-calendar/types'\nexport type { WeekDays } from './components/types'\nexport type { UseIlamyCalendarContextReturn } from './contexts/calendar-context/context'\n// Re-export rrule.js types for convenience\nexport type { Frequency, Weekday } from 'rrule'\nexport { RRule } from 'rrule'\n\n// Translation system\nexport type {\n  Translations,\n  TranslationKey,\n  TranslatorFunction,\n} from './lib/translations/types'\nexport { defaultTranslations } from './lib/translations/default'\n"
  ],
  "mappings": ";AACA,4BAAS,4BAAiB;AAC1B,4BAAgB;;;ACEhB;AAoDO,IAAM,kBACX,cAA+C,SAAS;AAEnD,IAAM,qBAAqB,MAA2B;AAAA,EAC3D,MAAM,UAAU,WAAW,eAAe;AAAA,EAC1C,IAAI,YAAY,WAAW;AAAA,IACzB,MAAM,IAAI,MAAM,2DAA2D;AAAA,EAC7E;AAAA,EACA,OAAO;AAAA;AA+BF,IAAM,0BAA0B,MAAqC;AAAA,EAC1E,MAAM,UAAU,WAAW,eAAe;AAAA,EAC1C,IAAI,YAAY,WAAW;AAAA,IACzB,MAAM,IAAI,MACR,gEACF;AAAA,EACF;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;;;ACxHF;AAEA;;;ACDA;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAeA;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;AA1JA,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;AAoJvB,IAAe;;;ADpKf;AAGO,SAAS,EAAE,IAAI,QAAsB;AAAA,EAC1C,OAAO,QAAQ,KAAK,MAAM,CAAC;AAAA;AAiBtB,SAAS,QAAQ,CAAC,MAAgD;AAAA,EACvE,IAAI,qBAAM,QAAQ,IAAI,GAAG;AAAA,IACvB,OAAO;AAAA,EACT;AAAA,EAEA,MAAM,aAAa,qBAAM,IAAI;AAAA,EAC7B,OAAO,WAAW,QAAQ,IAAI,aAAa,qBAAM;AAAA;AAG5C,IAAM,WAAW,CACtB,KACA,SACe;AAAA,EACf,MAAM,SAAS,KAAK,IAAI;AAAA,EACxB,WAAW,OAAO,MAAM;AAAA,IACtB,OAAO,OAAO;AAAA,EAChB;AAAA,EACA,OAAO;AAAA;AAGF,SAAS,kCAAkC,CAChD,QACiB;AAAA,EACjB,KAAK,WAAW,OAAO,QAAQ;AAAA,IAC7B,OAAO,CAAC;AAAA,EACV;AAAA,EAEA,OAAO,OAAO,IAAI,CAAC,UAAU;AAAA,IAE3B,OAAO;AAAA,SACF;AAAA,MACH,OAAO,qBAAM,QAAQ,MAAM,KAAK,IAAI,MAAM,QAAQ,qBAAM,MAAM,KAAK;AAAA,MACnE,KAAK,qBAAM,QAAQ,MAAM,GAAG,IAAI,MAAM,MAAM,qBAAM,MAAM,GAAG;AAAA,IAC7D;AAAA,GACD;AAAA;;;;ADpDH,IAAM,iBAAiB,IACrB,+bACA;AAAA,EACE,UAAU;AAAA,IACR,SAAS;AAAA,MACP,SACE;AAAA,MACF,aACE;AAAA,MACF,SACE;AAAA,MACF,WACE;AAAA,MACF,OACE;AAAA,MACF,MAAM;AAAA,IACR;AAAA,IACA,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,IACR;AAAA,EACF;AAAA,EACA,iBAAiB;AAAA,IACf,SAAS;AAAA,IACT,MAAM;AAAA,EACR;AACF,CACF;AAEA,SAAS,MAAM;AAAA,EACb;AAAA,EACA;AAAA,EACA;AAAA,EACA,UAAU;AAAA,KACP;AAAA,GAIA;AAAA,EACH,MAAM,OAAO,UAAU,OAAO;AAAA,EAE9B,uBACE,IAAC,MAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,eAAe,EAAE,SAAS,MAAM,UAAU,CAAC,CAAC;AAAA,OACtD;AAAA,GACN;AAAA;;AGvDJ;AACA;AAAA;AAAA;AAAA;AAAA;AAMA;;AAKA,SAAS,QAAQ;AAAA,EACf;AAAA,EACA;AAAA,EACA,kBAAkB;AAAA,EAClB,gBAAgB;AAAA,EAChB,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,KACG;AAAA,GAGF;AAAA,EACD,MAAM,oBAAoB,qBAAqB;AAAA,EAE/C,uBACE,KAAC,WAAD;AAAA,IACE;AAAA,IACA,WAAW,GACT,0JACA,OAAO,gDACP,OAAO,oDACP,SACF;AAAA,IACA;AAAA,IACA,YAAY;AAAA,MACV,qBAAqB,CAAC,SACpB,KAAK,eAAe,WAAW,EAAE,OAAO,QAAQ,CAAC;AAAA,SAChD;AAAA,IACL;AAAA,IACA,YAAY;AAAA,MACV,MAAM,GAAG,SAAS,kBAAkB,IAAI;AAAA,MACxC,QAAQ,GACN,4CACA,kBAAkB,MACpB;AAAA,MACA,OAAO,GAAG,8BAA8B,kBAAkB,KAAK;AAAA,MAC/D,KAAK,GACH,2EACA,kBAAkB,GACpB;AAAA,MACA,iBAAiB,GACf,eAAe,EAAE,SAAS,cAAc,CAAC,GACzC,+DACA,kBAAkB,eACpB;AAAA,MACA,aAAa,GACX,eAAe,EAAE,SAAS,cAAc,CAAC,GACzC,+DACA,kBAAkB,WACpB;AAAA,MACA,eAAe,GACb,4EACA,kBAAkB,aACpB;AAAA,MACA,WAAW,GACT,uFACA,kBAAkB,SACpB;AAAA,MACA,eAAe,GACb,uHACA,kBAAkB,aACpB;AAAA,MACA,UAAU,GACR,yCACA,kBAAkB,QACpB;AAAA,MACA,eAAe,GACb,2BACA,kBAAkB,UACd,YACA,2GACJ,kBAAkB,aACpB;AAAA,MACA,OAAO;AAAA,MACP,UAAU,GAAG,QAAQ,kBAAkB,QAAQ;AAAA,MAC/C,SAAS,GACP,iFACA,kBAAkB,OACpB;AAAA,MACA,MAAM,GAAG,oBAAoB,kBAAkB,IAAI;AAAA,MACnD,oBAAoB,GAClB,+BACA,kBAAkB,kBACpB;AAAA,MACA,aAAa,GACX,mDACA,kBAAkB,WACpB;AAAA,MACA,KAAK,GACH,6LACA,kBAAkB,GACpB;AAAA,MACA,aAAa,GACX,0BACA,kBAAkB,WACpB;AAAA,MACA,cAAc,GAAG,gBAAgB,kBAAkB,YAAY;AAAA,MAC/D,WAAW,GAAG,0BAA0B,kBAAkB,SAAS;AAAA,MACnE,OAAO,GACL,iFACA,kBAAkB,KACpB;AAAA,MACA,SAAS,GACP,6DACA,kBAAkB,OACpB;AAAA,MACA,UAAU,GACR,oCACA,kBAAkB,QACpB;AAAA,MACA,QAAQ,GAAG,aAAa,kBAAkB,MAAM;AAAA,SAC7C;AAAA,IACL;AAAA,IACA,YAAY;AAAA,MACV,MAAM,GAAG,uBAAW,YAAY,aAAY;AAAA,QAC1C,uBACE,KAAC,OAAD;AAAA,UACE,aAAU;AAAA,UACV,KAAK;AAAA,UACL,WAAW,GAAG,UAAS;AAAA,aACnB;AAAA,SACN;AAAA;AAAA,MAGJ,SAAS,GAAG,uBAAW,gBAAgB,aAAY;AAAA,QACjD,IAAI,gBAAgB,QAAQ;AAAA,UAC1B,uBACE,KAAC,iBAAD;AAAA,YAAiB,WAAW,GAAG,UAAU,UAAS;AAAA,eAAO;AAAA,WAAO;AAAA,QAEpE;AAAA,QAEA,IAAI,gBAAgB,SAAS;AAAA,UAC3B,uBACE,KAAC,kBAAD;AAAA,YACE,WAAW,GAAG,UAAU,UAAS;AAAA,eAC7B;AAAA,WACN;AAAA,QAEJ;AAAA,QAEA,uBACE,KAAC,iBAAD;AAAA,UAAiB,WAAW,GAAG,UAAU,UAAS;AAAA,aAAO;AAAA,SAAO;AAAA;AAAA,MAGpE,WAAW;AAAA,MACX,YAAY,GAAG,aAAa,aAAY;AAAA,QACtC,uBACE,KAIE,MAJF;AAAA,aAAQ;AAAA,UAAR,0BACE,KAEE,OAFF;AAAA,YAAK,WAAU;AAAA,YAAf;AAAA,WAEE;AAAA,SACF;AAAA;AAAA,SAGH;AAAA,IACL;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,KACG;AAAA,GACsC;AAAA,EACzC,MAAM,oBAAoB,qBAAqB;AAAA,EAE/C,MAAM,MAAY,aAA0B,IAAI;AAAA,EAC1C,gBAAU,MAAM;AAAA,IACpB,IAAI,UAAU,SAAS;AAAA,MACrB,IAAI,SAAS,MAAM;AAAA,IACrB;AAAA,KACC,CAAC,UAAU,OAAO,CAAC;AAAA,EAEtB,uBACE,KAAC,QAAD;AAAA,IACE;AAAA,IACA,SAAQ;AAAA,IACR,MAAK;AAAA,IACL,YAAU,IAAI,KAAK,mBAAmB;AAAA,IACtC,wBACE,UAAU,aACT,UAAU,gBACV,UAAU,cACV,UAAU;AAAA,IAEb,oBAAkB,UAAU;AAAA,IAC5B,kBAAgB,UAAU;AAAA,IAC1B,qBAAmB,UAAU;AAAA,IAC7B,WAAW,GACT,o3BACA,kBAAkB,KAClB,SACF;AAAA,OACI;AAAA,GACN;AAAA;;AChNJ;AACA;;AAIA,SAAS,QAAQ;AAAA,EACf;AAAA,KACG;AAAA,GACmD;AAAA,EACtD,uBACE,KAcoB,wBAdpB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,+eACA,SACF;AAAA,OACI;AAAA,IANN,0BAQE,KAKoB,6BALpB;AAAA,MACE,aAAU;AAAA,MACV,WAAU;AAAA,MAFZ,0BAIE,KAAC,WAAD;AAAA,QAAW,WAAU;AAAA,OAAW;AAAA,KAChC;AAAA,GACF;AAAA;;;ACrBN,SAAS,IAAI,GAAG,cAAc,SAAsC;AAAA,EAClE,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,wEACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,UAAU,GAAG,cAAc,SAAsC;AAAA,EACxE,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,iJACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,SAAS,GAAG,cAAc,SAAsC;AAAA,EACvE,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,8BAA8B,SAAS;AAAA,OACjD;AAAA,GACN;AAAA;AA2BJ,SAAS,WAAW,GAAG,cAAc,SAAsC;AAAA,EACzE,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,YAAY,SAAS;AAAA,OAC/B;AAAA,GACN;AAAA;;ACpEJ,qBAAS;;;ACAT;;AAIA,SAAS,OAAO;AAAA,KACX;AAAA,GACkD;AAAA,EACrD,uBAAO,KAAkB,uBAAlB;AAAA,IAAuB,aAAU;AAAA,OAAc;AAAA,GAAO;AAAA;AAG/D,SAAS,cAAc;AAAA,KAClB;AAAA,GACqD;AAAA,EACxD,uBAAO,KAAkB,0BAAlB;AAAA,IAA0B,aAAU;AAAA,OAAsB;AAAA,GAAO;AAAA;AAG1E,SAAS,cAAc;AAAA,EACrB;AAAA,EACA,QAAQ;AAAA,EACR,aAAa;AAAA,KACV;AAAA,GACqD;AAAA,EACxD,uBACE,KAWmB,yBAXnB;AAAA,8BACE,KAAkB,0BAAlB;AAAA,MACE,aAAU;AAAA,MACV;AAAA,MACA;AAAA,MACA,WAAW,GACT,keACA,SACF;AAAA,SACI;AAAA,KACN;AAAA,GACA;AAAA;;;ADzBN,mBAAS;AACT;AAAA;AAUO,SAAS,UAAU;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,EACA,QAAQ;AAAA,EACR;AAAA,GACkB;AAAA,EAClB,MAAM,aAAa,QAAiC,IAAI;AAAA,EAExD,MAAM,WAAW,CAAC,UAA2B;AAAA,IAC3C,QAAQ,KAAI;AAAA,IACZ,IAAI,eAAe;AAAA,MACjB,WAAW,SAAS,MAAM;AAAA,IAC5B;AAAA;AAAA,EAGF,uBACE,KAyBE,OAzBF;AAAA,IAAK;AAAA,IAAL,0BACE,KAuBE,SAvBF;AAAA,gBAuBE;AAAA,wBAtBA,KAWE,gBAXF;AAAA,UAAgB,SAAO;AAAA,UAAvB,0BACE,KASE,QATF;AAAA,YACE,SAAQ;AAAA,YACR,WAAW,GACT,+CACC,QAAQ,uBACX;AAAA,YALF,UASE;AAAA,8BAFA,KAAC,cAAD;AAAA,gBAAc,WAAU;AAAA,eAAe;AAAA,cACtC,OAAO,qBAAM,IAAI,EAAE,OAAO,aAAa,oBAAI,KAAe,QAAf;AAAA,0BAAO;AAAA,eAAQ;AAAA;AAAA,WAC3D;AAAA,SACF;AAAA,wBACF,KASE,gBATF;AAAA,UAAgB,WAAU;AAAA,UAAa,OAAM;AAAA,UAA7C,UASE;AAAA,4BARA,KAAC,cAAD;AAAA,cAAc,KAAK;AAAA,aAAY;AAAA,4BAC/B,KAAC,UAAD;AAAA,cACE,MAAK;AAAA,cACL,UAAU;AAAA,cACV;AAAA,cACA,OAAO;AAAA,cACP,cAAY;AAAA,aACd;AAAA;AAAA,SACA;AAAA;AAAA,KACF;AAAA,GACF;AAAA;;AE9DN;AACA;;AAIA,SAAS,MAAM;AAAA,KACV;AAAA,GACiD;AAAA,EACpD,uBAAO,KAAiB,sBAAjB;AAAA,IAAsB,aAAU;AAAA,OAAa;AAAA,GAAO;AAAA;AAS7D,SAAS,YAAY;AAAA,KAChB;AAAA,GACmD;AAAA,EACtD,uBAAO,KAAiB,wBAAjB;AAAA,IAAwB,aAAU;AAAA,OAAoB;AAAA,GAAO;AAAA;AAStE,SAAS,aAAa;AAAA,EACpB;AAAA,KACG;AAAA,GACoD;AAAA,EACvD,uBACE,KAAiB,yBAAjB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,0JACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,aAAa;AAAA,EACpB;AAAA,EACA;AAAA,KACG;AAAA,GACoD;AAAA,EACvD,uBACE,MAgBE,cAhBF;AAAA,IAAc,aAAU;AAAA,IAAxB,UAgBE;AAAA,sBAfA,KAAC,eAAD,EAAe;AAAA,sBACf,MAakB,yBAblB;AAAA,QACE,aAAU;AAAA,QACV,WAAW,GACT,6YACA,SACF;AAAA,WACI;AAAA,QANN,UAaE;AAAA,UALC;AAAA,0BACD,MAGkB,uBAHlB;AAAA,YAAuB,WAAU;AAAA,YAAjC,UAGE;AAAA,8BAFA,KAAC,OAAD,EAAO;AAAA,8BACP,KAAiC,QAAjC;AAAA,gBAAM,WAAU;AAAA,gBAAhB;AAAA,eAAiC;AAAA;AAAA,WACjC;AAAA;AAAA,OACF;AAAA;AAAA,GACF;AAAA;AAIN,SAAS,YAAY,GAAG,cAAc,SAAsC;AAAA,EAC1E,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,gDAAgD,SAAS;AAAA,OACnE;AAAA,GACN;AAAA;AAIJ,SAAS,YAAY,GAAG,cAAc,SAAsC;AAAA,EAC1E,uBACE,KAAC,OAAD;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,0DACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,WAAW;AAAA,EAClB;AAAA,KACG;AAAA,GACkD;AAAA,EACrD,uBACE,KAAiB,uBAAjB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,sCAAsC,SAAS;AAAA,OACzD;AAAA,GACN;AAAA;AAIJ,SAAS,iBAAiB;AAAA,EACxB;AAAA,KACG;AAAA,GACwD;AAAA,EAC3D,uBACE,KAAiB,6BAAjB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,iCAAiC,SAAS;AAAA,OACpD;AAAA,GACN;AAAA;;;ACjHJ,SAAS,KAAK,GAAG,WAAW,SAAS,SAAwC;AAAA,EAC3E,uBACE,KAAC,SAAD;AAAA,IACE;AAAA,IACA,aAAU;AAAA,IACV,WAAW,GACT,mcACA,iFACA,0GACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;;ACbJ;;AAHA;AAOA,SAAS,KAAK;AAAA,EACZ;AAAA,KACG;AAAA,GACgD;AAAA,EACnD,uBACE,KAAgB,qBAAhB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,uNACA,SACF;AAAA,OACI;AAAA,GACN;AAAA;;AClBJ;;AASA,SAAS,UAAU,GAAG,WAAW,aAAa,SAA0B;AAAA,EACtE,uBACE,MAiBsB,0BAjBtB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GAAG,YAAY,SAAS;AAAA,OAC/B;AAAA,IAHN,UAiBE;AAAA,sBAZA,MASsB,8BATtB;AAAA,WACM,MAAM;AAAA,QACV,aAAU;AAAA,QACV,WAAW,GACT,sJACA,MAAM,eAAe,SACvB;AAAA,QANF;AAAA,OASE;AAAA,sBACF,MAAC,WAAD,EAAW;AAAA,sBACX,MAAqB,4BAArB,EAA4B;AAAA;AAAA,GAC5B;AAAA;AAIN,SAAS,SAAS;AAAA,EAChB;AAAA,EACA,cAAc;AAAA,KACX;AAAA,GACoE;AAAA,EACvE,uBACE,MAiBsB,yCAjBtB;AAAA,IACE,aAAU;AAAA,IACV;AAAA,IACA,WAAW,GACT,sDACA,gBAAgB,cACd,8CACF,gBAAgB,gBACd,gDACF,SACF;AAAA,OACI;AAAA,IAXN,0BAaE,MAAqB,qCAArB;AAAA,MACE,aAAU;AAAA,MACV,WAAU;AAAA,KACZ;AAAA,GACA;AAAA;;ACvDN;AACA,sBAAS,+BAAW;;AAIpB,SAAS,MAAM;AAAA,KACV;AAAA,GACiD;AAAA,EACpD,uBAAO,MAAiB,sBAAjB;AAAA,IAAsB,aAAU;AAAA,OAAa;AAAA,GAAO;AAAA;AAS7D,SAAS,WAAW;AAAA,KACf;AAAA,GACkD;AAAA,EACrD,uBAAO,MAAiB,uBAAjB;AAAA,IAAuB,aAAU;AAAA,OAAmB;AAAA,GAAO;AAAA;AAGpE,SAAS,aAAa;AAAA,EACpB;AAAA,EACA,OAAO;AAAA,EACP;AAAA,KACG;AAAA,GAGF;AAAA,EACD,uBACE,MAakB,yBAblB;AAAA,IACE,aAAU;AAAA,IACV,aAAW;AAAA,IACX,WAAW,GACT,gzBACA,SACF;AAAA,OACI;AAAA,IAPN,UAaE;AAAA,MAJC;AAAA,sBACD,MAEkB,sBAFlB;AAAA,QAAsB,SAAO;AAAA,QAA7B,0BACE,MAAC,kBAAD;AAAA,UAAiB,WAAU;AAAA,SAAoB;AAAA,OAC/C;AAAA;AAAA,GACF;AAAA;AAIN,SAAS,aAAa;AAAA,EACpB;AAAA,EACA;AAAA,EACA,WAAW;AAAA,KACR;AAAA,GACoD;AAAA,EACvD,uBACE,MAwBkB,wBAxBlB;AAAA,8BACE,MAsBkB,yBAtBlB;AAAA,MACE,aAAU;AAAA,MACV,WAAW,GACT,ijBACA,aAAa,YACX,mIACF,SACF;AAAA,MACA;AAAA,SACI;AAAA,MATN,UAsBE;AAAA,wBAXA,MAAC,sBAAD,EAAsB;AAAA,wBACtB,MAQkB,0BARlB;AAAA,UACE,WAAW,GACT,OACA,aAAa,YACX,qGACJ;AAAA,UALF;AAAA,SAQE;AAAA,wBACF,MAAC,wBAAD,EAAwB;AAAA;AAAA,KACxB;AAAA,GACF;AAAA;AAiBN,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AAAA,KACG;AAAA,GACiD;AAAA,EACpD,uBACE,MAckB,sBAdlB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,6aACA,SACF;AAAA,OACI;AAAA,IANN,UAcE;AAAA,sBANA,MAIE,QAJF;AAAA,QAAM,WAAU;AAAA,QAAhB,0BACE,MAEkB,+BAFlB;AAAA,oCACE,MAAC,YAAD;AAAA,YAAW,WAAU;AAAA,WAAS;AAAA,SAC9B;AAAA,OACF;AAAA,sBACF,MAAsD,0BAAtD;AAAA;AAAA,OAAsC;AAAA;AAAA,GACtC;AAAA;AAiBN,SAAS,oBAAoB;AAAA,EAC3B;AAAA,KACG;AAAA,GAC2D;AAAA,EAC9D,uBACE,MASkB,gCATlB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,wDACA,SACF;AAAA,OACI;AAAA,IANN,0BAQE,MAAC,eAAD;AAAA,MAAe,WAAU;AAAA,KAAS;AAAA,GAClC;AAAA;AAIN,SAAS,sBAAsB;AAAA,EAC7B;AAAA,KACG;AAAA,GAC6D;AAAA,EAChE,uBACE,MASkB,kCATlB;AAAA,IACE,aAAU;AAAA,IACV,WAAW,GACT,wDACA,SACF;AAAA,OACI;AAAA,IANN,0BAQE,MAAC,kBAAD;AAAA,MAAiB,WAAU;AAAA,KAAS;AAAA,GACpC;AAAA;;ACtKN;;;ACAA;;AAIA,SAAS,eAAe;AAAA,EACtB,gBAAgB;AAAA,KACb;AAAA,GACsD;AAAA,EACzD,uBACE,MAAkB,2BAAlB;AAAA,IACE,aAAU;AAAA,IACV;AAAA,OACI;AAAA,GACN;AAAA;AAIJ,SAAS,OAAO;AAAA,KACX;AAAA,GACkD;AAAA,EACrD,uBACE,MAEE,iBAFF;AAAA,8BACE,MAAkB,uBAAlB;AAAA,MAAuB,aAAU;AAAA,SAAc;AAAA,KAAO;AAAA,GACtD;AAAA;AAIN,SAAS,cAAc;AAAA,KAClB;AAAA,GACqD;AAAA,EACxD,uBAAO,MAAkB,0BAAlB;AAAA,IAA0B,aAAU;AAAA,OAAsB;AAAA,GAAO;AAAA;AAG1E,SAAS,cAAc;AAAA,EACrB;AAAA,EACA,aAAa;AAAA,EACb;AAAA,KACG;AAAA,GACqD;AAAA,EACxD,uBACE,MAamB,yBAbnB;AAAA,8BACE,MAWmB,0BAXnB;AAAA,MACE,aAAU;AAAA,MACV;AAAA,MACA,WAAW,GACT,0aACA,SACF;AAAA,SACI;AAAA,MAPN,UAWE;AAAA,QAFC;AAAA,wBACD,MAAkB,wBAAlB;AAAA,UAAwB,WAAU;AAAA,SAA+F;AAAA;AAAA,KACjI;AAAA,GACF;AAAA;;AChDN;;;ACHA;AACA;AAEA;AAAA;AAEA,IAAM,uBAAuB,CAC3B,kBACA,mBACG;AAAA,EACH,IAAI,oBAAoB,gBAAgB;AAAA,IACtC,OAAO;AAAA,EACT;AAAA,EACA,IAAI,kBAAkB;AAAA,IACpB,OAAO;AAAA,EACT;AAAA,EACA,IAAI,gBAAgB;AAAA,IAClB,OAAO;AAAA,EACT;AAAA,EACA,OAAO;AAAA;AAGT,SAAS,wBAAwB;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,GAOb;AAAA,EACD,QAAQ,cAAc,aAAa,mBAAmB,uBACpD,mBAAmB;AAAA,EACrB,QAAQ,YAAY,WAAW,YAAY,eAAe,aAAa;AAAA,IACrE,IAAI;AAAA,IACJ,MAAM;AAAA,MACJ;AAAA,MACA,MAAM;AAAA,IACR;AAAA,IACA,UAAU,eAAe;AAAA,EAC3B,CAAC;AAAA,EAGD,MAAM,sBAAsB,MAAM;AAAA,IAEhC,MAAM,gBAAgB;AAAA,IAItB,MAAM,mBAAmB,cAAc;AAAA,IACvC,MAAM,iBAAiB,cAAc;AAAA,IAErC,uBACE,MA8BE,OA9BF;AAAA,MACE,WAAW,GACT,MAAM,mBAAmB,eACzB,MAAM,SAAS,cACf,kFACA,qBAAqB,kBAAkB,cAAc,CACvD;AAAA,MACA,OAAO,EAAE,iBAAiB,MAAM,iBAAiB,OAAO,MAAM,MAAM;AAAA,MAPtE,UA8BE;AAAA,QApBC,oCACC,MAAyE,OAAzE;AAAA,UAAK,WAAU;AAAA,SAA0D;AAAA,wBAI3E,MASE,KATF;AAAA,UACE,WAAW,GACT,+CAEA,oBAAoB,QACpB,kBAAkB,MACpB;AAAA,UANF,UAQG,MAAM;AAAA,SACP;AAAA,QAGD,kCACC,MAA0E,OAA1E;AAAA,UAAK,WAAU;AAAA,SAA2D;AAAA;AAAA,KAE5E;AAAA;AAAA,EAIN,uBACE,MAiCE,iBAjCF;AAAA,IAAiB,MAAK;AAAA,IAAtB,0BACE,MA+BE,OAAO,KA/BT;AAAA,MAEE,KAAK;AAAA,SACD;AAAA,SACA;AAAA,MACJ,SAAS,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,MAC9B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,MAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,MAC3B,QAAM;AAAA,MACN,UAAU;AAAA,MACV,YAAY,EAAE,UAAU,KAAK,MAAM,YAAY;AAAA,MAC/C,WAAW,GACT,0BACA,eAAe,qBACX,oBACE,mBACA,mBACF,eACJ,gBACI,eAAe,uBACjB,6BACF,SACF;AAAA,MACA;AAAA,MACA,SAAS,CAAC,MAAM;AAAA,QACd,EAAE,gBAAgB;AAAA,QAClB,aAAa,KAAK;AAAA;AAAA,MA1BtB,UA8BG,cAAc,YAAY,KAAK,oBAAI,MAAC,qBAAD,EAAqB;AAAA,OA7BpD,SA8BL;AAAA,GACF;AAAA;AAIC,IAAM,iBAAiB,KAC5B,0BACA,CAAC,WAAW,cAAc;AAAA,EAExB,OACE,UAAU,cAAc,UAAU,aAClC,UAAU,gBAAgB,UAAU,eACpC,UAAU,cAAc,UAAU,aAClC,UAAU,UAAU,UAAU;AAAA,CAGpC;;;;AD3HO,IAAM,iBAAgD,GAAG,UAAU;AAAA,EACxE,OAAO,YAAY,iBAAiB,SAAS,KAAK;AAAA,EAClD,OAAO,mBAAmB,wBACxB,SAAmC,IAAI;AAAA,EACzC,QAAQ,aAAa,mBAAmB,mBAAmB;AAAA,EAE3D,oBAAoB,KAAK,OAAO;AAAA,IAC9B,MAAM,MAAM,cAAc,IAAI;AAAA,IAC9B,OAAO,MAAM,cAAc,KAAK;AAAA,IAChC,sBAAsB,CAAC,cACrB,qBAAqB,SAAS;AAAA,EAClC,EAAE;AAAA,EAGF,MAAM,kBAAkB,YAAY,QAAQ,OAAO;AAAA,EAInD,IAAI,6BAA6B,gBAAgB,MAAM;AAAA,EACvD,OAAO,2BAA2B,IAAI,MAAM,gBAAgB;AAAA,IAC1D,6BAA6B,2BAA2B,SAAS,GAAG,KAAK;AAAA,EAC3E;AAAA,EAEA,uBACE,MAqBE,QArBF;AAAA,IAAQ,MAAM;AAAA,IAAY,cAAc;AAAA,IAAxC,0BACE,MAmBE,eAnBF;AAAA,MAAe,WAAU;AAAA,MAAzB,UAmBE;AAAA,wBAlBA,MAIE,cAJF;AAAA,oCACE,MAEE,aAFF;AAAA,sBACG,qBAAqB,kBAAkB,IAAI,OAAO,cAAc;AAAA,WACjE;AAAA,SACF;AAAA,wBACF,MAYE,OAZF;AAAA,UAAK,WAAU;AAAA,UAAf,UACG,qBACC,kBAAkB,OAAO,IAAI,CAAC,UAAU;AAAA,YACtC,uBACE,MAAC,gBAAD;AAAA,cACE,WAAW,4BAA4B,MAAM;AAAA,cAE7C;AAAA,cACA,WAAU;AAAA,eAFL,MAAM,EAGb;AAAA,WAEH;AAAA,SACH;AAAA;AAAA,KACF;AAAA,GACF;AAAA;;;AE9DN;;;ACDA;;AAiBO,SAAS,aAAa;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe;AAAA,GACM;AAAA,EACrB,QAAQ,aAAa,oBAAoB,qBACvC,mBAAmB;AAAA,EACrB,QAAQ,QAAQ,eAAe,aAAa;AAAA,IAC1C;AAAA,IACA,MAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,IACA,UAAU;AAAA,EACZ,CAAC;AAAA,EAED,MAAM,kBAAkB,CAAC,MAAwB;AAAA,IAC/C,EAAE,gBAAgB;AAAA,IAClB,IAAI,kBAAkB;AAAA,MACpB;AAAA,IACF;AAAA,IAEA,MAAM,YAAY,KAAK,KAAK,QAAQ,CAAC,EAAE,OAAO,UAAU,CAAC;AAAA,IACzD,IAAI,UAAU,UAAU,MAAM;AAAA,IAC9B,IAAI,SAAS,aAAa,WAAW,WAAW;AAAA,MAC9C,UAAU,QAAQ,KAAK,IAAI,EAAE,OAAO,SAAS,EAAE;AAAA,IACjD,EAAO,SAAI,SAAS,WAAW;AAAA,MAC7B,UAAU,QAAQ,KAAK,OAAO,CAAC,EAAE,OAAO,CAAC;AAAA,IAC3C,EAAO;AAAA,MACL,UAAU,QAAQ,KAAK,EAAE,EAAE,OAAO,EAAE;AAAA;AAAA,IAGtC,YAAY,WAAW,OAAO;AAAA;AAAA,EAGhC,uBACE,MAYE,OAZF;AAAA,IACE,KAAK;AAAA,IACL,eAAa;AAAA,IACb,WAAW,GACT,WACA,WAAW,sBAAsB,aACjC,mBAAmB,mBAAmB,gBACxC;AAAA,IACA,SAAS;AAAA,IACT;AAAA,IATF;AAAA,GAYE;AAAA;;;;AD1DC,IAAM,UAAkC;AAAA,EAC7C;AAAA,EACA;AAAA,EACA,YAAY;AAAA,MACR;AAAA,EACJ,MAAM,qBAAqB,OAAM,OAI9B,IAAI;AAAA,EACP;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,eAAe;AAAA,IACf;AAAA,MACE,mBAAmB;AAAA,EACvB,MAAM,cAAc,sBAClB,IAAI,QAAQ,KAAK,GACjB,IAAI,MAAM,KAAK,CACjB;AAAA,EAGA,MAAM,kBAAkB,YAAY,QAAQ,OAAO;AAAA,EAInD,IAAI,6BAA6B,gBAAgB,MAAM;AAAA,EACvD,OAAO,2BAA2B,IAAI,MAAM,gBAAgB;AAAA,IAC1D,6BAA6B,2BAA2B,SAAS,GAAG,KAAK;AAAA,EAC3E;AAAA,EAGA,MAAM,gBAAgB,CAAC,MAAkB,WAA4B;AAAA,IACnE,mBAAmB,SAAS,qBAAqB;AAAA,MAC/C;AAAA,MACA;AAAA,IACF,CAAC;AAAA,IACD,mBAAmB,SAAS,KAAK;AAAA;AAAA,EAGnC,MAAM,UAAU,IAAI,OAAO,qBAAM,GAAG,KAAK;AAAA,EACzC,MAAM,iBAAiB,IAAI,MAAM,MAAM,YAAY,MAAM;AAAA,EACzD,MAAM,eAAe,UAAU;AAAA,EAE/B,MAAM,oBAAoB,YAAY,SAAS;AAAA,EAC/C,MAAM,kBAAkB,oBAAoB;AAAA,EAE5C,uBACE;AAAA,cAkEE;AAAA,sBAjEA,MA6DE,eA7DF;AAAA,QACE,IAAI,YAAY,IAAI,OAAO,YAAY;AAAA,QACvC,MAAK;AAAA,QACL,eAAa,YAAY,IAAI,OAAO,YAAY;AAAA,QAChD,MAAM;AAAA,QACN,WAAW,GACT,kEACC,kBAAkB,sCACnB,gBAAgB,cAChB,SACF;AAAA,QAVF,0BAeE,MA6CE,OA7CF;AAAA,UAAK,WAAU;AAAA,UAAf,UA6CE;AAAA,4BA3CA,MASE,OATF;AAAA,cACE,WAAW,GACT,+EACA,WAAW,gDACb;AAAA,cAJF,UAMG,KAAK,eAAe,eAAe,EAAE,KAAK,UAAU,CAAC,EAAE,OACtD,IAAI,OAAO,CACb;AAAA,aACA;AAAA,YAGD,YAAY,MAAM,GAAG,YAAY,EAAE,IAAI,CAAC,OAAO,6BAC9C,MAAC,OAAD;AAAA,cAEE,WAAU;AAAA,cACV,eAAa,OAAO;AAAA,eAFf,SAAS,UAGhB,CACD;AAAA,YAGA,mCACC,MAmBE,OAnBF;AAAA,cACE,WAAU;AAAA,cACV,SAAS,CAAC,MAAM;AAAA,gBACd,EAAE,gBAAgB;AAAA,gBAElB,cAAc,KAAK,WAAW;AAAA;AAAA,cAEhC,WAAW,CAAC,MAAM;AAAA,gBAChB,IAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,KAAK;AAAA,kBACtC,EAAE,eAAe;AAAA,kBACjB,EAAE,gBAAgB;AAAA,kBAClB,cAAc,KAAK,WAAW;AAAA,gBAChC;AAAA;AAAA,cAEF,UAAU;AAAA,cAEV,MAAK;AAAA,cAhBP,UAmBE;AAAA,gBAnBF;AAAA,gBAkBI;AAAA,gBAlBJ;AAAA,gBAkBwB,EAAE,MAAM;AAAA;AAAA,aAC9B;AAAA;AAAA,SAEJ;AAAA,OACF;AAAA,sBAGF,MAAC,gBAAD;AAAA,QAAgB,KAAK;AAAA,OAAoB;AAAA;AAAA,GACzC;AAAA;;;AEpIN,4BAAS,4BAAiB;AAC1B;;AASO,IAAM,cAA0C,GAAG,gBAAgB;AAAA,EACxE;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MACE,mBAAmB;AAAA,EAGvB,MAAM,WAAW,QAAQ,MAAM;AAAA,IAC7B,MAAM,OAAO,qBAAM,SAAS,EAAE,IAAI,CAAC,QAAQ,IAAI,YAAY,CAAC;AAAA,IAC5D,MAAM,YAAY,qBAAM,cAAc,EAAE,IAAI,CAAC,QAAQ,IAAI,YAAY,CAAC;AAAA,IAGtE,SAAS,IAAI,EAAG,IAAI,gBAAgB,KAAK;AAAA,MACvC,MAAM,YAAY,KAAK,MAAM;AAAA,MAC7B,MAAM,iBAAiB,UAAU,MAAM;AAAA,MACvC,IAAI,WAAW;AAAA,QACb,KAAK,KAAK,SAAS;AAAA,MACrB;AAAA,MACA,IAAI,gBAAgB;AAAA,QAClB,UAAU,KAAK,cAAc;AAAA,MAC/B;AAAA,IACF;AAAA,IAEA,OAAO,EAAE,MAAM,UAAU;AAAA,KAExB,CAAC,gBAAgB,aAAa,CAAC;AAAA,EAElC,uBACE,MA+BE,OA/BF;AAAA,IACE,WAAW,GACT,6BACA,oBAAoB,qBACpB,qBACA,SACF;AAAA,IACA,eAAY;AAAA,IAPd,UASG,SAAS,KAAK,IAAI,CAAC,SAAS,0BAC3B,MAmBE,kBAnBF;AAAA,MAA+B,MAAK;AAAA,MAApC,0BACE,MAiBE,QAAO,KAjBT;AAAA,QAEE,SAAS,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,QAC9B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,QAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,QAC3B,YAAY;AAAA,UACV,UAAU;AAAA,UACV,MAAM;AAAA,UACN,OAAO,QAAQ;AAAA,QACjB;AAAA,QACA,WAAU;AAAA,QACV,eAAa,kBAAkB;AAAA,QAXjC,UAiBE;AAAA,0BAJA,MAAsD,QAAtD;AAAA,YAAM,WAAU;AAAA,YAAhB,UAA4C;AAAA,WAAU;AAAA,0BACtD,MAEE,QAFF;AAAA,YAAM,WAAU;AAAA,YAAhB,UACG,SAAS,UAAU;AAAA,WACpB;AAAA;AAAA,SAfG,OAgBL;AAAA,OAlBkB,OAmBpB,CACH;AAAA,GACD;AAAA;;;ACrEC,IAAM,uBAAuB;AAC7B,IAAM,oBAAoB;AAC1B,IAAM,mBAAmB;AAEzB,IAAM,uBAAiD;AAAA,EAC5D,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,UAAU;AACZ;;;ACOO,IAAM,yBAAyB;AAAA,EACpC;AAAA,MACiC;AAAA,EACjC,QAAQ,uBAAuB,iBAAiB,mBAAmB;AAAA,EAEnE,MAAM,YAAY,KAAK,GAAG,QAAQ,KAAK;AAAA,EACvC,MAAM,UAAU,KAAK,GAAG,MAAM,KAAK;AAAA,EAGnC,MAAM,aAAa,sBAAsB,WAAW,OAAO;AAAA,EAG3D,MAAM,iBAAiB,WAAW,OAChC,CAAC,MAAM,EAAE,IAAI,KAAK,EAAE,OAAO,KAAK,IAAI,CACtC;AAAA,EACA,MAAM,kBAAkB,WAAW,OACjC,CAAC,MAAM,EAAE,IAAI,KAAK,EAAE,OAAO,KAAK,MAAM,CACxC;AAAA,EAGA,MAAM,iBAAiB,CAAC,GAAG,cAAc,EAAE,KAAK,CAAC,GAAG,MAAM;AAAA,IACxD,MAAM,YAAY,EAAE,MAAM,KAAK,EAAE,KAAK;AAAA,IACtC,IAAI,cAAc,GAAG;AAAA,MACnB,OAAO;AAAA,IACT;AAAA,IACA,OAAO,EAAE,IAAI,KAAK,EAAE,KAAK,IAAI,EAAE,IAAI,KAAK,EAAE,KAAK;AAAA,GAChD;AAAA,EAGD,MAAM,kBAAkB,CAAC,GAAG,eAAe,EAAE,KAAK,CAAC,GAAG,MACpD,EAAE,MAAM,KAAK,EAAE,KAAK,CACtB;AAAA,EAGA,MAAM,OAA4D,CAAC;AAAA,EACnE,SAAS,MAAM,EAAG,MAAM,cAAc,OAAO;AAAA,IAC3C,KAAK,OAAO,CAAC;AAAA,IACb,SAAS,MAAM,EAAG,MAAM,GAAG,OAAO;AAAA,MAChC,KAAK,KAAK,OAAO,EAAE,OAAO,OAAO,OAAO,KAAK;AAAA,IAC/C;AAAA,EACF;AAAA,EAEA,MAAM,kBAAoC,CAAC;AAAA,EAG3C,WAAW,SAAS,gBAAgB;AAAA,IAClC,MAAM,aAAa,qBAAM,IAAI,MAAM,MAAM,QAAQ,KAAK,GAAG,SAAS;AAAA,IAClE,MAAM,WAAW,qBAAM,IAAI,MAAM,IAAI,QAAQ,KAAK,GAAG,OAAO;AAAA,IAC5D,MAAM,WAAW,KAAK,IAAI,GAAG,WAAW,KAAK,WAAW,KAAK,CAAC;AAAA,IAC9D,MAAM,SAAS,KAAK,IAAI,GAAG,SAAS,KAAK,WAAW,KAAK,CAAC;AAAA,IAG1D,MAAM,mBAAmB,MAAM,MAAM,QAAQ,KAAK,EAAE,SAAS,SAAS;AAAA,IACtE,MAAM,iBAAiB,MAAM,IAAI,QAAQ,KAAK,EAAE,QAAQ,OAAO;AAAA,IAG/D,IAAI,qBAAqB;AAAA,IAGzB,IAAI,cAAc;AAAA,IAClB,SAAS,MAAM,EAAG,MAAM,cAAc,OAAO;AAAA,MAC3C,IAAI,WAAW;AAAA,MACf,SAAS,MAAM,SAAU,OAAO,QAAQ,OAAO;AAAA,QAC7C,IAAI,KAAK,KAAK,KAAK,OAAO;AAAA,UACxB,WAAW;AAAA,UACX;AAAA,QACF;AAAA,MACF;AAAA,MACA,IAAI,UAAU;AAAA,QACZ,cAAc;AAAA,QACd;AAAA,MACF;AAAA,IACF;AAAA,IAGA,IAAI,gBAAgB,IAAI;AAAA,MACtB,SAAS,MAAM,SAAU,OAAO,QAAQ,OAAO;AAAA,QAC7C,KAAK,aAAa,OAAO,EAAE,OAAO,MAAM,MAAM;AAAA,MAChD;AAAA,MAGA,MAAM,WAAW,SAAS,WAAW;AAAA,MACrC,gBAAgB,KAAK;AAAA,QACnB,MAAO,WAAW,IAAK;AAAA,QACvB,OAAQ,WAAW,IAAK;AAAA,QACxB,KACE,oBACA,uBACA,eAAe,mBAAmB;AAAA,QACpC,QAAQ;AAAA,QACR,UAAU;AAAA,WACP;AAAA,QACH;AAAA,QACA;AAAA,MACF,CAAmB;AAAA,MACnB,qBAAqB;AAAA,IACvB;AAAA,IAGA,KAAK,oBAAoB;AAAA,MACvB,SACM,cAAc,WAAW,EAC7B,eAAe,QACf,eACA;AAAA,QAEA,IAAI,uBAAuB;AAAA,QAC3B,SAAS,MAAM,EAAG,MAAM,cAAc,OAAO;AAAA,UAC3C,IAAI,WAAW;AAAA,UACf,SAAS,MAAM,YAAa,OAAO,QAAQ,OAAO;AAAA,YAChD,IAAI,KAAK,KAAK,KAAK,OAAO;AAAA,cACxB,WAAW;AAAA,cACX;AAAA,YACF;AAAA,UACF;AAAA,UACA,IAAI,UAAU;AAAA,YACZ,uBAAuB;AAAA,YACvB;AAAA,UACF;AAAA,QACF;AAAA,QAGA,IAAI,yBAAyB,IAAI;AAAA,UAC/B,SAAS,MAAM,YAAa,OAAO,QAAQ,OAAO;AAAA,YAChD,KAAK,sBAAsB,OAAO,EAAE,OAAO,MAAM,MAAM;AAAA,UACzD;AAAA,UAGA,MAAM,oBAAoB,SAAS,cAAc;AAAA,UACjD,gBAAgB,KAAK;AAAA,YACnB,MAAO,cAAc,IAAK;AAAA,YAC1B,OAAQ,oBAAoB,IAAK;AAAA,YACjC,KACE,oBACA,uBACA,wBAAwB,mBAAmB;AAAA,YAC7C,QAAQ;AAAA,YACR,UAAU;AAAA,eACP;AAAA,YACH,kBAAkB;AAAA,YAClB;AAAA,UACF,CAAmB;AAAA,UACnB,qBAAqB;AAAA,UACrB;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAGA,WAAW,SAAS,iBAAiB;AAAA,IACnC,MAAM,aAAa,qBAAM,IAAI,MAAM,MAAM,QAAQ,KAAK,GAAG,SAAS;AAAA,IAClE,MAAM,MAAM,KAAK,IAAI,GAAG,WAAW,KAAK,WAAW,KAAK,CAAC;AAAA,IAGzD,MAAM,mBAAmB;AAAA,IACzB,MAAM,iBAAiB;AAAA,IAGvB,IAAI,cAAc;AAAA,IAClB,SAAS,MAAM,EAAG,MAAM,cAAc,OAAO;AAAA,MAC3C,KAAK,KAAK,KAAK,KAAK,OAAO;AAAA,QACzB,cAAc;AAAA,QACd;AAAA,MACF;AAAA,IACF;AAAA,IAGA,IAAI,gBAAgB,IAAI;AAAA,MACtB,KAAK,aAAa,OAAO,EAAE,OAAO,MAAM,MAAM;AAAA,MAG9C,gBAAgB,KAAK;AAAA,QACnB,MAAO,MAAM,IAAK;AAAA,QAClB,OAAQ,IAAI,IAAK;AAAA,QACjB,KACE,oBACA,uBACA,eAAe,mBAAmB;AAAA,QACpC,QAAQ;AAAA,QACR,UAAU;AAAA,WACP;AAAA,QACH;AAAA,QACA;AAAA,MACF,CAAmB;AAAA,IACrB;AAAA,EACF;AAAA,EAEA,OAAO;AAAA;;;;ACxMF,IAAM,kBAAkD,GAAG,WAAW;AAAA,EAC3E,MAAM,YAAY,KAAK;AAAA,EACvB,MAAM,sBAAsB,uBAAuB,EAAE,KAAK,CAAC;AAAA,EAE3D,uBACE,MA0BE,OA1BF;AAAA,IAAK,WAAU;AAAA,IAAf,UACG,oBAAoB,IAAI,CAAC,UAAU;AAAA,MAClC,uBACE,MAoBE,OApBF;AAAA,QAIE,WAAU;AAAA,QACV,OAAO;AAAA,UACL,MAAM,QAAQ,MAAM;AAAA,UACpB,OAAO,QAAQ,MAAM;AAAA,UACrB,KAAK,GAAG,MAAM;AAAA,UACd,QAAQ,GAAG;AAAA,QACb;AAAA,QACA,eAAa,0BAA0B,MAAM;AAAA,QAX/C,0BAaE,MAAC,gBAAD;AAAA,UACE,WAAW,SAAS,MAAM,MACxB,MAAM,YACJ,UAAU,OAAO,YAAY;AAAA,UACjC;AAAA,UACA,WAAU;AAAA,SACZ;AAAA,SAlBK,SAAS,MAAM,MAAM,MAAM,YAAY,UAAU,OACpD,YACF,GAiBA;AAAA,KAEL;AAAA,GACD;AAAA;;;;AxB7BC,IAAM,YAAsC,GAAG,eAAe,QAAQ;AAAA,EAC3E,MAAM,qBAAqB,OAAM,OAI9B,IAAI;AAAA,EACP,QAAQ,aAAa,mBAAmB,mBAAmB;AAAA,EAG3D,MAAM,kBAAkB,YAAY,QAAQ,OAAO;AAAA,EAInD,IAAI,6BAA6B,gBAAgB,MAAM;AAAA,EACvD,OAAO,2BAA2B,IAAI,MAAM,gBAAgB;AAAA,IAC1D,6BAA6B,2BAA2B,SAAS,GAAG,KAAK;AAAA,EAC3E;AAAA,EAIA,MAAM,eAAe,SAAQ,MAAM;AAAA,IAEjC,MAAM,OAAwB,CAAC,CAAC,CAAC;AAAA,IACjC,IAAI,MAAM,2BAA2B,MAAM;AAAA,IAC3C,SAAS,IAAI,EAAG,IAAI,IAAI,KAAK;AAAA,MAC3B,IAAI,KAAK,KAAK,SAAS,GAAG,WAAW,GAAG;AAAA,QACtC,KAAK,KAAK,CAAC,CAAC;AAAA,MACd;AAAA,MACA,KAAK,KAAK,SAAS,GAAG,KAAK,GAAG;AAAA,MAC9B,MAAM,IAAI,IAAI,GAAG,KAAK;AAAA,IACxB;AAAA,IACA,OAAO;AAAA,KACN,CAAC,0BAA0B,CAAC;AAAA,EAE/B,uBACE,OAoDE,OApDF;AAAA,IAAK,WAAU;AAAA,IAAuB,eAAY;AAAA,IAAlD,UAoDE;AAAA,sBAlDA,MAAC,aAAD;AAAA,QAAa,WAAU;AAAA,OAAW;AAAA,sBAGlC,MA2CE,YA3CF;AAAA,QACE,WAAU;AAAA,QACV,eAAY;AAAA,QACZ,eAAe,EAAE,WAAW,kCAAkC;AAAA,QAHhE,0BAKE,MAqCE,kBArCF;AAAA,UAAiB,MAAK;AAAA,UAAtB,0BACE,MAmCE,QAAO,KAnCT;AAAA,YAEE,SAAS,EAAE,SAAS,EAAE;AAAA,YACtB,SAAS,EAAE,SAAS,EAAE;AAAA,YACtB,MAAM,EAAE,SAAS,EAAE;AAAA,YACnB,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,YAChD,WAAU;AAAA,YACV,eAAY;AAAA,YAPd,UAUG,aAAa,IAAI,CAAC,MAAM,UAAU;AAAA,cACjC,uBACE,OAoBE,OApBF;AAAA,gBAEE,WAAU;AAAA,gBACV,eAAa,YAAY;AAAA,gBAH3B,UAoBE;AAAA,kBAfC,KAAK,IAAI,CAAC,KAAK,aAAa;AAAA,oBAC3B,uBACE,MAAC,SAAD;AAAA,sBACE,OAAO;AAAA,sBACP;AAAA,sBACA;AAAA,sBAEA,WAAU;AAAA,uBADL,IAAI,OAAO,YAAY,CAE9B;AAAA,mBAEH;AAAA,kCAED,MAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,0BACE,MAAC,iBAAD;AAAA,sBAAiB;AAAA,qBAAY;AAAA,mBAC7B;AAAA;AAAA,iBAlBG,QAAQ,OAmBb;AAAA,aAEL;AAAA,aAjCI,YAAY,OAAO,YAAY,CAkCpC;AAAA,SACF;AAAA,OACF;AAAA,sBAGF,MAAC,gBAAD;AAAA,QAAgB,KAAK;AAAA,OAAoB;AAAA;AAAA,GACzC;AAAA;;;AyBhGN;;;ACAA,oBAAgB;;AAMT,IAAM,gBAA0B,MAAM;AAAA,EAC3C,QAAQ,aAAa,uBAAuB,mBAC1C,mBAAmB;AAAA,EAGrB,MAAM,cAAc,YAAY,QAAQ,MAAM,EAAE,IAAI,cAAc;AAAA,EAElE,MAAM,sBAAsB,YAAY,SAAS,WAAW,IACxD,YAAY,SAAS,GAAG,MAAM,IAC9B;AAAA,EACJ,MAAM,YAAY,oBAAoB,IAAI,GAAG,KAAK;AAAA,EAGlD,MAAM,WAAW,CAAC;AAAA,EAClB,SAAS,IAAI,EAAG,IAAI,GAAG,KAAK;AAAA,IAC1B,SAAS,KAAK,oBAAoB,IAAI,GAAG,KAAK,CAAC;AAAA,EACjD;AAAA,EAGA,MAAM,oBAAoB,oBAAoB,SAAS,GAAG,KAAK;AAAA,EAC/D,MAAM,kBAAkB,UAAU,IAAI,GAAG,KAAK;AAAA,EAC9C,MAAM,aAAa,sBAAsB,mBAAmB,eAAe;AAAA,EAG3E,MAAM,eAAe,WAAW,OAAO,CAAC,UAAU,MAAM,MAAM;AAAA,EAG9D,QAAQ,0BAA0B,SAAQ,MAAM;AAAA,IAE9C,MAAM,eAAe,CAAC,GAAG,YAAY,EAAE,KAAK,CAAC,GAAG,MAAM;AAAA,MAEpD,MAAM,YAAY,EAAE,MAAM,KAAK,EAAE,KAAK;AAAA,MACtC,IAAI,cAAc,GAAG;AAAA,QACnB,OAAO;AAAA,MACT;AAAA,MAGA,MAAM,YAAY,EAAE,IAAI,KAAK,EAAE,KAAK;AAAA,MACpC,MAAM,YAAY,EAAE,IAAI,KAAK,EAAE,KAAK;AAAA,MACpC,OAAO,YAAY;AAAA,KACpB;AAAA,IAGD,MAAM,OAAuD,CAAC;AAAA,IAC9D,MAAM,kBAA4C,CAAC;AAAA,IAEnD,aAAa,QAAQ,CAAC,UAAU;AAAA,MAE9B,MAAM,aAAa,MAAM,MAAM,SAAS,mBAAmB,IACvD,sBACA,MAAM;AAAA,MACV,MAAM,WAAW,MAAM,IAAI,QAAQ,SAAS,IAAI,YAAY,MAAM;AAAA,MAGlE,MAAM,gBAAgB,KAAK,IACzB,GACA,WAAW,KAAK,qBAAqB,KAAK,CAC5C;AAAA,MACA,MAAM,cAAc,KAAK,IAAI,GAAG,SAAS,KAAK,qBAAqB,KAAK,CAAC;AAAA,MAEzE,MAAM,OAAQ,gBAAgB,IAAK;AAAA,MACnC,MAAM,SAAU,cAAc,gBAAgB,KAAK,IAAK;AAAA,MAGxD,IAAI,WAAW;AAAA,MACf,IAAI,SAAS;AAAA,MAEb,QAAQ,QAAQ;AAAA,QACd,IAAI,YAAY,KAAK,QAAQ;AAAA,UAE3B,KAAK,KAAK,CAAC,CAAC;AAAA,UACZ,SAAS;AAAA,QACX,EAAO;AAAA,UAEL,MAAM,MAAM,KAAK;AAAA,UACjB,MAAM,SAAS,IAAI,MAAM,CAAC,SAAS;AAAA,YACjC,OACE,WAAW,QAAQ,KAAK,GAAG,KAC3B,SAAS,SAAS,KAAK,MAAM,KAAK;AAAA,WAErC;AAAA,UAED,IAAI,QAAQ;AAAA,YACV,SAAS;AAAA,UACX,EAAO;AAAA,YACL;AAAA;AAAA;AAAA,MAGN;AAAA,MAGA,KAAK,UAAU,KAAK,EAAE,KAAK,UAAU,MAAM,CAAC;AAAA,MAG5C,gBAAgB,KAAK;AAAA,WAChB;AAAA,QACH;AAAA,QACA;AAAA,QACA,KAAK,YAAY,mBAAmB;AAAA,QACpC,QAAQ;AAAA,QACR,QAAQ;AAAA,MACV,CAAC;AAAA,KACF;AAAA,IAED,OAAO;AAAA,MACL,uBAAuB;AAAA,MACvB,iBAAiB,KAAK,IAAI,GAAG,KAAK,MAAM;AAAA,IAC1C;AAAA,KACC,CAAC,cAAc,qBAAqB,SAAS,CAAC;AAAA,EAEjD,uBACE,OA4CE,OA5CF;AAAA,IACE,WAAU;AAAA,IACV,eAAY;AAAA,IAFd,UA4CE;AAAA,sBAvCA,MAIE,OAJF;AAAA,QAAK,WAAU;AAAA,QAAf,0BACE,MAEE,QAFF;AAAA,UAAM,WAAU;AAAA,UAAhB;AAAA,SAEE;AAAA,OACF;AAAA,MAGD,SAAS,IAAI,CAAC,wBACb,MAAC,eAAD;AAAA,QAEE,IAAI,gBAAgB,IAAI,OAAO,YAAY;AAAA,QAC3C,MAAK;AAAA,QACL,MAAM;AAAA,QACN,WAAU;AAAA,SAJL,WAAW,IAAI,OAAO,YAAY,GAKzC,CACD;AAAA,sBAGD,MAoBE,OApBF;AAAA,QAAK,WAAU;AAAA,QAAf,UACG,sBAAsB,IAAI,CAAC,OAAO,0BACjC,MAgBE,OAhBF;AAAA,UAEE,WAAU;AAAA,UACV,OAAO;AAAA,YACL,MAAM,GAAG,MAAM;AAAA,YACf,OAAO,QAAQ,MAAM;AAAA,YACrB,KAAK,GAAG,MAAM;AAAA,YACd,QAAQ,GAAG,MAAM;AAAA,UACnB;AAAA,UARF,0BAUE,MAAC,gBAAD;AAAA,YACE,WAAW,WAAW,MAAM,MAAM;AAAA,YAClC;AAAA,YAEA,WAAU;AAAA,aADL,WAAW,MAAM,MAAM,OAE9B;AAAA,WAdK,qBAAqB,MAAM,IAehC,CACH;AAAA,OACD;AAAA;AAAA,GACF;AAAA;;;AChKN,4BAAS,4BAAiB;AAAA;AAOnB,IAAM,aAAwC,GAAG,gBAAgB;AAAA,EACtE;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MACE,mBAAmB;AAAA,EAGvB,MAAM,cAAc,YAAY,QAAQ,MAAM,EAAE,IAAI,cAAc;AAAA,EAElE,MAAM,sBAAsB,YAAY,SAAS,WAAW,IACxD,YAAY,SAAS,GAAG,MAAM,IAC9B;AAAA,EAGJ,MAAM,WAAW,CAAC;AAAA,EAClB,SAAS,IAAI,EAAG,IAAI,GAAG,KAAK;AAAA,IAC1B,SAAS,KAAK,oBAAoB,IAAI,GAAG,KAAK,CAAC;AAAA,EACjD;AAAA,EAEA,uBAEE,OA0DE,OA1DF;AAAA,IACE,WAAW,GACT,iEACA,oBAAoB,qBACpB,qBACA,SACF;AAAA,IACA,eAAY;AAAA,IAPd,UA0DE;AAAA,sBAhDA,MAKE,OALF;AAAA,QAAK,WAAU;AAAA,QAAf,0BACE,OAGE,OAHF;AAAA,UAAK,WAAU;AAAA,UAAf,UAGE;AAAA,4BAFA,MAAsD,QAAtD;AAAA,cAAM,WAAU;AAAA,cAAhB;AAAA,aAAsD;AAAA,4BACtD,MAAoD,QAApD;AAAA,cAAM,WAAU;AAAA,cAAhB,UAA+B,YAAY,KAAK;AAAA,aAAI;AAAA;AAAA,SACpD;AAAA,OACF;AAAA,MAGD,SAAS,IAAI,CAAC,KAAK,UAAU;AAAA,QAC5B,MAAM,UAAU,IAAI,OAAO,qBAAM,GAAG,KAAK;AAAA,QAEzC,uBACE,MAiCE,kBAjCF;AAAA,UAAgD,MAAK;AAAA,UAArD,0BACE,OA+BE,QAAO,KA/BT;AAAA,YAEE,SAAS,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,YAC9B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,YAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,YAC3B,YAAY;AAAA,cACV,UAAU;AAAA,cACV,MAAM;AAAA,cACN,OAAO,QAAQ;AAAA,YACjB;AAAA,YACA,WAAW,GACT,kFACA,WAAW,yBACb;AAAA,YACA,SAAS,MAAM;AAAA,cACb,WAAW,GAAG;AAAA,cACd,cAAc,GAAG;AAAA;AAAA,YAEnB,eAAa,mBAAmB,IAAI,OAAO,MAAM,EAAE,YAAY;AAAA,YAlBjE,UA+BE;AAAA,8BAXA,MAAyD,OAAzD;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAAqC,IAAI,OAAO,KAAK;AAAA,eAAI;AAAA,8BACzD,MASE,OATF;AAAA,gBACE,WAAW,GACT,uGACA,WAAW,oCACb;AAAA,gBAJF,UAMG,KAAK,eAAe,eAAe,EAAE,KAAK,UAAU,CAAC,EAAE,OACtD,IAAI,OAAO,CACb;AAAA,eACA;AAAA;AAAA,aA7BG,IAAI,OAAO,YAAY,CA8B5B;AAAA,WAhCkB,IAAI,OAAO,YAAY,CAiC3C;AAAA,OAEL;AAAA;AAAA,GACD;AAAA;;;AC5FN,oBAAS;AAeF,IAAM,wBAAwB,GAAG,UAAsC;AAAA,EAC5E,QAAQ,0BAA0B,mBAAmB;AAAA,EAErD,MAAM,cAAc,SAA0B,MAAM;AAAA,IAClD,IAAI,eAAe,sBACjB,IAAI,QAAQ,KAAK,GACjB,IAAI,MAAM,KAAK,CACjB;AAAA,IAGA,eAAe,aACZ,OAAO,CAAC,OAAO,EAAE,MAAM,EACvB,SAAS,CAAC,GAAG,MAAM,EAAE,MAAM,KAAK,EAAE,KAAK,CAAC;AAAA,IAE3C,IAAI,aAAa,WAAW,GAAG;AAAA,MAC7B,OAAO,CAAC;AAAA,IACV;AAAA,IAGA,MAAM,WAA8B,CAAC;AAAA,IACrC,IAAI,iBAAkC,CAAC;AAAA,IACvC,IAAI,eAAmC;AAAA,IACvC,WAAW,SAAS,cAAc;AAAA,MAChC,IAAI,gBAAgB,MAAM,MAAM,cAAc,YAAY,GAAG;AAAA,QAC3D,IAAI,eAAe,SAAS,GAAG;AAAA,UAC7B,SAAS,KAAK,cAAc;AAAA,QAC9B;AAAA,QACA,iBAAiB,CAAC;AAAA,MACpB;AAAA,MACA,eAAe,KAAK,KAAK;AAAA,MACzB,eAAe,eACX,qBAAM,IAAI,cAAc,MAAM,GAAG,IACjC,MAAM;AAAA,IACZ;AAAA,IACA,IAAI,eAAe,SAAS,GAAG;AAAA,MAC7B,SAAS,KAAK,cAAc;AAAA,IAC9B;AAAA,IAGA,MAAM,kBAAoC,CAAC;AAAA,IAC3C,WAAW,WAAW,UAAU;AAAA,MAC9B,IAAI,QAAQ,WAAW,GAAG;AAAA,QAExB,MAAM,QAAQ,QAAQ;AAAA,QACtB,MAAM,YAAY,MAAM,MAAM,KAAK,IAAI,MAAM,MAAM,OAAO,IAAI;AAAA,QAC9D,IAAI,UAAU,MAAM,IAAI,KAAK,IAAI,MAAM,IAAI,OAAO,IAAI;AAAA,QACtD,IAAI,UAAU,WAAW;AAAA,UAEvB,UAAU;AAAA,QACZ;AAAA,QACA,MAAM,gBAAgB,UAAU;AAAA,QAChC,MAAM,MAAO,YAAY,KAAM;AAAA,QAC/B,MAAM,SAAU,gBAAgB,KAAM;AAAA,QACtC,gBAAgB,KAAK,KAAK,OAAO,MAAM,GAAG,OAAO,KAAK,KAAK,OAAO,CAAC;AAAA,QACnE;AAAA,MACF;AAAA,MAIA,MAAM,eAAe,CAAC,GAAG,OAAO,EAAE,KAAK,CAAC,GAAG,MAAM;AAAA,QAC/C,MAAM,YAAY,EAAE,IAAI,KAAK,EAAE,OAAO,QAAQ;AAAA,QAC9C,MAAM,YAAY,EAAE,IAAI,KAAK,EAAE,OAAO,QAAQ;AAAA,QAG9C,IAAI,cAAc,WAAW;AAAA,UAC3B,OAAO,YAAY;AAAA,QACrB;AAAA,QAGA,OAAO,EAAE,MAAM,KAAK,EAAE,KAAK;AAAA,OAC5B;AAAA,MAGD,MAAM,cAAc,aAAa;AAAA,MAIjC,IAAI;AAAA,MACJ,IAAI,gBAAgB,GAAG;AAAA,QACrB,YAAY;AAAA,MACd,EAAO,SAAI,gBAAgB,GAAG;AAAA,QAC5B,YAAY;AAAA,MACd,EAAO,SAAI,gBAAgB,GAAG;AAAA,QAC5B,YAAY;AAAA,MACd,EAAO;AAAA,QACL,YAAY;AAAA;AAAA,MAGd,MAAM,iBAAiB,cAAc,IAAI,aAAa,cAAc,KAAK;AAAA,MAEzE,SAAS,IAAI,EAAG,IAAI,aAAa,QAAQ,KAAK;AAAA,QAC5C,MAAM,QAAQ,aAAa;AAAA,QAC3B,MAAM,YAAY,MAAM,MAAM,KAAK,IAAI,MAAM,MAAM,OAAO,IAAI;AAAA,QAC9D,IAAI,UAAU,MAAM,IAAI,KAAK,IAAI,MAAM,IAAI,OAAO,IAAI;AAAA,QAEtD,IAAI,UAAU,WAAW;AAAA,UAEvB,UAAU;AAAA,QACZ;AAAA,QAEA,MAAM,gBAAgB,UAAU;AAAA,QAChC,MAAM,MAAO,YAAY,KAAM;AAAA,QAC/B,MAAM,SAAU,gBAAgB,KAAM;AAAA,QAGtC,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,QAEJ,IAAI,MAAM,GAAG;AAAA,UAEX,OAAO;AAAA,UACP,QAAQ;AAAA,UACR,SAAS;AAAA,QACX,EAAO;AAAA,UAEL,OAAO,iBAAiB;AAAA,UACxB,QAAQ,MAAM;AAAA,UACd,SAAS,IAAI;AAAA;AAAA,QAGf,gBAAgB,KAAK;AAAA,aAChB;AAAA,UACH;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF;AAAA,IAEA,OAAO;AAAA,KACN,CAAC,KAAK,qBAAqB,CAAC;AAAA,EAE/B,OAAO;AAAA;;;;AC9IF,IAAM,iBAAgD;AAAA,EAC3D;AAAA,EACA,eAAe;AAAA,MACX;AAAA,EACJ,MAAM,cAAc,sBAAsB,EAAE,IAAI,CAAC;AAAA,EAEjD,uBACE,MA8BE,OA9BF;AAAA,IACE,eAAa;AAAA,IACb,WAAU;AAAA,IAFZ,UAIG,YAAY,IAAI,CAAC,OAAO,UAAU;AAAA,MACjC,MAAM,oBAAoB,SAAS,MAAM,MAAM,SAAS,IAAI,OAC1D,YACF;AAAA,MACA,MAAM,eAAe,MAAM,IAAI,KAAK,MAAM,OAAO,QAAQ,KAAK;AAAA,MAC9D,uBACE,MAiBE,OAjBF;AAAA,QAEE,WAAU;AAAA,QACV,OAAO;AAAA,UACL,MAAM,GAAG,MAAM;AAAA,UACf,OAAO,QAAQ,MAAM;AAAA,UACrB,KAAK,GAAG,MAAM;AAAA,UACd,QAAQ,GAAG,MAAM;AAAA,QACnB;AAAA,QARF,0BAUE,MAAC,gBAAD;AAAA,UACE,WAAW,aAAa;AAAA,UACxB;AAAA,UACA,WAAW,GAAG,gCAAgC;AAAA,YAC5C,gCAAgC;AAAA,UAClC,CAAC;AAAA,SACH;AAAA,SAfK,aAAa,mBAgBlB;AAAA,KAEL;AAAA,GACD;AAAA;;;;ACzCN,IAAM,QAAQ,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,IAAI,CAAC,SACzD,qBAAM,EAAE,KAAK,IAAI,EAAE,OAAO,CAAC,CAC7B;AAMO,IAAM,aAAwC,GAAG,UAAU;AAAA,EAChE,uBACE,OA4BE,OA5BF;AAAA,IACE,eAAa,gBAAgB,IAAI,OAAO,YAAY;AAAA,IACpD,WAAU;AAAA,IAFZ,UA4BE;AAAA,MAxBC,MAAM,IAAI,CAAC,SAAS;AAAA,QACnB,MAAM,OAAO,KAAK,KAAK;AAAA,QACvB,MAAM,WAAW,IAAI,OAAO,YAAY;AAAA,QAExC,uBACE,MAAC,eAAD;AAAA,UAEE,IAAI,aAAa,YAAY,KAAK,OAAO,IAAI;AAAA,UAC7C,MAAK;AAAA,UACL,MAAM;AAAA,UACN;AAAA,UACA,eAAa,kBAAkB,YAAY,KAAK,OAAO,IAAI;AAAA,UAC3D,WAAW,GACT,gEACF;AAAA,WARK,GAAG,YAAY,KAAK,OAAO,IAAI,GAStC;AAAA,OAEH;AAAA,sBAGD,MAAC,gBAAD;AAAA,QACE,eAAa,mBAAmB,IAAI,OAAO,YAAY;AAAA,QACvD;AAAA,OACF;AAAA;AAAA,GACA;AAAA;;;;ACvCN,IAAM,SAAQ,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,IAAI,CAAC,SACzD,qBAAM,EAAE,KAAK,IAAI,EAAE,OAAO,CAAC,CAC7B;AAEO,IAAM,eAAyB,MAAM;AAAA,EAC1C,QAAQ,aAAa,gBAAgB,kBAAkB,mBAAmB;AAAA,EAG1E,MAAM,cAAc,YAAY,QAAQ,MAAM,EAAE,IAAI,cAAc;AAAA,EAElE,MAAM,sBAAsB,YAAY,SAAS,WAAW,IACxD,YAAY,SAAS,GAAG,MAAM,IAC9B;AAAA,EAGJ,MAAM,WAAW,CAAC;AAAA,EAClB,SAAS,IAAI,EAAG,IAAI,GAAG,KAAK;AAAA,IAC1B,SAAS,KAAK,oBAAoB,IAAI,GAAG,KAAK,CAAC;AAAA,EACjD;AAAA,EAKA,MAAM,aAAa,SAAS,UAAU,CAAC,QAAQ,IAAI,OAAO,qBAAM,GAAG,KAAK,CAAC;AAAA,EACzE,MAAM,gBAAgB,eAAe;AAAA,EAErC,uBACE,OA+CE,OA/CF;AAAA,IACE,eAAY;AAAA,IACZ,WAAU;AAAA,IAFZ,UA+CE;AAAA,sBA1CA,MAmBE,OAnBF;AAAA,QACE,eAAY;AAAA,QACZ,WAAU;AAAA,QAFZ,UAIG,OAAM,IAAI,CAAC,yBACV,MAYE,OAZF;AAAA,UAEE,eAAa,kBAAkB,KAAK,OAAO,IAAI;AAAA,UAC/C,WAAU;AAAA,UAHZ,0BAKE,MAME,QANF;AAAA,YAAM,WAAU;AAAA,YAAhB,UACG,KAAK,eAAe,eAAe;AAAA,cAClC,MAAM;AAAA,cACN,QAAQ;AAAA,cACR,QAAQ;AAAA,YACV,CAAC,EAAE,OAAO,KAAK,OAAO,CAAC;AAAA,WACvB;AAAA,WAVG,KAAK,OAAO,OAAO,CAWxB,CACH;AAAA,OACD;AAAA,MAGD,SAAS,IAAI,CAAC,wBACb,MAAC,YAAD;AAAA,QAA2C;AAAA,SAA1B,IAAI,OAAO,YAAY,CAAa,CACtD;AAAA,MAGA,iCACC,MAYE,OAZF;AAAA,QACE,eAAY;AAAA,QACZ,WAAU;AAAA,QACV,OAAO;AAAA,UACL,KAAK,IAAI,qBAAM,EAAE,KAAK,IAAI,qBAAM,EAAE,OAAO,IAAI,MAAM;AAAA,UACnD,MAAM,GAAG,cAAc,MAAM;AAAA,UAC7B,OAAO,GAAG,MAAM;AAAA,QAClB;AAAA,QAPF,0BASE,MAEE,OAFF;AAAA,UAAK,WAAU;AAAA,UAAf,0BACE,MAA8D,OAA9D;AAAA,YAAK,WAAU;AAAA,WAA+C;AAAA,SAC9D;AAAA,OACF;AAAA;AAAA,GAEJ;AAAA;;;;ANvEN,qBAAM,OAAO,WAAU;AAEvB,IAAM,WAAqB,MAAM;AAAA,EAC/B,uBACE,OAaE,OAbF;AAAA,IAAK,WAAU;AAAA,IAAuB,eAAY;AAAA,IAAlD,UAaE;AAAA,sBAXA,MAAC,YAAD;AAAA,QAAY,WAAU;AAAA,OAAW;AAAA,sBAGjC,OAOE,YAPF;AAAA,QACE,WAAU;AAAA,QACV,eAAY;AAAA,QAFd,UAOE;AAAA,0BAFA,MAAC,eAAD,EAAe;AAAA,0BACf,MAAC,cAAD,EAAc;AAAA;AAAA,OACd;AAAA;AAAA,GACF;AAAA;AAIN,IAAe;;;AOzBf,qBAAS;;;ACHT,oBAAS;;AAMF,IAAM,eAAe,MAAM;AAAA,EAChC,QAAQ,aAAa,0BAA0B,mBAAmB;AAAA,EAIlE,MAAM,YAAY,sBAChB,YAAY,QAAQ,KAAK,GACzB,YAAY,MAAM,KAAK,CACzB;AAAA,EAGA,QAAQ,iBAAiB,SAAQ,MAAM;AAAA,IAErC,MAAM,aAAa,UAAU,OAAO,CAAC,UAAU,MAAM,MAAM;AAAA,IAG3D,MAAM,cAAc,UAAU,OAAO,CAAC,WAAW,MAAM,MAAM;AAAA,IAE7D,OAAO,EAAE,cAAc,YAAY,eAAe,YAAY;AAAA,KAC7D,CAAC,SAAS,CAAC;AAAA,EAGd,QAAQ,0BAA0B,SAAQ,MAAM;AAAA,IAE9C,MAAM,eAAe,CAAC,GAAG,YAAY,EAAE,KAAK,CAAC,GAAG,MAAM;AAAA,MACpD,OAAO,EAAE,MAAM,KAAK,EAAE,KAAK;AAAA,KAC5B;AAAA,IAGD,MAAM,OAAqC,CAAC;AAAA,IAC5C,MAAM,kBAA4C,CAAC;AAAA,IAEnD,aAAa,QAAQ,CAAC,OAAO,aAAa;AAAA,MACxC,IAAI,SAAS;AAAA,MAEb,QAAQ,QAAQ;AAAA,QACd,IAAI,YAAY,KAAK,QAAQ;AAAA,UAE3B,KAAK,KAAK,CAAC,CAAC;AAAA,UACZ,SAAS;AAAA,QACX,EAAO;AAAA,UAGL,SAAS;AAAA;AAAA,MAEb;AAAA,MAGA,KAAK,UAAU,KAAK,EAAE,MAAM,CAAC;AAAA,MAG7B,gBAAgB,KAAK;AAAA,WAChB;AAAA,QACH,MAAM;AAAA,QACN,OAAO;AAAA,QACP,KAAK,WAAW;AAAA,QAChB,QAAQ;AAAA,QACR,QAAQ;AAAA,MACV,CAAC;AAAA,KACF;AAAA,IAED,OAAO;AAAA,MACL,uBAAuB;AAAA,MACvB,iBAAiB,KAAK,IAAI,GAAG,KAAK,MAAM;AAAA,IAC1C;AAAA,KACC,CAAC,YAAY,CAAC;AAAA,EAEjB,uBACE,OAoCE,OApCF;AAAA,IACE,eAAY;AAAA,IACZ,WAAU;AAAA,IAFZ,UAoCE;AAAA,sBA/BA,MAIE,OAJF;AAAA,QAAK,WAAU;AAAA,QAAf,0BACE,MAEE,QAFF;AAAA,UAAM,WAAU;AAAA,UAAhB;AAAA,SAEE;AAAA,OACF;AAAA,sBAGF,MAuBE,OAvBF;AAAA,QAAK,WAAU;AAAA,QAAf,0BACE,MAqBE,eArBF;AAAA,UACE,IAAI,WAAW,YAAY,OAAO,YAAY;AAAA,UAC9C,MAAK;AAAA,UACL,MAAM;AAAA,UACN,WAAU;AAAA,UAJZ,UAMG,sBAAsB,IAAI,CAAC,OAAO,UAAU;AAAA,YAC3C,uBACE,MAUE,OAVF;AAAA,cAEE,OAAO,EAAE,QAAQ,mBAAmB,KAAK;AAAA,cAF3C,0BAIE,MAAC,gBAAD;AAAA,gBACE,WAAW,WAAW,MAAM,MAAM;AAAA,gBAClC;AAAA,gBACA,WAAU;AAAA,gBACV,OAAO,EAAE,OAAO,kCAAkC;AAAA,eACpD;AAAA,eARK,WAAW,MAAM,MAAM,OAS5B;AAAA,WAEL;AAAA,SACD;AAAA,OACF;AAAA;AAAA,GACF;AAAA;;;AC7GN,4BAAS,4BAAiB;;AAOnB,IAAM,YAAsC,GAAG,gBAAgB;AAAA,EACpE,QAAQ,aAAa,kBAAkB,wBACrC,mBAAmB;AAAA,EACrB,MAAM,UAAU,YAAY,OAAO,qBAAM,GAAG,KAAK;AAAA,EAEjD,uBACE,MAgCE,OAhCF;AAAA,IACE,eAAY;AAAA,IACZ,WAAW,GACT,0DACA,oBAAoB,qBACpB,qBACA,SACF;AAAA,IAPF,0BASE,MAsBE,kBAtBF;AAAA,MAAiB,MAAK;AAAA,MAAtB,0BACE,OAoBE,QAAO,KApBT;AAAA,QAEE,SAAS,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,QAC9B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,QAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,QAC3B,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,QAChD,WAAW,GACT,oEACA,WAAW,cACb;AAAA,QATF,UAoBE;AAAA,0BATA,MAEE,QAFF;AAAA,YAAM,WAAU;AAAA,YAAhB,UACG,YAAY,OAAO,QAAQ;AAAA,WAC5B;AAAA,UACD,YAAY,OAAO,cAAc;AAAA,UACjC,2BACC,MAEE,QAFF;AAAA,YAAM,WAAU;AAAA,YAAhB;AAAA,WAEE;AAAA;AAAA,SAjBC,YAAY,OAAO,YAAY,CAmBpC;AAAA,KACF;AAAA,GACF;AAAA;;;;AC3CN,IAAM,SAAQ,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,IAAI,CAAC,SAAS;AAAA,EAClE,OAAO,qBAAM,EAAE,KAAK,IAAI,EAAE,OAAO,CAAC;AAAA,CACnC;AAMM,IAAM,aAAwC,GAAG,gBAAgB;AAAA,EACtE,QAAQ,kBAAkB,mBAAmB;AAAA,EAE7C,uBACE,MAmBE,OAnBF;AAAA,IACE,eAAY;AAAA,IACZ,WAAW,mCAAmC;AAAA,IAFhD,UAIG,OAAM,IAAI,CAAC,yBACV,MAYE,OAZF;AAAA,MAEE,eAAa,iBAAiB,KAAK,OAAO,IAAI;AAAA,MAC9C,WAAU;AAAA,MAHZ,0BAKE,MAME,QANF;AAAA,QAAM,WAAU;AAAA,QAAhB,UACG,KAAK,eAAe,eAAe;AAAA,UAClC,MAAM;AAAA,UACN,QAAQ;AAAA,UACR,QAAQ;AAAA,QACV,CAAC,EAAE,OAAO,KAAK,OAAO,CAAC;AAAA,OACvB;AAAA,OAVG,KAAK,OAAO,OAAO,CAWxB,CACH;AAAA,GACD;AAAA;;;;AHvBN,IAAM,eAAe,CAAC,GAAG,IAAI,IAAI,EAAE;AAGnC,IAAM,SAAQ,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,IAAI,CAAC,SAAS;AAAA,EAClE,OAAO,qBAAM,EAAE,KAAK,IAAI,EAAE,OAAO,CAAC;AAAA,CACnC;AAED,IAAM,UAAU,MAAM;AAAA,EACpB,QAAQ,gBAAgB,mBAAmB;AAAA,EAE3C,MAAM,UAAU,YAAY,OAAO,qBAAM,GAAG,KAAK;AAAA,EACjD,MAAM,WAAW,YAAY,OAAO,YAAY;AAAA,EAEhD,uBACE,OAmHE,OAnHF;AAAA,IAAK,eAAY;AAAA,IAAW,WAAU;AAAA,IAAtC,UAmHE;AAAA,sBAjHA,MAAC,WAAD;AAAA,QAAW,WAAU;AAAA,OAAW;AAAA,sBAGhC,OA6GE,YA7GF;AAAA,QACE,eAAY;AAAA,QACZ,WAAU;AAAA,QAFZ,UA6GE;AAAA,0BAxGA,MAAC,cAAD,EAAc;AAAA,0BAGd,OAoGE,OApGF;AAAA,YACE,eAAY;AAAA,YACZ,WAAU;AAAA,YACV,OAAO,EAAE,QAAQ,GAAG,OAAM,SAAS,OAAO;AAAA,YAH5C,UAoGE;AAAA,8BA9FA,MAAC,YAAD;AAAA,gBAAY,WAAU;AAAA,eAAkC;AAAA,8BAGxD,OA0FE,OA1FF;AAAA,gBACE,eAAY;AAAA,gBACZ,WAAU;AAAA,gBAFZ,UA0FE;AAAA,kCArFA,MAqBE,OArBF;AAAA,oBACE,eAAY;AAAA,oBACZ,WAAU;AAAA,oBAFZ,UAIG,OAAM,IAAI,CAAC,MAAM,0BAChB,MAcE,OAdF;AAAA,sBAIE,WAAU;AAAA,sBAJZ,UAOG,aAAa,MAAM,CAAC,EAAE,IAAI,CAAC,4BAC1B,MAIG,OAJH;AAAA,wBAEE,WAAU;AAAA,wBACV,OAAO,EAAE,KAAK,GAAG,QAAQ,KAAK,YAAY;AAAA,yBAFrC,MAAM,KAAK,OAAO,IAAI,KAAK,SAG/B,CACJ;AAAA,uBAZI,MAAM,YAAY,OAAO,YAAY,KAAK,KAAK,OAClD,IACF,GAWA,CACH;AAAA,mBACD;AAAA,kCAGF,MA4CE,OA5CF;AAAA,oBACE,eAAY;AAAA,oBACZ,WAAU;AAAA,oBAFZ,UAIG,OAAM,IAAI,CAAC,SAAS;AAAA,sBACnB,MAAM,OAAO,KAAK,KAAK;AAAA,sBAEvB,uBACE,OAiCE,WAjCF;AAAA,kCAiCE;AAAA,0CAhCA,MAAC,eAAD;AAAA,4BACE,IAAI,aAAa,YAAY,KAAK,OAAO,IAAI;AAAA,4BAC7C,MAAK;AAAA,4BACL,MAAM;AAAA,4BACN;AAAA,4BACA,QAAQ;AAAA,4BACR,WAAW,GAAG,yCAAyC;AAAA,2BACzD;AAAA,0CACA,MAAC,eAAD;AAAA,4BACE,IAAI,aAAa,YAAY,KAAK,OAAO,IAAI;AAAA,4BAC7C,MAAK;AAAA,4BACL,MAAM;AAAA,4BACN;AAAA,4BACA,QAAQ;AAAA,4BACR,WAAU;AAAA,2BACZ;AAAA,0CACA,MAAC,eAAD;AAAA,4BACE,IAAI,aAAa,YAAY,KAAK,OAAO,IAAI;AAAA,4BAC7C,MAAK;AAAA,4BACL,MAAM;AAAA,4BACN;AAAA,4BACA,QAAQ;AAAA,4BACR,WAAU;AAAA,2BACZ;AAAA,0CACA,MAAC,eAAD;AAAA,4BACE,IAAI,aAAa,YAAY,KAAK,OAAO,IAAI;AAAA,4BAC7C,MAAK;AAAA,4BACL,MAAM;AAAA,4BACN;AAAA,4BACA,QAAQ;AAAA,4BACR,WAAU;AAAA,2BACZ;AAAA;AAAA,yBAhCa,GAAG,YAAY,KAAK,OAAO,IAAI,GAiC5C;AAAA,qBAEL;AAAA,mBACD;AAAA,kCAGF,MAAC,gBAAD;AAAA,oBAAgB,KAAK;AAAA,mBAAa;AAAA,kBAGjC,2BACC,MAQE,OARF;AAAA,oBACE,eAAY;AAAA,oBACZ,WAAU;AAAA,oBACV,OAAO;AAAA,sBACL,KAAK,IAAI,qBAAM,EAAE,KAAK,IAAI,qBAAM,EAAE,OAAO,IAAI,MAAM;AAAA,oBACrD;AAAA,oBALF,0BAOE,MAA+D,OAA/D;AAAA,sBAAK,WAAU;AAAA,qBAAgD;AAAA,mBAC/D;AAAA;AAAA,eAEJ;AAAA;AAAA,WACF;AAAA;AAAA,OACF;AAAA;AAAA,GACF;AAAA;AAIN,IAAe;;;AIhJf,sBAAgB,wBAAW;;;ACC3B;AAIO,IAAM,mBAAmB,CAAC,UAAkC;AAAA,EACjE,OAAO,QAAQ,MAAM,SAAS,MAAM,gBAAgB,MAAM,GAAG;AAAA;AAUxD,IAAM,0BAA0B;AAAA,EACrC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACmD;AAAA,EAEnD,KAAK,MAAM,OAAO;AAAA,IAChB,OAAO,CAAC;AAAA,EACV;AAAA,EAEA,IAAI;AAAA,IAGF,MAAM,cAA4B;AAAA,SAC7B,MAAM;AAAA,MACT,SAAS,MAAM,MAAM,WAAW,MAAM,MAAM,OAAO;AAAA,IACrD;AAAA,IACA,MAAM,OAAO,IAAI,MAAM,WAAW;AAAA,IAElC,MAAM,YAAY,cAAc,OAC9B,CAAC,MAAM,EAAE,gBAAgB,EAAE,QAAQ,MAAM,GAC3C;AAAA,IAGA,MAAM,gBAAgB,MAAM,IAAI,KAAK,MAAM,KAAK;AAAA,IAIhD,MAAM,wBAAwB,UAC3B,SAAS,eAAe,aAAa,EACrC,OAAO;AAAA,IACV,MAAM,cAAc,QAAQ,OAAO;AAAA,IAGnC,MAAM,cAAc,KAAK,QAAQ,uBAAuB,aAAa,IAAI;AAAA,IAGzE,MAAM,kBAAmC,YACtC,IAAI,CAAC,YAAY,UAAU;AAAA,MAC1B,MAAM,iBAAiB,qBAAM,UAAU;AAAA,MACvC,MAAM,mBAAmB,UAAU,KAAK,CAAC,MACvC,SAAS,EAAE,YAAY,EAAE,OAAO,cAAc,CAChD;AAAA,MAGA,IAAI,kBAAkB;AAAA,QACpB,OAAO,KAAK,UAAU,iBAAiB;AAAA,MACzC;AAAA,MAGA,MAAM,mBAAmB,MAAM,IAAI,KAAK,MAAM,KAAK;AAAA,MACnD,MAAM,aAAa,eAAe,IAAI,kBAAkB,aAAa;AAAA,MACrE,MAAM,mBAAmB,GAAG,MAAM,MAAM;AAAA,MACxC,MAAM,YAAY,MAAM,OAAO,GAAG,MAAM;AAAA,MAGxC,MAAM,iBAAgC;AAAA,WACjC;AAAA,QACH,IAAI;AAAA,QACJ,OAAO;AAAA,QACP,KAAK;AAAA,QACL,KAAK;AAAA,QACL,OAAO;AAAA,MACT;AAAA,MAEA,OAAO;AAAA,KACR,EACA,OAAO,CAAC,mBAAmB;AAAA,MAE1B,MAAM,aAAa,MAAM,WAAW,MAAM,QAAQ,SAAS;AAAA,MAC3D,IAAI,YAAY;AAAA,QACd,MAAM,gBAAgB,eAAe,MAAM,YAAY;AAAA,QACvD,MAAM,aAAa,MAAM,QAAQ,SAAS,aAAa;AAAA,QACvD,IAAI,YAAY;AAAA,UACd,OAAO;AAAA,QACT;AAAA,MACF;AAAA,MAKA,MAAM,kBACJ,eAAe,MAAM,eAAe,OAAO,KAC3C,eAAe,IAAI,cAAc,SAAS;AAAA,MAE5C,OAAO;AAAA,KACR;AAAA,IAEH,OAAO;AAAA,IACP,OAAO,OAAO;AAAA,IAEd,MAAM,IAAI,MACR,0BAA0B,KAAK,UAAU,MAAM,KAAK,aAAa,iBAAiB,QAAQ,MAAM,UAAU,iBAC5G;AAAA;AAAA;AAWG,IAAM,uBAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACgD;AAAA,EAChD,MAAM,gBAAgB,CAAC,GAAG,aAAa;AAAA,EAGvC,MAAM,iBAAiB,cAAc,UAAU,CAAC,MAAM;AAAA,IACpD,MAAM,YAAY,EAAE,OAAO,GAAG,EAAE;AAAA,IAChC,OAAO,cAAc,YAAY,OAAO,EAAE,UAAU,EAAE;AAAA,GACvD;AAAA,EAED,IAAI,mBAAmB,IAAI;AAAA,IACzB,MAAM,IAAI,MAAM,gCAAgC;AAAA,EAClD;AAAA,EAEA,MAAM,YAAY,cAAc;AAAA,EAEhC,QAAQ;AAAA,SACD,QAAQ;AAAA,MAEX,MAAM,sBAAsB,YAAY,MAAM,YAAY;AAAA,MAC1D,MAAM,kBAAkB,UAAU,WAAW,CAAC;AAAA,MAC9C,MAAM,iBAAiB,CAAC,GAAG,iBAAiB,mBAAmB;AAAA,MAE/D,MAAM,mBAAmB;AAAA,WACpB;AAAA,QACH,SAAS;AAAA,MACX;AAAA,MACA,cAAc,kBAAkB;AAAA,MAGhC,MAAM,kBAAkB,GAAG,YAAY,eAAe,KAAK,IAAI;AAAA,MAC/D,MAAM,gBAA+B;AAAA,WAEhC,SAAS,aAAa,CAAC,SAAS,UAAU,OAAO,QAAQ,OAAO,CAAC;AAAA,WACjE;AAAA,QACH,IAAI;AAAA,QACJ,cAAc;AAAA,QACd,KAAK,UAAU,OAAO,GAAG,UAAU;AAAA,QACnC,OAAO;AAAA,MACT;AAAA,MACA,cAAc,KAAK,aAAa;AAAA,MAChC;AAAA,IACF;AAAA,SAEK,aAAa;AAAA,MAKhB,MAAM,kBAAkB,YAAY,MAAM,SAAS,GAAG,KAAK;AAAA,MAC3D,MAAM,kBAAkB,gBAAgB,MAAM,KAAK,EAAE,OAAO;AAAA,MAG5D,MAAM,kBAAkB;AAAA,WACnB;AAAA,QACH,OAAO;AAAA,aACF,UAAU;AAAA,UACb,OAAO;AAAA,QACT;AAAA,MACF;AAAA,MACA,cAAc,kBAAkB;AAAA,MAGhC,MAAM,mBAAmB,UAAU,IAAI,KAAK,UAAU,KAAK;AAAA,MAC3D,MAAM,qBAAqB,QAAQ,SAAS,YAAY;AAAA,MACxD,MAAM,mBACJ,QAAQ,OAAO,mBAAmB,IAAI,gBAAgB;AAAA,MACxD,MAAM,cAAc,GAAG,UAAU;AAAA,MACjC,MAAM,eAAe,GAAG;AAAA,MAExB,MAAM,iBAAgC;AAAA,WACjC;AAAA,WACA;AAAA,QACH,OAAO;AAAA,aACF,UAAU;AAAA,aACV,QAAQ;AAAA,UACX,SAAS,mBAAmB,OAAO;AAAA,QACrC;AAAA,QACA,IAAI;AAAA,QACJ,KAAK;AAAA,QACL,OAAO;AAAA,QACP,KAAK;AAAA,QACL,cAAc;AAAA,MAChB;AAAA,MACA,cAAc,KAAK,cAAc;AAAA,MACjC;AAAA,IACF;AAAA,SAEK,OAAO;AAAA,MAEV,MAAM,mBAAmB;AAAA,WACpB;AAAA,WACA;AAAA,MACL;AAAA,MACA,cAAc,kBAAkB;AAAA,MAChC;AAAA,IACF;AAAA;AAAA,MAGE,MAAM,IAAI,MACR,kBAAkB,8CACpB;AAAA;AAAA,EAGJ,OAAO;AAAA;AASF,IAAM,uBAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,MACgD;AAAA,EAChD,MAAM,gBAAgB,CAAC,GAAG,aAAa;AAAA,EAGvC,MAAM,iBAAiB,cAAc,UAAU,CAAC,MAAM;AAAA,IACpD,MAAM,YAAY,EAAE,OAAO,GAAG,EAAE;AAAA,IAChC,OAAO,cAAc,YAAY,OAAO,EAAE,UAAU,EAAE;AAAA,GACvD;AAAA,EAED,IAAI,mBAAmB,IAAI;AAAA,IACzB,MAAM,IAAI,MAAM,gCAAgC;AAAA,EAClD;AAAA,EAEA,MAAM,YAAY,cAAc;AAAA,EAEhC,QAAQ;AAAA,SACD,QAAQ;AAAA,MAEX,MAAM,sBAAsB,YAAY,MAAM,YAAY;AAAA,MAC1D,MAAM,kBAAkB,UAAU,WAAW,CAAC;AAAA,MAC9C,MAAM,iBAAiB,CAAC,GAAG,iBAAiB,mBAAmB;AAAA,MAE/D,MAAM,mBAAmB,KAAK,WAAW,SAAS,eAAe;AAAA,MACjE,cAAc,kBAAkB;AAAA,MAChC;AAAA,IACF;AAAA,SAEK,aAAa;AAAA,MAKhB,MAAM,kBAAkB,YAAY,MAAM,SAAS,GAAG,KAAK;AAAA,MAC3D,MAAM,kBAAkB,gBAAgB,MAAM,KAAK,EAAE,OAAO;AAAA,MAE5D,MAAM,kBAAkB;AAAA,WACnB;AAAA,QACH,OAAO;AAAA,aACF,UAAU;AAAA,UACb,OAAO;AAAA,QACT;AAAA,MACF;AAAA,MACA,cAAc,kBAAkB;AAAA,MAChC;AAAA,IACF;AAAA,SAEK,OAAO;AAAA,MAEV,MAAM,4BAA4B,cAAc,OAC9C,CAAC,MAAM,EAAE,QAAQ,YAAY,GAC/B;AAAA,MACA,OAAO;AAAA,IACT;AAAA;AAAA,MAGE,MAAM,IAAI,MACR,kBAAkB,8CACpB;AAAA;AAAA,EAGJ,OAAO;AAAA;;;AC9RT,qBAAS,wBAAU,uBAAW;AAC9B,kBAAS;;AAKT,SAAS,mBAAmB,CAC1B,cACA,GACQ;AAAA,EACR,KAAK,cAAc;AAAA,IACjB,OAAO,EAAE,kBAAkB;AAAA,EAC7B;AAAA,EAEA,IAAI;AAAA,IAEF,MAAM,OAAO,IAAI,OAAM,YAAY;AAAA,IAGnC,MAAM,cAAc,KAAK,OAAO;AAAA,IAGhC,KACG,eACD,YAAY,SAAS,aAAa,KAClC,YAAY,SAAS,yBAAyB,KAC9C,YAAY,YAAY,EAAE,SAAS,OAAO,GAC1C;AAAA,MACA,OAAO,EAAE,kBAAkB;AAAA,IAC7B;AAAA,IAGA,OAAO,YAAY,OAAO,CAAC,EAAE,YAAY,IAAI,YAAY,MAAM,CAAC;AAAA,IAChE,MAAM;AAAA,IAEN,OAAO,EAAE,kBAAkB;AAAA;AAAA;AASxB,IAAM,mBAAoD;AAAA,EAC/D;AAAA,EACA;AAAA,MACI;AAAA,EACJ,QAAQ,MAAM,mBAAmB;AAAA,EACjC,OAAO,gBAAgB,qBAAqB,YAAW,KAAK;AAAA,EAG5D,MAAM,YAAY,SAChB,MAAM;AAAA,IACJ,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,QAAQ,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IACvD,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,QAAQ,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IACvD,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,SAAS,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IACxD,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,WAAW,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IAC1D,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,UAAU,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IACzD,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,QAAQ,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,IACvD,EAAE,OAAO,OAAM,IAAI,OAAO,EAAE,UAAU,GAAG,OAAO,EAAE,KAAK,EAAE;AAAA,EAC3D,GACA,CAAC,CAAC,CACJ;AAAA,EAGA,MAAM,qBAAqB,CAAC,SAAuC;AAAA,IACjE,MAAM,UAAkC;AAAA,OACrC,OAAM,QAAQ;AAAA,OACd,OAAM,SAAS;AAAA,OACf,OAAM,UAAU;AAAA,OAChB,OAAM,SAAS;AAAA,IAClB;AAAA,IACA,OAAO,QAAQ,SAAS;AAAA;AAAA,EAI1B,OAAO,cAAc,mBAAmB,UACtC,MAAM,SAAS,IACjB;AAAA,EAGA,WAAU,MAAM;AAAA,IACd,oBAAoB,KAAK;AAAA,IACzB,IAAI,OAAO;AAAA,MACT,gBAAgB,KAAK;AAAA,IACvB;AAAA,KACC,CAAC,KAAK,CAAC;AAAA,EAEV,MAAM,cAAc,CAAC,YAAmC;AAAA,IACtD,KAAK,cAAc;AAAA,MACjB;AAAA,IACF;AAAA,IAEA,MAAM,aAA2B,KAAK,iBAAiB,QAAQ;AAAA,IAC/D,gBAAgB,UAAU;AAAA,IAE1B,IAAI,gBAAgB;AAAA,MAClB,SAAS,UAAU;AAAA,IACrB,EAAO;AAAA,MACL,SAAS,IAAI;AAAA;AAAA;AAAA,EAIjB,MAAM,yBAAyB,CAAC,YAAqB;AAAA,IACnD,kBAAkB,OAAO;AAAA,IACzB,IAAI,SAAS;AAAA,MACX,IAAI,cAAc;AAAA,QAChB,SAAS,YAAY;AAAA,MACvB,EAAO;AAAA,QAGL,MAAM,eAAsC;AAAA,UAC1C,MAAM,OAAM;AAAA,UACZ,UAAU;AAAA,QACZ;AAAA,QACA,gBAAgB,YAA4B;AAAA,QAC5C,SAAS,YAA4B;AAAA;AAAA,IAEzC,EAAO;AAAA,MACL,SAAS,IAAI;AAAA;AAAA;AAAA,EAIjB,MAAM,wBAAwB,CAAC,cAAsB;AAAA,IAEnD,MAAM,UAAgD;AAAA,MACpD,OAAO,OAAM;AAAA,MACb,QAAQ,OAAM;AAAA,MACd,SAAS,OAAM;AAAA,MACf,QAAQ,OAAM;AAAA,IAChB;AAAA,IACA,YAAY,EAAE,MAAM,QAAQ,cAAc,OAAM,MAAM,CAAC;AAAA;AAAA,EAGzD,MAAM,uBAAuB,CAAC,MAA2C;AAAA,IACvE,MAAM,WAAW,KAAK,IAAI,GAAG,OAAO,SAAS,EAAE,OAAO,KAAK,KAAK,CAAC;AAAA,IACjE,YAAY,EAAE,SAAS,CAAC;AAAA;AAAA,EAG1B,MAAM,sBAAsB,CAAC,YAAyC;AAAA,IACpE,MAAM,UAAiC,CAAC;AAAA,IAExC,IAAI,YAAY,SAAS;AAAA,MAEvB,QAAQ,QAAQ;AAAA,MAChB,QAAQ,QAAQ;AAAA,IAClB,EAAO,SAAI,YAAY,SAAS;AAAA,MAE9B,QAAQ,QAAQ,cAAc,SAAS;AAAA,MACvC,QAAQ,QAAQ;AAAA,IAClB,EAAO,SAAI,YAAY,SAAS;AAAA,MAE9B,QAAQ,QACN,cAAc,SAAS,qBAAM,EAAE,IAAI,GAAG,OAAO,EAAE,MAAM,KAAK,EAAE,OAAO;AAAA,MACrE,QAAQ,QAAQ;AAAA,IAClB;AAAA,IAEA,YAAY,OAAO;AAAA;AAAA,EAGrB,MAAM,oBAAoB,CAAC,MAA2C;AAAA,IACpE,MAAM,QAAQ,KAAK,IAAI,GAAG,OAAO,SAAS,EAAE,OAAO,KAAK,KAAK,CAAC;AAAA,IAC9D,YAAY,EAAE,MAAM,CAAC;AAAA;AAAA,EAGvB,MAAM,sBAAsB,CAAC,SAA2B;AAAA,IACtD,MAAM,QAAQ,OAAO,qBAAM,IAAI,EAAE,MAAM,KAAK,EAAE,OAAO,IAAI;AAAA,IACzD,YAAY,EAAE,MAAM,CAAC;AAAA;AAAA,EAGvB,MAAM,kBAAkB,CAAC,aAAqB;AAAA,IAC5C,MAAM,aAAa;AAAA,MACjB,OAAM;AAAA,MACN,OAAM;AAAA,MACN,OAAM;AAAA,MACN,OAAM;AAAA,MACN,OAAM;AAAA,MACN,OAAM;AAAA,MACN,OAAM;AAAA,IACR;AAAA,IACA,MAAM,kBAAmB,cAAc,aAA2B,CAAC;AAAA,IACnE,MAAM,gBAAgB,WAAW;AAAA,IAEjC,MAAM,aAAa,gBAAgB,SAAS,aAAa;AAAA,IACzD,IAAI;AAAA,IAEJ,IAAI,YAAY;AAAA,MACd,cAAc,gBAAgB,OAAO,CAAC,QAAQ,QAAQ,aAAa;AAAA,IACrE,EAAO;AAAA,MACL,cAAc,CAAC,GAAG,iBAAiB,aAAa;AAAA;AAAA,IAGlD,YAAY;AAAA,MACV,WAAW,YAAY,SAAS,IAAI,cAAc;AAAA,IACpD,CAAC;AAAA;AAAA,EAIH,MAAM,aAAa,MAAmC;AAAA,IACpD,IAAI,cAAc,OAAO;AAAA,MACvB,OAAO;AAAA,IACT;AAAA,IACA,IAAI,cAAc,OAAO;AAAA,MACvB,OAAO;AAAA,IACT;AAAA,IACA,OAAO;AAAA;AAAA,EAGT,uBACE,OA8JE,MA9JF;AAAA,IAAM,eAAY;AAAA,IAAlB,UA8JE;AAAA,sBA7JA,OAeE,YAfF;AAAA,QAAY,WAAU;AAAA,QAAtB,UAeE;AAAA,0BAdA,OAQE,OARF;AAAA,YAAK,WAAU;AAAA,YAAf,UAQE;AAAA,8BAPA,MAAC,UAAD;AAAA,gBACE,IAAG;AAAA,gBACH,SAAS;AAAA,gBACT,iBAAiB;AAAA,gBACjB,eAAY;AAAA,eACd;AAAA,8BACA,MAA8C,WAA9C;AAAA,gBAAW,WAAU;AAAA,gBAArB,UAAgC,EAAE,QAAQ;AAAA,eAAI;AAAA;AAAA,WAC9C;AAAA,UACD,kBAAkB,yBACjB,MAEE,KAFF;AAAA,YAAG,WAAU;AAAA,YAAb,UACG,oBAAoB,OAAO,CAAC;AAAA,WAC7B;AAAA;AAAA,OAEJ;AAAA,MAED,kCACC,MAyIE,aAzIF;AAAA,QAAa,WAAU;AAAA,QAAvB,0BACE,OAuIE,OAvIF;AAAA,UAAK,WAAU;AAAA,UAAf,UAuIE;AAAA,4BArIA,OAsCE,OAtCF;AAAA,cAAK,WAAU;AAAA,cAAf,UAsCE;AAAA,gCArCA,OAsBE,OAtBF;AAAA,4BAsBE;AAAA,oCArBA,MAEE,OAFF;AAAA,sBAAO,SAAQ;AAAA,sBAAY,WAAU;AAAA,sBAArC,UACG,EAAE,SAAS;AAAA,qBACZ;AAAA,oCACF,OAiBE,QAjBF;AAAA,sBACE,OAAO,mBAAmB,cAAc,QAAQ,OAAM,KAAK;AAAA,sBAC3D,eAAe;AAAA,sBAFjB,UAiBE;AAAA,wCAbA,MAME,eANF;AAAA,0BACE,IAAG;AAAA,0BACH,WAAU;AAAA,0BACV,eAAY;AAAA,0BAHd,0BAKE,MAAC,aAAD,EAAa;AAAA,yBACb;AAAA,wCACF,OAKE,eALF;AAAA,oCAKE;AAAA,4CAJA,MAAwC,YAAxC;AAAA,8BAAY,OAAM;AAAA,8BAAlB,UAA2B,EAAE,OAAO;AAAA,6BAAI;AAAA,4CACxC,MAA0C,YAA1C;AAAA,8BAAY,OAAM;AAAA,8BAAlB,UAA4B,EAAE,QAAQ;AAAA,6BAAI;AAAA,4CAC1C,MAA4C,YAA5C;AAAA,8BAAY,OAAM;AAAA,8BAAlB,UAA6B,EAAE,SAAS;AAAA,6BAAI;AAAA,4CAC5C,MAA0C,YAA1C;AAAA,8BAAY,OAAM;AAAA,8BAAlB,UAA4B,EAAE,QAAQ;AAAA,6BAAI;AAAA;AAAA,yBAC1C;AAAA;AAAA,qBACF;AAAA;AAAA,iBACF;AAAA,gCAEF,OAYE,OAZF;AAAA,4BAYE;AAAA,oCAXA,MAEE,OAFF;AAAA,sBAAO,SAAQ;AAAA,sBAAW,WAAU;AAAA,sBAApC,UACG,EAAE,OAAO;AAAA,qBACV;AAAA,oCACF,MAAC,OAAD;AAAA,sBACE,IAAG;AAAA,sBACH,MAAK;AAAA,sBACL,KAAI;AAAA,sBACJ,OAAO,cAAc,YAAY;AAAA,sBACjC,UAAU;AAAA,sBACV,WAAU;AAAA,qBACZ;AAAA;AAAA,iBACA;AAAA;AAAA,aACF;AAAA,YAGD,cAAc,SAAS,OAAM,0BAC5B,OAgCE,OAhCF;AAAA,wBAgCE;AAAA,gCA/BA,MAA4C,OAA5C;AAAA,kBAAO,WAAU;AAAA,kBAAjB,UAA4B,EAAE,UAAU;AAAA,iBAAI;AAAA,gCAC5C,MA6BE,OA7BF;AAAA,kBAAK,WAAU;AAAA,kBAAf,UACG,UAAU,IAAI,CAAC,KAAK,UAAU;AAAA,oBAC7B,MAAM,iBAAiB,MAAM,QAC3B,cAAc,SAChB,IACI,aAAa,YACb,cAAc,YACZ,CAAC,aAAa,SAAS,IACvB,CAAC;AAAA,oBACP,MAAM,aAAa,eAAe,SAAS,IAAI,KAAK;AAAA,oBACpD,uBACE,OAeE,OAfF;AAAA,sBAEE,WAAU;AAAA,sBAFZ,UAeE;AAAA,wCAXA,MAAC,UAAD;AAAA,0BACE,IAAI,OAAO;AAAA,0BACX,SAAS;AAAA,0BACT,iBAAiB,MAAM,gBAAgB,KAAK;AAAA,yBAC9C;AAAA,wCACA,MAKE,OALF;AAAA,0BACE,SAAS,OAAO;AAAA,0BAChB,WAAU;AAAA,0BAFZ,UAIG,IAAI;AAAA,yBACL;AAAA;AAAA,uBAbG,OAAO,OAcZ;AAAA,mBAEL;AAAA,iBACD;AAAA;AAAA,aACF;AAAA,4BAIJ,OAsDE,OAtDF;AAAA,wBAsDE;AAAA,gCArDA,MAAwC,OAAxC;AAAA,kBAAO,WAAU;AAAA,kBAAjB,UAA4B,EAAE,MAAM;AAAA,iBAAI;AAAA,gCACxC,OAmDE,OAnDF;AAAA,kBAAK,WAAU;AAAA,kBAAf,UAmDE;AAAA,oCAlDA,OASE,OATF;AAAA,sBAAK,WAAU;AAAA,sBAAf,UASE;AAAA,wCARA,MAAC,UAAD;AAAA,0BACE,IAAG;AAAA,0BACH,SAAS,WAAW,MAAM;AAAA,0BAC1B,iBAAiB,MAAM,oBAAoB,OAAO;AAAA,yBACpD;AAAA,wCACA,MAEE,OAFF;AAAA,0BAAO,SAAQ;AAAA,0BAAQ,WAAU;AAAA,0BAAjC,UACG,EAAE,OAAO;AAAA,yBACV;AAAA;AAAA,qBACF;AAAA,oCAEF,OAoBE,OApBF;AAAA,sBAAK,WAAU;AAAA,sBAAf,UAoBE;AAAA,wCAnBA,MAAC,UAAD;AAAA,0BACE,IAAG;AAAA,0BACH,SAAS,WAAW,MAAM;AAAA,0BAC1B,iBAAiB,MAAM,oBAAoB,OAAO;AAAA,yBACpD;AAAA,wCACA,MAEE,OAFF;AAAA,0BAAO,SAAQ;AAAA,0BAAQ,WAAU;AAAA,0BAAjC,UACG,EAAE,OAAO;AAAA,yBACV;AAAA,wBACD,WAAW,MAAM,2BAChB,MAAC,OAAD;AAAA,0BACE,MAAK;AAAA,0BACL,KAAI;AAAA,0BACJ,OAAO,cAAc,SAAS;AAAA,0BAC9B,UAAU;AAAA,0BACV,WAAU;AAAA,0BACV,eAAY;AAAA,yBACd;AAAA,wCAEF,MAA8C,QAA9C;AAAA,0BAAM,WAAU;AAAA,0BAAhB,UAA2B,EAAE,aAAa;AAAA,yBAAI;AAAA;AAAA,qBAC9C;AAAA,oCAEF,OAgBE,OAhBF;AAAA,sBAAK,WAAU;AAAA,sBAAf,UAgBE;AAAA,wCAfA,MAAC,UAAD;AAAA,0BACE,IAAG;AAAA,0BACH,SAAS,WAAW,MAAM;AAAA,0BAC1B,iBAAiB,MAAM,oBAAoB,OAAO;AAAA,yBACpD;AAAA,wCACA,MAEE,OAFF;AAAA,0BAAO,SAAQ;AAAA,0BAAK,WAAU;AAAA,0BAA9B,UACG,EAAE,IAAI;AAAA,yBACP;AAAA,wBACD,WAAW,MAAM,2BAChB,MAAC,YAAD;AAAA,0BACE,MAAM,cAAc;AAAA,0BACpB,SAAS;AAAA,0BACT,WAAU;AAAA,yBACZ;AAAA;AAAA,qBAEF;AAAA;AAAA,iBACF;AAAA;AAAA,aACF;AAAA;AAAA,SACF;AAAA,OACF;AAAA;AAAA,GAEJ;AAAA;;;;AC7WC,SAAS,oBAAoB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,GAC4B;AAAA,EAC5B,QAAQ,MAAM,mBAAmB;AAAA,EAEjC,MAAM,oBAAoB,CAAC,UAA+B;AAAA,IACxD,UAAU,KAAK;AAAA,IACf,QAAQ;AAAA;AAAA,EAGV,MAAM,SAAS,kBAAkB;AAAA,EAEjC,uBACE,MA6DE,QA7DF;AAAA,IAAQ,MAAM;AAAA,IAAQ,cAAc;AAAA,IAApC,0BACE,OA2DE,eA3DF;AAAA,MAAe,WAAU;AAAA,MAAzB,UA2DE;AAAA,wBA1DA,OAUE,cAVF;AAAA,oBAUE;AAAA,4BATA,MAEE,aAFF;AAAA,wBACG,SAAS,EAAE,oBAAoB,IAAI,EAAE,sBAAsB;AAAA,aAC5D;AAAA,4BACF,OAKE,mBALF;AAAA,wBAKE;AAAA,gBALF;AAAA,gBACI;AAAA,gBADJ;AAAA,gBACiB;AAAA,gBACd,SACG,EAAE,4BAA4B,IAC9B,EAAE,8BAA8B;AAAA;AAAA,aACpC;AAAA;AAAA,SACF;AAAA,wBAEF,OAuCE,OAvCF;AAAA,UAAK,WAAU;AAAA,UAAf,UAuCE;AAAA,4BAtCA,MAWE,QAXF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cACV,SAAS,MAAM,kBAAkB,MAAM;AAAA,cAHzC,0BAKE,OAKE,OALF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAKE;AAAA,kCAJA,MAA+C,OAA/C;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAA8B,EAAE,WAAW;AAAA,mBAAI;AAAA,kCAC/C,MAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UACG,SAAS,EAAE,gBAAgB,IAAI,EAAE,gBAAgB;AAAA,mBAClD;AAAA;AAAA,eACF;AAAA,aACF;AAAA,4BAEF,MAWE,QAXF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cACV,SAAS,MAAM,kBAAkB,WAAW;AAAA,cAH9C,0BAKE,OAKE,OALF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAKE;AAAA,kCAJA,MAA4D,OAA5D;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAA8B,EAAE,wBAAwB;AAAA,mBAAI;AAAA,kCAC5D,MAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UACG,SAAS,EAAE,qBAAqB,IAAI,EAAE,qBAAqB;AAAA,mBAC5D;AAAA;AAAA,eACF;AAAA,aACF;AAAA,4BAEF,MAWE,QAXF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cACV,SAAS,MAAM,kBAAkB,KAAK;AAAA,cAHxC,0BAKE,OAKE,OALF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAKE;AAAA,kCAJA,MAA+C,OAA/C;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAA8B,EAAE,WAAW;AAAA,mBAAI;AAAA,kCAC/C,MAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UACG,SAAS,EAAE,oBAAoB,IAAI,EAAE,oBAAoB;AAAA,mBAC1D;AAAA;AAAA,eACF;AAAA,aACF;AAAA;AAAA,SACF;AAAA,wBAEF,MAIE,cAJF;AAAA,oCACE,MAEE,QAFF;AAAA,YAAQ,SAAQ;AAAA,YAAU,SAAS;AAAA,YAAnC,UACG,EAAE,QAAQ;AAAA,WACX;AAAA,SACF;AAAA;AAAA,KACF;AAAA,GACF;AAAA;;AClGN,qBAAS;AAKF,SAAS,wBAAwB,CAAC,YAAyB;AAAA,EAChE,QAAQ,6CAAsB,gDAAyB,mBAAmB;AAAA,EAE1E,OAAO,aAAa,kBAAkB,UAMnC;AAAA,IACD,QAAQ;AAAA,IACR,eAAe;AAAA,IACf,OAAO;AAAA,EACT,CAAC;AAAA,EAED,MAAM,iBAAiB,YACrB,CAAC,OAAsB,YAAoC;AAAA,IACzD,eAAe;AAAA,MACb,QAAQ;AAAA,MACR,eAAe;AAAA,MACf;AAAA,MACA;AAAA,MACA,WAAW,CAAC,UAA+B;AAAA,QACzC,sBAAqB,OAAO,SAAS;AAAA,UACnC;AAAA,UACA,WAAW,MAAM;AAAA,QACnB,CAAC;AAAA;AAAA,IAEL,CAAC;AAAA,KAEH,CAAC,qBAAoB,CACvB;AAAA,EAEA,MAAM,mBAAmB,YACvB,CAAC,UAAyB;AAAA,IACxB,eAAe;AAAA,MACb,QAAQ;AAAA,MACR,eAAe;AAAA,MACf;AAAA,MACA,WAAW,CAAC,UAA+B;AAAA,QACzC,sBAAqB,OAAO;AAAA,UAC1B;AAAA,UACA,WAAW,MAAM;AAAA,QACnB,CAAC;AAAA;AAAA,IAEL,CAAC;AAAA,KAEH,CAAC,qBAAoB,CACvB;AAAA,EAEA,MAAM,cAAc,YAAY,MAAM;AAAA,IACpC,eAAe;AAAA,MACb,QAAQ;AAAA,MACR,eAAe;AAAA,MACf,OAAO;AAAA,IACT,CAAC;AAAA,KACA,CAAC,CAAC;AAAA,EAEL,MAAM,gBAAgB,YACpB,CAAC,UAA+B;AAAA,IAC9B,IAAI,YAAY,WAAW;AAAA,MACzB,YAAY,UAAU,KAAK;AAAA,IAC7B;AAAA,IACA,YAAY;AAAA,IAEZ,aAAa;AAAA,KAEf,CAAC,aAAa,aAAa,UAAU,CACvC;AAAA,EAEA,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA;;;;AJpDF,IAAM,eAAe;AAAA,EACnB,EAAE,OAAO,6BAA6B,OAAO,OAAO;AAAA,EACpD,EAAE,OAAO,+BAA+B,OAAO,QAAQ;AAAA,EACvD,EAAE,OAAO,iCAAiC,OAAO,SAAS;AAAA,EAC1D,EAAE,OAAO,2BAA2B,OAAO,MAAM;AAAA,EACjD,EAAE,OAAO,iCAAiC,OAAO,SAAS;AAAA,EAC1D,EAAE,OAAO,6BAA6B,OAAO,OAAO;AAAA,EACpD,EAAE,OAAO,iCAAiC,OAAO,SAAS;AAAA,EAC1D,EAAE,OAAO,+BAA+B,OAAO,QAAQ;AAAA,EACvD,EAAE,OAAO,mCAAmC,OAAO,UAAU;AAAA,EAC7D,EAAE,OAAO,2BAA2B,OAAO,MAAM;AAAA,EACjD,EAAE,OAAO,iCAAiC,OAAO,SAAS;AAAA,EAC1D,EAAE,OAAO,6BAA6B,OAAO,OAAO;AAAA,EACpD,EAAE,OAAO,6BAA6B,OAAO,OAAO;AAAA,EACpD,EAAE,OAAO,iCAAiC,OAAO,SAAS;AAC5D;AAWO,IAAM,YAAsC;AAAA,EACjD;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACI;AAAA,EACJ;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MACE,yBAAyB,OAAO;AAAA,EAEpC,QAAQ,0BAA0B,MAAM,mBAAmB;AAAA,EAE3D,MAAM,QAAQ,eAAe;AAAA,EAC7B,MAAM,MAAM,eAAe;AAAA,EAG3B,MAAM,cAAc,gBAChB,yBAAyB,aAAa,IACtC;AAAA,EAGJ,MAAM,mBAAmB,cAAc,OAAO,KAAK,IAAI;AAAA,EACvD,MAAM,iBACJ,cAAc,IAAI,GAAG,MAAM,EAAE,OAAO,KAAK,qBAAM,EAAE,IAAI,GAAG,MAAM,EAAE,OAAO;AAAA,EAGzE,OAAO,WAAW,gBAAgB,UAChC,OAAO,OAAO,KAAK,gBACrB;AAAA,EACA,OAAO,SAAS,cAAc,UAAS,KAAK,OAAO,KAAK,cAAc;AAAA,EACtE,OAAO,UAAU,eAAe,UAAS,eAAe,UAAU,KAAK;AAAA,EACvE,OAAO,eAAe,oBAAoB,UACxC,eAAe,SAAS,aAAa,GAAG,KAC1C;AAAA,EAGA,OAAO,WAAW,gBAAgB,UAChC,QAAQ,MAAM,OAAO,OAAO,IAAI,qBAAM,gBAAgB,EAAE,OAAO,OAAO,CACxE;AAAA,EACA,OAAO,SAAS,cAAc,UAC5B,MAAM,IAAI,OAAO,OAAO,IAAI,qBAAM,cAAc,EAAE,OAAO,OAAO,CAClE;AAAA,EAGA,OAAO,YAAY,iBAAiB,UAAS;AAAA,IAC3C,OAAO,eAAe,SAAS;AAAA,IAC/B,aAAa,eAAe,eAAe;AAAA,IAC3C,UAAU,eAAe,YAAY;AAAA,EACvC,CAAC;AAAA,EAGD,OAAO,OAAO,YAAY,UAA8B,MAAM;AAAA,IAC5D,MAAM,aAAa,eAAe,SAAS,aAAa;AAAA,IACxD,OAAO,cAAc;AAAA,GACtB;AAAA,EAGD,MAAM,wBAAwB,CAAC,SAA2B;AAAA,IACxD,IAAI,MAAM;AAAA,MACR,aAAa,IAAI;AAAA,IACnB;AAAA;AAAA,EAGF,MAAM,sBAAsB,CAAC,SAA2B;AAAA,IACtD,IAAI,MAAM;AAAA,MACR,WAAW,IAAI;AAAA,IACjB;AAAA;AAAA,EAIF,MAAM,oBAAoB,CACxB,MACG;AAAA,IACH,QAAQ,MAAM,UAAU,EAAE;AAAA,IAC1B,cAAc,CAAC,UAAU,KAAK,OAAO,OAAO,MAAM,EAAE;AAAA;AAAA,EAItD,MAAM,mBAAmB,CACvB,GACA,YACG;AAAA,IACH,MAAM,YAAY,EAAE,OAAO;AAAA,IAC3B,IAAI,SAAS;AAAA,MACX,aAAa,SAAS;AAAA,IACxB,EAAO;AAAA,MACL,WAAW,SAAS;AAAA;AAAA;AAAA,EAIxB,WAAU,MAAM;AAAA,IAEd,IAAI,UAAU;AAAA,MACZ,WAAW,OAAO;AAAA,IACpB;AAAA,KACC,CAAC,QAAQ,CAAC;AAAA,EAGb,MAAM,eAAe,CAAC,MAAuB;AAAA,IAC3C,EAAE,eAAe;AAAA,IAGjB,OAAO,YAAY,gBAAgB,UAAU,MAAM,GAAG,EAAE,IAAI,MAAM;AAAA,IAClE,OAAO,UAAU,cAAc,QAAQ,MAAM,GAAG,EAAE,IAAI,MAAM;AAAA,IAE5D,IAAI,gBAAgB,qBAAM,SAAS,EAAE,KAAK,UAAU,EAAE,OAAO,YAAY;AAAA,IAEzE,IAAI,cAAc,qBAAM,OAAO,EAAE,KAAK,QAAQ,EAAE,OAAO,UAAU;AAAA,IAGjE,IAAI,UAAU;AAAA,MACZ,gBAAgB,cAAc,KAAK,CAAC,EAAE,OAAO,CAAC;AAAA,MAC9C,cAAc,YAAY,KAAK,EAAE,EAAE,OAAO,EAAE;AAAA,IAC9C;AAAA,IAEA,MAAM,YAA2B;AAAA,MAC/B,IAAI,eAAe,MAAM,qBAAM,EAAE,OAAO,gBAAgB;AAAA,MACxD,OAAO,WAAW;AAAA,MAClB,OAAO;AAAA,MACP,KAAK;AAAA,MACL,aAAa,WAAW;AAAA,MACxB,UAAU,WAAW;AAAA,MACrB,QAAQ;AAAA,MACR,OAAO;AAAA,MACP,OAAO,SAAS;AAAA,IAClB;AAAA,IAEA,IAAI,eAAe,IAAI;AAAA,MAErB,IAAI,iBAAiB,aAAa,GAAG;AAAA,QAEnC,eAAe,eAAe;AAAA,UAC5B,OAAO,WAAW;AAAA,UAClB,OAAO;AAAA,UACP,KAAK;AAAA,UACL,aAAa,WAAW;AAAA,UACxB,UAAU,WAAW;AAAA,UACrB,QAAQ;AAAA,UACR,OAAO;AAAA,UACP,OAAO,SAAS;AAAA,QAClB,CAAC;AAAA,QACD;AAAA,MACF;AAAA,MACA,WAAW,SAAS;AAAA,IACtB,EAAO;AAAA,MACL,QAAQ,SAAS;AAAA;AAAA,IAGnB,QAAQ;AAAA;AAAA,EAGV,MAAM,eAAe,MAAM;AAAA,IACzB,IAAI,eAAe,IAAI;AAAA,MAErB,IAAI,iBAAiB,aAAa,GAAG;AAAA,QAEnC,iBAAiB,aAAa;AAAA,QAC9B;AAAA,MACF;AAAA,MACA,WAAW,aAAa;AAAA,MACxB,QAAQ;AAAA,IACV;AAAA;AAAA,EAGF,MAAM,oBAAoB,CAAC,aAAkC;AAAA,IAC3D,IAAI,UAAU;AAAA,MAEZ,OAAO,YAAY,gBAAgB,UAAU,MAAM,GAAG,EAAE,IAAI,MAAM;AAAA,MAClE,IAAI,gBAAgB,qBAAM,SAAS,EAAE,KAAK,UAAU,EAAE,OAAO,YAAY;AAAA,MAEzE,IAAI,UAAU;AAAA,QACZ,gBAAgB,cAAc,KAAK,CAAC,EAAE,OAAO,CAAC;AAAA,MAChD;AAAA,MAGA,MAAM,gBAA8B;AAAA,WAC/B;AAAA,QACH,SAAS,cAAc,OAAO;AAAA,MAChC;AAAA,MACA,SAAS,aAAa;AAAA,IACxB,EAAO;AAAA,MACL,SAAS,IAAI;AAAA;AAAA;AAAA,EAKjB,WAAU,MAAM;AAAA,IACd,IAAI,qBAAM,SAAS,EAAE,QAAQ,qBAAM,OAAO,CAAC,GAAG;AAAA,MAC5C,WAAW,SAAS;AAAA,IACtB;AAAA,KACC,CAAC,WAAW,OAAO,CAAC;AAAA,EAEvB,uBACE;AAAA,cA8LE;AAAA,sBA7LA,MAmLE,QAnLF;AAAA,QAAQ,MAAM;AAAA,QAAM,cAAc;AAAA,QAAlC,0BACE,MAiLE,eAjLF;AAAA,UAAe,WAAU;AAAA,UAAzB,0BACE,OA+KE,QA/KF;AAAA,YAAM,UAAU;AAAA,YAAhB,UA+KE;AAAA,8BA9KA,OAOE,cAPF;AAAA,gBAAc,WAAU;AAAA,gBAAxB,UAOE;AAAA,kCANA,MAEE,aAFF;AAAA,oBAAa,WAAU;AAAA,oBAAvB,UACG,eAAe,KAAK,EAAE,WAAW,IAAI,EAAE,aAAa;AAAA,mBACrD;AAAA,kCACF,MAEE,mBAFF;AAAA,oBAAmB,WAAU;AAAA,oBAA7B,UACG,eAAe,KAAK,EAAE,kBAAkB,IAAI,EAAE,aAAa;AAAA,mBAC5D;AAAA;AAAA,eACF;AAAA,8BAEF,OAwIE,OAxIF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAwIE;AAAA,kCAvIA,OAaE,OAbF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAaE;AAAA,sCAZA,MAEE,OAFF;AAAA,wBAAO,SAAQ;AAAA,wBAAQ,WAAU;AAAA,wBAAjC,UACG,EAAE,OAAO;AAAA,uBACV;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAa,EAAE,uBAAuB;AAAA,wBACtC,UAAQ;AAAA,wBACR,WAAU;AAAA,uBACZ;AAAA;AAAA,mBACA;AAAA,kCAEF,OAYE,OAZF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAYE;AAAA,sCAXA,MAEE,OAFF;AAAA,wBAAO,SAAQ;AAAA,wBAAc,WAAU;AAAA,wBAAvC,UACG,EAAE,aAAa;AAAA,uBAChB;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAa,EAAE,6BAA6B;AAAA,wBAC5C,WAAU;AAAA,uBACZ;AAAA;AAAA,mBACA;AAAA,kCAEF,OASE,OATF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UASE;AAAA,sCARA,MAAC,UAAD;AAAA,wBACE,IAAG;AAAA,wBACH,SAAS;AAAA,wBACT,iBAAiB,CAAC,YAAY,YAAY,YAAY,IAAI;AAAA,uBAC5D;AAAA,sCACA,MAEE,OAFF;AAAA,wBAAO,SAAQ;AAAA,wBAAS,WAAU;AAAA,wBAAlC,UACG,EAAE,QAAQ;AAAA,uBACX;AAAA;AAAA,mBACF;AAAA,kCAEF,OAmBE,OAnBF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAmBE;AAAA,sCAlBA,OAQE,OARF;AAAA,kCAQE;AAAA,0CAPA,MAAwD,OAAxD;AAAA,4BAAO,WAAU;AAAA,4BAAjB,UAAuC,EAAE,WAAW;AAAA,2BAAI;AAAA,0CACxD,MAAC,YAAD;AAAA,4BACE,MAAM;AAAA,4BACN,SAAS;AAAA,4BACT,WAAU;AAAA,4BACV,eAAa;AAAA,2BACf;AAAA;AAAA,uBACA;AAAA,sCACF,OAQE,OARF;AAAA,kCAQE;AAAA,0CAPA,MAAsD,OAAtD;AAAA,4BAAO,WAAU;AAAA,4BAAjB,UAAuC,EAAE,SAAS;AAAA,2BAAI;AAAA,0CACtD,MAAC,YAAD;AAAA,4BACE,MAAM;AAAA,4BACN,SAAS;AAAA,4BACT,WAAU;AAAA,4BACV,eAAa;AAAA,2BACf;AAAA;AAAA,uBACA;AAAA;AAAA,mBACF;AAAA,mBAEA,4BACA,OAyBE,OAzBF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAyBE;AAAA,sCAxBA,OAWE,OAXF;AAAA,kCAWE;AAAA,0CAVA,MAEE,OAFF;AAAA,4BAAO,SAAQ;AAAA,4BAAa,WAAU;AAAA,4BAAtC,UACG,EAAE,WAAW;AAAA,2BACd;AAAA,0CACF,MAAC,OAAD;AAAA,4BACE,IAAG;AAAA,4BACH,MAAK;AAAA,4BACL,OAAO;AAAA,4BACP,UAAU,CAAC,MAAM,iBAAiB,GAAG,IAAI;AAAA,4BACzC,WAAU;AAAA,2BACZ;AAAA;AAAA,uBACA;AAAA,sCACF,OAWE,OAXF;AAAA,kCAWE;AAAA,0CAVA,MAEE,OAFF;AAAA,4BAAO,SAAQ;AAAA,4BAAW,WAAU;AAAA,4BAApC,UACG,EAAE,SAAS;AAAA,2BACZ;AAAA,0CACF,MAAC,OAAD;AAAA,4BACE,IAAG;AAAA,4BACH,MAAK;AAAA,4BACL,OAAO;AAAA,4BACP,UAAU,CAAC,MAAM,iBAAiB,GAAG,KAAK;AAAA,4BAC1C,WAAU;AAAA,2BACZ;AAAA;AAAA,uBACA;AAAA;AAAA,mBACF;AAAA,kCAGJ,OA2BE,OA3BF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UA2BE;AAAA,sCA1BA,MAAoD,OAApD;AAAA,wBAAO,WAAU;AAAA,wBAAjB,UAAuC,EAAE,OAAO;AAAA,uBAAI;AAAA,sCACpD,MAwBE,OAxBF;AAAA,wBAAK,WAAU;AAAA,wBAAf,0BACE,MAsBE,iBAtBF;AAAA,oCACG,aAAa,IAAI,CAAC,0BACjB,OAkBE,SAlBF;AAAA,sCAkBE;AAAA,8CAjBA,MAaE,gBAbF;AAAA,gCAAgB,SAAO;AAAA,gCAAvB,0BACE,MAAC,QAAD;AAAA,kCACE,SAAQ;AAAA,kCAER,MAAK;AAAA,kCACL,WAAW,GACT,GAAG,MAAM,4CACT,kBAAkB,MAAM,SACtB,kDACJ;AAAA,kCACA,SAAS,MAAM,iBAAiB,MAAM,KAAK;AAAA,kCAC3C,cAAY,MAAM;AAAA,mCARb,MAAM,KASb;AAAA,+BACA;AAAA,8CACF,MAEE,gBAFF;AAAA,0DACE,MAAiD,KAAjD;AAAA,kCAAG,WAAU;AAAA,kCAAb,UAAmC,MAAM;AAAA,iCAAQ;AAAA,+BACjD;AAAA;AAAA,6BAjBU,MAAM,KAkBlB,CACH;AAAA,yBACD;AAAA,uBACF;AAAA;AAAA,mBACF;AAAA,kCAEF,OAYE,OAZF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAYE;AAAA,sCAXA,MAEE,OAFF;AAAA,wBAAO,SAAQ;AAAA,wBAAW,WAAU;AAAA,wBAApC,UACG,EAAE,UAAU;AAAA,uBACb;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAa,EAAE,0BAA0B;AAAA,wBACzC,WAAU;AAAA,uBACZ;AAAA;AAAA,mBACA;AAAA,kCAGF,MAAC,kBAAD;AAAA,oBAAkB,OAAO;AAAA,oBAAO,UAAU;AAAA,mBAAmB;AAAA;AAAA,eAC7D;AAAA,8BAEF,OA0BE,cA1BF;AAAA,gBAAc,WAAU;AAAA,gBAAxB,UA0BE;AAAA,kBAzBC,eAAe,sBACd,MAQE,QARF;AAAA,oBACE,MAAK;AAAA,oBACL,SAAQ;AAAA,oBACR,SAAS;AAAA,oBACT,WAAU;AAAA,oBACV,MAAK;AAAA,oBALP,UAOG,EAAE,QAAQ;AAAA,mBACX;AAAA,kCAEJ,OAaE,OAbF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAaE;AAAA,sCAZA,MAQE,QARF;AAAA,wBACE,MAAK;AAAA,wBACL,SAAQ;AAAA,wBACR,SAAS;AAAA,wBACT,WAAU;AAAA,wBACV,MAAK;AAAA,wBALP,UAOG,EAAE,QAAQ;AAAA,uBACX;AAAA,sCACF,MAEE,QAFF;AAAA,wBAAQ,MAAK;AAAA,wBAAS,WAAU;AAAA,wBAAsB,MAAK;AAAA,wBAA3D,UACG,eAAe,KAAK,EAAE,QAAQ,IAAI,EAAE,QAAQ;AAAA,uBAC7C;AAAA;AAAA,mBACF;AAAA;AAAA,eACF;AAAA;AAAA,WACF;AAAA,SACF;AAAA,OACF;AAAA,sBAGF,MAAC,sBAAD;AAAA,QACE,QAAQ,YAAY;AAAA,QACpB,SAAS;AAAA,QACT,WAAW;AAAA,QACX,eAAe,YAAY;AAAA,QAC3B,YAAY,YAAY,OAAO,SAAS;AAAA,OAC1C;AAAA;AAAA,GACA;AAAA;;;AK1bN,kBAAS;AAUT,IAAM,iBAAiB,CAAC,SAAyB;AAAA,EAC/C,OAAO,KACJ,WAAW,MAAM,MAAM,EACvB,WAAW,KAAK,KAAK,EACrB,WAAW,KAAK,KAAK,EACrB,WAAW;AAAA,GAAM,KAAK,EACtB,WAAW,MAAM,EAAE;AAAA;AAMxB,IAAM,iBAAiB,CAAC,MAAmB,SAAS,UAAkB;AAAA,EACpE,IAAI,QAAQ;AAAA,IACV,OAAO,KAAK,OAAO,UAAU;AAAA,EAC/B;AAAA,EACA,OAAO,KAAK,IAAI,EAAE,OAAO,sBAAsB;AAAA;AAMjD,IAAM,cAAc,CAAC,UAAiC;AAAA,EACpD,IAAI,MAAM,KAAK;AAAA,IACb,OAAO,MAAM;AAAA,EACf;AAAA,EACA,OAAO,GAAG,MAAM;AAAA;AAMlB,IAAM,cAAc,CAAC,iBAAkC;AAAA,EACrD,IAAI;AAAA,IAEF,MAAM,OAAO,IAAI,OACf,YACF;AAAA,IACA,MAAM,cAAc,KAAK,SAAS;AAAA,IAElC,MAAM,YAAY,YACf,MAAM;AAAA,CAAI,EACV,KAAK,CAAC,SAAS,KAAK,WAAW,QAAQ,CAAC;AAAA,IAC3C,OAAO,aAAa;AAAA,IACpB,MAAM;AAAA,IACN,OAAO;AAAA;AAAA;AAOX,IAAM,mBAAmB,CAAC,UAAiC;AAAA,EACzD,MAAM,QAAkB,CAAC;AAAA,EAEzB,MAAM,KAAK,cAAc;AAAA,EAGzB,MAAM,KAAK,OAAO,YAAY,KAAK,GAAG;AAAA,EAGtC,MAAM,UAAU,eAAe,MAAM,OAAO,MAAM,MAAM;AAAA,EACxD,IAAI,MAAM,QAAQ;AAAA,IAChB,MAAM,KAAK,sBAAsB,SAAS;AAAA,EAC5C,EAAO;AAAA,IACL,MAAM,KAAK,WAAW,SAAS;AAAA;AAAA,EAIjC,MAAM,QAAQ,eAAe,MAAM,KAAK,MAAM,MAAM;AAAA,EACpD,IAAI,MAAM,QAAQ;AAAA,IAChB,MAAM,KAAK,oBAAoB,OAAO;AAAA,EACxC,EAAO;AAAA,IACL,MAAM,KAAK,SAAS,OAAO;AAAA;AAAA,EAI7B,MAAM,KAAK,WAAW,eAAe,MAAM,KAAK,GAAG;AAAA,EAGnD,IAAI,MAAM,aAAa;AAAA,IACrB,MAAM,KAAK,eAAe,eAAe,MAAM,WAAW,GAAG;AAAA,EAC/D;AAAA,EAGA,IAAI,MAAM,UAAU;AAAA,IAClB,MAAM,KAAK,YAAY,eAAe,MAAM,QAAQ,GAAG;AAAA,EACzD;AAAA,EAGA,IAAI,MAAM,OAAO;AAAA,IACf,MAAM,cAAc,YAAY,MAAM,KAAK;AAAA,IAC3C,IAAI,aAAa;AAAA,MACf,MAAM,KAAK,WAAW;AAAA,IACxB;AAAA,EACF;AAAA,EAGA,IAAI,MAAM,WAAW,MAAM,QAAQ,SAAS,GAAG;AAAA,IAC7C,MAAM,UAAU,MAAM,QACnB,IAAI,CAAC,YAAY,eAAe,qBAAM,OAAO,GAAG,MAAM,MAAM,CAAC,EAC7D,KAAK,GAAG;AAAA,IACX,MAAM,KAAK,UAAU,SAAS;AAAA,EAChC;AAAA,EAGA,IAAI,MAAM,cAAc;AAAA,IACtB,MAAM,eAAe,eAAe,qBAAM,MAAM,YAAY,GAAG,MAAM,MAAM;AAAA,IAC3E,MAAM,KAAK,iBAAiB,cAAc;AAAA,EAC5C;AAAA,EAGA,MAAM,MAAM,qBAAM,EAAE,IAAI,EAAE,OAAO,sBAAsB;AAAA,EACvD,MAAM,KAAK,WAAW,KAAK;AAAA,EAG3B,MAAM,KAAK,WAAW,KAAK;AAAA,EAG3B,MAAM,KAAK,iBAAiB,KAAK;AAAA,EAGjC,MAAM,KAAK,kBAAkB;AAAA,EAG7B,MAAM,KAAK,YAAY;AAAA,EAGvB,MAAM,KAAK,eAAe;AAAA,EAE1B,MAAM,KAAK,YAAY;AAAA,EAEvB,OAAO,MAAM,KAAK;AAAA,CAAM;AAAA;AAU1B,IAAM,wBAAwB,CAAC,WAA6C;AAAA,EAC1E,MAAM,eAAgC,CAAC;AAAA,EACvC,MAAM,gBAAgB,IAAI;AAAA,EAE1B,WAAW,SAAS,QAAQ;AAAA,IAE1B,MAAM,WAAW,MAAM,OAAO,GAAG,MAAM;AAAA,IAGvC,IAAI,MAAM,UAAU,MAAM,cAAc;AAAA,MACtC,aAAa,KAAK,KAAK;AAAA,MACvB,cAAc,IAAI,QAAQ;AAAA,MAC1B;AAAA,IACF;AAAA,IAGA,IAAI,MAAM,iBAAiB,MAAM,OAAO;AAAA,MACtC,aAAa,KAAK,KAAK;AAAA,MACvB;AAAA,IACF;AAAA,IAGA,KAAK,MAAM,UAAU,MAAM,cAAc;AAAA,MAEvC,MAAM,sBAAsB,cAAc,IAAI,QAAQ;AAAA,MAEtD,KAAK,qBAAqB;AAAA,QACxB,aAAa,KAAK,KAAK;AAAA,MACzB;AAAA,IAEF;AAAA,EACF;AAAA,EAEA,OAAO;AAAA;AAMF,IAAM,oBAAoB,CAC/B,QACA,eAAe,qBACJ;AAAA,EACX,MAAM,QAAkB,CAAC;AAAA,EAGzB,MAAM,KAAK,iBAAiB;AAAA,EAC5B,MAAM,KAAK,aAAa;AAAA,EACxB,MAAM,KAAK,qCAAqC;AAAA,EAChD,MAAM,KAAK,oBAAoB;AAAA,EAC/B,MAAM,KAAK,gBAAgB;AAAA,EAC3B,MAAM,KAAK,gBAAgB,eAAe,YAAY,GAAG;AAAA,EACzD,MAAM,KAAK,gBAAgB,eAAe,iBAAiB,cAAc,GAAG;AAAA,EAG5E,MAAM,KAAK,iBAAiB;AAAA,EAC5B,MAAM,KAAK,UAAU;AAAA,EACrB,MAAM,KAAK,gBAAgB;AAAA,EAC3B,MAAM,KAAK,yBAAyB;AAAA,EACpC,MAAM,KAAK,YAAY;AAAA,EACvB,MAAM,KAAK,oBAAoB;AAAA,EAC/B,MAAM,KAAK,kBAAkB;AAAA,EAC7B,MAAM,KAAK,cAAc;AAAA,EACzB,MAAM,KAAK,eAAe;AAAA,EAG1B,MAAM,iBAAiB,sBAAsB,MAAM;AAAA,EAGnD,eAAe,QAAQ,CAAC,UAAU;AAAA,IAChC,MAAM,KAAK,iBAAiB,KAAK,CAAC;AAAA,GACnC;AAAA,EAGD,MAAM,KAAK,eAAe;AAAA,EAE1B,OAAO,MAAM,KAAK;AAAA,CAAM;AAAA;AAMnB,IAAM,oBAAoB,CAC/B,QACA,WAAW,gBACX,eAAe,qBACN;AAAA,EACT,MAAM,cAAc,kBAAkB,QAAQ,YAAY;AAAA,EAG1D,MAAM,OAAO,IAAI,KAAK,CAAC,WAAW,GAAG;AAAA,IACnC,MAAM;AAAA,EACR,CAAC;AAAA,EAED,MAAM,MAAM,IAAI,gBAAgB,IAAI;AAAA,EACpC,MAAM,OAAO,SAAS,cAAc,GAAG;AAAA,EACvC,KAAK,OAAO;AAAA,EACZ,KAAK,WAAW,SAAS,SAAS,MAAM,IAAI,WAAW,GAAG;AAAA,EAG1D,SAAS,KAAK,OAAO,IAAI;AAAA,EACzB,KAAK,MAAM;AAAA,EACX,SAAS,KAAK,YAAY,IAAI;AAAA,EAG9B,IAAI,gBAAgB,GAAG;AAAA;;;AC3PzB,qBAAS;AACT,wBAAgB,0BAAa;;;ACA7B,4BAAS,4BAAiB;AAC1B;AACA,oBAAS,sBAAS;AAAA;AAKlB,IAAM,oBAAoB;AAAA,EACxB,SAAS,EAAE,SAAS,GAAG,GAAG,GAAG;AAAA,EAC7B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,EAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAC7B;AAEA,IAAM,eAAe,MAAM;AAAA,EACzB,QAAQ,aAAa,MAAM,gBAAgB,MAAM,mBAAmB;AAAA,EAGpE,MAAM,SAAS,SACb,MAAM;AAAA,IACJ,EAAE,SAAS;AAAA,IACX,EAAE,UAAU;AAAA,IACZ,EAAE,OAAO;AAAA,IACT,EAAE,OAAO;AAAA,IACT,EAAE,KAAK;AAAA,IACP,EAAE,MAAM;AAAA,IACR,EAAE,MAAM;AAAA,IACR,EAAE,QAAQ;AAAA,IACV,EAAE,WAAW;AAAA,IACb,EAAE,SAAS;AAAA,IACX,EAAE,UAAU;AAAA,IACZ,EAAE,UAAU;AAAA,EACd,GACA,CAAC,CAAC,CACJ;AAAA,EAGA,OAAO,kBAAkB,uBAAuB,UAAS,KAAK;AAAA,EAC9D,OAAO,iBAAiB,sBAAsB,UAAS,KAAK;AAAA,EAC5D,OAAO,iBAAiB,sBAAsB,UAAS,KAAK;AAAA,EAC5D,OAAO,gBAAgB,qBAAqB,UAAS,KAAK;AAAA,EAE1D,MAAM,cAAc,YAAY,KAAK;AAAA,EACrC,MAAM,QAAQ,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM,cAAc,IAAI,CAAC;AAAA,EAGtE,MAAM,oBAAoB,CAAC,UAAkB;AAAA,IAC3C,MAAM,UAAU,YAAY,MAAM,KAAK;AAAA,IACvC,eAAe,OAAO;AAAA,IACtB,oBAAoB,KAAK;AAAA;AAAA,EAG3B,MAAM,mBAAmB,CAAC,SAAiB;AAAA,IACzC,MAAM,UAAU,YAAY,KAAK,IAAI;AAAA,IACrC,eAAe,OAAO;AAAA,IACtB,mBAAmB,KAAK;AAAA;AAAA,EAG1B,uBACE;AAAA,cAwNE;AAAA,MAvNC,SAAS,0BACR,OAsCE,SAtCF;AAAA,QAAS,MAAM;AAAA,QAAkB,cAAc;AAAA,QAA/C,UAsCE;AAAA,0BArCA,MAmBE,gBAnBF;AAAA,YAAgB,SAAO;AAAA,YAAvB,0BACE,OAiBE,QAjBF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cAFZ,UAiBE;AAAA,gCAbA,MAWE,kBAXF;AAAA,kBAAiB,MAAK;AAAA,kBAAtB,0BACE,MASE,QAAO,MATT;AAAA,oBAEE,SAAQ;AAAA,oBACR,SAAQ;AAAA,oBACR,MAAK;AAAA,oBACL,UAAU;AAAA,oBACV,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,oBANlD,UAQG,YAAY,OAAO,MAAM;AAAA,qBAPrB,SAAS,YAAY,MAAM,GAQhC;AAAA,iBACF;AAAA,gCACF,MAAC,aAAD;AAAA,kBAAa,WAAU;AAAA,iBAAU;AAAA;AAAA,aACjC;AAAA,WACF;AAAA,0BACF,MAgBE,gBAhBF;AAAA,YAAgB,WAAU;AAAA,YAA1B,0BACE,MAcE,OAdF;AAAA,cAAK,WAAU;AAAA,cAAf,UACG,OAAO,IAAI,CAAC,OAAO,0BAClB,MAUE,QAVF;AAAA,gBAEE,SAAQ;AAAA,gBACR,WAAW,GACT,6BACA,YAAY,MAAM,MAAM,SAAS,eACnC;AAAA,gBACA,SAAS,MAAM,kBAAkB,KAAK;AAAA,gBAPxC,UASG;AAAA,iBARI,KASL,CACH;AAAA,aACD;AAAA,WACF;AAAA;AAAA,OACF;AAAA,sBAGJ,OAsCE,SAtCF;AAAA,QAAS,MAAM;AAAA,QAAiB,cAAc;AAAA,QAA9C,UAsCE;AAAA,0BArCA,MAmBE,gBAnBF;AAAA,YAAgB,SAAO;AAAA,YAAvB,0BACE,OAiBE,QAjBF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cAFZ,UAiBE;AAAA,gCAbA,MAWE,kBAXF;AAAA,kBAAiB,MAAK;AAAA,kBAAtB,0BACE,MASE,QAAO,MATT;AAAA,oBAEE,SAAQ;AAAA,oBACR,SAAQ;AAAA,oBACR,MAAK;AAAA,oBACL,UAAU;AAAA,oBACV,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,oBANlD,UAQG,YAAY,OAAO,MAAM;AAAA,qBAPrB,QAAQ,YAAY,KAAK,GAQ9B;AAAA,iBACF;AAAA,gCACF,MAAC,aAAD;AAAA,kBAAa,WAAU;AAAA,iBAAU;AAAA;AAAA,aACjC;AAAA,WACF;AAAA,0BACF,MAgBE,gBAhBF;AAAA,YAAgB,WAAU;AAAA,YAA1B,0BACE,MAcE,OAdF;AAAA,cAAK,WAAU;AAAA,cAAf,UACG,MAAM,IAAI,CAAC,yBACV,MAUE,QAVF;AAAA,gBAEE,SAAQ;AAAA,gBACR,WAAW,GACT,6BACA,YAAY,KAAK,MAAM,QAAQ,eACjC;AAAA,gBACA,SAAS,MAAM,iBAAiB,IAAI;AAAA,gBAPtC,UASG;AAAA,iBARI,IASL,CACH;AAAA,aACD;AAAA,WACF;AAAA;AAAA,OACF;AAAA,MAGD,SAAS,0BACR,OAgEE,SAhEF;AAAA,QAAS,MAAM;AAAA,QAAiB,cAAc;AAAA,QAA9C,UAgEE;AAAA,0BA/DA,MAuBE,gBAvBF;AAAA,YAAgB,SAAO;AAAA,YAAvB,0BACE,OAqBE,QArBF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cAFZ,UAqBE;AAAA,gCAjBA,MAeE,kBAfF;AAAA,kBAAiB,MAAK;AAAA,kBAAtB,0BACE,MAaE,QAAO,MAbT;AAAA,oBAEE,SAAQ;AAAA,oBACR,SAAQ;AAAA,oBACR,MAAK;AAAA,oBACL,UAAU;AAAA,oBACV,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,oBANlD,UAQG,GAAG,YACD,QAAQ,MAAM,EACd,OAAO,OAAO,OAAO,YACrB,MAAM,MAAM,EACZ,OAAO,OAAO;AAAA,qBAXZ,cAAc,YAAY,OAAO,YAAY,GAYlD;AAAA,iBACF;AAAA,gCACF,MAAC,aAAD;AAAA,kBAAa,WAAU;AAAA,iBAA0B;AAAA;AAAA,aACjD;AAAA,WACF;AAAA,0BACF,MAsCE,gBAtCF;AAAA,YAAgB,WAAU;AAAA,YAA1B,0BACE,MAoCE,OApCF;AAAA,cAAK,WAAU;AAAA,cAAf,UAEG,MAAM,KAAK,EAAE,QAAQ,EAAE,GAAG,CAAC,GAAG,MAAM;AAAA,gBACnC,MAAM,WAAW,YAAY,SAAS,GAAG,MAAM,EAAE,IAAI,GAAG,MAAM;AAAA,gBAC9D,MAAM,cAAc,SAAS,QAAQ,MAAM;AAAA,gBAC3C,MAAM,YAAY,SAAS,MAAM,MAAM;AAAA,gBACvC,MAAM,gBAAgB,SAAS,OAAO,aAAa,MAAM;AAAA,gBAEzD,uBACE,MAwBE,QAxBF;AAAA,kBAEE,SAAQ;AAAA,kBACR,WAAW,GACT,6BACA,iBAAiB,eACnB;AAAA,kBACA,SAAS,MAAM;AAAA,oBACb,eAAe,WAAW;AAAA,oBAC1B,mBAAmB,KAAK;AAAA;AAAA,kBAT5B,0BAYE,OAWE,OAXF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAWE;AAAA,sCAVA,MAEiC,QAFjC;AAAA,kCAAO,GAAG,YAAY,OACpB,OACF,OAAO,UAAU,OAAO,GAAG;AAAA,uBAAM;AAAA,sBAChC,YAAY,MAAM,MAAM,UAAU,MAAM,qBACvC,MAIE,QAJF;AAAA,wBAAM,WAAU;AAAA,wBAAhB,UACG,GAAG,YAAY,OAAO,KAAK,KAAK,UAAU,OACzC,KACF;AAAA,uBACA;AAAA;AAAA,mBAEJ;AAAA,mBAtBG,YAAY,OAAO,YAAY,CAuBpC;AAAA,eAEL;AAAA,aACD;AAAA,WACF;AAAA;AAAA,OACF;AAAA,MAEH,SAAS,yBACR,OA8DE,SA9DF;AAAA,QAAS,MAAM;AAAA,QAAgB,cAAc;AAAA,QAA7C,UA8DE;AAAA,0BA7DA,MAmBE,gBAnBF;AAAA,YAAgB,SAAO;AAAA,YAAvB,0BACE,OAiBE,QAjBF;AAAA,cACE,SAAQ;AAAA,cACR,WAAU;AAAA,cAFZ,UAiBE;AAAA,gCAbA,MAWE,kBAXF;AAAA,kBAAiB,MAAK;AAAA,kBAAtB,0BACE,MASE,QAAO,MATT;AAAA,oBAEE,SAAQ;AAAA,oBACR,SAAQ;AAAA,oBACR,MAAK;AAAA,oBACL,UAAU;AAAA,oBACV,YAAY,EAAE,UAAU,MAAM,MAAM,YAAY;AAAA,oBANlD,UAQG,YAAY,OAAO,SAAS;AAAA,qBAPxB,YAAY,YAAY,OAAO,YAAY,GAQhD;AAAA,iBACF;AAAA,gCACF,MAAC,aAAD;AAAA,kBAAa,WAAU;AAAA,iBAA0B;AAAA;AAAA,aACjD;AAAA,WACF;AAAA,0BACF,MAwCE,gBAxCF;AAAA,YAAgB,WAAU;AAAA,YAA1B,0BACE,MAsCE,OAtCF;AAAA,cAAK,WAAU;AAAA,cAAf,WAEI,MAAM;AAAA,gBAEN,MAAM,kBAAkB,YAAY,QAAQ,OAAO;AAAA,gBACnD,MAAM,cAAc,YAAY,YAAY;AAAA,gBAG5C,OAAO,MAAM,KAAK,EAAE,QAAQ,YAAY,GAAG,CAAC,GAAG,MAAM;AAAA,kBACnD,MAAM,UAAU,gBAAgB,KAAK,IAAI,CAAC;AAAA,kBAC1C,MAAM,eAAe,QAAQ,OAAO,aAAa,KAAK;AAAA,kBACtD,MAAM,UAAU,QAAQ,OAAO,qBAAM,GAAG,KAAK;AAAA,kBAE7C,uBACE,MAoBE,QApBF;AAAA,oBAEE,SAAQ;AAAA,oBACR,WAAW,GACT,6BACA,gBAAgB,eAClB;AAAA,oBACA,SAAS,MAAM;AAAA,sBACb,eAAe,OAAO;AAAA,sBACtB,kBAAkB,KAAK;AAAA;AAAA,oBAT3B,0BAYE,OAOE,OAPF;AAAA,sBAAK,WAAU;AAAA,sBAAf,UAOE;AAAA,wCANA,MAAuC,QAAvC;AAAA,oCAAO,QAAQ,OAAO,aAAa;AAAA,yBAAI;AAAA,wBACtC,2BACC,MAEE,QAFF;AAAA,0BAAM,WAAU;AAAA,0BAAhB,UACG,EAAE,OAAO;AAAA,yBACV;AAAA;AAAA,qBAEJ;AAAA,qBAlBG,QAAQ,OAAO,YAAY,CAmBhC;AAAA,iBAEL;AAAA,iBACA;AAAA,aACH;AAAA,WACF;AAAA;AAAA,OACF;AAAA;AAAA,GAEJ;AAAA;AAIN,IAAe;;;AC7Rf;;AAeA,IAAM,eAA4C;AAAA,EAChD;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACI;AAAA,EACJ,QAAQ,MAAM,mBAAmB;AAAA,EACjC,MAAM,SAAS,YAAY;AAAA,EAG3B,MAAM,qBAAqB,CAAC,aAAgD;AAAA,IAC1E,OAAO,GAEL,SAAS,WAAW,IAEpB,gBAAgB,YAAY,eAC9B;AAAA;AAAA,EAGF,MAAM,gBAAgB,CAAC,aAAgD;AAAA,IACrE,OAAO,gBAAgB,WAAW,YAAY;AAAA;AAAA,EAGhD,uBACE,OAiDE,OAjDF;AAAA,IACE,WAAW,GACT,SAAS,2BAA2B,cACpC,SACF;AAAA,IAJF,UAiDE;AAAA,sBA3CA,MAEE,QAFF;AAAA,QAAQ,SAAS;AAAA,QAAY,SAAQ;AAAA,QAAU;AAAA,QAA/C,0BACE,MAAC,aAAD;AAAA,UAAa,WAAU;AAAA,SAAU;AAAA,OACjC;AAAA,sBACF,MAEE,QAFF;AAAA,QAAQ,SAAS;AAAA,QAAQ,SAAQ;AAAA,QAAU;AAAA,QAA3C,0BACE,MAAC,cAAD;AAAA,UAAc,WAAU;AAAA,SAAU;AAAA,OAClC;AAAA,sBAEF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,KAAK;AAAA,QAC7B,SAAS,cAAc,KAAK;AAAA,QAC5B;AAAA,QACA,WAAW,mBAAmB,KAAK;AAAA,QAJrC,UAMG,EAAE,KAAK;AAAA,OACR;AAAA,sBACF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,MAAM;AAAA,QAC9B,SAAS,cAAc,MAAM;AAAA,QAC7B;AAAA,QACA,WAAW,mBAAmB,MAAM;AAAA,QAJtC,UAMG,EAAE,MAAM;AAAA,OACT;AAAA,sBACF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,OAAO;AAAA,QAC/B,SAAS,cAAc,OAAO;AAAA,QAC9B;AAAA,QACA,WAAW,mBAAmB,OAAO;AAAA,QAJvC,UAMG,EAAE,OAAO;AAAA,OACV;AAAA,sBACF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,MAAM;AAAA,QAC9B,SAAS,cAAc,MAAM;AAAA,QAC7B;AAAA,QACA,WAAW,mBAAmB,MAAM;AAAA,QAJtC,UAMG,EAAE,MAAM;AAAA,OACT;AAAA,sBAEF,MAEE,QAFF;AAAA,QAAQ,SAAS;AAAA,QAAS,SAAQ;AAAA,QAAU;AAAA,QAA5C,UACG,EAAE,OAAO;AAAA,OACV;AAAA;AAAA,GACF;AAAA;AAIN,IAAe;;;AFhFf,IAAM,SAAgC,GAAG,YAAY,SAAS;AAAA,EAC5D;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MACE,mBAAmB;AAAA,EAGvB,OAAO,mBAAmB,wBAAwB,UAAS,KAAK;AAAA,EAGhE,MAAM,mBAAmB,CACvB,SACA,eAAe,UACZ;AAAA,IACH,QAAQ,OAAO;AAAA,IACf,IAAI,cAAc;AAAA,MAChB,qBAAqB,KAAK;AAAA,IAC5B;AAAA;AAAA,EAIF,MAAM,eAAe,aAAY,MAAM;AAAA,IACrC,MAAM,WAAW,kBAAkB,IAAI,KAAK,EAAE,YAAY,EAAE,MAAM,GAAG,EAAE;AAAA,IACvE,kBAAkB,WAAW,UAAU,gBAAgB;AAAA,IACvD,qBAAqB,KAAK;AAAA,KACzB,CAAC,SAAS,CAAC;AAAA,EAGd,MAAM,mBAAmB;AAAA,IACvB,OAAO,MAAM;AAAA,MACX,MAAM;AAAA,MACN,qBAAqB,KAAK;AAAA;AAAA,IAE5B,UAAU,MAAM;AAAA,MACd,WAAW;AAAA,MACX,qBAAqB,KAAK;AAAA;AAAA,IAE5B,MAAM,MAAM;AAAA,MACV,WAAW;AAAA,MACX,qBAAqB,KAAK;AAAA;AAAA,EAE9B;AAAA,EAEA,MAAM,iBAAiB,aACrB,sBACE,MAUE,OAVF;AAAA,IAAK,WAAU;AAAA,IAAf,0BACE,OAQE,QARF;AAAA,MACE,SAAS,MAAM,cAAc;AAAA,MAC7B,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,WAAU;AAAA,MAJZ,UAQE;AAAA,wBAFA,MAAC,MAAD;AAAA,UAAM,WAAU;AAAA,SAAU;AAAA,wBAC1B,MAA0C,QAA1C;AAAA,UAAM,WAAU;AAAA,UAAhB;AAAA,SAA0C;AAAA;AAAA,KAC1C;AAAA,GACF,GAEJ,CAAC,aAAa,CAChB;AAAA,EAEA,IAAI,iBAAiB;AAAA,IAEnB,OAAO;AAAA,EACT;AAAA,EAEA,uBACE;AAAA,8BAEE,MA4FE,OA5FF;AAAA,MACE,WAAU;AAAA,MACV,eAAY;AAAA,MAFd,0BAIE,OAuFE,OAvFF;AAAA,QACE,WAAW,GACT,8FACA,WACA,eACF;AAAA,QALF,UAuFE;AAAA,0BA/EA,OAGE,OAHF;AAAA,YAAK,WAAU;AAAA,YAAf,UAGE;AAAA,8BAFA,MAAC,eAAD;AAAA,gBAAc,WAAU;AAAA,eAAU;AAAA,8BAClC,MAAC,uBAAD,EAAc;AAAA;AAAA,WACd;AAAA,0BAGF,OAwEE,OAxEF;AAAA,YAAK,WAAU;AAAA,YAAf,UAwEE;AAAA,8BAtEA,OAwBE,OAxBF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UAwBE;AAAA,kCAvBA,MAAC,uBAAD;AAAA,oBACE,aAAa;AAAA,oBACb,UAAU;AAAA,oBACV,SAAS;AAAA,oBACT,QAAQ;AAAA,oBACR,YAAY;AAAA,oBACZ,SAAQ;AAAA,oBACR,WAAU;AAAA,mBACZ;AAAA,kCAGA,MAAC,gBAAD,EAAgB;AAAA,kCAGhB,OAQE,QARF;AAAA,oBACE,SAAS;AAAA,oBACT,SAAQ;AAAA,oBACR,MAAK;AAAA,oBACL,WAAU;AAAA,oBAJZ,UAQE;AAAA,sCAFA,MAAC,UAAD;AAAA,wBAAU,WAAU;AAAA,uBAAU;AAAA,sCAC9B,MAAyD,QAAzD;AAAA,wBAAM,WAAU;AAAA,wBAAhB;AAAA,uBAAyD;AAAA;AAAA,mBACzD;AAAA;AAAA,eACF;AAAA,8BAGF,OA0CE,OA1CF;AAAA,gBAAK,WAAU;AAAA,gBAAf,UA0CE;AAAA,kCAxCA,MAAC,gBAAD,EAAgB;AAAA,kCAEhB,OAqCE,SArCF;AAAA,oBACE,MAAM;AAAA,oBACN,cAAc;AAAA,oBAFhB,UAqCE;AAAA,sCAjCA,MAIE,gBAJF;AAAA,wBAAgB,SAAO;AAAA,wBAAvB,0BACE,MAEE,QAFF;AAAA,0BAAQ,SAAQ;AAAA,0BAAU,MAAK;AAAA,0BAA/B,0BACE,MAAC,MAAD;AAAA,4BAAM,WAAU;AAAA,2BAAU;AAAA,yBAC1B;AAAA,uBACF;AAAA,sCACF,MA2BE,gBA3BF;AAAA,wBAAgB,OAAM;AAAA,wBAAM,WAAU;AAAA,wBAAtC,0BACE,OAyBE,OAzBF;AAAA,0BAAK,WAAU;AAAA,0BAAf,UAyBE;AAAA,4CAxBA,MAEE,MAFF;AAAA,8BAAI,WAAU;AAAA,8BAAd;AAAA,6BAEE;AAAA,4CACF,MAAC,uBAAD;AAAA,8BACE,aAAa;AAAA,8BACb,UAAU,CAAC,YAAY,iBAAiB,SAAS,IAAI;AAAA,8BACrD,SAAS,iBAAiB;AAAA,8BAC1B,QAAQ,iBAAiB;AAAA,8BACzB,YAAY,iBAAiB;AAAA,8BAC7B,SAAQ;AAAA,6BACV;AAAA,4CAGA,MAUE,OAVF;AAAA,8BAAK,WAAU;AAAA,8BAAf,0BACE,OAQE,QARF;AAAA,gCACE,SAAS;AAAA,gCACT,SAAQ;AAAA,gCACR,MAAK;AAAA,gCACL,WAAU;AAAA,gCAJZ,UAQE;AAAA,kDAFA,MAAC,UAAD;AAAA,oCAAU,WAAU;AAAA,mCAAU;AAAA,kCANhC;AAAA;AAAA,+BAQE;AAAA,6BACF;AAAA;AAAA,yBACF;AAAA,uBACF;AAAA;AAAA,mBACF;AAAA;AAAA,eACF;AAAA;AAAA,WACF;AAAA;AAAA,OACF;AAAA,KACF;AAAA,GACF;AAAA;AAIN,IAAe;;AGzLf,4BAAS,4BAAiB;AAAA;AAE1B,IAAM,WAAqB,MAAM;AAAA,EAC/B,QAAQ,aAAa,YAAY,QAAQ,SAAS,uBAAuB,MACvE,mBAAmB;AAAA,EACrB,MAAM,OAAO,YAAY,KAAK;AAAA,EAG9B,MAAM,SAAS,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM;AAAA,IAClD,MAAM,YAAY,qBAAM,EAAE,KAAK,IAAI,EAAE,MAAM,CAAC,EAAE,QAAQ,OAAO;AAAA,IAC7D,OAAO;AAAA,MACL,MAAM;AAAA,MACN,MAAM,UAAU,OAAO,MAAM;AAAA,MAC7B,aAAa,UAAU,YAAY;AAAA,MACnC,iBAAiB,UAAU,QAAQ,OAAO,EAAE,IAAI;AAAA,IAClD;AAAA,GACD;AAAA,EAGD,MAAM,uBAAuB,OAAO,IAAI,CAAC,UAAU;AAAA,IACjD,MAAM,gBAAgB,OAAO,OAC3B,CAAC,UACC,MAAM,MAAM,KAAK,MAAM,QACvB,MAAM,MAAM,MAAM,MAAM,MAAM,KAAK,MAAM,CAC7C;AAAA,IAEA,OAAO;AAAA,SACF;AAAA,MACH,YAAY,cAAc;AAAA,IAC5B;AAAA,GACD;AAAA,EAGD,MAAM,mBAAmB,CAAC,SAAsB;AAAA,IAC9C,WAAW,IAAI;AAAA,IACf,QAAQ,OAAO;AAAA;AAAA,EAIjB,MAAM,iBAAiB,CAAC,MAAmB,UAA4B;AAAA,IACrE,MAAM,gBAAgB;AAAA,IACtB,WAAW,IAAI;AAAA,IACf,QAAQ,KAAK;AAAA;AAAA,EAIf,MAAM,qBAAqB,CAAC,UAA4C;AAAA,IAEtE,MAAM,qBAAqB,MAAM,KAAK,QAAQ,OAAO,EAAE,QAAQ,MAAM;AAAA,IAGrE,MAAM,YAAY,MAAM,KAAK,EAAE,QAAQ,GAAG,GAAG,CAAC,GAAG,MAAM;AAAA,MACrD,MAAM,MAAM,mBAAmB,IAAI,GAAG,KAAK;AAAA,MAC3C,MAAM,iBAAiB,IAAI,MAAM,MAAM,MAAM,KAAK,MAAM;AAAA,MACxD,MAAM,UAAU,IAAI,OAAO,qBAAM,GAAG,KAAK;AAAA,MACzC,MAAM,gBAAgB,IAAI,OAAO,aAAa,KAAK;AAAA,MAGnD,MAAM,YAAY,sBAChB,IAAI,QAAQ,KAAK,GACjB,IAAI,MAAM,KAAK,CACjB;AAAA,MACA,MAAM,YAAY,UAAU,SAAS;AAAA,MAErC,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,YAAY,UAAU;AAAA,QAEtB,QAAQ;AAAA,MACV;AAAA,KACD;AAAA,IAED,uBACE,OAmFE,OAnFF;AAAA,MACE,eAAa,sBAAsB,MAAM,KAAK,OAAO,IAAI;AAAA,MACzD,WAAU;AAAA,MAFZ,UAmFE;AAAA,QA9EC,CAAC,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,GAAG,EAAE,IAAI,CAAC,SAAS,sBACjD,MAKE,OALF;AAAA,UAEE,WAAU;AAAA,UAFZ,UAIG;AAAA,WAHI,UAAU,GAIf,CACH;AAAA,QAGA,UAAU,IAAI,CAAC,SAAS,sBACvB,OAiEE,OAjEF;AAAA,UAEE,eAAa,YAAY,MAAM,KAAK,OAAO,SAAS,KAAK,QAAQ,IAAI,OAAO,YAAY;AAAA,UACxF,SAAS,CAAC,MAAM,eAAe,QAAQ,KAAK,CAAC;AAAA,UAC7C,WAAW,GACT,0FACA,8DACC,QAAQ,kBAAkB,oCAC3B,QAAQ,WACN,mDACF,QAAQ,kBACL,QAAQ,WACT,mCACF,QAAQ,cACL,QAAQ,YACR,QAAQ,iBACT,aACJ;AAAA,UACA,OACE,QAAQ,YACJ,GAAG,QAAQ,mBACT,QAAQ,aAAa,IAAI,MAAM,OAEjC;AAAA,UAvBR,UAiEE;AAAA,4BAvCA,MAEE,QAFF;AAAA,cAAM,WAAU;AAAA,cAAhB,UACG,QAAQ,IAAI,KAAK;AAAA,aAClB;AAAA,YAGD,QAAQ,6BACP,OA+BE,OA/BF;AAAA,cACE,WAAW,GACT,8DACA,QAAQ,UAAU,iBAAiB,EACrC;AAAA,cAJF,UA+BE;AAAA,gBAxBC,QAAQ,aAAa,qBACpB,MAAC,QAAD;AAAA,kBACE,WAAW,GACT,gCACA,QAAQ,UAAU,0BAA0B,YAC9C;AAAA,iBACF;AAAA,gBAED,QAAQ,aAAa,qBACpB,MAAC,QAAD;AAAA,kBACE,WAAW,GACT,gCACA,QAAQ,UAAU,0BAA0B,aAC9C;AAAA,iBACF;AAAA,gBAED,QAAQ,aAAa,qBACpB,MAAC,QAAD;AAAA,kBACE,WAAW,GACT,gCACA,QAAQ,UAAU,0BAA0B,cAC9C;AAAA,iBACF;AAAA;AAAA,aAEF;AAAA;AAAA,WA9DC,OAAO,GAgEZ,CACH;AAAA;AAAA,KACD;AAAA;AAAA,EAIN,uBACE,MA+CE,YA/CF;AAAA,IAAY,eAAY;AAAA,IAAY,WAAU;AAAA,IAA9C,0BACE,MA6CE,OA7CF;AAAA,MACE,eAAY;AAAA,MACZ,WAAU;AAAA,MAFZ,UAIG,qBAAqB,IAAI,CAAC,OAAO,0BAChC,OAsCE,OAtCF;AAAA,QAEE,eAAa,cAAc,MAAM,KAAK,OAAO,IAAI;AAAA,QACjD,SAAS,MAAM,iBAAiB,MAAM,IAAI;AAAA,QAC1C,WAAU;AAAA,QAJZ,UAsCE;AAAA,0BAhCA,MA6BE,kBA7BF;AAAA,YAAiB,MAAK;AAAA,YAAtB,0BACE,OA2BE,QAAO,KA3BT;AAAA,cAEE,SAAS,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,cAC9B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,cAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,cAC3B,YAAY;AAAA,gBACV,UAAU;AAAA,gBACV,MAAM;AAAA,gBACN,OAAO,QAAQ;AAAA,cACjB;AAAA,cACA,WAAU;AAAA,cAVZ,UA2BE;AAAA,gCAfA,MAKE,MALF;AAAA,kBACE,eAAa,oBAAoB,MAAM,KAAK,OAAO,IAAI;AAAA,kBACvD,WAAU;AAAA,kBAFZ,UAIG,MAAM;AAAA,iBACP;AAAA,gBACD,MAAM,aAAa,qBAClB,OAME,QANF;AAAA,kBACE,eAAa,0BAA0B,MAAM,KAAK,OAAO,IAAI;AAAA,kBAC7D,WAAU;AAAA,kBAFZ,UAME;AAAA,oBAFC,MAAM;AAAA,oBAAY;AAAA,oBAClB,MAAM,eAAe,IAAI,EAAE,OAAO,IAAI,EAAE,QAAQ;AAAA;AAAA,iBACjD;AAAA;AAAA,eAxBC,SAAS,OA0Bd;AAAA,WACF;AAAA,UAED,mBAAmB,KAAK;AAAA;AAAA,SApCpB,MAAM,IAqCX,CACH;AAAA,KACD;AAAA,GACF;AAAA;AAIN,IAAe;;;ACtNf,4BAAS,4BAAiB;;;ACP1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA,6BAAgB;AAMhB;;AAUO,SAAS,kBAAkB,GAAG,YAAqC;AAAA,EACxE,QAAQ,aAAa,6CAAsB,MAAM,uBAC/C,mBAAmB;AAAA,EACrB,OAAO,aAAa,kBAAkB,OAAM,SAC1C,IACF;AAAA,EAGA,OAAO,iBAAiB,sBAAsB,UAI3C;AAAA,IACD,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,SAAS;AAAA,EACX,CAAC;AAAA,EAGD,MAAM,cAAc,UAAU,aAAa;AAAA,IAEzC,sBAAsB;AAAA,MACpB,UAAU;AAAA,IACZ;AAAA,EACF,CAAC;AAAA,EAED,MAAM,cAAc,UAAU,aAAa;AAAA,IAEzC,sBAAsB;AAAA,MACpB,OAAO;AAAA,MACP,WAAW;AAAA,IACb;AAAA,EACF,CAAC;AAAA,EAED,MAAM,UAAU,WAAW,aAAa,WAAW;AAAA,EAGnD,MAAM,qBAAqB,CACzB,OACA,YACG;AAAA,IAEH,KAAK,UAAU,MAAM,IAAI;AAAA,MACvB;AAAA,IACF;AAAA,IAEA,KAAK,WAAW,OAAO,KAAK,OAAO,EAAE,WAAW,GAAG;AAAA,MACjD;AAAA,IACF;AAAA,IAEA,IAAI,iBAAiB,KAAK,GAAG;AAAA,MAE3B,mBAAmB;AAAA,QACjB,QAAQ;AAAA,QACR;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH,EAAO;AAAA,MAEL,YAAY,MAAM,IAAI,OAAO;AAAA;AAAA;AAAA,EAKjC,MAAM,8BAA8B,CAAC,UAA+B;AAAA,IAClE,KAAK,gBAAgB,UAAU,gBAAgB,SAAS;AAAA,MACtD,mBAAmB,EAAE,QAAQ,OAAO,OAAO,MAAM,SAAS,KAAK,CAAC;AAAA,MAChE;AAAA,IACF;AAAA,IAEA,IAAI;AAAA,MACF,sBAAqB,gBAAgB,OAAO,gBAAgB,SAAS;AAAA,QACnE;AAAA,QACA,WAAW,gBAAgB,MAAM;AAAA,MACnC,CAAC;AAAA,MACD,MAAM,WAEN;AAAA,MACA,mBAAmB,EAAE,QAAQ,OAAO,OAAO,MAAM,SAAS,KAAK,CAAC;AAAA;AAAA;AAAA,EAKpE,MAAM,4BAA4B,MAAM;AAAA,IACtC,mBAAmB,EAAE,QAAQ,OAAO,OAAO,MAAM,SAAS,KAAK,CAAC;AAAA;AAAA,EAGlE,MAAM,kBAAkB,CAAC,UAA0B;AAAA,IACjD,QAAQ,WAAW;AAAA,IAGnB,IAAI,OAAO,KAAK,SAAS,SAAS,kBAAkB;AAAA,MAClD,eAAe,OAAO,KAAK,QAAQ,KAAK;AAAA,IAC1C;AAAA;AAAA,EAGF,MAAM,gBAAgB,CAAC,UAAwB;AAAA,IAC7C,QAAQ,QAAQ,SAAS;AAAA,IAEzB,KAAK,WAAW,SAAS,aAAa;AAAA,MACpC,eAAe,IAAI;AAAA,MACnB;AAAA,IACF;AAAA,IAEA,IAAI,KAAK,KAAK,SAAS,SAAS,aAAa;AAAA,MAC3C,QAAQ,MAAM,OAAO,GAAG,SAAS,MAAM,KAAK,KAAK;AAAA,MAGjD,MAAM,QAAQ,YAAY;AAAA,MAC1B,MAAM,MAAM,YAAY;AAAA,MACxB,MAAM,kBAAkB,IAAI,KAAK,OAAO,QAAQ;AAAA,MAGhD,MAAM,WAAW,qBAAM,IAAI,EACxB,KAAK,IAAI,EACT,OAAO,UAAU,CAAC;AAAA,MAGrB,IAAI,SAAS,SAAS,IAAI,iBAAiB,QAAQ;AAAA,MACnD,IAAI,OAAO,OAAO,OAAO,QAAQ,KAAK,CAAC,GAAG;AAAA,QAExC,SAAS,OAAO,SAAS,GAAG,KAAK,EAAE,MAAM,KAAK;AAAA,MAChD;AAAA,MAGA,mBAAmB,aAAa;AAAA,QAC9B,OAAO;AAAA,QACP,KAAK;AAAA,MACP,CAAC;AAAA,IACH,EAAO,SAAI,KAAK,KAAK,SAAS,SAAS,YAAY;AAAA,MACjD,QAAQ,SAAS,KAAK,KAAK;AAAA,MAC3B,MAAM,UAAU,qBAAM,IAAI;AAAA,MAG1B,MAAM,mBAAmB,YAAY,MAAM,OAAO,YAAY,KAAK,KAAK;AAAA,MACxE,MAAM,QAAQ,YAAY;AAAA,MAC1B,MAAM,MAAM,YAAY;AAAA,MAExB,IAAI,iBAAiB;AAAA,QACnB,IAAI,SAAS,QAAQ;AAAA,UAEnB,MAAM,YAAY,MAAM,KAAK;AAAA,UAC7B,MAAM,cAAc,MAAM,OAAO;AAAA,UACjC,MAAM,UAAU,IAAI,KAAK;AAAA,UACzB,MAAM,YAAY,IAAI,OAAO;AAAA,UAG7B,MAAM,eAAe,IAAI,KAAK,OAAO,KAAK;AAAA,UAG1C,MAAM,WAAW,QACd,QAAQ,KAAK,EACb,KAAK,SAAS,EACd,OAAO,WAAW;AAAA,UACrB,MAAM,SAAS,SACZ,IAAI,cAAc,KAAK,EACvB,KAAK,OAAO,EACZ,OAAO,SAAS;AAAA,UAEnB,mBAAmB,aAAa;AAAA,YAC9B,OAAO;AAAA,YACP,KAAK;AAAA,UACP,CAAC;AAAA,QACH,EAAO;AAAA,UAGL,MAAM,iBAAiB,QAAQ,KAAK,MAAM,QAAQ,KAAK,GAAG,KAAK;AAAA,UAG/D,MAAM,WAAW,MAAM,IAAI,gBAAgB,KAAK;AAAA,UAChD,MAAM,SAAS,IAAI,IAAI,gBAAgB,KAAK;AAAA,UAE5C,mBAAmB,aAAa;AAAA,YAC9B,OAAO;AAAA,YACP,KAAK;AAAA,UACP,CAAC;AAAA;AAAA,MAEL,EAAO;AAAA,QAEL,MAAM,WAAW,QACd,KAAK,YAAY,MAAM,KAAK,CAAC,EAC7B,OAAO,YAAY,MAAM,OAAO,CAAC;AAAA,QAGpC,MAAM,kBAAkB,YAAY,IAAI,KACtC,YAAY,OACZ,QACF;AAAA,QACA,MAAM,SAAS,SAAS,IAAI,iBAAiB,QAAQ;AAAA,QAErD,mBAAmB,aAAa;AAAA,UAC9B,OAAO;AAAA,UACP,KAAK;AAAA,QACP,CAAC;AAAA;AAAA,IAEL;AAAA,IAEA,eAAe,IAAI;AAAA;AAAA,EAGrB,MAAM,mBAAmB,CAAC,WAA4B;AAAA,IACpD,eAAe,IAAI;AAAA;AAAA,EAIrB,IAAI,oBAAoB;AAAA,IACtB,OAAO;AAAA,EACT;AAAA,EAEA,uBACE;AAAA,cAgCE;AAAA,sBA/BA,OAqBE,YArBF;AAAA,QACE;AAAA,QACA,aAAa;AAAA,QACb,WAAW;AAAA,QACX,cAAc;AAAA,QACd,oBAAoB;AAAA,QALtB,UAqBE;AAAA,UAdC;AAAA,0BACD,MAYE,aAZF;AAAA,YAAa,WAAW,CAAC,kBAAkB;AAAA,YAA3C,UACG,+BACC,MAQE,OARF;AAAA,cACE,WAAW,GACT,kFACA,YAAY,mBAAmB,eAC/B,YAAY,SAAS,YACvB;AAAA,cALF,UAOG,aAAa;AAAA,aACd;AAAA,WAEJ;AAAA;AAAA,OACF;AAAA,sBAGF,MAAC,sBAAD;AAAA,QACE,QAAQ,gBAAgB;AAAA,QACxB,SAAS;AAAA,QACT,WAAW;AAAA,QACX,eAAc;AAAA,QACd,YAAY,gBAAgB,OAAO,SAAS;AAAA,OAC9C;AAAA;AAAA,GACA;AAAA;;;AC7QN,wBAAgB,2BAAa,uBAAW,sBAAS;;;ACC1C,IAAM,sBAAoC;AAAA,EAE/C,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,QAAQ;AAAA,EAGR,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,OAAO;AAAA,EACP,aAAa;AAAA,EACb,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,SAAS;AAAA,EACT,WAAW;AAAA,EACX,SAAS;AAAA,EACT,OAAO;AAAA,EAGP,aAAa;AAAA,EACb,WAAW;AAAA,EACX,aAAa;AAAA,EACb,kBAAkB;AAAA,EAClB,uBAAuB;AAAA,EACvB,6BAA6B;AAAA,EAC7B,0BAA0B;AAAA,EAG1B,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,kBAAkB;AAAA,EAClB,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,UAAU;AAAA,EACV,OAAO;AAAA,EACP,OAAO;AAAA,EACP,OAAO;AAAA,EACP,MAAM;AAAA,EACN,OAAO;AAAA,EACP,aAAa;AAAA,EACb,IAAI;AAAA,EAGJ,oBAAoB;AAAA,EACpB,sBAAsB;AAAA,EACtB,4BACE;AAAA,EACF,8BACE;AAAA,EACF,WAAW;AAAA,EACX,sBAAsB;AAAA,EACtB,wBAAwB;AAAA,EACxB,mCAAmC;AAAA,EACnC,WAAW;AAAA,EACX,sBAAsB;AAAA,EACtB,gBAAgB;AAAA,EAChB,qBAAqB;AAAA,EACrB,oBAAoB;AAAA,EACpB,gBAAgB;AAAA,EAChB,qBAAqB;AAAA,EACrB,oBAAoB;AAAA,EAGpB,OAAO;AAAA,EACP,MAAM;AAAA,EACN,KAAK;AAAA,EACL,MAAM;AAAA,EACN,MAAM;AAAA,EAGN,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,UAAU;AAAA,EAGV,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EAGL,SAAS;AAAA,EACT,UAAU;AAAA,EACV,OAAO;AAAA,EACP,OAAO;AAAA,EACP,KAAK;AAAA,EACL,MAAM;AAAA,EACN,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,SAAS;AAAA,EACT,UAAU;AAAA,EACV,UAAU;AACZ;;;;ADnEO,IAAM,mBAAoD;AAAA,EAC/D;AAAA,EACA,SAAS,CAAC;AAAA,EACV,iBAAiB;AAAA,EACjB,cAAc;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,mBAAmB;AAAA,EACnB,sBAAsB;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACI;AAAA,EAEJ,OAAO,aAAa,kBAAkB,UAAsB,qBAAM,CAAC;AAAA,EACnE,OAAO,MAAM,WAAW,UACtB,WACF;AAAA,EACA,OAAO,eAAe,oBAAoB,UAA0B,MAAM;AAAA,EAC1E,OAAO,iBAAiB,sBAAsB,UAAkB,KAAK;AAAA,EACrE,OAAO,eAAe,oBAAoB,UAA+B,IAAI;AAAA,EAC7E,OAAO,cAAc,mBAAmB,UAA6B,IAAI;AAAA,EACzE,OAAO,eAAe,oBAAoB,UAAiB,UAAU,IAAI;AAAA,EACzE,OAAO,iBAAiB,sBAAsB,UAAiB,aAAY,EAAE;AAAA,EAG7E,MAAM,IAAI,SAAQ,MAAM;AAAA,IACtB,IAAI,YAAY;AAAA,MAEd,OAAO;AAAA,IACT;AAAA,IAEA,IAAI,cAAc;AAAA,MAEhB,OAAO,CAAC,QAA4B,aAAa,QAAQ;AAAA,IAC3D;AAAA,IAEA,OAAO,CAAC,QAA4B,oBAAoB,QAAQ;AAAA,KAC/D,CAAC,cAAc,UAAU,CAAC;AAAA,EAG7B,MAAM,wBAAwB,aAC5B,CAAC,WAAwB,YAA0C;AAAA,IACjE,MAAM,YAA6B,CAAC;AAAA,IAEpC,WAAW,SAAS,eAAe;AAAA,MACjC,IAAI,MAAM,OAAO;AAAA,QAEf,MAAM,kBAAkB,wBAAwB;AAAA,UAC9C;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF,CAAC;AAAA,QACD,UAAU,KAAK,GAAG,eAAe;AAAA,MACnC,EAAO;AAAA,QAEL,MAAM,qBACJ,MAAM,MAAM,cAAc,SAAS,KACnC,MAAM,MAAM,eAAe,OAAO;AAAA,QAEpC,MAAM,mBACJ,MAAM,IAAI,cAAc,SAAS,KACjC,MAAM,IAAI,eAAe,OAAO;AAAA,QAElC,MAAM,kBACJ,MAAM,MAAM,SAAS,SAAS,KAAK,MAAM,IAAI,QAAQ,OAAO;AAAA,QAE9D,IAAI,sBAAsB,oBAAoB,iBAAiB;AAAA,UAC7D,UAAU,KAAK,KAAK;AAAA,QACtB;AAAA;AAAA,IAEJ;AAAA,IAEA,OAAO;AAAA,KAET,CAAC,aAAa,CAChB;AAAA,EAGA,MAAM,sBAAsB,aAAY,MAAM;AAAA,IAC5C,QAAQ;AAAA,WACD;AAAA,QACH,OAAO;AAAA,UACL,OAAO,YAAY,QAAQ,KAAK;AAAA,UAChC,KAAK,YAAY,MAAM,KAAK;AAAA,QAC9B;AAAA,WACG;AAAA,QACH,OAAO;AAAA,UACL,OAAO,YACJ,QAAQ,MAAM,EACd,SAAS,mBAAmB,IAAI,IAAI,GAAG,KAAK;AAAA,UAC/C,KAAK,YACF,MAAM,MAAM,EACZ,IAAI,mBAAmB,IAAI,IAAI,GAAG,KAAK;AAAA,QAC5C;AAAA,WACG;AAAA,QACH,OAAO;AAAA,UACL,OAAO,YACJ,QAAQ,OAAO,EACf,QAAQ,MAAM,EACd,SAAS,mBAAmB,IAAI,IAAI,GAAG,KAAK;AAAA,UAC/C,KAAK,YACF,MAAM,OAAO,EACb,MAAM,MAAM,EACZ,IAAI,mBAAmB,IAAI,IAAI,GAAG,KAAK;AAAA,QAC5C;AAAA,WACG;AAAA,QACH,OAAO;AAAA,UACL,OAAO,YAAY,QAAQ,MAAM;AAAA,UACjC,KAAK,YAAY,MAAM,MAAM;AAAA,QAC/B;AAAA;AAAA,QAEA,OAAO;AAAA,UACL,OAAO,YAAY,QAAQ,OAAO;AAAA,UAClC,KAAK,YAAY,MAAM,OAAO;AAAA,QAChC;AAAA;AAAA,KAEH,CAAC,aAAa,MAAM,cAAc,CAAC;AAAA,EAGtC,MAAM,kBAAkB,SAAQ,MAAM;AAAA,IACpC,QAAQ,OAAO,QAAQ,oBAAoB;AAAA,IAC3C,OAAO,sBAAsB,OAAO,GAAG;AAAA,KACtC,CAAC,uBAAuB,mBAAmB,CAAC;AAAA,EAG/C,WAAU,MAAM;AAAA,IACd,IAAI,QAAQ;AAAA,MACV,iBAAiB,MAAM;AAAA,IACzB;AAAA,KACC,CAAC,MAAM,CAAC;AAAA,EAGX,WAAU,MAAM;AAAA,IACd,IAAI,QAAQ;AAAA,MACV,iBAAiB,MAAM;AAAA,MACvB,qBAAM,OAAO,MAAM;AAAA,IACrB;AAAA,KACC,CAAC,MAAM,CAAC;AAAA,EAGX,WAAU,MAAM;AAAA,IACd,IAAI,WAAU;AAAA,MACZ,mBAAmB,SAAQ;AAAA,MAC3B,qBAAM,GAAG,WAAW,SAAQ;AAAA,IAC9B;AAAA,KACC,CAAC,SAAQ,CAAC;AAAA,EAGb,MAAM,aAAa,aACjB,CAAC,SAAsB;AAAA,IACrB,eAAe,IAAI;AAAA,IACnB,eAAe,IAAI;AAAA,KAErB,CAAC,YAAY,CACf;AAAA,EAEA,MAAM,aAAa,aAAY,MAAM;AAAA,IACnC,QAAQ;AAAA,WACD;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,IAAI,GAAG,OAAO;AAAA,UAC1C,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,IAAI,GAAG,MAAM;AAAA,UACzC,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,IAAI,GAAG,KAAK;AAAA,UACxC,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,IAAI,GAAG,MAAM;AAAA,UACzC,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA;AAAA,KAEH,CAAC,MAAM,YAAY,CAAC;AAAA,EAEvB,MAAM,aAAa,aAAY,MAAM;AAAA,IACnC,QAAQ;AAAA,WACD;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,SAAS,GAAG,OAAO;AAAA,UAC/C,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,SAAS,GAAG,MAAM;AAAA,UAC9C,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,SAAS,GAAG,KAAK;AAAA,UAC7C,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB;AAAA,UAC9B,MAAM,UAAU,aAAY,SAAS,GAAG,MAAM;AAAA,UAC9C,eAAe,OAAO;AAAA,UACtB,OAAO;AAAA,SACR;AAAA,QACD;AAAA;AAAA,KAEH,CAAC,MAAM,YAAY,CAAC;AAAA,EAEvB,MAAM,QAAQ,aAAY,MAAM;AAAA,IAC9B,MAAM,UAAU,qBAAM;AAAA,IACtB,eAAe,OAAO;AAAA,IACtB,eAAe,OAAO;AAAA,KACrB,CAAC,YAAY,CAAC;AAAA,EAEjB,MAAM,WAAW,aACf,CAAC,UAAyB;AAAA,IACxB,iBAAiB,CAAC,eAAe,CAAC,GAAG,YAAY,KAAK,CAAC;AAAA,IACvD,aAAa,KAAK;AAAA,KAEpB,CAAC,UAAU,CACb;AAAA,EAEA,MAAM,cAAc,aAClB,CAAC,SAAiB,iBAAyC;AAAA,IACzD,iBAAiB,CAAC,eAAe;AAAA,MAC/B,MAAM,UAAU,WAAW,IAAI,CAAC,UAAU;AAAA,QACxC,IAAI,MAAM,OAAO,SAAS;AAAA,UACxB,MAAM,WAAW,KAAK,UAAU,aAAa;AAAA,UAC7C,gBAAgB,QAAQ;AAAA,UACxB,OAAO;AAAA,QACT;AAAA,QACA,OAAO;AAAA,OACR;AAAA,MACD,OAAO;AAAA,KACR;AAAA,KAEH,CAAC,aAAa,CAChB;AAAA,EAEA,MAAM,wBAAuB,aAC3B,CACE,OACA,SACA,YACG;AAAA,IAEH,MAAM,eAAe,KAAK,UAAU,QAAQ;AAAA,IAG5C,gBAAgB,YAAY;AAAA,IAG5B,MAAM,gBAAgB,qBAAyB;AAAA,MAC7C,aAAa;AAAA,MACb;AAAA,MACA;AAAA,MACA,OAAO,QAAQ;AAAA,IACjB,CAAC;AAAA,IAED,iBAAiB,aAAa;AAAA,KAEhC,CAAC,eAAe,aAAa,CAC/B;AAAA,EAEA,MAAM,wBAAuB,aAC3B,CAAC,OAAsB,YAAmC;AAAA,IAExD,gBAAgB,KAAK;AAAA,IAGrB,MAAM,gBAAgB,qBAAyB;AAAA,MAC7C,aAAa;AAAA,MACb;AAAA,MACA,OAAO,QAAQ;AAAA,IACjB,CAAC;AAAA,IAED,iBAAiB,aAAa;AAAA,KAEhC,CAAC,eAAe,aAAa,CAC/B;AAAA,EAEA,MAAM,cAAc,aAClB,CAAC,YAAoB;AAAA,IACnB,iBAAiB,CAAC,eAAe;AAAA,MAC/B,MAAM,gBAAgB,WAAW,KAAK,CAAC,UAAU,MAAM,OAAO,OAAO;AAAA,MACrE,IAAI,eAAe;AAAA,QACjB,gBAAgB,aAAa;AAAA,MAC/B;AAAA,MACA,OAAO,WAAW,OAAO,CAAC,UAAU,MAAM,OAAO,OAAO;AAAA,KACzD;AAAA,KAEH,CAAC,aAAa,CAChB;AAAA,EAEA,MAAM,YAAY,aAAY,CAAC,UAAyB;AAAA,IACtD,iBAAiB,KAAK;AAAA,IACtB,mBAAmB,IAAI;AAAA,KACtB,CAAC,CAAC;AAAA,EAEL,MAAM,iBAAiB,aAAY,MAAM;AAAA,IACvC,gBAAgB,IAAI;AAAA,IACpB,iBAAiB,IAAI;AAAA,IACrB,mBAAmB,KAAK;AAAA,KACvB,CAAC,CAAC;AAAA,EAGL,MAAM,mBAAmB,aACvB,CAAC,YAA+C;AAAA,IAC9C,QAAQ,OAAO;AAAA,IACf,eAAe,OAAO;AAAA,KAExB,CAAC,YAAY,CACf;AAAA,EAEA,MAAM,mBAAmB,aACvB,CAAC,UAAyB;AAAA,IACxB,IAAI,kBAAkB;AAAA,MACpB;AAAA,IACF;AAAA,IACA,IAAI,cAAc;AAAA,MAChB,aAAa,KAAK;AAAA,IACpB,EAAO;AAAA,MACL,UAAU,KAAK;AAAA;AAAA,KAGnB,CAAC,kBAAkB,cAAc,SAAS,CAC5C;AAAA,EAEA,MAAM,kBAAkB,aACtB,CAAC,WAAwB,YAAyB;AAAA,IAChD,IAAI,kBAAkB;AAAA,MACpB;AAAA,IACF;AAAA,IAEA,IAAI,aAAa;AAAA,MACf,YAAY,WAAW,OAAO;AAAA,IAChC,EAAO;AAAA,MACL,gBAAgB,SAAS;AAAA,MACzB,iBAAiB;AAAA,QACf,OAAO,EAAE,UAAU;AAAA,QACnB,OAAO;AAAA,QACP,KAAK;AAAA,QACL,aAAa;AAAA,QACb,QAAQ;AAAA,MACV,CAAkB;AAAA,MAClB,mBAAmB,IAAI;AAAA;AAAA,KAG3B,CAAC,aAAa,kBAAkB,CAAC,CACnC;AAAA,EAEA,MAAM,sBAAsB,aAC1B,CAAC,SAAuB;AAAA,IACtB,IAAI,MAAM;AAAA,MACR,gBAAgB,IAAI;AAAA,IACtB;AAAA,IACA,iBAAiB;AAAA,MACf,OAAO,EAAE,UAAU;AAAA,MACnB,OAAO,QAAQ;AAAA,MACf,KAAK,QAAQ,YAAY,IAAI,GAAG,MAAM;AAAA,MACtC,aAAa;AAAA,MACb,QAAQ;AAAA,IACV,CAAkB;AAAA,IAClB,mBAAmB,IAAI;AAAA,KAEzB,CAAC,aAAa,CAAC,CACjB;AAAA,EAGA,MAAM,2BAA2B,aAC/B,CAAC,UAA+C;AAAA,IAE9C,MAAM,YAAY,MAAM;AAAA,IAExB,MAAM,cAAc,cAAc,KAAK,CAAC,MAAM;AAAA,MAC5C,MAAM,YAAY,EAAE,OAAO,GAAG,EAAE;AAAA,MAChC,OAAO,cAAc,aAAa,EAAE;AAAA,KACrC;AAAA,IAED,OAAO,eAAe;AAAA,KAExB,CAAC,aAAa,CAChB;AAAA,EAGA,MAAM,eAAe,SACnB,OAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR,WAAW;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,eAAe;AAAA,IACf;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,cAAc;AAAA,IACd,aAAa;AAAA,IACb;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IAEA;AAAA,EACF,IACA;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IAEA;AAAA,EACF,CACF;AAAA,EAEA,uBACE,MAEE,gBAAgB,UAFlB;AAAA,IAA0B,OAAO;AAAA,IAAjC;AAAA,GAEE;AAAA;;;;AF7gBN,IAAM,kBAA4B,MAAM;AAAA,EACtC;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MACE,mBAAmB;AAAA,EAEvB,MAAM,UAAU;AAAA,IACd,uBAAO,MAAC,WAAD;AAAA,MAAuB;AAAA,OAAR,OAAoC;AAAA,IAC1D,sBAAM,MAAC,mBAAD,IAAc,MAAO;AAAA,IAC3B,qBAAK,MAAC,kBAAD,IAAa,KAAM;AAAA,IACxB,sBAAM,MAAC,mBAAD,IAAc,MAAO;AAAA,EAC7B;AAAA,EAEA,MAAM,iBAAiB,CAAC,UAAyB;AAAA,IAC/C,YAAY,MAAM,IAAI,KAAK;AAAA;AAAA,EAG7B,MAAM,iBAAiB,CAAC,UAAyB;AAAA,IAC/C,YAAY,MAAM,EAAE;AAAA;AAAA,EAGtB,uBACE,OA8BE,OA9BF;AAAA,IAAK,WAAU;AAAA,IAAf,UA8BE;AAAA,sBA7BA,MAAC,qBAAD;AAAA,QAAQ,WAAU;AAAA,OAAM;AAAA,sBAGxB,MAaE,oBAbF;AAAA,kCACE,MAWE,kBAXF;AAAA,UAAiB,MAAK;AAAA,UAAtB,0BACE,MASE,QAAO,KATT;AAAA,YAEE,SAAS,EAAE,SAAS,GAAG,GAAG,GAAG;AAAA,YAC7B,SAAS,EAAE,SAAS,GAAG,GAAG,EAAE;AAAA,YAC5B,MAAM,EAAE,SAAS,GAAG,GAAG,IAAI;AAAA,YAC3B,YAAY,EAAE,UAAU,KAAK,MAAM,YAAY;AAAA,YAC/C,WAAU;AAAA,YANZ,UAQG,QAAQ;AAAA,aAPJ,IAQL;AAAA,SACF;AAAA,OACF;AAAA,MAGD,mCACC,MAAC,WAAD;AAAA,QACE,SAAS;AAAA,QACT;AAAA,QACA;AAAA,QACA,OAAO;AAAA,QACP,UAAU;AAAA,QACV,UAAU;AAAA,OACZ;AAAA;AAAA,GAEF;AAAA;AAIN,IAAM,yBAAyB;AACxB,IAAM,gBAA8C;AAAA,EACzD;AAAA,EACA,iBAAiB;AAAA,EACjB,cAAc;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe;AAAA,EACf,mBAAmB;AAAA,EACnB,sBAAsB;AAAA,EACtB;AAAA,EACA;AAAA,MACI;AAAA,EACJ,uBACE,MA0BE,kBA1BF;AAAA,IACE,QAAQ,mCAAmC,MAAM;AAAA,IACjD,gBAAgB,qBAAqB;AAAA,IACrC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IAvBF,0BAyBE,MAAC,iBAAD,EAAiB;AAAA,GACjB;AAAA;;;AIlHN,kBAAS;",
  "debugId": "B447EF05B8FF828364756E2164756E21",
  "names": []
}
|