File size: 3,003 Bytes
13a0af9
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
"use client";

import * as React from "react";
import { ChevronLeft, ChevronRight } from "lucide-react@0.487.0";
import { DayPicker } from "react-day-picker@8.10.1";

import { cn } from "./utils";
import { buttonVariants } from "./button";

function Calendar({

  className,

  classNames,

  showOutsideDays = true,

  ...props

}: React.ComponentProps<typeof DayPicker>) {
  return (
    <DayPicker

      showOutsideDays={showOutsideDays}

      className={cn("p-3", className)}

      classNames={{

        months: "flex flex-col sm:flex-row gap-2",

        month: "flex flex-col gap-4",

        caption: "flex justify-center pt-1 relative items-center w-full",

        caption_label: "text-sm font-medium",

        nav: "flex items-center gap-1",

        nav_button: cn(

          buttonVariants({ variant: "outline" }),

          "size-7 bg-transparent p-0 opacity-50 hover:opacity-100",

        ),

        nav_button_previous: "absolute left-1",

        nav_button_next: "absolute right-1",

        table: "w-full border-collapse space-x-1",

        head_row: "flex",

        head_cell:

          "text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]",

        row: "flex w-full mt-2",

        cell: cn(

          "relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-range-end)]:rounded-r-md",

          props.mode === "range"

            ? "[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md"

            : "[&:has([aria-selected])]:rounded-md",

        ),

        day: cn(

          buttonVariants({ variant: "ghost" }),

          "size-8 p-0 font-normal aria-selected:opacity-100",

        ),

        day_range_start:

          "day-range-start aria-selected:bg-primary aria-selected:text-primary-foreground",

        day_range_end:

          "day-range-end aria-selected:bg-primary aria-selected:text-primary-foreground",

        day_selected:

          "bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground",

        day_today: "bg-accent text-accent-foreground",

        day_outside:

          "day-outside text-muted-foreground aria-selected:text-muted-foreground",

        day_disabled: "text-muted-foreground opacity-50",

        day_range_middle:

          "aria-selected:bg-accent aria-selected:text-accent-foreground",

        day_hidden: "invisible",

        ...classNames,

      }}

      components={{

        IconLeft: ({ className, ...props }) => (

          <ChevronLeft className={cn("size-4", className)} {...props} />

        ),

        IconRight: ({ className, ...props }) => (

          <ChevronRight className={cn("size-4", className)} {...props} />

        ),

      }}

      {...props}

    />
  );
}

export { Calendar };