// react-datepicker
import DatePicker from "react-datepicker";
import "react-datepicker/dist/react-datepicker.css";
// helpers
import { renderFormattedPayloadDate } from "helpers/date-time.helper";

type Props = {
  renderAs?: "input" | "button";
  value: Date | string | null | undefined;
  onChange: (val: string | null) => void;
  handleOnOpen?: () => void;
  handleOnClose?: () => void;
  customInput?: React.ReactNode;
  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<Props> = ({
  renderAs = "button",
  value,
  onChange,
  handleOnOpen,
  handleOnClose,
  placeholder = "Select date",
  error = false,
  noBorder = false,
  wrapperClassName = "",
  className = "",
  isClearable = true,
  disabled = false,
  customInput,
  maxDate,
  minDate,
}) => (
  <DatePicker
    placeholderText={placeholder}
    selected={value ? new Date(value) : null}
    onChange={(val) => {
      if (!val) onChange(null);
      else onChange(renderFormattedPayloadDate(val));
    }}
    onCalendarOpen={handleOnOpen}
    onCalendarClose={handleOnClose}
    wrapperClassName={wrapperClassName}
    customInput={customInput}
    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={Boolean(isClearable && !disabled)}
    disabled={disabled}
    maxDate={maxDate}
    minDate={minDate}
  />
);