UNPKG

9.93 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5var _typeof3 = require("@babel/runtime/helpers/typeof");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports["default"] = void 0;
11
12var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
14var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
16var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
17
18var React = _interopRequireWildcard(require("react"));
19
20var _rcMotion = _interopRequireDefault(require("rc-motion"));
21
22var _classnames = _interopRequireDefault(require("classnames"));
23
24var _ScrollNumber = _interopRequireDefault(require("./ScrollNumber"));
25
26var _Ribbon = _interopRequireDefault(require("./Ribbon"));
27
28var _configProvider = require("../config-provider");
29
30var _reactNode = require("../_util/reactNode");
31
32var _utils = require("./utils");
33
34function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
36function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
38var __rest = void 0 && (void 0).__rest || function (s, e) {
39 var t = {};
40
41 for (var p in s) {
42 if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
43 }
44
45 if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
46 if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
47 }
48 return t;
49};
50
51var Badge = function Badge(_a) {
52 var _classNames, _classNames2;
53
54 var customizePrefixCls = _a.prefixCls,
55 customizeScrollNumberPrefixCls = _a.scrollNumberPrefixCls,
56 children = _a.children,
57 status = _a.status,
58 text = _a.text,
59 color = _a.color,
60 _a$count = _a.count,
61 count = _a$count === void 0 ? null : _a$count,
62 _a$overflowCount = _a.overflowCount,
63 overflowCount = _a$overflowCount === void 0 ? 99 : _a$overflowCount,
64 _a$dot = _a.dot,
65 dot = _a$dot === void 0 ? false : _a$dot,
66 _a$size = _a.size,
67 size = _a$size === void 0 ? 'default' : _a$size,
68 title = _a.title,
69 offset = _a.offset,
70 style = _a.style,
71 className = _a.className,
72 _a$showZero = _a.showZero,
73 showZero = _a$showZero === void 0 ? false : _a$showZero,
74 restProps = __rest(_a, ["prefixCls", "scrollNumberPrefixCls", "children", "status", "text", "color", "count", "overflowCount", "dot", "size", "title", "offset", "style", "className", "showZero"]);
75
76 var _React$useContext = React.useContext(_configProvider.ConfigContext),
77 getPrefixCls = _React$useContext.getPrefixCls,
78 direction = _React$useContext.direction;
79
80 var prefixCls = getPrefixCls('badge', customizePrefixCls); // ================================ Misc ================================
81
82 var numberedDisplayCount = count > overflowCount ? "".concat(overflowCount, "+") : count;
83 var hasStatus = status !== null && status !== undefined || color !== null && color !== undefined;
84 var isZero = numberedDisplayCount === '0' || numberedDisplayCount === 0;
85 var showAsDot = dot && !isZero || hasStatus;
86 var mergedCount = showAsDot ? '' : numberedDisplayCount;
87 var isHidden = (0, React.useMemo)(function () {
88 var isEmpty = mergedCount === null || mergedCount === undefined || mergedCount === '';
89 return (isEmpty || isZero && !showZero) && !showAsDot;
90 }, [mergedCount, isZero, showZero, showAsDot]); // Count should be cache in case hidden change it
91
92 var countRef = (0, React.useRef)(count);
93
94 if (!isHidden) {
95 countRef.current = count;
96 }
97
98 var livingCount = countRef.current; // We need cache count since remove motion should not change count display
99
100 var displayCountRef = (0, React.useRef)(mergedCount);
101
102 if (!isHidden) {
103 displayCountRef.current = mergedCount;
104 }
105
106 var displayCount = displayCountRef.current; // We will cache the dot status to avoid shaking on leaved motion
107
108 var isDotRef = (0, React.useRef)(showAsDot);
109
110 if (!isHidden) {
111 isDotRef.current = showAsDot;
112 } // =============================== Styles ===============================
113
114
115 var mergedStyle = (0, React.useMemo)(function () {
116 if (!offset) {
117 return (0, _extends2["default"])({}, style);
118 }
119
120 var offsetStyle = {
121 marginTop: offset[1]
122 };
123
124 if (direction === 'rtl') {
125 offsetStyle.left = parseInt(offset[0], 10);
126 } else {
127 offsetStyle.right = -parseInt(offset[0], 10);
128 }
129
130 return (0, _extends2["default"])((0, _extends2["default"])({}, offsetStyle), style);
131 }, [direction, offset, style]); // =============================== Render ===============================
132 // >>> Title
133
134 var titleNode = title !== null && title !== void 0 ? title : typeof livingCount === 'string' || typeof livingCount === 'number' ? livingCount : undefined; // >>> Status Text
135
136 var statusTextNode = isHidden || !text ? null : /*#__PURE__*/React.createElement("span", {
137 className: "".concat(prefixCls, "-status-text")
138 }, text); // >>> Display Component
139
140 var displayNode = !livingCount || (0, _typeof2["default"])(livingCount) !== 'object' ? undefined : (0, _reactNode.cloneElement)(livingCount, function (oriProps) {
141 return {
142 style: (0, _extends2["default"])((0, _extends2["default"])({}, mergedStyle), oriProps.style)
143 };
144 }); // Shared styles
145
146 var statusCls = (0, _classnames["default"])((_classNames = {}, (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-status-dot"), hasStatus), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-status-").concat(status), !!status), (0, _defineProperty2["default"])(_classNames, "".concat(prefixCls, "-status-").concat(color), (0, _utils.isPresetColor)(color)), _classNames));
147 var statusStyle = {};
148
149 if (color && !(0, _utils.isPresetColor)(color)) {
150 statusStyle.background = color;
151 }
152
153 var badgeClassName = (0, _classnames["default"])(prefixCls, (_classNames2 = {}, (0, _defineProperty2["default"])(_classNames2, "".concat(prefixCls, "-status"), hasStatus), (0, _defineProperty2["default"])(_classNames2, "".concat(prefixCls, "-not-a-wrapper"), !children), (0, _defineProperty2["default"])(_classNames2, "".concat(prefixCls, "-rtl"), direction === 'rtl'), _classNames2), className); // <Badge status="success" />
154
155 if (!children && hasStatus) {
156 var statusTextColor = mergedStyle.color;
157 return /*#__PURE__*/React.createElement("span", (0, _extends2["default"])({}, restProps, {
158 className: badgeClassName,
159 style: mergedStyle
160 }), /*#__PURE__*/React.createElement("span", {
161 className: statusCls,
162 style: statusStyle
163 }), /*#__PURE__*/React.createElement("span", {
164 style: {
165 color: statusTextColor
166 },
167 className: "".concat(prefixCls, "-status-text")
168 }, text));
169 } // <Badge status="success" count={<Icon type="xxx" />}></Badge>
170
171
172 return /*#__PURE__*/React.createElement("span", (0, _extends2["default"])({}, restProps, {
173 className: badgeClassName
174 }), children, /*#__PURE__*/React.createElement(_rcMotion["default"], {
175 visible: !isHidden,
176 motionName: "".concat(prefixCls, "-zoom"),
177 motionAppear: false
178 }, function (_ref) {
179 var _classNames3;
180
181 var motionClassName = _ref.className;
182 var scrollNumberPrefixCls = getPrefixCls('scroll-number', customizeScrollNumberPrefixCls);
183 var isDot = isDotRef.current;
184 var scrollNumberCls = (0, _classnames["default"])((_classNames3 = {}, (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-dot"), isDot), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-count"), !isDot), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-count-sm"), size === 'small'), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-multiple-words"), !isDot && displayCount && displayCount.toString().length > 1), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-status-").concat(status), !!status), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-status-").concat(color), (0, _utils.isPresetColor)(color)), _classNames3));
185 var scrollNumberStyle = (0, _extends2["default"])({}, mergedStyle);
186
187 if (color && !(0, _utils.isPresetColor)(color)) {
188 scrollNumberStyle = scrollNumberStyle || {};
189 scrollNumberStyle.background = color;
190 }
191
192 return /*#__PURE__*/React.createElement(_ScrollNumber["default"], {
193 prefixCls: scrollNumberPrefixCls,
194 show: !isHidden,
195 motionClassName: motionClassName,
196 className: scrollNumberCls,
197 count: displayCount,
198 title: titleNode,
199 style: scrollNumberStyle,
200 key: "scrollNumber"
201 }, displayNode);
202 }), statusTextNode);
203};
204
205Badge.Ribbon = _Ribbon["default"];
206var _default = Badge;
207exports["default"] = _default;
\No newline at end of file