// 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; }; export const CustomDatePicker: React.FC<Props> = ({ renderAs = "button", value, onChange, placeholder = "Select date", displayShortForm = false, error = false, noBorder = false, className = "", isClearable = true, disabled = false, }) => ( <DatePicker placeholderText={placeholder} selected={value ? new Date(value) : null} onChange={(val) => { 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-brand-surface-2" } duration-300 focus:border-brand-accent focus:outline-none focus:ring-1 focus:ring-brand-accent` : "" } ${error ? "border-red-500 bg-red-100" : ""} ${ disabled ? "cursor-not-allowed" : "cursor-pointer" } ${ noBorder ? "" : "border border-brand-base" } w-full rounded-md bg-transparent caret-transparent ${className}`} dateFormat="MMM dd, yyyy" isClearable={isClearable} disabled={disabled} /> );