UNPKG

grommet

Version:

focus on the essential experience

66 lines (65 loc) 3.35 kB
"use strict"; exports.__esModule = true; exports["default"] = exports.Header = void 0; var _react = _interopRequireWildcard(require("react")); var _grommet = require("grommet"); 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); } var renderPanelHeader = function renderPanelHeader(title, active) { return /*#__PURE__*/_react["default"].createElement(_grommet.Box, { direction: "row", align: "center", pad: "medium", gap: "small" }, /*#__PURE__*/_react["default"].createElement("strong", null, /*#__PURE__*/_react["default"].createElement(_grommet.Text, null, title)), /*#__PURE__*/_react["default"].createElement(_grommet.Text, { color: "brand" }, active ? '-' : '+')); }; var CustomHeaderAccordion = function CustomHeaderAccordion() { var _useState = (0, _react.useState)([0]), activeIndex = _useState[0], setActiveIndex = _useState[1]; return ( /*#__PURE__*/ // Uncomment <Grommet> lines when using outside of storybook // <Grommet theme={...}> _react["default"].createElement(_grommet.Accordion, { activeIndex: activeIndex, onActive: function onActive(newActiveIndex) { return setActiveIndex(newActiveIndex); } }, /*#__PURE__*/_react["default"].createElement(_grommet.AccordionPanel, { header: renderPanelHeader('Panel 1', activeIndex.includes(0)) }, /*#__PURE__*/_react["default"].createElement(_grommet.Box, { pad: "medium", background: "light-2", style: { height: '800px' } }, /*#__PURE__*/_react["default"].createElement(_grommet.Text, null, "Panel 1 contents"), /*#__PURE__*/_react["default"].createElement(_grommet.TextInput, { a11yTitle: "panel 1 text box" }))), /*#__PURE__*/_react["default"].createElement(_grommet.AccordionPanel, { header: renderPanelHeader('Panel 2', activeIndex.includes(1)) }, /*#__PURE__*/_react["default"].createElement(_grommet.Box, { pad: "medium", background: "light-2", style: { height: '50px' } }, /*#__PURE__*/_react["default"].createElement(_grommet.Text, null, "Panel 2 contents"))), /*#__PURE__*/_react["default"].createElement(_grommet.AccordionPanel, { header: renderPanelHeader('Panel 3', activeIndex.includes(2)) }, /*#__PURE__*/_react["default"].createElement(_grommet.Box, { pad: "medium", background: "light-2", style: { height: '300px' } }, /*#__PURE__*/_react["default"].createElement(_grommet.Text, null, "Panel 3 contents")))) // </Grommet> ); }; var Header = exports.Header = function Header() { return /*#__PURE__*/_react["default"].createElement(CustomHeaderAccordion, null); }; var _default = exports["default"] = { title: 'Controls/Accordion/Header' };