UNPKG

react-expand-animated

Version:

The expand component that animate the height of child component when toggling

222 lines (177 loc) 21.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _GROUP, _PropTypes$shape; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (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 _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } // In firefox, setTimeout with duration 0 too short for browser notice the changes in dom var initialTransitDuration = 20; var PHASE = { CLOSE: 'close', CLOSING: 'closing', CLOSED: 'closed', OPEN: 'open', OPENING: 'opening', OPENED: 'opened' }; var GROUP = (_GROUP = {}, _defineProperty(_GROUP, PHASE.CLOSE, PHASE.CLOSE), _defineProperty(_GROUP, PHASE.CLOSED, PHASE.CLOSE), _defineProperty(_GROUP, PHASE.OPENING, PHASE.CLOSE), _defineProperty(_GROUP, PHASE.CLOSING, PHASE.OPEN), _defineProperty(_GROUP, PHASE.OPEN, PHASE.OPEN), _defineProperty(_GROUP, PHASE.OPENED, PHASE.OPEN), _GROUP); var Expand = /*#__PURE__*/ function (_Component) { _inherits(Expand, _Component); function Expand(props) { var _this; _classCallCheck(this, Expand); _this = _possibleConstructorReturn(this, _getPrototypeOf(Expand).call(this, props)); _defineProperty(_assertThisInitialized(_this), "getClientHeight", function () { return _this.refWrapper.scrollHeight; }); _defineProperty(_assertThisInitialized(_this), "getDefaultExpandStyle", function () { var status = _this.state.status; switch (status) { case PHASE.OPENING: case PHASE.CLOSE: case PHASE.CLOSED: return { height: 0, opacity: 0, overflow: 'hidden' }; case PHASE.OPENED: case PHASE.CLOSING: return { height: _this.getClientHeight(), opacity: 1, overflow: 'hidden' }; default: return { height: 'auto', opacity: 1, overflow: 'unset' }; } }); _defineProperty(_assertThisInitialized(_this), "getExpandStyle", function () { return _objectSpread({}, _this.getDefaultExpandStyle(), {}, _this.props.styles[GROUP[_this.state.status]]); }); _defineProperty(_assertThisInitialized(_this), "getTransition", function (attribute) { return "".concat(attribute, " ").concat(_this.props.duration, "ms ").concat(_this.props.easing); }); _defineProperty(_assertThisInitialized(_this), "updateStatus", function (status) { return _this.setState({ status: status }); }); _defineProperty(_assertThisInitialized(_this), "delay", function (fn, time) { _this.timeout = setTimeout(fn, time); }); _defineProperty(_assertThisInitialized(_this), "clearDelay", function () { if (_this.timeout) { clearTimeout(_this.timeout); } }); _defineProperty(_assertThisInitialized(_this), "transit", function (entering, entered, enter) { var duration = _this.props.duration; _this.updateStatus(entering); _this.delay(function () { _this.updateStatus(entered); _this.delay(function () { _this.updateStatus(enter); }, duration); }, initialTransitDuration); }); _defineProperty(_assertThisInitialized(_this), "toggle", function (open) { _this.clearDelay(); if (open) { _this.transit(PHASE.OPENING, PHASE.OPENED, PHASE.OPEN); } else { _this.transit(PHASE.CLOSING, PHASE.CLOSED, PHASE.CLOSE); } }); _defineProperty(_assertThisInitialized(_this), "setRef", function (ref) { _this.refWrapper = ref; }); _this.state = { status: _this.props.open ? PHASE.OPEN : PHASE.CLOSE }; return _this; } _createClass(Expand, [{ key: "componentDidUpdate", value: function componentDidUpdate(prevProps /* prevState */ ) { if (prevProps.open !== this.props.open) { this.toggle(this.props.open); } } }, { key: "componentWillUnmount", value: function componentWillUnmount() { this.clearDelay(); } }, { key: "getStyle", value: function getStyle() { var transition = this.props.transitions.map(this.getTransition).join(','); return _objectSpread({}, this.getExpandStyle(), { transition: transition }); } }, { key: "render", value: function render() { var _this$props = this.props, className = _this$props.className, children = _this$props.children, Tag = _this$props.tag; var childProps = { className: className, style: this.getStyle(), ref: this.setRef }; return _react["default"].createElement(Tag, childProps, children); } }]); return Expand; }(_react.Component); Expand.propTypes = { children: _propTypes["default"].node.isRequired, open: _propTypes["default"].bool, duration: _propTypes["default"].number, easing: _propTypes["default"].string, className: _propTypes["default"].string, tag: _propTypes["default"].string, transitions: _propTypes["default"].arrayOf(_propTypes["default"].string), styles: _propTypes["default"].shape((_PropTypes$shape = {}, _defineProperty(_PropTypes$shape, PHASE.OPEN, _propTypes["default"].object), _defineProperty(_PropTypes$shape, PHASE.CLOSE, _propTypes["default"].object), _PropTypes$shape)) }; Expand.defaultProps = { open: false, duration: 400, easing: 'ease-in-out', className: '', tag: 'div', transitions: ['height', 'opacity'], styles: {} }; var _default = Expand; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Expand.jsx"],"names":["initialTransitDuration","PHASE","CLOSE","CLOSING","CLOSED","OPEN","OPENING","OPENED","GROUP","Expand","props","refWrapper","scrollHeight","status","state","height","opacity","overflow","getClientHeight","getDefaultExpandStyle","styles","attribute","duration","easing","setState","fn","time","timeout","setTimeout","clearTimeout","entering","entered","enter","updateStatus","delay","open","clearDelay","transit","ref","prevProps","toggle","transition","transitions","map","getTransition","join","getExpandStyle","className","children","Tag","tag","childProps","style","getStyle","setRef","Component","propTypes","PropTypes","node","isRequired","bool","number","string","arrayOf","shape","object","defaultProps"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\n// In firefox, setTimeout with duration 0 too short for browser notice the changes in dom\nconst initialTransitDuration = 20;\n\nconst PHASE = {\n  CLOSE: 'close',\n  CLOSING: 'closing',\n  CLOSED: 'closed',\n  OPEN: 'open',\n  OPENING: 'opening',\n  OPENED: 'opened',\n};\n\nconst GROUP = {\n  [PHASE.CLOSE]: PHASE.CLOSE,\n  [PHASE.CLOSED]: PHASE.CLOSE,\n  [PHASE.OPENING]: PHASE.CLOSE,\n\n  [PHASE.CLOSING]: PHASE.OPEN,\n  [PHASE.OPEN]: PHASE.OPEN,\n  [PHASE.OPENED]: PHASE.OPEN,\n};\n\nclass Expand extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      status: this.props.open ? PHASE.OPEN : PHASE.CLOSE,\n    };\n  }\n\n  componentDidUpdate(prevProps /* prevState */) {\n    if (prevProps.open !== this.props.open) {\n      this.toggle(this.props.open);\n    }\n  }\n\n  componentWillUnmount() {\n    this.clearDelay();\n  }\n\n  getClientHeight = () => this.refWrapper.scrollHeight;\n\n  getDefaultExpandStyle = () => {\n    const { status } = this.state;\n\n    switch (status) {\n      case PHASE.OPENING:\n      case PHASE.CLOSE:\n      case PHASE.CLOSED:\n        return { height: 0, opacity: 0, overflow: 'hidden' };\n      case PHASE.OPENED:\n      case PHASE.CLOSING:\n        return { height: this.getClientHeight(), opacity: 1, overflow: 'hidden' };\n      default:\n        return { height: 'auto', opacity: 1, overflow: 'unset' };\n    }\n  };\n\n  getExpandStyle = () => ({\n    ...this.getDefaultExpandStyle(),\n    ...this.props.styles[GROUP[this.state.status]],\n  });\n\n  getTransition = (attribute) => `${attribute} ${this.props.duration}ms ${this.props.easing}`;\n\n  getStyle() {\n    const transition = this.props.transitions.map(this.getTransition).join(',');\n\n    return {\n      ...this.getExpandStyle(),\n      transition,\n    };\n  }\n\n  updateStatus = (status) => this.setState({ status });\n\n  delay = (fn, time) => {\n    this.timeout = setTimeout(fn, time);\n  };\n\n  clearDelay = () => {\n    if (this.timeout) {\n      clearTimeout(this.timeout);\n    }\n  };\n\n  transit = (entering, entered, enter) => {\n    const { duration } = this.props;\n\n    this.updateStatus(entering);\n\n    this.delay(() => {\n      this.updateStatus(entered);\n\n      this.delay(() => {\n        this.updateStatus(enter);\n      }, duration);\n    }, initialTransitDuration);\n  };\n\n  toggle = (open) => {\n    this.clearDelay();\n\n    if (open) {\n      this.transit(PHASE.OPENING, PHASE.OPENED, PHASE.OPEN);\n    } else {\n      this.transit(PHASE.CLOSING, PHASE.CLOSED, PHASE.CLOSE);\n    }\n  };\n\n  setRef = (ref) => { this.refWrapper = ref; };\n\n  render() {\n    const { className, children, tag: Tag } = this.props;\n\n    const childProps = {\n      className,\n      style: this.getStyle(),\n      ref: this.setRef,\n    };\n\n    return (\n      <Tag {...childProps}>\n        {children}\n      </Tag>\n    );\n  }\n}\n\nExpand.propTypes = {\n  children: PropTypes.node.isRequired,\n  open: PropTypes.bool,\n  duration: PropTypes.number,\n  easing: PropTypes.string,\n  className: PropTypes.string,\n  tag: PropTypes.string,\n  transitions: PropTypes.arrayOf(PropTypes.string),\n  styles: PropTypes.shape({\n    [PHASE.OPEN]: PropTypes.object,\n    [PHASE.CLOSE]: PropTypes.object,\n  }),\n};\n\nExpand.defaultProps = {\n  open: false,\n  duration: 400,\n  easing: 'ease-in-out',\n  className: '',\n  tag: 'div',\n  transitions: ['height', 'opacity'],\n  styles: {},\n};\n\nexport default Expand;\n"]}