// 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;
  error?: boolean;
  className?: string;
  isClearable?: boolean;
  disabled?: boolean;
  startDate: string | null;
  endDate: string | null;
  selectsStart?: boolean;
  selectsEnd?: boolean;
  minDate?: Date | null | undefined;
  maxDate?: Date | null | undefined;
};

export const CustomRangeDatePicker: React.FC<Props> = ({
  renderAs = "button",
  value,
  onChange,
  error = false,
  className = "",
  disabled = false,
  startDate,
  endDate,
  selectsStart = false,
  selectsEnd = false,
  minDate = null,
  maxDate = null,
}) => (
  <DatePicker
    selected={value ? new Date(value) : null}
    onChange={(val) => {
      if (!val) onChange(null);
      else onChange(renderFormattedPayloadDate(val));
    }}
    className={`${
      renderAs === "input"
        ? "block px-3 py-2 text-sm focus:outline-none"
        : renderAs === "button"
          ? `px-3 py-1 text-xs shadow-sm ${
              disabled ? "" : "hover:bg-custom-background-80"
            } duration-300 focus:border-custom-primary focus:outline-none focus:ring-1 focus:ring-custom-primary`
          : ""
    } ${error ? "border-red-500 bg-red-100" : ""} ${
      disabled ? "cursor-not-allowed" : "cursor-pointer"
    } w-full rounded-md border border-custom-border-200 bg-transparent caret-transparent ${className}`}
    dateFormat="dd-MM-yyyy"
    disabled={disabled}
    selectsStart={selectsStart}
    selectsEnd={selectsEnd}
    startDate={startDate ? new Date(startDate) : new Date()}
    endDate={endDate ? new Date(endDate) : new Date()}
    minDate={minDate}
    maxDate={maxDate}
    shouldCloseOnSelect
    inline
  />
);