mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-12 07:09:55 +08:00
785115c580
* feat: config-provider support divider className and style properties * fix: simple ts definition * fix: merge style & className * fix: fix space className * feat: optimize type definition * feat: optimize type definition * feat: add version * test: update test * test: update test * fix: fix type * fix: fix api sort * fix: fix docs * docs: add another api table * Apply suggestions from code review --------- Co-authored-by: MadCcc <1075746765@qq.com>
108 lines
3.0 KiB
TypeScript
108 lines
3.0 KiB
TypeScript
import type { DerivativeFunc } from '@ant-design/cssinjs';
|
|
import * as React from 'react';
|
|
import type { Options } from 'scroll-into-view-if-needed';
|
|
import type { ButtonProps } from '../button';
|
|
import type { RequiredMark } from '../form/Form';
|
|
import type { Locale } from '../locale';
|
|
import type { SpaceProps } from '../space';
|
|
import type { AliasToken, MapToken, OverrideToken, SeedToken } from '../theme/interface';
|
|
import type { SizeType } from './SizeContext';
|
|
import type { RenderEmptyHandler } from './defaultRenderEmpty';
|
|
|
|
export const defaultIconPrefixCls = 'anticon';
|
|
|
|
export interface Theme {
|
|
primaryColor?: string;
|
|
infoColor?: string;
|
|
successColor?: string;
|
|
processingColor?: string;
|
|
errorColor?: string;
|
|
warningColor?: string;
|
|
}
|
|
|
|
export interface CSPConfig {
|
|
nonce?: string;
|
|
}
|
|
|
|
export type DirectionType = 'ltr' | 'rtl' | undefined;
|
|
|
|
export type MappingAlgorithm = DerivativeFunc<SeedToken, MapToken>;
|
|
|
|
export interface ThemeConfig {
|
|
token?: Partial<AliasToken>;
|
|
components?: OverrideToken;
|
|
algorithm?: MappingAlgorithm | MappingAlgorithm[];
|
|
hashed?: boolean;
|
|
inherit?: boolean;
|
|
}
|
|
|
|
export interface componentStyleConfig {
|
|
className?: string;
|
|
style?: React.CSSProperties;
|
|
}
|
|
|
|
export interface ButtonConfig extends componentStyleConfig {
|
|
classNames?: ButtonProps['classNames'];
|
|
styles?: ButtonProps['styles'];
|
|
}
|
|
|
|
export type PopupOverflow = 'viewport' | 'scroll';
|
|
|
|
export interface ConfigConsumerProps {
|
|
getTargetContainer?: () => HTMLElement;
|
|
getPopupContainer?: (triggerNode?: HTMLElement) => HTMLElement;
|
|
rootPrefixCls?: string;
|
|
iconPrefixCls: string;
|
|
getPrefixCls: (suffixCls?: string, customizePrefixCls?: string) => string;
|
|
renderEmpty?: RenderEmptyHandler;
|
|
csp?: CSPConfig;
|
|
autoInsertSpaceInButton?: boolean;
|
|
input?: {
|
|
autoComplete?: string;
|
|
};
|
|
pagination?: {
|
|
showSizeChanger?: boolean;
|
|
};
|
|
locale?: Locale;
|
|
pageHeader?: {
|
|
ghost: boolean;
|
|
};
|
|
direction?: DirectionType;
|
|
space?: {
|
|
size?: SizeType | number;
|
|
className?: SpaceProps['className'];
|
|
classNames?: SpaceProps['classNames'];
|
|
style?: SpaceProps['style'];
|
|
styles?: SpaceProps['styles'];
|
|
};
|
|
virtual?: boolean;
|
|
popupMatchSelectWidth?: boolean;
|
|
popupOverflow?: PopupOverflow;
|
|
form?: {
|
|
requiredMark?: RequiredMark;
|
|
colon?: boolean;
|
|
scrollToFirstError?: Options | boolean;
|
|
};
|
|
theme?: ThemeConfig;
|
|
select?: {
|
|
showSearch?: boolean;
|
|
};
|
|
button?: ButtonConfig;
|
|
divider?: componentStyleConfig;
|
|
}
|
|
|
|
const defaultGetPrefixCls = (suffixCls?: string, customizePrefixCls?: string) => {
|
|
if (customizePrefixCls) return customizePrefixCls;
|
|
|
|
return suffixCls ? `ant-${suffixCls}` : 'ant';
|
|
};
|
|
|
|
// zombieJ: 🚨 Do not pass `defaultRenderEmpty` here since it will cause circular dependency.
|
|
export const ConfigContext = React.createContext<ConfigConsumerProps>({
|
|
// We provide a default function for Context without provider
|
|
getPrefixCls: defaultGetPrefixCls,
|
|
iconPrefixCls: defaultIconPrefixCls,
|
|
});
|
|
|
|
export const { Consumer: ConfigConsumer } = ConfigContext;
|