1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
- import { createVNode as _createVNode } from "vue";
- import { defineComponent } from 'vue';
- import PropTypes from '../_util/vue-types';
- import initDefaultProps from '../_util/props-util/initDefaultProps';
- import StatisticNumber from './Number';
- import Skeleton from '../skeleton/Skeleton';
- import useConfigInject from '../_util/hooks/useConfigInject';
- export var statisticProps = function statisticProps() {
- return {
- prefixCls: String,
- decimalSeparator: String,
- groupSeparator: String,
- format: String,
- value: {
- type: [String, Number, Object]
- },
- valueStyle: {
- type: Object,
- default: undefined
- },
- valueRender: PropTypes.any,
- formatter: PropTypes.any,
- precision: Number,
- prefix: PropTypes.any,
- suffix: PropTypes.any,
- title: PropTypes.any,
- loading: {
- type: Boolean,
- default: undefined
- }
- };
- };
- export default defineComponent({
- compatConfig: {
- MODE: 3
- },
- name: 'AStatistic',
- props: initDefaultProps(statisticProps(), {
- decimalSeparator: '.',
- groupSeparator: ',',
- loading: false
- }),
- slots: ['title', 'prefix', 'suffix', 'formatter'],
- setup: function setup(props, _ref) {
- var slots = _ref.slots;
- var _useConfigInject = useConfigInject('statistic', props),
- prefixCls = _useConfigInject.prefixCls,
- direction = _useConfigInject.direction;
- return function () {
- var _props$title, _slots$title, _props$prefix, _slots$prefix, _props$suffix, _slots$suffix, _props$formatter;
- var _props$value = props.value,
- value = _props$value === void 0 ? 0 : _props$value,
- valueStyle = props.valueStyle,
- valueRender = props.valueRender;
- var pre = prefixCls.value;
- var title = (_props$title = props.title) !== null && _props$title !== void 0 ? _props$title : (_slots$title = slots.title) === null || _slots$title === void 0 ? void 0 : _slots$title.call(slots);
- var prefix = (_props$prefix = props.prefix) !== null && _props$prefix !== void 0 ? _props$prefix : (_slots$prefix = slots.prefix) === null || _slots$prefix === void 0 ? void 0 : _slots$prefix.call(slots);
- var suffix = (_props$suffix = props.suffix) !== null && _props$suffix !== void 0 ? _props$suffix : (_slots$suffix = slots.suffix) === null || _slots$suffix === void 0 ? void 0 : _slots$suffix.call(slots);
- var formatter = (_props$formatter = props.formatter) !== null && _props$formatter !== void 0 ? _props$formatter : slots.formatter;
- // data-for-update just for update component
- // https://github.com/vueComponent/ant-design-vue/pull/3170
- var valueNode = _createVNode(StatisticNumber, _objectSpread({
- "data-for-update": Date.now()
- }, _objectSpread(_objectSpread({}, props), {}, {
- prefixCls: pre,
- value: value,
- formatter: formatter
- })), null);
- if (valueRender) {
- valueNode = valueRender(valueNode);
- }
- return _createVNode("div", {
- "class": [pre, _defineProperty({}, "".concat(pre, "-rtl"), direction.value === 'rtl')]
- }, [title && _createVNode("div", {
- "class": "".concat(pre, "-title")
- }, [title]), _createVNode(Skeleton, {
- "paragraph": false,
- "loading": props.loading
- }, {
- default: function _default() {
- return [_createVNode("div", {
- "style": valueStyle,
- "class": "".concat(pre, "-content")
- }, [prefix && _createVNode("span", {
- "class": "".concat(pre, "-content-prefix")
- }, [prefix]), valueNode, suffix && _createVNode("span", {
- "class": "".concat(pre, "-content-suffix")
- }, [suffix])])];
- }
- })]);
- };
- }
- });
|