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

74 lines
2.6 KiB
Vue
Raw Normal View History

import type { CSSProperties, ExtractPropTypes, PropType } from 'vue';
2021-06-26 01:35:40 +00:00
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';
2022-05-21 07:06:02 +00:00
import type { valueType } from './utils';
2021-06-10 15:04:57 +00:00
import Skeleton from '../skeleton/Skeleton';
import useConfigInject from '../_util/hooks/useConfigInject';
export const statisticProps = () => ({
prefixCls: String,
decimalSeparator: String,
groupSeparator: String,
format: String,
2020-10-17 03:51:17 +00:00
value: {
2022-05-21 07:06:02 +00:00
type: [String, Number, Object] as PropType<valueType>,
2020-10-17 03:51:17 +00:00
},
valueStyle: { type: Object as PropType<CSSProperties>, default: undefined as CSSProperties },
2020-10-17 03:51:17 +00:00
valueRender: PropTypes.any,
formatter: PropTypes.any,
precision: Number,
2021-12-16 09:20:18 +00:00
prefix: PropTypes.any,
suffix: PropTypes.any,
title: PropTypes.any,
loading: { type: Boolean, default: undefined },
});
export type StatisticProps = Partial<ExtractPropTypes<ReturnType<typeof statisticProps>>>;
2021-06-23 13:47:53 +00:00
2020-10-17 03:51:17 +00:00
export default defineComponent({
compatConfig: { MODE: 3 },
name: 'AStatistic',
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
);
};
},
});