Files
keeppay/components/date-picker.tsx
T
root 5ddd93038c feat(fund-pool): 添加资金池管理功能
- 新增资金池分配、余额、配置和支出相关的 API 路由
- 添加资金池支出对话框和页面组件
- 更新相关依赖,支持新功能

这些更改为资金池管理提供了完整的功能支持。
2026-05-12 21:43:58 +08:00

98 lines
3.4 KiB
TypeScript

'use client'
import { useState } from 'react'
import { format } from 'date-fns'
import { zhCN } from 'date-fns/locale'
import { Calendar as CalendarIcon } from 'lucide-react'
import { cn } from '@/lib/utils'
import { Button } from '@/components/ui/button'
import { Calendar } from '@/components/ui/calendar'
import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/popover'
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'
interface DatePickerProps {
value: Date | undefined
onChange: (date: Date | undefined) => void
className?: string
placeholder?: string
}
export function DatePicker({ value, onChange, className, placeholder = '选择日期' }: DatePickerProps) {
const [open, setOpen] = useState(false)
return (
<Popover open={open} onOpenChange={setOpen}>
<PopoverTrigger asChild>
<Button
variant="outline"
className={cn(
'w-[140px] justify-start text-left font-normal h-8',
!value && 'text-muted-foreground',
className,
)}
>
<CalendarIcon className="mr-2 h-4 w-4" />
{value ? format(value, 'yyyy-MM-dd') : <span>{placeholder}</span>}
</Button>
</PopoverTrigger>
<PopoverContent className="w-auto p-0" align="start">
<Calendar
mode="single"
selected={value}
onSelect={(date) => {
onChange(date)
if (date) setOpen(false)
}}
locale={zhCN}
/>
</PopoverContent>
</Popover>
)
}
interface MonthPickerProps {
value: Date
onChange: (date: Date) => void
className?: string
}
export function MonthPicker({ value, onChange, className }: MonthPickerProps) {
const years = Array.from({ length: 10 }, (_, i) => value.getFullYear() - 5 + i)
const months = Array.from({ length: 12 }, (_, i) => i + 1)
return (
<div className={cn('flex items-center gap-1', className)}>
<Select
value={String(value.getFullYear())}
onValueChange={(y) => onChange(new Date(Number(y), value.getMonth(), 1))}
>
<SelectTrigger className="h-8 w-[90px]">
<SelectValue />
</SelectTrigger>
<SelectContent>
{years.map((y) => (
<SelectItem key={y} value={String(y)}>
{y}
</SelectItem>
))}
</SelectContent>
</Select>
<Select
value={String(value.getMonth() + 1)}
onValueChange={(m) => onChange(new Date(value.getFullYear(), Number(m) - 1, 1))}
>
<SelectTrigger className="h-8 w-[80px]">
<SelectValue />
</SelectTrigger>
<SelectContent>
{months.map((m) => (
<SelectItem key={m} value={String(m)}>
{m}
</SelectItem>
))}
</SelectContent>
</Select>
</div>
)
}