UNPKG

grommet

Version:

focus on the essential experience

67 lines 3.71 kB
var _excluded = ["actions", "gridProps", "parent", "responsive", "size", "subtitle", "title", "level"]; 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; } 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); } import React, { forwardRef, useContext } from 'react'; import { Box } from '../Box'; import { Header } from '../Header'; import { Heading } from '../Heading'; import { Grid } from '../Grid'; import { Paragraph } from '../Paragraph'; import { ResponsiveContext } from '../../contexts/ResponsiveContext'; import { useThemeValue } from '../../utils/useThemeValue'; var sizeStyle = function sizeStyle(size, feature, theme, breakpoint) { var _ref, _theme$pageHeader$siz, _theme$global$breakpo, _theme$global$breakpo2; var style = _extends({}, theme.pageHeader[feature], (_ref = size && ((_theme$pageHeader$siz = theme.pageHeader.size[size]) == null ? void 0 : _theme$pageHeader$siz[feature])) != null ? _ref : theme.pageHeader[feature], (!size || size === 'medium') && feature === 'subtitle' && ((_theme$global$breakpo = theme.global.breakpoints[breakpoint]) == null ? void 0 : _theme$global$breakpo.value) <= ((_theme$global$breakpo2 = theme.global.breakpoints.small) == null ? void 0 : _theme$global$breakpo2.value) && { size: 'medium' }); return style; }; var PageHeader = /*#__PURE__*/forwardRef(function (_ref2, ref) { var actions = _ref2.actions, gridPropsProp = _ref2.gridProps, parent = _ref2.parent, responsive = _ref2.responsive, size = _ref2.size, subtitle = _ref2.subtitle, title = _ref2.title, level = _ref2.level, rest = _objectWithoutPropertiesLoose(_ref2, _excluded); var _useThemeValue = useThemeValue(), theme = _useThemeValue.theme; var breakpoint = useContext(ResponsiveContext); var actionsProps = _extends({}, theme.pageHeader.actions); var gridProps = theme.pageHeader[breakpoint] || theme.pageHeader.medium; if (responsive && theme.pageHeader.responsive.breakpoints.includes(breakpoint)) { gridProps = _extends({}, gridProps, theme.pageHeader.responsive); actionsProps = _extends({}, actionsProps, theme.pageHeader.responsive.actions); } var _gridProps = gridProps, areas = _gridProps.areas, columns = _gridProps.columns, gap = _gridProps.gap, rows = _gridProps.rows; return /*#__PURE__*/React.createElement(Header, _extends({ ref: ref, direction: "column", gap: "none", pad: sizeStyle(size, 'pad', theme) }, rest), /*#__PURE__*/React.createElement(Grid, _extends({ columns: columns, rows: rows, areas: areas, gap: gap, fill: "horizontal" }, gridPropsProp), /*#__PURE__*/React.createElement(Box, _extends({ gridArea: "parent" }, theme.pageHeader.parent), parent), /*#__PURE__*/React.createElement(Box, { gridArea: "title" }, typeof title === 'string' ? /*#__PURE__*/React.createElement(Heading, _extends({}, sizeStyle(size, 'title', theme), { level: level }), title) : title), /*#__PURE__*/React.createElement(Box, { gridArea: "subtitle" }, typeof subtitle === 'string' ? /*#__PURE__*/React.createElement(Paragraph, sizeStyle(size, 'subtitle', theme, breakpoint), subtitle) : subtitle), /*#__PURE__*/React.createElement(Box, _extends({ gridArea: "actions" }, actionsProps), actions))); }); PageHeader.displayName = 'PageHeader'; export { PageHeader };