mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-11 22:58:33 +08:00
111 lines
2.7 KiB
TypeScript
111 lines
2.7 KiB
TypeScript
import type { FC } from 'react';
|
|
import * as React from 'react';
|
|
import type { TableProps } from 'antd';
|
|
import { Table } from 'antd';
|
|
import { createStyles } from 'antd-style';
|
|
import { getDesignToken } from 'antd-token-previewer';
|
|
import tokenMeta from 'antd/es/version/token-meta.json';
|
|
|
|
import useLocale from '../../../hooks/useLocale';
|
|
import ColorChunk from '../ColorChunk';
|
|
|
|
type TokenTableProps = {
|
|
type: 'seed' | 'map' | 'alias';
|
|
lang: 'zh' | 'en';
|
|
};
|
|
|
|
export type TokenData = {
|
|
name: string;
|
|
desc: string;
|
|
type: string;
|
|
value: any;
|
|
};
|
|
|
|
const defaultToken = getDesignToken();
|
|
|
|
const locales = {
|
|
cn: {
|
|
token: 'Token 名称',
|
|
description: '描述',
|
|
type: '类型',
|
|
value: '默认值',
|
|
},
|
|
en: {
|
|
token: 'Token Name',
|
|
description: 'Description',
|
|
type: 'Type',
|
|
value: 'Default Value',
|
|
},
|
|
};
|
|
|
|
const useStyle = createStyles(({ token, css }) => ({
|
|
codeSpan: css`
|
|
margin: 0 1px;
|
|
padding: 0.2em 0.4em;
|
|
font-size: 0.9em;
|
|
background: ${token.siteMarkdownCodeBg};
|
|
border: 1px solid ${token.colorSplit};
|
|
border-radius: ${token.borderRadiusSM}px;
|
|
font-family: monospace;
|
|
`,
|
|
}));
|
|
|
|
export function useColumns(): Exclude<TableProps<TokenData>['columns'], undefined> {
|
|
const [locale] = useLocale(locales);
|
|
const { styles } = useStyle();
|
|
|
|
return [
|
|
{
|
|
title: locale.token,
|
|
key: 'name',
|
|
dataIndex: 'name',
|
|
},
|
|
{
|
|
title: locale.description,
|
|
key: 'desc',
|
|
dataIndex: 'desc',
|
|
},
|
|
{
|
|
title: locale.type,
|
|
key: 'type',
|
|
dataIndex: 'type',
|
|
render: (_, record) => <span className={styles.codeSpan}>{record.type}</span>,
|
|
},
|
|
{
|
|
title: locale.value,
|
|
key: 'value',
|
|
render: (_, record) => {
|
|
const isColor =
|
|
typeof record.value === 'string' &&
|
|
(record.value.startsWith('#') || record.value.startsWith('rgb'));
|
|
if (isColor) {
|
|
return <ColorChunk value={record.value}>{record.value}</ColorChunk>;
|
|
}
|
|
return typeof record.value !== 'string' ? JSON.stringify(record.value) : record.value;
|
|
},
|
|
},
|
|
];
|
|
}
|
|
|
|
const TokenTable: FC<TokenTableProps> = ({ type }) => {
|
|
const [, lang] = useLocale(locales);
|
|
const columns = useColumns();
|
|
|
|
const data = React.useMemo<TokenData[]>(
|
|
() =>
|
|
Object.entries(tokenMeta.global)
|
|
.filter(([, meta]) => meta.source === type)
|
|
.map(([token, meta]) => ({
|
|
name: token,
|
|
desc: lang === 'cn' ? meta.desc : meta.descEn,
|
|
type: meta.type,
|
|
value: defaultToken[token],
|
|
})),
|
|
[type, lang],
|
|
);
|
|
|
|
return <Table dataSource={data} columns={columns} pagination={false} bordered />;
|
|
};
|
|
|
|
export default TokenTable;
|