| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = exports.badgeProps = void 0;
- var _vue = require("vue");
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
- var _ScrollNumber = _interopRequireDefault(require("./ScrollNumber"));
- var _classNames2 = _interopRequireDefault(require("../_util/classNames"));
- var _propsUtil = require("../_util/props-util");
- var _vnode = require("../_util/vnode");
- var _transition = require("../_util/transition");
- var _Ribbon = _interopRequireDefault(require("./Ribbon"));
- var _utils = require("./utils");
- var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
- var _isNumeric = _interopRequireDefault(require("../_util/isNumeric"));
- var badgeProps = function badgeProps() {
- return {
- /** Number to show in badge */
- count: _vueTypes.default.any,
- showZero: {
- type: Boolean,
- default: undefined
- },
- /** Max count to show */
- overflowCount: {
- type: Number,
- default: 99
- },
- /** whether to show red dot without number */
- dot: {
- type: Boolean,
- default: undefined
- },
- prefixCls: String,
- scrollNumberPrefixCls: String,
- status: {
- type: String
- },
- size: {
- type: String,
- default: 'default'
- },
- color: String,
- text: _vueTypes.default.any,
- offset: Array,
- numberStyle: {
- type: Object,
- default: undefined
- },
- title: String
- };
- };
- exports.badgeProps = badgeProps;
- var _default2 = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'ABadge',
- Ribbon: _Ribbon.default,
- inheritAttrs: false,
- props: badgeProps(),
- slots: ['text', 'count'],
- setup: function setup(props, _ref) {
- var slots = _ref.slots,
- attrs = _ref.attrs;
- var _useConfigInject = (0, _useConfigInject2.default)('badge', props),
- prefixCls = _useConfigInject.prefixCls,
- direction = _useConfigInject.direction;
- // ================================ Misc ================================
- var numberedDisplayCount = (0, _vue.computed)(function () {
- return props.count > props.overflowCount ? "".concat(props.overflowCount, "+") : props.count;
- });
- var hasStatus = (0, _vue.computed)(function () {
- return props.status !== null && props.status !== undefined || props.color !== null && props.color !== undefined;
- });
- var isZero = (0, _vue.computed)(function () {
- return numberedDisplayCount.value === '0' || numberedDisplayCount.value === 0;
- });
- var showAsDot = (0, _vue.computed)(function () {
- return props.dot && !isZero.value;
- });
- var mergedCount = (0, _vue.computed)(function () {
- return showAsDot.value ? '' : numberedDisplayCount.value;
- });
- var isHidden = (0, _vue.computed)(function () {
- var isEmpty = mergedCount.value === null || mergedCount.value === undefined || mergedCount.value === '';
- return (isEmpty || isZero.value && !props.showZero) && !showAsDot.value;
- });
- // Count should be cache in case hidden change it
- var livingCount = (0, _vue.ref)(props.count);
- // We need cache count since remove motion should not change count display
- var displayCount = (0, _vue.ref)(mergedCount.value);
- // We will cache the dot status to avoid shaking on leaved motion
- var isDotRef = (0, _vue.ref)(showAsDot.value);
- (0, _vue.watch)([function () {
- return props.count;
- }, mergedCount, showAsDot], function () {
- if (!isHidden.value) {
- livingCount.value = props.count;
- displayCount.value = mergedCount.value;
- isDotRef.value = showAsDot.value;
- }
- }, {
- immediate: true
- });
- // Shared styles
- var statusCls = (0, _vue.computed)(function () {
- var _ref2;
- return _ref2 = {}, (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value, "-status-dot"), hasStatus.value), (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value, "-status-").concat(props.status), !!props.status), (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value, "-status-").concat(props.color), (0, _utils.isPresetColor)(props.color)), _ref2;
- });
- var statusStyle = (0, _vue.computed)(function () {
- if (props.color && !(0, _utils.isPresetColor)(props.color)) {
- return {
- background: props.color
- };
- } else {
- return {};
- }
- });
- var scrollNumberCls = (0, _vue.computed)(function () {
- var _ref3;
- return _ref3 = {}, (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-dot"), isDotRef.value), (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-count"), !isDotRef.value), (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-count-sm"), props.size === 'small'), (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-multiple-words"), !isDotRef.value && displayCount.value && displayCount.value.toString().length > 1), (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-status-").concat(props.status), !!props.status), (0, _defineProperty2.default)(_ref3, "".concat(prefixCls.value, "-status-").concat(props.color), (0, _utils.isPresetColor)(props.color)), _ref3;
- });
- return function () {
- var _slots$default, _slots$count, _classNames;
- var offset = props.offset,
- title = props.title,
- color = props.color;
- var style = attrs.style;
- var text = (0, _propsUtil.getPropsSlot)(slots, props, 'text');
- var pre = prefixCls.value;
- var count = livingCount.value;
- var children = (0, _propsUtil.flattenChildren)((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots));
- children = children.length ? children : null;
- var visible = !!(!isHidden.value || slots.count);
- // =============================== Styles ===============================
- var mergedStyle = function () {
- if (!offset) {
- return (0, _objectSpread2.default)({}, style);
- }
- var offsetStyle = {
- marginTop: (0, _isNumeric.default)(offset[1]) ? "".concat(offset[1], "px") : offset[1]
- };
- if (direction.value === 'rtl') {
- offsetStyle.left = "".concat(parseInt(offset[0], 10), "px");
- } else {
- offsetStyle.right = "".concat(-parseInt(offset[0], 10), "px");
- }
- return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, offsetStyle), style);
- }();
- // =============================== Render ===============================
- // >>> Title
- var titleNode = title !== null && title !== void 0 ? title : typeof count === 'string' || typeof count === 'number' ? count : undefined;
- // >>> Status Text
- var statusTextNode = visible || !text ? null : (0, _vue.createVNode)("span", {
- "class": "".concat(pre, "-status-text")
- }, [text]);
- // >>> Display Component
- var displayNode = (0, _typeof2.default)(count) === 'object' || count === undefined && slots.count ? (0, _vnode.cloneElement)(count !== null && count !== void 0 ? count : (_slots$count = slots.count) === null || _slots$count === void 0 ? void 0 : _slots$count.call(slots), {
- style: mergedStyle
- }, false) : null;
- var badgeClassName = (0, _classNames2.default)(pre, (_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(pre, "-status"), hasStatus.value), (0, _defineProperty2.default)(_classNames, "".concat(pre, "-not-a-wrapper"), !children), (0, _defineProperty2.default)(_classNames, "".concat(pre, "-rtl"), direction.value === 'rtl'), _classNames), attrs.class);
- // <Badge status="success" />
- if (!children && hasStatus.value) {
- var statusTextColor = mergedStyle.color;
- return (0, _vue.createVNode)("span", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
- "class": badgeClassName,
- "style": mergedStyle
- }), [(0, _vue.createVNode)("span", {
- "class": statusCls.value,
- "style": statusStyle.value
- }, null), (0, _vue.createVNode)("span", {
- "style": {
- color: statusTextColor
- },
- "class": "".concat(pre, "-status-text")
- }, [text])]);
- }
- var transitionProps = (0, _transition.getTransitionProps)(children ? "".concat(pre, "-zoom") : '', {
- appear: false
- });
- var scrollNumberStyle = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, mergedStyle), props.numberStyle);
- if (color && !(0, _utils.isPresetColor)(color)) {
- scrollNumberStyle = scrollNumberStyle || {};
- scrollNumberStyle.background = color;
- }
- return (0, _vue.createVNode)("span", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
- "class": badgeClassName
- }), [children, (0, _vue.createVNode)(_transition.Transition, transitionProps, {
- default: function _default() {
- return [(0, _vue.withDirectives)((0, _vue.createVNode)(_ScrollNumber.default, {
- "prefixCls": props.scrollNumberPrefixCls,
- "show": visible,
- "class": scrollNumberCls.value,
- "count": displayCount.value,
- "title": titleNode,
- "style": scrollNumberStyle,
- "key": "scrollNumber"
- }, {
- default: function _default() {
- return [displayNode];
- }
- }), [[_vue.vShow, visible]])];
- }
- }), statusTextNode]);
- };
- }
- });
- exports.default = _default2;
|