All files / react-app/src/components/Inputs date-picker.tsx

100% Statements 6/6
100% Branches 3/3
100% Functions 2/2
100% Lines 6/6

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44                  72x 179x 179x                                           9x 9x 9x                
"use client";
 
import * as React from "react";
import { format } from "date-fns";
import { Calendar as CalendarIcon } from "lucide-react";
import { DatePickerProps } from "shared-types";
import { cn } from "@/utils";
import { Button, Calendar, Popover, PopoverContent, PopoverTrigger } from "@/components";
 
export const DatePicker = ({ date, onChange, dataTestId }: DatePickerProps) => {
  const [isCalendarOpen, setIsCalendarOpen] = React.useState<boolean>(false);
  const [selected, setSelected] = React.useState<Date>();
  return (
    <Popover open={isCalendarOpen} onOpenChange={setIsCalendarOpen}>
      <PopoverTrigger asChild>
        <Button
          variant={"outline"}
          className={cn(
            "w-[280px] justify-start text-left font-normal",
            !date && "text-muted-foreground",
          )}
          data-testid={`${dataTestId}-datepicker`}
        >
          <CalendarIcon className="mr-2 h-4 w-4" />
          {date ? format(date, "MM/dd/yyyy") : <span>Pick a date</span>}
        </Button>
      </PopoverTrigger>
      <PopoverContent className="w-auto p-0">
        <Calendar
          mode="single"
          selected={selected}
          defaultMonth={selected}
          onSelect={(date) => {
            setSelected(date);
            onChange(date);
            setIsCalendarOpen(false);
          }}
          initialFocus
        />
      </PopoverContent>
    </Popover>
  );
};