import * as React from 'react'; import { TinyColor } from '@ctrl/tinycolor'; import { Drawer, Form, Input, Button, InputNumber, Checkbox, Space } from 'antd'; import { useIntl } from 'react-intl'; import { BugOutlined, EyeOutlined } from '@ant-design/icons'; import { useState } from 'react'; import type { SeedToken } from '../../../../../components/_util/theme'; import defaultSeedToken from '../../../../../components/_util/theme/themes/default'; import { PresetColors } from '../../../../../components/_util/theme/interface'; import Preview from './Preview'; import Diff from './Diff'; export interface ThemeConfigProps { componentName: string; defaultToken: SeedToken; onChangeTheme: (theme: SeedToken) => void; } export default function DynamicTheme({ onChangeTheme, defaultToken, componentName, }: ThemeConfigProps) { const { formatMessage } = useIntl(); const [visible, setVisible] = React.useState(false); const [previewVisible, setPreviewVisible] = React.useState(false); const [form] = Form.useForm(); const [showDiff, setShowDiff] = useState(false); const keys = Object.keys(defaultSeedToken); const onFinish = (nextToken: SeedToken) => { onChangeTheme(nextToken); }; return ( <> {/* FIXME: need to be removed before published */}
setVisible(true)} > Dynamic Theme
{ setVisible(false); }} title={formatMessage({ id: 'app.theme.switch.dynamic' })} extra={ setShowDiff(e.target.checked)}> Diff } destroyOnClose >
{keys.map((key: keyof typeof defaultToken) => { if (PresetColors.includes(key as any)) { return null; } const originValue = defaultToken[key]; const originValueType = typeof originValue; let node: React.ReactElement; switch (originValueType) { case 'number': node = ; break; default: node = ; } const rules: any[] = [{ required: true }]; const originColor = new TinyColor(originValue); if (originValueType === 'string' && originColor.isValid) { rules.push({ validator: async (_: any, value: string) => { if (!new TinyColor(value).isValid) { throw new Error('Invalidate color type'); } }, }); } return ( {node} ); })} Bind Style on hash className
setPreviewVisible(false)} /> ); }