{"version":3,"file":"WeekView.cjs","names":["getDayTimeIntervals","useDragDropHandlers","calculateDropTime","useSlotDragSelect","useEventResize","getWeekDays","getWeekViewEvents","expandRecurringEvents","formatDate","Box","getBusinessHoursMod","UnstyledButton","getLabel","toDateString","isAllDayEvent","ScheduleEvent","WeekViewDay","ScheduleHeaderBase","previousWeek","nextWeek","getWeekLabel","AgendaView","ScrollArea","getWeekNumber","CurrentTimeIndicator","DragContext","classes"],"sources":["../../../src/components/WeekView/WeekView.tsx"],"sourcesContent":["import dayjs from 'dayjs';\nimport { useCallback, useMemo, useRef, useState } from 'react';\nimport {\n  Box,\n  BoxProps,\n  createVarsResolver,\n  DataAttributes,\n  ElementProps,\n  factory,\n  Factory,\n  getRadius,\n  MantineRadius,\n  rem,\n  ScrollArea,\n  ScrollAreaAutosizeProps,\n  StylesApiProps,\n  UnstyledButton,\n  useMantineTheme,\n  useProps,\n  useResolvedStylesApi,\n  useStyles,\n} from '@mantine/core';\nimport { useDatesContext } from '@mantine/dates';\nimport { useIsomorphicEffect, useMergedRef } from '@mantine/hooks';\nimport { useAutoScrollOnDrag } from '../../hooks/use-auto-scroll-on-drag';\nimport { useDragDropHandlers } from '../../hooks/use-drag-drop-handlers';\nimport { useEventResize } from '../../hooks/use-event-resize';\nimport { useSlotDragSelect } from '../../hooks/use-slot-drag-select';\nimport { getLabel, ScheduleLabelsOverride } from '../../labels';\nimport {\n  AnyDateValue,\n  DateLabelFormat,\n  DateStringValue,\n  DateTimeStringValue,\n  DayOfWeek,\n  ScheduleEventData,\n  ScheduleMode,\n  ScheduleViewLevel,\n} from '../../types';\nimport {\n  BusinessHoursValue,\n  calculateDropTime,\n  expandRecurringEvents,\n  formatDate,\n  getBusinessHoursMod,\n  getDayTimeIntervals,\n  getWeekDays,\n  getWeekNumber,\n  isAllDayEvent,\n  nextWeek,\n  previousWeek,\n  toDateString,\n} from '../../utils';\nimport { AgendaView, AgendaViewStylesNames } from '../AgendaView/AgendaView';\nimport {\n  CurrentTimeIndicator,\n  CurrentTimeIndicatorStylesNames,\n} from '../CurrentTimeIndicator/CurrentTimeIndicator';\nimport { DragContext, DragContextValue } from '../DragContext/DragContext';\nimport { RenderEvent, RenderEventBody, ScheduleEvent } from '../ScheduleEvent/ScheduleEvent';\nimport { CombinedScheduleHeaderStylesNames } from '../ScheduleHeader/ScheduleHeader';\nimport { ScheduleHeaderBase } from '../ScheduleHeader/ScheduleHeaderBase';\nimport { ViewSelectProps } from '../ScheduleHeader/ViewSelect/ViewSelect';\nimport { getWeekLabel } from './get-week-label/get-week-label';\nimport { getWeekViewEvents } from './get-week-view-events/get-week-view-events';\nimport { handleWeekViewKeyDown, WeekViewControlsRef } from './handle-week-view-key-down';\nimport { WeekViewDay } from './WeekViewDay';\nimport classes from './WeekView.module.css';\n\nexport type WeekViewStylesNames =\n  | 'weekView'\n  | 'weekViewRoot'\n  | 'weekViewHeader'\n  | 'weekViewInner'\n  | 'weekViewAllDaySlotsEvents'\n  | 'weekViewAllDaySlots'\n  | 'weekViewAllDaySlotsList'\n  | 'weekViewAllDaySlot'\n  | 'weekViewAllDaySlotsLabel'\n  | 'weekViewScrollArea'\n  | 'weekViewCorner'\n  | 'weekViewSlotLabels'\n  | 'weekViewSlotLabel'\n  | 'weekViewDayLabel'\n  | 'weekViewDayWeekday'\n  | 'weekViewDay'\n  | 'weekViewDayNumber'\n  | 'weekViewDaySlot'\n  | 'weekViewDaySlots'\n  | 'weekViewWeekLabel'\n  | 'weekViewWeekNumber'\n  | 'weekViewBackgroundEvent'\n  | CurrentTimeIndicatorStylesNames\n  | CombinedScheduleHeaderStylesNames\n  | AgendaViewStylesNames;\n\nexport type WeekViewCssVariables = {\n  weekView: '--week-view-radius' | '--week-view-slot-height' | '--week-view-all-day-slots-height';\n};\n\nexport interface WeekViewProps\n  extends BoxProps, StylesApiProps<WeekViewFactory>, ElementProps<'div'> {\n  __staticSelector?: string;\n\n  /** Week to display, Date object or date string in `YYYY-MM-DD` format */\n  date: Date | string;\n\n  /** Called with the new date value when a date is selected */\n  onDateChange?: (value: DateStringValue) => void;\n\n  /** Start time for the day view, in `HH:mm:ss` format @default 00:00:00 */\n  startTime?: string;\n\n  /** End time for the day view, in `HH:mm:ss` format @default 23:59:59 */\n  endTime?: string;\n\n  /** Number of minutes for each interval in the day view @default 60 */\n  intervalMinutes?: number;\n\n  /** If set, grid lines are displayed for intervals smaller than one hour, for example 15 and 30 minutes intervals @default true */\n  withSubHourGridLines?: boolean;\n\n  /** Dayjs format for slot labels or a callback function that returns formatted value @default HH:mm  */\n  slotLabelFormat?: DateLabelFormat;\n\n  /** Number 0-6, where 0 – Sunday and 6 – Saturday. @default 1 – Monday */\n  firstDayOfWeek?: DayOfWeek;\n\n  /** `dayjs` format for weekdays names. @default 'ddd' */\n  weekdayFormat?: DateLabelFormat;\n\n  /** Indices of weekend days, 0-6, where 0 is Sunday and 6 is Saturday. The default value is defined by `DatesProvider`. */\n  weekendDays?: DayOfWeek[];\n\n  /** If set to false, weekend days are hidden @default true */\n  withWeekendDays?: boolean;\n\n  /** If set to true, highlights today in the weekday row @default false */\n  highlightToday?: boolean;\n\n  /** Key of `theme.radius` or any valid CSS value to set `border-radius` @default theme.defaultRadius */\n  radius?: MantineRadius;\n\n  /** Props passed down to the `ScrollArea.Autosize` component */\n  scrollAreaProps?: ScrollAreaAutosizeProps & DataAttributes;\n\n  /** Locale passed down to dayjs, overrides value defined on `DatesProvider` */\n  locale?: string;\n\n  /** If set, the week number is displayed at the top left corner @default true */\n  withWeekNumber?: boolean;\n\n  /** If set, displays a line indicating the current time @default true */\n  withCurrentTimeIndicator?: boolean;\n\n  /** If set, the time indicator displays the current time in the bubble @default true */\n  withCurrentTimeBubble?: boolean;\n\n  /** If set, displays the current time indicator on the same day of week even when viewing a different week @default false */\n  forceCurrentTimeIndicator?: boolean;\n\n  /** A function to get the current time, called on every tick. Can be used to display the current time indicator in a different timezone. @default () => dayjs() */\n  getCurrentTime?: () => AnyDateValue;\n\n  /** If set, displays all-day slots at the top of the view @default true */\n  withAllDaySlots?: boolean;\n\n  /** If set, the header is displayed @default true */\n  withHeader?: boolean;\n\n  /** Called when view level select button is clicked */\n  onViewChange?: (view: ScheduleViewLevel) => void;\n\n  /** Props passed to previous month control */\n  previousControlProps?: React.ComponentProps<'button'> & DataAttributes;\n\n  /** Props passed to next month control */\n  nextControlProps?: React.ComponentProps<'button'> & DataAttributes;\n\n  /** Props passed to today control */\n  todayControlProps?: React.ComponentProps<'button'> & DataAttributes;\n\n  /** Props passed to view level select */\n  viewSelectProps?: Partial<ViewSelectProps> & DataAttributes;\n\n  /** Format for week label @default 'MMM DD' */\n  weekLabelFormat?: DateLabelFormat;\n\n  /** List of events to display in the week view */\n  events?: ScheduleEventData[];\n\n  /** Height of 1hr slot @default 64px */\n  slotHeight?: React.CSSProperties['height'];\n\n  /** Height of all-day slot @default 48px */\n  allDaySlotHeight?: React.CSSProperties['height'];\n\n  /** Labels override */\n  labels?: ScheduleLabelsOverride;\n\n  /** If set to true, highlights business hours with white background @default false */\n  highlightBusinessHours?: boolean;\n\n  /** Business hours range in `HH:mm:ss` format shared across all days, or a per-day record keyed by day of the week (`0` – Sunday, `6` – Saturday) for day-specific ranges. Set a day to `null` to mark it as fully outside business hours. @default ['09:00:00', '17:00:00'] */\n  businessHours?: BusinessHoursValue;\n\n  /** Function to customize event body, `event` object is passed as first argument */\n  renderEventBody?: RenderEventBody;\n\n  /** Function to fully customize event rendering, receives all props that would be passed to the root element including children */\n  renderEvent?: RenderEvent;\n\n  /** If true, events can be dragged and dropped @default false */\n  withEventsDragAndDrop?: boolean;\n\n  /** Called when event is dropped at new time */\n  onEventDrop?: (data: {\n    eventId: string | number;\n    newStart: DateTimeStringValue;\n    newEnd: DateTimeStringValue;\n    event: ScheduleEventData;\n  }) => void;\n\n  /** Function to determine if event can be dragged */\n  canDragEvent?: (event: ScheduleEventData) => boolean;\n\n  /** Called when any event drag starts */\n  onEventDragStart?: (event: ScheduleEventData) => void;\n\n  /** Called when any event drag ends */\n  onEventDragEnd?: () => void;\n\n  /** Called when time slot is clicked */\n  onTimeSlotClick?: (data: {\n    slotStart: DateTimeStringValue;\n    slotEnd: DateTimeStringValue;\n    nativeEvent: React.MouseEvent<HTMLButtonElement>;\n  }) => void;\n\n  /** Called when all-day slot is clicked */\n  onAllDaySlotClick?: (day: DateStringValue, event: React.MouseEvent<HTMLButtonElement>) => void;\n\n  /** Called when event is clicked */\n  onEventClick?: (event: ScheduleEventData, e: React.MouseEvent<HTMLButtonElement>) => void;\n\n  /** If set, enables drag-to-select time slot ranges @default false */\n  withDragSlotSelect?: boolean;\n\n  /** Called when a time slot range is selected by dragging */\n  onSlotDragEnd?: (rangeStart: DateTimeStringValue, rangeEnd: DateTimeStringValue) => void;\n\n  /** Interaction mode: 'default' allows all interactions, 'static' disables event interactions @default default */\n  mode?: ScheduleMode;\n\n  /** Time to scroll to on initial render, in `HH:mm:ss` format */\n  startScrollTime?: string;\n\n  /** Function to customize week label in the header */\n  renderWeekLabel?: (params: {\n    weekStart: DateStringValue;\n    weekEnd: DateStringValue;\n  }) => React.ReactNode;\n\n  /** Called when an external item is dropped onto the schedule. Receives the `DataTransfer` object and the drop target datetime. */\n  onExternalEventDrop?: (dataTransfer: DataTransfer, dropDateTime: DateTimeStringValue) => void;\n\n  /** If true, events can be resized by dragging their edges @default false */\n  withEventResize?: boolean;\n\n  /** Called when event is resized */\n  onEventResize?: (data: {\n    eventId: string | number;\n    newStart: DateTimeStringValue;\n    newEnd: DateTimeStringValue;\n    event: ScheduleEventData;\n  }) => void;\n\n  /** Function to determine if event can be resized */\n  canResizeEvent?: (event: ScheduleEventData) => boolean;\n\n  /** Max number of generated recurring instances per recurring series @default 2000 */\n  recurrenceExpansionLimit?: number;\n\n  /** Function to get additional props for each time slot. Receives slot start and end datetime strings. Returned props are spread onto the slot element. Event handlers returned by this function are composed with internal handlers (e.g. onClick) rather than overriding them. */\n  getTimeSlotProps?: (data: {\n    start: DateTimeStringValue;\n    end: DateTimeStringValue;\n  }) => Record<string, any> | undefined;\n\n  /** If set, displays an Agenda button in the header that opens an agenda list view @default false */\n  withAgenda?: boolean;\n}\n\nexport type WeekViewFactory = Factory<{\n  props: WeekViewProps;\n  ref: HTMLDivElement;\n  stylesNames: WeekViewStylesNames;\n  vars: WeekViewCssVariables;\n}>;\n\nconst defaultProps = {\n  __staticSelector: 'WeekView',\n  withWeekendDays: true,\n  withCurrentTimeIndicator: true,\n  startTime: '00:00:00',\n  endTime: '23:59:59',\n  slotLabelFormat: 'HH:mm',\n  intervalMinutes: 60,\n  withSubHourGridLines: true,\n  weekdayFormat: 'ddd',\n  withWeekNumber: true,\n  withCurrentTimeBubble: true,\n  withAllDaySlots: true,\n  withHeader: true,\n  weekLabelFormat: 'MMM DD',\n  highlightBusinessHours: false,\n  businessHours: ['09:00:00', '17:00:00'],\n  withEventsDragAndDrop: false,\n  withDragSlotSelect: false,\n  withEventResize: false,\n  mode: 'default',\n} satisfies Partial<WeekViewProps>;\n\nconst varsResolver = createVarsResolver<WeekViewFactory>(\n  (_theme, { radius, allDaySlotHeight, slotHeight }) => ({\n    weekView: {\n      '--week-view-radius': radius !== undefined ? getRadius(radius) : undefined,\n      '--week-view-all-day-slots-height': rem(allDaySlotHeight),\n      '--week-view-slot-height': rem(slotHeight),\n    },\n  })\n);\n\nexport const WeekView = factory<WeekViewFactory>((_props) => {\n  const props = useProps('WeekView', defaultProps, _props);\n  const {\n    classNames,\n    className,\n    style,\n    styles,\n    unstyled,\n    attributes,\n    vars,\n    startTime,\n    endTime,\n    date,\n    onDateChange,\n    intervalMinutes,\n    withSubHourGridLines,\n    slotLabelFormat,\n    withWeekendDays,\n    weekendDays,\n    firstDayOfWeek,\n    weekdayFormat,\n    radius,\n    highlightToday,\n    withCurrentTimeIndicator,\n    forceCurrentTimeIndicator,\n    getCurrentTime,\n    scrollAreaProps,\n    locale,\n    withWeekNumber,\n    withCurrentTimeBubble,\n    withAllDaySlots,\n    __staticSelector,\n    withHeader,\n    onViewChange,\n    previousControlProps,\n    nextControlProps,\n    todayControlProps,\n    viewSelectProps,\n    weekLabelFormat,\n    events,\n    allDaySlotHeight,\n    slotHeight,\n    labels,\n    highlightBusinessHours,\n    businessHours,\n    renderEventBody,\n    renderEvent,\n    withEventsDragAndDrop,\n    onEventDrop,\n    canDragEvent,\n    onEventDragStart,\n    onEventDragEnd,\n    onTimeSlotClick,\n    onAllDaySlotClick,\n    onEventClick,\n    withDragSlotSelect,\n    onSlotDragEnd,\n    mode,\n    startScrollTime,\n    renderWeekLabel,\n    onExternalEventDrop,\n    withEventResize,\n    onEventResize,\n    canResizeEvent,\n    recurrenceExpansionLimit,\n    getTimeSlotProps,\n    withAgenda,\n    ...others\n  } = props;\n\n  const [agendaOpen, setAgendaOpen] = useState(false);\n\n  const getStyles = useStyles<WeekViewFactory>({\n    name: __staticSelector,\n    classes,\n    props,\n    className,\n    style,\n    classNames,\n    styles,\n    unstyled,\n    vars,\n    varsResolver,\n    attributes,\n    rootSelector: 'weekView',\n  });\n\n  const { resolvedClassNames, resolvedStyles } = useResolvedStylesApi<WeekViewFactory>({\n    classNames,\n    styles,\n    props,\n  });\n\n  const stylesApiProps = {\n    classNames: resolvedClassNames,\n    styles: resolvedStyles,\n    attributes,\n    __staticSelector,\n    radius,\n  };\n\n  const theme = useMantineTheme();\n  const [scrolled, setScrolled] = useState(false);\n  const ctx = useDatesContext();\n  const slots = getDayTimeIntervals({ startTime, endTime, intervalMinutes });\n  const viewportRef = useRef<HTMLDivElement>(null);\n\n  useAutoScrollOnDrag({\n    viewportRef,\n    enabled: (withEventsDragAndDrop || !!onExternalEventDrop) && mode !== 'static',\n  });\n\n  type DropTargetSlot = { day: string; slotIndex: number };\n\n  const handleExternalDrop = useCallback(\n    (e: React.DragEvent, target: DropTargetSlot) => {\n      if (!onExternalEventDrop) {\n        return;\n      }\n      const slotDate = dayjs(target.day).format('YYYY-MM-DD');\n      onExternalEventDrop(e.dataTransfer, `${slotDate} ${slots[target.slotIndex].startTime}`);\n    },\n    [onExternalEventDrop, slots]\n  );\n\n  const handleExternalAllDayDrop = useCallback(\n    (e: React.DragEvent, day: string) => {\n      if (!onExternalEventDrop) {\n        return;\n      }\n      onExternalEventDrop(e.dataTransfer, `${dayjs(day).format('YYYY-MM-DD')} 00:00:00`);\n    },\n    [onExternalEventDrop]\n  );\n\n  const dragDrop = useDragDropHandlers<DropTargetSlot>({\n    enabled: withEventsDragAndDrop,\n    mode,\n    onEventDrop,\n    canDragEvent,\n    onEventDragStart,\n    onEventDragEnd,\n    calculateDropTarget: (target: DropTargetSlot, draggedEvent: ScheduleEventData) => {\n      const slotTime = slots[target.slotIndex].startTime;\n      return calculateDropTime({\n        draggedEvent,\n        targetDate: target.day,\n        targetSlotTime: slotTime,\n        intervalMinutes,\n      });\n    },\n    onExternalDrop: onExternalEventDrop ? handleExternalDrop : undefined,\n  });\n\n  const allDayDragDrop = useDragDropHandlers<string>({\n    enabled: withEventsDragAndDrop,\n    mode,\n    onEventDrop,\n    canDragEvent,\n    onEventDragStart,\n    onEventDragEnd,\n    calculateDropTarget: (targetDay: string, draggedEvent: ScheduleEventData) => {\n      const eventDuration = dayjs(draggedEvent.end).diff(dayjs(draggedEvent.start), 'millisecond');\n      const newStart = dayjs(targetDay).startOf('day');\n      return { start: newStart.toDate(), end: newStart.add(eventDuration, 'millisecond').toDate() };\n    },\n    onExternalDrop: onExternalEventDrop ? handleExternalAllDayDrop : undefined,\n  });\n\n  const slotDragSelect = useSlotDragSelect({\n    enabled: withDragSlotSelect && mode !== 'static',\n    onDragEnd: (startIndex, endIndex, group) => {\n      if (!onSlotDragEnd) {\n        return;\n      }\n      const slotDate = dayjs(group).format('YYYY-MM-DD');\n      onSlotDragEnd(\n        `${slotDate} ${slots[startIndex].startTime}`,\n        `${slotDate} ${slots[endIndex].endTime}`\n      );\n    },\n  });\n\n  const eventResize = useEventResize({\n    enabled: withEventResize,\n    mode,\n    startTime,\n    endTime,\n    intervalMinutes,\n    onEventResize,\n    canResizeEvent,\n  });\n\n  const withDragHandlers = (withEventsDragAndDrop || !!onExternalEventDrop) && mode !== 'static';\n\n  const handleTimeSlotClick = (\n    day: string,\n    slotTime: string,\n    e: React.MouseEvent<HTMLButtonElement>\n  ) => {\n    if (!onTimeSlotClick) {\n      return;\n    }\n\n    const slotDate = dayjs(day).format('YYYY-MM-DD');\n    const slotIndex = slots.findIndex((s) => s.startTime === slotTime);\n    if (slotIndex === -1) {\n      return;\n    }\n\n    const slot = slots[slotIndex];\n    onTimeSlotClick({\n      slotStart: `${slotDate} ${slot.startTime}`,\n      slotEnd: `${slotDate} ${slot.endTime}`,\n      nativeEvent: e,\n    });\n  };\n\n  const weekdays = getWeekDays({\n    week: date,\n    withWeekendDays,\n    weekendDays: ctx.getWeekendDays(weekendDays),\n    firstDayOfWeek: ctx.getFirstDayOfWeek(firstDayOfWeek),\n  });\n\n  const expandedEvents = expandRecurringEvents({\n    events,\n    rangeStart: dayjs(weekdays[0]).startOf('day').toDate(),\n    rangeEnd: dayjs(weekdays[weekdays.length - 1])\n      .endOf('day')\n      .toDate(),\n    expansionLimit: recurrenceExpansionLimit,\n  });\n\n  const weekEvents = getWeekViewEvents({\n    date,\n    events: expandedEvents,\n    startTime,\n    endTime,\n    intervalMinutes,\n    firstDayOfWeek: ctx.getFirstDayOfWeek(firstDayOfWeek),\n    weekendDays: ctx.getWeekendDays(weekendDays),\n    withWeekendDays,\n  });\n\n  const timeValues = slots.reduce<React.ReactNode[]>((acc, interval) => {\n    if (!interval.isHourStart) {\n      return acc;\n    }\n\n    const intervalTime = dayjs(`${dayjs(date).format('YYYY-MM-DD')} ${interval.startTime}`);\n    const label = formatDate({\n      date: intervalTime,\n      locale: ctx.getLocale(locale),\n      format: slotLabelFormat,\n    });\n\n    acc.push(\n      <Box\n        {...getStyles('weekViewSlotLabel')}\n        key={interval.startTime}\n        mod={{\n          'hour-start': interval.isHourStart,\n          ...getBusinessHoursMod({\n            time: interval.startTime,\n            businessHours,\n            highlightBusinessHours,\n          }),\n        }}\n      >\n        {label}\n      </Box>\n    );\n\n    return acc;\n  }, []);\n\n  const slotsRef: WeekViewControlsRef = useRef<HTMLButtonElement[][]>([]);\n  const allDaySlotsRef = useRef<HTMLButtonElement[]>([]);\n  const weekdaysRef = useRef<HTMLButtonElement[]>([]);\n  const daySlotsContainersRef = useRef<(HTMLDivElement | null)[]>([]);\n  const mergedViewportRef = useMergedRef(viewportRef, scrollAreaProps?.viewportRef);\n\n  const firstSlotIndex = { dayIndex: 0, slotIndex: 0 };\n\n  useIsomorphicEffect(() => {\n    if (!startScrollTime || !viewportRef.current) {\n      return;\n    }\n\n    const firstDaySlots = slotsRef.current[0];\n    if (!firstDaySlots || firstDaySlots.length === 0) {\n      return;\n    }\n\n    const targetIndex = slots.findIndex((s) => s.startTime >= startScrollTime);\n    if (targetIndex < 0) {\n      return;\n    }\n\n    const targetSlot = firstDaySlots[targetIndex];\n    if (!targetSlot) {\n      return;\n    }\n\n    const slotRect = targetSlot.getBoundingClientRect();\n    const viewportRect = viewportRef.current.getBoundingClientRect();\n    viewportRef.current.scrollTo({ left: 0, top: slotRect.top - viewportRect.top });\n  }, []);\n\n  const getSlotIndexFromDragPoint = useCallback((event: React.DragEvent, dayIndex: number) => {\n    const daySlots = slotsRef.current[dayIndex] ?? [];\n    const slotIndex = daySlots.findIndex((slotNode) => {\n      if (!slotNode) {\n        return false;\n      }\n\n      const rect = slotNode.getBoundingClientRect();\n      return event.clientY >= rect.top && event.clientY <= rect.bottom;\n    });\n\n    if (slotIndex >= 0) {\n      return slotIndex;\n    }\n\n    const firstSlot = daySlots[0];\n    const lastSlot = daySlots[daySlots.length - 1];\n\n    if (!firstSlot || !lastSlot) {\n      return null;\n    }\n\n    const firstRect = firstSlot.getBoundingClientRect();\n    const lastRect = lastSlot.getBoundingClientRect();\n\n    if (event.clientY < firstRect.top) {\n      return 0;\n    }\n\n    if (event.clientY > lastRect.bottom) {\n      return daySlots.length - 1;\n    }\n\n    return null;\n  }, []);\n\n  const handleSlotKeyDown = (\n    event: React.KeyboardEvent<HTMLButtonElement>,\n    dayIndex: number,\n    slotIndex: number\n  ) => {\n    handleWeekViewKeyDown({\n      controlsRef: slotsRef,\n      dayIndex,\n      slotIndex,\n      event,\n    });\n  };\n\n  const handleAllDaySlotKeyDown = (\n    event: React.KeyboardEvent<HTMLButtonElement>,\n    dayIndex: number\n  ) => {\n    const direction = event.key;\n    if (direction === 'ArrowRight' && dayIndex < weekdays.length - 1) {\n      event.preventDefault();\n      allDaySlotsRef.current[dayIndex + 1]?.focus();\n    } else if (direction === 'ArrowLeft' && dayIndex > 0) {\n      event.preventDefault();\n      allDaySlotsRef.current[dayIndex - 1]?.focus();\n    } else if (direction === 'ArrowDown') {\n      event.preventDefault();\n      slotsRef.current?.[dayIndex]?.[0]?.focus();\n    }\n  };\n\n  const handleWeekdayKeyDown = (\n    event: React.KeyboardEvent<HTMLButtonElement>,\n    dayIndex: number\n  ) => {\n    const direction = event.key;\n    if (direction === 'ArrowRight' && dayIndex < weekdays.length - 1) {\n      event.preventDefault();\n      weekdaysRef.current[dayIndex + 1]?.focus();\n    } else if (direction === 'ArrowLeft' && dayIndex > 0) {\n      event.preventDefault();\n      weekdaysRef.current[dayIndex - 1]?.focus();\n    }\n  };\n\n  const resolveNow = () => (getCurrentTime ? dayjs(getCurrentTime()) : dayjs());\n  const now = resolveNow();\n\n  const currentWeekdayIndex = withCurrentTimeIndicator\n    ? forceCurrentTimeIndicator\n      ? weekdays.findIndex((day) => dayjs(day).day() === now.day())\n      : weekdays.findIndex((day) => dayjs(day).isSame(now, 'date'))\n    : -1;\n\n  const weekdaysLabels = weekdays.map((day, dayIndex) => (\n    <UnstyledButton\n      {...getStyles('weekViewDayLabel')}\n      key={day}\n      ref={(node) => {\n        weekdaysRef.current[dayIndex] = node!;\n      }}\n      aria-label={`${getLabel('weekday', labels)} ${dayjs(day).format('YYYY-MM-DD')}`}\n      mod={{\n        today: dayjs(day).isSame(now, 'day') && !!highlightToday,\n        weekend: ctx.getWeekendDays(weekendDays).includes(dayjs(day).day() as DayOfWeek),\n        static: mode === 'static',\n      }}\n      tabIndex={mode === 'static' ? -1 : dayIndex === 0 ? 0 : -1}\n      onKeyDown={mode === 'static' ? undefined : (event) => handleWeekdayKeyDown(event, dayIndex)}\n      onClick={\n        mode === 'static'\n          ? undefined\n          : () => {\n              onViewChange?.('day');\n              onDateChange?.(toDateString(day));\n            }\n      }\n    >\n      <Box {...getStyles('weekViewDayWeekday')} key=\"weekday\">\n        {formatDate({ locale: ctx.getLocale(locale), date: day, format: weekdayFormat })}\n      </Box>\n      <div {...getStyles('weekViewDayNumber')} key=\"date\">\n        {dayjs(day).date()}\n      </div>\n    </UnstyledButton>\n  ));\n\n  const days = weekdays.map((day, dayIndex) => {\n    const allBgEvents = weekEvents.backgroundEvents[day] || [];\n\n    const backgroundEventNodes = allBgEvents\n      .filter((event) => !event.position.allDay)\n      .map((event) => {\n        const colors = theme.variantColorResolver({\n          color: event.color || theme.primaryColor,\n          theme,\n          variant: 'light',\n          autoContrast: true,\n        });\n\n        const bgEventBody =\n          typeof renderEventBody === 'function' ? renderEventBody(event) : event.title;\n\n        const bgEventProps = {\n          key: `bg-${event.id}`,\n          ...getStyles('weekViewBackgroundEvent', {\n            style: {\n              top: `${event.position.top}%`,\n              height: `${event.position.height}%`,\n              width: '100%',\n            },\n          }),\n          __vars: {\n            '--bg-event-bg': colors.background,\n            '--bg-event-color': colors.color,\n          },\n          children: bgEventBody,\n        };\n\n        if (typeof renderEvent === 'function') {\n          return renderEvent(event, bgEventProps as any);\n        }\n\n        const { key: bgEventKey, ...restBgEventProps } = bgEventProps;\n        return <Box key={bgEventKey} {...restBgEventProps} />;\n      });\n\n    const dayEvents = (weekEvents.regularEvents[day] || []).map((event) => {\n      const eventIsAllDay = isAllDayEvent({ event, date: day });\n      const isDraggable = !eventIsAllDay && dragDrop.isDraggableEvent(event);\n      const isResizable = !eventIsAllDay && eventResize.isResizableEvent(event);\n      const resizePosition = eventResize.getResizePosition(event.id);\n      const eventTop = resizePosition ? resizePosition.top : event.position.top;\n      const eventHeight = resizePosition ? resizePosition.height : event.position.height;\n\n      return (\n        <ScheduleEvent\n          key={event.id}\n          event={event}\n          autoSize\n          hanging={event.position.hanging}\n          draggable={isDraggable}\n          withResize={isResizable}\n          isResizing={resizePosition !== null}\n          onResizeStart={\n            isResizable\n              ? (edge, e) => {\n                  const container = daySlotsContainersRef.current[dayIndex];\n                  if (container) {\n                    eventResize.handleResizeStart({\n                      event,\n                      edge,\n                      container,\n                      originalTop: event.position.top,\n                      originalHeight: event.position.height,\n                      eventDate: dayjs(day).format('YYYY-MM-DD'),\n                      pointerEvent: e,\n                    });\n                  }\n                }\n              : undefined\n          }\n          renderEventBody={renderEventBody}\n          renderEvent={renderEvent}\n          radius={radius}\n          mode={mode}\n          onClick={\n            onEventClick\n              ? (e) => {\n                  if (!eventResize.wasResizing()) {\n                    onEventClick(event, e);\n                  }\n                }\n              : undefined\n          }\n          style={{\n            position: 'absolute',\n            top: `calc(${eventTop}% + 1px)`,\n            left: `${event.position.offset}%`,\n            width: `${event.position.width}%`,\n            height: `calc(${eventHeight}% - 1px)`,\n          }}\n        />\n      );\n    });\n\n    return (\n      <WeekViewDay\n        key={day}\n        day={day}\n        dayIndex={dayIndex}\n        slots={slots}\n        intervalMinutes={intervalMinutes}\n        getStyles={getStyles}\n        weekendDays={weekendDays}\n        highlightBusinessHours={highlightBusinessHours}\n        businessHours={businessHours}\n        labels={labels}\n        withEventsDragAndDrop={withDragHandlers}\n        mode={mode}\n        slotsRef={slotsRef}\n        firstSlotIndex={firstSlotIndex}\n        onSlotKeyDown={handleSlotKeyDown}\n        onSlotClick={handleTimeSlotClick}\n        onFirstSlotArrowUp={\n          withAllDaySlots\n            ? (dayIdx) => {\n                allDaySlotsRef.current[dayIdx]?.focus();\n              }\n            : undefined\n        }\n        onDaySlotsDragOver={(event, dayStr, dayIdx) => {\n          const slotIndex = getSlotIndexFromDragPoint(event, dayIdx);\n          if (slotIndex !== null) {\n            dragDrop.handleDragOver(event, { day: dayStr, slotIndex });\n          }\n        }}\n        onDaySlotsDragLeave={dragDrop.handleDragLeave}\n        onDaySlotsDrop={(event, dayStr, dayIdx) => {\n          const slotIndex = getSlotIndexFromDragPoint(event, dayIdx);\n          if (slotIndex !== null) {\n            dragDrop.handleDrop(event, { day: dayStr, slotIndex });\n          }\n        }}\n        dropTargetSlotIndex={\n          dragDrop.dropTarget?.day === day ? dragDrop.dropTarget.slotIndex : undefined\n        }\n        withDragSlotSelect={withDragSlotSelect}\n        onSlotPointerDown={slotDragSelect.handleSlotPointerDown}\n        isSlotDragSelected={slotDragSelect.isSlotSelected}\n        daySlotsContainerRef={(node) => {\n          daySlotsContainersRef.current[dayIndex] = node;\n        }}\n        getTimeSlotProps={getTimeSlotProps}\n      >\n        {backgroundEventNodes}\n        {dayEvents}\n      </WeekViewDay>\n    );\n  });\n\n  const allDaySlots = weekdays.map((day, dayIndex) => (\n    <UnstyledButton\n      aria-label={`${getLabel('allDay', labels)} ${dayjs(day).format('YYYY-MM-DD')}`}\n      key={day}\n      ref={(node) => {\n        allDaySlotsRef.current[dayIndex] = node!;\n      }}\n      tabIndex={dayIndex === 0 ? 0 : -1}\n      onKeyDown={(event) => handleAllDaySlotKeyDown(event, dayIndex)}\n      onClick={\n        mode === 'static' || !onAllDaySlotClick\n          ? undefined\n          : (e) => onAllDaySlotClick(dayjs(day).format('YYYY-MM-DD'), e)\n      }\n      onDragOver={withDragHandlers ? (e) => allDayDragDrop.handleDragOver(e, day) : undefined}\n      onDragLeave={withDragHandlers ? allDayDragDrop.handleDragLeave : undefined}\n      onDrop={withDragHandlers ? (e) => allDayDragDrop.handleDrop(e, day) : undefined}\n      {...getStyles('weekViewDaySlot')}\n      mod={{ 'drop-target': allDayDragDrop.isDropTarget(day) }}\n    />\n  ));\n\n  const allDayEventIds = useMemo(\n    () => new Set(weekEvents.allDayEvents.map((e) => e.id)),\n    [weekEvents.allDayEvents]\n  );\n\n  const allDayEvents = weekEvents.allDayEvents.map((event) => (\n    <ScheduleEvent\n      key={event.id}\n      event={event}\n      autoSize\n      nowrap\n      hanging={event.position.hanging}\n      draggable={allDayDragDrop.isDraggableEvent(event)}\n      renderEvent={renderEvent}\n      mode={mode}\n      onClick={onEventClick ? (e) => onEventClick(event, e) : undefined}\n      style={{\n        position: 'absolute',\n        zIndex: 2,\n        top: `calc(${event.position.row * 50}% + 1px)`,\n        left: `calc(${event.position.offset}% + 1px)`,\n        width: `calc(${event.position.width}% - 1px)`,\n        height: 'calc(50% - 2px)',\n        maxHeight: 'calc(50% - 2px)',\n      }}\n    />\n  ));\n\n  const allDayBackgroundEventNodes = weekdays.flatMap((day, dayIndex) => {\n    const allDayBgEvents = (weekEvents.backgroundEvents[day] || []).filter(\n      (event) => event.position.allDay\n    );\n    const dayWidth = 100 / weekdays.length;\n    const dayOffset = dayIndex * dayWidth;\n\n    return allDayBgEvents.map((event) => {\n      const colors = theme.variantColorResolver({\n        color: event.color || theme.primaryColor,\n        theme,\n        variant: 'light',\n        autoContrast: true,\n      });\n\n      const bgEventBody =\n        typeof renderEventBody === 'function' ? renderEventBody(event) : event.title;\n\n      const bgEventProps = {\n        key: `bg-allday-${event.id}-${day}`,\n        ...getStyles('weekViewBackgroundEvent', {\n          style: {\n            top: 0,\n            height: '100%',\n            left: `${dayOffset}%`,\n            width: `${dayWidth}%`,\n          },\n        }),\n        __vars: {\n          '--bg-event-bg': colors.background,\n          '--bg-event-color': colors.color,\n        },\n        children: bgEventBody,\n      };\n\n      if (typeof renderEvent === 'function') {\n        return renderEvent(event, bgEventProps as any);\n      }\n\n      const { key: bgEventKey, ...restBgEventProps } = bgEventProps;\n      return <Box key={bgEventKey} {...restBgEventProps} />;\n    });\n  });\n\n  // Extra rows show on hover = total rows - 2 visible rows (starts from 0, so -1)\n  const extraRows = Math.max(...weekEvents.allDayEvents.map((event) => event.position.row), 1) - 1;\n\n  const content = (\n    <Box\n      {...getStyles('weekView')}\n      mod={{ static: mode === 'static', 'slot-dragging': slotDragSelect.isDragging }}\n      {...others}\n    >\n      {withHeader && (\n        <ScheduleHeaderBase\n          view=\"week\"\n          navigationHandlers={{\n            previous: () => previousWeek(date, ctx.getFirstDayOfWeek(firstDayOfWeek)),\n            next: () => nextWeek(date, ctx.getFirstDayOfWeek(firstDayOfWeek)),\n            today: () => toDateString(resolveNow()),\n          }}\n          control={{\n            miw: 140,\n            title: getWeekLabel({\n              weekdays,\n              locale: ctx.getLocale(locale),\n              weekLabelFormat,\n              renderWeekLabel,\n            }),\n          }}\n          labels={labels}\n          onDateChange={onDateChange}\n          onViewChange={onViewChange}\n          previousControlProps={previousControlProps}\n          nextControlProps={nextControlProps}\n          todayControlProps={todayControlProps}\n          viewSelectProps={viewSelectProps}\n          stylesApiProps={stylesApiProps}\n          onAgendaClick={withAgenda ? () => setAgendaOpen((v) => !v) : undefined}\n          agendaActive={agendaOpen}\n        />\n      )}\n\n      {agendaOpen && (\n        <AgendaView\n          rangeStart={dayjs(weekdays[0]).format('YYYY-MM-DD')}\n          rangeEnd={dayjs(weekdays[weekdays.length - 1]).format('YYYY-MM-DD')}\n          events={events}\n          locale={locale}\n          labels={labels}\n          mode={mode}\n          onEventClick={onEventClick}\n          recurrenceExpansionLimit={recurrenceExpansionLimit}\n          {...stylesApiProps}\n        />\n      )}\n\n      {!agendaOpen && (\n        <Box\n          {...getStyles('weekViewRoot')}\n          __vars={{\n            '--indicator-offset-index':\n              currentWeekdayIndex === -1 ? undefined : `${currentWeekdayIndex + 1}`,\n            '--number-of-days': withWeekendDays\n              ? '7'\n              : `${7 - ctx.getWeekendDays(weekendDays).length}`,\n          }}\n          mod={{\n            'with-weekends': withWeekendDays,\n            'hide-sub-hour-grid-lines': !withSubHourGridLines,\n            'event-interaction': eventResize.isResizing || dragDrop.dragContextValue.isDragging,\n          }}\n        >\n          <ScrollArea.Autosize\n            scrollbarSize={4}\n            {...scrollAreaProps}\n            {...getStyles('weekViewScrollArea', {\n              className: scrollAreaProps?.className,\n              style: scrollAreaProps?.style,\n            })}\n            onScrollPositionChange={(position) => {\n              scrollAreaProps?.onScrollPositionChange?.(position);\n              setScrolled(position.y !== 0);\n            }}\n            viewportRef={mergedViewportRef}\n          >\n            <Box {...getStyles('weekViewHeader')} mod={{ scrolled }}>\n              <div {...getStyles('weekViewCorner')} key=\"corner\">\n                {withWeekNumber && (\n                  <>\n                    <div {...getStyles('weekViewWeekLabel')}>{getLabel('week', labels)}</div>\n                    <div {...getStyles('weekViewWeekNumber')}>{getWeekNumber(date)}</div>\n                  </>\n                )}\n              </div>\n\n              {weekdaysLabels}\n            </Box>\n\n            {withAllDaySlots && (\n              <div {...getStyles('weekViewAllDaySlots')}>\n                <div {...getStyles('weekViewAllDaySlotsLabel')}>{getLabel('allDay', labels)}</div>\n                <div {...getStyles('weekViewAllDaySlotsList')}>\n                  {allDayBackgroundEventNodes}\n                  <Box\n                    {...getStyles('weekViewAllDaySlotsEvents')}\n                    __vars={{ '--extra-rows': `${extraRows}` }}\n                  >\n                    {allDayEvents}\n                  </Box>\n                  {allDaySlots}\n                </div>\n              </div>\n            )}\n\n            <div {...getStyles('weekViewInner')}>\n              <div {...getStyles('weekViewSlotLabels')}>{timeValues}</div>\n\n              {withCurrentTimeIndicator && currentWeekdayIndex !== -1 && (\n                <CurrentTimeIndicator\n                  startOffset=\"calc(100% - (100% / var(--number-of-days)) * (var(--number-of-days) - var(--indicator-offset-index) + 1) + ((var(--number-of-days) - var(--indicator-offset-index) + 1) * var(--indicator-labels-offset)))\"\n                  endOffset=\"calc((100% / var(--number-of-days)) * (var(--number-of-days) - var(--indicator-offset-index)) - (var(--number-of-days) - var(--indicator-offset-index)) * var(--indicator-labels-offset))\"\n                  timeBubbleStartOffset=\"calc(var(--week-view-slots-label-width) - var(--time-bubble-width))\"\n                  currentTimeFormat={slotLabelFormat}\n                  withTimeBubble={withCurrentTimeBubble}\n                  withThumb={withCurrentTimeBubble ? currentWeekdayIndex !== 0 : true}\n                  locale={locale}\n                  startTime={startTime}\n                  endTime={endTime}\n                  intervalMinutes={intervalMinutes}\n                  getCurrentTime={getCurrentTime}\n                  {...stylesApiProps}\n                />\n              )}\n              {days}\n            </div>\n          </ScrollArea.Autosize>\n        </Box>\n      )}\n    </Box>\n  );\n\n  const mergedDragContextValue = useMemo<DragContextValue>(\n    () => ({\n      isDragging:\n        dragDrop.dragContextValue.isDragging || allDayDragDrop.dragContextValue.isDragging,\n      draggedEventId:\n        dragDrop.dragContextValue.draggedEventId ?? allDayDragDrop.dragContextValue.draggedEventId,\n      draggedEvent:\n        dragDrop.dragContextValue.draggedEvent ?? allDayDragDrop.dragContextValue.draggedEvent,\n      dropTarget:\n        dragDrop.dragContextValue.dropTarget ?? allDayDragDrop.dragContextValue.dropTarget,\n      onDragStart: (event: ScheduleEventData) => {\n        if (allDayEventIds.has(event.id)) {\n          allDayDragDrop.handleDragStart(event);\n        } else {\n          dragDrop.handleDragStart(event);\n        }\n      },\n      onDragEnd: () => {\n        dragDrop.handleDragEnd();\n        allDayDragDrop.handleDragEnd();\n      },\n      setDropTarget: dragDrop.dragContextValue.setDropTarget,\n    }),\n    [dragDrop.dragContextValue, allDayDragDrop.dragContextValue, allDayEventIds]\n  );\n\n  if (withEventsDragAndDrop) {\n    return <DragContext.Provider value={mergedDragContextValue}>{content}</DragContext.Provider>;\n  }\n\n  return content;\n});\n\nWeekView.displayName = '@mantine/schedule/WeekView';\nWeekView.classes = classes;\nWeekView.varsResolver = varsResolver;\n\nexport namespace WeekView {\n  export type Props = WeekViewProps;\n  export type Factory = WeekViewFactory;\n  export type StylesNames = WeekViewStylesNames;\n  export type CssVariables = WeekViewCssVariables;\n}\n"],"mappings":"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"}