UNPKG

grommet

Version:

focus on the essential experience

131 lines (129 loc) 5.89 kB
var _excluded = ["children", "header", "id", "label", "onClick", "onMouseOut", "onMouseOver", "onFocus", "onBlur"]; 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; } import React, { forwardRef, useContext, useMemo, useState } from 'react'; import { normalizeColor, parseMetricToNum, useId } from '../../utils'; import { Box } from '../Box'; import { Button } from '../Button'; import { Collapsible } from '../Collapsible'; import { Heading } from '../Heading'; import { AccordionContext } from '../Accordion/AccordionContext'; import { AccordionPanelPropTypes } from './propTypes'; import { useThemeValue } from '../../utils/useThemeValue'; var AccordionPanel = /*#__PURE__*/forwardRef(function (_ref, ref) { var _theme$accordion$labe, _theme$accordion$icon; var children = _ref.children, header = _ref.header, id = _ref.id, label = _ref.label, onClick = _ref.onClick, _onMouseOut = _ref.onMouseOut, _onMouseOver = _ref.onMouseOver, _onFocus = _ref.onFocus, _onBlur = _ref.onBlur, rest = _objectWithoutPropertiesLoose(_ref, _excluded); var panelButtonId = useId(); var _useThemeValue = useThemeValue(), theme = _useThemeValue.theme; var _useContext = useContext(AccordionContext), active = _useContext.active, animate = _useContext.animate, level = _useContext.level, onPanelChange = _useContext.onPanelChange; var _useState = useState(undefined), hover = _useState[0], setHover = _useState[1]; var _useState2 = useState(), focus = _useState2[0], setFocus = _useState2[1]; var iconColor = useMemo(function () { return normalizeColor(theme.accordion.icons.color || 'control', theme); }, [theme]); var AccordionIcon = useMemo(function () { return active ? theme.accordion.icons.collapse : theme.accordion.icons.expand; }, [active, theme.accordion.icons]); var defaultHoverColor = JSON.stringify({ dark: 'light-4', light: 'dark-3' }); // accordion.hover.color will be deprecated in v3. if (JSON.stringify(theme.accordion.hover.color) !== defaultHoverColor) console.warn("The theme style for accordion.hover.color is deprecated,\n use accordion.hover.heading.color instead."); // accordion.hover.heading.color will trump accordion.hover.color in case // the user sets its value to be any other value than the // default value (defaultHoverColor). // accordion.hover.color will be deprecated in v3. var headingColor = theme.accordion.hover && JSON.stringify(theme.accordion.hover.heading.color) !== defaultHoverColor ? theme.accordion.hover.heading.color : theme.accordion.hover.color; var contentBorder = theme.accordion.border; var panelBorder = theme.accordion.panel.border; var abutMargin; if (panelBorder) // abutMargin 'bottom' is set to overlap adjacent border panels abutMargin = { bottom: "-" + parseMetricToNum( // in case border.size defined as a t-shirt size // or in case border size is a custom size i.e. '5px' theme.global.borderSize[panelBorder.size] || panelBorder.size || theme.global.borderSize.xsmall // '-1px' ) + "px" }; return /*#__PURE__*/React.createElement(Box, { ref: ref, flex: false, onClick: onClick, border: panelBorder, margin: abutMargin }, /*#__PURE__*/React.createElement(Button, { id: panelButtonId, "aria-expanded": active, plain: theme.button["default"] ? true : undefined, onClick: onPanelChange, hoverIndicator: theme.accordion.hover.background, onMouseOver: function onMouseOver(event) { setHover(headingColor); if (_onMouseOver) _onMouseOver(event); }, onMouseOut: function onMouseOut(event) { setHover(undefined); if (_onMouseOut) _onMouseOut(event); }, onFocus: function onFocus(event) { setHover(headingColor); setFocus(true); if (_onFocus) _onFocus(event); }, onBlur: function onBlur(event) { setHover(undefined); setFocus(false); if (_onBlur) _onBlur(event); }, style: focus ? { zIndex: 1 } : undefined }, header || /*#__PURE__*/React.createElement(Box, _extends({ align: "center", direction: "row", justify: "between", id: id }, rest), typeof label === 'string' ? /*#__PURE__*/React.createElement(Box, { pad: (_theme$accordion$labe = theme.accordion.label) == null || (_theme$accordion$labe = _theme$accordion$labe.container) == null ? void 0 : _theme$accordion$labe.pad }, /*#__PURE__*/React.createElement(Heading, { level: level || theme.accordion.heading && theme.accordion.heading.level || 4, margin: theme.accordion.heading && theme.accordion.heading.margin || undefined, color: hover }, label)) : label, AccordionIcon && /*#__PURE__*/React.createElement(Box, { pad: (_theme$accordion$icon = theme.accordion.icon) == null || (_theme$accordion$icon = _theme$accordion$icon.container) == null ? void 0 : _theme$accordion$icon.pad, width: { min: 'fit-content' } }, /*#__PURE__*/React.createElement(AccordionIcon, { color: iconColor })))), /*#__PURE__*/React.createElement(Box, { role: "region", border: contentBorder, "aria-labelledby": panelButtonId }, animate ? /*#__PURE__*/React.createElement(Collapsible, { open: active }, children) : active && children)); }); AccordionPanel.displayName = 'AccordionPanel'; AccordionPanel.propTypes = AccordionPanelPropTypes; export { AccordionPanel };