{"version":3,"file":"use-basic-date-table.mjs","names":[],"sources":["../../../../../../../packages/components/date-picker-panel/src/composables/use-basic-date-table.ts"],"sourcesContent":["import { computed, nextTick, ref, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { flatten } from 'lodash-unified'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { castArray, isArray } from '@element-plus/utils'\nimport { buildPickerTable } from '../utils'\n\nimport type { SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DateCell } from '../types'\nimport type {\n  BasicDateTableEmits,\n  BasicDateTableProps,\n} from '../props/basic-date-table'\n\nconst isNormalDay = (type = '') => {\n  return ['normal', 'today'].includes(type)\n}\n\nexport const useBasicDateTable = (\n  props: BasicDateTableProps,\n  emit: SetupContext<BasicDateTableEmits>['emit']\n) => {\n  const { lang } = useLocale()\n  const tbodyRef = ref<HTMLElement>()\n  const currentCellRef = ref<HTMLElement>()\n  // data\n  const lastRow = ref<number>()\n  const lastColumn = ref<number>()\n  const tableRows = ref<DateCell[][]>([[], [], [], [], [], []])\n\n  let focusWithClick = false\n\n  // todo better way to get Day.js locale object\n  const firstDayOfWeek = (props.date as any).$locale().weekStart || 7\n  const WEEKS_CONSTANT = props.date\n    .locale('en')\n    .localeData()\n    .weekdaysShort()\n    .map((_) => _.toLowerCase())\n\n  const offsetDay = computed(() => {\n    // Sunday 7(0), cal the left and right offset days, 3217654, such as Monday is -1, the is to adjust the position of the first two rows of dates\n    return firstDayOfWeek > 3 ? 7 - firstDayOfWeek : -firstDayOfWeek\n  })\n\n  const startDate = computed(() => {\n    const startDayOfMonth = props.date.startOf('month')\n    return startDayOfMonth.subtract(startDayOfMonth.day() || 7, 'day')\n  })\n\n  const WEEKS = computed(() => {\n    return WEEKS_CONSTANT.concat(WEEKS_CONSTANT).slice(\n      firstDayOfWeek,\n      firstDayOfWeek + 7\n    )\n  })\n\n  const hasCurrent = computed<boolean>(() => {\n    return flatten(unref(rows)).some((row) => {\n      return row.isCurrent\n    })\n  })\n\n  const days = computed(() => {\n    const startOfMonth = props.date.startOf('month')\n    const startOfMonthDay = startOfMonth.day() || 7 // day of first day\n    const dateCountOfMonth = startOfMonth.daysInMonth()\n\n    const dateCountOfLastMonth = startOfMonth.subtract(1, 'month').daysInMonth()\n\n    return {\n      startOfMonthDay,\n      dateCountOfMonth,\n      dateCountOfLastMonth,\n    }\n  })\n\n  const selectedDate = computed<Dayjs[]>(() => {\n    return props.selectionMode === 'dates' ? castArray(props.parsedValue!) : []\n  })\n\n  // Return value indicates should the counter be incremented\n  type CellCoordinate = { columnIndex: number; rowIndex: number }\n  type CellMeta = CellCoordinate & {\n    count: number\n  }\n  const setDateText = (\n    cell: DateCell,\n    { count, rowIndex, columnIndex }: CellMeta\n  ): boolean => {\n    const { startOfMonthDay, dateCountOfMonth, dateCountOfLastMonth } =\n      unref(days)\n    const offset = unref(offsetDay)\n    if (rowIndex >= 0 && rowIndex <= 1) {\n      const numberOfDaysFromPreviousMonth =\n        startOfMonthDay + offset < 0\n          ? 7 + startOfMonthDay + offset\n          : startOfMonthDay + offset\n\n      if (columnIndex + rowIndex * 7 >= numberOfDaysFromPreviousMonth) {\n        cell.text = count\n        return true\n      } else {\n        cell.text =\n          dateCountOfLastMonth -\n          (numberOfDaysFromPreviousMonth - (columnIndex % 7)) +\n          1 +\n          rowIndex * 7\n        cell.type = 'prev-month'\n      }\n    } else {\n      if (count <= dateCountOfMonth) {\n        cell.text = count\n      } else {\n        cell.text = count - dateCountOfMonth\n        cell.type = 'next-month'\n      }\n      return true\n    }\n    return false\n  }\n\n  const setCellMetadata = (\n    cell: DateCell,\n    { columnIndex, rowIndex }: CellCoordinate,\n    count: number\n  ) => {\n    const { disabledDate, cellClassName } = props\n    const _selectedDate = unref(selectedDate)\n    const shouldIncrement = setDateText(cell, { count, rowIndex, columnIndex })\n\n    const cellDate = cell.dayjs!.toDate()\n    cell.selected = _selectedDate.find((d) => d.isSame(cell.dayjs, 'day'))\n    cell.isSelected = !!cell.selected\n    cell.isCurrent = isCurrent(cell)\n    cell.disabled = disabledDate?.(cellDate)\n    cell.customClass = cellClassName?.(cellDate)\n    return shouldIncrement\n  }\n\n  const setRowMetadata = (row: DateCell[]) => {\n    if (props.selectionMode === 'week') {\n      const [start, end] = props.showWeekNumber ? [1, 7] : [0, 6]\n      const isActive = isWeekActive(row[start + 1])\n      row[start].inRange = isActive\n      row[start].start = isActive\n      row[end].inRange = isActive\n      row[end].end = isActive\n    }\n  }\n\n  const rows = computed(() => {\n    const { minDate, maxDate, rangeState, showWeekNumber } = props\n\n    const offset = unref(offsetDay)\n    const rows_ = unref(tableRows)\n    const dateUnit = 'day'\n    let count = 1\n\n    buildPickerTable({ row: 6, column: 7 }, rows_, {\n      startDate: minDate,\n      columnIndexOffset: showWeekNumber ? 1 : 0,\n      nextEndDate:\n        rangeState.endDate ||\n        maxDate ||\n        (rangeState.selecting && minDate) ||\n        null,\n      now: dayjs().locale(unref(lang)).startOf(dateUnit),\n      unit: dateUnit,\n      relativeDateGetter: (idx: number) =>\n        unref(startDate).add(idx - offset, dateUnit),\n      setCellMetadata: (...args) => {\n        if (setCellMetadata(...args, count)) {\n          count += 1\n        }\n      },\n\n      setRowMetadata,\n    })\n\n    if (showWeekNumber) {\n      for (let rowIndex = 0; rowIndex < 6; rowIndex++) {\n        if (rows_[rowIndex][1].dayjs) {\n          rows_[rowIndex][0] = {\n            type: 'week',\n            text: rows_[rowIndex][1].dayjs!.week(),\n          }\n        }\n      }\n    }\n\n    return rows_\n  })\n\n  watch(\n    () => props.date,\n    async () => {\n      if (unref(tbodyRef)?.contains(document.activeElement)) {\n        await nextTick()\n        await focus()\n        // currentCellRef.value?.focus()\n      }\n    }\n  )\n\n  const focus = async () => unref(currentCellRef)?.focus()\n\n  const isCurrent = (cell: DateCell): boolean => {\n    return (\n      props.selectionMode === 'date' &&\n      isNormalDay(cell.type) &&\n      cellMatchesDate(cell, props.parsedValue as Dayjs)\n    )\n  }\n\n  const cellMatchesDate = (cell: DateCell, date: Dayjs) => {\n    if (!date) return false\n    return dayjs(date)\n      .locale(unref(lang))\n      .isSame(props.date.date(Number(cell.text)), 'day')\n  }\n\n  const getDateOfCell = (row: number, column: number) => {\n    //NOTE: because relying of startDate is not reliable in every weekStart (especially 2, 3); we re-create it\n    const startOfMonthDay = unref(days).startOfMonthDay\n    const offset = unref(offsetDay)\n    const numberOfDaysFromPreviousMonth =\n      startOfMonthDay + offset < 0\n        ? 7 + startOfMonthDay + offset\n        : startOfMonthDay + offset\n    const offsetFromStart = row * 7 + (column - (props.showWeekNumber ? 1 : 0))\n    return props.date\n      .startOf('month')\n      .subtract(numberOfDaysFromPreviousMonth, 'day')\n      .add(offsetFromStart, 'day')\n  }\n\n  const handleMouseMove = (event: MouseEvent) => {\n    if (!props.rangeState.selecting) return\n\n    let target = event.target as HTMLElement\n    if (target.tagName === 'SPAN') {\n      target = target.parentNode?.parentNode as HTMLElement\n    }\n    if (target.tagName === 'DIV') {\n      target = target.parentNode as HTMLElement\n    }\n    if (target.tagName !== 'TD') return\n\n    const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n    const column = (target as HTMLTableCellElement).cellIndex\n\n    // can not select disabled date\n    if (unref(rows)[row][column].disabled) return\n\n    // only update rangeState when mouse moves to a new cell\n    // this avoids frequent Date object creation and improves performance\n    if (row !== unref(lastRow) || column !== unref(lastColumn)) {\n      lastRow.value = row\n      lastColumn.value = column\n      emit('changerange', {\n        selecting: true,\n        endDate: getDateOfCell(row, column),\n      })\n    }\n  }\n\n  const isSelectedCell = (cell: DateCell) => {\n    return (\n      (!unref(hasCurrent) && cell?.text === 1 && isNormalDay(cell.type)) ||\n      cell.isCurrent\n    )\n  }\n\n  const handleFocus = (event: FocusEvent) => {\n    if (focusWithClick || unref(hasCurrent) || props.selectionMode !== 'date')\n      return\n    handlePickDate(event, true)\n  }\n\n  const handleMouseDown = (event: MouseEvent) => {\n    const target = (event.target as HTMLElement).closest('td')\n    if (!target) return\n    focusWithClick = true\n  }\n\n  const handleMouseUp = (event: MouseEvent) => {\n    const target = (event.target as HTMLElement).closest('td')\n    if (!target) return\n    focusWithClick = false\n  }\n\n  const handleRangePick = (newDate: Dayjs) => {\n    if (!props.rangeState.selecting || !props.minDate) {\n      emit('pick', { minDate: newDate, maxDate: null })\n      emit('select', true)\n    } else {\n      if (newDate >= props.minDate) {\n        emit('pick', { minDate: props.minDate, maxDate: newDate })\n      } else {\n        emit('pick', { minDate: newDate, maxDate: props.minDate })\n      }\n      emit('select', false)\n    }\n  }\n\n  const handleWeekPick = (newDate: Dayjs) => {\n    const weekNumber = newDate.week()\n    const value = `${newDate.year()}w${weekNumber}`\n    emit('pick', {\n      year: newDate.year(),\n      week: weekNumber,\n      value,\n      date: newDate.startOf('week'),\n    })\n  }\n\n  const handleDatesPick = (newDate: Dayjs, selected: boolean) => {\n    const newValue = selected\n      ? castArray(props.parsedValue).filter(\n          (d) => d?.valueOf() !== newDate.valueOf()\n        )\n      : castArray(props.parsedValue).concat([newDate])\n    emit('pick', newValue)\n  }\n\n  const handlePickDate = (\n    event: FocusEvent | MouseEvent,\n    isKeyboardMovement = false\n  ) => {\n    if (props.disabled) return\n    const target = (event.target as HTMLElement).closest('td')\n\n    if (!target) return\n\n    const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n    const column = (target as HTMLTableCellElement).cellIndex\n    const cell = unref(rows)[row][column]\n\n    if (cell.disabled || cell.type === 'week') return\n\n    const newDate = getDateOfCell(row, column)\n\n    switch (props.selectionMode) {\n      case 'range': {\n        handleRangePick(newDate)\n        break\n      }\n      case 'date': {\n        emit('pick', newDate, isKeyboardMovement)\n        break\n      }\n      case 'week': {\n        handleWeekPick(newDate)\n        break\n      }\n      case 'dates': {\n        handleDatesPick(newDate, !!cell.selected)\n        break\n      }\n      default: {\n        break\n      }\n    }\n  }\n\n  const isWeekActive = (cell: DateCell) => {\n    if (props.selectionMode !== 'week') return false\n    let newDate = props.date.startOf('day')\n\n    if (cell.type === 'prev-month') {\n      newDate = newDate.subtract(1, 'month')\n    }\n\n    if (cell.type === 'next-month') {\n      newDate = newDate.add(1, 'month')\n    }\n\n    newDate = newDate.date(Number.parseInt(cell.text as any, 10))\n\n    if (props.parsedValue && !isArray(props.parsedValue)) {\n      const dayOffset = ((props.parsedValue.day() - firstDayOfWeek + 7) % 7) - 1\n      const weekDate = props.parsedValue.subtract(dayOffset, 'day')\n      return weekDate.isSame(newDate, 'day')\n    }\n    return false\n  }\n\n  return {\n    WEEKS,\n    rows,\n    tbodyRef,\n    currentCellRef,\n\n    // cellMatchesDate,\n    // getDateOfCell,\n    focus,\n    isCurrent,\n    isWeekActive,\n    isSelectedCell,\n\n    handlePickDate,\n    handleMouseUp,\n    handleMouseDown,\n    handleMouseMove,\n    handleFocus,\n  }\n}\n\nexport const useBasicDateTableDOM = (\n  props: BasicDateTableProps,\n  {\n    isCurrent,\n    isWeekActive,\n  }: Pick<ReturnType<typeof useBasicDateTable>, 'isCurrent' | 'isWeekActive'>\n) => {\n  const ns = useNamespace('date-table')\n  const { t } = useLocale()\n\n  const tableKls = computed(() => [\n    ns.b(),\n    ns.is('week-mode', props.selectionMode === 'week' && !props.disabled),\n  ])\n\n  const tableLabel = computed(() => t('el.datepicker.dateTablePrompt'))\n\n  const getCellClasses = (cell: DateCell) => {\n    const classes: string[] = []\n    if (isNormalDay(cell.type) && !cell.disabled) {\n      classes.push('available')\n      if (cell.type === 'today') {\n        classes.push('today')\n      }\n    } else {\n      classes.push(cell.type!)\n    }\n\n    if (isCurrent(cell)) {\n      classes.push('current')\n    }\n\n    if (\n      cell.inRange &&\n      (isNormalDay(cell.type) || props.selectionMode === 'week')\n    ) {\n      classes.push('in-range')\n\n      if (cell.start) {\n        classes.push('start-date')\n      }\n\n      if (cell.end) {\n        classes.push('end-date')\n      }\n    }\n\n    if (cell.disabled || props.disabled) {\n      classes.push('disabled')\n    }\n\n    if (cell.selected) {\n      classes.push('selected')\n    }\n\n    if (cell.customClass) {\n      classes.push(cell.customClass)\n    }\n\n    return classes.join(' ')\n  }\n\n  const getRowKls = (cell: DateCell) => [\n    ns.e('row'),\n    { current: isWeekActive(cell) },\n  ]\n\n  return {\n    tableKls,\n    tableLabel,\n    weekHeaderClass: ns.e('week-header'),\n\n    getCellClasses,\n    getRowKls,\n    t,\n  }\n}\n"],"mappings":"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"}