first commit

This commit is contained in:
JohnsonRan
2025-08-12 21:50:58 +08:00
commit 8b9be4bb19
121 changed files with 36497 additions and 0 deletions

View File

@@ -0,0 +1,74 @@
/* eslint-disable react-hooks/exhaustive-deps */
'use client';
import React, { useEffect, useState } from 'react';
interface WeekdaySelectorProps {
onWeekdayChange: (weekday: string) => void;
className?: string;
}
const weekdays = [
{ value: 'Mon', label: '周一', shortLabel: '周一' },
{ value: 'Tue', label: '周二', shortLabel: '周二' },
{ value: 'Wed', label: '周三', shortLabel: '周三' },
{ value: 'Thu', label: '周四', shortLabel: '周四' },
{ value: 'Fri', label: '周五', shortLabel: '周五' },
{ value: 'Sat', label: '周六', shortLabel: '周六' },
{ value: 'Sun', label: '周日', shortLabel: '周日' },
];
const WeekdaySelector: React.FC<WeekdaySelectorProps> = ({
onWeekdayChange,
className = '',
}) => {
// 获取今天的星期数,默认选中今天
const getTodayWeekday = (): string => {
const today = new Date().getDay();
// getDay() 返回 0-60 是周日1-6 是周一到周六
const weekdayMap = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];
return weekdayMap[today];
};
const [selectedWeekday, setSelectedWeekday] = useState<string>(
getTodayWeekday()
);
// 组件初始化时通知父组件默认选中的星期
useEffect(() => {
onWeekdayChange(getTodayWeekday());
}, []); // 只在组件挂载时执行一次
return (
<div
className={`relative inline-flex rounded-full p-0.5 sm:p-1 ${className}`}
>
{weekdays.map((weekday) => {
const isActive = selectedWeekday === weekday.value;
return (
<button
key={weekday.value}
onClick={() => {
setSelectedWeekday(weekday.value);
onWeekdayChange(weekday.value);
}}
className={`
relative z-10 px-2 py-1 sm:px-4 sm:py-2 text-xs sm:text-sm font-medium rounded-full transition-all duration-200 whitespace-nowrap
${
isActive
? 'text-green-600 dark:text-green-400 font-semibold'
: 'text-gray-600 hover:text-gray-800 dark:text-gray-400 dark:hover:text-gray-200 cursor-pointer'
}
`}
title={weekday.label}
>
{weekday.shortLabel}
</button>
);
})}
</div>
);
};
export default WeekdaySelector;