ant-design/components/theme/index.tsx
2024-08-23 10:36:52 +08:00

44 lines
1.3 KiB
TypeScript

/* eslint-disable import/prefer-default-export */
import getDesignToken from './getDesignToken';
import type { GlobalToken, MappingAlgorithm } from './interface';
import {
defaultConfig,
DesignTokenContext as InternalDesignTokenContext,
useToken as useInternalToken,
} from './internal';
import compactAlgorithm from './themes/compact';
import darkAlgorithm from './themes/dark';
import defaultAlgorithm from './themes/default';
// ZombieJ: We export as object to user but array in internal.
// This is used to minimize the bundle size for antd package but safe to refactor as object also.
// Please do not export internal `useToken` directly to avoid something export unexpected.
/** Get current context Design Token. Will be different if you are using nest theme config. */
function useToken() {
const [theme, token, hashId] = useInternalToken();
return { theme, token, hashId };
}
export type { GlobalToken, MappingAlgorithm };
export default {
/** Default seedToken */
defaultSeed: defaultConfig.token,
useToken,
defaultAlgorithm,
darkAlgorithm,
compactAlgorithm,
getDesignToken,
/**
* @private Private variable.
* @warring 🔥 Do not use in production. 🔥
*/
defaultConfig,
/**
* @private Private variable.
* @warring 🔥 Do not use in production. 🔥
*/
_internalContext: InternalDesignTokenContext,
};