wetrade-design
Version:
一款多语言支持Vue3的UI框架
103 lines (102 loc) • 4.46 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.statisticProps = exports.default = void 0;
var _vue = require("vue");
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps"));
var _Number = _interopRequireDefault(require("./Number"));
var _Skeleton = _interopRequireDefault(require("../skeleton/Skeleton"));
var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
var statisticProps = function statisticProps() {
return {
prefixCls: String,
decimalSeparator: String,
groupSeparator: String,
format: String,
value: {
type: [String, Number, Object]
},
valueStyle: {
type: Object,
default: undefined
},
valueRender: _vueTypes.default.any,
formatter: _vueTypes.default.any,
precision: Number,
prefix: _vueTypes.default.any,
suffix: _vueTypes.default.any,
title: _vueTypes.default.any,
loading: {
type: Boolean,
default: undefined
}
};
};
exports.statisticProps = statisticProps;
var _default2 = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'AStatistic',
props: (0, _initDefaultProps.default)(statisticProps(), {
decimalSeparator: '.',
groupSeparator: ',',
loading: false
}),
slots: ['title', 'prefix', 'suffix', 'formatter'],
setup: function setup(props, _ref) {
var slots = _ref.slots;
var _useConfigInject = (0, _useConfigInject2.default)('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/wetrade-design/pull/3170
var valueNode = (0, _vue.createVNode)(_Number.default, (0, _objectSpread2.default)({
"data-for-update": Date.now()
}, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
prefixCls: pre,
value: value,
formatter: formatter
})), null);
if (valueRender) {
valueNode = valueRender(valueNode);
}
return (0, _vue.createVNode)("div", {
"class": [pre, (0, _defineProperty2.default)({}, "".concat(pre, "-rtl"), direction.value === 'rtl')]
}, [title && (0, _vue.createVNode)("div", {
"class": "".concat(pre, "-title")
}, [title]), (0, _vue.createVNode)(_Skeleton.default, {
"paragraph": false,
"loading": props.loading
}, {
default: function _default() {
return [(0, _vue.createVNode)("div", {
"style": valueStyle,
"class": "".concat(pre, "-content")
}, [prefix && (0, _vue.createVNode)("span", {
"class": "".concat(pre, "-content-prefix")
}, [prefix]), valueNode, suffix && (0, _vue.createVNode)("span", {
"class": "".concat(pre, "-content-suffix")
}, [suffix])])];
}
})]);
};
}
});
exports.default = _default2;