Notice.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof3 = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  10. var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
  11. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  12. var _classnames = _interopRequireDefault(require("classnames"));
  13. var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
  14. var React = _interopRequireWildcard(require("react"));
  15. var _pickAttrs = _interopRequireDefault(require("rc-util/lib/pickAttrs"));
  16. function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
  17. function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
  18. var Notify = /*#__PURE__*/React.forwardRef(function (props, ref) {
  19. var prefixCls = props.prefixCls,
  20. style = props.style,
  21. className = props.className,
  22. _props$duration = props.duration,
  23. duration = _props$duration === void 0 ? 4.5 : _props$duration,
  24. showProgress = props.showProgress,
  25. _props$pauseOnHover = props.pauseOnHover,
  26. pauseOnHover = _props$pauseOnHover === void 0 ? true : _props$pauseOnHover,
  27. eventKey = props.eventKey,
  28. content = props.content,
  29. closable = props.closable,
  30. _props$closeIcon = props.closeIcon,
  31. closeIcon = _props$closeIcon === void 0 ? 'x' : _props$closeIcon,
  32. divProps = props.props,
  33. onClick = props.onClick,
  34. onNoticeClose = props.onNoticeClose,
  35. times = props.times,
  36. forcedHovering = props.hovering;
  37. var _React$useState = React.useState(false),
  38. _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
  39. hovering = _React$useState2[0],
  40. setHovering = _React$useState2[1];
  41. var _React$useState3 = React.useState(0),
  42. _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
  43. percent = _React$useState4[0],
  44. setPercent = _React$useState4[1];
  45. var _React$useState5 = React.useState(0),
  46. _React$useState6 = (0, _slicedToArray2.default)(_React$useState5, 2),
  47. spentTime = _React$useState6[0],
  48. setSpentTime = _React$useState6[1];
  49. var mergedHovering = forcedHovering || hovering;
  50. var mergedShowProgress = duration > 0 && showProgress;
  51. // ======================== Close =========================
  52. var onInternalClose = function onInternalClose() {
  53. onNoticeClose(eventKey);
  54. };
  55. var onCloseKeyDown = function onCloseKeyDown(e) {
  56. if (e.key === 'Enter' || e.code === 'Enter' || e.keyCode === _KeyCode.default.ENTER) {
  57. onInternalClose();
  58. }
  59. };
  60. // ======================== Effect ========================
  61. React.useEffect(function () {
  62. if (!mergedHovering && duration > 0) {
  63. var start = Date.now() - spentTime;
  64. var timeout = setTimeout(function () {
  65. onInternalClose();
  66. }, duration * 1000 - spentTime);
  67. return function () {
  68. if (pauseOnHover) {
  69. clearTimeout(timeout);
  70. }
  71. setSpentTime(Date.now() - start);
  72. };
  73. }
  74. // eslint-disable-next-line react-hooks/exhaustive-deps
  75. }, [duration, mergedHovering, times]);
  76. React.useEffect(function () {
  77. if (!mergedHovering && mergedShowProgress && (pauseOnHover || spentTime === 0)) {
  78. var start = performance.now();
  79. var animationFrame;
  80. var calculate = function calculate() {
  81. cancelAnimationFrame(animationFrame);
  82. animationFrame = requestAnimationFrame(function (timestamp) {
  83. var runtime = timestamp + spentTime - start;
  84. var progress = Math.min(runtime / (duration * 1000), 1);
  85. setPercent(progress * 100);
  86. if (progress < 1) {
  87. calculate();
  88. }
  89. });
  90. };
  91. calculate();
  92. return function () {
  93. if (pauseOnHover) {
  94. cancelAnimationFrame(animationFrame);
  95. }
  96. };
  97. }
  98. // eslint-disable-next-line react-hooks/exhaustive-deps
  99. }, [duration, spentTime, mergedHovering, mergedShowProgress, times]);
  100. // ======================== Closable ========================
  101. var closableObj = React.useMemo(function () {
  102. if ((0, _typeof2.default)(closable) === 'object' && closable !== null) {
  103. return closable;
  104. }
  105. if (closable) {
  106. return {
  107. closeIcon: closeIcon
  108. };
  109. }
  110. return {};
  111. }, [closable, closeIcon]);
  112. var ariaProps = (0, _pickAttrs.default)(closableObj, true);
  113. // ======================== Progress ========================
  114. var validPercent = 100 - (!percent || percent < 0 ? 0 : percent > 100 ? 100 : percent);
  115. // ======================== Render ========================
  116. var noticePrefixCls = "".concat(prefixCls, "-notice");
  117. return /*#__PURE__*/React.createElement("div", (0, _extends2.default)({}, divProps, {
  118. ref: ref,
  119. className: (0, _classnames.default)(noticePrefixCls, className, (0, _defineProperty2.default)({}, "".concat(noticePrefixCls, "-closable"), closable)),
  120. style: style,
  121. onMouseEnter: function onMouseEnter(e) {
  122. var _divProps$onMouseEnte;
  123. setHovering(true);
  124. divProps === null || divProps === void 0 || (_divProps$onMouseEnte = divProps.onMouseEnter) === null || _divProps$onMouseEnte === void 0 || _divProps$onMouseEnte.call(divProps, e);
  125. },
  126. onMouseLeave: function onMouseLeave(e) {
  127. var _divProps$onMouseLeav;
  128. setHovering(false);
  129. divProps === null || divProps === void 0 || (_divProps$onMouseLeav = divProps.onMouseLeave) === null || _divProps$onMouseLeav === void 0 || _divProps$onMouseLeav.call(divProps, e);
  130. },
  131. onClick: onClick
  132. }), /*#__PURE__*/React.createElement("div", {
  133. className: "".concat(noticePrefixCls, "-content")
  134. }, content), closable && /*#__PURE__*/React.createElement("a", (0, _extends2.default)({
  135. tabIndex: 0,
  136. className: "".concat(noticePrefixCls, "-close"),
  137. onKeyDown: onCloseKeyDown,
  138. "aria-label": "Close"
  139. }, ariaProps, {
  140. onClick: function onClick(e) {
  141. e.preventDefault();
  142. e.stopPropagation();
  143. onInternalClose();
  144. }
  145. }), closableObj.closeIcon), mergedShowProgress && /*#__PURE__*/React.createElement("progress", {
  146. className: "".concat(noticePrefixCls, "-progress"),
  147. max: "100",
  148. value: validPercent
  149. }, validPercent + '%'));
  150. });
  151. var _default = exports.default = Notify;