UNPKG

adui

Version:

<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>

197 lines (167 loc) 25.5 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var React = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _rcAnimate = _interopRequireDefault(require("rc-animate")); var _excluded = ["afterLeave", "animation", "appear", "children", "duration", "onLeave", "transition"]; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _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); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; } function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } var noop = function noop() {}; var MOTION_DURATION_BASE = 200; var transitionNames = { slide: "slide-up", zoom: "zoom-motion", zoomHorizontal: "zoom-motion-horizontal" }; var Motion = function Motion(_ref) { var afterLeave = _ref.afterLeave, animation = _ref.animation, _appear = _ref.appear, children = _ref.children, duration = _ref.duration, onLeave = _ref.onLeave, transition = _ref.transition, othersProps = _objectWithoutProperties(_ref, _excluded); var dur = duration !== null && duration !== undefined ? duration : MOTION_DURATION_BASE; var transitionName = transition && transitionNames[transition]; var getNodeStyle = function getNodeStyle(node, styleName) { return getComputedStyle(node).getPropertyValue(styleName); }; var setNodeStyle = function setNodeStyle(node) { if (node) { if (transitionName && transitionName.includes("horizontal")) { node.style.marginRight = "0"; node.style.marginLeft = "0"; node.style.paddingRight = "0"; node.style.paddingLeft = "0"; node.style.width = "0"; } else { node.style.marginTop = "0"; node.style.marginBottom = "0"; node.style.paddingTop = "0"; node.style.paddingBottom = "0"; node.style.height = "0"; } } }; var getEnterAnimation = function getEnterAnimation(node, done) { var width = "".concat(node.getBoundingClientRect().width, "px"); var height = "".concat(node.getBoundingClientRect().height, "px"); var paddingTop = getNodeStyle(node, "padding-top"); var paddingRight = getNodeStyle(node, "padding-right"); var paddingBottom = getNodeStyle(node, "padding-bottom"); var paddingLeft = getNodeStyle(node, "padding-left"); if (transitionName && transitionName.includes("slide")) { node.style.opacity = "1"; } if (transitionName && transitionName.includes("horizontal")) { node.style.width = "0"; node.style.paddingRight = "0"; node.style.paddingLeft = "0"; } else { node.style.height = "0"; node.style.paddingTop = "0"; node.style.paddingBottom = "0"; } node.style.overflow = "hidden"; node.style.setProperty("animation-duration", "".concat(dur, "ms"), "important"); node.classList.add("".concat(transitionName, "-enter"), "".concat(transitionName, "-enter-active")); setTimeout(function () { if (transitionName && transitionName.includes("horizontal")) { node.style.transition = "all ".concat(dur, "ms var(--ease-in-out)"); node.style.width = width; node.style.paddingRight = paddingRight; node.style.paddingLeft = paddingLeft; } else { node.style.transition = "all ".concat(dur, "ms var(--ease-in-out)"); node.style.height = height; node.style.paddingTop = paddingTop; node.style.paddingBottom = paddingBottom; } }, 10); var promise = new Promise(function (resolve) { return setTimeout(resolve, dur); }); promise.then(function () { node.classList.remove("".concat(transitionName, "-enter"), "".concat(transitionName, "-enter-active")); if (transitionName && transitionName.includes("horizontal")) { node.style.width = ""; } else { node.style.height = ""; } node.style.overflow = ""; return done(); }); }; return React.createElement(_rcAnimate["default"], _extends({ animation: animation || { appear: function appear(node, done) { if (_appear) { getEnterAnimation(node, done); } return done(); }, enter: function enter(node, done) { getEnterAnimation(node, done); }, leave: function leave(node, done) { if (onLeave) { onLeave(node); } if (transitionName && transitionName.includes("horizontal")) { var width = "".concat(node.getBoundingClientRect().width, "px"); node.style.width = width; } else { var height = "".concat(node.getBoundingClientRect().height, "px"); node.style.height = height; } node.style.setProperty("animation-duration", "".concat(dur, "ms"), "important"); node.style.overflow = "hidden"; node.classList.remove("".concat(transitionName, "-enter"), "".concat(transitionName, "-enter-active")); node.classList.add("".concat(transitionName, "-leave"), "".concat(transitionName, "-leave-active")); setTimeout(function () { node.style.transition = "all ".concat(dur, "ms var(--ease-in-out)"); setNodeStyle(node); }, 10); var promise = new Promise(function (resolve) { return setTimeout(resolve, dur); }); promise.then(function () { if (afterLeave) { afterLeave(node); } return done(); }); } } }, othersProps), children); }; Motion.propTypes = { afterLeave: _propTypes["default"].func, animation: _propTypes["default"].object, appear: _propTypes["default"].bool, children: _propTypes["default"].node, duration: _propTypes["default"].number, onLeave: _propTypes["default"].func, transition: _propTypes["default"].oneOf(["slide", "zoom", "zoomHorizontal"]) }; Motion.defaultProps = { afterLeave: noop, animation: undefined, appear: false, children: null, duration: undefined, onLeave: noop, transition: "zoom" }; var _default = Motion; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["noop","MOTION_DURATION_BASE","transitionNames","slide","zoom","zoomHorizontal","Motion","afterLeave","animation","appear","children","duration","onLeave","transition","othersProps","dur","undefined","transitionName","getNodeStyle","node","styleName","getComputedStyle","getPropertyValue","setNodeStyle","includes","style","marginRight","marginLeft","paddingRight","paddingLeft","width","marginTop","marginBottom","paddingTop","paddingBottom","height","getEnterAnimation","done","getBoundingClientRect","opacity","overflow","setProperty","classList","add","setTimeout","promise","Promise","resolve","then","remove","enter","leave","propTypes","PropTypes","func","object","bool","number","oneOf","defaultProps"],"sources":["../../components/motion/Motion.tsx"],"sourcesContent":["import * as React from \"react\"\nimport PropTypes from \"prop-types\"\nimport Animate from \"rc-animate\"\n\nconst noop = () => {}\nconst MOTION_DURATION_BASE = 200\nconst transitionNames = {\n  slide: \"slide-up\",\n  zoom: \"zoom-motion\",\n  zoomHorizontal: \"zoom-motion-horizontal\",\n}\n\nexport interface IMotionProps {\n  [key: string]: any\n  /**\n   * dom 移除后的 handler\n   */\n  afterLeave?: (node: HTMLElement) => void\n  /**\n   * 可自定义 animation 的 appear, enter, leave\n   */\n  animation?: object\n  /**\n   * 进入动画是否作用于 appear 阶段\n   */\n  appear?: boolean\n  /**\n   * 子元素\n   */\n  children?: React.ReactNode\n  /**\n   * Motion 包裹层的元素标签\n   */\n  component?: string\n  /**\n   * 动效持续时间，单位 ms\n   */\n  duration?: number\n  /**\n   * dom 开始移除的 handler\n   */\n  onLeave?: (node: HTMLElement) => void\n  /**\n   * 动效形式\n   */\n  transition?: \"slide\" | \"zoom\" | \"zoomHorizontal\"\n}\n\nconst Motion: React.FC<IMotionProps> = ({\n  afterLeave,\n  animation,\n  appear,\n  children,\n  duration,\n  onLeave,\n  transition,\n  ...othersProps\n}: IMotionProps) => {\n  const dur =\n    duration !== null && duration !== undefined\n      ? duration\n      : MOTION_DURATION_BASE\n  const transitionName = transition && transitionNames[transition]\n\n  const getNodeStyle = (node: HTMLElement, styleName: string) =>\n    getComputedStyle(node).getPropertyValue(styleName)\n\n  const setNodeStyle = (node: HTMLElement) => {\n    if (node) {\n      if (transitionName && transitionName.includes(\"horizontal\")) {\n        node.style.marginRight = \"0\"\n        node.style.marginLeft = \"0\"\n        node.style.paddingRight = \"0\"\n        node.style.paddingLeft = \"0\"\n        node.style.width = \"0\"\n      } else {\n        node.style.marginTop = \"0\"\n        node.style.marginBottom = \"0\"\n        node.style.paddingTop = \"0\"\n        node.style.paddingBottom = \"0\"\n        node.style.height = \"0\"\n      }\n    }\n  }\n\n  const getEnterAnimation = (node: HTMLElement, done: () => void) => {\n    const width = `${node.getBoundingClientRect().width}px`\n    const height = `${node.getBoundingClientRect().height}px`\n    const paddingTop = getNodeStyle(node, \"padding-top\")\n    const paddingRight = getNodeStyle(node, \"padding-right\")\n    const paddingBottom = getNodeStyle(node, \"padding-bottom\")\n    const paddingLeft = getNodeStyle(node, \"padding-left\")\n\n    if (transitionName && transitionName.includes(\"slide\")) {\n      node.style.opacity = \"1\"\n    }\n\n    if (transitionName && transitionName.includes(\"horizontal\")) {\n      node.style.width = \"0\"\n      node.style.paddingRight = \"0\"\n      node.style.paddingLeft = \"0\"\n    } else {\n      node.style.height = \"0\"\n      node.style.paddingTop = \"0\"\n      node.style.paddingBottom = \"0\"\n    }\n\n    node.style.overflow = \"hidden\"\n    node.style.setProperty(\"animation-duration\", `${dur}ms`, \"important\")\n    node.classList.add(\n      `${transitionName}-enter`,\n      `${transitionName}-enter-active`\n    )\n\n    setTimeout(() => {\n      if (transitionName && transitionName.includes(\"horizontal\")) {\n        node.style.transition = `all ${dur}ms var(--ease-in-out)`\n        node.style.width = width\n        node.style.paddingRight = paddingRight\n        node.style.paddingLeft = paddingLeft\n      } else {\n        node.style.transition = `all ${dur}ms var(--ease-in-out)`\n        node.style.height = height\n        node.style.paddingTop = paddingTop\n        node.style.paddingBottom = paddingBottom\n      }\n    }, 10)\n    const promise = new Promise((resolve) => setTimeout(resolve, dur))\n    promise.then(() => {\n      node.classList.remove(\n        `${transitionName}-enter`,\n        `${transitionName}-enter-active`\n      )\n      if (transitionName && transitionName.includes(\"horizontal\")) {\n        node.style.width = \"\"\n      } else {\n        node.style.height = \"\"\n      }\n      node.style.overflow = \"\"\n      return done()\n    })\n  }\n\n  return (\n    <Animate\n      animation={\n        animation || {\n          appear(node: HTMLElement, done: () => void) {\n            if (appear) {\n              getEnterAnimation(node, done)\n            }\n            return done()\n          },\n          enter(node: HTMLElement, done: () => void) {\n            getEnterAnimation(node, done)\n          },\n          leave(node: HTMLElement, done: () => void) {\n            if (onLeave) {\n              onLeave(node)\n            }\n            if (transitionName && transitionName.includes(\"horizontal\")) {\n              const width = `${node.getBoundingClientRect().width}px`\n              node.style.width = width\n            } else {\n              const height = `${node.getBoundingClientRect().height}px`\n              node.style.height = height\n            }\n            node.style.setProperty(\n              \"animation-duration\",\n              `${dur}ms`,\n              \"important\"\n            )\n            node.style.overflow = \"hidden\"\n            node.classList.remove(\n              `${transitionName}-enter`,\n              `${transitionName}-enter-active`\n            )\n            node.classList.add(\n              `${transitionName}-leave`,\n              `${transitionName}-leave-active`\n            )\n            setTimeout(() => {\n              node.style.transition = `all ${dur}ms var(--ease-in-out)`\n              setNodeStyle(node)\n            }, 10)\n            const promise = new Promise((resolve) => setTimeout(resolve, dur))\n            promise.then(() => {\n              if (afterLeave) {\n                afterLeave(node)\n              }\n              return done()\n            })\n          },\n        }\n      }\n      {...othersProps}\n    >\n      {children}\n    </Animate>\n  )\n}\n\nMotion.propTypes = {\n  afterLeave: PropTypes.func,\n  animation: PropTypes.object,\n  appear: PropTypes.bool,\n  children: PropTypes.node,\n  duration: PropTypes.number,\n  onLeave: PropTypes.func,\n  transition: PropTypes.oneOf([\"slide\", \"zoom\", \"zoomHorizontal\"]),\n}\n\nMotion.defaultProps = {\n  afterLeave: noop,\n  animation: undefined,\n  appear: false,\n  children: null,\n  duration: undefined,\n  onLeave: noop,\n  transition: \"zoom\",\n}\n\nexport default Motion\n"],"mappings":"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"}