@arkyn/components 3.0.1-beta.145 → 3.0.1-beta.146

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/dist/bundle.css +1 -1
  2. package/dist/bundle.js +747 -242
  3. package/dist/components/fullCalendar/_fullCalendarProvider.d.ts +35 -0
  4. package/dist/components/fullCalendar/_fullCalendarProvider.d.ts.map +1 -0
  5. package/dist/components/fullCalendar/_fullCalendarProvider.js +33 -0
  6. package/dist/components/fullCalendar/_viewService.d.ts +28 -0
  7. package/dist/components/fullCalendar/_viewService.d.ts.map +1 -0
  8. package/dist/components/fullCalendar/_viewService.js +144 -0
  9. package/dist/components/fullCalendar/dayCalendar/dayCalendarContainer/index.d.ts +8 -0
  10. package/dist/components/fullCalendar/dayCalendar/dayCalendarContainer/index.d.ts.map +1 -0
  11. package/dist/components/fullCalendar/dayCalendar/dayCalendarContainer/index.js +6 -0
  12. package/dist/components/fullCalendar/dayCalendar/dayCalendarEvent/index.d.ts +7 -0
  13. package/dist/components/fullCalendar/dayCalendar/dayCalendarEvent/index.d.ts.map +1 -0
  14. package/dist/components/fullCalendar/dayCalendar/dayCalendarEvent/index.js +101 -0
  15. package/dist/components/fullCalendar/dayCalendar/dayCalendarRow/index.d.ts +8 -0
  16. package/dist/components/fullCalendar/dayCalendar/dayCalendarRow/index.d.ts.map +1 -0
  17. package/dist/components/fullCalendar/dayCalendar/dayCalendarRow/index.js +9 -0
  18. package/dist/components/fullCalendar/dayCalendar/index.d.ts +3 -0
  19. package/dist/components/fullCalendar/dayCalendar/index.d.ts.map +1 -0
  20. package/dist/components/fullCalendar/dayCalendar/index.js +9 -0
  21. package/dist/components/fullCalendar/fullCalendarContainer/index.d.ts +8 -0
  22. package/dist/components/fullCalendar/fullCalendarContainer/index.d.ts.map +1 -0
  23. package/dist/components/fullCalendar/fullCalendarContainer/index.js +6 -0
  24. package/dist/components/fullCalendar/fullCalendarHeader/index.d.ts +8 -0
  25. package/dist/components/fullCalendar/fullCalendarHeader/index.d.ts.map +1 -0
  26. package/dist/components/fullCalendar/fullCalendarHeader/index.js +37 -0
  27. package/dist/components/fullCalendar/index.d.ts +78 -0
  28. package/dist/components/fullCalendar/index.d.ts.map +1 -0
  29. package/dist/components/fullCalendar/index.js +62 -0
  30. package/dist/components/fullCalendar/monthlyCalendar/index.d.ts +3 -0
  31. package/dist/components/fullCalendar/monthlyCalendar/index.d.ts.map +1 -0
  32. package/dist/components/fullCalendar/monthlyCalendar/index.js +8 -0
  33. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarEvent/index.d.ts +9 -0
  34. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarEvent/index.d.ts.map +1 -0
  35. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarEvent/index.js +25 -0
  36. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableBody/index.d.ts +4 -0
  37. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableBody/index.d.ts.map +1 -0
  38. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableBody/index.js +9 -0
  39. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableContainer/index.d.ts +8 -0
  40. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableContainer/index.d.ts.map +1 -0
  41. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableContainer/index.js +6 -0
  42. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableHeader/index.d.ts +4 -0
  43. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableHeader/index.d.ts.map +1 -0
  44. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableHeader/index.js +9 -0
  45. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableTd/index.d.ts +10 -0
  46. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableTd/index.d.ts.map +1 -0
  47. package/dist/components/fullCalendar/monthlyCalendar/monthlyCalendarTableTd/index.js +14 -0
  48. package/dist/components/fullCalendar/weekCalendar/index.d.ts +3 -0
  49. package/dist/components/fullCalendar/weekCalendar/index.d.ts.map +1 -0
  50. package/dist/components/fullCalendar/weekCalendar/index.js +8 -0
  51. package/dist/components/fullCalendar/weekCalendar/weekCalendarEvent/index.d.ts +10 -0
  52. package/dist/components/fullCalendar/weekCalendar/weekCalendarEvent/index.d.ts.map +1 -0
  53. package/dist/components/fullCalendar/weekCalendar/weekCalendarEvent/index.js +98 -0
  54. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableBody/index.d.ts +4 -0
  55. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableBody/index.d.ts.map +1 -0
  56. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableBody/index.js +11 -0
  57. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableContainer/index.d.ts +8 -0
  58. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableContainer/index.d.ts.map +1 -0
  59. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableContainer/index.js +6 -0
  60. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableHeader/index.d.ts +4 -0
  61. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableHeader/index.d.ts.map +1 -0
  62. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableHeader/index.js +10 -0
  63. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableTd/index.d.ts +11 -0
  64. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableTd/index.d.ts.map +1 -0
  65. package/dist/components/fullCalendar/weekCalendar/weekCalendarTableTd/index.js +14 -0
  66. package/dist/index.d.ts +1 -0
  67. package/dist/index.d.ts.map +1 -1
  68. package/dist/index.js +1 -0
  69. package/package.json +1 -1
@@ -0,0 +1,62 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState } from "react";
3
+ import { FullCalendarProvider } from "./_fullCalendarProvider";
4
+ import { DayCalendar } from "./dayCalendar";
5
+ import { FullCalendarContainer } from "./fullCalendarContainer";
6
+ import { FullCalendarHeader } from "./fullCalendarHeader";
7
+ import { MonthlyCalendar } from "./monthlyCalendar";
8
+ import { WeekCalendar } from "./weekCalendar";
9
+ /**
10
+ * FullCalendar — interactive calendar with day, week, and month views.
11
+ *
12
+ * Renders a navigable calendar that displays a list of events. The active view
13
+ * can be switched at runtime via the built-in header controls.
14
+ *
15
+ * @param props.defaultView - Initial view to render (`"day"` | `"week"` | `"month"`). Default: `"month"`
16
+ * @param props.defaultValue - Initial selected date. Defaults to today.
17
+ * @param props.events - Array of events to display on the calendar.
18
+ * @param props.events[].title - Event label shown on the calendar.
19
+ * @param props.events[].date - Event start date/time.
20
+ * @param props.events[].endDate - Event end date/time (optional).
21
+ * @param props.events[].data - Arbitrary payload forwarded to `onClick`.
22
+ * @param props.events[].scheme - Color scheme for the event chip (`"primary"` | `"success"` | `"warning"` | `"danger"` | `"info"`).
23
+ * @param props.events[].onClick - Fires when the user clicks the event — receives `data`.
24
+ * @param props.onChange - Fires when the selected date changes — receives the new `Date`.
25
+ * @param props.onChangeView - Fires when the user navigates to a different period — receives the current `Date`.
26
+ *
27
+ * @returns FullCalendar JSX element.
28
+ *
29
+ * @example
30
+ * ```tsx
31
+ * // Basic monthly calendar
32
+ * <FullCalendar />
33
+ *
34
+ * // Start on week view with a pre-selected date
35
+ * <FullCalendar defaultView="week" defaultValue={new Date("2025-06-01")} />
36
+ *
37
+ * // With events
38
+ * <FullCalendar
39
+ * events={[
40
+ * {
41
+ * title: "Team meeting",
42
+ * date: new Date("2025-06-13T10:00:00"),
43
+ * endDate: new Date("2025-06-13T11:00:00"),
44
+ * scheme: "primary",
45
+ * data: { meetingId: 42 },
46
+ * onClick: ({ meetingId }) => openMeeting(meetingId),
47
+ * },
48
+ * {
49
+ * title: "Deadline",
50
+ * date: new Date("2025-06-20"),
51
+ * scheme: "danger",
52
+ * },
53
+ * ]}
54
+ * onChangeView={(date) => fetchEventsForMonth(date)}
55
+ * />
56
+ * ```
57
+ */
58
+ function FullCalendar(props) {
59
+ const [viewType, setViewType] = useState(props.defaultView || "month");
60
+ return (_jsx(FullCalendarProvider, { events: props.events || [], defaultValue: props.defaultValue, onChangeView: props.onChangeView, children: _jsxs(FullCalendarContainer, { children: [_jsx(FullCalendarHeader, { viewType: viewType, setViewType: setViewType }), viewType === "day" && _jsx(DayCalendar, {}), viewType === "month" && _jsx(MonthlyCalendar, {}), viewType === "week" && _jsx(WeekCalendar, {})] }) }));
61
+ }
62
+ export { FullCalendar };
@@ -0,0 +1,3 @@
1
+ declare function MonthlyCalendar(): import("react/jsx-runtime").JSX.Element;
2
+ export { MonthlyCalendar };
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/fullCalendar/monthlyCalendar/index.tsx"],"names":[],"mappings":"AAIA,iBAAS,eAAe,4CAOvB;AAED,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { MonthlyCalendarTableBody } from "./monthlyCalendarTableBody";
3
+ import { MonthlyCalendarTableContainer } from "./monthlyCalendarTableContainer";
4
+ import { MonthlyCalendarTableHeader } from "./monthlyCalendarTableHeader";
5
+ function MonthlyCalendar() {
6
+ return (_jsxs(MonthlyCalendarTableContainer, { children: [_jsx(MonthlyCalendarTableHeader, {}), _jsx(MonthlyCalendarTableBody, {})] }));
7
+ }
8
+ export { MonthlyCalendar };
@@ -0,0 +1,9 @@
1
+ import "./styles.css";
2
+ type MonthlyCalendarEventProps = {
3
+ day: number;
4
+ month: number;
5
+ year: number;
6
+ };
7
+ declare function MonthlyCalendarEvent(props: MonthlyCalendarEventProps): import("react/jsx-runtime").JSX.Element | import("react/jsx-runtime").JSX.Element[];
8
+ export { MonthlyCalendarEvent };
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/monthlyCalendar/monthlyCalendarEvent/index.tsx"],"names":[],"mappings":"AACA,OAAO,cAAc,CAAC;AAEtB,KAAK,yBAAyB,GAAG;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,iBAAS,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,uFAsC7D;AAED,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,25 @@
1
+ import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useFullCalendar } from "../../_fullCalendarProvider";
3
+ import "./styles.css";
4
+ function MonthlyCalendarEvent(props) {
5
+ const { events } = useFullCalendar();
6
+ const filteredEvents = events.filter((event) => {
7
+ return (event.date.getDate() === props.day &&
8
+ event.date.getMonth() === props.month &&
9
+ event.date.getFullYear() === props.year);
10
+ });
11
+ if (filteredEvents.length === 0)
12
+ return _jsx(_Fragment, {});
13
+ function makeEventKey(index) {
14
+ return `${props.day}-${props.month}-${props.year}-${index}`;
15
+ }
16
+ function makeHour(date) {
17
+ const hours = date.getHours();
18
+ const minutes = date.getMinutes();
19
+ if (minutes === 0)
20
+ return `${hours}h`;
21
+ return `${hours}h${minutes}`;
22
+ }
23
+ return filteredEvents.map((event, index) => (_jsxs("div", { className: `arkynMonthlyCalendarEvent ${event?.scheme || "primary"}`, onClick: () => event.onClick?.(event.data), children: [_jsxs("strong", { children: [makeHour(event.date), " ", event?.endDate && `- ${makeHour(event.endDate)}`] }), _jsx("p", { children: event.title })] }, makeEventKey(index))));
24
+ }
25
+ export { MonthlyCalendarEvent };
@@ -0,0 +1,4 @@
1
+ import "./styles.css";
2
+ declare function MonthlyCalendarTableBody(): import("react/jsx-runtime").JSX.Element;
3
+ export { MonthlyCalendarTableBody };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/monthlyCalendar/monthlyCalendarTableBody/index.tsx"],"names":[],"mappings":"AAEA,OAAO,cAAc,CAAC;AAEtB,iBAAS,wBAAwB,4CAchC;AAED,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useFullCalendar } from "../../_fullCalendarProvider";
3
+ import { MonthlyCalendarTableTd } from "../monthlyCalendarTableTd";
4
+ import "./styles.css";
5
+ function MonthlyCalendarTableBody() {
6
+ const fullCalendar = useFullCalendar();
7
+ return (_jsx("tbody", { className: "arkynMonthlyCalendarTableBody", children: fullCalendar.listMonthlyMatrix.map((week, weekIndex) => (_jsx("tr", { children: week.map((props, dayIndex) => (_jsx(MonthlyCalendarTableTd, { ...props }, dayIndex))) }, weekIndex))) }));
8
+ }
9
+ export { MonthlyCalendarTableBody };
@@ -0,0 +1,8 @@
1
+ import type { ReactNode } from "react";
2
+ import "./styles.css";
3
+ type MonthlyCalendarTableContainerProps = {
4
+ children: ReactNode;
5
+ };
6
+ declare function MonthlyCalendarTableContainer({ children, }: MonthlyCalendarTableContainerProps): import("react/jsx-runtime").JSX.Element;
7
+ export { MonthlyCalendarTableContainer };
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/monthlyCalendar/monthlyCalendarTableContainer/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,cAAc,CAAC;AAEtB,KAAK,kCAAkC,GAAG;IACxC,QAAQ,EAAE,SAAS,CAAC;CACrB,CAAC;AAEF,iBAAS,6BAA6B,CAAC,EACrC,QAAQ,GACT,EAAE,kCAAkC,2CAMpC;AAED,OAAO,EAAE,6BAA6B,EAAE,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import "./styles.css";
3
+ function MonthlyCalendarTableContainer({ children, }) {
4
+ return (_jsx("div", { className: "arkynMonthlyCalendarTableContainer", children: _jsx("table", { children: children }) }));
5
+ }
6
+ export { MonthlyCalendarTableContainer };
@@ -0,0 +1,4 @@
1
+ import "./styles.css";
2
+ declare function MonthlyCalendarTableHeader(): import("react/jsx-runtime").JSX.Element;
3
+ export { MonthlyCalendarTableHeader };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/monthlyCalendar/monthlyCalendarTableHeader/index.tsx"],"names":[],"mappings":"AAEA,OAAO,cAAc,CAAC;AAEtB,iBAAS,0BAA0B,4CAYlC;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { formatToCapitalizeFirstWordLetter } from "@arkyn/shared";
3
+ import { useFullCalendar } from "../../_fullCalendarProvider";
4
+ import "./styles.css";
5
+ function MonthlyCalendarTableHeader() {
6
+ const { listWeek } = useFullCalendar();
7
+ return (_jsx("thead", { className: "arkynMonthlyCalendarTableHeader", children: _jsx("tr", { children: listWeek.map((day, index) => (_jsx("th", { children: formatToCapitalizeFirstWordLetter(day) }, index))) }) }));
8
+ }
9
+ export { MonthlyCalendarTableHeader };
@@ -0,0 +1,10 @@
1
+ import "./styles.css";
2
+ type MonthlyCalendarTableTdProps = {
3
+ day: number;
4
+ month: number;
5
+ year: number;
6
+ dayOwner: "previous" | "current" | "next";
7
+ };
8
+ declare function MonthlyCalendarTableTd(props: MonthlyCalendarTableTdProps): import("react/jsx-runtime").JSX.Element;
9
+ export { MonthlyCalendarTableTd };
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/monthlyCalendar/monthlyCalendarTableTd/index.tsx"],"names":[],"mappings":"AACA,OAAO,cAAc,CAAC;AAEtB,KAAK,2BAA2B,GAAG;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,UAAU,GAAG,SAAS,GAAG,MAAM,CAAC;CAC3C,CAAC;AAEF,iBAAS,sBAAsB,CAAC,KAAK,EAAE,2BAA2B,2CAoBjE;AAED,OAAO,EAAE,sBAAsB,EAAE,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { MonthlyCalendarEvent } from "../monthlyCalendarEvent";
3
+ import "./styles.css";
4
+ function MonthlyCalendarTableTd(props) {
5
+ const { day, month, year, dayOwner } = props;
6
+ function isToday() {
7
+ const today = new Date();
8
+ return (day === today.getDate() &&
9
+ month === today.getMonth() &&
10
+ year === today.getFullYear());
11
+ }
12
+ return (_jsxs("td", { className: `arkynMonthlyCalendarTableTd ${dayOwner}`, children: [_jsx("p", { className: isToday() ? "today" : "", children: day }), _jsx("div", { className: "arkynMonthlyCalendarEventContainer", children: _jsx(MonthlyCalendarEvent, { day: day, month: month, year: year }) })] }));
13
+ }
14
+ export { MonthlyCalendarTableTd };
@@ -0,0 +1,3 @@
1
+ declare function WeekCalendar(): import("react/jsx-runtime").JSX.Element;
2
+ export { WeekCalendar };
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/fullCalendar/weekCalendar/index.tsx"],"names":[],"mappings":"AAIA,iBAAS,YAAY,4CAOpB;AAED,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { WeekCalendarTableBody } from "./weekCalendarTableBody";
3
+ import { WeekCalendarTableContainer } from "./weekCalendarTableContainer";
4
+ import { WeekCalendarTableHeader } from "./weekCalendarTableHeader";
5
+ function WeekCalendar() {
6
+ return (_jsxs(WeekCalendarTableContainer, { children: [_jsx(WeekCalendarTableHeader, {}), _jsx(WeekCalendarTableBody, {})] }));
7
+ }
8
+ export { WeekCalendar };
@@ -0,0 +1,10 @@
1
+ import "./styles.css";
2
+ type WeekCalendarEventProps = {
3
+ day: number;
4
+ month: number;
5
+ year: number;
6
+ timeInMinutes: number;
7
+ };
8
+ declare function WeekCalendarEvent(props: WeekCalendarEventProps): import("react/jsx-runtime").JSX.Element | import("react/jsx-runtime").JSX.Element[];
9
+ export { WeekCalendarEvent };
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/weekCalendar/weekCalendarEvent/index.tsx"],"names":[],"mappings":"AACA,OAAO,cAAc,CAAC;AAEtB,KAAK,sBAAsB,GAAG;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,EAAE,MAAM,CAAC;CACvB,CAAC;AAKF,iBAAS,iBAAiB,CAAC,KAAK,EAAE,sBAAsB,uFAuIvD;AAED,OAAO,EAAE,iBAAiB,EAAE,CAAC"}
@@ -0,0 +1,98 @@
1
+ import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useFullCalendar } from "../../_fullCalendarProvider";
3
+ import "./styles.css";
4
+ const SLOT_DURATION_MINUTES = 30;
5
+ const OVERLAP_OFFSET_PX = 40;
6
+ function WeekCalendarEvent(props) {
7
+ const { events } = useFullCalendar();
8
+ const dayEvents = events
9
+ .map((event, sourceIndex) => ({ event, sourceIndex }))
10
+ .filter(({ event }) => {
11
+ return (event.date.getDate() === props.day &&
12
+ event.date.getMonth() === props.month &&
13
+ event.date.getFullYear() === props.year);
14
+ })
15
+ .sort((a, b) => {
16
+ const startA = a.event.date.getTime();
17
+ const startB = b.event.date.getTime();
18
+ if (startA !== startB)
19
+ return startA - startB;
20
+ const endA = a.event.endDate?.getTime() ?? startA + SLOT_DURATION_MINUTES * 60_000;
21
+ const endB = b.event.endDate?.getTime() ?? startB + SLOT_DURATION_MINUTES * 60_000;
22
+ if (endA !== endB)
23
+ return endA - endB;
24
+ return a.sourceIndex - b.sourceIndex;
25
+ });
26
+ const dayEventOrderBySourceIndex = new Map(dayEvents.map((item, orderIndex) => [item.sourceIndex, orderIndex]));
27
+ const filteredEvents = dayEvents.filter(({ event }) => {
28
+ const dayHour = Math.floor(props.timeInMinutes / 60);
29
+ const dayMinute = props.timeInMinutes % 60;
30
+ function isEventInInterval() {
31
+ const eventHour = event.date.getHours();
32
+ const eventMinute = event.date.getMinutes();
33
+ if (eventHour !== dayHour)
34
+ return false;
35
+ if (dayMinute === 0)
36
+ return eventMinute < 30 && eventMinute >= 0;
37
+ if (dayMinute === 30)
38
+ return eventMinute >= 30 && eventMinute < 60;
39
+ }
40
+ return (isEventInInterval() &&
41
+ event.date.getDate() === props.day &&
42
+ event.date.getMonth() === props.month &&
43
+ event.date.getFullYear() === props.year);
44
+ });
45
+ if (filteredEvents.length === 0)
46
+ return _jsx(_Fragment, {});
47
+ function makeEventKey(index, sourceIndex) {
48
+ return `${props.day}-${props.month}-${props.year}-${sourceIndex}-${index}`;
49
+ }
50
+ function makeHour(date) {
51
+ const hours = date.getHours();
52
+ const minutes = date.getMinutes();
53
+ if (minutes === 0)
54
+ return `${hours}h`;
55
+ return `${hours}h${minutes}`;
56
+ }
57
+ function getEventRangeInMinutes(event) {
58
+ const startMinutes = event.date.getHours() * 60 + event.date.getMinutes();
59
+ const endMinutes = event.endDate
60
+ ? event.endDate.getHours() * 60 + event.endDate.getMinutes()
61
+ : startMinutes + SLOT_DURATION_MINUTES;
62
+ return {
63
+ startMinutes,
64
+ endMinutes: Math.max(endMinutes, startMinutes + 1),
65
+ };
66
+ }
67
+ function countOverlappingPreviousEvents(currentEvent, sourceIndex) {
68
+ const current = getEventRangeInMinutes(currentEvent);
69
+ const currentOrderIndex = dayEventOrderBySourceIndex.get(sourceIndex);
70
+ if (currentOrderIndex == null)
71
+ return 0;
72
+ return dayEvents.reduce((count, item, orderIndex) => {
73
+ if (orderIndex >= currentOrderIndex)
74
+ return count;
75
+ const candidate = getEventRangeInMinutes(item.event);
76
+ const intersects = candidate.startMinutes < current.endMinutes &&
77
+ candidate.endMinutes > current.startMinutes;
78
+ if (!intersects)
79
+ return count;
80
+ return count + 1;
81
+ }, 0);
82
+ }
83
+ function getEventStyle(event, sourceIndex) {
84
+ const { startMinutes, endMinutes } = getEventRangeInMinutes(event);
85
+ const startOffsetInCell = startMinutes - props.timeInMinutes;
86
+ const durationInMinutes = Math.max(endMinutes - startMinutes, 1);
87
+ const top = (startOffsetInCell / SLOT_DURATION_MINUTES) * 100;
88
+ const height = (durationInMinutes / SLOT_DURATION_MINUTES) * 100;
89
+ const overlapOffset = countOverlappingPreviousEvents(event, sourceIndex) * OVERLAP_OFFSET_PX;
90
+ return {
91
+ top: `${top}%`,
92
+ height: `${height}%`,
93
+ left: `${overlapOffset}px`,
94
+ };
95
+ }
96
+ return filteredEvents.map(({ event, sourceIndex }, index) => (_jsxs("div", { className: `arkynWeekCalendarEvent ${event?.scheme || "primary"}`, style: getEventStyle(event, sourceIndex), onClick: () => event.onClick?.(event.data), children: [_jsxs("strong", { children: [makeHour(event.date), " ", event?.endDate && `- ${makeHour(event.endDate)}`] }), _jsx("p", { children: event.title })] }, makeEventKey(index, sourceIndex))));
97
+ }
98
+ export { WeekCalendarEvent };
@@ -0,0 +1,4 @@
1
+ import "./styles.css";
2
+ declare function WeekCalendarTableBody(): import("react/jsx-runtime").JSX.Element;
3
+ export { WeekCalendarTableBody };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/weekCalendar/weekCalendarTableBody/index.tsx"],"names":[],"mappings":"AAGA,OAAO,cAAc,CAAC;AAEtB,iBAAS,qBAAqB,4CAsB7B;AAED,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useFullCalendar } from "../../_fullCalendarProvider";
3
+ import { ViewService } from "../../_viewService";
4
+ import { WeekCalendarTableTd } from "../weekCalendarTableTd";
5
+ import "./styles.css";
6
+ function WeekCalendarTableBody() {
7
+ const fullCalendar = useFullCalendar();
8
+ const viewService = new ViewService();
9
+ return (_jsx("tbody", { className: "arkynWeekCalendarTableBody", children: fullCalendar.listWeeklyMatrix.map((hourRow) => (_jsxs("tr", { children: [_jsx("td", { className: "hourTd", children: _jsx("p", { children: viewService.formatHourLabel(hourRow[0].timeInMinutes) }) }), hourRow.map((cell, index) => (_jsx(WeekCalendarTableTd, { ...cell }, `${cell.year}-${cell.month}-${cell.day}-${cell.timeInMinutes}-${index}`)))] }, hourRow[0].timeInMinutes))) }));
10
+ }
11
+ export { WeekCalendarTableBody };
@@ -0,0 +1,8 @@
1
+ import type { ReactNode } from "react";
2
+ import "./styles.css";
3
+ type WeekCalendarTableContainerProps = {
4
+ children: ReactNode;
5
+ };
6
+ declare function WeekCalendarTableContainer({ children, }: WeekCalendarTableContainerProps): import("react/jsx-runtime").JSX.Element;
7
+ export { WeekCalendarTableContainer };
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/weekCalendar/weekCalendarTableContainer/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,cAAc,CAAC;AAEtB,KAAK,+BAA+B,GAAG;IACrC,QAAQ,EAAE,SAAS,CAAC;CACrB,CAAC;AAEF,iBAAS,0BAA0B,CAAC,EAClC,QAAQ,GACT,EAAE,+BAA+B,2CAMjC;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import "./styles.css";
3
+ function WeekCalendarTableContainer({ children, }) {
4
+ return (_jsx("div", { className: "arkynWeekCalendarTableContainer", children: _jsx("table", { children: children }) }));
5
+ }
6
+ export { WeekCalendarTableContainer };
@@ -0,0 +1,4 @@
1
+ import "./styles.css";
2
+ declare function WeekCalendarTableHeader(): import("react/jsx-runtime").JSX.Element;
3
+ export { WeekCalendarTableHeader };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/weekCalendar/weekCalendarTableHeader/index.tsx"],"names":[],"mappings":"AAEA,OAAO,cAAc,CAAC;AAEtB,iBAAS,uBAAuB,4CAmB/B;AAED,OAAO,EAAE,uBAAuB,EAAE,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { formatToCapitalizeFirstWordLetter } from "@arkyn/shared";
3
+ import { useFullCalendar } from "../../_fullCalendarProvider";
4
+ import "./styles.css";
5
+ function WeekCalendarTableHeader() {
6
+ const { listWeek, listWeeklyMatrix } = useFullCalendar();
7
+ const firstHourRow = listWeeklyMatrix[0] || [];
8
+ return (_jsx("thead", { className: "arkynWeekCalendarTableHeader", children: _jsxs("tr", { children: [_jsx("th", {}), listWeek.map((day, index) => (_jsx("th", { children: _jsxs("div", { className: "arkynWeekCalendarTableHeaderContent", children: [_jsx("span", { children: formatToCapitalizeFirstWordLetter(day) }), _jsx("strong", { children: firstHourRow[index]?.day })] }) }, index)))] }) }));
9
+ }
10
+ export { WeekCalendarTableHeader };
@@ -0,0 +1,11 @@
1
+ import "./styles.css";
2
+ type WeekCalendarTableTdProps = {
3
+ day: number;
4
+ month: number;
5
+ year: number;
6
+ dayOwner: "previous" | "current" | "next";
7
+ timeInMinutes: number;
8
+ };
9
+ declare function WeekCalendarTableTd(props: WeekCalendarTableTdProps): import("react/jsx-runtime").JSX.Element;
10
+ export { WeekCalendarTableTd };
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/fullCalendar/weekCalendar/weekCalendarTableTd/index.tsx"],"names":[],"mappings":"AACA,OAAO,cAAc,CAAC;AAEtB,KAAK,wBAAwB,GAAG;IAC9B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,UAAU,GAAG,SAAS,GAAG,MAAM,CAAC;IAC1C,aAAa,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,iBAAS,mBAAmB,CAAC,KAAK,EAAE,wBAAwB,2CA4B3D;AAED,OAAO,EAAE,mBAAmB,EAAE,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { WeekCalendarEvent } from "../weekCalendarEvent";
3
+ import "./styles.css";
4
+ function WeekCalendarTableTd(props) {
5
+ const { day, month, year, dayOwner, timeInMinutes } = props;
6
+ function isToday() {
7
+ const today = new Date();
8
+ return (day === today.getDate() &&
9
+ month === today.getMonth() &&
10
+ year === today.getFullYear());
11
+ }
12
+ return (_jsx("td", { className: `arkynWeekCalendarTableTd ${dayOwner} ${isToday() ? "today" : ""}`, "data-day": day, "data-time": timeInMinutes, children: _jsx("div", { className: "arkynWeekCalendarTableTdContent", children: _jsx(WeekCalendarEvent, { day: day, month: month, year: year, timeInMinutes: timeInMinutes }) }) }));
13
+ }
14
+ export { WeekCalendarTableTd };
package/dist/index.d.ts CHANGED
@@ -21,6 +21,7 @@ export { FieldError } from "./components/fieldError";
21
21
  export { FieldLabel } from "./components/fieldLabel";
22
22
  export { FieldWrapper } from "./components/fieldWrapper";
23
23
  export { FileUpload } from "./components/fileUpload";
24
+ export { FullCalendar } from "./components/fullCalendar";
24
25
  export { GoogleAnalytics } from "./components/googleAnalytics";
25
26
  export { GoogleTagManager } from "./components/googleTagManager";
26
27
  export { IconButton } from "./components/iconButton";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
package/dist/index.js CHANGED
@@ -22,6 +22,7 @@ export { FieldError } from "./components/fieldError";
22
22
  export { FieldLabel } from "./components/fieldLabel";
23
23
  export { FieldWrapper } from "./components/fieldWrapper";
24
24
  export { FileUpload } from "./components/fileUpload";
25
+ export { FullCalendar } from "./components/fullCalendar";
25
26
  export { GoogleAnalytics } from "./components/googleAnalytics";
26
27
  export { GoogleTagManager } from "./components/googleTagManager";
27
28
  export { IconButton } from "./components/iconButton";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@arkyn/components",
3
- "version": "3.0.1-beta.145",
3
+ "version": "3.0.1-beta.146",
4
4
  "main": "./dist/bundle.js",
5
5
  "module": "./dist/bundle.js",
6
6
  "types": "./dist/index.d.ts",