UNPKG

react-day-picker

Version:

Customizable Date Picker for React

40 lines 1.43 kB
import React from "react"; export function useSingle(props, dateLib) { const { selected: initiallySelected, required, onSelect, mode } = props; const [selected, setSelected] = React.useState(initiallySelected); const { isSameDay, Date, startOfDay } = dateLib; // Update the selected date if the required flag is set. React.useEffect(() => { if (required && selected === undefined) { setSelected(startOfDay(new Date())); } }, [required, selected, Date, startOfDay, mode]); // Update the selected date if the `selected` value changes. React.useEffect(() => { setSelected(initiallySelected); }, [initiallySelected]); const isSelected = (compareDate) => { return selected ? isSameDay(selected, compareDate) : false; }; const select = (triggerDate, modifiers, e) => { let newDate = triggerDate; if (!required && selected && selected && isSameDay(triggerDate, selected)) { // If the date is the same, clear the selection. newDate = undefined; } setSelected(newDate); if (required) { onSelect?.(newDate, triggerDate, modifiers, e); } else { onSelect?.(newDate, triggerDate, modifiers, e); } return newDate; }; return { selected, select, isSelected }; } //# sourceMappingURL=useSingle.js.map