import React, { useState } from "react"; import { Popover } from "@headlessui/react"; import DatePicker from "react-datepicker"; import { usePopper } from "react-popper"; import { CalendarDays, X } from "lucide-react"; // import "react-datepicker/dist/react-datepicker.css"; // helpers import { renderFormattedDate } from "helpers/date-time.helper"; import { cn } from "helpers/common.helper"; // types import { TButtonVariants } from "./types"; import { Placement } from "@popperjs/core"; type Props = { buttonClassName?: string; buttonContainerClassName?: string; buttonVariant: TButtonVariants; disabled?: boolean; icon?: React.ReactNode; isClearable?: boolean; minDate?: Date; maxDate?: Date; onChange: (val: Date | null) => void; placeholder: string; placement?: Placement; value: Date | string | null; closeOnSelect?: boolean; }; type ButtonProps = { className?: string; date: string | Date | null; icon: React.ReactNode; isClearable: boolean; hideText?: boolean; onClear: () => void; placeholder: string; }; const BorderButton = (props: ButtonProps) => { const { className, date, icon, isClearable, hideText = false, onClear, placeholder } = props; return (
{icon} {!hideText && {date ? renderFormattedDate(date) : placeholder}} {isClearable && ( { e.stopPropagation(); onClear(); }} /> )}
); }; const BackgroundButton = (props: ButtonProps) => { const { className, date, icon, isClearable, hideText = false, onClear, placeholder } = props; return (
{icon} {!hideText && {date ? renderFormattedDate(date) : placeholder}} {isClearable && ( { e.stopPropagation(); onClear(); }} /> )}
); }; const TransparentButton = (props: ButtonProps) => { const { className, date, icon, isClearable, hideText = false, onClear, placeholder } = props; return (
{icon} {!hideText && {date ? renderFormattedDate(date) : placeholder}} {isClearable && ( { e.stopPropagation(); onClear(); }} /> )}
); }; export const DateDropdown: React.FC = (props) => { const { buttonClassName = "", buttonContainerClassName, buttonVariant, disabled = false, icon = , isClearable = true, minDate, maxDate, onChange, placeholder, placement, value, closeOnSelect = true, } = props; // popper-js refs const [referenceElement, setReferenceElement] = useState(null); const [popperElement, setPopperElement] = useState(null); // popper-js init const { styles, attributes } = usePopper(referenceElement, popperElement, { placement: placement ?? "bottom-start", modifiers: [ { name: "preventOverflow", options: { padding: 12, }, }, ], }); const isDateSelected = value !== null && value !== undefined && value.toString().trim() !== ""; return ( {({ close }) => ( <>
{ onChange(val); if (closeOnSelect) close(); }} dateFormat="dd-MM-yyyy" minDate={minDate} maxDate={maxDate} calendarClassName="shadow-custom-shadow-rg rounded" inline />
)}
); };