@ilamy/calendar 0.2.1 → 0.3.1

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/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 = () => /* @__PURE__ */ jsx14("div", {
905
- className: cn(event.backgroundColor || "bg-blue-500", event.color || "text-white", "h-full w-full px-1 border-[1.5px] border-card rounded-md text-left overflow-clip"),
906
- style: { backgroundColor: event.backgroundColor, color: event.color },
907
- children: /* @__PURE__ */ jsx14("p", {
908
- className: "text-[10px] font-semibold sm:text-xs mt-0.5",
909
- children: event.title
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 jsxs6 } from "react/jsx-runtime";
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__ */ jsxs6(DialogContent, {
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 jsxs7, Fragment } from "react/jsx-runtime";
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__ */ jsxs7(Fragment, {
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__ */ jsxs7("div", {
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__ */ jsxs7("div", {
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
- " more"
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 jsxs8 } from "react/jsx-runtime";
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-100", viewHeaderClassName, className),
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__ */ jsxs8(motion2.div, {
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-20 overflow-clip",
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 jsxs9 } from "react/jsx-runtime";
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__ */ jsxs9("div", {
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__ */ jsxs9("div", {
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 jsxs10 } from "react/jsx-runtime";
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__ */ jsxs10("div", {
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 jsxs11 } from "react/jsx-runtime";
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__ */ jsxs11("div", {
1539
- className: cn("grid grid-cols-[auto_1fr_1fr_1fr_1fr_1fr_1fr_1fr] grid-rows-1", stickyViewHeader && "sticky top-0 z-100", viewHeaderClassName, className),
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__ */ jsxs11("div", {
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__ */ jsxs11(motion4.div, {
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-30",
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 jsxs12 } from "react/jsx-runtime";
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__ */ jsxs12("div", {
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-20 h-[60px] cursor-pointer border-b")
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 jsxs13 } from "react/jsx-runtime";
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__ */ jsxs13("div", {
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 jsxs14 } from "react/jsx-runtime";
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__ */ jsxs14("div", {
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__ */ jsxs14(ScrollArea, {
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 jsxs15 } from "react/jsx-runtime";
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__ */ jsxs15("div", {
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 jsxs16 } from "react/jsx-runtime";
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-100", viewHeaderClassName, className),
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__ */ jsxs16(motion5.div, {
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 jsxs17 } from "react/jsx-runtime";
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__ */ jsxs17("div", {
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__ */ jsxs17(ScrollArea, {
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__ */ jsxs17("div", {
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__ */ jsxs17("div", {
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-20",
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__ */ jsxs17(Fragment2, {
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 startDateTime = startDate.toDate();
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(startDateTime, endDateTime, true);
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 (!hasExdates) {
2131
- return true;
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 eventStartISO = recurringEvent.start.toISOString();
2134
- const isExcluded = event.exdates.includes(eventStartISO);
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 jsxs18 } from "react/jsx-runtime";
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 "Custom recurrence";
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 "Custom recurrence";
2324
+ return t("customRecurrence");
2284
2325
  }
2285
2326
  return naturalText.charAt(0).toUpperCase() + naturalText.slice(1);
2286
2327
  } catch {
2287
- return "Custom recurrence";
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__ */ jsxs18(Card, {
2458
+ return /* @__PURE__ */ jsxs19(Card, {
2417
2459
  "data-testid": "recurrence-editor",
2418
2460
  children: [
2419
- /* @__PURE__ */ jsxs18(CardHeader, {
2461
+ /* @__PURE__ */ jsxs19(CardHeader, {
2420
2462
  className: "pb-3",
2421
2463
  children: [
2422
- /* @__PURE__ */ jsxs18("div", {
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: "Repeat"
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__ */ jsxs18("div", {
2487
+ children: /* @__PURE__ */ jsxs19("div", {
2446
2488
  className: "space-y-4",
2447
2489
  children: [
2448
- /* @__PURE__ */ jsxs18("div", {
2490
+ /* @__PURE__ */ jsxs19("div", {
2449
2491
  className: "grid grid-cols-2 gap-4",
2450
2492
  children: [
2451
- /* @__PURE__ */ jsxs18("div", {
2493
+ /* @__PURE__ */ jsxs19("div", {
2452
2494
  children: [
2453
2495
  /* @__PURE__ */ jsx31(Label, {
2454
2496
  htmlFor: "frequency",
2455
2497
  className: "text-xs",
2456
- children: "Repeats"
2498
+ children: t("repeats")
2457
2499
  }),
2458
- /* @__PURE__ */ jsxs18(Select, {
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__ */ jsxs18(SelectContent, {
2510
+ /* @__PURE__ */ jsxs19(SelectContent, {
2469
2511
  children: [
2470
2512
  /* @__PURE__ */ jsx31(SelectItem, {
2471
2513
  value: "DAILY",
2472
- children: "Daily"
2514
+ children: t("daily")
2473
2515
  }),
2474
2516
  /* @__PURE__ */ jsx31(SelectItem, {
2475
2517
  value: "WEEKLY",
2476
- children: "Weekly"
2518
+ children: t("weekly")
2477
2519
  }),
2478
2520
  /* @__PURE__ */ jsx31(SelectItem, {
2479
2521
  value: "MONTHLY",
2480
- children: "Monthly"
2522
+ children: t("monthly")
2481
2523
  }),
2482
2524
  /* @__PURE__ */ jsx31(SelectItem, {
2483
2525
  value: "YEARLY",
2484
- children: "Yearly"
2526
+ children: t("yearly")
2485
2527
  })
2486
2528
  ]
2487
2529
  })
@@ -2489,12 +2531,12 @@ var RecurrenceEditor = ({
2489
2531
  })
2490
2532
  ]
2491
2533
  }),
2492
- /* @__PURE__ */ jsxs18("div", {
2534
+ /* @__PURE__ */ jsxs19("div", {
2493
2535
  children: [
2494
2536
  /* @__PURE__ */ jsx31(Label, {
2495
2537
  htmlFor: "interval",
2496
2538
  className: "text-xs",
2497
- children: "Every"
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__ */ jsxs18("div", {
2553
+ rruleOptions?.freq === RRule2.WEEKLY && /* @__PURE__ */ jsxs19("div", {
2512
2554
  children: [
2513
2555
  /* @__PURE__ */ jsx31(Label, {
2514
2556
  className: "text-xs",
2515
- children: "Repeat on"
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__ */ jsxs18("div", {
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__ */ jsxs18("div", {
2583
+ /* @__PURE__ */ jsxs19("div", {
2542
2584
  children: [
2543
2585
  /* @__PURE__ */ jsx31(Label, {
2544
2586
  className: "text-xs",
2545
- children: "Ends"
2587
+ children: t("ends")
2546
2588
  }),
2547
- /* @__PURE__ */ jsxs18("div", {
2589
+ /* @__PURE__ */ jsxs19("div", {
2548
2590
  className: "space-y-2 mt-1",
2549
2591
  children: [
2550
- /* @__PURE__ */ jsxs18("div", {
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: "Never"
2603
+ children: t("never")
2562
2604
  })
2563
2605
  ]
2564
2606
  }),
2565
- /* @__PURE__ */ jsxs18("div", {
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: "After"
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__ */ jsxs18("div", {
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: "On"
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 jsxs19 } from "react/jsx-runtime";
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 actionText = operationType === "edit" ? "change" : "delete";
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__ */ jsxs19(DialogContent, {
2683
+ children: /* @__PURE__ */ jsxs20(DialogContent, {
2642
2684
  className: "max-w-md",
2643
2685
  children: [
2644
- /* @__PURE__ */ jsxs19(DialogHeader, {
2686
+ /* @__PURE__ */ jsxs20(DialogHeader, {
2645
2687
  children: [
2646
- /* @__PURE__ */ jsxs19(DialogTitle, {
2647
- children: [
2648
- actionVerb,
2649
- " recurring event"
2650
- ]
2688
+ /* @__PURE__ */ jsx32(DialogTitle, {
2689
+ children: isEdit ? t("editRecurringEvent") : t("deleteRecurringEvent")
2651
2690
  }),
2652
- /* @__PURE__ */ jsxs19(DialogDescription, {
2691
+ /* @__PURE__ */ jsxs20(DialogDescription, {
2653
2692
  children: [
2654
2693
  '"',
2655
2694
  eventTitle,
2656
- '" is a recurring event. How would you like to',
2695
+ '"',
2657
2696
  " ",
2658
- actionText,
2659
- " it?"
2697
+ isEdit ? t("editRecurringEventQuestion") : t("deleteRecurringEventQuestion")
2660
2698
  ]
2661
2699
  })
2662
2700
  ]
2663
2701
  }),
2664
- /* @__PURE__ */ jsxs19("div", {
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__ */ jsxs19("div", {
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: "This event"
2714
+ children: t("thisEvent")
2677
2715
  }),
2678
- /* @__PURE__ */ jsxs19("div", {
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__ */ jsxs19("div", {
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: "This and following events"
2732
+ children: t("thisAndFollowingEvents")
2699
2733
  }),
2700
- /* @__PURE__ */ jsxs19("div", {
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__ */ jsxs19("div", {
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: "All events"
2750
+ children: t("allEvents")
2720
2751
  }),
2721
- /* @__PURE__ */ jsxs19("div", {
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: "Cancel"
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 jsxs20, Fragment as Fragment3 } from "react/jsx-runtime";
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__ */ jsxs20(Fragment3, {
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__ */ jsxs20("form", {
2991
+ children: /* @__PURE__ */ jsxs21("form", {
2964
2992
  onSubmit: handleSubmit,
2965
2993
  children: [
2966
- /* @__PURE__ */ jsxs20(DialogHeader, {
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 ? "Edit Event" : "Create Event"
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 ? "Edit your event details" : "Add a new event to your calendar"
3003
+ children: selectedEvent?.id ? t("editEventDetails") : t("addNewEvent")
2976
3004
  })
2977
3005
  ]
2978
3006
  }),
2979
- /* @__PURE__ */ jsxs20("div", {
3007
+ /* @__PURE__ */ jsxs21("div", {
2980
3008
  className: "grid gap-3 py-2 sm:gap-4 sm:py-4",
2981
3009
  children: [
2982
- /* @__PURE__ */ jsxs20("div", {
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: "Title"
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: "Event title",
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__ */ jsxs20("div", {
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: "Description"
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: "Event description (optional)",
3042
+ placeholder: t("eventDescriptionPlaceholder"),
3015
3043
  className: "h-8 text-sm sm:h-9"
3016
3044
  })
3017
3045
  ]
3018
3046
  }),
3019
- /* @__PURE__ */ jsxs20("div", {
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: "All day"
3058
+ children: t("allDay")
3031
3059
  })
3032
3060
  ]
3033
3061
  }),
3034
- /* @__PURE__ */ jsxs20("div", {
3062
+ /* @__PURE__ */ jsxs21("div", {
3035
3063
  className: "grid grid-cols-2 gap-2 sm:gap-4",
3036
3064
  children: [
3037
- /* @__PURE__ */ jsxs20("div", {
3065
+ /* @__PURE__ */ jsxs21("div", {
3038
3066
  children: [
3039
3067
  /* @__PURE__ */ jsx33(Label, {
3040
3068
  className: "text-xs sm:text-sm",
3041
- children: "Start Date"
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__ */ jsxs20("div", {
3079
+ /* @__PURE__ */ jsxs21("div", {
3052
3080
  children: [
3053
3081
  /* @__PURE__ */ jsx33(Label, {
3054
3082
  className: "text-xs sm:text-sm",
3055
- children: "End Date"
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__ */ jsxs20("div", {
3095
+ !isAllDay && /* @__PURE__ */ jsxs21("div", {
3068
3096
  className: "grid grid-cols-2 gap-2 sm:gap-4",
3069
3097
  children: [
3070
- /* @__PURE__ */ jsxs20("div", {
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: "Start Time"
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__ */ jsxs20("div", {
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: "End Time"
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__ */ jsxs20("div", {
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: "Color"
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__ */ jsxs20(Tooltip, {
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__ */ jsxs20("div", {
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: "Location"
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: "Event location (optional)",
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__ */ jsxs20(DialogFooter, {
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: "Delete"
3199
+ children: t("delete")
3172
3200
  }),
3173
- /* @__PURE__ */ jsxs20("div", {
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: "Cancel"
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 ? "Update" : "Create"
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 jsxs21, Fragment as Fragment4 } from "react/jsx-runtime";
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__ */ jsxs21(Fragment4, {
3424
+ return /* @__PURE__ */ jsxs22(Fragment4, {
3397
3425
  children: [
3398
- view !== "year" && /* @__PURE__ */ jsxs21(Popover, {
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__ */ jsxs21(Button, {
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__ */ jsxs21(Popover, {
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__ */ jsxs21(Button, {
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__ */ jsxs21(Popover, {
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__ */ jsxs21(Button, {
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__ */ jsxs21("div", {
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__ */ jsxs21(Popover, {
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__ */ jsxs21(Button, {
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__ */ jsxs21("div", {
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: "Today"
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 jsxs22 } from "react/jsx-runtime";
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" : "", viewType === "year" ? isGrid ? "w-full" : "hidden md:inline-flex" : "", currentView === viewType && "bg-primary/80");
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__ */ jsxs22("div", {
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: "Day"
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: "Week"
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: "Month"
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: "Year"
3704
+ children: t("year")
3676
3705
  }),
3677
3706
  /* @__PURE__ */ jsx35(Button, {
3678
3707
  onClick: onToday,
3679
3708
  variant: "outline",
3680
3709
  size,
3681
- children: "Today"
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 jsxs23, Fragment as Fragment5 } from "react/jsx-runtime";
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,7 +3724,9 @@ var Header = ({ className = "" }) => {
3695
3724
  today,
3696
3725
  openEventForm,
3697
3726
  headerComponent,
3698
- rawEvents
3727
+ headerClassName,
3728
+ rawEvents,
3729
+ t
3699
3730
  } = useCalendarContext();
3700
3731
  const [mobilePopoverOpen, setMobilePopoverOpen] = useState6(false);
3701
3732
  const handleViewChange = (newView, closePopover = false) => {
@@ -3725,7 +3756,7 @@ var Header = ({ className = "" }) => {
3725
3756
  };
3726
3757
  const NewEventButton = useCallback2(() => /* @__PURE__ */ jsx36("div", {
3727
3758
  className: "flex items-center gap-2",
3728
- children: /* @__PURE__ */ jsxs23(Button, {
3759
+ children: /* @__PURE__ */ jsxs24(Button, {
3729
3760
  onClick: () => openEventForm(),
3730
3761
  variant: "default",
3731
3762
  size: "sm",
@@ -3735,134 +3766,138 @@ var Header = ({ className = "" }) => {
3735
3766
  className: "h-4 w-4"
3736
3767
  }),
3737
3768
  /* @__PURE__ */ jsx36("span", {
3738
- className: "hidden lg:inline",
3739
- children: "New"
3769
+ className: "hidden @4xl:inline",
3770
+ children: t("new")
3740
3771
  })
3741
3772
  ]
3742
3773
  })
3743
- }), [openEventForm]);
3774
+ }), [openEventForm, t]);
3744
3775
  if (headerComponent) {
3745
3776
  return headerComponent;
3746
3777
  }
3747
3778
  return /* @__PURE__ */ jsx36(Fragment5, {
3748
- children: /* @__PURE__ */ jsxs23("div", {
3749
- className: cn("@container flex justify-center lg:justify-between flex-wrap items-center gap-2 border-b", className),
3779
+ children: /* @__PURE__ */ jsx36("div", {
3780
+ className: "@container/base-header w-full",
3750
3781
  "data-testid": "calendar-header",
3751
- children: [
3752
- /* @__PURE__ */ jsxs23("div", {
3753
- className: "flex flex-wrap items-center justify-center gap-1 2xl:col-span-5 2xl:justify-start",
3754
- children: [
3755
- /* @__PURE__ */ jsx36(CalendarIcon2, {
3756
- className: "h-5 w-5"
3757
- }),
3758
- /* @__PURE__ */ jsx36(title_content_default, {})
3759
- ]
3760
- }),
3761
- /* @__PURE__ */ jsxs23("div", {
3762
- className: "flex flex-wrap justify-center gap-1 2xl:col-span-7 2xl:justify-end",
3763
- children: [
3764
- /* @__PURE__ */ jsxs23("div", {
3765
- className: "hidden items-center justify-start lg:justify-center 2xl:justify-end gap-1 sm:flex w-full overflow-x-auto",
3766
- children: [
3767
- /* @__PURE__ */ jsx36(view_controls_default, {
3768
- currentView: view,
3769
- onChange: setView,
3770
- onToday: today,
3771
- onNext: nextPeriod,
3772
- onPrevious: prevPeriod,
3773
- variant: "default",
3774
- className: "justify-end"
3775
- }),
3776
- /* @__PURE__ */ jsx36(NewEventButton, {}),
3777
- /* @__PURE__ */ jsxs23(Button, {
3778
- onClick: handleExport,
3779
- variant: "outline",
3780
- size: "sm",
3781
- className: "flex items-center gap-1",
3782
- children: [
3783
- /* @__PURE__ */ jsx36(Download, {
3784
- className: "h-4 w-4"
3785
- }),
3786
- /* @__PURE__ */ jsx36("span", {
3787
- className: "hidden lg:inline",
3788
- children: "Export"
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
- })
3782
+ children: /* @__PURE__ */ jsxs24("div", {
3783
+ className: cn("flex justify-center @2xl/base-header:justify-between flex-wrap items-center gap-2 border-b", className, headerClassName),
3784
+ children: [
3785
+ /* @__PURE__ */ jsxs24("div", {
3786
+ className: "flex flex-wrap items-center justify-center gap-1 @2xl/base-header:justify-start",
3787
+ children: [
3788
+ /* @__PURE__ */ jsx36(CalendarIcon2, {
3789
+ className: "h-5 w-5"
3790
+ }),
3791
+ /* @__PURE__ */ jsx36(title_content_default, {})
3792
+ ]
3793
+ }),
3794
+ /* @__PURE__ */ jsxs24("div", {
3795
+ className: "flex flex-wrap justify-start @xl/base-header:justify-center gap-1 @4xl/base-header:justify-end overflow-x-auto",
3796
+ children: [
3797
+ /* @__PURE__ */ jsxs24("div", {
3798
+ className: "hidden @md/base-header:flex items-center justify-start gap-1",
3799
+ children: [
3800
+ /* @__PURE__ */ jsx36(view_controls_default, {
3801
+ currentView: view,
3802
+ onChange: setView,
3803
+ onToday: today,
3804
+ onNext: nextPeriod,
3805
+ onPrevious: prevPeriod,
3806
+ variant: "default",
3807
+ className: "justify-end"
3808
+ }),
3809
+ /* @__PURE__ */ jsx36(NewEventButton, {}),
3810
+ /* @__PURE__ */ jsxs24(Button, {
3811
+ onClick: handleExport,
3812
+ variant: "outline",
3813
+ size: "sm",
3814
+ className: "flex items-center gap-1",
3815
+ children: [
3816
+ /* @__PURE__ */ jsx36(Download, {
3817
+ className: "h-4 w-4"
3818
+ }),
3819
+ /* @__PURE__ */ jsx36("span", {
3820
+ className: "hidden @4xl/base-header:inline",
3821
+ children: t("export")
3810
3822
  })
3811
- }),
3812
- /* @__PURE__ */ jsx36(PopoverContent, {
3813
- align: "end",
3814
- className: "w-[240px] p-2",
3815
- children: /* @__PURE__ */ jsxs23("div", {
3816
- className: "space-y-2",
3817
- children: [
3818
- /* @__PURE__ */ jsx36("h3", {
3819
- className: "mb-1 text-sm font-medium",
3820
- children: "View & Navigation"
3821
- }),
3822
- /* @__PURE__ */ jsx36(view_controls_default, {
3823
- currentView: view,
3824
- onChange: (newView) => handleViewChange(newView, true),
3825
- onToday: handleNavigation.today,
3826
- onNext: handleNavigation.next,
3827
- onPrevious: handleNavigation.previous,
3828
- variant: "grid"
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
- })
3823
+ ]
3824
+ })
3825
+ ]
3826
+ }),
3827
+ /* @__PURE__ */ jsxs24("div", {
3828
+ className: "flex items-center justify-end gap-1 @md/base-header:hidden",
3829
+ children: [
3830
+ /* @__PURE__ */ jsx36(NewEventButton, {}),
3831
+ /* @__PURE__ */ jsxs24(Popover, {
3832
+ open: mobilePopoverOpen,
3833
+ onOpenChange: setMobilePopoverOpen,
3834
+ children: [
3835
+ /* @__PURE__ */ jsx36(PopoverTrigger, {
3836
+ asChild: true,
3837
+ children: /* @__PURE__ */ jsx36(Button, {
3838
+ variant: "outline",
3839
+ size: "sm",
3840
+ children: /* @__PURE__ */ jsx36(Menu, {
3841
+ className: "h-4 w-4"
3844
3842
  })
3845
- ]
3843
+ })
3844
+ }),
3845
+ /* @__PURE__ */ jsx36(PopoverContent, {
3846
+ align: "end",
3847
+ className: "w-[240px] p-2",
3848
+ children: /* @__PURE__ */ jsxs24("div", {
3849
+ className: "space-y-2",
3850
+ children: [
3851
+ /* @__PURE__ */ jsx36("h3", {
3852
+ className: "mb-1 text-sm font-medium",
3853
+ children: "View & Navigation"
3854
+ }),
3855
+ /* @__PURE__ */ jsx36(view_controls_default, {
3856
+ currentView: view,
3857
+ onChange: (newView) => handleViewChange(newView, true),
3858
+ onToday: handleNavigation.today,
3859
+ onNext: handleNavigation.next,
3860
+ onPrevious: handleNavigation.previous,
3861
+ variant: "grid"
3862
+ }),
3863
+ /* @__PURE__ */ jsx36("div", {
3864
+ className: "pt-2 border-t",
3865
+ children: /* @__PURE__ */ jsxs24(Button, {
3866
+ onClick: handleExport,
3867
+ variant: "outline",
3868
+ size: "sm",
3869
+ className: "w-full flex items-center gap-2",
3870
+ children: [
3871
+ /* @__PURE__ */ jsx36(Download, {
3872
+ className: "h-4 w-4"
3873
+ }),
3874
+ t("export"),
3875
+ " Calendar (.ics)"
3876
+ ]
3877
+ })
3878
+ })
3879
+ ]
3880
+ })
3846
3881
  })
3847
- })
3848
- ]
3849
- })
3850
- ]
3851
- })
3852
- ]
3853
- })
3854
- ]
3882
+ ]
3883
+ })
3884
+ ]
3885
+ })
3886
+ ]
3887
+ })
3888
+ ]
3889
+ })
3855
3890
  })
3856
3891
  });
3857
3892
  };
3858
3893
  var base_header_default = Header;
3859
3894
  // src/features/year-view/view/year-view.tsx
3860
3895
  import { AnimatePresence as AnimatePresence7, motion as motion7 } from "motion/react";
3861
- import { jsx as jsx37, jsxs as jsxs24 } from "react/jsx-runtime";
3896
+ import { jsx as jsx37, jsxs as jsxs25 } from "react/jsx-runtime";
3862
3897
  var YearView = () => {
3863
- const { currentDate, selectDate, events, setView, getEventsForDateRange } = useCalendarContext();
3898
+ const { currentDate, selectDate, events, setView, getEventsForDateRange, t } = useCalendarContext();
3864
3899
  const year = currentDate.year();
3865
- const months2 = Array.from({ length: 12 }, (_, i) => {
3900
+ const months = Array.from({ length: 12 }, (_, i) => {
3866
3901
  const monthDate = dayjs_config_default().year(year).month(i).startOf("month");
3867
3902
  return {
3868
3903
  date: monthDate,
@@ -3871,7 +3906,7 @@ var YearView = () => {
3871
3906
  firstDayOfMonth: monthDate.startOf("month").day()
3872
3907
  };
3873
3908
  });
3874
- const monthsWithEventCount = months2.map((month) => {
3909
+ const monthsWithEventCount = months.map((month) => {
3875
3910
  const eventsInMonth = events.filter((event) => event.start.year() === year && event.start.month() === month.date.month());
3876
3911
  return {
3877
3912
  ...month,
@@ -3906,7 +3941,7 @@ var YearView = () => {
3906
3941
  events: dayEvents
3907
3942
  };
3908
3943
  });
3909
- return /* @__PURE__ */ jsxs24("div", {
3944
+ return /* @__PURE__ */ jsxs25("div", {
3910
3945
  "data-testid": `year-mini-calendar-${month.date.format("MM")}`,
3911
3946
  className: "grid grid-cols-7 gap-[1px] text-[0.6rem]",
3912
3947
  children: [
@@ -3914,7 +3949,7 @@ var YearView = () => {
3914
3949
  className: "text-muted-foreground h-3 text-center",
3915
3950
  children: dayName
3916
3951
  }, `header-${i}`)),
3917
- daysArray.map((dayInfo, i) => /* @__PURE__ */ jsxs24("div", {
3952
+ daysArray.map((dayInfo, i) => /* @__PURE__ */ jsxs25("div", {
3918
3953
  "data-testid": `year-day-${month.date.format("YYYY-MM")}-${dayInfo.day.format("YYYY-MM-DD")}`,
3919
3954
  onClick: (e) => handleDayClick(dayInfo.day, e),
3920
3955
  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 +3959,7 @@ var YearView = () => {
3924
3959
  className: "text-center leading-none",
3925
3960
  children: dayInfo.day.date()
3926
3961
  }),
3927
- dayInfo.hasEvents && /* @__PURE__ */ jsxs24("div", {
3962
+ dayInfo.hasEvents && /* @__PURE__ */ jsxs25("div", {
3928
3963
  className: cn("absolute bottom-0 flex w-full justify-center space-x-[1px]", dayInfo.isToday ? "bottom-[1px]" : ""),
3929
3964
  children: [
3930
3965
  dayInfo.eventCount > 0 && /* @__PURE__ */ jsx37("span", {
@@ -3949,14 +3984,14 @@ var YearView = () => {
3949
3984
  children: /* @__PURE__ */ jsx37("div", {
3950
3985
  "data-testid": "year-grid",
3951
3986
  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__ */ jsxs24("div", {
3987
+ children: monthsWithEventCount.map((month, index) => /* @__PURE__ */ jsxs25("div", {
3953
3988
  "data-testid": `year-month-${month.date.format("MM")}`,
3954
3989
  onClick: () => handleMonthClick(month.date),
3955
3990
  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
3991
  children: [
3957
3992
  /* @__PURE__ */ jsx37(AnimatePresence7, {
3958
3993
  mode: "wait",
3959
- children: /* @__PURE__ */ jsxs24(motion7.div, {
3994
+ children: /* @__PURE__ */ jsxs25(motion7.div, {
3960
3995
  initial: { opacity: 0, y: -10 },
3961
3996
  animate: { opacity: 1, y: 0 },
3962
3997
  exit: { opacity: 0, y: -10 },
@@ -3972,13 +4007,13 @@ var YearView = () => {
3972
4007
  className: "text-lg font-medium",
3973
4008
  children: month.name
3974
4009
  }),
3975
- month.eventCount > 0 && /* @__PURE__ */ jsxs24("span", {
4010
+ month.eventCount > 0 && /* @__PURE__ */ jsxs25("span", {
3976
4011
  "data-testid": `year-month-event-count-${month.date.format("MM")}`,
3977
4012
  className: "bg-primary text-primary-foreground rounded-full px-2 py-1 text-xs",
3978
4013
  children: [
3979
4014
  month.eventCount,
3980
4015
  " ",
3981
- month.eventCount === 1 ? "event" : "events"
4016
+ month.eventCount === 1 ? t("event") : t("events")
3982
4017
  ]
3983
4018
  })
3984
4019
  ]
@@ -4007,7 +4042,7 @@ import {
4007
4042
  } from "@dnd-kit/core";
4008
4043
  import React9, { useState as useState7 } from "react";
4009
4044
  import { snapCenterToCursor } from "@dnd-kit/modifiers";
4010
- import { jsx as jsx38, jsxs as jsxs25, Fragment as Fragment6 } from "react/jsx-runtime";
4045
+ import { jsx as jsx38, jsxs as jsxs26, Fragment as Fragment6 } from "react/jsx-runtime";
4011
4046
  function CalendarDndContext({ children }) {
4012
4047
  const { updateEvent, updateRecurringEvent: updateRecurringEvent2, view, disableDragAndDrop } = useCalendarContext();
4013
4048
  const [activeEvent, setActiveEvent] = React9.useState(null);
@@ -4134,9 +4169,9 @@ function CalendarDndContext({ children }) {
4134
4169
  if (disableDragAndDrop) {
4135
4170
  return children;
4136
4171
  }
4137
- return /* @__PURE__ */ jsxs25(Fragment6, {
4172
+ return /* @__PURE__ */ jsxs26(Fragment6, {
4138
4173
  children: [
4139
- /* @__PURE__ */ jsxs25(DndContext, {
4174
+ /* @__PURE__ */ jsxs26(DndContext, {
4140
4175
  sensors,
4141
4176
  onDragStart: handleDragStart,
4142
4177
  onDragEnd: handleDragEnd,
@@ -4165,16 +4200,116 @@ function CalendarDndContext({ children }) {
4165
4200
  }
4166
4201
 
4167
4202
  // src/contexts/calendar-context/provider.tsx
4168
- import { useCallback as useCallback3, useEffect as useEffect4, useMemo as useMemo6, useState as useState8 } from "react";
4203
+ import { useCallback as useCallback3, useEffect as useEffect4, useMemo as useMemo8, useState as useState8 } from "react";
4204
+
4205
+ // src/lib/translations/default.ts
4206
+ var defaultTranslations = {
4207
+ today: "Today",
4208
+ create: "Create",
4209
+ new: "New",
4210
+ update: "Update",
4211
+ delete: "Delete",
4212
+ cancel: "Cancel",
4213
+ export: "Export",
4214
+ event: "Event",
4215
+ events: "Events",
4216
+ newEvent: "New Event",
4217
+ title: "Title",
4218
+ description: "Description",
4219
+ location: "Location",
4220
+ allDay: "All day",
4221
+ startDate: "Start Date",
4222
+ endDate: "End Date",
4223
+ startTime: "Start Time",
4224
+ endTime: "End Time",
4225
+ color: "Color",
4226
+ createEvent: "Create Event",
4227
+ editEvent: "Edit Event",
4228
+ addNewEvent: "Add a new event to your calendar",
4229
+ editEventDetails: "Edit your event details",
4230
+ eventTitlePlaceholder: "Event title",
4231
+ eventDescriptionPlaceholder: "Event description (optional)",
4232
+ eventLocationPlaceholder: "Event location (optional)",
4233
+ repeat: "Repeat",
4234
+ repeats: "Repeats",
4235
+ customRecurrence: "Custom recurrence",
4236
+ daily: "Daily",
4237
+ weekly: "Weekly",
4238
+ monthly: "Monthly",
4239
+ yearly: "Yearly",
4240
+ interval: "Interval",
4241
+ repeatOn: "Repeat on",
4242
+ never: "Never",
4243
+ count: "Count",
4244
+ every: "Every",
4245
+ ends: "Ends",
4246
+ after: "After",
4247
+ occurrences: "occurrences",
4248
+ on: "On",
4249
+ editRecurringEvent: "Edit recurring event",
4250
+ deleteRecurringEvent: "Delete recurring event",
4251
+ editRecurringEventQuestion: "is a recurring event. How would you like to edit it?",
4252
+ deleteRecurringEventQuestion: "is a recurring event. How would you like to delete it?",
4253
+ thisEvent: "This event",
4254
+ thisEventDescription: "Only change this specific occurrence",
4255
+ thisAndFollowingEvents: "This and following events",
4256
+ thisAndFollowingEventsDescription: "Edit this and all future occurrences",
4257
+ allEvents: "All events",
4258
+ allEventsDescription: "Edit the entire recurring series",
4259
+ onlyChangeThis: "Only change this specific occurrence",
4260
+ changeThisAndFuture: "Change this and all future occurrences",
4261
+ changeEntireSeries: "Change the entire recurring series",
4262
+ onlyDeleteThis: "Only delete this specific occurrence",
4263
+ deleteThisAndFuture: "Delete this and all future occurrences",
4264
+ deleteEntireSeries: "Delete the entire recurring series",
4265
+ month: "Month",
4266
+ week: "Week",
4267
+ day: "Day",
4268
+ year: "Year",
4269
+ more: "more",
4270
+ sunday: "Sunday",
4271
+ monday: "Monday",
4272
+ tuesday: "Tuesday",
4273
+ wednesday: "Wednesday",
4274
+ thursday: "Thursday",
4275
+ friday: "Friday",
4276
+ saturday: "Saturday",
4277
+ sun: "Sun",
4278
+ mon: "Mon",
4279
+ tue: "Tue",
4280
+ wed: "Wed",
4281
+ thu: "Thu",
4282
+ fri: "Fri",
4283
+ sat: "Sat",
4284
+ january: "January",
4285
+ february: "February",
4286
+ march: "March",
4287
+ april: "April",
4288
+ may: "May",
4289
+ june: "June",
4290
+ july: "July",
4291
+ august: "August",
4292
+ september: "September",
4293
+ october: "October",
4294
+ november: "November",
4295
+ december: "December"
4296
+ };
4297
+
4298
+ // src/contexts/calendar-context/provider.tsx
4169
4299
  import { jsx as jsx39 } from "react/jsx-runtime";
4170
4300
  var CalendarProvider = ({
4171
4301
  children,
4172
4302
  events = [],
4173
4303
  firstDayOfWeek = 0,
4304
+ initialView = "month",
4174
4305
  renderEvent,
4175
4306
  onEventClick,
4176
4307
  onCellClick,
4177
4308
  onViewChange,
4309
+ onEventAdd,
4310
+ onEventUpdate,
4311
+ onEventDelete,
4312
+ onDateChange,
4178
4313
  locale,
4179
4314
  timezone: timezone2,
4180
4315
  disableCellClick,
@@ -4183,16 +4318,28 @@ var CalendarProvider = ({
4183
4318
  dayMaxEvents,
4184
4319
  stickyViewHeader = true,
4185
4320
  viewHeaderClassName = "",
4186
- headerComponent
4321
+ headerComponent,
4322
+ headerClassName,
4323
+ translations,
4324
+ translator
4187
4325
  }) => {
4188
4326
  const [currentDate, setCurrentDate] = useState8(dayjs_config_default());
4189
- const [view, setView] = useState8("month");
4327
+ const [view, setView] = useState8(initialView);
4190
4328
  const [currentEvents, setCurrentEvents] = useState8(events);
4191
4329
  const [isEventFormOpen, setIsEventFormOpen] = useState8(false);
4192
4330
  const [selectedEvent, setSelectedEvent] = useState8(null);
4193
4331
  const [selectedDate, setSelectedDate] = useState8(null);
4194
4332
  const [currentLocale, setCurrentLocale] = useState8(locale || "en");
4195
4333
  const [currentTimezone, setCurrentTimezone] = useState8(timezone2 || "");
4334
+ const t = useMemo8(() => {
4335
+ if (translator) {
4336
+ return translator;
4337
+ }
4338
+ if (translations) {
4339
+ return (key) => translations[key] || key;
4340
+ }
4341
+ return (key) => defaultTranslations[key] || key;
4342
+ }, [translations, translator]);
4196
4343
  const getEventsForDateRange = useCallback3((startDate, endDate) => {
4197
4344
  const allEvents = [];
4198
4345
  for (const event of currentEvents) {
@@ -4244,7 +4391,7 @@ var CalendarProvider = ({
4244
4391
  };
4245
4392
  }
4246
4393
  }, [currentDate, view, firstDayOfWeek]);
4247
- const processedEvents = useMemo6(() => {
4394
+ const processedEvents = useMemo8(() => {
4248
4395
  const { start, end } = getCurrentViewRange();
4249
4396
  return getEventsForDateRange(start, end);
4250
4397
  }, [getEventsForDateRange, getCurrentViewRange]);
@@ -4267,49 +4414,97 @@ var CalendarProvider = ({
4267
4414
  }, [timezone2]);
4268
4415
  const selectDate = useCallback3((date) => {
4269
4416
  setCurrentDate(date);
4270
- }, []);
4417
+ onDateChange?.(date);
4418
+ }, [onDateChange]);
4271
4419
  const nextPeriod = useCallback3(() => {
4272
4420
  switch (view) {
4273
4421
  case "month":
4274
- setCurrentDate((currentDate2) => currentDate2.add(1, "month"));
4422
+ setCurrentDate((currentDate2) => {
4423
+ const newDate = currentDate2.add(1, "month");
4424
+ onDateChange?.(newDate);
4425
+ return newDate;
4426
+ });
4275
4427
  break;
4276
4428
  case "week":
4277
- setCurrentDate((currentDate2) => currentDate2.add(1, "week"));
4429
+ setCurrentDate((currentDate2) => {
4430
+ const newDate = currentDate2.add(1, "week");
4431
+ onDateChange?.(newDate);
4432
+ return newDate;
4433
+ });
4278
4434
  break;
4279
4435
  case "day":
4280
- setCurrentDate((currentDate2) => currentDate2.add(1, "day"));
4436
+ setCurrentDate((currentDate2) => {
4437
+ const newDate = currentDate2.add(1, "day");
4438
+ onDateChange?.(newDate);
4439
+ return newDate;
4440
+ });
4281
4441
  break;
4282
4442
  case "year":
4283
- setCurrentDate((currentDate2) => currentDate2.add(1, "year"));
4443
+ setCurrentDate((currentDate2) => {
4444
+ const newDate = currentDate2.add(1, "year");
4445
+ onDateChange?.(newDate);
4446
+ return newDate;
4447
+ });
4284
4448
  break;
4285
4449
  }
4286
- }, [view]);
4450
+ }, [view, onDateChange]);
4287
4451
  const prevPeriod = useCallback3(() => {
4288
4452
  switch (view) {
4289
4453
  case "month":
4290
- setCurrentDate((currentDate2) => currentDate2.subtract(1, "month"));
4454
+ setCurrentDate((currentDate2) => {
4455
+ const newDate = currentDate2.subtract(1, "month");
4456
+ onDateChange?.(newDate);
4457
+ return newDate;
4458
+ });
4291
4459
  break;
4292
4460
  case "week":
4293
- setCurrentDate((currentDate2) => currentDate2.subtract(1, "week"));
4461
+ setCurrentDate((currentDate2) => {
4462
+ const newDate = currentDate2.subtract(1, "week");
4463
+ onDateChange?.(newDate);
4464
+ return newDate;
4465
+ });
4294
4466
  break;
4295
4467
  case "day":
4296
- setCurrentDate((currentDate2) => currentDate2.subtract(1, "day"));
4468
+ setCurrentDate((currentDate2) => {
4469
+ const newDate = currentDate2.subtract(1, "day");
4470
+ onDateChange?.(newDate);
4471
+ return newDate;
4472
+ });
4297
4473
  break;
4298
4474
  case "year":
4299
- setCurrentDate((currentDate2) => currentDate2.subtract(1, "year"));
4475
+ setCurrentDate((currentDate2) => {
4476
+ const newDate = currentDate2.subtract(1, "year");
4477
+ onDateChange?.(newDate);
4478
+ return newDate;
4479
+ });
4300
4480
  break;
4301
4481
  }
4302
- }, [view]);
4482
+ }, [view, onDateChange]);
4303
4483
  const today = useCallback3(() => {
4304
- setCurrentDate(dayjs_config_default());
4305
- }, []);
4484
+ const newDate = dayjs_config_default();
4485
+ setCurrentDate(newDate);
4486
+ onDateChange?.(newDate);
4487
+ }, [onDateChange]);
4306
4488
  const addEvent = useCallback3((event) => {
4307
4489
  setCurrentEvents((prevEvents) => [...prevEvents, event]);
4308
- }, []);
4490
+ onEventAdd?.(event);
4491
+ }, [onEventAdd]);
4309
4492
  const updateEvent = useCallback3((eventId, updatedEvent) => {
4310
- setCurrentEvents((prevEvents) => prevEvents.map((event) => event.id === eventId ? { ...event, ...updatedEvent } : event));
4311
- }, []);
4493
+ setCurrentEvents((prevEvents) => {
4494
+ const updated = prevEvents.map((event) => {
4495
+ if (event.id === eventId) {
4496
+ const newEvent = { ...event, ...updatedEvent };
4497
+ onEventUpdate?.(newEvent);
4498
+ return newEvent;
4499
+ }
4500
+ return event;
4501
+ });
4502
+ return updated;
4503
+ });
4504
+ }, [onEventUpdate]);
4312
4505
  const updateRecurringEvent2 = useCallback3((event, updates, options) => {
4506
+ const updatedEvent = { ...event, ...updates };
4507
+ onEventUpdate?.(updatedEvent);
4313
4508
  const updatedEvents = updateRecurringEvent({
4314
4509
  targetEvent: event,
4315
4510
  updates,
@@ -4317,18 +4512,25 @@ var CalendarProvider = ({
4317
4512
  scope: options.scope
4318
4513
  });
4319
4514
  setCurrentEvents(updatedEvents);
4320
- }, [currentEvents]);
4515
+ }, [currentEvents, onEventUpdate]);
4321
4516
  const deleteRecurringEvent2 = useCallback3((event, options) => {
4517
+ onEventDelete?.(event);
4322
4518
  const updatedEvents = deleteRecurringEvent({
4323
4519
  targetEvent: event,
4324
4520
  currentEvents,
4325
4521
  scope: options.scope
4326
4522
  });
4327
4523
  setCurrentEvents(updatedEvents);
4328
- }, [currentEvents]);
4524
+ }, [currentEvents, onEventDelete]);
4329
4525
  const deleteEvent = useCallback3((eventId) => {
4330
- setCurrentEvents((prevEvents) => prevEvents.filter((event) => event.id !== eventId));
4331
- }, []);
4526
+ setCurrentEvents((prevEvents) => {
4527
+ const eventToDelete = prevEvents.find((event) => event.id === eventId);
4528
+ if (eventToDelete) {
4529
+ onEventDelete?.(eventToDelete);
4530
+ }
4531
+ return prevEvents.filter((event) => event.id !== eventId);
4532
+ });
4533
+ }, [onEventDelete]);
4332
4534
  const editEvent = useCallback3((event) => {
4333
4535
  setSelectedEvent(event);
4334
4536
  setIsEventFormOpen(true);
@@ -4361,7 +4563,7 @@ var CalendarProvider = ({
4361
4563
  } else {
4362
4564
  setSelectedDate(startDate);
4363
4565
  setSelectedEvent({
4364
- title: `New Event`,
4566
+ title: t("newEvent"),
4365
4567
  start: startDate,
4366
4568
  end: endDate,
4367
4569
  description: "",
@@ -4369,20 +4571,20 @@ var CalendarProvider = ({
4369
4571
  });
4370
4572
  setIsEventFormOpen(true);
4371
4573
  }
4372
- }, [onCellClick, disableCellClick]);
4574
+ }, [onCellClick, disableCellClick, t]);
4373
4575
  const handleOpenEventForm = useCallback3((date) => {
4374
4576
  if (date) {
4375
4577
  setSelectedDate(date);
4376
4578
  }
4377
4579
  setSelectedEvent({
4378
- title: `New Event`,
4580
+ title: t("newEvent"),
4379
4581
  start: date ?? currentDate,
4380
4582
  end: date ?? currentDate.add(1, "hour"),
4381
4583
  description: "",
4382
4584
  allDay: false
4383
4585
  });
4384
4586
  setIsEventFormOpen(true);
4385
- }, [currentDate]);
4587
+ }, [currentDate, t]);
4386
4588
  const findParentRecurringEvent = useCallback3((event) => {
4387
4589
  const targetUID = event.uid;
4388
4590
  const parentEvent = currentEvents.find((e) => {
@@ -4391,7 +4593,7 @@ var CalendarProvider = ({
4391
4593
  });
4392
4594
  return parentEvent || null;
4393
4595
  }, [currentEvents]);
4394
- const contextValue = useMemo6(() => ({
4596
+ const contextValue = useMemo8(() => ({
4395
4597
  currentDate,
4396
4598
  view,
4397
4599
  events: processedEvents,
@@ -4427,7 +4629,9 @@ var CalendarProvider = ({
4427
4629
  dayMaxEvents,
4428
4630
  stickyViewHeader,
4429
4631
  viewHeaderClassName,
4430
- headerComponent
4632
+ headerComponent,
4633
+ headerClassName,
4634
+ t
4431
4635
  }), [
4432
4636
  currentDate,
4433
4637
  view,
@@ -4463,7 +4667,9 @@ var CalendarProvider = ({
4463
4667
  dayMaxEvents,
4464
4668
  stickyViewHeader,
4465
4669
  viewHeaderClassName,
4466
- headerComponent
4670
+ headerComponent,
4671
+ headerClassName,
4672
+ t
4467
4673
  ]);
4468
4674
  return /* @__PURE__ */ jsx39(CalendarContext.Provider, {
4469
4675
  value: contextValue,
@@ -4472,7 +4678,7 @@ var CalendarProvider = ({
4472
4678
  };
4473
4679
 
4474
4680
  // src/components/ilamy-calendar/ilamy-calendar.tsx
4475
- import { jsx as jsx40, jsxs as jsxs26 } from "react/jsx-runtime";
4681
+ import { jsx as jsx40, jsxs as jsxs27 } from "react/jsx-runtime";
4476
4682
  var CalendarContent = () => {
4477
4683
  const {
4478
4684
  view,
@@ -4499,7 +4705,7 @@ var CalendarContent = () => {
4499
4705
  const handleOnDelete = (event) => {
4500
4706
  deleteEvent(event.id);
4501
4707
  };
4502
- return /* @__PURE__ */ jsxs26("div", {
4708
+ return /* @__PURE__ */ jsxs27("div", {
4503
4709
  className: "flex flex-col w-full h-full",
4504
4710
  children: [
4505
4711
  /* @__PURE__ */ jsx40(base_header_default, {
@@ -4533,11 +4739,18 @@ var DEFAULT_DAY_MAX_EVENTS = 4;
4533
4739
  var IlamyCalendar = ({
4534
4740
  events,
4535
4741
  firstDayOfWeek = "sunday",
4742
+ initialView = "month",
4536
4743
  renderEvent,
4537
4744
  onEventClick,
4538
4745
  onCellClick,
4539
4746
  onViewChange,
4747
+ onEventAdd,
4748
+ onEventUpdate,
4749
+ onEventDelete,
4750
+ onDateChange,
4540
4751
  locale,
4752
+ translations,
4753
+ translator,
4541
4754
  timezone: timezone2,
4542
4755
  disableCellClick,
4543
4756
  disableEventClick,
@@ -4545,16 +4758,24 @@ var IlamyCalendar = ({
4545
4758
  dayMaxEvents = DEFAULT_DAY_MAX_EVENTS,
4546
4759
  stickyViewHeader = true,
4547
4760
  viewHeaderClassName = "",
4548
- headerComponent
4761
+ headerComponent,
4762
+ headerClassName
4549
4763
  }) => {
4550
4764
  return /* @__PURE__ */ jsx40(CalendarProvider, {
4551
4765
  events: normalizePublicFacingCalendarEvent(events),
4552
4766
  firstDayOfWeek: WEEK_DAYS_NUMBER_MAP[firstDayOfWeek],
4767
+ initialView,
4553
4768
  renderEvent,
4554
4769
  onEventClick,
4555
4770
  onCellClick,
4556
4771
  onViewChange,
4772
+ onEventAdd,
4773
+ onEventUpdate,
4774
+ onEventDelete,
4775
+ onDateChange,
4557
4776
  locale,
4777
+ translations,
4778
+ translator,
4558
4779
  timezone: timezone2,
4559
4780
  disableCellClick,
4560
4781
  disableEventClick,
@@ -4563,6 +4784,7 @@ var IlamyCalendar = ({
4563
4784
  stickyViewHeader,
4564
4785
  viewHeaderClassName,
4565
4786
  headerComponent,
4787
+ headerClassName,
4566
4788
  children: /* @__PURE__ */ jsx40(CalendarContent, {})
4567
4789
  });
4568
4790
  };
@@ -4573,9 +4795,10 @@ export {
4573
4795
  useIlamyCalendarContext,
4574
4796
  isRecurringEvent,
4575
4797
  generateRecurringEvents,
4798
+ defaultTranslations,
4576
4799
  RRule4 as RRule,
4577
4800
  IlamyCalendar
4578
4801
  };
4579
4802
 
4580
- //# debugId=7721FF42EA85BA6064756E2164756E21
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": ";AACA,4BAAS,4BAAiB;AAC1B,4BAAgB;;;ACChB;AAiDO,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;;;ACpHF;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,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,sBAC1B,MAWE,OAXF;AAAA,IACE,WAAW,GACT,MAAM,mBAAmB,eACzB,MAAM,SAAS,cACf,kFACF;AAAA,IACA,OAAO,EAAE,iBAAiB,MAAM,iBAAiB,OAAO,MAAM,MAAM;AAAA,IANtE,0BAQE,MAEE,KAFF;AAAA,MAAG,WAAU;AAAA,MAAb,UACG,MAAM;AAAA,KACP;AAAA,GACF;AAAA,EAGJ,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;;;;AD9EO,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,MACb,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;AAAA,aAmBE;AAAA;AAAA,SAEJ;AAAA,OACF;AAAA,sBAGF,MAAC,gBAAD;AAAA,QAAgB,KAAK;AAAA,OAAoB;AAAA;AAAA,GACzC;AAAA;;;AEnIN,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,sBACpB,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,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,MACL,CAAC;AAAA,MACD,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,UACL,CAAC;AAAA,UACD,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,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,MACL,CAAC;AAAA,IACH;AAAA,EACF;AAAA,EAEA,OAAO;AAAA;;;;AC1LF,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,MAoDE,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,MAoBE,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,sBACpB,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,sBACpB,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,UAAU,OAAO;AAAA,IACvC,MAAM,cAAc,QAAQ,OAAO;AAAA,IACnC,MAAM,cAAc,KAAK,QAAQ,eAAe,aAAa,IAAI;AAAA,IAGjE,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,KAAK,YAAY;AAAA,QACf,OAAO;AAAA,MACT;AAAA,MAEA,MAAM,gBAAgB,eAAe,MAAM,YAAY;AAAA,MACvD,MAAM,aAAa,MAAM,QAAQ,SAAS,aAAa;AAAA,MACvD,QAAQ;AAAA,KACT;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;;;AC7QT,qBAAS,wBAAU;AACnB,kBAAS;AAAA;AAIT,SAAS,mBAAmB,CAAC,cAA2C;AAAA,EACtE,KAAK,cAAc;AAAA,IACjB,OAAO;AAAA,EACT;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;AAAA,IACT;AAAA,IAGA,OAAO,YAAY,OAAO,CAAC,EAAE,YAAY,IAAI,YAAY,MAAM,CAAC;AAAA,IAChE,MAAM;AAAA,IAEN,OAAO;AAAA;AAAA;AASX,IAAM,YAAgE;AAAA,EACpE,EAAE,OAAO,OAAM,IAAI,OAAO,UAAU,OAAO,MAAM;AAAA,EACjD,EAAE,OAAO,OAAM,IAAI,OAAO,UAAU,OAAO,MAAM;AAAA,EACjD,EAAE,OAAO,OAAM,IAAI,OAAO,WAAW,OAAO,MAAM;AAAA,EAClD,EAAE,OAAO,OAAM,IAAI,OAAO,aAAa,OAAO,MAAM;AAAA,EACpD,EAAE,OAAO,OAAM,IAAI,OAAO,YAAY,OAAO,MAAM;AAAA,EACnD,EAAE,OAAO,OAAM,IAAI,OAAO,UAAU,OAAO,MAAM;AAAA,EACjD,EAAE,OAAO,OAAM,IAAI,OAAO,YAAY,OAAO,MAAM;AACrD;AAEO,IAAM,mBAAoD;AAAA,EAC/D;AAAA,EACA;AAAA,MACI;AAAA,EACJ,OAAO,gBAAgB,qBAAqB,YAAW,KAAK;AAAA,EAG5D,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,MAAuC,WAAvC;AAAA,gBAAW,WAAU;AAAA,gBAArB;AAAA,eAAuC;AAAA;AAAA,WACvC;AAAA,UACD,kBAAkB,yBACjB,MAEE,KAFF;AAAA,YAAG,WAAU;AAAA,YAAb,UACG,oBAAoB,KAAK;AAAA,WAC1B;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;AAAA,qBAEE;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,MAAiC,YAAjC;AAAA,8BAAY,OAAM;AAAA,8BAAlB;AAAA,6BAAiC;AAAA,4CACjC,MAAmC,YAAnC;AAAA,8BAAY,OAAM;AAAA,8BAAlB;AAAA,6BAAmC;AAAA,4CACnC,MAAqC,YAArC;AAAA,8BAAY,OAAM;AAAA,8BAAlB;AAAA,6BAAqC;AAAA,4CACrC,MAAmC,YAAnC;AAAA,8BAAY,OAAM;AAAA,8BAAlB;AAAA,6BAAmC;AAAA;AAAA,yBACnC;AAAA;AAAA,qBACF;AAAA;AAAA,iBACF;AAAA,gCAEF,OAYE,OAZF;AAAA,4BAYE;AAAA,oCAXA,MAEE,OAFF;AAAA,sBAAO,SAAQ;AAAA,sBAAW,WAAU;AAAA,sBAApC;AAAA,qBAEE;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,MAAsC,OAAtC;AAAA,kBAAO,WAAU;AAAA,kBAAjB;AAAA,iBAAsC;AAAA,gCACtC,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,MAAiC,OAAjC;AAAA,kBAAO,WAAU;AAAA,kBAAjB;AAAA,iBAAiC;AAAA,gCACjC,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;AAAA,yBAEE;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;AAAA,yBAEE;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,MAAuC,QAAvC;AAAA,0BAAM,WAAU;AAAA,0BAAhB;AAAA,yBAAuC;AAAA;AAAA,qBACvC;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;AAAA,yBAEE;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;;;;ACrWC,SAAS,oBAAoB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,GAC4B;AAAA,EAC5B,MAAM,oBAAoB,CAAC,UAA+B;AAAA,IACxD,UAAU,KAAK;AAAA,IACf,QAAQ;AAAA;AAAA,EAGV,MAAM,aAAa,kBAAkB,SAAS,WAAW;AAAA,EACzD,MAAM,aAAa,kBAAkB,SAAS,SAAS;AAAA,EAEvD,uBACE,MAyDE,QAzDF;AAAA,IAAQ,MAAM;AAAA,IAAQ,cAAc;AAAA,IAApC,0BACE,OAuDE,eAvDF;AAAA,MAAe,WAAU;AAAA,MAAzB,UAuDE;AAAA,wBAtDA,OAME,cANF;AAAA,oBAME;AAAA,4BALA,OAA2C,aAA3C;AAAA,wBAA2C;AAAA,gBAA7B;AAAA,gBAAd;AAAA;AAAA,aAA2C;AAAA,4BAC3C,OAGE,mBAHF;AAAA,wBAGE;AAAA,gBAHF;AAAA,gBACI;AAAA,gBADJ;AAAA,gBAC6D;AAAA,gBAC1D;AAAA,gBAFH;AAAA;AAAA,aAGE;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,MAAyC,OAAzC;AAAA,oBAAK,WAAU;AAAA,oBAAf;AAAA,mBAAyC;AAAA,kCACzC,OAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAEE;AAAA,sBAFF;AAAA,sBACQ;AAAA,sBADR;AAAA;AAAA,mBAEE;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,MAAwD,OAAxD;AAAA,oBAAK,WAAU;AAAA,oBAAf;AAAA,mBAAwD;AAAA,kCACxD,OAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAEE;AAAA,sBADC;AAAA,sBADH;AAAA;AAAA,mBAEE;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,MAAyC,OAAzC;AAAA,oBAAK,WAAU;AAAA,oBAAf;AAAA,mBAAyC;AAAA,kCACzC,OAEE,OAFF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAEE;AAAA,sBADC;AAAA,sBADH;AAAA;AAAA,mBAEE;AAAA;AAAA,eACF;AAAA,aACF;AAAA;AAAA,SACF;AAAA,wBAEF,MAIE,cAJF;AAAA,oCACE,MAEE,QAFF;AAAA,YAAQ,SAAQ;AAAA,YAAU,SAAS;AAAA,YAAnC;AAAA,WAEE;AAAA,SACF;AAAA;AAAA,KACF;AAAA,GACF;AAAA;;AC5FN,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,6BAA6B,mBAAmB;AAAA,EAExD,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,cAgME;AAAA,sBA/LA,MAqLE,QArLF;AAAA,QAAQ,MAAM;AAAA,QAAM,cAAc;AAAA,QAAlC,0BACE,MAmLE,eAnLF;AAAA,UAAe,WAAU;AAAA,UAAzB,0BACE,OAiLE,QAjLF;AAAA,YAAM,UAAU;AAAA,YAAhB,UAiLE;AAAA,8BAhLA,OASE,cATF;AAAA,gBAAc,WAAU;AAAA,gBAAxB,UASE;AAAA,kCARA,MAEE,aAFF;AAAA,oBAAa,WAAU;AAAA,oBAAvB,UACG,eAAe,KAAK,eAAe;AAAA,mBACpC;AAAA,kCACF,MAIE,mBAJF;AAAA,oBAAmB,WAAU;AAAA,oBAA7B,UACG,eAAe,KACZ,4BACA;AAAA,mBACJ;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;AAAA,uBAEE;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAY;AAAA,wBACZ,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;AAAA,uBAEE;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAY;AAAA,wBACZ,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;AAAA,uBAEE;AAAA;AAAA,mBACF;AAAA,kCAEF,OAmBE,OAnBF;AAAA,oBAAK,WAAU;AAAA,oBAAf,UAmBE;AAAA,sCAlBA,OAQE,OARF;AAAA,kCAQE;AAAA,0CAPA,MAAkD,OAAlD;AAAA,4BAAO,WAAU;AAAA,4BAAjB;AAAA,2BAAkD;AAAA,0CAClD,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,MAAgD,OAAhD;AAAA,4BAAO,WAAU;AAAA,4BAAjB;AAAA,2BAAgD;AAAA,0CAChD,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;AAAA,2BAEE;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;AAAA,2BAEE;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,MAA6C,OAA7C;AAAA,wBAAO,WAAU;AAAA,wBAAjB;AAAA,uBAA6C;AAAA,sCAC7C,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;AAAA,uBAEE;AAAA,sCACF,MAAC,OAAD;AAAA,wBACE,IAAG;AAAA,wBACH,MAAK;AAAA,wBACL,OAAO,WAAW;AAAA,wBAClB,UAAU;AAAA,wBACV,aAAY;AAAA,wBACZ,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;AAAA,mBAQE;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;AAAA,uBAQE;AAAA,sCACF,MAEE,QAFF;AAAA,wBAAQ,MAAK;AAAA,wBAAS,WAAU;AAAA,wBAAsB,MAAK;AAAA,wBAA3D,UACG,eAAe,KAAK,WAAW;AAAA,uBAChC;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;;;AK5bN,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,qBAAS;AAAA;AAGT,IAAM,SAAS;AAAA,EACb;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAGA,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,mBAAmB,mBAAmB;AAAA,EAGjE,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;AAAA,yBAEE;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;;;ACxRf;AAAA;AAcA,IAAM,eAA4C;AAAA,EAChD;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,MACI;AAAA,EACJ,MAAM,SAAS,YAAY;AAAA,EAG3B,MAAM,qBAAqB,CAAC,aAAgD;AAAA,IAC1E,OAAO,GAEL,SAAS,WAAW,IAEpB,aAAa,SAAU,SAAS,WAAW,0BAA2B,IAEtE,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;AAAA,OAOE;AAAA,sBACF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,MAAM;AAAA,QAC9B,SAAS,cAAc,MAAM;AAAA,QAC7B;AAAA,QACA,WAAW,mBAAmB,MAAM;AAAA,QAJtC;AAAA,OAOE;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;AAAA,OAOE;AAAA,sBACF,MAOE,QAPF;AAAA,QACE,SAAS,MAAM,SAAS,MAAM;AAAA,QAC9B,SAAS,cAAc,MAAM;AAAA,QAC7B;AAAA,QACA,WAAW,mBAAmB,MAAM;AAAA,QAJtC;AAAA,OAOE;AAAA,sBAEF,MAEE,QAFF;AAAA,QAAQ,SAAS;AAAA,QAAS,SAAQ;AAAA,QAAU;AAAA,QAA5C;AAAA,OAEE;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,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,MAAwC,QAAxC;AAAA,UAAM,WAAU;AAAA,UAAhB;AAAA,SAAwC;AAAA;AAAA,KACxC;AAAA,GACF,GAEJ,CAAC,aAAa,CAChB;AAAA,EAEA,IAAI,iBAAiB;AAAA,IAEnB,OAAO;AAAA,EACT;AAAA,EAEA,uBACE;AAAA,8BAEE,OAuFE,OAvFF;AAAA,MACE,WAAW,GACT,2FACA,SACF;AAAA,MACA,eAAY;AAAA,MALd,UAuFE;AAAA,wBA/EA,OAGE,OAHF;AAAA,UAAK,WAAU;AAAA,UAAf,UAGE;AAAA,4BAFA,MAAC,eAAD;AAAA,cAAc,WAAU;AAAA,aAAU;AAAA,4BAClC,MAAC,uBAAD,EAAc;AAAA;AAAA,SACd;AAAA,wBAGF,OAwEE,OAxEF;AAAA,UAAK,WAAU;AAAA,UAAf,UAwEE;AAAA,4BAtEA,OAwBE,OAxBF;AAAA,cAAK,WAAU;AAAA,cAAf,UAwBE;AAAA,gCAvBA,MAAC,uBAAD;AAAA,kBACE,aAAa;AAAA,kBACb,UAAU;AAAA,kBACV,SAAS;AAAA,kBACT,QAAQ;AAAA,kBACR,YAAY;AAAA,kBACZ,SAAQ;AAAA,kBACR,WAAU;AAAA,iBACZ;AAAA,gCAGA,MAAC,gBAAD,EAAgB;AAAA,gCAGhB,OAQE,QARF;AAAA,kBACE,SAAS;AAAA,kBACT,SAAQ;AAAA,kBACR,MAAK;AAAA,kBACL,WAAU;AAAA,kBAJZ,UAQE;AAAA,oCAFA,MAAC,UAAD;AAAA,sBAAU,WAAU;AAAA,qBAAU;AAAA,oCAC9B,MAA2C,QAA3C;AAAA,sBAAM,WAAU;AAAA,sBAAhB;AAAA,qBAA2C;AAAA;AAAA,iBAC3C;AAAA;AAAA,aACF;AAAA,4BAGF,OA0CE,OA1CF;AAAA,cAAK,WAAU;AAAA,cAAf,UA0CE;AAAA,gCAxCA,MAAC,gBAAD,EAAgB;AAAA,gCAEhB,OAqCE,SArCF;AAAA,kBACE,MAAM;AAAA,kBACN,cAAc;AAAA,kBAFhB,UAqCE;AAAA,oCAjCA,MAIE,gBAJF;AAAA,sBAAgB,SAAO;AAAA,sBAAvB,0BACE,MAEE,QAFF;AAAA,wBAAQ,SAAQ;AAAA,wBAAU,MAAK;AAAA,wBAA/B,0BACE,MAAC,MAAD;AAAA,0BAAM,WAAU;AAAA,yBAAU;AAAA,uBAC1B;AAAA,qBACF;AAAA,oCACF,MA2BE,gBA3BF;AAAA,sBAAgB,OAAM;AAAA,sBAAM,WAAU;AAAA,sBAAtC,0BACE,OAyBE,OAzBF;AAAA,wBAAK,WAAU;AAAA,wBAAf,UAyBE;AAAA,0CAxBA,MAEE,MAFF;AAAA,4BAAI,WAAU;AAAA,4BAAd;AAAA,2BAEE;AAAA,0CACF,MAAC,uBAAD;AAAA,4BACE,aAAa;AAAA,4BACb,UAAU,CAAC,YAAY,iBAAiB,SAAS,IAAI;AAAA,4BACrD,SAAS,iBAAiB;AAAA,4BAC1B,QAAQ,iBAAiB;AAAA,4BACzB,YAAY,iBAAiB;AAAA,4BAC7B,SAAQ;AAAA,2BACV;AAAA,0CAGA,MAUE,OAVF;AAAA,4BAAK,WAAU;AAAA,4BAAf,0BACE,OAQE,QARF;AAAA,8BACE,SAAS;AAAA,8BACT,SAAQ;AAAA,8BACR,MAAK;AAAA,8BACL,WAAU;AAAA,8BAJZ,UAQE;AAAA,gDAFA,MAAC,UAAD;AAAA,kCAAU,WAAU;AAAA,iCAAU;AAAA,gCANhC;AAAA;AAAA,6BAQE;AAAA,2BACF;AAAA;AAAA,uBACF;AAAA,qBACF;AAAA;AAAA,iBACF;AAAA;AAAA,aACF;AAAA;AAAA,SACF;AAAA;AAAA,KACF;AAAA,GACF;AAAA;AAIN,IAAe;;AGnLf,4BAAS,4BAAiB;AAAA;AAE1B,IAAM,WAAqB,MAAM;AAAA,EAC/B,QAAQ,aAAa,YAAY,QAAQ,SAAS,0BAChD,mBAAmB;AAAA,EACrB,MAAM,OAAO,YAAY,KAAK;AAAA,EAG9B,MAAM,UAAS,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,QAAO,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,UAAU;AAAA;AAAA,iBACpC;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;;AA8B1C,IAAM,mBAAoD;AAAA,EAC/D;AAAA,EACA,SAAS,CAAC;AAAA,EACV,iBAAiB;AAAA,EACjB;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,MACI;AAAA,EAEJ,OAAO,aAAa,kBAAkB,UAAsB,qBAAM,CAAC;AAAA,EACnE,OAAO,MAAM,WAAW,UAA4C,OAAO;AAAA,EAC3E,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,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,aAAY,CAAC,SAAsB;AAAA,IACpD,eAAe,IAAI;AAAA,KAClB,CAAC,CAAC;AAAA,EAEL,MAAM,aAAa,aAAY,MAAM;AAAA,IACnC,QAAQ;AAAA,WACD;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,IAAI,GAAG,OAAO,CAAC;AAAA,QAC3D;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,IAAI,GAAG,MAAM,CAAC;AAAA,QAC1D;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,IAAI,GAAG,KAAK,CAAC;AAAA,QACzD;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,IAAI,GAAG,MAAM,CAAC;AAAA,QAC1D;AAAA;AAAA,KAEH,CAAC,IAAI,CAAC;AAAA,EAET,MAAM,aAAa,aAAY,MAAM;AAAA,IACnC,QAAQ;AAAA,WACD;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,SAAS,GAAG,OAAO,CAAC;AAAA,QAChE;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,SAAS,GAAG,MAAM,CAAC;AAAA,QAC/D;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,SAAS,GAAG,KAAK,CAAC;AAAA,QAC9D;AAAA,WACG;AAAA,QACH,eAAe,CAAC,iBAAgB,aAAY,SAAS,GAAG,MAAM,CAAC;AAAA,QAC/D;AAAA;AAAA,KAEH,CAAC,IAAI,CAAC;AAAA,EAET,MAAM,QAAQ,aAAY,MAAM;AAAA,IAC9B,eAAe,qBAAM,CAAC;AAAA,KACrB,CAAC,CAAC;AAAA,EAEL,MAAM,WAAW,aAAY,CAAC,UAAyB;AAAA,IACrD,iBAAiB,CAAC,eAAe,CAAC,GAAG,YAAY,KAAK,CAAC;AAAA,KACtD,CAAC,CAAC;AAAA,EAEL,MAAM,cAAc,aAClB,CAAC,SAAiB,iBAAyC;AAAA,IACzD,iBAAiB,CAAC,eAChB,WAAW,IAAI,CAAC,UACd,MAAM,OAAO,UAAU,KAAK,UAAU,aAAa,IAAI,KACzD,CACF;AAAA,KAEF,CAAC,CACH;AAAA,EAEA,MAAM,wBAAuB,aAC3B,CACE,OACA,SACA,YACG;AAAA,IAEH,MAAM,gBAAgB,qBAAyB;AAAA,MAC7C,aAAa;AAAA,MACb;AAAA,MACA;AAAA,MACA,OAAO,QAAQ;AAAA,IACjB,CAAC;AAAA,IAED,iBAAiB,aAAa;AAAA,KAEhC,CAAC,aAAa,CAChB;AAAA,EAEA,MAAM,wBAAuB,aAC3B,CAAC,OAAsB,YAAmC;AAAA,IAExD,MAAM,gBAAgB,qBAAyB;AAAA,MAC7C,aAAa;AAAA,MACb;AAAA,MACA,OAAO,QAAQ;AAAA,IACjB,CAAC;AAAA,IAED,iBAAiB,aAAa;AAAA,KAEhC,CAAC,aAAa,CAChB;AAAA,EAEA,MAAM,cAAc,aAAY,CAAC,YAAoB;AAAA,IACnD,iBAAiB,CAAC,eAChB,WAAW,OAAO,CAAC,UAAU,MAAM,OAAO,OAAO,CACnD;AAAA,KACC,CAAC,CAAC;AAAA,EAEL,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;AAAA,QACP,OAAO;AAAA,QACP,KAAK;AAAA,QACL,aAAa;AAAA,QACb,QAAQ;AAAA,MACV,CAAkB;AAAA,MAClB,mBAAmB,IAAI;AAAA;AAAA,KAG3B,CAAC,aAAa,gBAAgB,CAChC;AAAA,EAEA,MAAM,sBAAsB,aAC1B,CAAC,SAAuB;AAAA,IACtB,IAAI,MAAM;AAAA,MACR,gBAAgB,IAAI;AAAA,IACtB;AAAA,IACA,iBAAiB;AAAA,MACf,OAAO;AAAA,MACP,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,WAAW,CACd;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,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,EACF,CACF;AAAA,EAEA,uBACE,MAEE,gBAAgB,UAFlB;AAAA,IAA0B,OAAO;AAAA,IAAjC;AAAA,GAEE;AAAA;;;;AFnaN,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;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,MACI;AAAA,EACJ,uBACE,MAkBE,kBAlBF;AAAA,IACE,QAAQ,mCAAmC,MAAM;AAAA,IACjD,gBAAgB,qBAAqB;AAAA,IACrC;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,IAfF,0BAiBE,MAAC,iBAAD,EAAiB;AAAA,GACjB;AAAA;;;AGlGN,kBAAS;",
  "debugId": "7721FF42EA85BA6064756E2164756E21",
  "names": []
}
4803
+ //# debugId=610D3B681CFFAA3D64756E2164756E21
4804
+ //# 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    t,\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\">{t('new')}</span>\n        </Button>\n      </div>\n    ),\n    [openEventForm, t]\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\">\n                  {t('export')}\n                </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                        {t('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  new: 'New',\n  update: 'Update',\n  delete: 'Delete',\n  cancel: 'Cancel',\n  export: 'Export',\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": "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",
  "debugId": "610D3B681CFFAA3D64756E2164756E21",
  "names": []
}