ant-design-vue/components/statistic/Statistic.tsx

74 lines
2.5 KiB
Vue
Raw Normal View History

2021-06-26 01:35:40 +00:00
import type { ExtractPropTypes, PropType } from 'vue';
import { defineComponent } from 'vue';
import PropTypes from '../_util/vue-types';
2020-10-17 03:51:17 +00:00
import initDefaultProps from '../_util/props-util/initDefaultProps';
import StatisticNumber from './Number';
2021-06-26 01:35:40 +00:00
import type { countdownValueType } from './utils';
2021-06-10 15:04:57 +00:00
import Skeleton from '../skeleton/Skeleton';
import useConfigInject from '../_util/hooks/useConfigInject';
2021-06-23 13:47:53 +00:00
export const statisticProps = {
2020-10-17 03:51:17 +00:00
prefixCls: PropTypes.string,
decimalSeparator: PropTypes.string,
groupSeparator: PropTypes.string,
format: PropTypes.string,
value: {
type: [String, Number, Object] as PropType<countdownValueType>,
},
valueStyle: PropTypes.style,
valueRender: PropTypes.any,
formatter: PropTypes.any,
precision: PropTypes.number,
2021-12-16 09:20:18 +00:00
prefix: PropTypes.any,
suffix: PropTypes.any,
title: PropTypes.any,
2020-10-17 03:51:17 +00:00
onFinish: PropTypes.func,
2021-06-10 15:04:57 +00:00
loading: PropTypes.looseBool,
};
2021-06-23 13:47:53 +00:00
export type StatisticProps = Partial<ExtractPropTypes<typeof statisticProps>>;
2020-10-17 03:51:17 +00:00
export default defineComponent({
name: 'AStatistic',
2021-06-23 13:47:53 +00:00
props: initDefaultProps(statisticProps, {
2020-10-17 03:51:17 +00:00
decimalSeparator: '.',
groupSeparator: ',',
2021-06-10 15:04:57 +00:00
loading: false,
2020-10-17 03:51:17 +00:00
}),
2021-06-10 15:04:57 +00:00
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 = (
<StatisticNumber
data-for-update={Date.now()}
{...{ ...props, prefixCls: pre, value, formatter }}
/>
);
if (valueRender) {
valueNode = valueRender(valueNode);
}
return (
<div class={[pre, { [`${pre}-rtl`]: direction.value === 'rtl' }]}>
{title && <div class={`${pre}-title`}>{title}</div>}
<Skeleton paragraph={false} loading={props.loading}>
<div style={valueStyle} class={`${pre}-content`}>
{prefix && <span class={`${pre}-content-prefix`}>{prefix}</span>}
{valueNode}
{suffix && <span class={`${pre}-content-suffix`}>{suffix}</span>}
</div>
</Skeleton>
</div>
2021-06-10 15:04:57 +00:00
);
};
},
});