From e86e5e500003d1d182aa1d76607fed0ce21fd6a7 Mon Sep 17 00:00:00 2001 From: JiaQi <112228030+Yuiai01@users.noreply.github.com> Date: Fri, 7 Jul 2023 19:02:55 +0800 Subject: [PATCH] feat: ConfigProvider support DatePicker & TimePicker className and style properties (#43418) --- .../config-provider/__tests__/style.test.tsx | 58 +++++++++++++++++++ components/config-provider/context.ts | 2 + components/config-provider/index.en-US.md | 2 + components/config-provider/index.tsx | 6 ++ components/config-provider/index.zh-CN.md | 2 + .../generatePicker/generateSinglePicker.tsx | 13 ++++- 6 files changed, 82 insertions(+), 1 deletion(-) diff --git a/components/config-provider/__tests__/style.test.tsx b/components/config-provider/__tests__/style.test.tsx index 0c0408a26d..622a9ed40d 100644 --- a/components/config-provider/__tests__/style.test.tsx +++ b/components/config-provider/__tests__/style.test.tsx @@ -13,6 +13,7 @@ import Cascader from '../../cascader'; import Checkbox from '../../checkbox'; import Collapse from '../../collapse'; import ColorPicker from '../../color-picker'; +import DatePicker from '../../date-picker'; import Descriptions from '../../descriptions'; import Divider from '../../divider'; import Drawer from '../../drawer'; @@ -44,6 +45,7 @@ import Switch from '../../switch'; import Table from '../../table'; import Tabs from '../../tabs'; import Tag from '../../tag'; +import TimePicker from '../../time-picker'; import Timeline from '../../timeline'; import Transfer from '../../transfer'; import Tree from '../../tree'; @@ -1010,6 +1012,34 @@ describe('ConfigProvider support style and className props', () => { expect(element).toHaveStyle({ backgroundColor: 'red' }); }); + it('Should TimePicker className works', () => { + const { container } = render( + + + , + ); + + expect(container.querySelector('.ant-picker')).toHaveClass('test-class'); + }); + + it('Should TimePicker style works', () => { + const { container } = render( + + + , + ); + + expect(container.querySelector('.ant-picker')).toHaveStyle('color: red; font-size: 16px;'); + }); + it('Should message className & style works', () => { const Demo: React.FC = () => { const [messageApi, contextHolder] = message.useMessage(); @@ -1205,4 +1235,32 @@ describe('ConfigProvider support style and className props', () => { expect(element).toHaveClass('cp-colorPicker'); expect(element).toHaveStyle({ backgroundColor: 'red' }); }); + + it('Should DatePicker className works', () => { + const { container } = render( + + + , + ); + + expect(container.querySelector('.ant-picker')).toHaveClass('test-class'); + }); + + it('Should DatePicker style works', () => { + const { container } = render( + + + , + ); + + expect(container.querySelector('.ant-picker')).toHaveStyle('color: red; font-size: 16px;'); + }); }); diff --git a/components/config-provider/context.ts b/components/config-provider/context.ts index 5717b45a3b..b13611610d 100644 --- a/components/config-provider/context.ts +++ b/components/config-provider/context.ts @@ -136,10 +136,12 @@ export interface ConfigConsumerProps { card?: ComponentStyleConfig; tabs?: ComponentStyleConfig; timeline?: ComponentStyleConfig; + timePicker?: ComponentStyleConfig; upload?: ComponentStyleConfig; notification?: ComponentStyleConfig; tree?: ComponentStyleConfig; colorPicker?: ComponentStyleConfig; + datePicker?: ComponentStyleConfig; } const defaultGetPrefixCls = (suffixCls?: string, customizePrefixCls?: string) => { diff --git a/components/config-provider/index.en-US.md b/components/config-provider/index.en-US.md index 52e95f9c71..09e0f9dfc5 100644 --- a/components/config-provider/index.en-US.md +++ b/components/config-provider/index.en-US.md @@ -114,6 +114,7 @@ const { | checkbox | Set Checkbox common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | collapse | Set Collapse common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | colorPicker | Set ColorPicker common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | +| datePicker | Set datePicker common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | descriptions | Set Descriptions common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | divider | Set Divider common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | drawer | Set Drawer common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | @@ -146,6 +147,7 @@ const { | tabs | Set Tabs common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | tag | Set Tag common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | timeline | Set Timeline common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | +| timePicker | Set TimePicker common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | transfer | Set Transfer common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | tree | Set Tree common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | typography | Set Typography common props | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | diff --git a/components/config-provider/index.tsx b/components/config-provider/index.tsx index ec1a0eebde..56c5602670 100644 --- a/components/config-provider/index.tsx +++ b/components/config-provider/index.tsx @@ -178,10 +178,12 @@ export interface ConfigProviderProps { card?: ComponentStyleConfig; tabs?: ComponentStyleConfig; timeline?: ComponentStyleConfig; + timePicker?: ComponentStyleConfig; upload?: ComponentStyleConfig; notification?: ComponentStyleConfig; tree?: ComponentStyleConfig; colorPicker?: ComponentStyleConfig; + datePicker?: ComponentStyleConfig; } interface ProviderChildrenProps extends ConfigProviderProps { @@ -312,10 +314,12 @@ const ProviderChildren: React.FC = (props) => { card, tabs, timeline, + timePicker, upload, notification, tree, colorPicker, + datePicker, } = props; // =================================== Warning =================================== @@ -408,10 +412,12 @@ const ProviderChildren: React.FC = (props) => { card, tabs, timeline, + timePicker, upload, notification, tree, colorPicker, + datePicker, }; const config = { diff --git a/components/config-provider/index.zh-CN.md b/components/config-provider/index.zh-CN.md index d8c7f0cbe3..9bb937e72a 100644 --- a/components/config-provider/index.zh-CN.md +++ b/components/config-provider/index.zh-CN.md @@ -116,6 +116,7 @@ const { | checkbox | 设置 Checkbox 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | collapse | 设置 Collapse 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | colorPicker | 设置 ColorPicker 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | +| datePicker | 设置 DatePicker 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | descriptions | 设置 Descriptions 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | divider | 设置 Divider 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | drawer | 设置 Drawer 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | @@ -148,6 +149,7 @@ const { | tabs | 设置 Tabs 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | tag | 设置 Tag 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | timeline | 设置 Timeline 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | +| timePicker | 设置 TimePicker 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | transfer | 设置 Transfer 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | tree | 设置 Tree 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | | typography | 设置 Typography 组件的通用属性 | { className?: string, style?: React.CSSProperties } | - | 5.7.0 | diff --git a/components/date-picker/generatePicker/generateSinglePicker.tsx b/components/date-picker/generatePicker/generateSinglePicker.tsx index a886b58fc2..205d5b829e 100644 --- a/components/date-picker/generatePicker/generateSinglePicker.tsx +++ b/components/date-picker/generatePicker/generateSinglePicker.tsx @@ -37,11 +37,13 @@ export default function generatePicker(generateConfig: GenerateConfig< picker?: PickerMode, displayName?: string, ) { + const consumerName = displayName === 'TimePicker' ? 'timePicker' : 'datePicker'; const Picker = forwardRef | CommonPickerMethods, InnerPickerProps>( (props, ref) => { const { prefixCls: customizePrefixCls, getPopupContainer: customizeGetPopupContainer, + style, className, rootClassName, size: customizeSize, @@ -55,7 +57,14 @@ export default function generatePicker(generateConfig: GenerateConfig< ...restProps } = props; - const { getPrefixCls, direction, getPopupContainer } = useContext(ConfigContext); + const { + getPrefixCls, + direction, + getPopupContainer, + // Consume different styles according to different names + [consumerName]: consumerStyle, + } = useContext(ConfigContext); + const prefixCls = getPrefixCls('picker', customizePrefixCls); const { compactSize, compactItemClassnames } = useCompactItemContext(prefixCls, direction); const innerRef = React.useRef>(null); @@ -153,9 +162,11 @@ export default function generatePicker(generateConfig: GenerateConfig< ), hashId, compactItemClassnames, + consumerStyle?.className, className, rootClassName, )} + style={{ ...consumerStyle?.style, ...style }} prefixCls={prefixCls} getPopupContainer={customizeGetPopupContainer || getPopupContainer} generateConfig={generateConfig}