/* eslint-disable react/no-array-index-key */ import * as React from 'react'; import classNames from 'classnames'; import type { Breakpoint } from '../_util/responsiveObserver'; import { matchScreen } from '../_util/responsiveObserver'; import { ConfigContext } from '../config-provider'; import useSize from '../config-provider/hooks/useSize'; import useBreakpoint from '../grid/hooks/useBreakpoint'; import DEFAULT_COLUMN_MAP from './constant'; import DescriptionsContext from './DescriptionsContext'; import useItems from './hooks/useItems'; import useRow from './hooks/useRow'; import type { DescriptionsItemProps } from './Item'; import DescriptionsItem from './Item'; import Row from './Row'; import useStyle from './style'; import useCSSVar from './style/cssVar'; interface CompoundedComponent { Item: typeof DescriptionsItem; } export interface InternalDescriptionsItemType extends DescriptionsItemProps { key?: React.Key; } export interface DescriptionsItemType extends Omit { span?: number | { [key in Breakpoint]?: number }; } export interface DescriptionsProps { prefixCls?: string; className?: string; rootClassName?: string; style?: React.CSSProperties; bordered?: boolean; size?: 'middle' | 'small' | 'default'; /** * @deprecated use `items` instead */ children?: React.ReactNode; title?: React.ReactNode; extra?: React.ReactNode; column?: number | Partial>; layout?: 'horizontal' | 'vertical'; colon?: boolean; labelStyle?: React.CSSProperties; contentStyle?: React.CSSProperties; items?: DescriptionsItemType[]; } const Descriptions: React.FC & CompoundedComponent = (props) => { const { prefixCls: customizePrefixCls, title, extra, column, colon = true, bordered, layout, children, className, rootClassName, style, size: customizeSize, labelStyle, contentStyle, items, ...restProps } = props; const { getPrefixCls, direction, descriptions } = React.useContext(ConfigContext); const prefixCls = getPrefixCls('descriptions', customizePrefixCls); const screens = useBreakpoint(); // Column count const mergedColumn = React.useMemo(() => { if (typeof column === 'number') { return column; } return ( matchScreen(screens, { ...DEFAULT_COLUMN_MAP, ...column, }) ?? 3 ); }, [screens, column]); // Items with responsive const mergedItems = useItems(screens, items, children); const mergedSize = useSize(customizeSize); const rows = useRow(mergedColumn, mergedItems); const [, hashId] = useStyle(prefixCls); const wrapCSSVar = useCSSVar(prefixCls); // ======================== Render ======================== const contextValue = React.useMemo( () => ({ labelStyle, contentStyle }), [labelStyle, contentStyle], ); return wrapCSSVar(
{(title || extra) && (
{title &&
{title}
} {extra &&
{extra}
}
)}
{rows.map((row, index) => ( ))}
, ); }; if (process.env.NODE_ENV !== 'production') { Descriptions.displayName = 'Descriptions'; } export type { DescriptionsContextProps } from './DescriptionsContext'; export { DescriptionsContext }; Descriptions.Item = DescriptionsItem; export default Descriptions;