import type { CSSProperties, ExtractPropTypes, PropType } from 'vue'; import { defineComponent } from 'vue'; import PropTypes from '../_util/vue-types'; import initDefaultProps from '../_util/props-util/initDefaultProps'; import StatisticNumber from './Number'; import type { valueType } from './utils'; import Skeleton from '../skeleton/Skeleton'; import useConfigInject from '../_util/hooks/useConfigInject'; export const statisticProps = () => ({ prefixCls: String, decimalSeparator: String, groupSeparator: String, format: String, value: { type: [String, Number, Object] as PropType, }, valueStyle: { type: Object as PropType, default: undefined as CSSProperties }, valueRender: PropTypes.any, formatter: PropTypes.any, precision: Number, prefix: PropTypes.any, suffix: PropTypes.any, title: PropTypes.any, loading: { type: Boolean, default: undefined }, }); export type StatisticProps = Partial>>; export default defineComponent({ name: 'AStatistic', props: initDefaultProps(statisticProps(), { decimalSeparator: '.', groupSeparator: ',', loading: false, }), slots: ['title', 'prefix', 'suffix', 'formatter'], setup(props, { slots }) { const { prefixCls, direction } = useConfigInject('statistic', props); return () => { const { value = 0, valueStyle, valueRender } = props; const pre = prefixCls.value; const title = props.title ?? slots.title?.(); const prefix = props.prefix ?? slots.prefix?.(); const suffix = props.suffix ?? slots.suffix?.(); const formatter = props.formatter ?? slots.formatter; // data-for-update just for update component // https://github.com/vueComponent/ant-design-vue/pull/3170 let valueNode = ( ); if (valueRender) { valueNode = valueRender(valueNode); } return (
{title &&
{title}
}
{prefix && {prefix}} {valueNode} {suffix && {suffix}}
); }; }, });