تمسازی
ما از متغیرهای CSS برای مدیریت رنگهای تم استفاده میکنیم، که امکان سفارشیسازی و گسترش تم را آسان میکند. شما میتوانید رنگهای تم را با ویرایش متغیرهای CSS در فایل موجود در:assets/styles/tailwind/index.css
اینجا تنظیم پیشفرض برای حالتهای روشن و تاریک است:
:root {
--neutral: #ffffff;
--primary: #2a85ff;
--primary-deep: #0069f6;
--primary-mild: #4996ff;
--primary-subtle: #2a85ff1a;
--error: #ff6a55;
--error-subtle: #ff6a551a;
--success: #10b981;
--success-subtle: #05eb7624;
--info: #2a85ff;
--info-subtle: #2a85ff1a;
--warning: #f59e0b;
--warning-subtle: #ffd40045;
--gray-50: #fafafa;
--gray-100: #f5f5f5;
--gray-200: #e5e5e5;
--gray-300: #d4d4d4;
--gray-400: #a3a3a3;
--gray-500: #737373;
--gray-600: #525252;
--gray-700: #404040;
--gray-800: #262626;
--gray-900: #171717;
--gray-950: #0a0a0a;
}
.dark {
--neutral: #ffffff;
--primary: #2a85ff;
--primary-deep: #0069f6;
--primary-mild: #4996ff;
--primary-subtle: #2a85ff1a;
--error: #ff6a55;
--error-subtle: #ff6a551a;
--success: #10b981;
--success-subtle: #05eb7624;
--info: #2a85ff;
--info-subtle: #2a85ff1a;
--warning: #f59e0b;
--warning-subtle: #ffd40045;
--gray-50: #fafafa;
--gray-100: #f5f5f5;
--gray-200: #e5e5e5;
--gray-300: #d4d4d4;
--gray-400: #a3a3a3;
--gray-500: #737373;
--gray-600: #525252;
--gray-700: #404040;
--gray-800: #262626;
--gray-900: #171717;
--gray-950: #0a0a0a;
}راهاندازی تم پویا
اگر میخواهید تغییر تم پویا را در برنامه خود فعال کنید، باید چند مرحله اضافی انجام دهید. ابتدا، طرح تم خود را در فایل configs/theme.config.ts تنظیم کنید:
export type Variables =
| "primary"
| "primaryDeep"
| "primaryMild"
| "primarySubtle"
| "neutral";
export type ThemeVariables = Record<
"light" | "dark",
Record<Variables, string>
>
/** Default theme schema should corresponding to the CSS variables */
const defaultTheme: ThemeVariables = {
light: {
primary: "#2a85ff",
primaryDeep: "#0069f6",
primaryMild: "#4996ff",
primarySubtle: "#2a85ff1a",
neutral: "#ffffff",
},
dark: {
primary: "#2a85ff",
primaryDeep: "#0069f6",
primaryMild: "#4996ff",
primarySubtle: "#2a85ff1a",
neutral: "#ffffff",
},
}
/** Example of a custom green theme schema */
const greenTheme: ThemeVariables = {
light: {
primary: "#0CAF60",
primaryDeep: "#088d50",
primaryMild: "#34c779",
primarySubtle: "#0CAF601a",
neutral: "#ffffff",
},
dark: {
primary: "#0CAF60",
primaryDeep: "#088d50",
primaryMild: "#34c779",
primarySubtle: "#0CAF601a",
neutral: "#ffffff",
},
}
const presetThemeSchemaConfig: Record<string, ThemeVariables> = {
default: defaultTheme,
green: greenTheme,
}
export default presetThemeSchemaConfigاکنون که طرحهای تم شما تنظیم شدهاند، میتوانید از هوک useTheme برای تغییر بین رنگهای تم مختلف استفاده کنید. اینجا یک مثال از چگونگی پیادهسازی یک تغییردهنده تم است:
import classNames from '@/utils/classNames'
import { TbCheck } from 'react-icons/tb'
import presetThemeSchemaConfig from '@/configs/preset-theme-schema.config'
import useTheme from '@/utils/hooks/useTheme'
const ThemeSwitcher = () => {
const schema = useTheme((state) => state.themeSchema)
const setSchema = useTheme((state) => state.setSchema)
const mode = useTheme((state) => state.mode)
return (
<div className="inline-flex items-center gap-2">
{Object.entries(presetThemeSchemaConfig).map(([key, value]) => (
<button
key={key}
className={classNames(
'h-8 w-8 rounded-full flex items-center justify-center border-2 border-white',
schema === key && 'ring-2 ring-primary',
)}
style={{ backgroundColor: value[mode].primary || '' }}
onClick={() => setSchema(key)}
>
{schema === key ? (
<TbCheck className="text-neutral text-lg" />
) : (
<></>
)}
</button>
))}
</div>
)
}
export default ThemeSwitcherاین راهنما باید به شما کمک کند تا تمها را بهطور موثر در برنامه خود مدیریت و تغییر دهید. میتوانید طرحهای تم را بهطور دلخواه گسترش دهید تا با نیازهای طراحی خود همخوانی داشته باشد.