// react-datepicker import DatePicker from "react-datepicker"; import "react-datepicker/dist/react-datepicker.css"; // helpers import { renderDateFormat } from "helpers/date-time.helper"; type Props = { renderAs?: "input" | "button"; value: Date | string | null | undefined; onChange: (val: string | null) => void; handleOnOpen?: () => void; handleOnClose?: () => void; placeholder?: string; displayShortForm?: boolean; error?: boolean; noBorder?: boolean; wrapperClassName?: string; className?: string; isClearable?: boolean; disabled?: boolean; maxDate?: Date; minDate?: Date; }; export const CustomDatePicker: React.FC = ({ renderAs = "button", value, onChange, handleOnOpen, handleOnClose, placeholder = "Select date", displayShortForm = false, error = false, noBorder = false, wrapperClassName = "", className = "", isClearable = true, disabled = false, maxDate, minDate, }) => ( { if (!val) onChange(null); else onChange(renderDateFormat(val)); }} onCalendarOpen={handleOnOpen} onCalendarClose={handleOnClose} wrapperClassName={wrapperClassName} className={`${ renderAs === "input" ? "block px-2 py-2 text-sm focus:outline-none" : renderAs === "button" ? `px-2 py-1 text-xs shadow-sm ${ disabled ? "" : "hover:bg-custom-background-80" } duration-300` : "" } ${error ? "border-red-500 bg-red-100" : ""} ${ disabled ? "cursor-not-allowed" : "cursor-pointer" } ${ noBorder ? "" : "border border-custom-border-200" } w-full rounded-md caret-transparent outline-none ${className}`} dateFormat="MMM dd, yyyy" isClearable={isClearable} disabled={disabled} maxDate={maxDate} minDate={minDate} /> );