fomantic-ui-react
Version:
Fomantic-UI React -- A React Component Library.
123 lines (98 loc) • 4.86 kB
JavaScript
/**
* fomantic-ui-react v0.0.1-alpha.10
* (c) 2022 FireLoong <fireloong@foxmail.com>
* @license MIT
*/
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var defineProperty = require('../_chunks/dep-6ab59a61.js');
var slicedToArray = require('../_chunks/dep-640599ea.js');
var objectWithoutProperties = require('../_chunks/dep-03754121.js');
var React = require('react');
var classNames = require('classnames');
var reactUse = require('react-use');
var shape_ShapeSides = require('./ShapeSides.js');
var shape_ShapeSide = require('./ShapeSide.js');
var _util_reactNode = require('../_util/reactNode.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames);
var _excluded = ["as", "className", "behavior", "type", "duration", "change", "children", "onStart", "onComplete"];
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); 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 = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { defineProperty._defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
var Shape = function Shape(_ref) {
var _ref$as = _ref.as,
as = _ref$as === void 0 ? "div" : _ref$as,
className = _ref.className,
behavior = _ref.behavior,
type = _ref.type,
_ref$duration = _ref.duration,
duration = _ref$duration === void 0 ? 700 : _ref$duration,
change = _ref.change,
children = _ref.children,
onStart = _ref.onStart,
onComplete = _ref.onComplete,
props = objectWithoutProperties._objectWithoutProperties(_ref, _excluded);
var _useState = React.useState(false),
_useState2 = slicedToArray._slicedToArray(_useState, 2),
animating = _useState2[0],
setAnimating = _useState2[1];
var _useMap = reactUse.useMap(),
_useMap2 = slicedToArray._slicedToArray(_useMap, 2),
styles = _useMap2[0],
setStyle = _useMap2[1].set;
var ref = React.useRef(null);
var _useState3 = React.useState(change),
_useState4 = slicedToArray._slicedToArray(_useState3, 2),
isChange = _useState4[0],
setIsChange = _useState4[1];
React.useEffect(function () {
setIsChange(change);
if (change) {
onStart === null || onStart === void 0 ? void 0 : onStart();
}
}, [change]);
React.useEffect(function () {
if (isChange) {
var _ref$current, _ref$current2;
setAnimating(true);
setStyle("width", "".concat((_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.offsetWidth, "px"));
setStyle("height", "".concat((_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.offsetHeight, "px"));
setTimeout(function () {
setAnimating(false);
setStyle("width", void 0);
setStyle("height", void 0);
setIsChange(false);
onComplete === null || onComplete === void 0 ? void 0 : onComplete();
}, duration);
}
}, [isChange]);
if (!as) {
as = "div";
}
var sides;
if (_util_reactNode.isNil(children)) ; else {
var child = React.Children.only(children);
if (_util_reactNode.isValidElement(child)) {
var _ref$current3, _ref$current4;
sides = /*#__PURE__*/React.cloneElement(child, {
change: isChange,
duration: duration,
behavior: behavior,
width: (_ref$current3 = ref.current) === null || _ref$current3 === void 0 ? void 0 : _ref$current3.offsetWidth,
height: (_ref$current4 = ref.current) === null || _ref$current4 === void 0 ? void 0 : _ref$current4.offsetHeight
});
}
}
return /*#__PURE__*/React.createElement(as, _objectSpread({
ref: ref,
className: classNames__default["default"]("ui", type && defineProperty._defineProperty({}, type, type), "shape", {
animating: animating
}, className),
style: _objectSpread(_objectSpread({}, props.style), styles)
}, props), sides);
};
Shape.displayName = "Shape";
Shape.Sides = shape_ShapeSides["default"];
Shape.Side = shape_ShapeSide["default"];
exports["default"] = Shape;
//# sourceMappingURL=Shape.js.map