mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-07-02 17:08:39 +00:00
66 lines
2.1 KiB
TypeScript
66 lines
2.1 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import { Calendar } from "@/examples/base/ui/calendar"
|
|
import { Card, CardContent, CardFooter } from "@/examples/base/ui/card"
|
|
import { Field, FieldGroup, FieldLabel } from "@/examples/base/ui/field"
|
|
import {
|
|
InputGroup,
|
|
InputGroupAddon,
|
|
InputGroupInput,
|
|
} from "@/examples/base/ui/input-group"
|
|
import { Clock2Icon } from "lucide-react"
|
|
|
|
export function CalendarWithTime() {
|
|
const [date, setDate] = React.useState<Date | undefined>(
|
|
new Date(new Date().getFullYear(), new Date().getMonth(), 12)
|
|
)
|
|
|
|
return (
|
|
<Card size="sm" className="mx-auto w-fit">
|
|
<CardContent>
|
|
<Calendar
|
|
mode="single"
|
|
selected={date}
|
|
onSelect={setDate}
|
|
className="p-0"
|
|
/>
|
|
</CardContent>
|
|
<CardFooter className="border-t bg-card">
|
|
<FieldGroup>
|
|
<Field>
|
|
<FieldLabel htmlFor="time-from">Start Time</FieldLabel>
|
|
<InputGroup>
|
|
<InputGroupInput
|
|
id="time-from"
|
|
type="time"
|
|
step="1"
|
|
defaultValue="10:30:00"
|
|
className="appearance-none [&::-webkit-calendar-picker-indicator]:hidden [&::-webkit-calendar-picker-indicator]:appearance-none"
|
|
/>
|
|
<InputGroupAddon>
|
|
<Clock2Icon className="text-muted-foreground" />
|
|
</InputGroupAddon>
|
|
</InputGroup>
|
|
</Field>
|
|
<Field>
|
|
<FieldLabel htmlFor="time-to">End Time</FieldLabel>
|
|
<InputGroup>
|
|
<InputGroupInput
|
|
id="time-to"
|
|
type="time"
|
|
step="1"
|
|
defaultValue="12:30:00"
|
|
className="appearance-none [&::-webkit-calendar-picker-indicator]:hidden [&::-webkit-calendar-picker-indicator]:appearance-none"
|
|
/>
|
|
<InputGroupAddon>
|
|
<Clock2Icon className="text-muted-foreground" />
|
|
</InputGroupAddon>
|
|
</InputGroup>
|
|
</Field>
|
|
</FieldGroup>
|
|
</CardFooter>
|
|
</Card>
|
|
)
|
|
}
|