Home / File/ calendar.tsx — ui Source File

calendar.tsx — ui Source File

Architecture documentation for calendar.tsx, a tsx file in the ui codebase. 5 imports, 0 dependents.

File tsx DocumentationAtlas SearchAPI 5 imports 2 functions

Entity Profile

Dependency Diagram

graph LR
  59ba36ea_026b_17fb_4e18_a819ae8b0340["calendar.tsx"]
  1d141819_425e_b5fd_4c8e_32f7c6a42cf2["react"]
  59ba36ea_026b_17fb_4e18_a819ae8b0340 --> 1d141819_425e_b5fd_4c8e_32f7c6a42cf2
  191e4a89_25e4_f7a3_d5fb_d71d101e0990["utils"]
  59ba36ea_026b_17fb_4e18_a819ae8b0340 --> 191e4a89_25e4_f7a3_d5fb_d71d101e0990
  4b1d2128_46d9_46f0_b915_b6e1925b7876["button"]
  59ba36ea_026b_17fb_4e18_a819ae8b0340 --> 4b1d2128_46d9_46f0_b915_b6e1925b7876
  d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3["lucide-react"]
  59ba36ea_026b_17fb_4e18_a819ae8b0340 --> d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3
  bfc8708c_7488_3983_8998_32b793781735["react-day-picker"]
  59ba36ea_026b_17fb_4e18_a819ae8b0340 --> bfc8708c_7488_3983_8998_32b793781735
  style 59ba36ea_026b_17fb_4e18_a819ae8b0340 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

"use client"

import * as React from "react"
import { cn } from "@/examples/radix/lib/utils"
import { Button, buttonVariants } from "@/examples/radix/ui/button"
import {
  ChevronDownIcon,
  ChevronLeftIcon,
  ChevronRightIcon,
} from "lucide-react"
import {
  DayPicker,
  getDefaultClassNames,
  type DayButton,
  type Locale,
} from "react-day-picker"

function Calendar({
  className,
  classNames,
  showOutsideDays = true,
  captionLayout = "label",
  buttonVariant = "ghost",
  locale,
  formatters,
  components,
  ...props
}: React.ComponentProps<typeof DayPicker> & {
  buttonVariant?: React.ComponentProps<typeof Button>["variant"]
}) {
  const defaultClassNames = getDefaultClassNames()

  return (
    <DayPicker
      showOutsideDays={showOutsideDays}
      className={cn(
        "bg-background group/calendar p-2 [--cell-radius:var(--radius-md)] [--cell-size:--spacing(7)] in-data-[slot=card-content]:bg-transparent in-data-[slot=popover-content]:bg-transparent",
        String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,
        String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,
        className
      )}
      captionLayout={captionLayout}
      locale={locale}
      formatters={{
        formatMonthDropdown: (date) =>
          date.toLocaleString(locale?.code, { month: "short" }),
        ...formatters,
      }}
      classNames={{
        root: cn("w-fit", defaultClassNames.root),
        months: cn(
          "flex gap-4 flex-col md:flex-row relative",
          defaultClassNames.months
        ),
        month: cn("flex flex-col w-full gap-4", defaultClassNames.month),
        nav: cn(
          "flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",
          defaultClassNames.nav
        ),
        button_previous: cn(
// ... (172 more lines)

Subdomains

Dependencies

  • button
  • lucide-react
  • react
  • react-day-picker
  • utils

Frequently Asked Questions

What does calendar.tsx do?
calendar.tsx is a source file in the ui codebase, written in tsx. It belongs to the DocumentationAtlas domain, SearchAPI subdomain.
What functions are defined in calendar.tsx?
calendar.tsx defines 2 function(s): Calendar, CalendarDayButton.
What does calendar.tsx depend on?
calendar.tsx imports 5 module(s): button, lucide-react, react, react-day-picker, utils.
Where is calendar.tsx in the architecture?
calendar.tsx is located at apps/v4/examples/radix/ui/calendar.tsx (domain: DocumentationAtlas, subdomain: SearchAPI, directory: apps/v4/examples/radix/ui).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free