// 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; placeholder?: string; displayShortForm?: boolean; error?: boolean; noBorder?: boolean; className?: string; isClearable?: boolean; disabled?: boolean; minDate?: Date; }; export const CustomDatePicker: React.FC = ({ renderAs = "button", value, onChange, placeholder = "Select date", displayShortForm = false, error = false, noBorder = false, className = "", isClearable = true, disabled = false, minDate, }) => ( { if (!val) onChange(null); else onChange(renderDateFormat(val)); }} 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} minDate={minDate} /> );