@innosolutions/inno-calendar 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/dist/agenda-dropdown-BtVd7oeX.cjs +2 -0
  2. package/dist/agenda-dropdown-BtVd7oeX.cjs.map +1 -0
  3. package/dist/agenda-dropdown-CU74g7uM.js +3393 -0
  4. package/dist/agenda-dropdown-CU74g7uM.js.map +1 -0
  5. package/dist/agenda-view-CgPn9KUd.js +2390 -0
  6. package/dist/agenda-view-CgPn9KUd.js.map +1 -0
  7. package/dist/agenda-view-WMI-YjDn.cjs +11 -0
  8. package/dist/agenda-view-WMI-YjDn.cjs.map +1 -0
  9. package/dist/components/calendar.d.ts +43 -0
  10. package/dist/components/calendar.d.ts.map +1 -0
  11. package/dist/components/event/event-card.d.ts +106 -0
  12. package/dist/components/event/event-card.d.ts.map +1 -0
  13. package/dist/components/event/event-popover.d.ts +138 -0
  14. package/dist/components/event/event-popover.d.ts.map +1 -0
  15. package/dist/components/event/index.d.ts +6 -0
  16. package/dist/components/event/index.d.ts.map +1 -0
  17. package/dist/components/filters/calendar-filter-sidebar.d.ts +54 -0
  18. package/dist/components/filters/calendar-filter-sidebar.d.ts.map +1 -0
  19. package/dist/components/filters/index.d.ts +9 -0
  20. package/dist/components/filters/index.d.ts.map +1 -0
  21. package/dist/components/filters/schedule-type-filter.d.ts +31 -0
  22. package/dist/components/filters/schedule-type-filter.d.ts.map +1 -0
  23. package/dist/components/filters/user-filter.d.ts +31 -0
  24. package/dist/components/filters/user-filter.d.ts.map +1 -0
  25. package/dist/components/header/calendar-header.d.ts +55 -0
  26. package/dist/components/header/calendar-header.d.ts.map +1 -0
  27. package/dist/components/header/components/date-navigator.d.ts +22 -0
  28. package/dist/components/header/components/date-navigator.d.ts.map +1 -0
  29. package/dist/components/header/components/index.d.ts +8 -0
  30. package/dist/components/header/components/index.d.ts.map +1 -0
  31. package/dist/components/header/components/today-button.d.ts +15 -0
  32. package/dist/components/header/components/today-button.d.ts.map +1 -0
  33. package/dist/components/header/index.d.ts +7 -0
  34. package/dist/components/header/index.d.ts.map +1 -0
  35. package/dist/components/index.cjs +2 -0
  36. package/dist/components/index.cjs.map +1 -0
  37. package/dist/components/index.d.ts +25 -0
  38. package/dist/components/index.d.ts.map +1 -0
  39. package/dist/components/index.mjs +45 -0
  40. package/dist/components/index.mjs.map +1 -0
  41. package/dist/components/inno-calendar.d.ts +37 -0
  42. package/dist/components/inno-calendar.d.ts.map +1 -0
  43. package/dist/components/integrated-calendar.d.ts +37 -0
  44. package/dist/components/integrated-calendar.d.ts.map +1 -0
  45. package/dist/components/primitives/calendar-timeline.d.ts +13 -0
  46. package/dist/components/primitives/calendar-timeline.d.ts.map +1 -0
  47. package/dist/components/primitives/index.d.ts +7 -0
  48. package/dist/components/primitives/index.d.ts.map +1 -0
  49. package/dist/components/primitives/multi-day-banner.d.ts +14 -0
  50. package/dist/components/primitives/multi-day-banner.d.ts.map +1 -0
  51. package/dist/components/primitives/selectable-slot.d.ts +62 -0
  52. package/dist/components/primitives/selectable-slot.d.ts.map +1 -0
  53. package/dist/components/settings/badge-variant-setting.d.ts +25 -0
  54. package/dist/components/settings/badge-variant-setting.d.ts.map +1 -0
  55. package/dist/components/settings/index.d.ts +10 -0
  56. package/dist/components/settings/index.d.ts.map +1 -0
  57. package/dist/components/settings/slot-duration-setting.d.ts +20 -0
  58. package/dist/components/settings/slot-duration-setting.d.ts.map +1 -0
  59. package/dist/components/settings/visible-hours-setting.d.ts +23 -0
  60. package/dist/components/settings/visible-hours-setting.d.ts.map +1 -0
  61. package/dist/components/settings/working-hours-setting.d.ts +41 -0
  62. package/dist/components/settings/working-hours-setting.d.ts.map +1 -0
  63. package/dist/components/ui/badge.d.ts +10 -0
  64. package/dist/components/ui/badge.d.ts.map +1 -0
  65. package/dist/components/ui/button.d.ts +13 -0
  66. package/dist/components/ui/button.d.ts.map +1 -0
  67. package/dist/components/ui/dropdown-menu.d.ts +34 -0
  68. package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
  69. package/dist/components/ui/index.d.ts +12 -0
  70. package/dist/components/ui/index.d.ts.map +1 -0
  71. package/dist/components/ui/popover.d.ts +8 -0
  72. package/dist/components/ui/popover.d.ts.map +1 -0
  73. package/dist/components/ui/select.d.ts +12 -0
  74. package/dist/components/ui/select.d.ts.map +1 -0
  75. package/dist/components/ui/tooltip.d.ts +8 -0
  76. package/dist/components/ui/tooltip.d.ts.map +1 -0
  77. package/dist/components/views/agenda-view.d.ts +28 -0
  78. package/dist/components/views/agenda-view.d.ts.map +1 -0
  79. package/dist/components/views/day-view.d.ts +40 -0
  80. package/dist/components/views/day-view.d.ts.map +1 -0
  81. package/dist/components/views/index.d.ts +10 -0
  82. package/dist/components/views/index.d.ts.map +1 -0
  83. package/dist/components/views/month-view.d.ts +32 -0
  84. package/dist/components/views/month-view.d.ts.map +1 -0
  85. package/dist/components/views/timeline-view.d.ts +33 -0
  86. package/dist/components/views/timeline-view.d.ts.map +1 -0
  87. package/dist/components/views/week-view.d.ts +44 -0
  88. package/dist/components/views/week-view.d.ts.map +1 -0
  89. package/dist/components/views/year-view.d.ts +16 -0
  90. package/dist/components/views/year-view.d.ts.map +1 -0
  91. package/dist/components/widget/agenda-dropdown.d.ts +20 -0
  92. package/dist/components/widget/agenda-dropdown.d.ts.map +1 -0
  93. package/dist/components/widget/agenda-widget.d.ts +27 -0
  94. package/dist/components/widget/agenda-widget.d.ts.map +1 -0
  95. package/dist/components/widget/index.d.ts +6 -0
  96. package/dist/components/widget/index.d.ts.map +1 -0
  97. package/dist/core/constants.d.ts +78 -0
  98. package/dist/core/constants.d.ts.map +1 -0
  99. package/dist/core/context/calendar-context.d.ts +65 -0
  100. package/dist/core/context/calendar-context.d.ts.map +1 -0
  101. package/dist/core/context/drag-drop-context.d.ts +58 -0
  102. package/dist/core/context/drag-drop-context.d.ts.map +1 -0
  103. package/dist/core/context/index.d.ts +5 -0
  104. package/dist/core/context/index.d.ts.map +1 -0
  105. package/dist/core/context/inno-calendar-provider.d.ts +121 -0
  106. package/dist/core/context/inno-calendar-provider.d.ts.map +1 -0
  107. package/dist/core/context/slot-selection-context.d.ts +42 -0
  108. package/dist/core/context/slot-selection-context.d.ts.map +1 -0
  109. package/dist/core/hooks/index.d.ts +5 -0
  110. package/dist/core/hooks/index.d.ts.map +1 -0
  111. package/dist/core/hooks/use-calendar-time-config.d.ts +31 -0
  112. package/dist/core/hooks/use-calendar-time-config.d.ts.map +1 -0
  113. package/dist/core/hooks/use-calendar.d.ts +63 -0
  114. package/dist/core/hooks/use-calendar.d.ts.map +1 -0
  115. package/dist/core/hooks/use-preferences.d.ts +21 -0
  116. package/dist/core/hooks/use-preferences.d.ts.map +1 -0
  117. package/dist/core/hooks/use-slot-selection.d.ts +39 -0
  118. package/dist/core/hooks/use-slot-selection.d.ts.map +1 -0
  119. package/dist/core/index.cjs +2 -0
  120. package/dist/core/index.cjs.map +1 -0
  121. package/dist/core/index.d.ts +13 -0
  122. package/dist/core/index.d.ts.map +1 -0
  123. package/dist/core/index.mjs +157 -0
  124. package/dist/core/index.mjs.map +1 -0
  125. package/dist/core/preferences/index.d.ts +9 -0
  126. package/dist/core/preferences/index.d.ts.map +1 -0
  127. package/dist/core/preferences/types.d.ts +153 -0
  128. package/dist/core/preferences/types.d.ts.map +1 -0
  129. package/dist/core/preferences/use-preferences.d.ts +54 -0
  130. package/dist/core/preferences/use-preferences.d.ts.map +1 -0
  131. package/dist/core/types.d.ts +466 -0
  132. package/dist/core/types.d.ts.map +1 -0
  133. package/dist/core/utils/date-utils.d.ts +254 -0
  134. package/dist/core/utils/date-utils.d.ts.map +1 -0
  135. package/dist/core/utils/event-utils.d.ts +91 -0
  136. package/dist/core/utils/event-utils.d.ts.map +1 -0
  137. package/dist/core/utils/grid-utils.d.ts +69 -0
  138. package/dist/core/utils/grid-utils.d.ts.map +1 -0
  139. package/dist/core/utils/index.d.ts +5 -0
  140. package/dist/core/utils/index.d.ts.map +1 -0
  141. package/dist/core/utils/position-utils.d.ts +33 -0
  142. package/dist/core/utils/position-utils.d.ts.map +1 -0
  143. package/dist/index-D2U2F80P.cjs +2 -0
  144. package/dist/index-D2U2F80P.cjs.map +1 -0
  145. package/dist/index-DtaLkIY8.js +2777 -0
  146. package/dist/index-DtaLkIY8.js.map +1 -0
  147. package/dist/index.cjs +2 -0
  148. package/dist/index.cjs.map +1 -0
  149. package/dist/index.d.ts +41 -0
  150. package/dist/index.d.ts.map +1 -0
  151. package/dist/index.mjs +204 -0
  152. package/dist/index.mjs.map +1 -0
  153. package/dist/inno-calendar-provider-B0e1XLeo.js +556 -0
  154. package/dist/inno-calendar-provider-B0e1XLeo.js.map +1 -0
  155. package/dist/inno-calendar-provider-BwP6uUAq.cjs +2 -0
  156. package/dist/inno-calendar-provider-BwP6uUAq.cjs.map +1 -0
  157. package/dist/lib/index.cjs +2 -0
  158. package/dist/lib/index.cjs.map +1 -0
  159. package/dist/lib/index.d.ts +2 -0
  160. package/dist/lib/index.d.ts.map +1 -0
  161. package/dist/lib/index.mjs +5 -0
  162. package/dist/lib/index.mjs.map +1 -0
  163. package/dist/lib/utils.d.ts +6 -0
  164. package/dist/lib/utils.d.ts.map +1 -0
  165. package/dist/presets/default/default-calendar.d.ts +44 -0
  166. package/dist/presets/default/default-calendar.d.ts.map +1 -0
  167. package/dist/presets/default/index.d.ts +2 -0
  168. package/dist/presets/default/index.d.ts.map +1 -0
  169. package/dist/presets/index.cjs +2 -0
  170. package/dist/presets/index.cjs.map +1 -0
  171. package/dist/presets/index.d.ts +3 -0
  172. package/dist/presets/index.d.ts.map +1 -0
  173. package/dist/presets/index.mjs +6 -0
  174. package/dist/presets/index.mjs.map +1 -0
  175. package/dist/presets/tailwind/index.d.ts +2 -0
  176. package/dist/presets/tailwind/index.d.ts.map +1 -0
  177. package/dist/presets/tailwind/tailwind-calendar.d.ts +122 -0
  178. package/dist/presets/tailwind/tailwind-calendar.d.ts.map +1 -0
  179. package/dist/slot-selection-context-BCNnYGHC.js +1069 -0
  180. package/dist/slot-selection-context-BCNnYGHC.js.map +1 -0
  181. package/dist/slot-selection-context-C52lU9W4.cjs +2 -0
  182. package/dist/slot-selection-context-C52lU9W4.cjs.map +1 -0
  183. package/dist/tailwind-calendar-CC9RHr10.cjs +2 -0
  184. package/dist/tailwind-calendar-CC9RHr10.cjs.map +1 -0
  185. package/dist/tailwind-calendar-D-D8H4FV.js +414 -0
  186. package/dist/tailwind-calendar-D-D8H4FV.js.map +1 -0
  187. package/dist/use-calendar-time-config-CtKkXw_L.js +191 -0
  188. package/dist/use-calendar-time-config-CtKkXw_L.js.map +1 -0
  189. package/dist/use-calendar-time-config-F-8WV_Sd.cjs +2 -0
  190. package/dist/use-calendar-time-config-F-8WV_Sd.cjs.map +1 -0
  191. package/package.json +128 -0
@@ -0,0 +1,191 @@
1
+ import { useState as b, useRef as M, useCallback as i, useEffect as O, useMemo as p } from "react";
2
+ import { a as x, a$ as w, q as I, b as Y } from "./slot-selection-context-BCNnYGHC.js";
3
+ import { d as k } from "./inno-calendar-provider-B0e1XLeo.js";
4
+ const S = {
5
+ isSelecting: !1,
6
+ startDate: null,
7
+ endDate: null,
8
+ startY: null,
9
+ currentY: null,
10
+ resourceId: void 0
11
+ };
12
+ function L(e) {
13
+ const {
14
+ dayStart: n,
15
+ visibleHours: o,
16
+ hourHeight: a = x,
17
+ slotDuration: s = 30,
18
+ resourceId: f,
19
+ enabled: d = !0,
20
+ onSelect: H
21
+ } = e, [t, r] = b(S), g = M(0), h = i(
22
+ (l, u) => {
23
+ if (!d) return;
24
+ const c = l.clientY - u.top;
25
+ g.current = u.height;
26
+ const D = w(c, n, o, a, s);
27
+ r({
28
+ isSelecting: !0,
29
+ startDate: D,
30
+ endDate: I(D, s),
31
+ startY: c,
32
+ currentY: c,
33
+ resourceId: f
34
+ });
35
+ },
36
+ [d, n, o, a, s, f]
37
+ ), E = i(
38
+ (l, u) => {
39
+ if (!t.isSelecting || !t.startY) return;
40
+ const c = Math.max(0, Math.min(l.clientY - u.top, u.height)), D = w(c, n, o, a, s);
41
+ r((m) => {
42
+ if (!m.startDate) return m;
43
+ const y = c >= (m.startY ?? 0);
44
+ return {
45
+ ...m,
46
+ currentY: c,
47
+ endDate: y ? I(D, s) : D,
48
+ startDate: y ? m.startDate : D
49
+ };
50
+ });
51
+ },
52
+ [t.isSelecting, t.startY, n, o, a, s]
53
+ ), P = i(() => {
54
+ if (!t.isSelecting || !t.startDate || !t.endDate) {
55
+ r(S);
56
+ return;
57
+ }
58
+ const l = t.startDate < t.endDate ? t.startDate : t.endDate, u = t.startDate < t.endDate ? t.endDate : t.startDate, c = {
59
+ startDate: l,
60
+ endDate: u,
61
+ resourceId: t.resourceId
62
+ };
63
+ H?.(c), r(S);
64
+ }, [t, H]), T = i(() => {
65
+ r(S);
66
+ }, []), C = (() => {
67
+ if (!t.isSelecting || t.startY === null || t.currentY === null)
68
+ return { top: 0, height: 0, visible: !1 };
69
+ const l = Math.min(t.startY, t.currentY), u = Math.max(t.startY, t.currentY);
70
+ return {
71
+ top: l,
72
+ height: Math.max(u - l, 20),
73
+ // Minimum height
74
+ visible: !0
75
+ };
76
+ })();
77
+ return {
78
+ selection: t,
79
+ overlay: C,
80
+ handlePointerDown: h,
81
+ handlePointerMove: E,
82
+ handlePointerUp: P,
83
+ cancel: T,
84
+ isSelecting: t.isSelecting
85
+ };
86
+ }
87
+ function U(e = {}) {
88
+ const { initial: n = {}, storageKey: o, onChange: a } = e, [s, f] = b(() => {
89
+ if (o && typeof window < "u")
90
+ try {
91
+ const r = localStorage.getItem(o);
92
+ if (r) {
93
+ const g = JSON.parse(r);
94
+ return { ...Y, ...g, ...n };
95
+ }
96
+ } catch {
97
+ }
98
+ return { ...Y, ...n };
99
+ });
100
+ O(() => {
101
+ if (o && typeof window < "u")
102
+ try {
103
+ localStorage.setItem(o, JSON.stringify(s));
104
+ } catch {
105
+ }
106
+ }, [s, o]);
107
+ const d = i(
108
+ (r) => {
109
+ f((g) => {
110
+ const h = { ...g, ...r };
111
+ return a?.(h), h;
112
+ });
113
+ },
114
+ [a]
115
+ ), H = i(() => {
116
+ const r = { ...Y, ...n };
117
+ f(r), a?.(r);
118
+ }, [n, a]), t = i(
119
+ (r) => s[r],
120
+ [s]
121
+ );
122
+ return {
123
+ preferences: s,
124
+ setPreferences: d,
125
+ resetPreferences: H,
126
+ getPreference: t
127
+ };
128
+ }
129
+ function W() {
130
+ const { preferences: e, setPreferences: n } = k(), o = p(
131
+ () => ({
132
+ from: e.startHour,
133
+ to: e.endHour
134
+ }),
135
+ [e.startHour, e.endHour]
136
+ ), a = p(
137
+ () => ({
138
+ // Default: Mon-Fri same hours
139
+ 1: { from: e.startHour, to: e.endHour },
140
+ 2: { from: e.startHour, to: e.endHour },
141
+ 3: { from: e.startHour, to: e.endHour },
142
+ 4: { from: e.startHour, to: e.endHour },
143
+ 5: { from: e.startHour, to: e.endHour }
144
+ }),
145
+ [e.startHour, e.endHour]
146
+ ), s = i(
147
+ (t) => {
148
+ n({
149
+ startHour: t.from,
150
+ endHour: t.to
151
+ });
152
+ },
153
+ [n]
154
+ ), f = i(
155
+ (t) => {
156
+ const r = Object.values(t)[0];
157
+ r && n({
158
+ startHour: r.from,
159
+ endHour: r.to
160
+ });
161
+ },
162
+ [n]
163
+ ), d = i(
164
+ (t) => {
165
+ n({ slotDuration: t });
166
+ },
167
+ [n]
168
+ ), H = i(
169
+ (t) => {
170
+ console.warn("showWorkingHoursOnly is not yet supported in core preferences");
171
+ },
172
+ []
173
+ );
174
+ return {
175
+ visibleHours: o,
176
+ setVisibleHours: s,
177
+ workingHours: a,
178
+ setWorkingHours: f,
179
+ slotDuration: e.slotDuration,
180
+ setSlotDuration: d,
181
+ showWorkingHoursOnly: !1,
182
+ // Default until added to core preferences
183
+ setShowWorkingHoursOnly: H
184
+ };
185
+ }
186
+ export {
187
+ U as a,
188
+ L as b,
189
+ W as u
190
+ };
191
+ //# sourceMappingURL=use-calendar-time-config-CtKkXw_L.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-calendar-time-config-CtKkXw_L.js","sources":["../src/core/hooks/use-slot-selection.ts","../src/core/hooks/use-preferences.ts","../src/core/hooks/use-calendar-time-config.ts"],"sourcesContent":["/**\r\n * useSlotSelection - Drag-to-Select Hook\r\n *\r\n * Handles mouse/touch interactions for creating events by\r\n * selecting time slots in the calendar grid.\r\n */\r\n\r\nimport { useState, useCallback, useRef } from 'react';\r\nimport type { ISlotSelection, ISelectionResult, IVisibleHours } from '../types';\r\nimport { addMinutes } from '../utils/date-utils';\r\nimport { yToTime } from '../utils/position-utils';\r\nimport { DEFAULT_HOUR_HEIGHT } from '../constants';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UseSlotSelectionOptions {\r\n\t/** Current day being selected on */\r\n\tdayStart: Date;\r\n\t/** Visible hours configuration */\r\n\tvisibleHours: IVisibleHours;\r\n\t/** Height of one hour in pixels */\r\n\thourHeight?: number;\r\n\t/** Slot duration in minutes for snapping */\r\n\tslotDuration?: number;\r\n\t/** Resource ID (for resource views) */\r\n\tresourceId?: string;\r\n\t/** Whether selection is enabled */\r\n\tenabled?: boolean;\r\n\t/** Callback when selection completes */\r\n\tonSelect?: (selection: ISelectionResult) => void;\r\n}\r\n\r\nexport interface UseSlotSelectionReturn {\r\n\t/** Current selection state */\r\n\tselection: ISlotSelection;\r\n\t/** Selection overlay for rendering */\r\n\toverlay: { top: number; height: number; visible: boolean };\r\n\t/** Handler for mouse/touch down */\r\n\thandlePointerDown: (e: React.PointerEvent, containerRect: DOMRect) => void;\r\n\t/** Handler for mouse/touch move */\r\n\thandlePointerMove: (e: React.PointerEvent, containerRect: DOMRect) => void;\r\n\t/** Handler for mouse/touch up */\r\n\thandlePointerUp: () => void;\r\n\t/** Cancel current selection */\r\n\tcancel: () => void;\r\n\t/** Whether currently selecting */\r\n\tisSelecting: boolean;\r\n}\r\n\r\n// ============================================================================\r\n// INITIAL STATE\r\n// ============================================================================\r\n\r\nconst INITIAL_SELECTION: ISlotSelection = {\r\n\tisSelecting: false,\r\n\tstartDate: null,\r\n\tendDate: null,\r\n\tstartY: null,\r\n\tcurrentY: null,\r\n\tresourceId: undefined,\r\n};\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\nexport function useSlotSelection(options: UseSlotSelectionOptions): UseSlotSelectionReturn {\r\n\tconst {\r\n\t\tdayStart,\r\n\t\tvisibleHours,\r\n\t\thourHeight = DEFAULT_HOUR_HEIGHT,\r\n\t\tslotDuration = 30,\r\n\t\tresourceId,\r\n\t\tenabled = true,\r\n\t\tonSelect,\r\n\t} = options;\r\n\r\n\tconst [selection, setSelection] = useState<ISlotSelection>(INITIAL_SELECTION);\r\n\tconst containerHeightRef = useRef<number>(0);\r\n\r\n\t// ========================================================================\r\n\t// HANDLERS\r\n\t// ========================================================================\r\n\r\n\tconst handlePointerDown = useCallback(\r\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\r\n\t\t\tif (!enabled) return;\r\n\r\n\t\t\tconst y = e.clientY - containerRect.top;\r\n\t\t\tcontainerHeightRef.current = containerRect.height;\r\n\r\n\t\t\tconst startTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\r\n\r\n\t\t\tsetSelection({\r\n\t\t\t\tisSelecting: true,\r\n\t\t\t\tstartDate: startTime,\r\n\t\t\t\tendDate: addMinutes(startTime, slotDuration),\r\n\t\t\t\tstartY: y,\r\n\t\t\t\tcurrentY: y,\r\n\t\t\t\tresourceId,\r\n\t\t\t});\r\n\t\t},\r\n\t\t[enabled, dayStart, visibleHours, hourHeight, slotDuration, resourceId],\r\n\t);\r\n\r\n\tconst handlePointerMove = useCallback(\r\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\r\n\t\t\tif (!selection.isSelecting || !selection.startY) return;\r\n\r\n\t\t\tconst y = Math.max(0, Math.min(e.clientY - containerRect.top, containerRect.height));\r\n\t\t\tconst currentTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\r\n\r\n\t\t\tsetSelection((prev) => {\r\n\t\t\t\tif (!prev.startDate) return prev;\r\n\r\n\t\t\t\t// Determine if dragging up or down\r\n\t\t\t\tconst isDraggingDown = y >= (prev.startY ?? 0);\r\n\r\n\t\t\t\treturn {\r\n\t\t\t\t\t...prev,\r\n\t\t\t\t\tcurrentY: y,\r\n\t\t\t\t\tendDate: isDraggingDown\r\n\t\t\t\t\t\t? addMinutes(currentTime, slotDuration)\r\n\t\t\t\t\t\t: currentTime,\r\n\t\t\t\t\tstartDate: isDraggingDown\r\n\t\t\t\t\t\t? prev.startDate\r\n\t\t\t\t\t\t: currentTime,\r\n\t\t\t\t};\r\n\t\t\t});\r\n\t\t},\r\n\t\t[selection.isSelecting, selection.startY, dayStart, visibleHours, hourHeight, slotDuration],\r\n\t);\r\n\r\n\tconst handlePointerUp = useCallback(() => {\r\n\t\tif (!selection.isSelecting || !selection.startDate || !selection.endDate) {\r\n\t\t\tsetSelection(INITIAL_SELECTION);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Ensure start is before end\r\n\t\tconst start = selection.startDate < selection.endDate\r\n\t\t\t? selection.startDate\r\n\t\t\t: selection.endDate;\r\n\t\tconst end = selection.startDate < selection.endDate\r\n\t\t\t? selection.endDate\r\n\t\t\t: selection.startDate;\r\n\r\n\t\tconst result: ISelectionResult = {\r\n\t\t\tstartDate: start,\r\n\t\t\tendDate: end,\r\n\t\t\tresourceId: selection.resourceId,\r\n\t\t};\r\n\r\n\t\tonSelect?.(result);\r\n\t\tsetSelection(INITIAL_SELECTION);\r\n\t}, [selection, onSelect]);\r\n\r\n\tconst cancel = useCallback(() => {\r\n\t\tsetSelection(INITIAL_SELECTION);\r\n\t}, []);\r\n\r\n\t// ========================================================================\r\n\t// OVERLAY CALCULATION\r\n\t// ========================================================================\r\n\r\n\tconst overlay = (() => {\r\n\t\tif (!selection.isSelecting || selection.startY === null || selection.currentY === null) {\r\n\t\t\treturn { top: 0, height: 0, visible: false };\r\n\t\t}\r\n\r\n\t\tconst minY = Math.min(selection.startY, selection.currentY);\r\n\t\tconst maxY = Math.max(selection.startY, selection.currentY);\r\n\r\n\t\treturn {\r\n\t\t\ttop: minY,\r\n\t\t\theight: Math.max(maxY - minY, 20), // Minimum height\r\n\t\t\tvisible: true,\r\n\t\t};\r\n\t})();\r\n\r\n\t// ========================================================================\r\n\t// RETURN\r\n\t// ========================================================================\r\n\r\n\treturn {\r\n\t\tselection,\r\n\t\toverlay,\r\n\t\thandlePointerDown,\r\n\t\thandlePointerMove,\r\n\t\thandlePointerUp,\r\n\t\tcancel,\r\n\t\tisSelecting: selection.isSelecting,\r\n\t};\r\n}\r\n","/**\r\n * usePreferences - Calendar Preferences Hook\r\n *\r\n * Manages user preferences with optional localStorage persistence.\r\n */\r\n\r\nimport { useState, useCallback, useEffect } from 'react';\r\nimport type { ICalendarPreferences } from '../types';\r\nimport { DEFAULT_PREFERENCES } from '../constants';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UsePreferencesOptions {\r\n\t/** Initial preferences (overrides defaults) */\r\n\tinitial?: Partial<ICalendarPreferences>;\r\n\t/** Storage key for persistence (if provided, uses localStorage) */\r\n\tstorageKey?: string;\r\n\t/** Callback when preferences change */\r\n\tonChange?: (preferences: ICalendarPreferences) => void;\r\n}\r\n\r\nexport interface UsePreferencesReturn {\r\n\t/** Current preferences */\r\n\tpreferences: ICalendarPreferences;\r\n\t/** Update preferences */\r\n\tsetPreferences: (updates: Partial<ICalendarPreferences>) => void;\r\n\t/** Reset to defaults */\r\n\tresetPreferences: () => void;\r\n\t/** Get a specific preference */\r\n\tgetPreference: <K extends keyof ICalendarPreferences>(key: K) => ICalendarPreferences[K];\r\n}\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\nexport function usePreferences(options: UsePreferencesOptions = {}): UsePreferencesReturn {\r\n\tconst { initial = {}, storageKey, onChange } = options;\r\n\r\n\t// Load from storage or use defaults\r\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => {\r\n\t\tif (storageKey && typeof window !== 'undefined') {\r\n\t\t\ttry {\r\n\t\t\t\tconst stored = localStorage.getItem(storageKey);\r\n\t\t\t\tif (stored) {\r\n\t\t\t\t\tconst parsed = JSON.parse(stored) as Partial<ICalendarPreferences>;\r\n\t\t\t\t\treturn { ...DEFAULT_PREFERENCES, ...parsed, ...initial };\r\n\t\t\t\t}\r\n\t\t\t} catch {\r\n\t\t\t\t// Ignore parsing errors\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn { ...DEFAULT_PREFERENCES, ...initial };\r\n\t});\r\n\r\n\t// Persist to storage when preferences change\r\n\tuseEffect(() => {\r\n\t\tif (storageKey && typeof window !== 'undefined') {\r\n\t\t\ttry {\r\n\t\t\t\tlocalStorage.setItem(storageKey, JSON.stringify(preferences));\r\n\t\t\t} catch {\r\n\t\t\t\t// Ignore storage errors\r\n\t\t\t}\r\n\t\t}\r\n\t}, [preferences, storageKey]);\r\n\r\n\tconst setPreferences = useCallback(\r\n\t\t(updates: Partial<ICalendarPreferences>) => {\r\n\t\t\tsetPreferencesState((prev) => {\r\n\t\t\t\tconst next = { ...prev, ...updates };\r\n\t\t\t\tonChange?.(next);\r\n\t\t\t\treturn next;\r\n\t\t\t});\r\n\t\t},\r\n\t\t[onChange],\r\n\t);\r\n\r\n\tconst resetPreferences = useCallback(() => {\r\n\t\tconst defaults = { ...DEFAULT_PREFERENCES, ...initial };\r\n\t\tsetPreferencesState(defaults);\r\n\t\tonChange?.(defaults);\r\n\t}, [initial, onChange]);\r\n\r\n\tconst getPreference = useCallback(\r\n\t\t<K extends keyof ICalendarPreferences>(key: K): ICalendarPreferences[K] => {\r\n\t\t\treturn preferences[key];\r\n\t\t},\r\n\t\t[preferences],\r\n\t);\r\n\r\n\treturn {\r\n\t\tpreferences,\r\n\t\tsetPreferences,\r\n\t\tresetPreferences,\r\n\t\tgetPreference,\r\n\t};\r\n}\r\n","/**\r\n * useCalendarTimeConfig - Time Configuration Hook\r\n *\r\n * Convenience hook that provides access to time-related preferences\r\n * from the calendar context. Matches agenda-v2 naming conventions.\r\n *\r\n * @example\r\n * ```tsx\r\n * function TimeSettings() {\r\n * const {\r\n * visibleHours,\r\n * setVisibleHours,\r\n * workingHours,\r\n * setWorkingHours,\r\n * slotDuration,\r\n * setSlotDuration,\r\n * showWorkingHoursOnly,\r\n * setShowWorkingHoursOnly,\r\n * } = useCalendarTimeConfig();\r\n *\r\n * return (\r\n * <div>\r\n * <p>Visible: {visibleHours.from}:00 - {visibleHours.to}:00</p>\r\n * <p>Slot duration: {slotDuration} minutes</p>\r\n * </div>\r\n * );\r\n * }\r\n * ```\r\n */\r\n\r\nimport { useCallback, useMemo } from 'react';\r\nimport { useCalendarContext } from '../context/calendar-context';\r\nimport type { TSlotDuration } from '../types';\r\nimport type {\r\n\tIVisibleHoursConfig,\r\n\tTWorkingHoursConfig,\r\n} from '../preferences/types';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UseCalendarTimeConfigReturn {\r\n\t/** Current visible hours range */\r\n\tvisibleHours: IVisibleHoursConfig;\r\n\t/** Update visible hours */\r\n\tsetVisibleHours: (hours: IVisibleHoursConfig) => void;\r\n\t/** Current working hours configuration */\r\n\tworkingHours: TWorkingHoursConfig;\r\n\t/** Update working hours */\r\n\tsetWorkingHours: (hours: TWorkingHoursConfig) => void;\r\n\t/** Current slot duration in minutes */\r\n\tslotDuration: TSlotDuration;\r\n\t/** Update slot duration */\r\n\tsetSlotDuration: (duration: TSlotDuration) => void;\r\n\t/** Whether to show only working hours */\r\n\tshowWorkingHoursOnly: boolean;\r\n\t/** Toggle show working hours only */\r\n\tsetShowWorkingHoursOnly: (show: boolean) => void;\r\n}\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\n/**\r\n * Get time configuration from calendar context\r\n *\r\n * Provides a focused subset of calendar preferences related to time display.\r\n * All setters will update the underlying preferences in the calendar context.\r\n *\r\n * Note: This hook maps the core preferences (startHour/endHour) to the\r\n * agenda-v2 naming convention (visibleHours.from/to, workingHours).\r\n */\r\nexport function useCalendarTimeConfig(): UseCalendarTimeConfigReturn {\r\n\tconst { preferences, setPreferences } = useCalendarContext();\r\n\r\n\t// Map core preferences to visible hours format\r\n\tconst visibleHours = useMemo<IVisibleHoursConfig>(\r\n\t\t() => ({\r\n\t\t\tfrom: preferences.startHour,\r\n\t\t\tto: preferences.endHour,\r\n\t\t}),\r\n\t\t[preferences.startHour, preferences.endHour],\r\n\t);\r\n\r\n\t// Default working hours based on visible hours (can be extended later)\r\n\tconst workingHours = useMemo<TWorkingHoursConfig>(\r\n\t\t() => ({\r\n\t\t\t// Default: Mon-Fri same hours\r\n\t\t\t1: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t2: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t3: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t4: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t5: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t}),\r\n\t\t[preferences.startHour, preferences.endHour],\r\n\t);\r\n\r\n\tconst setVisibleHours = useCallback(\r\n\t\t(hours: IVisibleHoursConfig) => {\r\n\t\t\tsetPreferences({\r\n\t\t\t\tstartHour: hours.from,\r\n\t\t\t\tendHour: hours.to,\r\n\t\t\t});\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setWorkingHours = useCallback(\r\n\t\t(_hours: TWorkingHoursConfig) => {\r\n\t\t\t// Working hours per-day config would need to be added to core preferences\r\n\t\t\t// For now, we use the first available day's hours to set visible hours\r\n\t\t\tconst firstDay = Object.values(_hours)[0];\r\n\t\t\tif (firstDay) {\r\n\t\t\t\tsetPreferences({\r\n\t\t\t\t\tstartHour: firstDay.from,\r\n\t\t\t\t\tendHour: firstDay.to,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setSlotDuration = useCallback(\r\n\t\t(duration: TSlotDuration) => {\r\n\t\t\tsetPreferences({ slotDuration: duration });\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setShowWorkingHoursOnly = useCallback(\r\n\t\t(_show: boolean) => {\r\n\t\t\t// This would need to be added to ICalendarPreferences\r\n\t\t\t// For now, this is a no-op but provides the API surface\r\n\t\t\tconsole.warn('showWorkingHoursOnly is not yet supported in core preferences');\r\n\t\t},\r\n\t\t[],\r\n\t);\r\n\r\n\treturn {\r\n\t\tvisibleHours,\r\n\t\tsetVisibleHours,\r\n\t\tworkingHours,\r\n\t\tsetWorkingHours,\r\n\t\tslotDuration: preferences.slotDuration as TSlotDuration,\r\n\t\tsetSlotDuration,\r\n\t\tshowWorkingHoursOnly: false, // Default until added to core preferences\r\n\t\tsetShowWorkingHoursOnly,\r\n\t};\r\n}\r\n"],"names":["INITIAL_SELECTION","useSlotSelection","options","dayStart","visibleHours","hourHeight","DEFAULT_HOUR_HEIGHT","slotDuration","resourceId","enabled","onSelect","selection","setSelection","useState","containerHeightRef","useRef","handlePointerDown","useCallback","e","containerRect","y","startTime","yToTime","addMinutes","handlePointerMove","currentTime","prev","isDraggingDown","handlePointerUp","start","end","result","cancel","overlay","minY","maxY","usePreferences","initial","storageKey","onChange","preferences","setPreferencesState","stored","parsed","DEFAULT_PREFERENCES","useEffect","setPreferences","updates","next","resetPreferences","defaults","getPreference","key","useCalendarTimeConfig","useCalendarContext","useMemo","workingHours","setVisibleHours","hours","setWorkingHours","_hours","firstDay","setSlotDuration","duration","setShowWorkingHoursOnly","_show"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ "use strict";const n=require("react"),d=require("./slot-selection-context-C52lU9W4.cjs"),T=require("./inno-calendar-provider-BwP6uUAq.cjs"),C={isSelecting:!1,startDate:null,endDate:null,startY:null,currentY:null,resourceId:void 0};function P(t){const{dayStart:s,visibleHours:a,hourHeight:u=d.DEFAULT_HOUR_HEIGHT,slotDuration:o=30,resourceId:f,enabled:D=!0,onSelect:H}=t,[e,r]=n.useState(C),S=n.useRef(0),m=n.useCallback((l,c)=>{if(!D)return;const i=l.clientY-c.top;S.current=c.height;const g=d.yToTime(i,s,a,u,o);r({isSelecting:!0,startDate:g,endDate:d.addMinutes(g,o),startY:i,currentY:i,resourceId:f})},[D,s,a,u,o,f]),b=n.useCallback((l,c)=>{if(!e.isSelecting||!e.startY)return;const i=Math.max(0,Math.min(l.clientY-c.top,c.height)),g=d.yToTime(i,s,a,u,o);r(h=>{if(!h.startDate)return h;const E=i>=(h.startY??0);return{...h,currentY:i,endDate:E?d.addMinutes(g,o):g,startDate:E?h.startDate:g}})},[e.isSelecting,e.startY,s,a,u,o]),Y=n.useCallback(()=>{if(!e.isSelecting||!e.startDate||!e.endDate){r(C);return}const l=e.startDate<e.endDate?e.startDate:e.endDate,c=e.startDate<e.endDate?e.endDate:e.startDate,i={startDate:l,endDate:c,resourceId:e.resourceId};H?.(i),r(C)},[e,H]),y=n.useCallback(()=>{r(C)},[]),k=(()=>{if(!e.isSelecting||e.startY===null||e.currentY===null)return{top:0,height:0,visible:!1};const l=Math.min(e.startY,e.currentY),c=Math.max(e.startY,e.currentY);return{top:l,height:Math.max(c-l,20),visible:!0}})();return{selection:e,overlay:k,handlePointerDown:m,handlePointerMove:b,handlePointerUp:Y,cancel:y,isSelecting:e.isSelecting}}function w(t={}){const{initial:s={},storageKey:a,onChange:u}=t,[o,f]=n.useState(()=>{if(a&&typeof window<"u")try{const r=localStorage.getItem(a);if(r){const S=JSON.parse(r);return{...d.DEFAULT_PREFERENCES,...S,...s}}}catch{}return{...d.DEFAULT_PREFERENCES,...s}});n.useEffect(()=>{if(a&&typeof window<"u")try{localStorage.setItem(a,JSON.stringify(o))}catch{}},[o,a]);const D=n.useCallback(r=>{f(S=>{const m={...S,...r};return u?.(m),m})},[u]),H=n.useCallback(()=>{const r={...d.DEFAULT_PREFERENCES,...s};f(r),u?.(r)},[s,u]),e=n.useCallback(r=>o[r],[o]);return{preferences:o,setPreferences:D,resetPreferences:H,getPreference:e}}function I(){const{preferences:t,setPreferences:s}=T.useCalendarContext(),a=n.useMemo(()=>({from:t.startHour,to:t.endHour}),[t.startHour,t.endHour]),u=n.useMemo(()=>({1:{from:t.startHour,to:t.endHour},2:{from:t.startHour,to:t.endHour},3:{from:t.startHour,to:t.endHour},4:{from:t.startHour,to:t.endHour},5:{from:t.startHour,to:t.endHour}}),[t.startHour,t.endHour]),o=n.useCallback(e=>{s({startHour:e.from,endHour:e.to})},[s]),f=n.useCallback(e=>{const r=Object.values(e)[0];r&&s({startHour:r.from,endHour:r.to})},[s]),D=n.useCallback(e=>{s({slotDuration:e})},[s]),H=n.useCallback(e=>{console.warn("showWorkingHoursOnly is not yet supported in core preferences")},[]);return{visibleHours:a,setVisibleHours:o,workingHours:u,setWorkingHours:f,slotDuration:t.slotDuration,setSlotDuration:D,showWorkingHoursOnly:!1,setShowWorkingHoursOnly:H}}exports.useCalendarTimeConfig=I;exports.usePreferences=w;exports.useSlotSelection=P;
2
+ //# sourceMappingURL=use-calendar-time-config-F-8WV_Sd.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-calendar-time-config-F-8WV_Sd.cjs","sources":["../src/core/hooks/use-slot-selection.ts","../src/core/hooks/use-preferences.ts","../src/core/hooks/use-calendar-time-config.ts"],"sourcesContent":["/**\r\n * useSlotSelection - Drag-to-Select Hook\r\n *\r\n * Handles mouse/touch interactions for creating events by\r\n * selecting time slots in the calendar grid.\r\n */\r\n\r\nimport { useState, useCallback, useRef } from 'react';\r\nimport type { ISlotSelection, ISelectionResult, IVisibleHours } from '../types';\r\nimport { addMinutes } from '../utils/date-utils';\r\nimport { yToTime } from '../utils/position-utils';\r\nimport { DEFAULT_HOUR_HEIGHT } from '../constants';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UseSlotSelectionOptions {\r\n\t/** Current day being selected on */\r\n\tdayStart: Date;\r\n\t/** Visible hours configuration */\r\n\tvisibleHours: IVisibleHours;\r\n\t/** Height of one hour in pixels */\r\n\thourHeight?: number;\r\n\t/** Slot duration in minutes for snapping */\r\n\tslotDuration?: number;\r\n\t/** Resource ID (for resource views) */\r\n\tresourceId?: string;\r\n\t/** Whether selection is enabled */\r\n\tenabled?: boolean;\r\n\t/** Callback when selection completes */\r\n\tonSelect?: (selection: ISelectionResult) => void;\r\n}\r\n\r\nexport interface UseSlotSelectionReturn {\r\n\t/** Current selection state */\r\n\tselection: ISlotSelection;\r\n\t/** Selection overlay for rendering */\r\n\toverlay: { top: number; height: number; visible: boolean };\r\n\t/** Handler for mouse/touch down */\r\n\thandlePointerDown: (e: React.PointerEvent, containerRect: DOMRect) => void;\r\n\t/** Handler for mouse/touch move */\r\n\thandlePointerMove: (e: React.PointerEvent, containerRect: DOMRect) => void;\r\n\t/** Handler for mouse/touch up */\r\n\thandlePointerUp: () => void;\r\n\t/** Cancel current selection */\r\n\tcancel: () => void;\r\n\t/** Whether currently selecting */\r\n\tisSelecting: boolean;\r\n}\r\n\r\n// ============================================================================\r\n// INITIAL STATE\r\n// ============================================================================\r\n\r\nconst INITIAL_SELECTION: ISlotSelection = {\r\n\tisSelecting: false,\r\n\tstartDate: null,\r\n\tendDate: null,\r\n\tstartY: null,\r\n\tcurrentY: null,\r\n\tresourceId: undefined,\r\n};\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\nexport function useSlotSelection(options: UseSlotSelectionOptions): UseSlotSelectionReturn {\r\n\tconst {\r\n\t\tdayStart,\r\n\t\tvisibleHours,\r\n\t\thourHeight = DEFAULT_HOUR_HEIGHT,\r\n\t\tslotDuration = 30,\r\n\t\tresourceId,\r\n\t\tenabled = true,\r\n\t\tonSelect,\r\n\t} = options;\r\n\r\n\tconst [selection, setSelection] = useState<ISlotSelection>(INITIAL_SELECTION);\r\n\tconst containerHeightRef = useRef<number>(0);\r\n\r\n\t// ========================================================================\r\n\t// HANDLERS\r\n\t// ========================================================================\r\n\r\n\tconst handlePointerDown = useCallback(\r\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\r\n\t\t\tif (!enabled) return;\r\n\r\n\t\t\tconst y = e.clientY - containerRect.top;\r\n\t\t\tcontainerHeightRef.current = containerRect.height;\r\n\r\n\t\t\tconst startTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\r\n\r\n\t\t\tsetSelection({\r\n\t\t\t\tisSelecting: true,\r\n\t\t\t\tstartDate: startTime,\r\n\t\t\t\tendDate: addMinutes(startTime, slotDuration),\r\n\t\t\t\tstartY: y,\r\n\t\t\t\tcurrentY: y,\r\n\t\t\t\tresourceId,\r\n\t\t\t});\r\n\t\t},\r\n\t\t[enabled, dayStart, visibleHours, hourHeight, slotDuration, resourceId],\r\n\t);\r\n\r\n\tconst handlePointerMove = useCallback(\r\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\r\n\t\t\tif (!selection.isSelecting || !selection.startY) return;\r\n\r\n\t\t\tconst y = Math.max(0, Math.min(e.clientY - containerRect.top, containerRect.height));\r\n\t\t\tconst currentTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\r\n\r\n\t\t\tsetSelection((prev) => {\r\n\t\t\t\tif (!prev.startDate) return prev;\r\n\r\n\t\t\t\t// Determine if dragging up or down\r\n\t\t\t\tconst isDraggingDown = y >= (prev.startY ?? 0);\r\n\r\n\t\t\t\treturn {\r\n\t\t\t\t\t...prev,\r\n\t\t\t\t\tcurrentY: y,\r\n\t\t\t\t\tendDate: isDraggingDown\r\n\t\t\t\t\t\t? addMinutes(currentTime, slotDuration)\r\n\t\t\t\t\t\t: currentTime,\r\n\t\t\t\t\tstartDate: isDraggingDown\r\n\t\t\t\t\t\t? prev.startDate\r\n\t\t\t\t\t\t: currentTime,\r\n\t\t\t\t};\r\n\t\t\t});\r\n\t\t},\r\n\t\t[selection.isSelecting, selection.startY, dayStart, visibleHours, hourHeight, slotDuration],\r\n\t);\r\n\r\n\tconst handlePointerUp = useCallback(() => {\r\n\t\tif (!selection.isSelecting || !selection.startDate || !selection.endDate) {\r\n\t\t\tsetSelection(INITIAL_SELECTION);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// Ensure start is before end\r\n\t\tconst start = selection.startDate < selection.endDate\r\n\t\t\t? selection.startDate\r\n\t\t\t: selection.endDate;\r\n\t\tconst end = selection.startDate < selection.endDate\r\n\t\t\t? selection.endDate\r\n\t\t\t: selection.startDate;\r\n\r\n\t\tconst result: ISelectionResult = {\r\n\t\t\tstartDate: start,\r\n\t\t\tendDate: end,\r\n\t\t\tresourceId: selection.resourceId,\r\n\t\t};\r\n\r\n\t\tonSelect?.(result);\r\n\t\tsetSelection(INITIAL_SELECTION);\r\n\t}, [selection, onSelect]);\r\n\r\n\tconst cancel = useCallback(() => {\r\n\t\tsetSelection(INITIAL_SELECTION);\r\n\t}, []);\r\n\r\n\t// ========================================================================\r\n\t// OVERLAY CALCULATION\r\n\t// ========================================================================\r\n\r\n\tconst overlay = (() => {\r\n\t\tif (!selection.isSelecting || selection.startY === null || selection.currentY === null) {\r\n\t\t\treturn { top: 0, height: 0, visible: false };\r\n\t\t}\r\n\r\n\t\tconst minY = Math.min(selection.startY, selection.currentY);\r\n\t\tconst maxY = Math.max(selection.startY, selection.currentY);\r\n\r\n\t\treturn {\r\n\t\t\ttop: minY,\r\n\t\t\theight: Math.max(maxY - minY, 20), // Minimum height\r\n\t\t\tvisible: true,\r\n\t\t};\r\n\t})();\r\n\r\n\t// ========================================================================\r\n\t// RETURN\r\n\t// ========================================================================\r\n\r\n\treturn {\r\n\t\tselection,\r\n\t\toverlay,\r\n\t\thandlePointerDown,\r\n\t\thandlePointerMove,\r\n\t\thandlePointerUp,\r\n\t\tcancel,\r\n\t\tisSelecting: selection.isSelecting,\r\n\t};\r\n}\r\n","/**\r\n * usePreferences - Calendar Preferences Hook\r\n *\r\n * Manages user preferences with optional localStorage persistence.\r\n */\r\n\r\nimport { useState, useCallback, useEffect } from 'react';\r\nimport type { ICalendarPreferences } from '../types';\r\nimport { DEFAULT_PREFERENCES } from '../constants';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UsePreferencesOptions {\r\n\t/** Initial preferences (overrides defaults) */\r\n\tinitial?: Partial<ICalendarPreferences>;\r\n\t/** Storage key for persistence (if provided, uses localStorage) */\r\n\tstorageKey?: string;\r\n\t/** Callback when preferences change */\r\n\tonChange?: (preferences: ICalendarPreferences) => void;\r\n}\r\n\r\nexport interface UsePreferencesReturn {\r\n\t/** Current preferences */\r\n\tpreferences: ICalendarPreferences;\r\n\t/** Update preferences */\r\n\tsetPreferences: (updates: Partial<ICalendarPreferences>) => void;\r\n\t/** Reset to defaults */\r\n\tresetPreferences: () => void;\r\n\t/** Get a specific preference */\r\n\tgetPreference: <K extends keyof ICalendarPreferences>(key: K) => ICalendarPreferences[K];\r\n}\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\nexport function usePreferences(options: UsePreferencesOptions = {}): UsePreferencesReturn {\r\n\tconst { initial = {}, storageKey, onChange } = options;\r\n\r\n\t// Load from storage or use defaults\r\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => {\r\n\t\tif (storageKey && typeof window !== 'undefined') {\r\n\t\t\ttry {\r\n\t\t\t\tconst stored = localStorage.getItem(storageKey);\r\n\t\t\t\tif (stored) {\r\n\t\t\t\t\tconst parsed = JSON.parse(stored) as Partial<ICalendarPreferences>;\r\n\t\t\t\t\treturn { ...DEFAULT_PREFERENCES, ...parsed, ...initial };\r\n\t\t\t\t}\r\n\t\t\t} catch {\r\n\t\t\t\t// Ignore parsing errors\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn { ...DEFAULT_PREFERENCES, ...initial };\r\n\t});\r\n\r\n\t// Persist to storage when preferences change\r\n\tuseEffect(() => {\r\n\t\tif (storageKey && typeof window !== 'undefined') {\r\n\t\t\ttry {\r\n\t\t\t\tlocalStorage.setItem(storageKey, JSON.stringify(preferences));\r\n\t\t\t} catch {\r\n\t\t\t\t// Ignore storage errors\r\n\t\t\t}\r\n\t\t}\r\n\t}, [preferences, storageKey]);\r\n\r\n\tconst setPreferences = useCallback(\r\n\t\t(updates: Partial<ICalendarPreferences>) => {\r\n\t\t\tsetPreferencesState((prev) => {\r\n\t\t\t\tconst next = { ...prev, ...updates };\r\n\t\t\t\tonChange?.(next);\r\n\t\t\t\treturn next;\r\n\t\t\t});\r\n\t\t},\r\n\t\t[onChange],\r\n\t);\r\n\r\n\tconst resetPreferences = useCallback(() => {\r\n\t\tconst defaults = { ...DEFAULT_PREFERENCES, ...initial };\r\n\t\tsetPreferencesState(defaults);\r\n\t\tonChange?.(defaults);\r\n\t}, [initial, onChange]);\r\n\r\n\tconst getPreference = useCallback(\r\n\t\t<K extends keyof ICalendarPreferences>(key: K): ICalendarPreferences[K] => {\r\n\t\t\treturn preferences[key];\r\n\t\t},\r\n\t\t[preferences],\r\n\t);\r\n\r\n\treturn {\r\n\t\tpreferences,\r\n\t\tsetPreferences,\r\n\t\tresetPreferences,\r\n\t\tgetPreference,\r\n\t};\r\n}\r\n","/**\r\n * useCalendarTimeConfig - Time Configuration Hook\r\n *\r\n * Convenience hook that provides access to time-related preferences\r\n * from the calendar context. Matches agenda-v2 naming conventions.\r\n *\r\n * @example\r\n * ```tsx\r\n * function TimeSettings() {\r\n * const {\r\n * visibleHours,\r\n * setVisibleHours,\r\n * workingHours,\r\n * setWorkingHours,\r\n * slotDuration,\r\n * setSlotDuration,\r\n * showWorkingHoursOnly,\r\n * setShowWorkingHoursOnly,\r\n * } = useCalendarTimeConfig();\r\n *\r\n * return (\r\n * <div>\r\n * <p>Visible: {visibleHours.from}:00 - {visibleHours.to}:00</p>\r\n * <p>Slot duration: {slotDuration} minutes</p>\r\n * </div>\r\n * );\r\n * }\r\n * ```\r\n */\r\n\r\nimport { useCallback, useMemo } from 'react';\r\nimport { useCalendarContext } from '../context/calendar-context';\r\nimport type { TSlotDuration } from '../types';\r\nimport type {\r\n\tIVisibleHoursConfig,\r\n\tTWorkingHoursConfig,\r\n} from '../preferences/types';\r\n\r\n// ============================================================================\r\n// TYPES\r\n// ============================================================================\r\n\r\nexport interface UseCalendarTimeConfigReturn {\r\n\t/** Current visible hours range */\r\n\tvisibleHours: IVisibleHoursConfig;\r\n\t/** Update visible hours */\r\n\tsetVisibleHours: (hours: IVisibleHoursConfig) => void;\r\n\t/** Current working hours configuration */\r\n\tworkingHours: TWorkingHoursConfig;\r\n\t/** Update working hours */\r\n\tsetWorkingHours: (hours: TWorkingHoursConfig) => void;\r\n\t/** Current slot duration in minutes */\r\n\tslotDuration: TSlotDuration;\r\n\t/** Update slot duration */\r\n\tsetSlotDuration: (duration: TSlotDuration) => void;\r\n\t/** Whether to show only working hours */\r\n\tshowWorkingHoursOnly: boolean;\r\n\t/** Toggle show working hours only */\r\n\tsetShowWorkingHoursOnly: (show: boolean) => void;\r\n}\r\n\r\n// ============================================================================\r\n// HOOK\r\n// ============================================================================\r\n\r\n/**\r\n * Get time configuration from calendar context\r\n *\r\n * Provides a focused subset of calendar preferences related to time display.\r\n * All setters will update the underlying preferences in the calendar context.\r\n *\r\n * Note: This hook maps the core preferences (startHour/endHour) to the\r\n * agenda-v2 naming convention (visibleHours.from/to, workingHours).\r\n */\r\nexport function useCalendarTimeConfig(): UseCalendarTimeConfigReturn {\r\n\tconst { preferences, setPreferences } = useCalendarContext();\r\n\r\n\t// Map core preferences to visible hours format\r\n\tconst visibleHours = useMemo<IVisibleHoursConfig>(\r\n\t\t() => ({\r\n\t\t\tfrom: preferences.startHour,\r\n\t\t\tto: preferences.endHour,\r\n\t\t}),\r\n\t\t[preferences.startHour, preferences.endHour],\r\n\t);\r\n\r\n\t// Default working hours based on visible hours (can be extended later)\r\n\tconst workingHours = useMemo<TWorkingHoursConfig>(\r\n\t\t() => ({\r\n\t\t\t// Default: Mon-Fri same hours\r\n\t\t\t1: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t2: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t3: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t4: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t\t5: { from: preferences.startHour, to: preferences.endHour },\r\n\t\t}),\r\n\t\t[preferences.startHour, preferences.endHour],\r\n\t);\r\n\r\n\tconst setVisibleHours = useCallback(\r\n\t\t(hours: IVisibleHoursConfig) => {\r\n\t\t\tsetPreferences({\r\n\t\t\t\tstartHour: hours.from,\r\n\t\t\t\tendHour: hours.to,\r\n\t\t\t});\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setWorkingHours = useCallback(\r\n\t\t(_hours: TWorkingHoursConfig) => {\r\n\t\t\t// Working hours per-day config would need to be added to core preferences\r\n\t\t\t// For now, we use the first available day's hours to set visible hours\r\n\t\t\tconst firstDay = Object.values(_hours)[0];\r\n\t\t\tif (firstDay) {\r\n\t\t\t\tsetPreferences({\r\n\t\t\t\t\tstartHour: firstDay.from,\r\n\t\t\t\t\tendHour: firstDay.to,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setSlotDuration = useCallback(\r\n\t\t(duration: TSlotDuration) => {\r\n\t\t\tsetPreferences({ slotDuration: duration });\r\n\t\t},\r\n\t\t[setPreferences],\r\n\t);\r\n\r\n\tconst setShowWorkingHoursOnly = useCallback(\r\n\t\t(_show: boolean) => {\r\n\t\t\t// This would need to be added to ICalendarPreferences\r\n\t\t\t// For now, this is a no-op but provides the API surface\r\n\t\t\tconsole.warn('showWorkingHoursOnly is not yet supported in core preferences');\r\n\t\t},\r\n\t\t[],\r\n\t);\r\n\r\n\treturn {\r\n\t\tvisibleHours,\r\n\t\tsetVisibleHours,\r\n\t\tworkingHours,\r\n\t\tsetWorkingHours,\r\n\t\tslotDuration: preferences.slotDuration as TSlotDuration,\r\n\t\tsetSlotDuration,\r\n\t\tshowWorkingHoursOnly: false, // Default until added to core preferences\r\n\t\tsetShowWorkingHoursOnly,\r\n\t};\r\n}\r\n"],"names":["INITIAL_SELECTION","useSlotSelection","options","dayStart","visibleHours","hourHeight","DEFAULT_HOUR_HEIGHT","slotDuration","resourceId","enabled","onSelect","selection","setSelection","useState","containerHeightRef","useRef","handlePointerDown","useCallback","e","containerRect","y","startTime","yToTime","addMinutes","handlePointerMove","currentTime","prev","isDraggingDown","handlePointerUp","start","end","result","cancel","overlay","minY","maxY","usePreferences","initial","storageKey","onChange","preferences","setPreferencesState","stored","parsed","DEFAULT_PREFERENCES","useEffect","setPreferences","updates","next","resetPreferences","defaults","getPreference","key","useCalendarTimeConfig","useCalendarContext","useMemo","workingHours","setVisibleHours","hours","setWorkingHours","_hours","firstDay","setSlotDuration","duration","setShowWorkingHoursOnly","_show"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,128 @@
1
+ {
2
+ "name": "@innosolutions/inno-calendar",
3
+ "version": "1.0.0",
4
+ "description": "A headless-first, fully customizable React calendar for enterprise applications",
5
+ "license": "MIT",
6
+ "type": "module",
7
+ "main": "./dist/index.cjs",
8
+ "module": "./dist/index.mjs",
9
+ "types": "./dist/index.d.ts",
10
+ "sideEffects": [
11
+ "**/*.css"
12
+ ],
13
+ "exports": {
14
+ ".": {
15
+ "types": "./dist/index.d.ts",
16
+ "import": "./dist/index.mjs",
17
+ "require": "./dist/index.cjs"
18
+ },
19
+ "./core": {
20
+ "types": "./dist/core/index.d.ts",
21
+ "import": "./dist/core/index.mjs",
22
+ "require": "./dist/core/index.cjs"
23
+ },
24
+ "./components": {
25
+ "types": "./dist/components/index.d.ts",
26
+ "import": "./dist/components/index.mjs",
27
+ "require": "./dist/components/index.cjs"
28
+ },
29
+ "./presets": {
30
+ "types": "./dist/presets/index.d.ts",
31
+ "import": "./dist/presets/index.mjs",
32
+ "require": "./dist/presets/index.cjs"
33
+ },
34
+ "./lib": {
35
+ "types": "./dist/lib/index.d.ts",
36
+ "import": "./dist/lib/index.mjs",
37
+ "require": "./dist/lib/index.cjs"
38
+ }
39
+ },
40
+ "files": [
41
+ "dist",
42
+ "README.md",
43
+ "LICENSE"
44
+ ],
45
+ "scripts": {
46
+ "dev": "vite",
47
+ "build": "vite build",
48
+ "typecheck": "tsc --noEmit",
49
+ "lint": "biome check src",
50
+ "format": "biome format --write src",
51
+ "prepublishOnly": "npm run build"
52
+ },
53
+ "peerDependencies": {
54
+ "react": ">=18.0.0",
55
+ "react-dom": ">=18.0.0"
56
+ },
57
+ "peerDependenciesMeta": {
58
+ "tailwindcss": {
59
+ "optional": true
60
+ },
61
+ "@radix-ui/react-popover": {
62
+ "optional": true
63
+ },
64
+ "@radix-ui/react-dropdown-menu": {
65
+ "optional": true
66
+ },
67
+ "@radix-ui/react-tooltip": {
68
+ "optional": true
69
+ },
70
+ "@radix-ui/react-dialog": {
71
+ "optional": true
72
+ },
73
+ "@radix-ui/react-scroll-area": {
74
+ "optional": true
75
+ },
76
+ "@radix-ui/react-select": {
77
+ "optional": true
78
+ },
79
+ "@radix-ui/react-avatar": {
80
+ "optional": true
81
+ }
82
+ },
83
+ "dependencies": {
84
+ "class-variance-authority": "^0.7.1",
85
+ "clsx": "^2.1.1",
86
+ "tailwind-merge": "^3.0.2"
87
+ },
88
+ "devDependencies": {
89
+ "@biomejs/biome": "^2.2.5",
90
+ "@radix-ui/react-dropdown-menu": "^2.1.16",
91
+ "@radix-ui/react-popover": "^1.1.15",
92
+ "@radix-ui/react-tooltip": "^1.2.8",
93
+ "@types/react": "^19.0.0",
94
+ "@types/react-dom": "^19.0.0",
95
+ "@vitejs/plugin-react": "^4.3.4",
96
+ "lucide-react": "^0.563.0",
97
+ "react": "^19.0.0",
98
+ "react-dom": "^19.0.0",
99
+ "tailwindcss": "^4.0.15",
100
+ "typescript": "^5.9.3",
101
+ "vite": "^7.1.9",
102
+ "vite-plugin-dts": "^4.5.0"
103
+ },
104
+ "keywords": [
105
+ "react",
106
+ "calendar",
107
+ "scheduler",
108
+ "headless",
109
+ "tailwindcss",
110
+ "agenda",
111
+ "timeline",
112
+ "enterprise",
113
+ "customizable",
114
+ "shadcn"
115
+ ],
116
+ "repository": {
117
+ "type": "git",
118
+ "url": "https://github.com/innosolutions/inno-calendar.git"
119
+ },
120
+ "bugs": {
121
+ "url": "https://github.com/innosolutions/inno-calendar/issues"
122
+ },
123
+ "homepage": "https://github.com/innosolutions/inno-calendar#readme",
124
+ "author": "InnoSolutions",
125
+ "publishConfig": {
126
+ "access": "public"
127
+ }
128
+ }