import * as React from 'react'; import pickAttrs from '@rc-component/util/lib/pickAttrs'; import classNames from 'classnames'; import type { HTMLAriaDataAttributes } from '../_util/aria-data-attrs'; import { devUseWarning } from '../_util/warning'; import type { ConfigConsumerProps } from '../config-provider'; import { ConfigContext } from '../config-provider'; import Skeleton from '../skeleton'; import StatisticNumber from './Number'; import useStyle from './style'; import type { FormatConfig, valueType } from './utils'; export type SemanticName = 'root' | 'content' | 'title' | 'header' | 'prefix' | 'suffix'; interface StatisticReactProps extends FormatConfig { prefixCls?: string; className?: string; classNames?: Partial>; styles?: Partial>; rootClassName?: string; style?: React.CSSProperties; value?: valueType; /** @deprecated Please use `styles={{ content: { } }}` instead */ valueStyle?: React.CSSProperties; valueRender?: (node: React.ReactNode) => React.ReactNode; title?: React.ReactNode; prefix?: React.ReactNode; suffix?: React.ReactNode; loading?: boolean; onMouseEnter?: React.MouseEventHandler; onMouseLeave?: React.MouseEventHandler; } export type StatisticProps = HTMLAriaDataAttributes & StatisticReactProps; const Statistic: React.FC = (props) => { const { prefixCls: customizePrefixCls, className, rootClassName, style, valueStyle, value = 0, title, valueRender, prefix, suffix, loading = false, /* --- FormatConfig starts --- */ formatter, precision, decimalSeparator = '.', groupSeparator = ',', /* --- FormatConfig starts --- */ onMouseEnter, onMouseLeave, styles, classNames: statisticClassNames, ...rest } = props; const { getPrefixCls, direction, statistic } = React.useContext(ConfigContext); const prefixCls = getPrefixCls('statistic', customizePrefixCls); const [wrapCSSVar, hashId, cssVarCls] = useStyle(prefixCls); // ============================= Warning ============================== if (process.env.NODE_ENV !== 'production') { const warning = devUseWarning('Statistic'); [['valueStyle', 'styles={{ content: { } }}']].forEach(([deprecatedName, newName]) => { warning.deprecated(!(deprecatedName in props), deprecatedName, newName); }); } const valueNode: React.ReactNode = ( ); const rootClassNames = classNames( prefixCls, { [`${prefixCls}-rtl`]: direction === 'rtl', }, statistic?.className, className, rootClassName, statistic?.classNames?.root, statisticClassNames?.root, hashId, cssVarCls, ); const headerClassNames = classNames( `${prefixCls}-header`, statistic?.classNames?.header, statisticClassNames?.header, ); const titleClassNames = classNames( `${prefixCls}-title`, statistic?.classNames?.title, statisticClassNames?.title, ); const contentClassNames = classNames( `${prefixCls}-content`, statistic?.classNames?.content, statisticClassNames?.content, ); const prefixClassNames = classNames( `${prefixCls}-content-prefix`, statistic?.classNames?.prefix, statisticClassNames?.prefix, ); const suffixClassNames = classNames( `${prefixCls}-content-suffix`, statistic?.classNames?.suffix, statisticClassNames?.suffix, ); const restProps = pickAttrs(rest, { aria: true, data: true }); return wrapCSSVar(
{title && (
{title}
)}
{prefix && ( {prefix} )} {valueRender ? valueRender(valueNode) : valueNode} {suffix && ( {suffix} )}
, ); }; if (process.env.NODE_ENV !== 'production') { Statistic.displayName = 'Statistic'; } export default Statistic;