UNPKG

@procore/core-react

Version:
515 lines (510 loc) • 29.7 kB
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } var _excluded = ["gutterX"], _excluded2 = ["transparent"], _excluded3 = ["children"], _excluded4 = ["minSections"], _excluded5 = ["children", "open", "focusOnOpen", "restoreFocusOnClose"]; function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _regeneratorRuntime() { "use strict"; var r = _regenerator(), e = r.m(_regeneratorRuntime), t = (Object.getPrototypeOf ? Object.getPrototypeOf(e) : e.__proto__).constructor; function n(r) { var e = "function" == typeof r && r.constructor; return !!e && (e === t || "GeneratorFunction" === (e.displayName || e.name)); } var o = { "throw": 1, "return": 2, "break": 3, "continue": 3 }; function a(r) { var e, t; return function (n) { e || (e = { stop: function stop() { return t(n.a, 2); }, "catch": function _catch() { return n.v; }, abrupt: function abrupt(r, e) { return t(n.a, o[r], e); }, delegateYield: function delegateYield(r, o, a) { return e.resultName = o, t(n.d, _regeneratorValues(r), a); }, finish: function finish(r) { return t(n.f, r); } }, t = function t(r, _t, o) { n.p = e.prev, n.n = e.next; try { return r(_t, o); } finally { e.next = n.n; } }), e.resultName && (e[e.resultName] = n.v, e.resultName = void 0), e.sent = n.v, e.next = n.n; try { return r.call(this, e); } finally { n.p = e.prev, n.n = e.next; } }; } return (_regeneratorRuntime = function _regeneratorRuntime() { return { wrap: function wrap(e, t, n, o) { return r.w(a(e), t, n, o && o.reverse()); }, isGeneratorFunction: n, mark: r.m, awrap: function awrap(r, e) { return new _OverloadYield(r, e); }, AsyncIterator: _regeneratorAsyncIterator, async: function async(r, e, t, o, u) { return (n(e) ? _regeneratorAsyncGen : _regeneratorAsync)(a(r), e, t, o, u); }, keys: _regeneratorKeys, values: _regeneratorValues }; })(); } function _regeneratorValues(e) { if (null != e) { var t = e["function" == typeof Symbol && Symbol.iterator || "@@iterator"], r = 0; if (t) return t.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) return { next: function next() { return e && r >= e.length && (e = void 0), { value: e && e[r++], done: !e }; } }; } throw new TypeError(_typeof(e) + " is not iterable"); } function _regeneratorKeys(e) { var n = Object(e), r = []; for (var t in n) r.unshift(t); return function e() { for (; r.length;) if ((t = r.pop()) in n) return e.value = t, e.done = !1, e; return e.done = !0, e; }; } function _regeneratorAsync(n, e, r, t, o) { var a = _regeneratorAsyncGen(n, e, r, t, o); return a.next().then(function (n) { return n.done ? n.value : a.next(); }); } function _regeneratorAsyncGen(r, e, t, o, n) { return new _regeneratorAsyncIterator(_regenerator().w(r, e, t, o), n || Promise); } function _regeneratorAsyncIterator(t, e) { function n(r, o, i, f) { try { var c = t[r](o), u = c.value; return u instanceof _OverloadYield ? e.resolve(u.v).then(function (t) { n("next", t, i, f); }, function (t) { n("throw", t, i, f); }) : e.resolve(u).then(function (t) { c.value = t, i(c); }, function (t) { return n("throw", t, i, f); }); } catch (t) { f(t); } } var r; this.next || (_regeneratorDefine2(_regeneratorAsyncIterator.prototype), _regeneratorDefine2(_regeneratorAsyncIterator.prototype, "function" == typeof Symbol && Symbol.asyncIterator || "@asyncIterator", function () { return this; })), _regeneratorDefine2(this, "_invoke", function (t, o, i) { function f() { return new e(function (e, r) { n(t, i, e, r); }); } return r = r ? r.then(f, f) : f(); }, !0); } function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { if (r) i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n;else { var o = function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); }; o("next", 0), o("throw", 1), o("return", 2); } }, _regeneratorDefine2(e, r, n, t); } function _OverloadYield(e, d) { this.v = e, this.k = d; } function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } 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 _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; } 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 { FocusScope } from '@react-aria/focus'; import throttle from 'lodash.throttle'; import React from 'react'; import { AnchorNavigation } from '../AnchorNavigation/AnchorNavigation'; import { useAnchorNavigationContext } from '../AnchorNavigation/AnchorNavigationProvider'; import { Grid as BaseGrid } from '../Grid/Grid'; import { TearsheetContext } from '../Tearsheet/Tearsheet'; import { useResize } from '../_hooks/Resize'; import { useScroll } from '../_hooks/Scroll'; import { useUpdateEffect } from '../_hooks/useUpdateEffect'; import { addSubcomponents } from '../_utils/addSubcomponents'; import { mergeRefs } from '../_utils/mergeRefs'; import { pageLayoutRootDataAttr } from './PageLayout.constants'; import { animationDuration, StyledAside, StyledAsideFluidContainer, StyledAsidePanel, StyledBody, StyledContent, StyledFooter, StyledNavigation, StyledPageBanner, StyledPageBreadcrumbs, StyledPageContainer, StyledPageHeader, StyledPageMain, StyledPageTabs, StyledPageTitle } from './PageLayout.styles'; import { getBottomOffsetForFooterUseCase, getGlobalBottomOffset, getGlobalTopOffset, getIsIntersectingVertically, getRightOffset, wait } from './PageLayout.utils'; var defaultAsideIsOpen = false; export var PageContext = /*#__PURE__*/React.createContext({ bodyRef: /*#__PURE__*/React.createRef(), footerRef: /*#__PURE__*/React.createRef(), containerRef: /*#__PURE__*/React.createRef(), navigationRef: /*#__PURE__*/React.createRef(), aside: { open: function open() { return Promise.resolve(); }, close: function close() { return Promise.resolve(); }, isOpen: defaultAsideIsOpen } }); // for some reason this does not appear in the deprecated in typedoc generated json, but Page.Row does /** * @parent Page * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Grid`, `Page.Row`, `Page.Column` * * AFTER `Grid` `Grid.Row` `Grid.Col` * @deprecatedSince 12 */ export var Grid = function Grid(_ref) { var gutterX = _ref.gutterX, props = _objectWithoutProperties(_ref, _excluded); return /*#__PURE__*/React.createElement(BaseGrid, _extends({ gutterX: gutterX !== null && gutterX !== void 0 ? gutterX : 'lg' }, props)); }; /** * @parent Page * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Row` AFTER `Grid.Row` * @deprecatedSince 12 */ export var Row = BaseGrid.Row; /** * @parent Page * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Column` AFTER `Grid.Col` * @deprecatedSince 12 */ export var Column = BaseGrid.Col; var PageHeader = /*#__PURE__*/React.forwardRef(function PageHeader(_ref2, ref) { var transparent = _ref2.transparent, props = _objectWithoutProperties(_ref2, _excluded2); return /*#__PURE__*/React.createElement(StyledPageHeader, _extends({ $transparent: transparent }, props, { ref: ref })); }); var PageBody = /*#__PURE__*/React.forwardRef(function PageBody(_ref3, ref) { var children = _ref3.children, props = _objectWithoutProperties(_ref3, _excluded3); var _React$useContext = React.useContext(PageContext), bodyRef = _React$useContext.bodyRef; var navigation; var content = []; React.Children.forEach(children, function (child) { if (! /*#__PURE__*/React.isValidElement(child)) return; if (child.type === PageBodyNavigation) { navigation = child; } else { content.push(child); } }); if (!navigation) { return /*#__PURE__*/React.createElement(StyledBody, _extends({ children: children }, props, { ref: mergeRefs(ref, bodyRef) })); } return /*#__PURE__*/React.createElement(StyledBody, _extends({}, props, { ref: mergeRefs(ref, bodyRef) }), /*#__PURE__*/React.createElement(StyledNavigation, null, navigation), /*#__PURE__*/React.createElement(StyledContent, null, content)); }); export var PageBodyNavigation = /*#__PURE__*/React.forwardRef(function (_ref4, ref) { var _props$sections$lengt, _props$sections, _props$sections2, _props$selected, _props$onSelect; var _ref4$minSections = _ref4.minSections, minSections = _ref4$minSections === void 0 ? 2 : _ref4$minSections, props = _objectWithoutProperties(_ref4, _excluded4); var _React$useContext2 = React.useContext(PageContext), navigationRef = _React$useContext2.navigationRef; var _useAnchorNavigationC = useAnchorNavigationContext(), sections = _useAnchorNavigationC.sections, selected = _useAnchorNavigationC.selected, onSelect = _useAnchorNavigationC.onSelect; var sectionsLength = (_props$sections$lengt = (_props$sections = props.sections) === null || _props$sections === void 0 ? void 0 : _props$sections.length) !== null && _props$sections$lengt !== void 0 ? _props$sections$lengt : sections.length; if (sectionsLength < minSections) return null; return /*#__PURE__*/React.createElement(AnchorNavigation, _extends({ ref: mergeRefs(ref, navigationRef), sections: (_props$sections2 = props.sections) !== null && _props$sections2 !== void 0 ? _props$sections2 : sections, selected: (_props$selected = props.selected) !== null && _props$selected !== void 0 ? _props$selected : selected, onSelect: (_props$onSelect = props.onSelect) !== null && _props$onSelect !== void 0 ? _props$onSelect : onSelect }, props)); }); var PageFooter = /*#__PURE__*/React.forwardRef(function PageFooter(props, ref) { var _React$useContext3 = React.useContext(PageContext), bodyRef = _React$useContext3.bodyRef, footerRef = _React$useContext3.footerRef, aside = _React$useContext3.aside; var _React$useContext4 = React.useContext(TearsheetContext), addListener = _React$useContext4.addListener; var _React$useState = React.useState(false), _React$useState2 = _slicedToArray(_React$useState, 2), isIntersectingWithBody = _React$useState2[0], setIsIntersectingWithBody = _React$useState2[1]; function calculateIntersections() { if (!footerRef.current || !bodyRef.current) { return; } setIsIntersectingWithBody(getIsIntersectingVertically(bodyRef.current, footerRef.current)); } React.useEffect(function () { var _bodyRef$current; var tabWasPressed = false; var onActiveElementChange = function onActiveElementChange() { if (tabWasPressed && footerRef.current && document.activeElement && getIsIntersectingVertically(document.activeElement, footerRef.current)) { document.activeElement.scrollIntoView(); } }; var onKeyDown = function onKeyDown(e) { if (e.code === 'Tab') { tabWasPressed = true; // setTimeout is added to the end of async queue // after all already attached eventListeners // `tabWasPressed` marked as `false` after all events // which can be triggered by pressing Tab setTimeout(function () { tabWasPressed = false; }, 0); } }; (_bodyRef$current = bodyRef.current) === null || _bodyRef$current === void 0 ? void 0 : _bodyRef$current.addEventListener('focusin', onActiveElementChange); document.addEventListener('keydown', onKeyDown, true); return function () { var _bodyRef$current2; (_bodyRef$current2 = bodyRef.current) === null || _bodyRef$current2 === void 0 ? void 0 : _bodyRef$current2.removeEventListener('focusin', onActiveElementChange); document.removeEventListener('keydown', onKeyDown, true); }; }, []); React.useEffect(function () { return addListener('scroll', calculateIntersections); }, []); React.useEffect(calculateIntersections, []); useScroll({ onScroll: calculateIntersections }); useResize({ onResize: calculateIntersections }); return /*#__PURE__*/React.createElement(StyledFooter, _extends({}, props, { $isAsideOpen: aside.isOpen, $hasShadow: isIntersectingWithBody, "data-sticky": isIntersectingWithBody ? 'sticky' : '', ref: mergeRefs(ref, footerRef) })); }); var PageAside = /*#__PURE__*/React.forwardRef(function PageAside(_ref5, ref) { var _ref6; var children = _ref5.children, controlledIsOpen = _ref5.open, _ref5$focusOnOpen = _ref5.focusOnOpen, focusOnOpen = _ref5$focusOnOpen === void 0 ? false : _ref5$focusOnOpen, _ref5$restoreFocusOnC = _ref5.restoreFocusOnClose, restoreFocusOnClose = _ref5$restoreFocusOnC === void 0 ? false : _ref5$restoreFocusOnC, props = _objectWithoutProperties(_ref5, _excluded5); var _React$useContext5 = React.useContext(PageContext), _React$useContext5$as = _React$useContext5.aside, contextIsOpen = _React$useContext5$as.isOpen, open = _React$useContext5$as.open, close = _React$useContext5$as.close; var _React$useContext6 = React.useContext(TearsheetContext), tearsheetPlacement = _React$useContext6.placement, addTearsheetListener = _React$useContext6.addListener; var _React$useContext7 = React.useContext(PageContext), footerRef = _React$useContext7.footerRef, containerRef = _React$useContext7.containerRef; var innerRef = React.useRef(null); var panelRef = React.useRef(null); var prevIsOpenRef = React.useRef((_ref6 = controlledIsOpen !== null && controlledIsOpen !== void 0 ? controlledIsOpen : contextIsOpen) !== null && _ref6 !== void 0 ? _ref6 : false); var _React$useState3 = React.useState(null), _React$useState4 = _slicedToArray(_React$useState3, 2), topOffset = _React$useState4[0], setTopOffset = _React$useState4[1]; var _React$useState5 = React.useState(0), _React$useState6 = _slicedToArray(_React$useState5, 2), bottomOffset = _React$useState6[0], setBottomOffset = _React$useState6[1]; var _React$useState7 = React.useState(0), _React$useState8 = _slicedToArray(_React$useState7, 2), rightOffset = _React$useState8[0], setRightOffset = _React$useState8[1]; var initialIsOpen = controlledIsOpen !== null && controlledIsOpen !== void 0 ? controlledIsOpen : contextIsOpen; var _React$useState9 = React.useState(initialIsOpen ? 'open' : 'closed'), _React$useState0 = _slicedToArray(_React$useState9, 2), animationStatus = _React$useState0[0], setAnimationStatus = _React$useState0[1]; var _React$useState1 = React.useState(initialIsOpen), _React$useState10 = _slicedToArray(_React$useState1, 2), isOpen = _React$useState10[0], setIsOpen = _React$useState10[1]; var throttledToggle = React.useCallback(throttle(function (isOpen) { if (isOpen) { open(); } else { close(); } }, // wait just a little longer than the animation duration to avoid odd blinking animationDuration.panel + 100, { trailing: true }), []); React.useEffect(function () { throttledToggle(controlledIsOpen); }, [controlledIsOpen, throttledToggle]); React.useEffect(function () { setIsOpen(contextIsOpen); }, []); useUpdateEffect(function () { ; _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() { var wasOpen, isRealOpenTransition, _panelRef$current; return _regeneratorRuntime().wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: wasOpen = prevIsOpenRef.current; prevIsOpenRef.current = contextIsOpen; if (!contextIsOpen) { _context.next = 13; break; } isRealOpenTransition = !wasOpen; setIsOpen(true); // allow browsers to recalculate the layout _context.next = 7; return wait(0); case 7: setAnimationStatus('opening'); _context.next = 10; return wait(animationDuration.panel); case 10: setAnimationStatus('open'); if (focusOnOpen && isRealOpenTransition) { (_panelRef$current = panelRef.current) === null || _panelRef$current === void 0 ? void 0 : _panelRef$current.focus(); } return _context.abrupt("return"); case 13: setAnimationStatus('closing'); _context.next = 16; return wait(animationDuration.panel); case 16: setAnimationStatus('closed'); setIsOpen(false); case 18: case "end": return _context.stop(); } }, _callee); }))(); }, [contextIsOpen, focusOnOpen]); function calculateOffsets() { calculateHorizontalOffsets(); calculateVerticalOffsets(); } function calculateHorizontalOffsets() { if (!containerRef.current) { return; } setRightOffset(getRightOffset(containerRef.current)); } function calculateVerticalOffsets() { if (!innerRef.current || !containerRef.current) { return; } var globalTopOffset = getGlobalTopOffset(containerRef.current); setTopOffset(globalTopOffset); var globalBottomOffset = getGlobalBottomOffset(containerRef.current); setBottomOffset(globalBottomOffset); if (!footerRef.current) { return; } var bottomOffset = getBottomOffsetForFooterUseCase(footerRef.current, globalBottomOffset); if (bottomOffset !== null) { setBottomOffset(bottomOffset); } } useScroll({ onScroll: calculateOffsets }); useResize({ onResize: calculateOffsets }); React.useEffect(function () { if (tearsheetPlacement) { return addTearsheetListener('afterShow', calculateOffsets); } calculateOffsets(); }, []); useUpdateEffect(calculateOffsets, [contextIsOpen, animationStatus]); var asideOpen = ['open', 'opening'].includes(animationStatus); var asideClosed = ['closed', 'closing'].includes(animationStatus); return isOpen ? /*#__PURE__*/React.createElement(StyledAside, _extends({}, props, { $open: asideOpen, $closed: asideClosed, ref: mergeRefs(ref, innerRef, calculateOffsets) }), /*#__PURE__*/React.createElement(StyledAsideFluidContainer, { $open: asideOpen, $closed: asideClosed }, /*#__PURE__*/React.createElement(FocusScope, { restoreFocus: restoreFocusOnClose }, /*#__PURE__*/React.createElement(StyledAsidePanel, { ref: panelRef, tabIndex: -1, $offsetTop: topOffset, $rightOffset: rightOffset, $minusHeight: (topOffset !== null && topOffset !== void 0 ? topOffset : 0) + bottomOffset, $closing: animationStatus === 'closing', $opening: animationStatus === 'opening', $closed: animationStatus === 'closed', $altAnimation: tearsheetPlacement === 'left' }, children)))) : null; }); var PageContainer = /*#__PURE__*/React.forwardRef(function PageContainer(props, ref) { var _React$useState11 = React.useState(defaultAsideIsOpen), _React$useState12 = _slicedToArray(_React$useState11, 2), isAsideOpen = _React$useState12[0], setIsAsideOpen = _React$useState12[1]; var openAside = function openAside() { setIsAsideOpen(true); return wait(animationDuration.panel); }; var closeAside = function closeAside() { setIsAsideOpen(false); return wait(animationDuration.panel); }; var containerRef = React.useRef(null); var bodyRef = React.useRef(null); var navigationRef = React.useRef(null); var footerRef = React.useRef(null); return /*#__PURE__*/React.createElement(PageContext.Provider, { value: { bodyRef: bodyRef, footerRef: footerRef, containerRef: containerRef, navigationRef: navigationRef, aside: { open: openAside, close: closeAside, isOpen: isAsideOpen } } }, /*#__PURE__*/React.createElement(StyledPageContainer, _extends({ "data-core-react": "page" }, props, { ref: mergeRefs(ref, containerRef) }))); }); var PageMain = /*#__PURE__*/React.forwardRef(function PageMain(props, ref) { var _React$useContext8 = React.useContext(TearsheetContext), tearsheetPlacement = _React$useContext8.placement; var attrs = _defineProperty({}, pageLayoutRootDataAttr, true); return /*#__PURE__*/React.createElement(Grid, { gutterX: "lg" }, /*#__PURE__*/React.createElement(StyledPageMain, _extends({}, props, attrs, { ref: ref, $tearsheetPlacement: tearsheetPlacement }))); }); var PageBreadcrumbs = /*#__PURE__*/React.forwardRef(function PageBreadcrumbs(props, ref) { return /*#__PURE__*/React.createElement(StyledPageBreadcrumbs, _extends({ ref: ref }, props)); }); var PageBanner = /*#__PURE__*/React.forwardRef(function PageBanner(props, ref) { return /*#__PURE__*/React.createElement(StyledPageBanner, _extends({ ref: ref }, props)); }); var PageTitle = /*#__PURE__*/React.forwardRef(function PageTitle(props, ref) { return /*#__PURE__*/React.createElement(StyledPageTitle, _extends({ ref: ref }, props)); }); var PageTabs = /*#__PURE__*/React.forwardRef(function PageTabs(props, ref) { return /*#__PURE__*/React.createElement(StyledPageTabs, _extends({ ref: ref }, props)); }); Grid.displayName = 'Page.Grid'; PageHeader.displayName = 'Page.Header'; PageBanner.displayName = 'Page.Banner'; PageBreadcrumbs.displayName = 'Page.Breadcrumbs'; PageTitle.displayName = 'Page.Title'; PageTabs.displayName = 'Page.Tabs'; PageBody.displayName = 'Page.Body'; PageFooter.displayName = 'Page.Footer'; PageAside.displayName = 'Page.Aside'; PageContainer.displayName = 'Page'; PageMain.displayName = 'Page.Main'; /** Building block elements for layout that should be used to build a common skeleton of a page. - Page - Page.Main - Page.Header - Page.Breadcrumbs - Breadcrumbs - Page.Banner - Banner - Page.Title - Title or H1 - Page.Tabs - Tabs - Page.Body - Page.Footer - Page.Aside Other helpers, such as Page.Grid, Page.Row and Page.Column are thin wrappers over Grid components and share the same API. */ export var Page = addSubcomponents({ Header: PageHeader, Banner: PageBanner, Breadcrumbs: PageBreadcrumbs, Title: PageTitle, Tabs: PageTabs, Footer: PageFooter, Body: PageBody, Main: PageMain, Aside: PageAside, // Grid utilities /** * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Grid` AFTER `Grid` (or `Grid gutterX="lg"`) * @deprecatedSince 12 */ Grid: Grid, /** * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Column` AFTER `Grid.Col` * @deprecatedSince 12 */ Column: Column, /** * @deprecated A wrapper around Grid, please use Grid instead. Page already sets * a default gutterX in context for children grid components. * * BEFORE `Page.Row` AFTER `Grid.Row` * @deprecatedSince 12 */ Row: Row }, PageContainer); //# sourceMappingURL=PageLayout.js.map