grommet
Version:
focus on the essential experience
76 lines (74 loc) • 4 kB
JavaScript
;
exports.__esModule = true;
exports.Accordion = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = require("./propTypes");
var _Box = require("../Box");
var _AccordionContext = require("./AccordionContext");
var _excluded = ["activeIndex", "animate", "children", "level", "multiple", "onActive"];
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
var activeAsArray = function activeAsArray(active) {
return typeof active === 'number' ? [active] : active;
};
var Accordion = exports.Accordion = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
var activeIndex = _ref.activeIndex,
_ref$animate = _ref.animate,
animate = _ref$animate === void 0 ? true : _ref$animate,
children = _ref.children,
level = _ref.level,
multiple = _ref.multiple,
onActive = _ref.onActive,
rest = _objectWithoutPropertiesLoose(_ref, _excluded);
var _useState = (0, _react.useState)([]),
activeIndexes = _useState[0],
setActiveIndexes = _useState[1];
var _useState2 = (0, _react.useState)(),
stateActiveIndex = _useState2[0],
setStateActiveIndex = _useState2[1];
// Derived state from props
// https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops
var derivedActiveIndexes = activeAsArray(activeIndex) || [];
if ((typeof activeIndex !== 'undefined' || activeIndex !== stateActiveIndex) && derivedActiveIndexes.join() !== activeIndexes.join()) {
setActiveIndexes(derivedActiveIndexes);
setStateActiveIndex(activeIndex);
}
var getAccordionContext = (0, _react.useCallback)(function (index) {
var _onPanelChange = function onPanelChange(nextIndex) {
var nextActiveIndexes = [].concat(activeIndexes || []);
var nextActiveIndex = nextActiveIndexes.indexOf(nextIndex);
if (nextActiveIndex > -1) {
nextActiveIndexes.splice(nextActiveIndex, 1);
} else if (multiple) {
nextActiveIndexes.push(nextIndex);
} else {
nextActiveIndexes = [nextIndex];
}
setActiveIndexes(nextActiveIndexes);
if (onActive) {
onActive(nextActiveIndexes);
}
};
return {
active: activeIndexes.indexOf(index) > -1,
animate: animate,
level: level,
onPanelChange: function onPanelChange() {
return _onPanelChange(index);
}
};
}, [activeIndexes, animate, level, multiple, onActive]);
return /*#__PURE__*/_react["default"].createElement(_Box.Box, _extends({
ref: ref
}, rest), _react.Children.toArray(children).filter(function (child) {
return child;
}).map(function (child, index) {
return /*#__PURE__*/_react["default"].createElement(_AccordionContext.AccordionContext.Provider, {
// eslint-disable-next-line react/no-array-index-key
key: index,
value: getAccordionContext(index)
}, child);
}));
});
Accordion.propTypes = _propTypes.AccordionPropTypes;