/* 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 { devUseWarning } from '../_util/warning'; 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'; interface CompoundedComponent { Item: typeof DescriptionsItem; } export interface InternalDescriptionsItemType extends DescriptionsItemProps { key?: React.Key; filled?: boolean; } export interface DescriptionsItemType extends Omit { span?: number | 'filled' | { [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; styles?: { root?: React.CSSProperties; header?: React.CSSProperties; title?: React.CSSProperties; extra?: React.CSSProperties; label?: React.CSSProperties; content?: React.CSSProperties; }; classNames?: { root?: string; header?: string; title?: string; extra?: string; label?: string; content?: string; }; items?: DescriptionsItemType[]; id?: string; } const Descriptions: React.FC & CompoundedComponent = (props) => { const { prefixCls: customizePrefixCls, title, extra, column, colon = true, bordered, layout, children, className, rootClassName, style, size: customizeSize, labelStyle, contentStyle, styles, items, classNames: descriptionsClassNames, ...restProps } = props; const { getPrefixCls, direction, descriptions } = React.useContext(ConfigContext); const prefixCls = getPrefixCls('descriptions', customizePrefixCls); const screens = useBreakpoint(); // ============================== Warn ============================== if (process.env.NODE_ENV !== 'production') { const warning = devUseWarning('Descriptions'); [ ['labelStyle', 'styles={{ label: {} }}'], ['contentStyle', 'styles={{ content: {} }}'], ].forEach(([deprecatedName, newName]) => { warning.deprecated(!(deprecatedName in props), deprecatedName, newName); }); } // 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 [wrapCSSVar, hashId, cssVarCls] = useStyle(prefixCls); // ======================== Render ======================== const contextValue = React.useMemo( () => ({ labelStyle, contentStyle, styles: { content: { ...descriptions?.styles?.content, ...styles?.content }, label: { ...descriptions?.styles?.label, ...styles?.label }, }, classNames: { label: classNames(descriptions?.classNames?.label, descriptionsClassNames?.label), content: classNames(descriptions?.classNames?.content, descriptionsClassNames?.content), }, }), [labelStyle, contentStyle, styles, descriptionsClassNames, descriptions], ); 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;