@innosolutions/inno-calendar 1.0.48 → 1.0.49
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/agenda-widget-B-AVTnqM.cjs +2 -0
- package/dist/agenda-widget-B-AVTnqM.cjs.map +1 -0
- package/dist/{agenda-widget-DzXBzBfm.js → agenda-widget-DhCPt2vI.js} +941 -929
- package/dist/agenda-widget-DhCPt2vI.js.map +1 -0
- package/dist/components/event/event-card.d.ts.map +1 -1
- package/dist/components/index.cjs +1 -1
- package/dist/components/index.mjs +2 -2
- package/dist/components/inno-calendar.d.ts +11 -0
- package/dist/components/inno-calendar.d.ts.map +1 -1
- package/dist/core/context/inno-calendar-provider.d.ts +15 -1
- package/dist/core/context/inno-calendar-provider.d.ts.map +1 -1
- package/dist/core/index.cjs +1 -1
- package/dist/core/index.mjs +43 -43
- package/dist/core/types.d.ts +12 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.mjs +62 -62
- package/dist/presets/index.cjs +1 -1
- package/dist/presets/index.mjs +1 -1
- package/dist/slot-selection-context-BCsC7WT7.cjs +2 -0
- package/dist/slot-selection-context-BCsC7WT7.cjs.map +1 -0
- package/dist/slot-selection-context-D1495hEJ.js +595 -0
- package/dist/slot-selection-context-D1495hEJ.js.map +1 -0
- package/dist/{tailwind-calendar-Ba5BO9tj.js → tailwind-calendar-BmJa4HhQ.js} +2 -2
- package/dist/{tailwind-calendar-Ba5BO9tj.js.map → tailwind-calendar-BmJa4HhQ.js.map} +1 -1
- package/dist/{tailwind-calendar-4FkVdxbr.cjs → tailwind-calendar-CJmOutn1.cjs} +2 -2
- package/dist/{tailwind-calendar-4FkVdxbr.cjs.map → tailwind-calendar-CJmOutn1.cjs.map} +1 -1
- package/dist/use-calendar-BEuelmSu.cjs +2 -0
- package/dist/use-calendar-BEuelmSu.cjs.map +1 -0
- package/dist/use-calendar-Clo9DFK4.js +175 -0
- package/dist/use-calendar-Clo9DFK4.js.map +1 -0
- package/dist/{use-slot-selection-BJHlyfxL.js → use-slot-selection-BCZKnZSM.js} +2 -2
- package/dist/{use-slot-selection-BJHlyfxL.js.map → use-slot-selection-BCZKnZSM.js.map} +1 -1
- package/dist/{use-slot-selection-CTFC2-xS.cjs → use-slot-selection-Bwqwjiaq.cjs} +2 -2
- package/dist/{use-slot-selection-CTFC2-xS.cjs.map → use-slot-selection-Bwqwjiaq.cjs.map} +1 -1
- package/dist/week-view-D19YRBQC.cjs +11 -0
- package/dist/week-view-D19YRBQC.cjs.map +1 -0
- package/dist/{week-view-CVbu7Qh2.js → week-view-aRPB2cjn.js} +934 -916
- package/dist/week-view-aRPB2cjn.js.map +1 -0
- package/package.json +1 -1
- package/dist/agenda-widget-D_DbVHjB.cjs +0 -2
- package/dist/agenda-widget-D_DbVHjB.cjs.map +0 -1
- package/dist/agenda-widget-DzXBzBfm.js.map +0 -1
- package/dist/slot-selection-context-Bx3FKJfR.cjs +0 -2
- package/dist/slot-selection-context-Bx3FKJfR.cjs.map +0 -1
- package/dist/slot-selection-context-D2eu2o-7.js +0 -203
- package/dist/slot-selection-context-D2eu2o-7.js.map +0 -1
- package/dist/use-calendar-DR2emWYC.js +0 -555
- package/dist/use-calendar-DR2emWYC.js.map +0 -1
- package/dist/use-calendar-DR89bZu5.cjs +0 -2
- package/dist/use-calendar-DR89bZu5.cjs.map +0 -1
- package/dist/week-view-7r6Vhahg.cjs +0 -11
- package/dist/week-view-7r6Vhahg.cjs.map +0 -1
- package/dist/week-view-CVbu7Qh2.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tailwind-calendar-4FkVdxbr.cjs","sources":["../src/presets/default/default-calendar.tsx","../src/presets/tailwind/tailwind-calendar.tsx"],"sourcesContent":["/**\n * DefaultCalendar - Pre-styled Calendar Preset\n *\n * A fully styled calendar using CSS custom properties for theming.\n * Designed for projects that don't use TailwindCSS but want a complete solution.\n *\n * CSS Custom Properties (override these for theming):\n * - --ic-bg: Background color\n * - --ic-bg-muted: Muted background\n * - --ic-text: Primary text color\n * - --ic-text-muted: Secondary text color\n * - --ic-border: Border color\n * - --ic-primary: Primary/accent color\n * - --ic-primary-foreground: Text on primary background\n * - --ic-radius: Border radius\n *\n * @example\n * ```tsx\n * import { DefaultCalendar } from '@inno/calendar/presets';\n *\n * function MyAgenda() {\n * return (\n * <div style={{ '--ic-primary': '#6366f1' }}>\n * <DefaultCalendar\n * events={myEvents}\n * onEventClick={(event) => console.log('Clicked:', event)}\n * />\n * </div>\n * );\n * }\n * ```\n */\n\nimport { type CSSProperties, type ReactNode, useCallback, useMemo, useState } from 'react';\nimport { CalendarHeader } from '../../components/header/calendar-header';\nimport { AgendaView } from '../../components/views/agenda-view';\nimport { DayView } from '../../components/views/day-view';\nimport { MonthView } from '../../components/views/month-view';\nimport { WeekView } from '../../components/views/week-view';\nimport { DEFAULT_PREFERENCES } from '../../core/constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTBadgeVariant,\n\tTCalendarView,\n} from '../../core/types';\nimport { navigateNext, navigatePrev, navigateToday } from '../../core/utils/grid-utils';\n\n// ============================================================================\n// STYLES (CSS-in-JS for zero-config usage)\n// ============================================================================\n\nconst baseStyles: CSSProperties = {\n\tdisplay: 'flex',\n\tflexDirection: 'column',\n\theight: '100%',\n\tminHeight: '400px',\n\tbackgroundColor: 'var(--ic-bg, #ffffff)',\n\tborder: '1px solid var(--ic-border, #e5e7eb)',\n\tborderRadius: 'var(--ic-radius, 0.5rem)',\n\toverflow: 'hidden',\n\tfontFamily:\n\t\t'var(--ic-font-family, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif)',\n\tfontSize: 'var(--ic-font-size, 0.875rem)',\n\tcolor: 'var(--ic-text, #111827)',\n};\n\nconst headerStyles: CSSProperties = {\n\tborderBottom: '1px solid var(--ic-border, #e5e7eb)',\n};\n\nconst contentStyles: CSSProperties = {\n\tflex: 1,\n\toverflow: 'auto',\n};\n\nconst fallbackViewStyles: CSSProperties = {\n\tdisplay: 'flex',\n\talignItems: 'center',\n\tjustifyContent: 'center',\n\theight: '16rem',\n\tcolor: 'var(--ic-text-muted, #6b7280)',\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface DefaultCalendarProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\t/** Available resources */\n\tresources?: IResource<TResourceData>[];\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[];\n\t/** Initial view */\n\tinitialView?: TCalendarView;\n\t/** Initial date */\n\tinitialDate?: Date;\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters;\n\t/** Preferences */\n\tpreferences?: Partial<ICalendarPreferences>;\n\t/** Badge variant for events (dot, colored, mixed) */\n\tbadgeVariant?: TBadgeVariant;\n\t/** Hide the header */\n\thideHeader?: boolean;\n\t/** Available views to show in view switcher */\n\tavailableViews?: TCalendarView[];\n\t/** Event click handler */\n\tonEventClick?: (event: CalendarEvent<TEventData>) => void;\n\t/** Slot selection handler */\n\tonSlotSelect?: (selection: ISelectionResult) => void;\n\t/** View change handler */\n\tonViewChange?: (view: TCalendarView) => void;\n\t/** Date change handler */\n\tonDateChange?: (date: Date) => void;\n\t/** Additional CSS class */\n\tclassName?: string;\n\t/** Custom style overrides */\n\tstyle?: CSSProperties;\n\t/** Custom header actions */\n\theaderActions?: ReactNode;\n\t/** Empty state for agenda view */\n\temptyState?: ReactNode;\n\t/** Children (for header slot) */\n\tchildren?: ReactNode;\n}\n\n// ============================================================================\n// COMPONENT\n// ============================================================================\n\nexport function DefaultCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({\n\tevents,\n\tresources: _resources,\n\tscheduleTypes: _scheduleTypes,\n\tinitialView = 'week',\n\tinitialDate,\n\tinitialFilters: _initialFilters,\n\tpreferences: userPreferences,\n\tbadgeVariant = 'colored',\n\thideHeader = false,\n\tavailableViews = ['day', 'week', 'month', 'agenda'],\n\tonEventClick,\n\tonSlotSelect,\n\tonViewChange,\n\tonDateChange,\n\tclassName = '',\n\tstyle,\n\theaderActions,\n\temptyState,\n\tchildren: _children,\n}: DefaultCalendarProps<TEventData, TScheduleTypeData, TResourceData>) {\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setView] = useState<TCalendarView>(initialView);\n\tconst [date, setDate] = useState<Date>(initialDate ?? new Date());\n\n\t// Merge user preferences with defaults\n\tconst preferences: ICalendarPreferences = useMemo(\n\t\t() => ({\n\t\t\t...DEFAULT_PREFERENCES,\n\t\t\t...userPreferences,\n\t\t}),\n\t\t[userPreferences]\n\t);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handleViewChange = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetView(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst handleDateChange = useCallback(\n\t\t(newDate: Date) => {\n\t\t\tsetDate(newDate);\n\t\t\tonDateChange?.(newDate);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst handleNavigatePrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateNext = useCallback(() => {\n\t\tconst newDate = navigateNext(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateToday = useCallback(() => {\n\t\tconst newDate = navigateToday();\n\t\thandleDateChange(newDate);\n\t}, [handleDateChange]);\n\n\tconst handleDayClick = useCallback(\n\t\t(clickedDate: Date) => {\n\t\t\t// Navigate to day view when clicking a day in month view\n\t\t\thandleDateChange(clickedDate);\n\t\t\thandleViewChange('day');\n\t\t},\n\t\t[handleDateChange, handleViewChange]\n\t);\n\n\t// ========================================================================\n\t// VIEW RENDERING\n\t// ========================================================================\n\n\t// Build visible hours from preferences\n\tconst visibleHours = useMemo(\n\t\t() => ({\n\t\t\tstartHour: preferences.startHour,\n\t\t\tendHour: preferences.endHour,\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\t// Week starts on (convert from 0-6 to 0 | 1)\n\tconst weekStartsOn: 0 | 1 = preferences.firstDayOfWeek === 0 ? 0 : 1;\n\n\tconst renderView = () => {\n\t\tswitch (view) {\n\t\t\tcase 'day':\n\t\t\t\treturn (\n\t\t\t\t\t<DayView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'week':\n\t\t\t\treturn (\n\t\t\t\t\t<WeekView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'month':\n\t\t\t\treturn (\n\t\t\t\t\t<MonthView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'agenda':\n\t\t\t\treturn (\n\t\t\t\t\t<AgendaView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(emptyState && { emptyState })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tdefault:\n\t\t\t\treturn <div style={fallbackViewStyles}>View "{view}" is not yet implemented</div>;\n\t\t}\n\t};\n\n\t// ========================================================================\n\t// RENDER\n\t// ========================================================================\n\n\treturn (\n\t\t<div className={className} style={{ ...baseStyles, ...style }}>\n\t\t\t{/* Header */}\n\t\t\t{!hideHeader && (\n\t\t\t\t<div style={headerStyles}>\n\t\t\t\t\t<CalendarHeader\n\t\t\t\t\t\tview={view}\n\t\t\t\t\t\tcurrentDate={date}\n\t\t\t\t\t\tavailableViews={availableViews}\n\t\t\t\t\t\tonViewChange={handleViewChange}\n\t\t\t\t\t\tonNavigate={(direction) => {\n\t\t\t\t\t\t\tif (direction === 'prev') handleNavigatePrev();\n\t\t\t\t\t\t\telse if (direction === 'next') handleNavigateNext();\n\t\t\t\t\t\t\telse handleNavigateToday();\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tactions={headerActions}\n\t\t\t\t\t\tclassName=\"p-3\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Calendar View */}\n\t\t\t<div style={contentStyles}>{renderView()}</div>\n\t\t</div>\n\t);\n}\n","/**\n * TailwindCalendar - Tailwind-Optimized Calendar Preset\n *\n * A fully featured, ready-to-use calendar component designed for TailwindCSS projects.\n * Composes all calendar components into a cohesive experience.\n *\n * Features:\n * - Full customization via render props (renderEvent, renderEventPopover, renderFilterSidebar)\n * - All visual components can be replaced while keeping state management\n * - Matches production quality when used with custom components\n *\n * @example\n * ```tsx\n * import { TailwindCalendar } from '@inno/calendar/presets';\n *\n * function MyAgenda() {\n * return (\n * <TailwindCalendar\n * events={myEvents}\n * onEventClick={(event) => console.log('Clicked:', event)}\n * onSlotSelect={(selection) => console.log('Selected:', selection)}\n * // Custom components for production quality\n * renderEvent={(event) => <MyEventCard event={event} />}\n * renderEventPopover={(event, onClose) => <MyEventPopover event={event} onClose={onClose} />}\n * renderFilterSidebar={(props) => <MyFilterSidebar {...props} />}\n * />\n * );\n * }\n * ```\n */\n\nimport { type ReactNode, useCallback, useMemo, useState } from 'react';\nimport { CalendarHeader } from '../../components/header/calendar-header';\nimport { AgendaView } from '../../components/views/agenda-view';\nimport { DayView } from '../../components/views/day-view';\nimport { MonthView } from '../../components/views/month-view';\nimport { WeekView } from '../../components/views/week-view';\nimport { DEFAULT_PREFERENCES } from '../../core/constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIEventPosition,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTBadgeVariant,\n\tTCalendarView,\n} from '../../core/types';\nimport { navigateNext, navigatePrev, navigateToday } from '../../core/utils/grid-utils';\nimport { cn } from '../../lib/utils';\n\n// ============================================================================\n// RENDER PROP TYPES\n// ============================================================================\n\n/**\n * Props for custom event rendering\n */\nexport interface RenderEventProps<TEventData = Record<string, unknown>> {\n\tevent: CalendarEvent<TEventData>;\n\tview: TCalendarView;\n\tvariant: 'full' | 'compact' | 'dot' | 'block';\n\tposition?: IEventPosition;\n\tbadgeVariant: TBadgeVariant;\n\tonClick?: () => void;\n}\n\n/**\n * Props for custom event popover rendering\n */\nexport interface RenderEventPopoverProps<TEventData = Record<string, unknown>> {\n\tevent: CalendarEvent<TEventData>;\n\tonClose: () => void;\n}\n\n/**\n * Props for custom filter sidebar rendering\n */\nexport interface RenderFilterSidebarProps<TScheduleTypeData = Record<string, unknown>> {\n\tscheduleTypes: IScheduleType<TScheduleTypeData>[];\n\tselectedScheduleTypeIds: number[];\n\tonScheduleTypeChange: (ids: number[]) => void;\n\tselectedParticipantIds: string[];\n\tonParticipantChange: (ids: string[]) => void;\n\tonClearAll?: () => void;\n}\n\n/**\n * Props for custom header rendering\n */\nexport interface RenderHeaderProps {\n\tview: TCalendarView;\n\tcurrentDate: Date;\n\tavailableViews: TCalendarView[];\n\tonViewChange: (view: TCalendarView) => void;\n\tonNavigate: (direction: 'prev' | 'next' | 'today') => void;\n\tonNavigatePrev?: () => void;\n\tonNavigateNext?: () => void;\n\tonNavigateToday?: () => void;\n\tonAddEvent?: () => void;\n\tactions?: ReactNode;\n\tclassName?: string;\n}\n\n// ============================================================================\n// COMPONENT PROPS\n// ============================================================================\n\nexport interface TailwindCalendarProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\t/** Available resources */\n\tresources?: IResource<TResourceData>[];\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[];\n\t/** Initial view */\n\tinitialView?: TCalendarView;\n\t/** Initial date */\n\tinitialDate?: Date;\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters;\n\t/** Preferences */\n\tpreferences?: Partial<ICalendarPreferences>;\n\t/** Badge variant for events (dot, colored, mixed) */\n\tbadgeVariant?: TBadgeVariant;\n\t/** Hide the header */\n\thideHeader?: boolean;\n\t/** Show filter sidebar */\n\tshowFilterSidebar?: boolean;\n\t/** Available views to show in view switcher */\n\tavailableViews?: TCalendarView[];\n\n\t// ========================================================================\n\t// CALLBACKS\n\t// ========================================================================\n\n\t/** Event click handler */\n\tonEventClick?: (event: CalendarEvent<TEventData>) => void;\n\t/** Slot selection handler */\n\tonSlotSelect?: (selection: ISelectionResult) => void;\n\t/** View change handler */\n\tonViewChange?: (view: TCalendarView) => void;\n\t/** Date change handler */\n\tonDateChange?: (date: Date) => void;\n\t/** Add event handler (for header button) */\n\tonAddEvent?: () => void;\n\t/** Filter change handler */\n\tonFiltersChange?: (filters: ICalendarFilters) => void;\n\n\t// ========================================================================\n\t// RENDER PROPS (for custom components)\n\t// ========================================================================\n\n\t/**\n\t * Custom event renderer\n\t * Use this to inject your own EventCard component\n\t */\n\trenderEvent?: (props: RenderEventProps<TEventData>) => ReactNode;\n\n\t/**\n\t * Custom event popover renderer\n\t * Use this to inject your own EventPopover component\n\t * If not provided, a basic popover is shown\n\t */\n\trenderEventPopover?: (props: RenderEventPopoverProps<TEventData>) => ReactNode;\n\n\t/**\n\t * Custom filter sidebar renderer\n\t * Use this to inject your own CalendarFilterSidebar component\n\t */\n\trenderFilterSidebar?: (props: RenderFilterSidebarProps<TScheduleTypeData>) => ReactNode;\n\n\t/**\n\t * Custom header renderer\n\t * Use this to inject your own CalendarHeader component\n\t */\n\trenderHeader?: (props: RenderHeaderProps) => ReactNode;\n\n\t// ========================================================================\n\t// HEADER SLOTS\n\t// ========================================================================\n\n\t/** Settings popover content (for default header) */\n\tsettingsContent?: ReactNode;\n\t/** Filter row content (for default header) */\n\tfilterContent?: ReactNode;\n\t/** Whether to show the settings button (default: true) */\n\tshowSettings?: boolean;\n\t/** Whether to show timeline view options (default: false) */\n\tshowTimelineViews?: boolean;\n\n\t// ========================================================================\n\t// STYLING\n\t// ========================================================================\n\n\t/** Additional CSS class */\n\tclassName?: string;\n\t/** Custom header actions (shown in default header) */\n\theaderActions?: ReactNode;\n\t/** Empty state for agenda view */\n\temptyState?: ReactNode;\n\t/** Children (for header slot) */\n\tchildren?: ReactNode;\n}\n\n// ============================================================================\n// COMPONENT\n// ============================================================================\n\nexport function TailwindCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({\n\tevents,\n\tresources: _resources,\n\tscheduleTypes = [],\n\tinitialView = 'week',\n\tinitialDate,\n\tinitialFilters: _initialFilters,\n\tpreferences: userPreferences,\n\tbadgeVariant = 'colored',\n\thideHeader = false,\n\tshowFilterSidebar = false,\n\tavailableViews = ['day', 'week', 'month', 'agenda'],\n\tonEventClick,\n\tonSlotSelect,\n\tonViewChange,\n\tonDateChange,\n\tonAddEvent,\n\tonFiltersChange,\n\trenderEvent,\n\trenderEventPopover: _renderEventPopover,\n\trenderFilterSidebar,\n\trenderHeader,\n\tsettingsContent,\n\tfilterContent,\n\tshowSettings = true,\n\tshowTimelineViews = false,\n\tclassName,\n\theaderActions,\n\temptyState,\n\tchildren: _children,\n}: TailwindCalendarProps<TEventData, TScheduleTypeData, TResourceData>) {\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setView] = useState<TCalendarView>(initialView);\n\tconst [date, setDate] = useState<Date>(initialDate ?? new Date());\n\n\t// Filter state (for filter sidebar)\n\tconst [selectedScheduleTypeIds, setSelectedScheduleTypeIds] = useState<number[]>([]);\n\tconst [selectedParticipantIds, setSelectedParticipantIds] = useState<string[]>([]);\n\n\t// Merge user preferences with defaults\n\tconst preferences: ICalendarPreferences = useMemo(\n\t\t() => ({\n\t\t\t...DEFAULT_PREFERENCES,\n\t\t\t...userPreferences,\n\t\t}),\n\t\t[userPreferences]\n\t);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handleViewChange = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetView(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst handleDateChange = useCallback(\n\t\t(newDate: Date) => {\n\t\t\tsetDate(newDate);\n\t\t\tonDateChange?.(newDate);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst handleNavigatePrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateNext = useCallback(() => {\n\t\tconst newDate = navigateNext(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateToday = useCallback(() => {\n\t\tconst newDate = navigateToday();\n\t\thandleDateChange(newDate);\n\t}, [handleDateChange]);\n\n\tconst handleDayClick = useCallback(\n\t\t(clickedDate: Date) => {\n\t\t\t// Navigate to day view when clicking a day in month view\n\t\t\thandleDateChange(clickedDate);\n\t\t\thandleViewChange('day');\n\t\t},\n\t\t[handleDateChange, handleViewChange]\n\t);\n\n\t// ========================================================================\n\t// VIEW RENDERING\n\t// ========================================================================\n\n\t// Visible hours - show all hours (0-24) so users can see the full day\n\t// The working hours determine which slots have striped (disabled) appearance\n\tconst visibleHours = useMemo(\n\t\t() => ({\n\t\t\tstartHour: 0,\n\t\t\tendHour: 24,\n\t\t}),\n\t\t[]\n\t);\n\n\t// Week starts on (convert from 0-6 to 0 | 1)\n\tconst weekStartsOn: 0 | 1 = preferences.firstDayOfWeek === 0 ? 0 : 1;\n\n\t// Build working hours from preferences (for time grid views)\n\t// Working hours determine which slots are clickable and don't have striped pattern\n\t// Non-working hours get diagonal stripes and are disabled\n\tconst workingHours = useMemo(() => {\n\t\tconst hours: Record<number, { enabled: boolean; from: number; to: number }> = {};\n\t\tfor (let i = 0; i <= 6; i++) {\n\t\t\tconst isWeekend = i === 0 || i === 6;\n\t\t\t// Weekdays: use preferences, Weekends: use preferences if showWeekends, otherwise disabled\n\t\t\tif (!isWeekend) {\n\t\t\t\t// Weekdays (Mon-Fri): always have working hours from preferences\n\t\t\t\thours[i] = { enabled: true, from: preferences.startHour, to: preferences.endHour };\n\t\t\t} else if (preferences.showWeekends) {\n\t\t\t\t// Weekends with showWeekends: Saturday half-day (8-12), Sunday disabled\n\t\t\t\tif (i === 6) {\n\t\t\t\t\t// Saturday - half day (matching agenda-v2)\n\t\t\t\t\thours[i] = { enabled: true, from: 8, to: 12 };\n\t\t\t\t} else {\n\t\t\t\t\t// Sunday - disabled\n\t\t\t\t\thours[i] = { enabled: false, from: 0, to: 0 };\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Weekends without showWeekends: both disabled\n\t\t\t\thours[i] = { enabled: false, from: 0, to: 0 };\n\t\t\t}\n\t\t}\n\t\treturn hours;\n\t}, [preferences.startHour, preferences.endHour, preferences.showWeekends]);\n\n\t// Handle filter changes\n\tconst handleScheduleTypeFilterChange = useCallback(\n\t\t(ids: number[]) => {\n\t\t\tsetSelectedScheduleTypeIds(ids);\n\t\t\tonFiltersChange?.({\n\t\t\t\tscheduleTypeIds: ids,\n\t\t\t\tparticipantIds: selectedParticipantIds,\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange, selectedParticipantIds]\n\t);\n\n\tconst handleParticipantFilterChange = useCallback(\n\t\t(ids: string[]) => {\n\t\t\tsetSelectedParticipantIds(ids);\n\t\t\tonFiltersChange?.({\n\t\t\t\tscheduleTypeIds: selectedScheduleTypeIds,\n\t\t\t\tparticipantIds: ids,\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange, selectedScheduleTypeIds]\n\t);\n\n\t// Create render event adapters for different view types\n\t// Each view has a slightly different renderEvent signature\n\n\tconst dayWeekRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: {\n\t\t\tevent: CalendarEvent<TEventData>;\n\t\t\tposition: { top: number; height: number; left: number; width: number };\n\t\t}) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview,\n\t\t\t\tvariant: 'full',\n\t\t\t\tposition: { ...props.position, zIndex: 1 },\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, view, badgeVariant, onEventClick]);\n\n\tconst monthRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: { event: CalendarEvent<TEventData>; variant: 'compact' }) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview: 'month',\n\t\t\t\tvariant: props.variant,\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, badgeVariant, onEventClick]);\n\n\tconst agendaRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: { event: CalendarEvent<TEventData> }) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview: 'agenda',\n\t\t\t\tvariant: 'block',\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, badgeVariant, onEventClick]);\n\n\tconst renderView = () => {\n\t\tswitch (view) {\n\t\t\tcase 'day':\n\t\t\t\treturn (\n\t\t\t\t\t<DayView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tworkingHours={workingHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(dayWeekRenderEvent && { renderEvent: dayWeekRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'week':\n\t\t\t\treturn (\n\t\t\t\t\t<WeekView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tworkingHours={workingHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(dayWeekRenderEvent && { renderEvent: dayWeekRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'month':\n\t\t\t\treturn (\n\t\t\t\t\t<MonthView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(monthRenderEvent && { renderEvent: monthRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'agenda':\n\t\t\t\treturn (\n\t\t\t\t\t<AgendaView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(emptyState && { emptyState })}\n\t\t\t\t\t\t{...(agendaRenderEvent && { renderEvent: agendaRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tdefault:\n\t\t\t\treturn (\n\t\t\t\t\t<div className=\"flex items-center justify-center h-64 text-gray-500\">\n\t\t\t\t\t\tView "{view}" is not yet implemented\n\t\t\t\t\t</div>\n\t\t\t\t);\n\t\t}\n\t};\n\n\t// ========================================================================\n\t// RENDER\n\t// ========================================================================\n\n\t// Header navigation handler\n\tconst handleNavigate = useCallback(\n\t\t(direction: 'prev' | 'next' | 'today') => {\n\t\t\tif (direction === 'prev') handleNavigatePrev();\n\t\t\telse if (direction === 'next') handleNavigateNext();\n\t\t\telse handleNavigateToday();\n\t\t},\n\t\t[handleNavigatePrev, handleNavigateNext, handleNavigateToday]\n\t);\n\n\t// Default header props (conditionally add optional props)\n\tconst headerProps: RenderHeaderProps = {\n\t\tview,\n\t\tcurrentDate: date,\n\t\tavailableViews,\n\t\tonViewChange: handleViewChange,\n\t\tonNavigate: handleNavigate,\n\t\tonNavigatePrev: handleNavigatePrev,\n\t\tonNavigateNext: handleNavigateNext,\n\t\tonNavigateToday: handleNavigateToday,\n\t\t...(onAddEvent && { onAddEvent }),\n\t\t...(headerActions && { actions: headerActions }),\n\t\tclassName: 'border-b border-gray-200 p-3',\n\t};\n\n\t// Calendar header props (includes events for count display + slots)\n\tconst calendarHeaderProps = {\n\t\t...headerProps,\n\t\tevents,\n\t\tweekStartsOn,\n\t\tsettingsContent,\n\t\tfilterContent,\n\t\tshowSettings,\n\t\tshowTimelineViews,\n\t};\n\n\t// Clear all filters handler\n\tconst handleClearAllFilters = useCallback(() => {\n\t\tsetSelectedScheduleTypeIds([]);\n\t\tsetSelectedParticipantIds([]);\n\t\tonFiltersChange?.({\n\t\t\tscheduleTypeIds: [],\n\t\t\tparticipantIds: [],\n\t\t});\n\t}, [onFiltersChange]);\n\n\treturn (\n\t\t<div className={cn('flex h-full bg-white border border-gray-200 rounded-lg', className)}>\n\t\t\t{/* Filter Sidebar */}\n\t\t\t{showFilterSidebar && (\n\t\t\t\t<div className=\"w-64 border-r border-gray-200 flex-shrink-0\">\n\t\t\t\t\t{renderFilterSidebar ? (\n\t\t\t\t\t\trenderFilterSidebar({\n\t\t\t\t\t\t\tscheduleTypes,\n\t\t\t\t\t\t\tselectedScheduleTypeIds,\n\t\t\t\t\t\t\tselectedParticipantIds,\n\t\t\t\t\t\t\tonScheduleTypeChange: handleScheduleTypeFilterChange,\n\t\t\t\t\t\t\tonParticipantChange: handleParticipantFilterChange,\n\t\t\t\t\t\t\tonClearAll: handleClearAllFilters,\n\t\t\t\t\t\t})\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<div className=\"p-4 text-sm text-gray-500\">Filter sidebar not configured</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Main Calendar Area */}\n\t\t\t<div className=\"flex flex-col flex-1 min-w-0\">\n\t\t\t\t{/* Header */}\n\t\t\t\t{!hideHeader &&\n\t\t\t\t\t(renderHeader ? renderHeader(headerProps) : <CalendarHeader {...calendarHeaderProps} />)}\n\n\t\t\t\t{/* Calendar View */}\n\t\t\t\t<div className=\"flex-1 overflow-auto\">{renderView()}</div>\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":["baseStyles","headerStyles","contentStyles","fallbackViewStyles","DefaultCalendar","events","_resources","_scheduleTypes","initialView","initialDate","_initialFilters","userPreferences","badgeVariant","hideHeader","availableViews","onEventClick","onSlotSelect","onViewChange","onDateChange","className","style","headerActions","emptyState","_children","view","setView","useState","date","setDate","preferences","useMemo","DEFAULT_PREFERENCES","handleViewChange","useCallback","newView","handleDateChange","newDate","handleNavigatePrev","navigatePrev","handleNavigateNext","navigateNext","handleNavigateToday","navigateToday","handleDayClick","clickedDate","visibleHours","weekStartsOn","renderView","jsx","DayView","WeekView","MonthView","AgendaView","jsxs","CalendarHeader","direction","TailwindCalendar","scheduleTypes","showFilterSidebar","onAddEvent","onFiltersChange","renderEvent","_renderEventPopover","renderFilterSidebar","renderHeader","settingsContent","filterContent","showSettings","showTimelineViews","selectedScheduleTypeIds","setSelectedScheduleTypeIds","selectedParticipantIds","setSelectedParticipantIds","workingHours","hours","i","handleScheduleTypeFilterChange","ids","handleParticipantFilterChange","dayWeekRenderEvent","props","monthRenderEvent","agendaRenderEvent","handleNavigate","headerProps","calendarHeaderProps","handleClearAllFilters","cn"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tailwind-calendar-CJmOutn1.cjs","sources":["../src/presets/default/default-calendar.tsx","../src/presets/tailwind/tailwind-calendar.tsx"],"sourcesContent":["/**\n * DefaultCalendar - Pre-styled Calendar Preset\n *\n * A fully styled calendar using CSS custom properties for theming.\n * Designed for projects that don't use TailwindCSS but want a complete solution.\n *\n * CSS Custom Properties (override these for theming):\n * - --ic-bg: Background color\n * - --ic-bg-muted: Muted background\n * - --ic-text: Primary text color\n * - --ic-text-muted: Secondary text color\n * - --ic-border: Border color\n * - --ic-primary: Primary/accent color\n * - --ic-primary-foreground: Text on primary background\n * - --ic-radius: Border radius\n *\n * @example\n * ```tsx\n * import { DefaultCalendar } from '@inno/calendar/presets';\n *\n * function MyAgenda() {\n * return (\n * <div style={{ '--ic-primary': '#6366f1' }}>\n * <DefaultCalendar\n * events={myEvents}\n * onEventClick={(event) => console.log('Clicked:', event)}\n * />\n * </div>\n * );\n * }\n * ```\n */\n\nimport { type CSSProperties, type ReactNode, useCallback, useMemo, useState } from 'react';\nimport { CalendarHeader } from '../../components/header/calendar-header';\nimport { AgendaView } from '../../components/views/agenda-view';\nimport { DayView } from '../../components/views/day-view';\nimport { MonthView } from '../../components/views/month-view';\nimport { WeekView } from '../../components/views/week-view';\nimport { DEFAULT_PREFERENCES } from '../../core/constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTBadgeVariant,\n\tTCalendarView,\n} from '../../core/types';\nimport { navigateNext, navigatePrev, navigateToday } from '../../core/utils/grid-utils';\n\n// ============================================================================\n// STYLES (CSS-in-JS for zero-config usage)\n// ============================================================================\n\nconst baseStyles: CSSProperties = {\n\tdisplay: 'flex',\n\tflexDirection: 'column',\n\theight: '100%',\n\tminHeight: '400px',\n\tbackgroundColor: 'var(--ic-bg, #ffffff)',\n\tborder: '1px solid var(--ic-border, #e5e7eb)',\n\tborderRadius: 'var(--ic-radius, 0.5rem)',\n\toverflow: 'hidden',\n\tfontFamily:\n\t\t'var(--ic-font-family, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif)',\n\tfontSize: 'var(--ic-font-size, 0.875rem)',\n\tcolor: 'var(--ic-text, #111827)',\n};\n\nconst headerStyles: CSSProperties = {\n\tborderBottom: '1px solid var(--ic-border, #e5e7eb)',\n};\n\nconst contentStyles: CSSProperties = {\n\tflex: 1,\n\toverflow: 'auto',\n};\n\nconst fallbackViewStyles: CSSProperties = {\n\tdisplay: 'flex',\n\talignItems: 'center',\n\tjustifyContent: 'center',\n\theight: '16rem',\n\tcolor: 'var(--ic-text-muted, #6b7280)',\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface DefaultCalendarProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\t/** Available resources */\n\tresources?: IResource<TResourceData>[];\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[];\n\t/** Initial view */\n\tinitialView?: TCalendarView;\n\t/** Initial date */\n\tinitialDate?: Date;\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters;\n\t/** Preferences */\n\tpreferences?: Partial<ICalendarPreferences>;\n\t/** Badge variant for events (dot, colored, mixed) */\n\tbadgeVariant?: TBadgeVariant;\n\t/** Hide the header */\n\thideHeader?: boolean;\n\t/** Available views to show in view switcher */\n\tavailableViews?: TCalendarView[];\n\t/** Event click handler */\n\tonEventClick?: (event: CalendarEvent<TEventData>) => void;\n\t/** Slot selection handler */\n\tonSlotSelect?: (selection: ISelectionResult) => void;\n\t/** View change handler */\n\tonViewChange?: (view: TCalendarView) => void;\n\t/** Date change handler */\n\tonDateChange?: (date: Date) => void;\n\t/** Additional CSS class */\n\tclassName?: string;\n\t/** Custom style overrides */\n\tstyle?: CSSProperties;\n\t/** Custom header actions */\n\theaderActions?: ReactNode;\n\t/** Empty state for agenda view */\n\temptyState?: ReactNode;\n\t/** Children (for header slot) */\n\tchildren?: ReactNode;\n}\n\n// ============================================================================\n// COMPONENT\n// ============================================================================\n\nexport function DefaultCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({\n\tevents,\n\tresources: _resources,\n\tscheduleTypes: _scheduleTypes,\n\tinitialView = 'week',\n\tinitialDate,\n\tinitialFilters: _initialFilters,\n\tpreferences: userPreferences,\n\tbadgeVariant = 'colored',\n\thideHeader = false,\n\tavailableViews = ['day', 'week', 'month', 'agenda'],\n\tonEventClick,\n\tonSlotSelect,\n\tonViewChange,\n\tonDateChange,\n\tclassName = '',\n\tstyle,\n\theaderActions,\n\temptyState,\n\tchildren: _children,\n}: DefaultCalendarProps<TEventData, TScheduleTypeData, TResourceData>) {\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setView] = useState<TCalendarView>(initialView);\n\tconst [date, setDate] = useState<Date>(initialDate ?? new Date());\n\n\t// Merge user preferences with defaults\n\tconst preferences: ICalendarPreferences = useMemo(\n\t\t() => ({\n\t\t\t...DEFAULT_PREFERENCES,\n\t\t\t...userPreferences,\n\t\t}),\n\t\t[userPreferences]\n\t);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handleViewChange = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetView(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst handleDateChange = useCallback(\n\t\t(newDate: Date) => {\n\t\t\tsetDate(newDate);\n\t\t\tonDateChange?.(newDate);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst handleNavigatePrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateNext = useCallback(() => {\n\t\tconst newDate = navigateNext(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateToday = useCallback(() => {\n\t\tconst newDate = navigateToday();\n\t\thandleDateChange(newDate);\n\t}, [handleDateChange]);\n\n\tconst handleDayClick = useCallback(\n\t\t(clickedDate: Date) => {\n\t\t\t// Navigate to day view when clicking a day in month view\n\t\t\thandleDateChange(clickedDate);\n\t\t\thandleViewChange('day');\n\t\t},\n\t\t[handleDateChange, handleViewChange]\n\t);\n\n\t// ========================================================================\n\t// VIEW RENDERING\n\t// ========================================================================\n\n\t// Build visible hours from preferences\n\tconst visibleHours = useMemo(\n\t\t() => ({\n\t\t\tstartHour: preferences.startHour,\n\t\t\tendHour: preferences.endHour,\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\t// Week starts on (convert from 0-6 to 0 | 1)\n\tconst weekStartsOn: 0 | 1 = preferences.firstDayOfWeek === 0 ? 0 : 1;\n\n\tconst renderView = () => {\n\t\tswitch (view) {\n\t\t\tcase 'day':\n\t\t\t\treturn (\n\t\t\t\t\t<DayView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'week':\n\t\t\t\treturn (\n\t\t\t\t\t<WeekView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'month':\n\t\t\t\treturn (\n\t\t\t\t\t<MonthView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'agenda':\n\t\t\t\treturn (\n\t\t\t\t\t<AgendaView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(emptyState && { emptyState })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tdefault:\n\t\t\t\treturn <div style={fallbackViewStyles}>View "{view}" is not yet implemented</div>;\n\t\t}\n\t};\n\n\t// ========================================================================\n\t// RENDER\n\t// ========================================================================\n\n\treturn (\n\t\t<div className={className} style={{ ...baseStyles, ...style }}>\n\t\t\t{/* Header */}\n\t\t\t{!hideHeader && (\n\t\t\t\t<div style={headerStyles}>\n\t\t\t\t\t<CalendarHeader\n\t\t\t\t\t\tview={view}\n\t\t\t\t\t\tcurrentDate={date}\n\t\t\t\t\t\tavailableViews={availableViews}\n\t\t\t\t\t\tonViewChange={handleViewChange}\n\t\t\t\t\t\tonNavigate={(direction) => {\n\t\t\t\t\t\t\tif (direction === 'prev') handleNavigatePrev();\n\t\t\t\t\t\t\telse if (direction === 'next') handleNavigateNext();\n\t\t\t\t\t\t\telse handleNavigateToday();\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tactions={headerActions}\n\t\t\t\t\t\tclassName=\"p-3\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Calendar View */}\n\t\t\t<div style={contentStyles}>{renderView()}</div>\n\t\t</div>\n\t);\n}\n","/**\n * TailwindCalendar - Tailwind-Optimized Calendar Preset\n *\n * A fully featured, ready-to-use calendar component designed for TailwindCSS projects.\n * Composes all calendar components into a cohesive experience.\n *\n * Features:\n * - Full customization via render props (renderEvent, renderEventPopover, renderFilterSidebar)\n * - All visual components can be replaced while keeping state management\n * - Matches production quality when used with custom components\n *\n * @example\n * ```tsx\n * import { TailwindCalendar } from '@inno/calendar/presets';\n *\n * function MyAgenda() {\n * return (\n * <TailwindCalendar\n * events={myEvents}\n * onEventClick={(event) => console.log('Clicked:', event)}\n * onSlotSelect={(selection) => console.log('Selected:', selection)}\n * // Custom components for production quality\n * renderEvent={(event) => <MyEventCard event={event} />}\n * renderEventPopover={(event, onClose) => <MyEventPopover event={event} onClose={onClose} />}\n * renderFilterSidebar={(props) => <MyFilterSidebar {...props} />}\n * />\n * );\n * }\n * ```\n */\n\nimport { type ReactNode, useCallback, useMemo, useState } from 'react';\nimport { CalendarHeader } from '../../components/header/calendar-header';\nimport { AgendaView } from '../../components/views/agenda-view';\nimport { DayView } from '../../components/views/day-view';\nimport { MonthView } from '../../components/views/month-view';\nimport { WeekView } from '../../components/views/week-view';\nimport { DEFAULT_PREFERENCES } from '../../core/constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIEventPosition,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTBadgeVariant,\n\tTCalendarView,\n} from '../../core/types';\nimport { navigateNext, navigatePrev, navigateToday } from '../../core/utils/grid-utils';\nimport { cn } from '../../lib/utils';\n\n// ============================================================================\n// RENDER PROP TYPES\n// ============================================================================\n\n/**\n * Props for custom event rendering\n */\nexport interface RenderEventProps<TEventData = Record<string, unknown>> {\n\tevent: CalendarEvent<TEventData>;\n\tview: TCalendarView;\n\tvariant: 'full' | 'compact' | 'dot' | 'block';\n\tposition?: IEventPosition;\n\tbadgeVariant: TBadgeVariant;\n\tonClick?: () => void;\n}\n\n/**\n * Props for custom event popover rendering\n */\nexport interface RenderEventPopoverProps<TEventData = Record<string, unknown>> {\n\tevent: CalendarEvent<TEventData>;\n\tonClose: () => void;\n}\n\n/**\n * Props for custom filter sidebar rendering\n */\nexport interface RenderFilterSidebarProps<TScheduleTypeData = Record<string, unknown>> {\n\tscheduleTypes: IScheduleType<TScheduleTypeData>[];\n\tselectedScheduleTypeIds: number[];\n\tonScheduleTypeChange: (ids: number[]) => void;\n\tselectedParticipantIds: string[];\n\tonParticipantChange: (ids: string[]) => void;\n\tonClearAll?: () => void;\n}\n\n/**\n * Props for custom header rendering\n */\nexport interface RenderHeaderProps {\n\tview: TCalendarView;\n\tcurrentDate: Date;\n\tavailableViews: TCalendarView[];\n\tonViewChange: (view: TCalendarView) => void;\n\tonNavigate: (direction: 'prev' | 'next' | 'today') => void;\n\tonNavigatePrev?: () => void;\n\tonNavigateNext?: () => void;\n\tonNavigateToday?: () => void;\n\tonAddEvent?: () => void;\n\tactions?: ReactNode;\n\tclassName?: string;\n}\n\n// ============================================================================\n// COMPONENT PROPS\n// ============================================================================\n\nexport interface TailwindCalendarProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\t/** Available resources */\n\tresources?: IResource<TResourceData>[];\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[];\n\t/** Initial view */\n\tinitialView?: TCalendarView;\n\t/** Initial date */\n\tinitialDate?: Date;\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters;\n\t/** Preferences */\n\tpreferences?: Partial<ICalendarPreferences>;\n\t/** Badge variant for events (dot, colored, mixed) */\n\tbadgeVariant?: TBadgeVariant;\n\t/** Hide the header */\n\thideHeader?: boolean;\n\t/** Show filter sidebar */\n\tshowFilterSidebar?: boolean;\n\t/** Available views to show in view switcher */\n\tavailableViews?: TCalendarView[];\n\n\t// ========================================================================\n\t// CALLBACKS\n\t// ========================================================================\n\n\t/** Event click handler */\n\tonEventClick?: (event: CalendarEvent<TEventData>) => void;\n\t/** Slot selection handler */\n\tonSlotSelect?: (selection: ISelectionResult) => void;\n\t/** View change handler */\n\tonViewChange?: (view: TCalendarView) => void;\n\t/** Date change handler */\n\tonDateChange?: (date: Date) => void;\n\t/** Add event handler (for header button) */\n\tonAddEvent?: () => void;\n\t/** Filter change handler */\n\tonFiltersChange?: (filters: ICalendarFilters) => void;\n\n\t// ========================================================================\n\t// RENDER PROPS (for custom components)\n\t// ========================================================================\n\n\t/**\n\t * Custom event renderer\n\t * Use this to inject your own EventCard component\n\t */\n\trenderEvent?: (props: RenderEventProps<TEventData>) => ReactNode;\n\n\t/**\n\t * Custom event popover renderer\n\t * Use this to inject your own EventPopover component\n\t * If not provided, a basic popover is shown\n\t */\n\trenderEventPopover?: (props: RenderEventPopoverProps<TEventData>) => ReactNode;\n\n\t/**\n\t * Custom filter sidebar renderer\n\t * Use this to inject your own CalendarFilterSidebar component\n\t */\n\trenderFilterSidebar?: (props: RenderFilterSidebarProps<TScheduleTypeData>) => ReactNode;\n\n\t/**\n\t * Custom header renderer\n\t * Use this to inject your own CalendarHeader component\n\t */\n\trenderHeader?: (props: RenderHeaderProps) => ReactNode;\n\n\t// ========================================================================\n\t// HEADER SLOTS\n\t// ========================================================================\n\n\t/** Settings popover content (for default header) */\n\tsettingsContent?: ReactNode;\n\t/** Filter row content (for default header) */\n\tfilterContent?: ReactNode;\n\t/** Whether to show the settings button (default: true) */\n\tshowSettings?: boolean;\n\t/** Whether to show timeline view options (default: false) */\n\tshowTimelineViews?: boolean;\n\n\t// ========================================================================\n\t// STYLING\n\t// ========================================================================\n\n\t/** Additional CSS class */\n\tclassName?: string;\n\t/** Custom header actions (shown in default header) */\n\theaderActions?: ReactNode;\n\t/** Empty state for agenda view */\n\temptyState?: ReactNode;\n\t/** Children (for header slot) */\n\tchildren?: ReactNode;\n}\n\n// ============================================================================\n// COMPONENT\n// ============================================================================\n\nexport function TailwindCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({\n\tevents,\n\tresources: _resources,\n\tscheduleTypes = [],\n\tinitialView = 'week',\n\tinitialDate,\n\tinitialFilters: _initialFilters,\n\tpreferences: userPreferences,\n\tbadgeVariant = 'colored',\n\thideHeader = false,\n\tshowFilterSidebar = false,\n\tavailableViews = ['day', 'week', 'month', 'agenda'],\n\tonEventClick,\n\tonSlotSelect,\n\tonViewChange,\n\tonDateChange,\n\tonAddEvent,\n\tonFiltersChange,\n\trenderEvent,\n\trenderEventPopover: _renderEventPopover,\n\trenderFilterSidebar,\n\trenderHeader,\n\tsettingsContent,\n\tfilterContent,\n\tshowSettings = true,\n\tshowTimelineViews = false,\n\tclassName,\n\theaderActions,\n\temptyState,\n\tchildren: _children,\n}: TailwindCalendarProps<TEventData, TScheduleTypeData, TResourceData>) {\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setView] = useState<TCalendarView>(initialView);\n\tconst [date, setDate] = useState<Date>(initialDate ?? new Date());\n\n\t// Filter state (for filter sidebar)\n\tconst [selectedScheduleTypeIds, setSelectedScheduleTypeIds] = useState<number[]>([]);\n\tconst [selectedParticipantIds, setSelectedParticipantIds] = useState<string[]>([]);\n\n\t// Merge user preferences with defaults\n\tconst preferences: ICalendarPreferences = useMemo(\n\t\t() => ({\n\t\t\t...DEFAULT_PREFERENCES,\n\t\t\t...userPreferences,\n\t\t}),\n\t\t[userPreferences]\n\t);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handleViewChange = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetView(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst handleDateChange = useCallback(\n\t\t(newDate: Date) => {\n\t\t\tsetDate(newDate);\n\t\t\tonDateChange?.(newDate);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst handleNavigatePrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateNext = useCallback(() => {\n\t\tconst newDate = navigateNext(date, view);\n\t\thandleDateChange(newDate);\n\t}, [date, view, handleDateChange]);\n\n\tconst handleNavigateToday = useCallback(() => {\n\t\tconst newDate = navigateToday();\n\t\thandleDateChange(newDate);\n\t}, [handleDateChange]);\n\n\tconst handleDayClick = useCallback(\n\t\t(clickedDate: Date) => {\n\t\t\t// Navigate to day view when clicking a day in month view\n\t\t\thandleDateChange(clickedDate);\n\t\t\thandleViewChange('day');\n\t\t},\n\t\t[handleDateChange, handleViewChange]\n\t);\n\n\t// ========================================================================\n\t// VIEW RENDERING\n\t// ========================================================================\n\n\t// Visible hours - show all hours (0-24) so users can see the full day\n\t// The working hours determine which slots have striped (disabled) appearance\n\tconst visibleHours = useMemo(\n\t\t() => ({\n\t\t\tstartHour: 0,\n\t\t\tendHour: 24,\n\t\t}),\n\t\t[]\n\t);\n\n\t// Week starts on (convert from 0-6 to 0 | 1)\n\tconst weekStartsOn: 0 | 1 = preferences.firstDayOfWeek === 0 ? 0 : 1;\n\n\t// Build working hours from preferences (for time grid views)\n\t// Working hours determine which slots are clickable and don't have striped pattern\n\t// Non-working hours get diagonal stripes and are disabled\n\tconst workingHours = useMemo(() => {\n\t\tconst hours: Record<number, { enabled: boolean; from: number; to: number }> = {};\n\t\tfor (let i = 0; i <= 6; i++) {\n\t\t\tconst isWeekend = i === 0 || i === 6;\n\t\t\t// Weekdays: use preferences, Weekends: use preferences if showWeekends, otherwise disabled\n\t\t\tif (!isWeekend) {\n\t\t\t\t// Weekdays (Mon-Fri): always have working hours from preferences\n\t\t\t\thours[i] = { enabled: true, from: preferences.startHour, to: preferences.endHour };\n\t\t\t} else if (preferences.showWeekends) {\n\t\t\t\t// Weekends with showWeekends: Saturday half-day (8-12), Sunday disabled\n\t\t\t\tif (i === 6) {\n\t\t\t\t\t// Saturday - half day (matching agenda-v2)\n\t\t\t\t\thours[i] = { enabled: true, from: 8, to: 12 };\n\t\t\t\t} else {\n\t\t\t\t\t// Sunday - disabled\n\t\t\t\t\thours[i] = { enabled: false, from: 0, to: 0 };\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Weekends without showWeekends: both disabled\n\t\t\t\thours[i] = { enabled: false, from: 0, to: 0 };\n\t\t\t}\n\t\t}\n\t\treturn hours;\n\t}, [preferences.startHour, preferences.endHour, preferences.showWeekends]);\n\n\t// Handle filter changes\n\tconst handleScheduleTypeFilterChange = useCallback(\n\t\t(ids: number[]) => {\n\t\t\tsetSelectedScheduleTypeIds(ids);\n\t\t\tonFiltersChange?.({\n\t\t\t\tscheduleTypeIds: ids,\n\t\t\t\tparticipantIds: selectedParticipantIds,\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange, selectedParticipantIds]\n\t);\n\n\tconst handleParticipantFilterChange = useCallback(\n\t\t(ids: string[]) => {\n\t\t\tsetSelectedParticipantIds(ids);\n\t\t\tonFiltersChange?.({\n\t\t\t\tscheduleTypeIds: selectedScheduleTypeIds,\n\t\t\t\tparticipantIds: ids,\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange, selectedScheduleTypeIds]\n\t);\n\n\t// Create render event adapters for different view types\n\t// Each view has a slightly different renderEvent signature\n\n\tconst dayWeekRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: {\n\t\t\tevent: CalendarEvent<TEventData>;\n\t\t\tposition: { top: number; height: number; left: number; width: number };\n\t\t}) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview,\n\t\t\t\tvariant: 'full',\n\t\t\t\tposition: { ...props.position, zIndex: 1 },\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, view, badgeVariant, onEventClick]);\n\n\tconst monthRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: { event: CalendarEvent<TEventData>; variant: 'compact' }) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview: 'month',\n\t\t\t\tvariant: props.variant,\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, badgeVariant, onEventClick]);\n\n\tconst agendaRenderEvent = useMemo(() => {\n\t\tif (!renderEvent) return undefined;\n\t\treturn (props: { event: CalendarEvent<TEventData> }) => {\n\t\t\treturn renderEvent({\n\t\t\t\tevent: props.event,\n\t\t\t\tview: 'agenda',\n\t\t\t\tvariant: 'block',\n\t\t\t\tbadgeVariant,\n\t\t\t\t...(onEventClick && { onClick: () => onEventClick(props.event) }),\n\t\t\t});\n\t\t};\n\t}, [renderEvent, badgeVariant, onEventClick]);\n\n\tconst renderView = () => {\n\t\tswitch (view) {\n\t\t\tcase 'day':\n\t\t\t\treturn (\n\t\t\t\t\t<DayView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tworkingHours={workingHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(dayWeekRenderEvent && { renderEvent: dayWeekRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'week':\n\t\t\t\treturn (\n\t\t\t\t\t<WeekView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tvisibleHours={visibleHours}\n\t\t\t\t\t\tworkingHours={workingHours}\n\t\t\t\t\t\tslotDuration={preferences.slotDuration}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(dayWeekRenderEvent && { renderEvent: dayWeekRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'month':\n\t\t\t\treturn (\n\t\t\t\t\t<MonthView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\tweekStartsOn={weekStartsOn}\n\t\t\t\t\t\tonDayClick={handleDayClick}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(onSlotSelect && { onSlotSelect })}\n\t\t\t\t\t\t{...(monthRenderEvent && { renderEvent: monthRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tcase 'agenda':\n\t\t\t\treturn (\n\t\t\t\t\t<AgendaView<TEventData>\n\t\t\t\t\t\tevents={events}\n\t\t\t\t\t\tdate={date}\n\t\t\t\t\t\tbadgeVariant={badgeVariant}\n\t\t\t\t\t\t{...(onEventClick && { onEventClick })}\n\t\t\t\t\t\t{...(emptyState && { emptyState })}\n\t\t\t\t\t\t{...(agendaRenderEvent && { renderEvent: agendaRenderEvent })}\n\t\t\t\t\t/>\n\t\t\t\t);\n\n\t\t\tdefault:\n\t\t\t\treturn (\n\t\t\t\t\t<div className=\"flex items-center justify-center h-64 text-gray-500\">\n\t\t\t\t\t\tView "{view}" is not yet implemented\n\t\t\t\t\t</div>\n\t\t\t\t);\n\t\t}\n\t};\n\n\t// ========================================================================\n\t// RENDER\n\t// ========================================================================\n\n\t// Header navigation handler\n\tconst handleNavigate = useCallback(\n\t\t(direction: 'prev' | 'next' | 'today') => {\n\t\t\tif (direction === 'prev') handleNavigatePrev();\n\t\t\telse if (direction === 'next') handleNavigateNext();\n\t\t\telse handleNavigateToday();\n\t\t},\n\t\t[handleNavigatePrev, handleNavigateNext, handleNavigateToday]\n\t);\n\n\t// Default header props (conditionally add optional props)\n\tconst headerProps: RenderHeaderProps = {\n\t\tview,\n\t\tcurrentDate: date,\n\t\tavailableViews,\n\t\tonViewChange: handleViewChange,\n\t\tonNavigate: handleNavigate,\n\t\tonNavigatePrev: handleNavigatePrev,\n\t\tonNavigateNext: handleNavigateNext,\n\t\tonNavigateToday: handleNavigateToday,\n\t\t...(onAddEvent && { onAddEvent }),\n\t\t...(headerActions && { actions: headerActions }),\n\t\tclassName: 'border-b border-gray-200 p-3',\n\t};\n\n\t// Calendar header props (includes events for count display + slots)\n\tconst calendarHeaderProps = {\n\t\t...headerProps,\n\t\tevents,\n\t\tweekStartsOn,\n\t\tsettingsContent,\n\t\tfilterContent,\n\t\tshowSettings,\n\t\tshowTimelineViews,\n\t};\n\n\t// Clear all filters handler\n\tconst handleClearAllFilters = useCallback(() => {\n\t\tsetSelectedScheduleTypeIds([]);\n\t\tsetSelectedParticipantIds([]);\n\t\tonFiltersChange?.({\n\t\t\tscheduleTypeIds: [],\n\t\t\tparticipantIds: [],\n\t\t});\n\t}, [onFiltersChange]);\n\n\treturn (\n\t\t<div className={cn('flex h-full bg-white border border-gray-200 rounded-lg', className)}>\n\t\t\t{/* Filter Sidebar */}\n\t\t\t{showFilterSidebar && (\n\t\t\t\t<div className=\"w-64 border-r border-gray-200 flex-shrink-0\">\n\t\t\t\t\t{renderFilterSidebar ? (\n\t\t\t\t\t\trenderFilterSidebar({\n\t\t\t\t\t\t\tscheduleTypes,\n\t\t\t\t\t\t\tselectedScheduleTypeIds,\n\t\t\t\t\t\t\tselectedParticipantIds,\n\t\t\t\t\t\t\tonScheduleTypeChange: handleScheduleTypeFilterChange,\n\t\t\t\t\t\t\tonParticipantChange: handleParticipantFilterChange,\n\t\t\t\t\t\t\tonClearAll: handleClearAllFilters,\n\t\t\t\t\t\t})\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<div className=\"p-4 text-sm text-gray-500\">Filter sidebar not configured</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Main Calendar Area */}\n\t\t\t<div className=\"flex flex-col flex-1 min-w-0\">\n\t\t\t\t{/* Header */}\n\t\t\t\t{!hideHeader &&\n\t\t\t\t\t(renderHeader ? renderHeader(headerProps) : <CalendarHeader {...calendarHeaderProps} />)}\n\n\t\t\t\t{/* Calendar View */}\n\t\t\t\t<div className=\"flex-1 overflow-auto\">{renderView()}</div>\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":["baseStyles","headerStyles","contentStyles","fallbackViewStyles","DefaultCalendar","events","_resources","_scheduleTypes","initialView","initialDate","_initialFilters","userPreferences","badgeVariant","hideHeader","availableViews","onEventClick","onSlotSelect","onViewChange","onDateChange","className","style","headerActions","emptyState","_children","view","setView","useState","date","setDate","preferences","useMemo","DEFAULT_PREFERENCES","handleViewChange","useCallback","newView","handleDateChange","newDate","handleNavigatePrev","navigatePrev","handleNavigateNext","navigateNext","handleNavigateToday","navigateToday","handleDayClick","clickedDate","visibleHours","weekStartsOn","renderView","jsx","DayView","WeekView","MonthView","AgendaView","jsxs","CalendarHeader","direction","TailwindCalendar","scheduleTypes","showFilterSidebar","onAddEvent","onFiltersChange","renderEvent","_renderEventPopover","renderFilterSidebar","renderHeader","settingsContent","filterContent","showSettings","showTimelineViews","selectedScheduleTypeIds","setSelectedScheduleTypeIds","selectedParticipantIds","setSelectedParticipantIds","workingHours","hours","i","handleScheduleTypeFilterChange","ids","handleParticipantFilterChange","dayWeekRenderEvent","props","monthRenderEvent","agendaRenderEvent","handleNavigate","headerProps","calendarHeaderProps","handleClearAllFilters","cn"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const H=require("react/jsx-runtime"),t=require("react"),r=require("./utils.cjs"),x=t.createContext(void 0);function J({children:n,value:s}){return H.jsx(x.Provider,{value:s,children:n})}function C(){const n=t.useContext(x);if(!n)throw new Error("useCalendarContext must be used within a CalendarProvider");return n}function K(){return t.useContext(x)}function Q(){const{view:n,setView:s}=C();return{view:n,setView:s}}function X(){const{currentDate:n,setCurrentDate:s,goToNext:d,goToPrev:f,goToToday:E,goToDate:h}=C();return{currentDate:n,setCurrentDate:s,goToNext:d,goToPrev:f,goToToday:E,goToDate:h}}function Y(){const{events:n,filteredEvents:s}=C();return{events:n,filteredEvents:s}}function Z(){const{filters:n,setFilters:s,updateFilters:d,clearFilters:f}=C();return{filters:n,setFilters:s,updateFilters:d,clearFilters:f}}function $(){const{preferences:n,setPreferences:s}=C();return{preferences:n,setPreferences:s}}function ee(n){const{events:s,resources:d=[],scheduleTypes:f=[],initialView:E="week",initialDate:h,initialFilters:p={},preferences:R={},lockedPreferences:k={},locale:T="en-US",onViewChange:S,onDateChange:y,onEventClick:P,onSlotSelect:b,onFiltersChange:u}=n,[a,V]=t.useState(E),[o,m]=t.useState(()=>h??new Date),[v,w]=t.useState(p),[g,B]=t.useState(()=>({...r.DEFAULT_PREFERENCES,...R,...k})),D=t.useMemo(()=>r.getViewDateRange(o,a,g.firstDayOfWeek),[o,a,g.firstDayOfWeek]),O=t.useMemo(()=>r.getViewTitle(o,a,T),[o,a,T]),I=t.useMemo(()=>{let e=[...s];e=r.filterEventsByDateRange(e,D.startDate,D.endDate);const l=v.scheduleTypeIds;l&&l.length>0&&(e=r.filterEventsByScheduleType(e,l));const i=v.resourceIds;i&&i.length>0&&(e=r.filterEventsByResource(e,i));const F=v.search;return F&&(e=r.filterEventsBySearch(e,F)),g.showCanceledEvents||(e=r.filterOutCanceled(e)),r.sortEventsByStart(e)},[s,D,v,g.showCanceledEvents]),N=t.useCallback(e=>{V(e),S?.(e)},[S]),c=t.useCallback(e=>{m(e),y?.(e)},[y]),q=t.useCallback(()=>{const e=r.navigateNext(o,a);c(e)},[o,a,c]),M=t.useCallback(()=>{const e=r.navigatePrev(o,a);c(e)},[o,a,c]),j=t.useCallback(()=>{c(r.navigateToday())},[c]),U=t.useCallback(e=>{c(e)},[c]),W=t.useCallback(e=>{w(e),u?.(e)},[u]),A=t.useCallback(e=>{w(l=>{const i={...l,...e};return u?.(i),i})},[u]),L=t.useCallback(()=>{const e={};w(e),u?.(e)},[u]),_=t.useCallback(e=>{B(l=>({...l,...e,...k}))},[k]),z=t.useCallback(e=>{P?.(e)},[P]),G=t.useCallback(e=>{b?.(e)},[b]);return{view:a,currentDate:o,dateRange:D,filters:v,preferences:g,filteredEvents:I,viewTitle:O,events:s,resources:d,scheduleTypes:f,setView:N,setCurrentDate:c,goToNext:q,goToPrev:M,goToToday:j,goToDate:U,setFilters:W,updateFilters:A,clearFilters:L,setPreferences:_,handleEventClick:z,handleSlotSelect:G}}exports.CalendarProvider=J;exports.useCalendar=ee;exports.useCalendarContext=C;exports.useCalendarDate=X;exports.useCalendarEvents=Y;exports.useCalendarFilters=Z;exports.useCalendarPreferences=$;exports.useCalendarView=Q;exports.useOptionalCalendarContext=K;
|
|
2
|
+
//# sourceMappingURL=use-calendar-BEuelmSu.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-calendar-BEuelmSu.cjs","sources":["../src/core/context/calendar-context.tsx","../src/core/hooks/use-calendar.ts"],"sourcesContent":["/**\n * CalendarContext - React Context for Calendar State\n *\n * Provides calendar state to deeply nested components without prop drilling.\n */\n\nimport { createContext, type ReactNode, useContext } from 'react';\nimport type { UseCalendarReturn } from '../hooks/use-calendar';\n\n// ============================================================================\n// CONTEXT\n// ============================================================================\n\n/**\n * Calendar context type - generic to support any event data type\n * We use `any` here because context consumers may not know the exact type\n * Use the typed hooks below for type-safe access\n */\n// biome-ignore lint/suspicious/noExplicitAny: Context needs to be flexible for different event types\nconst CalendarContext = createContext<UseCalendarReturn<any, any, any> | undefined>(undefined);\n\n// ============================================================================\n// PROVIDER\n// ============================================================================\n\nexport interface CalendarProviderProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\tchildren: ReactNode;\n\tvalue: UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData>;\n}\n\nexport function CalendarProvider<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({ children, value }: CalendarProviderProps<TEventData, TScheduleTypeData, TResourceData>) {\n\treturn <CalendarContext.Provider value={value}>{children}</CalendarContext.Provider>;\n}\n\n// ============================================================================\n// HOOKS\n// ============================================================================\n\n/**\n * Get the full calendar context (throws if not in provider)\n */\nexport function useCalendarContext<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> {\n\tconst context = useContext(CalendarContext);\n\tif (!context) {\n\t\tthrow new Error('useCalendarContext must be used within a CalendarProvider');\n\t}\n\treturn context as UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData>;\n}\n\n/**\n * Get the calendar context or undefined (safe version)\n */\nexport function useOptionalCalendarContext<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> | undefined {\n\tconst context = useContext(CalendarContext);\n\treturn context as UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> | undefined;\n}\n\n// ============================================================================\n// CONVENIENCE HOOKS\n// ============================================================================\n\n/**\n * Get current view\n */\nexport function useCalendarView() {\n\tconst { view, setView } = useCalendarContext();\n\treturn { view, setView };\n}\n\n/**\n * Get current date and navigation\n */\nexport function useCalendarDate() {\n\tconst { currentDate, setCurrentDate, goToNext, goToPrev, goToToday, goToDate } =\n\t\tuseCalendarContext();\n\treturn { currentDate, setCurrentDate, goToNext, goToPrev, goToToday, goToDate };\n}\n\n/**\n * Get filtered events\n */\nexport function useCalendarEvents<TEventData = Record<string, unknown>>() {\n\tconst { events, filteredEvents } = useCalendarContext<TEventData>();\n\treturn { events, filteredEvents };\n}\n\n/**\n * Get filters\n */\nexport function useCalendarFilters() {\n\tconst { filters, setFilters, updateFilters, clearFilters } = useCalendarContext();\n\treturn { filters, setFilters, updateFilters, clearFilters };\n}\n\n/**\n * Get preferences\n */\nexport function useCalendarPreferences() {\n\tconst { preferences, setPreferences } = useCalendarContext();\n\treturn { preferences, setPreferences };\n}\n\n// ============================================================================\n// ALIASES (for agenda-v2 naming convention compatibility)\n// ============================================================================\n\n/**\n * Alias for useCalendarContext - matches agenda-v2 naming convention\n */\nexport { useCalendarContext as useCalendar };\n\n/**\n * Alias for useOptionalCalendarContext - matches agenda-v2 naming convention\n */\nexport { useOptionalCalendarContext as useOptionalCalendar };\n","/**\n * useCalendar - Main Calendar Hook\n *\n * This hook provides all the state and methods needed to build a calendar.\n * It is fully generic, allowing consumers to define their own event data types.\n *\n * @example\n * ```tsx\n * interface MyEventData {\n * projectId: number;\n * priority: 'low' | 'medium' | 'high';\n * }\n *\n * const calendar = useCalendar<MyEventData>({\n * events: myEvents,\n * onEventClick: (event) => {\n * console.log(event.data?.projectId);\n * },\n * });\n * ```\n */\n\nimport { useCallback, useMemo, useState } from 'react';\nimport { DEFAULT_PREFERENCES } from '../constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIDateRange,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTCalendarView,\n} from '../types';\nimport {\n\tfilterEventsByDateRange,\n\tfilterEventsByResource,\n\tfilterEventsByScheduleType,\n\tfilterEventsBySearch,\n\tfilterOutCanceled,\n\tsortEventsByStart,\n} from '../utils/event-utils';\nimport {\n\tgetViewDateRange,\n\tgetViewTitle,\n\tnavigateNext,\n\tnavigatePrev,\n\tnavigateToday,\n} from '../utils/grid-utils';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/**\n * Options for useCalendar hook\n */\nexport interface UseCalendarOptions<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\n\t/** Available resources (for resource views) */\n\tresources?: IResource<TResourceData>[] | undefined;\n\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[] | undefined;\n\n\t/** Initial view */\n\tinitialView?: TCalendarView | undefined;\n\n\t/** Initial date */\n\tinitialDate?: Date | undefined;\n\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters | undefined;\n\n\t/** User preferences */\n\tpreferences?: Partial<ICalendarPreferences> | undefined;\n\n\t/** Locked preferences (cannot be changed by user) */\n\tlockedPreferences?: Partial<ICalendarPreferences> | undefined;\n\n\t/** Locale for formatting */\n\tlocale?: string | undefined;\n\n\t/** Callback when view changes */\n\tonViewChange?: ((view: TCalendarView) => void) | undefined;\n\n\t/** Callback when date changes */\n\tonDateChange?: ((date: Date) => void) | undefined;\n\n\t/** Callback when event is clicked */\n\tonEventClick?: ((event: CalendarEvent<TEventData>) => void) | undefined;\n\n\t/** Callback when slot is selected */\n\tonSlotSelect?: ((selection: ISelectionResult) => void) | undefined;\n\n\t/** Callback when filters change */\n\tonFiltersChange?: ((filters: ICalendarFilters) => void) | undefined;\n}\n\n/**\n * Return type for useCalendar hook\n */\nexport interface UseCalendarReturn<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t// State\n\tview: TCalendarView;\n\tcurrentDate: Date;\n\tdateRange: IDateRange;\n\tfilters: ICalendarFilters;\n\tpreferences: ICalendarPreferences;\n\n\t// Computed\n\tfilteredEvents: CalendarEvent<TEventData>[];\n\tviewTitle: string;\n\n\t// Data\n\tevents: CalendarEvent<TEventData>[];\n\tresources: IResource<TResourceData>[];\n\tscheduleTypes: IScheduleType<TScheduleTypeData>[];\n\n\t// Actions\n\tsetView: (view: TCalendarView) => void;\n\tsetCurrentDate: (date: Date) => void;\n\tgoToNext: () => void;\n\tgoToPrev: () => void;\n\tgoToToday: () => void;\n\tgoToDate: (date: Date) => void;\n\n\t// Filters\n\tsetFilters: (filters: ICalendarFilters) => void;\n\tupdateFilters: (updates: Partial<ICalendarFilters>) => void;\n\tclearFilters: () => void;\n\n\t// Preferences\n\tsetPreferences: (prefs: Partial<ICalendarPreferences>) => void;\n\n\t// Event handlers\n\thandleEventClick: (event: CalendarEvent<TEventData>) => void;\n\thandleSlotSelect: (selection: ISelectionResult) => void;\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function useCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(\n\toptions: UseCalendarOptions<TEventData, TScheduleTypeData, TResourceData>\n): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> {\n\tconst {\n\t\tevents,\n\t\tresources = [],\n\t\tscheduleTypes = [],\n\t\tinitialView = 'week',\n\t\tinitialDate,\n\t\tinitialFilters = {},\n\t\tpreferences: userPreferences = {},\n\t\tlockedPreferences = {},\n\t\tlocale = 'en-US',\n\t\tonViewChange,\n\t\tonDateChange,\n\t\tonEventClick,\n\t\tonSlotSelect,\n\t\tonFiltersChange,\n\t} = options;\n\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setViewState] = useState<TCalendarView>(initialView);\n\tconst [currentDate, setCurrentDateState] = useState<Date>(() => initialDate ?? new Date());\n\tconst [filters, setFiltersState] = useState<ICalendarFilters>(initialFilters);\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => ({\n\t\t...DEFAULT_PREFERENCES,\n\t\t...userPreferences,\n\t\t...lockedPreferences,\n\t}));\n\n\t// ========================================================================\n\t// COMPUTED\n\t// ========================================================================\n\n\tconst dateRange = useMemo(\n\t\t() => getViewDateRange(currentDate, view, preferences.firstDayOfWeek),\n\t\t[currentDate, view, preferences.firstDayOfWeek]\n\t);\n\n\tconst viewTitle = useMemo(\n\t\t() => getViewTitle(currentDate, view, locale),\n\t\t[currentDate, view, locale]\n\t);\n\n\tconst filteredEvents = useMemo(() => {\n\t\tlet result = [...events];\n\n\t\t// Filter by date range\n\t\tresult = filterEventsByDateRange(result, dateRange.startDate, dateRange.endDate);\n\n\t\t// Filter by schedule types\n\t\tconst scheduleTypeIds = filters.scheduleTypeIds;\n\t\tif (scheduleTypeIds && scheduleTypeIds.length > 0) {\n\t\t\tresult = filterEventsByScheduleType(result, scheduleTypeIds);\n\t\t}\n\n\t\t// Filter by resources\n\t\tconst resourceIds = filters.resourceIds;\n\t\tif (resourceIds && resourceIds.length > 0) {\n\t\t\tresult = filterEventsByResource(result, resourceIds);\n\t\t}\n\n\t\t// Filter by search\n\t\tconst search = filters.search;\n\t\tif (search) {\n\t\t\tresult = filterEventsBySearch(result, search);\n\t\t}\n\n\t\t// Filter canceled\n\t\tif (!preferences.showCanceledEvents) {\n\t\t\tresult = filterOutCanceled(result);\n\t\t}\n\n\t\t// Sort by start date\n\t\treturn sortEventsByStart(result);\n\t}, [events, dateRange, filters, preferences.showCanceledEvents]);\n\n\t// ========================================================================\n\t// ACTIONS\n\t// ========================================================================\n\n\tconst setView = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetViewState(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst setCurrentDate = useCallback(\n\t\t(date: Date) => {\n\t\t\tsetCurrentDateState(date);\n\t\t\tonDateChange?.(date);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst goToNext = useCallback(() => {\n\t\tconst newDate = navigateNext(currentDate, view);\n\t\tsetCurrentDate(newDate);\n\t}, [currentDate, view, setCurrentDate]);\n\n\tconst goToPrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(currentDate, view);\n\t\tsetCurrentDate(newDate);\n\t}, [currentDate, view, setCurrentDate]);\n\n\tconst goToToday = useCallback(() => {\n\t\tsetCurrentDate(navigateToday());\n\t}, [setCurrentDate]);\n\n\tconst goToDate = useCallback(\n\t\t(date: Date) => {\n\t\t\tsetCurrentDate(date);\n\t\t},\n\t\t[setCurrentDate]\n\t);\n\n\t// ========================================================================\n\t// FILTERS\n\t// ========================================================================\n\n\tconst setFilters = useCallback(\n\t\t(newFilters: ICalendarFilters) => {\n\t\t\tsetFiltersState(newFilters);\n\t\t\tonFiltersChange?.(newFilters);\n\t\t},\n\t\t[onFiltersChange]\n\t);\n\n\tconst updateFilters = useCallback(\n\t\t(updates: Partial<ICalendarFilters>) => {\n\t\t\tsetFiltersState((prev) => {\n\t\t\t\tconst next = { ...prev, ...updates };\n\t\t\t\tonFiltersChange?.(next);\n\t\t\t\treturn next;\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange]\n\t);\n\n\tconst clearFilters = useCallback(() => {\n\t\tconst emptyFilters: ICalendarFilters = {};\n\t\tsetFiltersState(emptyFilters);\n\t\tonFiltersChange?.(emptyFilters);\n\t}, [onFiltersChange]);\n\n\t// ========================================================================\n\t// PREFERENCES\n\t// ========================================================================\n\n\tconst setPreferences = useCallback(\n\t\t(prefs: Partial<ICalendarPreferences>) => {\n\t\t\tsetPreferencesState((prev) => ({\n\t\t\t\t...prev,\n\t\t\t\t...prefs,\n\t\t\t\t...lockedPreferences, // Locked prefs always override\n\t\t\t}));\n\t\t},\n\t\t[lockedPreferences]\n\t);\n\n\t// ========================================================================\n\t// EVENT HANDLERS\n\t// ========================================================================\n\n\tconst handleEventClick = useCallback(\n\t\t(event: CalendarEvent<TEventData>) => {\n\t\t\tonEventClick?.(event);\n\t\t},\n\t\t[onEventClick]\n\t);\n\n\tconst handleSlotSelect = useCallback(\n\t\t(selection: ISelectionResult) => {\n\t\t\tonSlotSelect?.(selection);\n\t\t},\n\t\t[onSlotSelect]\n\t);\n\n\t// ========================================================================\n\t// RETURN\n\t// ========================================================================\n\n\treturn {\n\t\t// State\n\t\tview,\n\t\tcurrentDate,\n\t\tdateRange,\n\t\tfilters,\n\t\tpreferences,\n\n\t\t// Computed\n\t\tfilteredEvents,\n\t\tviewTitle,\n\n\t\t// Data\n\t\tevents,\n\t\tresources,\n\t\tscheduleTypes,\n\n\t\t// Actions\n\t\tsetView,\n\t\tsetCurrentDate,\n\t\tgoToNext,\n\t\tgoToPrev,\n\t\tgoToToday,\n\t\tgoToDate,\n\n\t\t// Filters\n\t\tsetFilters,\n\t\tupdateFilters,\n\t\tclearFilters,\n\n\t\t// Preferences\n\t\tsetPreferences,\n\n\t\t// Event handlers\n\t\thandleEventClick,\n\t\thandleSlotSelect,\n\t};\n}\n"],"names":["CalendarContext","createContext","CalendarProvider","children","value","jsx","useCalendarContext","context","useContext","useOptionalCalendarContext","useCalendarView","view","setView","useCalendarDate","currentDate","setCurrentDate","goToNext","goToPrev","goToToday","goToDate","useCalendarEvents","events","filteredEvents","useCalendarFilters","filters","setFilters","updateFilters","clearFilters","useCalendarPreferences","preferences","setPreferences","useCalendar","options","resources","scheduleTypes","initialView","initialDate","initialFilters","userPreferences","lockedPreferences","locale","onViewChange","onDateChange","onEventClick","onSlotSelect","onFiltersChange","setViewState","useState","setCurrentDateState","setFiltersState","setPreferencesState","DEFAULT_PREFERENCES","dateRange","useMemo","getViewDateRange","viewTitle","getViewTitle","result","filterEventsByDateRange","scheduleTypeIds","filterEventsByScheduleType","resourceIds","filterEventsByResource","search","filterEventsBySearch","filterOutCanceled","sortEventsByStart","useCallback","newView","date","newDate","navigateNext","navigatePrev","navigateToday","newFilters","updates","prev","next","emptyFilters","prefs","handleEventClick","event","handleSlotSelect","selection"],"mappings":"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"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { jsx as K } from "react/jsx-runtime";
|
|
2
|
+
import { createContext as Q, useContext as V, useState as D, useMemo as p, useCallback as s } from "react";
|
|
3
|
+
import { DEFAULT_PREFERENCES as X, getViewDateRange as Y, getViewTitle as Z, filterEventsByDateRange as $, filterEventsByScheduleType as ee, filterEventsByResource as te, filterEventsBySearch as ne, filterOutCanceled as se, sortEventsByStart as re, navigateNext as oe, navigatePrev as ae, navigateToday as ce } from "./utils.mjs";
|
|
4
|
+
const x = Q(void 0);
|
|
5
|
+
function de({ children: t, value: n }) {
|
|
6
|
+
return /* @__PURE__ */ K(x.Provider, { value: n, children: t });
|
|
7
|
+
}
|
|
8
|
+
function v() {
|
|
9
|
+
const t = V(x);
|
|
10
|
+
if (!t)
|
|
11
|
+
throw new Error("useCalendarContext must be used within a CalendarProvider");
|
|
12
|
+
return t;
|
|
13
|
+
}
|
|
14
|
+
function fe() {
|
|
15
|
+
return V(x);
|
|
16
|
+
}
|
|
17
|
+
function Ce() {
|
|
18
|
+
const { view: t, setView: n } = v();
|
|
19
|
+
return { view: t, setView: n };
|
|
20
|
+
}
|
|
21
|
+
function ve() {
|
|
22
|
+
const { currentDate: t, setCurrentDate: n, goToNext: u, goToPrev: d, goToToday: h, goToDate: E } = v();
|
|
23
|
+
return { currentDate: t, setCurrentDate: n, goToNext: u, goToPrev: d, goToToday: h, goToDate: E };
|
|
24
|
+
}
|
|
25
|
+
function ge() {
|
|
26
|
+
const { events: t, filteredEvents: n } = v();
|
|
27
|
+
return { events: t, filteredEvents: n };
|
|
28
|
+
}
|
|
29
|
+
function De() {
|
|
30
|
+
const { filters: t, setFilters: n, updateFilters: u, clearFilters: d } = v();
|
|
31
|
+
return { filters: t, setFilters: n, updateFilters: u, clearFilters: d };
|
|
32
|
+
}
|
|
33
|
+
function he() {
|
|
34
|
+
const { preferences: t, setPreferences: n } = v();
|
|
35
|
+
return { preferences: t, setPreferences: n };
|
|
36
|
+
}
|
|
37
|
+
function Ee(t) {
|
|
38
|
+
const {
|
|
39
|
+
events: n,
|
|
40
|
+
resources: u = [],
|
|
41
|
+
scheduleTypes: d = [],
|
|
42
|
+
initialView: h = "week",
|
|
43
|
+
initialDate: E,
|
|
44
|
+
initialFilters: R = {},
|
|
45
|
+
preferences: B = {},
|
|
46
|
+
lockedPreferences: T = {},
|
|
47
|
+
locale: y = "en-US",
|
|
48
|
+
onViewChange: S,
|
|
49
|
+
onDateChange: P,
|
|
50
|
+
onEventClick: F,
|
|
51
|
+
onSlotSelect: m,
|
|
52
|
+
onFiltersChange: i
|
|
53
|
+
} = t, [r, I] = D(h), [o, N] = D(() => E ?? /* @__PURE__ */ new Date()), [f, w] = D(R), [C, O] = D(() => ({
|
|
54
|
+
...X,
|
|
55
|
+
...B,
|
|
56
|
+
...T
|
|
57
|
+
})), g = p(
|
|
58
|
+
() => Y(o, r, C.firstDayOfWeek),
|
|
59
|
+
[o, r, C.firstDayOfWeek]
|
|
60
|
+
), b = p(
|
|
61
|
+
() => Z(o, r, y),
|
|
62
|
+
[o, r, y]
|
|
63
|
+
), U = p(() => {
|
|
64
|
+
let e = [...n];
|
|
65
|
+
e = $(e, g.startDate, g.endDate);
|
|
66
|
+
const c = f.scheduleTypeIds;
|
|
67
|
+
c && c.length > 0 && (e = ee(e, c));
|
|
68
|
+
const l = f.resourceIds;
|
|
69
|
+
l && l.length > 0 && (e = te(e, l));
|
|
70
|
+
const k = f.search;
|
|
71
|
+
return k && (e = ne(e, k)), C.showCanceledEvents || (e = se(e)), re(e);
|
|
72
|
+
}, [n, g, f, C.showCanceledEvents]), W = s(
|
|
73
|
+
(e) => {
|
|
74
|
+
I(e), S?.(e);
|
|
75
|
+
},
|
|
76
|
+
[S]
|
|
77
|
+
), a = s(
|
|
78
|
+
(e) => {
|
|
79
|
+
N(e), P?.(e);
|
|
80
|
+
},
|
|
81
|
+
[P]
|
|
82
|
+
), j = s(() => {
|
|
83
|
+
const e = oe(o, r);
|
|
84
|
+
a(e);
|
|
85
|
+
}, [o, r, a]), A = s(() => {
|
|
86
|
+
const e = ae(o, r);
|
|
87
|
+
a(e);
|
|
88
|
+
}, [o, r, a]), L = s(() => {
|
|
89
|
+
a(ce());
|
|
90
|
+
}, [a]), M = s(
|
|
91
|
+
(e) => {
|
|
92
|
+
a(e);
|
|
93
|
+
},
|
|
94
|
+
[a]
|
|
95
|
+
), _ = s(
|
|
96
|
+
(e) => {
|
|
97
|
+
w(e), i?.(e);
|
|
98
|
+
},
|
|
99
|
+
[i]
|
|
100
|
+
), q = s(
|
|
101
|
+
(e) => {
|
|
102
|
+
w((c) => {
|
|
103
|
+
const l = { ...c, ...e };
|
|
104
|
+
return i?.(l), l;
|
|
105
|
+
});
|
|
106
|
+
},
|
|
107
|
+
[i]
|
|
108
|
+
), z = s(() => {
|
|
109
|
+
const e = {};
|
|
110
|
+
w(e), i?.(e);
|
|
111
|
+
}, [i]), G = s(
|
|
112
|
+
(e) => {
|
|
113
|
+
O((c) => ({
|
|
114
|
+
...c,
|
|
115
|
+
...e,
|
|
116
|
+
...T
|
|
117
|
+
// Locked prefs always override
|
|
118
|
+
}));
|
|
119
|
+
},
|
|
120
|
+
[T]
|
|
121
|
+
), H = s(
|
|
122
|
+
(e) => {
|
|
123
|
+
F?.(e);
|
|
124
|
+
},
|
|
125
|
+
[F]
|
|
126
|
+
), J = s(
|
|
127
|
+
(e) => {
|
|
128
|
+
m?.(e);
|
|
129
|
+
},
|
|
130
|
+
[m]
|
|
131
|
+
);
|
|
132
|
+
return {
|
|
133
|
+
// State
|
|
134
|
+
view: r,
|
|
135
|
+
currentDate: o,
|
|
136
|
+
dateRange: g,
|
|
137
|
+
filters: f,
|
|
138
|
+
preferences: C,
|
|
139
|
+
// Computed
|
|
140
|
+
filteredEvents: U,
|
|
141
|
+
viewTitle: b,
|
|
142
|
+
// Data
|
|
143
|
+
events: n,
|
|
144
|
+
resources: u,
|
|
145
|
+
scheduleTypes: d,
|
|
146
|
+
// Actions
|
|
147
|
+
setView: W,
|
|
148
|
+
setCurrentDate: a,
|
|
149
|
+
goToNext: j,
|
|
150
|
+
goToPrev: A,
|
|
151
|
+
goToToday: L,
|
|
152
|
+
goToDate: M,
|
|
153
|
+
// Filters
|
|
154
|
+
setFilters: _,
|
|
155
|
+
updateFilters: q,
|
|
156
|
+
clearFilters: z,
|
|
157
|
+
// Preferences
|
|
158
|
+
setPreferences: G,
|
|
159
|
+
// Event handlers
|
|
160
|
+
handleEventClick: H,
|
|
161
|
+
handleSlotSelect: J
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
export {
|
|
165
|
+
de as C,
|
|
166
|
+
v as a,
|
|
167
|
+
ve as b,
|
|
168
|
+
ge as c,
|
|
169
|
+
De as d,
|
|
170
|
+
he as e,
|
|
171
|
+
Ce as f,
|
|
172
|
+
fe as g,
|
|
173
|
+
Ee as u
|
|
174
|
+
};
|
|
175
|
+
//# sourceMappingURL=use-calendar-Clo9DFK4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-calendar-Clo9DFK4.js","sources":["../src/core/context/calendar-context.tsx","../src/core/hooks/use-calendar.ts"],"sourcesContent":["/**\n * CalendarContext - React Context for Calendar State\n *\n * Provides calendar state to deeply nested components without prop drilling.\n */\n\nimport { createContext, type ReactNode, useContext } from 'react';\nimport type { UseCalendarReturn } from '../hooks/use-calendar';\n\n// ============================================================================\n// CONTEXT\n// ============================================================================\n\n/**\n * Calendar context type - generic to support any event data type\n * We use `any` here because context consumers may not know the exact type\n * Use the typed hooks below for type-safe access\n */\n// biome-ignore lint/suspicious/noExplicitAny: Context needs to be flexible for different event types\nconst CalendarContext = createContext<UseCalendarReturn<any, any, any> | undefined>(undefined);\n\n// ============================================================================\n// PROVIDER\n// ============================================================================\n\nexport interface CalendarProviderProps<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\tchildren: ReactNode;\n\tvalue: UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData>;\n}\n\nexport function CalendarProvider<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>({ children, value }: CalendarProviderProps<TEventData, TScheduleTypeData, TResourceData>) {\n\treturn <CalendarContext.Provider value={value}>{children}</CalendarContext.Provider>;\n}\n\n// ============================================================================\n// HOOKS\n// ============================================================================\n\n/**\n * Get the full calendar context (throws if not in provider)\n */\nexport function useCalendarContext<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> {\n\tconst context = useContext(CalendarContext);\n\tif (!context) {\n\t\tthrow new Error('useCalendarContext must be used within a CalendarProvider');\n\t}\n\treturn context as UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData>;\n}\n\n/**\n * Get the calendar context or undefined (safe version)\n */\nexport function useOptionalCalendarContext<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> | undefined {\n\tconst context = useContext(CalendarContext);\n\treturn context as UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> | undefined;\n}\n\n// ============================================================================\n// CONVENIENCE HOOKS\n// ============================================================================\n\n/**\n * Get current view\n */\nexport function useCalendarView() {\n\tconst { view, setView } = useCalendarContext();\n\treturn { view, setView };\n}\n\n/**\n * Get current date and navigation\n */\nexport function useCalendarDate() {\n\tconst { currentDate, setCurrentDate, goToNext, goToPrev, goToToday, goToDate } =\n\t\tuseCalendarContext();\n\treturn { currentDate, setCurrentDate, goToNext, goToPrev, goToToday, goToDate };\n}\n\n/**\n * Get filtered events\n */\nexport function useCalendarEvents<TEventData = Record<string, unknown>>() {\n\tconst { events, filteredEvents } = useCalendarContext<TEventData>();\n\treturn { events, filteredEvents };\n}\n\n/**\n * Get filters\n */\nexport function useCalendarFilters() {\n\tconst { filters, setFilters, updateFilters, clearFilters } = useCalendarContext();\n\treturn { filters, setFilters, updateFilters, clearFilters };\n}\n\n/**\n * Get preferences\n */\nexport function useCalendarPreferences() {\n\tconst { preferences, setPreferences } = useCalendarContext();\n\treturn { preferences, setPreferences };\n}\n\n// ============================================================================\n// ALIASES (for agenda-v2 naming convention compatibility)\n// ============================================================================\n\n/**\n * Alias for useCalendarContext - matches agenda-v2 naming convention\n */\nexport { useCalendarContext as useCalendar };\n\n/**\n * Alias for useOptionalCalendarContext - matches agenda-v2 naming convention\n */\nexport { useOptionalCalendarContext as useOptionalCalendar };\n","/**\n * useCalendar - Main Calendar Hook\n *\n * This hook provides all the state and methods needed to build a calendar.\n * It is fully generic, allowing consumers to define their own event data types.\n *\n * @example\n * ```tsx\n * interface MyEventData {\n * projectId: number;\n * priority: 'low' | 'medium' | 'high';\n * }\n *\n * const calendar = useCalendar<MyEventData>({\n * events: myEvents,\n * onEventClick: (event) => {\n * console.log(event.data?.projectId);\n * },\n * });\n * ```\n */\n\nimport { useCallback, useMemo, useState } from 'react';\nimport { DEFAULT_PREFERENCES } from '../constants';\nimport type {\n\tCalendarEvent,\n\tICalendarFilters,\n\tICalendarPreferences,\n\tIDateRange,\n\tIResource,\n\tIScheduleType,\n\tISelectionResult,\n\tTCalendarView,\n} from '../types';\nimport {\n\tfilterEventsByDateRange,\n\tfilterEventsByResource,\n\tfilterEventsByScheduleType,\n\tfilterEventsBySearch,\n\tfilterOutCanceled,\n\tsortEventsByStart,\n} from '../utils/event-utils';\nimport {\n\tgetViewDateRange,\n\tgetViewTitle,\n\tnavigateNext,\n\tnavigatePrev,\n\tnavigateToday,\n} from '../utils/grid-utils';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/**\n * Options for useCalendar hook\n */\nexport interface UseCalendarOptions<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t/** Events to display */\n\tevents: CalendarEvent<TEventData>[];\n\n\t/** Available resources (for resource views) */\n\tresources?: IResource<TResourceData>[] | undefined;\n\n\t/** Available schedule types */\n\tscheduleTypes?: IScheduleType<TScheduleTypeData>[] | undefined;\n\n\t/** Initial view */\n\tinitialView?: TCalendarView | undefined;\n\n\t/** Initial date */\n\tinitialDate?: Date | undefined;\n\n\t/** Initial filters */\n\tinitialFilters?: ICalendarFilters | undefined;\n\n\t/** User preferences */\n\tpreferences?: Partial<ICalendarPreferences> | undefined;\n\n\t/** Locked preferences (cannot be changed by user) */\n\tlockedPreferences?: Partial<ICalendarPreferences> | undefined;\n\n\t/** Locale for formatting */\n\tlocale?: string | undefined;\n\n\t/** Callback when view changes */\n\tonViewChange?: ((view: TCalendarView) => void) | undefined;\n\n\t/** Callback when date changes */\n\tonDateChange?: ((date: Date) => void) | undefined;\n\n\t/** Callback when event is clicked */\n\tonEventClick?: ((event: CalendarEvent<TEventData>) => void) | undefined;\n\n\t/** Callback when slot is selected */\n\tonSlotSelect?: ((selection: ISelectionResult) => void) | undefined;\n\n\t/** Callback when filters change */\n\tonFiltersChange?: ((filters: ICalendarFilters) => void) | undefined;\n}\n\n/**\n * Return type for useCalendar hook\n */\nexport interface UseCalendarReturn<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n> {\n\t// State\n\tview: TCalendarView;\n\tcurrentDate: Date;\n\tdateRange: IDateRange;\n\tfilters: ICalendarFilters;\n\tpreferences: ICalendarPreferences;\n\n\t// Computed\n\tfilteredEvents: CalendarEvent<TEventData>[];\n\tviewTitle: string;\n\n\t// Data\n\tevents: CalendarEvent<TEventData>[];\n\tresources: IResource<TResourceData>[];\n\tscheduleTypes: IScheduleType<TScheduleTypeData>[];\n\n\t// Actions\n\tsetView: (view: TCalendarView) => void;\n\tsetCurrentDate: (date: Date) => void;\n\tgoToNext: () => void;\n\tgoToPrev: () => void;\n\tgoToToday: () => void;\n\tgoToDate: (date: Date) => void;\n\n\t// Filters\n\tsetFilters: (filters: ICalendarFilters) => void;\n\tupdateFilters: (updates: Partial<ICalendarFilters>) => void;\n\tclearFilters: () => void;\n\n\t// Preferences\n\tsetPreferences: (prefs: Partial<ICalendarPreferences>) => void;\n\n\t// Event handlers\n\thandleEventClick: (event: CalendarEvent<TEventData>) => void;\n\thandleSlotSelect: (selection: ISelectionResult) => void;\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function useCalendar<\n\tTEventData = Record<string, unknown>,\n\tTScheduleTypeData = Record<string, unknown>,\n\tTResourceData = Record<string, unknown>,\n>(\n\toptions: UseCalendarOptions<TEventData, TScheduleTypeData, TResourceData>\n): UseCalendarReturn<TEventData, TScheduleTypeData, TResourceData> {\n\tconst {\n\t\tevents,\n\t\tresources = [],\n\t\tscheduleTypes = [],\n\t\tinitialView = 'week',\n\t\tinitialDate,\n\t\tinitialFilters = {},\n\t\tpreferences: userPreferences = {},\n\t\tlockedPreferences = {},\n\t\tlocale = 'en-US',\n\t\tonViewChange,\n\t\tonDateChange,\n\t\tonEventClick,\n\t\tonSlotSelect,\n\t\tonFiltersChange,\n\t} = options;\n\n\t// ========================================================================\n\t// STATE\n\t// ========================================================================\n\n\tconst [view, setViewState] = useState<TCalendarView>(initialView);\n\tconst [currentDate, setCurrentDateState] = useState<Date>(() => initialDate ?? new Date());\n\tconst [filters, setFiltersState] = useState<ICalendarFilters>(initialFilters);\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => ({\n\t\t...DEFAULT_PREFERENCES,\n\t\t...userPreferences,\n\t\t...lockedPreferences,\n\t}));\n\n\t// ========================================================================\n\t// COMPUTED\n\t// ========================================================================\n\n\tconst dateRange = useMemo(\n\t\t() => getViewDateRange(currentDate, view, preferences.firstDayOfWeek),\n\t\t[currentDate, view, preferences.firstDayOfWeek]\n\t);\n\n\tconst viewTitle = useMemo(\n\t\t() => getViewTitle(currentDate, view, locale),\n\t\t[currentDate, view, locale]\n\t);\n\n\tconst filteredEvents = useMemo(() => {\n\t\tlet result = [...events];\n\n\t\t// Filter by date range\n\t\tresult = filterEventsByDateRange(result, dateRange.startDate, dateRange.endDate);\n\n\t\t// Filter by schedule types\n\t\tconst scheduleTypeIds = filters.scheduleTypeIds;\n\t\tif (scheduleTypeIds && scheduleTypeIds.length > 0) {\n\t\t\tresult = filterEventsByScheduleType(result, scheduleTypeIds);\n\t\t}\n\n\t\t// Filter by resources\n\t\tconst resourceIds = filters.resourceIds;\n\t\tif (resourceIds && resourceIds.length > 0) {\n\t\t\tresult = filterEventsByResource(result, resourceIds);\n\t\t}\n\n\t\t// Filter by search\n\t\tconst search = filters.search;\n\t\tif (search) {\n\t\t\tresult = filterEventsBySearch(result, search);\n\t\t}\n\n\t\t// Filter canceled\n\t\tif (!preferences.showCanceledEvents) {\n\t\t\tresult = filterOutCanceled(result);\n\t\t}\n\n\t\t// Sort by start date\n\t\treturn sortEventsByStart(result);\n\t}, [events, dateRange, filters, preferences.showCanceledEvents]);\n\n\t// ========================================================================\n\t// ACTIONS\n\t// ========================================================================\n\n\tconst setView = useCallback(\n\t\t(newView: TCalendarView) => {\n\t\t\tsetViewState(newView);\n\t\t\tonViewChange?.(newView);\n\t\t},\n\t\t[onViewChange]\n\t);\n\n\tconst setCurrentDate = useCallback(\n\t\t(date: Date) => {\n\t\t\tsetCurrentDateState(date);\n\t\t\tonDateChange?.(date);\n\t\t},\n\t\t[onDateChange]\n\t);\n\n\tconst goToNext = useCallback(() => {\n\t\tconst newDate = navigateNext(currentDate, view);\n\t\tsetCurrentDate(newDate);\n\t}, [currentDate, view, setCurrentDate]);\n\n\tconst goToPrev = useCallback(() => {\n\t\tconst newDate = navigatePrev(currentDate, view);\n\t\tsetCurrentDate(newDate);\n\t}, [currentDate, view, setCurrentDate]);\n\n\tconst goToToday = useCallback(() => {\n\t\tsetCurrentDate(navigateToday());\n\t}, [setCurrentDate]);\n\n\tconst goToDate = useCallback(\n\t\t(date: Date) => {\n\t\t\tsetCurrentDate(date);\n\t\t},\n\t\t[setCurrentDate]\n\t);\n\n\t// ========================================================================\n\t// FILTERS\n\t// ========================================================================\n\n\tconst setFilters = useCallback(\n\t\t(newFilters: ICalendarFilters) => {\n\t\t\tsetFiltersState(newFilters);\n\t\t\tonFiltersChange?.(newFilters);\n\t\t},\n\t\t[onFiltersChange]\n\t);\n\n\tconst updateFilters = useCallback(\n\t\t(updates: Partial<ICalendarFilters>) => {\n\t\t\tsetFiltersState((prev) => {\n\t\t\t\tconst next = { ...prev, ...updates };\n\t\t\t\tonFiltersChange?.(next);\n\t\t\t\treturn next;\n\t\t\t});\n\t\t},\n\t\t[onFiltersChange]\n\t);\n\n\tconst clearFilters = useCallback(() => {\n\t\tconst emptyFilters: ICalendarFilters = {};\n\t\tsetFiltersState(emptyFilters);\n\t\tonFiltersChange?.(emptyFilters);\n\t}, [onFiltersChange]);\n\n\t// ========================================================================\n\t// PREFERENCES\n\t// ========================================================================\n\n\tconst setPreferences = useCallback(\n\t\t(prefs: Partial<ICalendarPreferences>) => {\n\t\t\tsetPreferencesState((prev) => ({\n\t\t\t\t...prev,\n\t\t\t\t...prefs,\n\t\t\t\t...lockedPreferences, // Locked prefs always override\n\t\t\t}));\n\t\t},\n\t\t[lockedPreferences]\n\t);\n\n\t// ========================================================================\n\t// EVENT HANDLERS\n\t// ========================================================================\n\n\tconst handleEventClick = useCallback(\n\t\t(event: CalendarEvent<TEventData>) => {\n\t\t\tonEventClick?.(event);\n\t\t},\n\t\t[onEventClick]\n\t);\n\n\tconst handleSlotSelect = useCallback(\n\t\t(selection: ISelectionResult) => {\n\t\t\tonSlotSelect?.(selection);\n\t\t},\n\t\t[onSlotSelect]\n\t);\n\n\t// ========================================================================\n\t// RETURN\n\t// ========================================================================\n\n\treturn {\n\t\t// State\n\t\tview,\n\t\tcurrentDate,\n\t\tdateRange,\n\t\tfilters,\n\t\tpreferences,\n\n\t\t// Computed\n\t\tfilteredEvents,\n\t\tviewTitle,\n\n\t\t// Data\n\t\tevents,\n\t\tresources,\n\t\tscheduleTypes,\n\n\t\t// Actions\n\t\tsetView,\n\t\tsetCurrentDate,\n\t\tgoToNext,\n\t\tgoToPrev,\n\t\tgoToToday,\n\t\tgoToDate,\n\n\t\t// Filters\n\t\tsetFilters,\n\t\tupdateFilters,\n\t\tclearFilters,\n\n\t\t// Preferences\n\t\tsetPreferences,\n\n\t\t// Event handlers\n\t\thandleEventClick,\n\t\thandleSlotSelect,\n\t};\n}\n"],"names":["CalendarContext","createContext","CalendarProvider","children","value","jsx","useCalendarContext","context","useContext","useOptionalCalendarContext","useCalendarView","view","setView","useCalendarDate","currentDate","setCurrentDate","goToNext","goToPrev","goToToday","goToDate","useCalendarEvents","events","filteredEvents","useCalendarFilters","filters","setFilters","updateFilters","clearFilters","useCalendarPreferences","preferences","setPreferences","useCalendar","options","resources","scheduleTypes","initialView","initialDate","initialFilters","userPreferences","lockedPreferences","locale","onViewChange","onDateChange","onEventClick","onSlotSelect","onFiltersChange","setViewState","useState","setCurrentDateState","setFiltersState","setPreferencesState","DEFAULT_PREFERENCES","dateRange","useMemo","getViewDateRange","viewTitle","getViewTitle","result","filterEventsByDateRange","scheduleTypeIds","filterEventsByScheduleType","resourceIds","filterEventsByResource","search","filterEventsBySearch","filterOutCanceled","sortEventsByStart","useCallback","newView","date","newDate","navigateNext","navigatePrev","navigateToday","newFilters","updates","prev","next","emptyFilters","prefs","handleEventClick","event","handleSlotSelect","selection"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { useMemo as p, useCallback as i, useState as E, useEffect as M, useRef as O } from "react";
|
|
2
|
-
import {
|
|
2
|
+
import { a as x } from "./use-calendar-Clo9DFK4.js";
|
|
3
3
|
import { DEFAULT_PREFERENCES as Y, DEFAULT_HOUR_HEIGHT as k, yToTime as w, addMinutes as I } from "./utils.mjs";
|
|
4
4
|
function L() {
|
|
5
5
|
const { preferences: e, setPreferences: n } = x(), s = p(
|
|
@@ -185,4 +185,4 @@ export {
|
|
|
185
185
|
W as b,
|
|
186
186
|
L as u
|
|
187
187
|
};
|
|
188
|
-
//# sourceMappingURL=use-slot-selection-
|
|
188
|
+
//# sourceMappingURL=use-slot-selection-BCZKnZSM.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-slot-selection-BJHlyfxL.js","sources":["../src/core/hooks/use-calendar-time-config.ts","../src/core/hooks/use-preferences.ts","../src/core/hooks/use-slot-selection.ts"],"sourcesContent":["/**\n * useCalendarTimeConfig - Time Configuration Hook\n *\n * Convenience hook that provides access to time-related preferences\n * from the calendar context. Matches agenda-v2 naming conventions.\n *\n * @example\n * ```tsx\n * function TimeSettings() {\n * const {\n * visibleHours,\n * setVisibleHours,\n * workingHours,\n * setWorkingHours,\n * slotDuration,\n * setSlotDuration,\n * showWorkingHoursOnly,\n * setShowWorkingHoursOnly,\n * } = useCalendarTimeConfig();\n *\n * return (\n * <div>\n * <p>Visible: {visibleHours.from}:00 - {visibleHours.to}:00</p>\n * <p>Slot duration: {slotDuration} minutes</p>\n * </div>\n * );\n * }\n * ```\n */\n\nimport { useCallback, useMemo } from 'react';\nimport { useCalendarContext } from '../context/calendar-context';\nimport type { IVisibleHoursConfig, TWorkingHoursConfig } from '../preferences/types';\nimport type { TSlotDuration } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UseCalendarTimeConfigReturn {\n\t/** Current visible hours range */\n\tvisibleHours: IVisibleHoursConfig;\n\t/** Update visible hours */\n\tsetVisibleHours: (hours: IVisibleHoursConfig) => void;\n\t/** Current working hours configuration */\n\tworkingHours: TWorkingHoursConfig;\n\t/** Update working hours */\n\tsetWorkingHours: (hours: TWorkingHoursConfig) => void;\n\t/** Current slot duration in minutes */\n\tslotDuration: TSlotDuration;\n\t/** Update slot duration */\n\tsetSlotDuration: (duration: TSlotDuration) => void;\n\t/** Whether to show only working hours */\n\tshowWorkingHoursOnly: boolean;\n\t/** Toggle show working hours only */\n\tsetShowWorkingHoursOnly: (show: boolean) => void;\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\n/**\n * Get time configuration from calendar context\n *\n * Provides a focused subset of calendar preferences related to time display.\n * All setters will update the underlying preferences in the calendar context.\n *\n * Note: This hook maps the core preferences (startHour/endHour) to the\n * agenda-v2 naming convention (visibleHours.from/to, workingHours).\n */\nexport function useCalendarTimeConfig(): UseCalendarTimeConfigReturn {\n\tconst { preferences, setPreferences } = useCalendarContext();\n\n\t// Map core preferences to visible hours format\n\tconst visibleHours = useMemo<IVisibleHoursConfig>(\n\t\t() => ({\n\t\t\tfrom: preferences.startHour,\n\t\t\tto: preferences.endHour,\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\t// Default working hours based on visible hours (can be extended later)\n\tconst workingHours = useMemo<TWorkingHoursConfig>(\n\t\t() => ({\n\t\t\t// Default: Mon-Fri same hours\n\t\t\t1: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t2: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t3: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t4: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t5: { from: preferences.startHour, to: preferences.endHour },\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\tconst setVisibleHours = useCallback(\n\t\t(hours: IVisibleHoursConfig) => {\n\t\t\tsetPreferences({\n\t\t\t\tstartHour: hours.from,\n\t\t\t\tendHour: hours.to,\n\t\t\t});\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setWorkingHours = useCallback(\n\t\t(_hours: TWorkingHoursConfig) => {\n\t\t\t// Working hours per-day config would need to be added to core preferences\n\t\t\t// For now, we use the first available day's hours to set visible hours\n\t\t\tconst firstDay = Object.values(_hours)[0];\n\t\t\tif (firstDay) {\n\t\t\t\tsetPreferences({\n\t\t\t\t\tstartHour: firstDay.from,\n\t\t\t\t\tendHour: firstDay.to,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setSlotDuration = useCallback(\n\t\t(duration: TSlotDuration) => {\n\t\t\tsetPreferences({ slotDuration: duration });\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setShowWorkingHoursOnly = useCallback((_show: boolean) => {\n\t\t// This would need to be added to ICalendarPreferences\n\t\t// For now, this is a no-op but provides the API surface\n\t\tconsole.warn('showWorkingHoursOnly is not yet supported in core preferences');\n\t}, []);\n\n\treturn {\n\t\tvisibleHours,\n\t\tsetVisibleHours,\n\t\tworkingHours,\n\t\tsetWorkingHours,\n\t\tslotDuration: preferences.slotDuration as TSlotDuration,\n\t\tsetSlotDuration,\n\t\tshowWorkingHoursOnly: false, // Default until added to core preferences\n\t\tsetShowWorkingHoursOnly,\n\t};\n}\n","/**\n * usePreferences - Calendar Preferences Hook\n *\n * Manages user preferences with optional localStorage persistence.\n */\n\nimport { useCallback, useEffect, useState } from 'react';\nimport { DEFAULT_PREFERENCES } from '../constants';\nimport type { ICalendarPreferences } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UsePreferencesOptions {\n\t/** Initial preferences (overrides defaults) */\n\tinitial?: Partial<ICalendarPreferences>;\n\t/** Storage key for persistence (if provided, uses localStorage) */\n\tstorageKey?: string;\n\t/** Callback when preferences change */\n\tonChange?: (preferences: ICalendarPreferences) => void;\n}\n\nexport interface UsePreferencesReturn {\n\t/** Current preferences */\n\tpreferences: ICalendarPreferences;\n\t/** Update preferences */\n\tsetPreferences: (updates: Partial<ICalendarPreferences>) => void;\n\t/** Reset to defaults */\n\tresetPreferences: () => void;\n\t/** Get a specific preference */\n\tgetPreference: <K extends keyof ICalendarPreferences>(key: K) => ICalendarPreferences[K];\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function usePreferences(options: UsePreferencesOptions = {}): UsePreferencesReturn {\n\tconst { initial = {}, storageKey, onChange } = options;\n\n\t// Load from storage or use defaults\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => {\n\t\tif (storageKey && typeof window !== 'undefined') {\n\t\t\ttry {\n\t\t\t\tconst stored = localStorage.getItem(storageKey);\n\t\t\t\tif (stored) {\n\t\t\t\t\tconst parsed = JSON.parse(stored) as Partial<ICalendarPreferences>;\n\t\t\t\t\treturn { ...DEFAULT_PREFERENCES, ...parsed, ...initial };\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Ignore parsing errors\n\t\t\t}\n\t\t}\n\t\treturn { ...DEFAULT_PREFERENCES, ...initial };\n\t});\n\n\t// Persist to storage when preferences change\n\tuseEffect(() => {\n\t\tif (storageKey && typeof window !== 'undefined') {\n\t\t\ttry {\n\t\t\t\tlocalStorage.setItem(storageKey, JSON.stringify(preferences));\n\t\t\t} catch {\n\t\t\t\t// Ignore storage errors\n\t\t\t}\n\t\t}\n\t}, [preferences, storageKey]);\n\n\tconst setPreferences = useCallback(\n\t\t(updates: Partial<ICalendarPreferences>) => {\n\t\t\tsetPreferencesState((prev) => {\n\t\t\t\tconst next = { ...prev, ...updates };\n\t\t\t\tonChange?.(next);\n\t\t\t\treturn next;\n\t\t\t});\n\t\t},\n\t\t[onChange]\n\t);\n\n\tconst resetPreferences = useCallback(() => {\n\t\tconst defaults = { ...DEFAULT_PREFERENCES, ...initial };\n\t\tsetPreferencesState(defaults);\n\t\tonChange?.(defaults);\n\t}, [initial, onChange]);\n\n\tconst getPreference = useCallback(\n\t\t<K extends keyof ICalendarPreferences>(key: K): ICalendarPreferences[K] => {\n\t\t\treturn preferences[key];\n\t\t},\n\t\t[preferences]\n\t);\n\n\treturn {\n\t\tpreferences,\n\t\tsetPreferences,\n\t\tresetPreferences,\n\t\tgetPreference,\n\t};\n}\n","/**\n * useSlotSelection - Drag-to-Select Hook\n *\n * Handles mouse/touch interactions for creating events by\n * selecting time slots in the calendar grid.\n */\n\nimport { useCallback, useRef, useState } from 'react';\nimport { DEFAULT_HOUR_HEIGHT } from '../constants';\nimport type { ISelectionResult, ISlotSelection, IVisibleHours } from '../types';\nimport { addMinutes } from '../utils/date-utils';\nimport { yToTime } from '../utils/position-utils';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UseSlotSelectionOptions {\n\t/** Current day being selected on */\n\tdayStart: Date;\n\t/** Visible hours configuration */\n\tvisibleHours: IVisibleHours;\n\t/** Height of one hour in pixels */\n\thourHeight?: number;\n\t/** Slot duration in minutes for snapping */\n\tslotDuration?: number;\n\t/** Resource ID (for resource views) */\n\tresourceId?: string;\n\t/** Whether selection is enabled */\n\tenabled?: boolean;\n\t/** Callback when selection completes */\n\tonSelect?: (selection: ISelectionResult) => void;\n}\n\nexport interface UseSlotSelectionReturn {\n\t/** Current selection state */\n\tselection: ISlotSelection;\n\t/** Selection overlay for rendering */\n\toverlay: { top: number; height: number; visible: boolean };\n\t/** Handler for mouse/touch down */\n\thandlePointerDown: (e: React.PointerEvent, containerRect: DOMRect) => void;\n\t/** Handler for mouse/touch move */\n\thandlePointerMove: (e: React.PointerEvent, containerRect: DOMRect) => void;\n\t/** Handler for mouse/touch up */\n\thandlePointerUp: () => void;\n\t/** Cancel current selection */\n\tcancel: () => void;\n\t/** Whether currently selecting */\n\tisSelecting: boolean;\n}\n\n// ============================================================================\n// INITIAL STATE\n// ============================================================================\n\nconst INITIAL_SELECTION: ISlotSelection = {\n\tisSelecting: false,\n\tstartDate: null,\n\tendDate: null,\n\tstartY: null,\n\tcurrentY: null,\n\tresourceId: undefined,\n};\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function useSlotSelection(options: UseSlotSelectionOptions): UseSlotSelectionReturn {\n\tconst {\n\t\tdayStart,\n\t\tvisibleHours,\n\t\thourHeight = DEFAULT_HOUR_HEIGHT,\n\t\tslotDuration = 30,\n\t\tresourceId,\n\t\tenabled = true,\n\t\tonSelect,\n\t} = options;\n\n\tconst [selection, setSelection] = useState<ISlotSelection>(INITIAL_SELECTION);\n\tconst containerHeightRef = useRef<number>(0);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handlePointerDown = useCallback(\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\n\t\t\tif (!enabled) return;\n\n\t\t\tconst y = e.clientY - containerRect.top;\n\t\t\tcontainerHeightRef.current = containerRect.height;\n\n\t\t\tconst startTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\n\n\t\t\tsetSelection({\n\t\t\t\tisSelecting: true,\n\t\t\t\tstartDate: startTime,\n\t\t\t\tendDate: addMinutes(startTime, slotDuration),\n\t\t\t\tstartY: y,\n\t\t\t\tcurrentY: y,\n\t\t\t\tresourceId,\n\t\t\t});\n\t\t},\n\t\t[enabled, dayStart, visibleHours, hourHeight, slotDuration, resourceId]\n\t);\n\n\tconst handlePointerMove = useCallback(\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\n\t\t\tif (!selection.isSelecting || !selection.startY) return;\n\n\t\t\tconst y = Math.max(0, Math.min(e.clientY - containerRect.top, containerRect.height));\n\t\t\tconst currentTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\n\n\t\t\tsetSelection((prev) => {\n\t\t\t\tif (!prev.startDate) return prev;\n\n\t\t\t\t// Determine if dragging up or down\n\t\t\t\tconst isDraggingDown = y >= (prev.startY ?? 0);\n\n\t\t\t\treturn {\n\t\t\t\t\t...prev,\n\t\t\t\t\tcurrentY: y,\n\t\t\t\t\tendDate: isDraggingDown ? addMinutes(currentTime, slotDuration) : currentTime,\n\t\t\t\t\tstartDate: isDraggingDown ? prev.startDate : currentTime,\n\t\t\t\t};\n\t\t\t});\n\t\t},\n\t\t[selection.isSelecting, selection.startY, dayStart, visibleHours, hourHeight, slotDuration]\n\t);\n\n\tconst handlePointerUp = useCallback(() => {\n\t\tif (!selection.isSelecting || !selection.startDate || !selection.endDate) {\n\t\t\tsetSelection(INITIAL_SELECTION);\n\t\t\treturn;\n\t\t}\n\n\t\t// Ensure start is before end\n\t\tconst start = selection.startDate < selection.endDate ? selection.startDate : selection.endDate;\n\t\tconst end = selection.startDate < selection.endDate ? selection.endDate : selection.startDate;\n\n\t\tconst result: ISelectionResult = {\n\t\t\tstartDate: start,\n\t\t\tendDate: end,\n\t\t\tresourceId: selection.resourceId,\n\t\t};\n\n\t\tonSelect?.(result);\n\t\tsetSelection(INITIAL_SELECTION);\n\t}, [selection, onSelect]);\n\n\tconst cancel = useCallback(() => {\n\t\tsetSelection(INITIAL_SELECTION);\n\t}, []);\n\n\t// ========================================================================\n\t// OVERLAY CALCULATION\n\t// ========================================================================\n\n\tconst overlay = (() => {\n\t\tif (!selection.isSelecting || selection.startY === null || selection.currentY === null) {\n\t\t\treturn { top: 0, height: 0, visible: false };\n\t\t}\n\n\t\tconst minY = Math.min(selection.startY, selection.currentY);\n\t\tconst maxY = Math.max(selection.startY, selection.currentY);\n\n\t\treturn {\n\t\t\ttop: minY,\n\t\t\theight: Math.max(maxY - minY, 20), // Minimum height\n\t\t\tvisible: true,\n\t\t};\n\t})();\n\n\t// ========================================================================\n\t// RETURN\n\t// ========================================================================\n\n\treturn {\n\t\tselection,\n\t\toverlay,\n\t\thandlePointerDown,\n\t\thandlePointerMove,\n\t\thandlePointerUp,\n\t\tcancel,\n\t\tisSelecting: selection.isSelecting,\n\t};\n}\n"],"names":["useCalendarTimeConfig","preferences","setPreferences","useCalendarContext","visibleHours","useMemo","workingHours","setVisibleHours","useCallback","hours","setWorkingHours","_hours","firstDay","setSlotDuration","duration","setShowWorkingHoursOnly","_show","usePreferences","options","initial","storageKey","onChange","setPreferencesState","useState","stored","parsed","DEFAULT_PREFERENCES","useEffect","updates","prev","next","resetPreferences","defaults","getPreference","key","INITIAL_SELECTION","useSlotSelection","dayStart","hourHeight","DEFAULT_HOUR_HEIGHT","slotDuration","resourceId","enabled","onSelect","selection","setSelection","containerHeightRef","useRef","handlePointerDown","e","containerRect","y","startTime","yToTime","addMinutes","handlePointerMove","currentTime","isDraggingDown","handlePointerUp","start","end","result","cancel","overlay","minY","maxY"],"mappings":";;;AAuEO,SAASA,IAAqD;AACpE,QAAM,EAAE,aAAAC,GAAa,gBAAAC,EAAA,IAAmBC,EAAA,GAGlCC,IAAeC;AAAA,IACpB,OAAO;AAAA,MACN,MAAMJ,EAAY;AAAA,MAClB,IAAIA,EAAY;AAAA,IAAA;AAAA,IAEjB,CAACA,EAAY,WAAWA,EAAY,OAAO;AAAA,EAAA,GAItCK,IAAeD;AAAA,IACpB,OAAO;AAAA;AAAA,MAEN,GAAG,EAAE,MAAMJ,EAAY,WAAW,IAAIA,EAAY,QAAA;AAAA,MAClD,GAAG,EAAE,MAAMA,EAAY,WAAW,IAAIA,EAAY,QAAA;AAAA,MAClD,GAAG,EAAE,MAAMA,EAAY,WAAW,IAAIA,EAAY,QAAA;AAAA,MAClD,GAAG,EAAE,MAAMA,EAAY,WAAW,IAAIA,EAAY,QAAA;AAAA,MAClD,GAAG,EAAE,MAAMA,EAAY,WAAW,IAAIA,EAAY,QAAA;AAAA,IAAQ;AAAA,IAE3D,CAACA,EAAY,WAAWA,EAAY,OAAO;AAAA,EAAA,GAGtCM,IAAkBC;AAAA,IACvB,CAACC,MAA+B;AAC/B,MAAAP,EAAe;AAAA,QACd,WAAWO,EAAM;AAAA,QACjB,SAASA,EAAM;AAAA,MAAA,CACf;AAAA,IACF;AAAA,IACA,CAACP,CAAc;AAAA,EAAA,GAGVQ,IAAkBF;AAAA,IACvB,CAACG,MAAgC;AAGhC,YAAMC,IAAW,OAAO,OAAOD,CAAM,EAAE,CAAC;AACxC,MAAIC,KACHV,EAAe;AAAA,QACd,WAAWU,EAAS;AAAA,QACpB,SAASA,EAAS;AAAA,MAAA,CAClB;AAAA,IAEH;AAAA,IACA,CAACV,CAAc;AAAA,EAAA,GAGVW,IAAkBL;AAAA,IACvB,CAACM,MAA4B;AAC5B,MAAAZ,EAAe,EAAE,cAAcY,GAAU;AAAA,IAC1C;AAAA,IACA,CAACZ,CAAc;AAAA,EAAA,GAGVa,IAA0BP,EAAY,CAACQ,MAAmB;AAG/D,YAAQ,KAAK,+DAA+D;AAAA,EAC7E,GAAG,CAAA,CAAE;AAEL,SAAO;AAAA,IACN,cAAAZ;AAAA,IACA,iBAAAG;AAAA,IACA,cAAAD;AAAA,IACA,iBAAAI;AAAA,IACA,cAAcT,EAAY;AAAA,IAC1B,iBAAAY;AAAA,IACA,sBAAsB;AAAA;AAAA,IACtB,yBAAAE;AAAA,EAAA;AAEF;AC1GO,SAASE,EAAeC,IAAiC,IAA0B;AACzF,QAAM,EAAE,SAAAC,IAAU,CAAA,GAAI,YAAAC,GAAY,UAAAC,MAAaH,GAGzC,CAACjB,GAAaqB,CAAmB,IAAIC,EAA+B,MAAM;AAC/E,QAAIH,KAAc,OAAO,SAAW;AACnC,UAAI;AACH,cAAMI,IAAS,aAAa,QAAQJ,CAAU;AAC9C,YAAII,GAAQ;AACX,gBAAMC,IAAS,KAAK,MAAMD,CAAM;AAChC,iBAAO,EAAE,GAAGE,GAAqB,GAAGD,GAAQ,GAAGN,EAAA;AAAA,QAChD;AAAA,MACD,QAAQ;AAAA,MAER;AAED,WAAO,EAAE,GAAGO,GAAqB,GAAGP,EAAA;AAAA,EACrC,CAAC;AAGD,EAAAQ,EAAU,MAAM;AACf,QAAIP,KAAc,OAAO,SAAW;AACnC,UAAI;AACH,qBAAa,QAAQA,GAAY,KAAK,UAAUnB,CAAW,CAAC;AAAA,MAC7D,QAAQ;AAAA,MAER;AAAA,EAEF,GAAG,CAACA,GAAamB,CAAU,CAAC;AAE5B,QAAMlB,IAAiBM;AAAA,IACtB,CAACoB,MAA2C;AAC3C,MAAAN,EAAoB,CAACO,MAAS;AAC7B,cAAMC,IAAO,EAAE,GAAGD,GAAM,GAAGD,EAAA;AAC3B,eAAAP,IAAWS,CAAI,GACRA;AAAA,MACR,CAAC;AAAA,IACF;AAAA,IACA,CAACT,CAAQ;AAAA,EAAA,GAGJU,IAAmBvB,EAAY,MAAM;AAC1C,UAAMwB,IAAW,EAAE,GAAGN,GAAqB,GAAGP,EAAA;AAC9C,IAAAG,EAAoBU,CAAQ,GAC5BX,IAAWW,CAAQ;AAAA,EACpB,GAAG,CAACb,GAASE,CAAQ,CAAC,GAEhBY,IAAgBzB;AAAA,IACrB,CAAuC0B,MAC/BjC,EAAYiC,CAAG;AAAA,IAEvB,CAACjC,CAAW;AAAA,EAAA;AAGb,SAAO;AAAA,IACN,aAAAA;AAAA,IACA,gBAAAC;AAAA,IACA,kBAAA6B;AAAA,IACA,eAAAE;AAAA,EAAA;AAEF;AC3CA,MAAME,IAAoC;AAAA,EACzC,aAAa;AAAA,EACb,WAAW;AAAA,EACX,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,YAAY;AACb;AAMO,SAASC,EAAiBlB,GAA0D;AAC1F,QAAM;AAAA,IACL,UAAAmB;AAAA,IACA,cAAAjC;AAAA,IACA,YAAAkC,IAAaC;AAAA,IACb,cAAAC,IAAe;AAAA,IACf,YAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,UAAAC;AAAA,EAAA,IACGzB,GAEE,CAAC0B,GAAWC,CAAY,IAAItB,EAAyBY,CAAiB,GACtEW,IAAqBC,EAAe,CAAC,GAMrCC,IAAoBxC;AAAA,IACzB,CAACyC,GAAuBC,MAA2B;AAClD,UAAI,CAACR,EAAS;AAEd,YAAMS,IAAIF,EAAE,UAAUC,EAAc;AACpC,MAAAJ,EAAmB,UAAUI,EAAc;AAE3C,YAAME,IAAYC,EAAQF,GAAGd,GAAUjC,GAAckC,GAAYE,CAAY;AAE7E,MAAAK,EAAa;AAAA,QACZ,aAAa;AAAA,QACb,WAAWO;AAAA,QACX,SAASE,EAAWF,GAAWZ,CAAY;AAAA,QAC3C,QAAQW;AAAA,QACR,UAAUA;AAAA,QACV,YAAAV;AAAA,MAAA,CACA;AAAA,IACF;AAAA,IACA,CAACC,GAASL,GAAUjC,GAAckC,GAAYE,GAAcC,CAAU;AAAA,EAAA,GAGjEc,IAAoB/C;AAAA,IACzB,CAACyC,GAAuBC,MAA2B;AAClD,UAAI,CAACN,EAAU,eAAe,CAACA,EAAU,OAAQ;AAEjD,YAAMO,IAAI,KAAK,IAAI,GAAG,KAAK,IAAIF,EAAE,UAAUC,EAAc,KAAKA,EAAc,MAAM,CAAC,GAC7EM,IAAcH,EAAQF,GAAGd,GAAUjC,GAAckC,GAAYE,CAAY;AAE/E,MAAAK,EAAa,CAAChB,MAAS;AACtB,YAAI,CAACA,EAAK,UAAW,QAAOA;AAG5B,cAAM4B,IAAiBN,MAAMtB,EAAK,UAAU;AAE5C,eAAO;AAAA,UACN,GAAGA;AAAA,UACH,UAAUsB;AAAA,UACV,SAASM,IAAiBH,EAAWE,GAAahB,CAAY,IAAIgB;AAAA,UAClE,WAAWC,IAAiB5B,EAAK,YAAY2B;AAAA,QAAA;AAAA,MAE/C,CAAC;AAAA,IACF;AAAA,IACA,CAACZ,EAAU,aAAaA,EAAU,QAAQP,GAAUjC,GAAckC,GAAYE,CAAY;AAAA,EAAA,GAGrFkB,IAAkBlD,EAAY,MAAM;AACzC,QAAI,CAACoC,EAAU,eAAe,CAACA,EAAU,aAAa,CAACA,EAAU,SAAS;AACzE,MAAAC,EAAaV,CAAiB;AAC9B;AAAA,IACD;AAGA,UAAMwB,IAAQf,EAAU,YAAYA,EAAU,UAAUA,EAAU,YAAYA,EAAU,SAClFgB,IAAMhB,EAAU,YAAYA,EAAU,UAAUA,EAAU,UAAUA,EAAU,WAE9EiB,IAA2B;AAAA,MAChC,WAAWF;AAAA,MACX,SAASC;AAAA,MACT,YAAYhB,EAAU;AAAA,IAAA;AAGvB,IAAAD,IAAWkB,CAAM,GACjBhB,EAAaV,CAAiB;AAAA,EAC/B,GAAG,CAACS,GAAWD,CAAQ,CAAC,GAElBmB,IAAStD,EAAY,MAAM;AAChC,IAAAqC,EAAaV,CAAiB;AAAA,EAC/B,GAAG,CAAA,CAAE,GAMC4B,KAAW,MAAM;AACtB,QAAI,CAACnB,EAAU,eAAeA,EAAU,WAAW,QAAQA,EAAU,aAAa;AACjF,aAAO,EAAE,KAAK,GAAG,QAAQ,GAAG,SAAS,GAAA;AAGtC,UAAMoB,IAAO,KAAK,IAAIpB,EAAU,QAAQA,EAAU,QAAQ,GACpDqB,IAAO,KAAK,IAAIrB,EAAU,QAAQA,EAAU,QAAQ;AAE1D,WAAO;AAAA,MACN,KAAKoB;AAAA,MACL,QAAQ,KAAK,IAAIC,IAAOD,GAAM,EAAE;AAAA;AAAA,MAChC,SAAS;AAAA,IAAA;AAAA,EAEX,GAAA;AAMA,SAAO;AAAA,IACN,WAAApB;AAAA,IACA,SAAAmB;AAAA,IACA,mBAAAf;AAAA,IACA,mBAAAO;AAAA,IACA,iBAAAG;AAAA,IACA,QAAAI;AAAA,IACA,aAAalB,EAAU;AAAA,EAAA;AAEzB;"}
|
|
1
|
+
{"version":3,"file":"use-slot-selection-BCZKnZSM.js","sources":["../src/core/hooks/use-calendar-time-config.ts","../src/core/hooks/use-preferences.ts","../src/core/hooks/use-slot-selection.ts"],"sourcesContent":["/**\n * useCalendarTimeConfig - Time Configuration Hook\n *\n * Convenience hook that provides access to time-related preferences\n * from the calendar context. Matches agenda-v2 naming conventions.\n *\n * @example\n * ```tsx\n * function TimeSettings() {\n * const {\n * visibleHours,\n * setVisibleHours,\n * workingHours,\n * setWorkingHours,\n * slotDuration,\n * setSlotDuration,\n * showWorkingHoursOnly,\n * setShowWorkingHoursOnly,\n * } = useCalendarTimeConfig();\n *\n * return (\n * <div>\n * <p>Visible: {visibleHours.from}:00 - {visibleHours.to}:00</p>\n * <p>Slot duration: {slotDuration} minutes</p>\n * </div>\n * );\n * }\n * ```\n */\n\nimport { useCallback, useMemo } from 'react';\nimport { useCalendarContext } from '../context/calendar-context';\nimport type { IVisibleHoursConfig, TWorkingHoursConfig } from '../preferences/types';\nimport type { TSlotDuration } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UseCalendarTimeConfigReturn {\n\t/** Current visible hours range */\n\tvisibleHours: IVisibleHoursConfig;\n\t/** Update visible hours */\n\tsetVisibleHours: (hours: IVisibleHoursConfig) => void;\n\t/** Current working hours configuration */\n\tworkingHours: TWorkingHoursConfig;\n\t/** Update working hours */\n\tsetWorkingHours: (hours: TWorkingHoursConfig) => void;\n\t/** Current slot duration in minutes */\n\tslotDuration: TSlotDuration;\n\t/** Update slot duration */\n\tsetSlotDuration: (duration: TSlotDuration) => void;\n\t/** Whether to show only working hours */\n\tshowWorkingHoursOnly: boolean;\n\t/** Toggle show working hours only */\n\tsetShowWorkingHoursOnly: (show: boolean) => void;\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\n/**\n * Get time configuration from calendar context\n *\n * Provides a focused subset of calendar preferences related to time display.\n * All setters will update the underlying preferences in the calendar context.\n *\n * Note: This hook maps the core preferences (startHour/endHour) to the\n * agenda-v2 naming convention (visibleHours.from/to, workingHours).\n */\nexport function useCalendarTimeConfig(): UseCalendarTimeConfigReturn {\n\tconst { preferences, setPreferences } = useCalendarContext();\n\n\t// Map core preferences to visible hours format\n\tconst visibleHours = useMemo<IVisibleHoursConfig>(\n\t\t() => ({\n\t\t\tfrom: preferences.startHour,\n\t\t\tto: preferences.endHour,\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\t// Default working hours based on visible hours (can be extended later)\n\tconst workingHours = useMemo<TWorkingHoursConfig>(\n\t\t() => ({\n\t\t\t// Default: Mon-Fri same hours\n\t\t\t1: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t2: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t3: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t4: { from: preferences.startHour, to: preferences.endHour },\n\t\t\t5: { from: preferences.startHour, to: preferences.endHour },\n\t\t}),\n\t\t[preferences.startHour, preferences.endHour]\n\t);\n\n\tconst setVisibleHours = useCallback(\n\t\t(hours: IVisibleHoursConfig) => {\n\t\t\tsetPreferences({\n\t\t\t\tstartHour: hours.from,\n\t\t\t\tendHour: hours.to,\n\t\t\t});\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setWorkingHours = useCallback(\n\t\t(_hours: TWorkingHoursConfig) => {\n\t\t\t// Working hours per-day config would need to be added to core preferences\n\t\t\t// For now, we use the first available day's hours to set visible hours\n\t\t\tconst firstDay = Object.values(_hours)[0];\n\t\t\tif (firstDay) {\n\t\t\t\tsetPreferences({\n\t\t\t\t\tstartHour: firstDay.from,\n\t\t\t\t\tendHour: firstDay.to,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setSlotDuration = useCallback(\n\t\t(duration: TSlotDuration) => {\n\t\t\tsetPreferences({ slotDuration: duration });\n\t\t},\n\t\t[setPreferences]\n\t);\n\n\tconst setShowWorkingHoursOnly = useCallback((_show: boolean) => {\n\t\t// This would need to be added to ICalendarPreferences\n\t\t// For now, this is a no-op but provides the API surface\n\t\tconsole.warn('showWorkingHoursOnly is not yet supported in core preferences');\n\t}, []);\n\n\treturn {\n\t\tvisibleHours,\n\t\tsetVisibleHours,\n\t\tworkingHours,\n\t\tsetWorkingHours,\n\t\tslotDuration: preferences.slotDuration as TSlotDuration,\n\t\tsetSlotDuration,\n\t\tshowWorkingHoursOnly: false, // Default until added to core preferences\n\t\tsetShowWorkingHoursOnly,\n\t};\n}\n","/**\n * usePreferences - Calendar Preferences Hook\n *\n * Manages user preferences with optional localStorage persistence.\n */\n\nimport { useCallback, useEffect, useState } from 'react';\nimport { DEFAULT_PREFERENCES } from '../constants';\nimport type { ICalendarPreferences } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UsePreferencesOptions {\n\t/** Initial preferences (overrides defaults) */\n\tinitial?: Partial<ICalendarPreferences>;\n\t/** Storage key for persistence (if provided, uses localStorage) */\n\tstorageKey?: string;\n\t/** Callback when preferences change */\n\tonChange?: (preferences: ICalendarPreferences) => void;\n}\n\nexport interface UsePreferencesReturn {\n\t/** Current preferences */\n\tpreferences: ICalendarPreferences;\n\t/** Update preferences */\n\tsetPreferences: (updates: Partial<ICalendarPreferences>) => void;\n\t/** Reset to defaults */\n\tresetPreferences: () => void;\n\t/** Get a specific preference */\n\tgetPreference: <K extends keyof ICalendarPreferences>(key: K) => ICalendarPreferences[K];\n}\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function usePreferences(options: UsePreferencesOptions = {}): UsePreferencesReturn {\n\tconst { initial = {}, storageKey, onChange } = options;\n\n\t// Load from storage or use defaults\n\tconst [preferences, setPreferencesState] = useState<ICalendarPreferences>(() => {\n\t\tif (storageKey && typeof window !== 'undefined') {\n\t\t\ttry {\n\t\t\t\tconst stored = localStorage.getItem(storageKey);\n\t\t\t\tif (stored) {\n\t\t\t\t\tconst parsed = JSON.parse(stored) as Partial<ICalendarPreferences>;\n\t\t\t\t\treturn { ...DEFAULT_PREFERENCES, ...parsed, ...initial };\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Ignore parsing errors\n\t\t\t}\n\t\t}\n\t\treturn { ...DEFAULT_PREFERENCES, ...initial };\n\t});\n\n\t// Persist to storage when preferences change\n\tuseEffect(() => {\n\t\tif (storageKey && typeof window !== 'undefined') {\n\t\t\ttry {\n\t\t\t\tlocalStorage.setItem(storageKey, JSON.stringify(preferences));\n\t\t\t} catch {\n\t\t\t\t// Ignore storage errors\n\t\t\t}\n\t\t}\n\t}, [preferences, storageKey]);\n\n\tconst setPreferences = useCallback(\n\t\t(updates: Partial<ICalendarPreferences>) => {\n\t\t\tsetPreferencesState((prev) => {\n\t\t\t\tconst next = { ...prev, ...updates };\n\t\t\t\tonChange?.(next);\n\t\t\t\treturn next;\n\t\t\t});\n\t\t},\n\t\t[onChange]\n\t);\n\n\tconst resetPreferences = useCallback(() => {\n\t\tconst defaults = { ...DEFAULT_PREFERENCES, ...initial };\n\t\tsetPreferencesState(defaults);\n\t\tonChange?.(defaults);\n\t}, [initial, onChange]);\n\n\tconst getPreference = useCallback(\n\t\t<K extends keyof ICalendarPreferences>(key: K): ICalendarPreferences[K] => {\n\t\t\treturn preferences[key];\n\t\t},\n\t\t[preferences]\n\t);\n\n\treturn {\n\t\tpreferences,\n\t\tsetPreferences,\n\t\tresetPreferences,\n\t\tgetPreference,\n\t};\n}\n","/**\n * useSlotSelection - Drag-to-Select Hook\n *\n * Handles mouse/touch interactions for creating events by\n * selecting time slots in the calendar grid.\n */\n\nimport { useCallback, useRef, useState } from 'react';\nimport { DEFAULT_HOUR_HEIGHT } from '../constants';\nimport type { ISelectionResult, ISlotSelection, IVisibleHours } from '../types';\nimport { addMinutes } from '../utils/date-utils';\nimport { yToTime } from '../utils/position-utils';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface UseSlotSelectionOptions {\n\t/** Current day being selected on */\n\tdayStart: Date;\n\t/** Visible hours configuration */\n\tvisibleHours: IVisibleHours;\n\t/** Height of one hour in pixels */\n\thourHeight?: number;\n\t/** Slot duration in minutes for snapping */\n\tslotDuration?: number;\n\t/** Resource ID (for resource views) */\n\tresourceId?: string;\n\t/** Whether selection is enabled */\n\tenabled?: boolean;\n\t/** Callback when selection completes */\n\tonSelect?: (selection: ISelectionResult) => void;\n}\n\nexport interface UseSlotSelectionReturn {\n\t/** Current selection state */\n\tselection: ISlotSelection;\n\t/** Selection overlay for rendering */\n\toverlay: { top: number; height: number; visible: boolean };\n\t/** Handler for mouse/touch down */\n\thandlePointerDown: (e: React.PointerEvent, containerRect: DOMRect) => void;\n\t/** Handler for mouse/touch move */\n\thandlePointerMove: (e: React.PointerEvent, containerRect: DOMRect) => void;\n\t/** Handler for mouse/touch up */\n\thandlePointerUp: () => void;\n\t/** Cancel current selection */\n\tcancel: () => void;\n\t/** Whether currently selecting */\n\tisSelecting: boolean;\n}\n\n// ============================================================================\n// INITIAL STATE\n// ============================================================================\n\nconst INITIAL_SELECTION: ISlotSelection = {\n\tisSelecting: false,\n\tstartDate: null,\n\tendDate: null,\n\tstartY: null,\n\tcurrentY: null,\n\tresourceId: undefined,\n};\n\n// ============================================================================\n// HOOK\n// ============================================================================\n\nexport function useSlotSelection(options: UseSlotSelectionOptions): UseSlotSelectionReturn {\n\tconst {\n\t\tdayStart,\n\t\tvisibleHours,\n\t\thourHeight = DEFAULT_HOUR_HEIGHT,\n\t\tslotDuration = 30,\n\t\tresourceId,\n\t\tenabled = true,\n\t\tonSelect,\n\t} = options;\n\n\tconst [selection, setSelection] = useState<ISlotSelection>(INITIAL_SELECTION);\n\tconst containerHeightRef = useRef<number>(0);\n\n\t// ========================================================================\n\t// HANDLERS\n\t// ========================================================================\n\n\tconst handlePointerDown = useCallback(\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\n\t\t\tif (!enabled) return;\n\n\t\t\tconst y = e.clientY - containerRect.top;\n\t\t\tcontainerHeightRef.current = containerRect.height;\n\n\t\t\tconst startTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\n\n\t\t\tsetSelection({\n\t\t\t\tisSelecting: true,\n\t\t\t\tstartDate: startTime,\n\t\t\t\tendDate: addMinutes(startTime, slotDuration),\n\t\t\t\tstartY: y,\n\t\t\t\tcurrentY: y,\n\t\t\t\tresourceId,\n\t\t\t});\n\t\t},\n\t\t[enabled, dayStart, visibleHours, hourHeight, slotDuration, resourceId]\n\t);\n\n\tconst handlePointerMove = useCallback(\n\t\t(e: React.PointerEvent, containerRect: DOMRect) => {\n\t\t\tif (!selection.isSelecting || !selection.startY) return;\n\n\t\t\tconst y = Math.max(0, Math.min(e.clientY - containerRect.top, containerRect.height));\n\t\t\tconst currentTime = yToTime(y, dayStart, visibleHours, hourHeight, slotDuration);\n\n\t\t\tsetSelection((prev) => {\n\t\t\t\tif (!prev.startDate) return prev;\n\n\t\t\t\t// Determine if dragging up or down\n\t\t\t\tconst isDraggingDown = y >= (prev.startY ?? 0);\n\n\t\t\t\treturn {\n\t\t\t\t\t...prev,\n\t\t\t\t\tcurrentY: y,\n\t\t\t\t\tendDate: isDraggingDown ? addMinutes(currentTime, slotDuration) : currentTime,\n\t\t\t\t\tstartDate: isDraggingDown ? prev.startDate : currentTime,\n\t\t\t\t};\n\t\t\t});\n\t\t},\n\t\t[selection.isSelecting, selection.startY, dayStart, visibleHours, hourHeight, slotDuration]\n\t);\n\n\tconst handlePointerUp = useCallback(() => {\n\t\tif (!selection.isSelecting || !selection.startDate || !selection.endDate) {\n\t\t\tsetSelection(INITIAL_SELECTION);\n\t\t\treturn;\n\t\t}\n\n\t\t// Ensure start is before end\n\t\tconst start = selection.startDate < selection.endDate ? selection.startDate : selection.endDate;\n\t\tconst end = selection.startDate < selection.endDate ? selection.endDate : selection.startDate;\n\n\t\tconst result: ISelectionResult = {\n\t\t\tstartDate: start,\n\t\t\tendDate: end,\n\t\t\tresourceId: selection.resourceId,\n\t\t};\n\n\t\tonSelect?.(result);\n\t\tsetSelection(INITIAL_SELECTION);\n\t}, [selection, onSelect]);\n\n\tconst cancel = useCallback(() => {\n\t\tsetSelection(INITIAL_SELECTION);\n\t}, []);\n\n\t// ========================================================================\n\t// OVERLAY CALCULATION\n\t// ========================================================================\n\n\tconst overlay = (() => {\n\t\tif (!selection.isSelecting || selection.startY === null || selection.currentY === null) {\n\t\t\treturn { top: 0, height: 0, visible: false };\n\t\t}\n\n\t\tconst minY = Math.min(selection.startY, selection.currentY);\n\t\tconst maxY = Math.max(selection.startY, selection.currentY);\n\n\t\treturn {\n\t\t\ttop: minY,\n\t\t\theight: Math.max(maxY - minY, 20), // Minimum height\n\t\t\tvisible: true,\n\t\t};\n\t})();\n\n\t// ========================================================================\n\t// RETURN\n\t// ========================================================================\n\n\treturn {\n\t\tselection,\n\t\toverlay,\n\t\thandlePointerDown,\n\t\thandlePointerMove,\n\t\thandlePointerUp,\n\t\tcancel,\n\t\tisSelecting: selection.isSelecting,\n\t};\n}\n"],"names":["useCalendarTimeConfig","preferences","setPreferences","useCalendarContext","visibleHours","useMemo","workingHours","setVisibleHours","useCallback","hours","setWorkingHours","_hours","firstDay","setSlotDuration","duration","setShowWorkingHoursOnly","_show","usePreferences","options","initial","storageKey","onChange","setPreferencesState","useState","stored","parsed","DEFAULT_PREFERENCES","useEffect","updates","prev","next","resetPreferences","defaults","getPreference","key","INITIAL_SELECTION","useSlotSelection","dayStart","hourHeight","DEFAULT_HOUR_HEIGHT","slotDuration","resourceId","enabled","onSelect","selection","setSelection","containerHeightRef","useRef","handlePointerDown","e","containerRect","y","startTime","yToTime","addMinutes","handlePointerMove","currentTime","isDraggingDown","handlePointerUp","start","end","result","cancel","overlay","minY","maxY"],"mappings":"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"}
|