Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@iroomit/react-date-range

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@iroomit/react-date-range - npm Package Compare versions

Comparing version 3.0.0 to 3.1.0

2

dist/accessibility/index.d.ts

@@ -1,2 +0,2 @@

export type AriasLabelsType = {
export type AriaLabelsType = {
dateInput?: {

@@ -3,0 +3,0 @@ startDate?: string;

@@ -6,2 +6,2 @@ "use strict";

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FjY2Vzc2liaWxpdHkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQXJpYXNMYWJlbHNUeXBlID0ge1xuICBkYXRlSW5wdXQ/OiB7XG4gICAgc3RhcnREYXRlPzogc3RyaW5nLFxuICAgIGVuZERhdGU/OiBzdHJpbmdcbiAgfSxcbiAgbW9udGhQaWNrZXI/OiBzdHJpbmcsXG4gIHllYXJQaWNrZXI/OiBzdHJpbmcsXG4gIHByZXZCdXR0b24/OiBzdHJpbmcsXG4gIG5leHRCdXR0b24/OiBzdHJpbmdcbn07Il0sIm1hcHBpbmdzIjoiIn0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FjY2Vzc2liaWxpdHkvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQXJpYUxhYmVsc1R5cGUgPSB7XG4gIGRhdGVJbnB1dD86IHtcbiAgICBzdGFydERhdGU/OiBzdHJpbmcsXG4gICAgZW5kRGF0ZT86IHN0cmluZ1xuICB9LFxuICBtb250aFBpY2tlcj86IHN0cmluZyxcbiAgeWVhclBpY2tlcj86IHN0cmluZyxcbiAgcHJldkJ1dHRvbj86IHN0cmluZyxcbiAgbmV4dEJ1dHRvbj86IHN0cmluZ1xufTsiXSwibWFwcGluZ3MiOiIifQ==
import React from 'react';
import { StylesType } from '../../styles';
import { AriasLabelsType } from '../../accessibility';
import { AriaLabelsType } from '../../accessibility';
import { Locale } from 'date-fns';

@@ -59,4 +59,5 @@ import { DateRange } from '../DayCell';

preventSnapRefocus?: boolean;
ariaLabels?: AriasLabelsType;
ariaLabels?: AriaLabelsType;
preventScrollToFocusedMonth?: boolean;
};
export default function Calendar({ showMonthArrow, showMonthAndYearPickers, disabledDates, disabledDay, minDate, maxDate, date, onChange, onPreviewChange, onRangeFocusChange, classNames, locale, shownDate, onShownDateChange, ranges, preview, dateDisplayFormat, monthDisplayFormat, weekdayDisplayFormat, weekStartsOn, dayDisplayFormat, focusedRange, dayContentRenderer, months, className, showDateDisplay, showPreview, displayMode, color, updateRange, scroll, direction, startDatePlaceholder, endDatePlaceholder, rangeColors, editableDateInputs, dragSelectionEnabled, fixedHeight, calendarFocus, preventSnapRefocus, ariaLabels, }: CalendarProps): import("react/jsx-runtime").JSX.Element;
export default function Calendar({ showMonthArrow, showMonthAndYearPickers, disabledDates, disabledDay, minDate, maxDate, date, onChange, onPreviewChange, onRangeFocusChange, classNames, locale, shownDate, onShownDateChange, ranges, preview, dateDisplayFormat, monthDisplayFormat, weekdayDisplayFormat, weekStartsOn, dayDisplayFormat, focusedRange, dayContentRenderer, months, className, showDateDisplay, showPreview, displayMode, color, updateRange, scroll, direction, startDatePlaceholder, endDatePlaceholder, rangeColors, editableDateInputs, dragSelectionEnabled, fixedHeight, calendarFocus, preventSnapRefocus, ariaLabels, preventScrollToFocusedMonth }: CalendarProps): import("react/jsx-runtime").JSX.Element;

@@ -12,2 +12,2 @@ import { CalendarProps } from '../Calendar';

} & CalendarProps;
export default function DateRange({ ariaLabels, weekStartsOn, weekdayDisplayFormat, editableDateInputs, endDatePlaceholder, showMonthAndYearPickers, onShownDateChange, preventSnapRefocus, preview, scroll, showDateDisplay, showMonthArrow, showPreview, shownDate, startDatePlaceholder, date, dateDisplayFormat, dayContentRenderer, dayDisplayFormat, direction, disabledDay, dragSelectionEnabled, fixedHeight, locale, calendarFocus, className, monthDisplayFormat, months, onChange, classNames, ranges, moveRangeOnFirstSelection, retainEndDateOnFirstSelection, rangeColors, disabledDates, initialFocusedRange, focusedRange, maxDate, minDate, onRangeFocusChange, color, previewRange }: DateRangeProps): import("react/jsx-runtime").JSX.Element;
export default function DateRange({ ariaLabels, weekStartsOn, weekdayDisplayFormat, editableDateInputs, endDatePlaceholder, showMonthAndYearPickers, onShownDateChange, preventSnapRefocus, preview, scroll, showDateDisplay, showMonthArrow, showPreview, shownDate, startDatePlaceholder, date, dateDisplayFormat, dayContentRenderer, dayDisplayFormat, direction, disabledDay, dragSelectionEnabled, fixedHeight, locale, calendarFocus, className, monthDisplayFormat, months, onChange, classNames, ranges, moveRangeOnFirstSelection, retainEndDateOnFirstSelection, rangeColors, disabledDates, initialFocusedRange, focusedRange, maxDate, minDate, onRangeFocusChange, color, previewRange, preventScrollToFocusedMonth }: DateRangeProps): import("react/jsx-runtime").JSX.Element;

@@ -57,3 +57,4 @@ "use strict";

color,
previewRange
previewRange,
preventScrollToFocusedMonth
} = _ref;

@@ -225,5 +226,6 @@ const refs = _react.default.useRef({

minDate: minDate,
color: color
color: color,
preventScrollToFocusedMonth: preventScrollToFocusedMonth
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Calendar","_utils","_styles","_dateFns","_classnames","obj","__esModule","default","DateRange","_ref","ariaLabels","weekStartsOn","weekdayDisplayFormat","editableDateInputs","endDatePlaceholder","showMonthAndYearPickers","onShownDateChange","preventSnapRefocus","preview","scroll","showDateDisplay","showMonthArrow","showPreview","shownDate","startDatePlaceholder","date","dateDisplayFormat","dayContentRenderer","dayDisplayFormat","direction","disabledDay","dragSelectionEnabled","fixedHeight","locale","calendarFocus","className","monthDisplayFormat","months","onChange","classNames","ranges","moveRangeOnFirstSelection","retainEndDateOnFirstSelection","rangeColors","disabledDates","initialFocusedRange","focusedRange","maxDate","minDate","onRangeFocusChange","color","previewRange","refs","React","useRef","styles","generateStyles","Styles","state","setState","useState","findNextRangeIndex","useEffect","updatePreview","calcNewSelection","endDate","value","isSingleValue","arguments","length","undefined","focusedRangeInternal","focusedRangeIndex","selectedRange","startDate","now","Date","nextFocusRange","dayOffset","differenceInCalendarDays","calculateEndDate","addDays","isBefore","min","isStartDateSelected","inValidDatesWithinRange","filter","disabledDate","isWithinInterval","start","end","max","nextFocusRangeIndex","wasValid","range","setSelection","newSelection","toChange","key","s","handleRangeFocusChange","val","colorInternal","createElement","onPreviewChange","displayMode","classnames","current","dateRangeWrapper","updateRange"],"sources":["../../../src/components/DateRange/index.tsx"],"sourcesContent":["import React from 'react';\nimport Calendar, { CalendarProps } from '../Calendar';\nimport { type DateRange } from '../DayCell';\nimport { findNextRangeIndex, generateStyles } from '../../utils';\nimport Styles from '../../styles';\nimport { addDays, differenceInCalendarDays, isBefore, isWithinInterval, max, min } from 'date-fns';\nimport classnames from 'classnames';\n\nexport type DateRangeProps = {\n  onChange: (dateRange: DateRange) => void,\n  onRangeFocusChange?: (range: number[]) => void,\n  className?: string,\n  ranges?: DateRange[],\n  moveRangeOnFirstSelection?: boolean,\n  retainEndDateOnFirstSelection?: boolean,\n  previewRange?: DateRange,\n} & CalendarProps;\n\nexport default function DateRange({\n  ariaLabels,\n  weekStartsOn,\n  weekdayDisplayFormat,\n  editableDateInputs,\n  endDatePlaceholder,\n  showMonthAndYearPickers,\n  onShownDateChange,\n  preventSnapRefocus,\n  preview,\n  scroll,\n  showDateDisplay,\n  showMonthArrow,\n  showPreview,\n  shownDate,\n  startDatePlaceholder,\n  date,\n  dateDisplayFormat,\n  dayContentRenderer,\n  dayDisplayFormat,\n  direction,\n  disabledDay,\n  dragSelectionEnabled,\n  fixedHeight,\n  locale,\n  calendarFocus,\n  className,\n  monthDisplayFormat,\n  months,\n  onChange,\n  classNames = {},\n  ranges = [],\n  moveRangeOnFirstSelection = false,\n  retainEndDateOnFirstSelection = false,\n  rangeColors = ['#3d91ff', '#3ecf8e', '#fed14c'],\n  disabledDates = [],\n  initialFocusedRange,\n  focusedRange,\n  maxDate,\n  minDate,\n  onRangeFocusChange,\n  color,\n  previewRange\n}: DateRangeProps) {\n\n  const refs = React.useRef({\n    styles: generateStyles([Styles, classNames])\n  });\n\n  const [state, setState] = React.useState({\n    focusedRange: initialFocusedRange || [findNextRangeIndex(ranges, 0)],\n    preview: null\n  });\n\n  React.useEffect(() => {\n    updatePreview(previewRange ? calcNewSelection(previewRange, !previewRange.endDate) : null)\n  }, [previewRange]);\n\n  const calcNewSelection = (value: DateRange | Date, isSingleValue = true) => {\n    const focusedRangeInternal = (focusedRange || state.focusedRange);\n    const focusedRangeIndex = focusedRangeInternal[0];\n    const selectedRange = ranges[focusedRangeIndex];\n\n    if (!selectedRange || !onChange) return {};\n\n    let { startDate, endDate } = selectedRange;\n\n    const now = new Date();\n\n    let nextFocusRange: undefined | number[];\n\n    if (!isSingleValue) {\n      startDate = (value as DateRange).startDate;\n      endDate = (value as DateRange).endDate;\n    } else if (focusedRangeInternal[1] === 0) {\n      const dayOffset = differenceInCalendarDays(endDate || now, startDate);\n\n      const calculateEndDate = () => {\n        if (moveRangeOnFirstSelection) {\n          return addDays(value as Date, dayOffset);\n        }\n\n        if (retainEndDateOnFirstSelection) {\n          if (!endDate || isBefore(value as Date, endDate)) {\n            return endDate;\n          }\n          return value as Date;\n        }\n\n        return (value as Date || now);\n      }\n\n      startDate = value as Date;\n      endDate = calculateEndDate();\n      if (maxDate) endDate = min([endDate, maxDate]);\n\n      nextFocusRange = [focusedRangeInternal[0], 1];\n    } else {\n      endDate = value as Date;\n    }\n\n    // reverse dates if startDate before endDate\n    let isStartDateSelected = focusedRangeInternal[1] === 0;\n    if (isBefore(endDate, startDate)) {\n      isStartDateSelected = !isStartDateSelected;\n      [startDate, endDate] = [endDate, startDate];\n    }\n\n    const inValidDatesWithinRange = disabledDates.filter(disabledDate =>\n      isWithinInterval(disabledDate, {\n        start: startDate,\n        end: endDate,\n      })\n    );\n\n    if (inValidDatesWithinRange.length > 0) {\n      if (isStartDateSelected) {\n        startDate = addDays(max(inValidDatesWithinRange), 1);\n      } else {\n        endDate = addDays(min(inValidDatesWithinRange), -1);\n      }\n    }\n\n    if (!nextFocusRange) {\n      const nextFocusRangeIndex = findNextRangeIndex(ranges, focusedRangeInternal[0]);\n      nextFocusRange = [nextFocusRangeIndex, 0];\n    }\n\n    return {\n      wasValid: !(inValidDatesWithinRange.length > 0),\n      range: { startDate, endDate },\n      nextFocusRange: nextFocusRange,\n    };\n\n  }\n\n  const setSelection = (value: DateRange | Date, isSingleValue?: boolean) => {\n    const focusedRangeIndex = (focusedRange || state.focusedRange)[0];\n\n    const selectedRange = ranges[focusedRangeIndex];\n    if (!selectedRange || !onChange) return;\n\n    const newSelection = calcNewSelection(value, isSingleValue);\n\n    const toChange = {\n      [selectedRange.key || `range${focusedRangeIndex + 1}`]: {\n        ...selectedRange,\n        ...newSelection.range,\n      },\n    };\n    \n    onChange?.(toChange as unknown as DateRange);\n\n    setState(s => ({ ...s, focusedRange: newSelection.nextFocusRange, preview: null }));\n\n    onRangeFocusChange?.(newSelection.nextFocusRange);\n  }\n\n  const handleRangeFocusChange = (focusedRange: number[]) => {\n    setState(s => ({ ...s, focusedRange }));\n    onRangeFocusChange?.(focusedRange);\n  }\n\n  const updatePreview = (val?: {\n    wasValid?: boolean,\n    range?: DateRange,\n    nextFocusRange?: number[],\n  }) => {\n\n    if (!val) {\n      setState(s => ({ ...s, preview: null }));\n      return;\n    }\n\n    const focusedRangeInternal = focusedRange || state.focusedRange;\n    const colorInternal = ranges[focusedRangeInternal[0]]?.color || rangeColors[focusedRangeInternal[0]] || color;\n\n    setState((s => ({ ...s, preview: { ...val.range, color: colorInternal } })));\n  }\n  \n  return (\n    <Calendar\n      focusedRange={focusedRange || state.focusedRange}\n      onRangeFocusChange={handleRangeFocusChange}\n      preview={preview || state.preview}\n      onPreviewChange={value => {\n        updatePreview(value ? calcNewSelection(value) : null);\n      }}\n      ariaLabels={ariaLabels}\n      weekStartsOn={weekStartsOn}\n      weekdayDisplayFormat={weekdayDisplayFormat}\n      editableDateInputs={editableDateInputs}\n      endDatePlaceholder={endDatePlaceholder}\n      showMonthAndYearPickers={showMonthAndYearPickers}\n      onShownDateChange={onShownDateChange}\n      preventSnapRefocus={preventSnapRefocus}\n      scroll={scroll}\n      showDateDisplay={showDateDisplay}\n      showMonthArrow={showMonthArrow}\n      showPreview={showPreview}\n      shownDate={shownDate}\n      startDatePlaceholder={startDatePlaceholder}\n      date={date}\n      dateDisplayFormat={dateDisplayFormat}\n      dayContentRenderer={dayContentRenderer}\n      dayDisplayFormat={dayDisplayFormat}\n      direction={direction}\n      disabledDay={disabledDay}\n      dragSelectionEnabled={dragSelectionEnabled}\n      fixedHeight={fixedHeight}\n      locale={locale}\n      calendarFocus={calendarFocus}\n      displayMode='dateRange'\n      className={classnames(refs.current.styles.dateRangeWrapper, className)}\n      onChange={setSelection}\n      updateRange={val => setSelection(val, false)}\n      monthDisplayFormat={monthDisplayFormat}\n      months={months}\n      classNames={classNames}\n      ranges={ranges}\n      rangeColors={rangeColors}\n      disabledDates={disabledDates}\n      initialFocusedRange={initialFocusedRange}\n      maxDate={maxDate}\n      minDate={minDate}\n      color={color}\n    />\n  )\n} "],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Calendar","_utils","_styles","_dateFns","_classnames","obj","__esModule","default","DateRange","_ref","ariaLabels","weekStartsOn","weekdayDisplayFormat","editableDateInputs","endDatePlaceholder","showMonthAndYearPickers","onShownDateChange","preventSnapRefocus","preview","scroll","showDateDisplay","showMonthArrow","showPreview","shownDate","startDatePlaceholder","date","dateDisplayFormat","dayContentRenderer","dayDisplayFormat","direction","disabledDay","dragSelectionEnabled","fixedHeight","locale","calendarFocus","className","monthDisplayFormat","months","onChange","classNames","ranges","moveRangeOnFirstSelection","retainEndDateOnFirstSelection","rangeColors","disabledDates","initialFocusedRange","focusedRange","maxDate","minDate","onRangeFocusChange","color","previewRange","preventScrollToFocusedMonth","refs","React","useRef","styles","generateStyles","Styles","state","setState","useState","findNextRangeIndex","useEffect","updatePreview","calcNewSelection","endDate","value","isSingleValue","arguments","length","undefined","focusedRangeInternal","focusedRangeIndex","selectedRange","startDate","now","Date","nextFocusRange","dayOffset","differenceInCalendarDays","calculateEndDate","addDays","isBefore","min","isStartDateSelected","inValidDatesWithinRange","filter","disabledDate","isWithinInterval","start","end","max","nextFocusRangeIndex","wasValid","range","setSelection","newSelection","toChange","key","s","handleRangeFocusChange","val","colorInternal","createElement","onPreviewChange","displayMode","classnames","current","dateRangeWrapper","updateRange"],"sources":["../../../src/components/DateRange/index.tsx"],"sourcesContent":["import React from 'react';\nimport Calendar, { CalendarProps } from '../Calendar';\nimport { type DateRange } from '../DayCell';\nimport { findNextRangeIndex, generateStyles } from '../../utils';\nimport Styles from '../../styles';\nimport { addDays, differenceInCalendarDays, isBefore, isWithinInterval, max, min } from 'date-fns';\nimport classnames from 'classnames';\n\nexport type DateRangeProps = {\n  onChange: (dateRange: DateRange) => void,\n  onRangeFocusChange?: (range: number[]) => void,\n  className?: string,\n  ranges?: DateRange[],\n  moveRangeOnFirstSelection?: boolean,\n  retainEndDateOnFirstSelection?: boolean,\n  previewRange?: DateRange,\n} & CalendarProps;\n\nexport default function DateRange({\n  ariaLabels,\n  weekStartsOn,\n  weekdayDisplayFormat,\n  editableDateInputs,\n  endDatePlaceholder,\n  showMonthAndYearPickers,\n  onShownDateChange,\n  preventSnapRefocus,\n  preview,\n  scroll,\n  showDateDisplay,\n  showMonthArrow,\n  showPreview,\n  shownDate,\n  startDatePlaceholder,\n  date,\n  dateDisplayFormat,\n  dayContentRenderer,\n  dayDisplayFormat,\n  direction,\n  disabledDay,\n  dragSelectionEnabled,\n  fixedHeight,\n  locale,\n  calendarFocus,\n  className,\n  monthDisplayFormat,\n  months,\n  onChange,\n  classNames = {},\n  ranges = [],\n  moveRangeOnFirstSelection = false,\n  retainEndDateOnFirstSelection = false,\n  rangeColors = ['#3d91ff', '#3ecf8e', '#fed14c'],\n  disabledDates = [],\n  initialFocusedRange,\n  focusedRange,\n  maxDate,\n  minDate,\n  onRangeFocusChange,\n  color,\n  previewRange,\n  preventScrollToFocusedMonth\n}: DateRangeProps) {\n\n  const refs = React.useRef({\n    styles: generateStyles([Styles, classNames])\n  });\n\n  const [state, setState] = React.useState({\n    focusedRange: initialFocusedRange || [findNextRangeIndex(ranges, 0)],\n    preview: null\n  });\n\n  React.useEffect(() => {\n    updatePreview(previewRange ? calcNewSelection(previewRange, !previewRange.endDate) : null)\n  }, [previewRange]);\n\n  const calcNewSelection = (value: DateRange | Date, isSingleValue = true) => {\n    const focusedRangeInternal = (focusedRange || state.focusedRange);\n    const focusedRangeIndex = focusedRangeInternal[0];\n    const selectedRange = ranges[focusedRangeIndex];\n\n    if (!selectedRange || !onChange) return {};\n\n    let { startDate, endDate } = selectedRange;\n\n    const now = new Date();\n\n    let nextFocusRange: undefined | number[];\n\n    if (!isSingleValue) {\n      startDate = (value as DateRange).startDate;\n      endDate = (value as DateRange).endDate;\n    } else if (focusedRangeInternal[1] === 0) {\n      const dayOffset = differenceInCalendarDays(endDate || now, startDate);\n\n      const calculateEndDate = () => {\n        if (moveRangeOnFirstSelection) {\n          return addDays(value as Date, dayOffset);\n        }\n\n        if (retainEndDateOnFirstSelection) {\n          if (!endDate || isBefore(value as Date, endDate)) {\n            return endDate;\n          }\n          return value as Date;\n        }\n\n        return (value as Date || now);\n      }\n\n      startDate = value as Date;\n      endDate = calculateEndDate();\n      if (maxDate) endDate = min([endDate, maxDate]);\n\n      nextFocusRange = [focusedRangeInternal[0], 1];\n    } else {\n      endDate = value as Date;\n    }\n\n    // reverse dates if startDate before endDate\n    let isStartDateSelected = focusedRangeInternal[1] === 0;\n    if (isBefore(endDate, startDate)) {\n      isStartDateSelected = !isStartDateSelected;\n      [startDate, endDate] = [endDate, startDate];\n    }\n\n    const inValidDatesWithinRange = disabledDates.filter(disabledDate =>\n      isWithinInterval(disabledDate, {\n        start: startDate,\n        end: endDate,\n      })\n    );\n\n    if (inValidDatesWithinRange.length > 0) {\n      if (isStartDateSelected) {\n        startDate = addDays(max(inValidDatesWithinRange), 1);\n      } else {\n        endDate = addDays(min(inValidDatesWithinRange), -1);\n      }\n    }\n\n    if (!nextFocusRange) {\n      const nextFocusRangeIndex = findNextRangeIndex(ranges, focusedRangeInternal[0]);\n      nextFocusRange = [nextFocusRangeIndex, 0];\n    }\n\n    return {\n      wasValid: !(inValidDatesWithinRange.length > 0),\n      range: { startDate, endDate },\n      nextFocusRange: nextFocusRange,\n    };\n\n  }\n\n  const setSelection = (value: DateRange | Date, isSingleValue?: boolean) => {\n    const focusedRangeIndex = (focusedRange || state.focusedRange)[0];\n\n    const selectedRange = ranges[focusedRangeIndex];\n    if (!selectedRange || !onChange) return;\n\n    const newSelection = calcNewSelection(value, isSingleValue);\n\n    const toChange = {\n      [selectedRange.key || `range${focusedRangeIndex + 1}`]: {\n        ...selectedRange,\n        ...newSelection.range,\n      },\n    };\n    \n    onChange?.(toChange as unknown as DateRange);\n\n    setState(s => ({ ...s, focusedRange: newSelection.nextFocusRange, preview: null }));\n\n    onRangeFocusChange?.(newSelection.nextFocusRange);\n  }\n\n  const handleRangeFocusChange = (focusedRange: number[]) => {\n    setState(s => ({ ...s, focusedRange }));\n    onRangeFocusChange?.(focusedRange);\n  }\n\n  const updatePreview = (val?: {\n    wasValid?: boolean,\n    range?: DateRange,\n    nextFocusRange?: number[],\n  }) => {\n\n    if (!val) {\n      setState(s => ({ ...s, preview: null }));\n      return;\n    }\n\n    const focusedRangeInternal = focusedRange || state.focusedRange;\n    const colorInternal = ranges[focusedRangeInternal[0]]?.color || rangeColors[focusedRangeInternal[0]] || color;\n\n    setState((s => ({ ...s, preview: { ...val.range, color: colorInternal } })));\n  }\n  \n  return (\n    <Calendar\n      focusedRange={focusedRange || state.focusedRange}\n      onRangeFocusChange={handleRangeFocusChange}\n      preview={preview || state.preview}\n      onPreviewChange={value => {\n        updatePreview(value ? calcNewSelection(value) : null);\n      }}\n      ariaLabels={ariaLabels}\n      weekStartsOn={weekStartsOn}\n      weekdayDisplayFormat={weekdayDisplayFormat}\n      editableDateInputs={editableDateInputs}\n      endDatePlaceholder={endDatePlaceholder}\n      showMonthAndYearPickers={showMonthAndYearPickers}\n      onShownDateChange={onShownDateChange}\n      preventSnapRefocus={preventSnapRefocus}\n      scroll={scroll}\n      showDateDisplay={showDateDisplay}\n      showMonthArrow={showMonthArrow}\n      showPreview={showPreview}\n      shownDate={shownDate}\n      startDatePlaceholder={startDatePlaceholder}\n      date={date}\n      dateDisplayFormat={dateDisplayFormat}\n      dayContentRenderer={dayContentRenderer}\n      dayDisplayFormat={dayDisplayFormat}\n      direction={direction}\n      disabledDay={disabledDay}\n      dragSelectionEnabled={dragSelectionEnabled}\n      fixedHeight={fixedHeight}\n      locale={locale}\n      calendarFocus={calendarFocus}\n      displayMode='dateRange'\n      className={classnames(refs.current.styles.dateRangeWrapper, className)}\n      onChange={setSelection}\n      updateRange={val => setSelection(val, false)}\n      monthDisplayFormat={monthDisplayFormat}\n      months={months}\n      classNames={classNames}\n      ranges={ranges}\n      rangeColors={rangeColors}\n      disabledDates={disabledDates}\n      initialFocusedRange={initialFocusedRange}\n      maxDate={maxDate}\n      minDate={minDate}\n      color={color}\n      preventScrollToFocusedMonth={preventScrollToFocusedMonth}\n    />\n  )\n} "],"mappings":"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"}
import { DateRangeProps } from '../DateRange';
import { DefinedRangeProps } from '../DefinedRange';
export type DateRangePickerProps = DateRangeProps & DefinedRangeProps;
export default function DateRangePicker({ weekStartsOn, weekdayDisplayFormat, editableDateInputs, endDatePlaceholder, rangeColors, ranges, renderStaticRangeLabel, retainEndDateOnFirstSelection, showMonthAndYearPickers, updateRange, initialFocusedRange, ariaLabels, scroll, showDateDisplay, showMonthArrow, showPreview, shownDate, startDatePlaceholder, date, dateDisplayFormat, dayContentRenderer, dayDisplayFormat, direction, disabledDates, disabledDay, displayMode, dragSelectionEnabled, fixedHeight, focusedRange, onChange, footerContent, headerContent, locale, calendarFocus, className, classNames, color, maxDate, minDate, monthDisplayFormat, months, moveRangeOnFirstSelection }: DateRangePickerProps): import("react/jsx-runtime").JSX.Element;
export default function DateRangePicker({ weekStartsOn, weekdayDisplayFormat, editableDateInputs, endDatePlaceholder, rangeColors, ranges, renderStaticRangeLabel, retainEndDateOnFirstSelection, showMonthAndYearPickers, updateRange, initialFocusedRange, ariaLabels, scroll, showDateDisplay, showMonthArrow, showPreview, shownDate, startDatePlaceholder, date, dateDisplayFormat, dayContentRenderer, dayDisplayFormat, direction, disabledDates, disabledDay, displayMode, dragSelectionEnabled, fixedHeight, focusedRange, onChange, footerContent, headerContent, locale, calendarFocus, className, classNames, color, maxDate, minDate, monthDisplayFormat, months, moveRangeOnFirstSelection, preventScrollToFocusedMonth }: DateRangePickerProps): import("react/jsx-runtime").JSX.Element;

@@ -57,3 +57,4 @@ "use strict";

months,
moveRangeOnFirstSelection
moveRangeOnFirstSelection,
preventScrollToFocusedMonth
} = _ref;

@@ -120,5 +121,6 @@ const refs = _react.default.useRef({

months: months,
moveRangeOnFirstSelection: moveRangeOnFirstSelection
moveRangeOnFirstSelection: moveRangeOnFirstSelection,
preventScrollToFocusedMonth: preventScrollToFocusedMonth
}));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_DefinedRange","_utils","_styles","_classnames","_DateRange","obj","__esModule","default","DateRangePicker","_ref","weekStartsOn","weekdayDisplayFormat","editableDateInputs","endDatePlaceholder","rangeColors","ranges","renderStaticRangeLabel","retainEndDateOnFirstSelection","showMonthAndYearPickers","updateRange","initialFocusedRange","ariaLabels","scroll","showDateDisplay","showMonthArrow","showPreview","shownDate","startDatePlaceholder","date","dateDisplayFormat","dayContentRenderer","dayDisplayFormat","direction","disabledDates","disabledDay","displayMode","dragSelectionEnabled","fixedHeight","focusedRange","onChange","footerContent","headerContent","locale","calendarFocus","className","classNames","color","maxDate","minDate","monthDisplayFormat","months","moveRangeOnFirstSelection","refs","React","useRef","styles","generateStyles","Styles","state","setState","useState","findNextRangeIndex","rangePreview","undefined","createElement","classnames","current","dateRangePickerWrapper","onRangeFocusChange","s","previewRange"],"sources":["../../../src/components/DateRangePicker/index.tsx"],"sourcesContent":["import React from 'react';\nimport { DateRangeProps } from '../DateRange';\nimport DefinedRange, { DefinedRangeProps } from '../DefinedRange';\nimport { findNextRangeIndex, generateStyles } from '../../utils';\nimport Styles from '../../styles';\nimport classnames from 'classnames';\nimport DateRange from '../DateRange';\n\nexport type DateRangePickerProps = DateRangeProps & DefinedRangeProps;\n\n\nexport default function DateRangePicker({\n  weekStartsOn,\n  weekdayDisplayFormat,\n  editableDateInputs,\n  endDatePlaceholder,\n  rangeColors,\n  ranges,\n  renderStaticRangeLabel,\n  retainEndDateOnFirstSelection,\n  showMonthAndYearPickers,\n  updateRange,\n  initialFocusedRange,\n  ariaLabels,\n  scroll,\n  showDateDisplay,\n  showMonthArrow,\n  showPreview,\n  shownDate,\n  startDatePlaceholder,\n  date,\n  dateDisplayFormat,\n  dayContentRenderer,\n  dayDisplayFormat,\n  direction,\n  disabledDates,\n  disabledDay,\n  displayMode,\n  dragSelectionEnabled,\n  fixedHeight,\n  focusedRange,\n  onChange,\n  footerContent,\n  headerContent,\n  locale,\n  calendarFocus,\n  className,\n  classNames,\n  color,\n  maxDate,\n  minDate,\n  monthDisplayFormat,\n  months,\n  moveRangeOnFirstSelection\n}: DateRangePickerProps) {\n\n  const refs = React.useRef({\n    styles: generateStyles([Styles, classNames])\n  });\n\n  const [state, setState] = React.useState({\n    focusedRange: [findNextRangeIndex(ranges), 0],\n    rangePreview: undefined\n  });\n\n\n  return (\n    <div className={classnames(refs.current.styles.dateRangePickerWrapper, className)}>\n      <DefinedRange\n        focusedRange={focusedRange || state.focusedRange}\n        rangeColors={rangeColors}\n        onChange={onChange}\n        ranges={ranges}\n        renderStaticRangeLabel={renderStaticRangeLabel}\n        headerContent={headerContent}\n        footerContent={footerContent}\n      />\n      <DateRange\n        onRangeFocusChange={focusedRange => setState(s => ({...s, focusedRange}))}\n        focusedRange={focusedRange || state.focusedRange}\n        weekStartsOn={weekStartsOn}\n        weekdayDisplayFormat={weekdayDisplayFormat}\n        editableDateInputs={editableDateInputs}\n        endDatePlaceholder={endDatePlaceholder}\n        rangeColors={rangeColors}\n        ranges={ranges}\n        retainEndDateOnFirstSelection={retainEndDateOnFirstSelection}\n        showMonthAndYearPickers={showMonthAndYearPickers}\n        updateRange={updateRange}\n        initialFocusedRange={initialFocusedRange}\n        ariaLabels={ariaLabels}\n        scroll={scroll}\n        showDateDisplay={showDateDisplay}\n        showMonthArrow={showMonthArrow}\n        onChange={onChange}\n        showPreview={showPreview}\n        shownDate={shownDate}\n        startDatePlaceholder={startDatePlaceholder}\n        date={date}\n        dateDisplayFormat={dateDisplayFormat}\n        dayContentRenderer={dayContentRenderer}\n        dayDisplayFormat={dayDisplayFormat}\n        direction={direction}\n        disabledDates={disabledDates}\n        disabledDay={disabledDay}\n        displayMode={displayMode}\n        dragSelectionEnabled={dragSelectionEnabled}\n        fixedHeight={fixedHeight}\n        locale={locale}\n        calendarFocus={calendarFocus}\n        previewRange={state.rangePreview}\n        classNames={classNames}\n        color={color}\n        maxDate={maxDate}\n        minDate={minDate}\n        monthDisplayFormat={monthDisplayFormat}\n        months={months}\n        moveRangeOnFirstSelection={moveRangeOnFirstSelection}\n      />\n    </div>\n  )\n\n}"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_DefinedRange","_utils","_styles","_classnames","_DateRange","obj","__esModule","default","DateRangePicker","_ref","weekStartsOn","weekdayDisplayFormat","editableDateInputs","endDatePlaceholder","rangeColors","ranges","renderStaticRangeLabel","retainEndDateOnFirstSelection","showMonthAndYearPickers","updateRange","initialFocusedRange","ariaLabels","scroll","showDateDisplay","showMonthArrow","showPreview","shownDate","startDatePlaceholder","date","dateDisplayFormat","dayContentRenderer","dayDisplayFormat","direction","disabledDates","disabledDay","displayMode","dragSelectionEnabled","fixedHeight","focusedRange","onChange","footerContent","headerContent","locale","calendarFocus","className","classNames","color","maxDate","minDate","monthDisplayFormat","months","moveRangeOnFirstSelection","preventScrollToFocusedMonth","refs","React","useRef","styles","generateStyles","Styles","state","setState","useState","findNextRangeIndex","rangePreview","undefined","createElement","classnames","current","dateRangePickerWrapper","onRangeFocusChange","s","previewRange"],"sources":["../../../src/components/DateRangePicker/index.tsx"],"sourcesContent":["import React from 'react';\nimport { DateRangeProps } from '../DateRange';\nimport DefinedRange, { DefinedRangeProps } from '../DefinedRange';\nimport { findNextRangeIndex, generateStyles } from '../../utils';\nimport Styles from '../../styles';\nimport classnames from 'classnames';\nimport DateRange from '../DateRange';\n\nexport type DateRangePickerProps = DateRangeProps & DefinedRangeProps;\n\n\nexport default function DateRangePicker({\n  weekStartsOn,\n  weekdayDisplayFormat,\n  editableDateInputs,\n  endDatePlaceholder,\n  rangeColors,\n  ranges,\n  renderStaticRangeLabel,\n  retainEndDateOnFirstSelection,\n  showMonthAndYearPickers,\n  updateRange,\n  initialFocusedRange,\n  ariaLabels,\n  scroll,\n  showDateDisplay,\n  showMonthArrow,\n  showPreview,\n  shownDate,\n  startDatePlaceholder,\n  date,\n  dateDisplayFormat,\n  dayContentRenderer,\n  dayDisplayFormat,\n  direction,\n  disabledDates,\n  disabledDay,\n  displayMode,\n  dragSelectionEnabled,\n  fixedHeight,\n  focusedRange,\n  onChange,\n  footerContent,\n  headerContent,\n  locale,\n  calendarFocus,\n  className,\n  classNames,\n  color,\n  maxDate,\n  minDate,\n  monthDisplayFormat,\n  months,\n  moveRangeOnFirstSelection,\n  preventScrollToFocusedMonth\n}: DateRangePickerProps) {\n\n  const refs = React.useRef({\n    styles: generateStyles([Styles, classNames])\n  });\n\n  const [state, setState] = React.useState({\n    focusedRange: [findNextRangeIndex(ranges), 0],\n    rangePreview: undefined\n  });\n\n\n  return (\n    <div className={classnames(refs.current.styles.dateRangePickerWrapper, className)}>\n      <DefinedRange\n        focusedRange={focusedRange || state.focusedRange}\n        rangeColors={rangeColors}\n        onChange={onChange}\n        ranges={ranges}\n        renderStaticRangeLabel={renderStaticRangeLabel}\n        headerContent={headerContent}\n        footerContent={footerContent}\n      />\n      <DateRange\n        onRangeFocusChange={focusedRange => setState(s => ({...s, focusedRange}))}\n        focusedRange={focusedRange || state.focusedRange}\n        weekStartsOn={weekStartsOn}\n        weekdayDisplayFormat={weekdayDisplayFormat}\n        editableDateInputs={editableDateInputs}\n        endDatePlaceholder={endDatePlaceholder}\n        rangeColors={rangeColors}\n        ranges={ranges}\n        retainEndDateOnFirstSelection={retainEndDateOnFirstSelection}\n        showMonthAndYearPickers={showMonthAndYearPickers}\n        updateRange={updateRange}\n        initialFocusedRange={initialFocusedRange}\n        ariaLabels={ariaLabels}\n        scroll={scroll}\n        showDateDisplay={showDateDisplay}\n        showMonthArrow={showMonthArrow}\n        onChange={onChange}\n        showPreview={showPreview}\n        shownDate={shownDate}\n        startDatePlaceholder={startDatePlaceholder}\n        date={date}\n        dateDisplayFormat={dateDisplayFormat}\n        dayContentRenderer={dayContentRenderer}\n        dayDisplayFormat={dayDisplayFormat}\n        direction={direction}\n        disabledDates={disabledDates}\n        disabledDay={disabledDay}\n        displayMode={displayMode}\n        dragSelectionEnabled={dragSelectionEnabled}\n        fixedHeight={fixedHeight}\n        locale={locale}\n        calendarFocus={calendarFocus}\n        previewRange={state.rangePreview}\n        classNames={classNames}\n        color={color}\n        maxDate={maxDate}\n        minDate={minDate}\n        monthDisplayFormat={monthDisplayFormat}\n        months={months}\n        moveRangeOnFirstSelection={moveRangeOnFirstSelection}\n        preventScrollToFocusedMonth={preventScrollToFocusedMonth}\n      />\n    </div>\n  )\n\n}"],"mappings":"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"}
{
"name": "@iroomit/react-date-range",
"version": "3.0.0",
"version": "3.1.0",
"description": "A React component for choosing dates and date ranges.",

@@ -5,0 +5,0 @@ "main": "dist/index.js",

@@ -77,16 +77,13 @@ # @iroomit/react-date-range

```javascript
import React from 'react';
import { Calendar } from '@iroomit/react-date-range';
class MyComponent extends Component {
handleSelect(date){
console.log(date); // native Date object
}
render(){
return (
<Calendar
date={new Date()}
onChange={this.handleSelect}
/>
)
}
function MyComponent() {
const [date, setDate] = React.useState(new Date());
return (
// onChange returns native Date Object
<Calendar date={date} onChange={date => setDate(date)}/>
)
}

@@ -98,27 +95,30 @@

```javascript
import React from 'react';
import { DateRangePicker } from '@iroomit/react-date-range';
class MyComponent extends Component {
handleSelect(ranges){
console.log(ranges);
// {
// selection: {
// startDate: [native Date Object],
// endDate: [native Date Object],
// }
// }
}
render(){
const selectionRange = {
startDate: new Date(),
endDate: new Date(),
key: 'selection',
}
return (
<DateRangePicker
ranges={[selectionRange]}
onChange={this.handleSelect}
/>
)
}
function MyComponent() {
const [range, setRange] = React.useState({
startDate: new Date(),
endDate: new Date(),
key: 'selection' // used as key for range returned from onChange
});
return (
<DateRangePicker ranges={[range]} onChange={(range) => {
// range returned from onChange will have the structure
// {
// selection: {
// startDate: [native Date Object],
// endDate: [native Date Object],
// }
// }
setRange({
startDate: range.startDate,
endDate: range.endDate,
key: Object.keys(range)[0]
});
}}/>
);
}

@@ -179,31 +179,30 @@

dayContentRenderer | Function | null | Function to customize the rendering of Calendar Day. given a date is supposed to return what to render.
preventScrollToFocusedMonth | Boolean | false | When two or more months are open, prevent the shift of the focused month to the left.
*shape of range:
```js
{
startDate: PropTypes.object,
endDate: PropTypes.object,
color: PropTypes.string,
key: PropTypes.string,
autoFocus: PropTypes.bool,
disabled: PropTypes.bool,
showDateDisplay: PropTypes.bool,
}
#### Type DateRange:
```ts
type DateRange = {
startDate: Date,
endDate: Date,
color?: string,
key?: string,
autoFocus?: boolean,
disabled?: boolean,
showDateDisplay?: boolean,
label?: string
}
```
**shape of ariaLabels:
```js
{
// The key of dateInput should be same as key in range.
dateInput: PropTypes.objectOf(
PropTypes.shape({
startDate: PropTypes.string,
endDate: PropTypes.string
})
),
monthPicker: PropTypes.string,
yearPicker: PropTypes.string,
prevButton: PropTypes.string,
nextButton: PropTypes.string,
}
#### Type AriaLabelsType:
```ts
type AriaLabelsType = {
dateInput?: {
startDate?: string,
endDate?: string
},
monthPicker?: string,
yearPicker?: string,
prevButton?: string,
nextButton?: string
}
```

@@ -215,12 +214,11 @@ #### Infinite Scrolled Mode

```js
// shape of scroll prop
scroll: {
enabled: PropTypes.bool,
monthHeight: PropTypes.number,
longMonthHeight: PropTypes.number, // some months has 1 more row than others
monthWidth: PropTypes.number, // just used when direction="horizontal"
calendarWidth: PropTypes.number, // defaults monthWidth * months
calendarHeight: PropTypes.number, // defaults monthHeight * months
}),
```ts
type Scroll = {
enabled?: boolean,
monthHeight?: number,
longMonthHeight?: number,
monthWidth?: number,
calendarWidth?: number,
calendarHeight?: number
}
```

@@ -227,0 +225,0 @@

@@ -1,2 +0,2 @@

export type AriasLabelsType = {
export type AriaLabelsType = {
dateInput?: {

@@ -3,0 +3,0 @@ startDate?: string,

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc