diff --git a/packages/ui/descriptions/src/Cell.tsx b/packages/ui/descriptions/src/Cell.tsx index 10d3b17e3..c7d8c07ea 100644 --- a/packages/ui/descriptions/src/Cell.tsx +++ b/packages/ui/descriptions/src/Cell.tsx @@ -13,9 +13,9 @@ export const Cell: React.FC = ({ label, content, labelWidth, + cellColumnGap, }) => { const Component: any = component - if (bordered) { const compareStyle = !isNullish(labelWidth) && !isNullish(label) @@ -42,7 +42,7 @@ export const Cell: React.FC = ({ return ( -
+
{!isNullish(label) && ( {label} @@ -67,4 +67,5 @@ export interface CellProps { label?: React.ReactNode content?: React.ReactNode labelWidth?: React.ReactText + cellColumnGap?: React.ReactText } diff --git a/packages/ui/descriptions/src/Descriptions.tsx b/packages/ui/descriptions/src/Descriptions.tsx index 5876e5d3d..9220da768 100644 --- a/packages/ui/descriptions/src/Descriptions.tsx +++ b/packages/ui/descriptions/src/Descriptions.tsx @@ -29,6 +29,7 @@ export const Descriptions = forwardRef appearance = 'unset', labelPlacement = 'left', labelWidth, + columnGap, size = 'md', ...rest }, @@ -66,6 +67,7 @@ export const Descriptions = forwardRef noBackground={noBackground} labelPlacement={labelPlacement} rootLabelWidth={labelWidth} + cellColumnGap={columnGap} /> ))} @@ -100,6 +102,11 @@ export interface DescriptionsProps extends HiBaseHTMLProps<'div'> { * label宽度 */ labelWidth?: React.ReactText + /** + * 单元格列间距 + * 注:在无边框场景下生效 + */ + columnGap?: React.ReactText /** * 设置大小 */ diff --git a/packages/ui/descriptions/src/Row.tsx b/packages/ui/descriptions/src/Row.tsx index aaec27471..c5117cb42 100644 --- a/packages/ui/descriptions/src/Row.tsx +++ b/packages/ui/descriptions/src/Row.tsx @@ -49,6 +49,7 @@ export interface RowProps { noBackground?: boolean labelPlacement?: 'left' | 'center' | 'right' rootLabelWidth?: React.ReactText + cellColumnGap?: React.ReactText } interface CellConfig { @@ -60,7 +61,13 @@ interface CellConfig { function renderCols( items: React.ReactElement[], - { prefixCls, bordered, labelPlacement: labelPlacementContext, rootLabelWidth }: RowProps, + { + prefixCls, + bordered, + labelPlacement: labelPlacementContext, + rootLabelWidth, + cellColumnGap, + }: RowProps, { component, type, showLabel, showContent }: CellConfig ) { return items.map( @@ -95,6 +102,7 @@ function renderCols( label={showLabel ? label : null} content={showContent ? children : null} labelWidth={labelWidth ?? rootLabelWidth} + cellColumnGap={index === items.length - 1 ? 0 : cellColumnGap} /> ) }