5ddd93038c
- 新增资金池分配、余额、配置和支出相关的 API 路由 - 添加资金池支出对话框和页面组件 - 更新相关依赖,支持新功能 这些更改为资金池管理提供了完整的功能支持。
98 lines
3.4 KiB
TypeScript
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>
|
|
)
|
|
}
|