@pingux/astro 2.51.0 → 2.52.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -31,17 +31,25 @@ var _excluded = ["defaultTheme", "themeOverrides", "children"],
31
31
  function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
32
32
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { _Object$defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
33
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
34
- var GlobalStyles = function GlobalStyles() {
34
+ var pingitoFont = "\n @font-face {\n font-weight: 200;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Light.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 400;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 600;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 700;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 900;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 200;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 400;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 600;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 700;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n size-adjust: 100%;\n }\n";
35
+ var GlobalStyles = function GlobalStyles(_ref2) {
36
+ var isEndUserTheme = _ref2.isEndUserTheme;
35
37
  return (0, _react2.jsx)(_react2.Global, {
36
- styles: /*#__PURE__*/(0, _react2.css)("@import url(\"https://use.typekit.net/icz8cni.css\");{}", _emotionNormalize["default"], " *{box-sizing:border-box;}html,body{padding:0;margin:0;background:white;min-height:100%;font-family:\"Helvetica Neue\",Helvetica,sans-serif;}.is-disabled{opacity:0.5;pointer-events:none;}[data-live-announcer]{display:none;}button:focus-visible,[type=\"button\"]:focus-visible,[type=\"reset\"]:focus-visible,[type=\"submit\"]:focus-visible{outline:0;}" + (process.env.NODE_ENV === "production" ? "" : ";label:GlobalStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZUyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Bc3Ryb1Byb3ZpZGVyL0FzdHJvUHJvdmlkZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcywgR2xvYmFsLCBUaGVtZVByb3ZpZGVyIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGVtb3Rpb25Ob3JtYWxpemUgZnJvbSAnZW1vdGlvbi1ub3JtYWxpemUnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IG1lcmdlIH0gZnJvbSAndGhlbWUtdWknO1xuXG5pbXBvcnQgYXN0cm9UaGVtZSBmcm9tICcuLi8uLi9zdHlsZXMvdGhlbWUnO1xuaW1wb3J0IEJveCBmcm9tICcuLi9Cb3gnO1xuXG5leHBvcnQgY29uc3QgR2xvYmFsU3R5bGVzID0gKCkgPT4gKFxuICA8R2xvYmFsXG4gICAgc3R5bGVzPXtcbiAgICAgIGNzc2BcbiAgICAgICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcbiAgICAgICAgJHtlbW90aW9uTm9ybWFsaXplfVxuICAgICAgICAqIHtcbiAgICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgICB9XG4gICAgICAgIGh0bWwsXG4gICAgICAgIGJvZHkge1xuICAgICAgICAgIHBhZGRpbmc6IDA7XG4gICAgICAgICAgbWFyZ2luOiAwO1xuICAgICAgICAgIGJhY2tncm91bmQ6IHdoaXRlO1xuICAgICAgICAgIG1pbi1oZWlnaHQ6IDEwMCU7XG4gICAgICAgICAgZm9udC1mYW1pbHk6IFwiSGVsdmV0aWNhIE5ldWVcIiwgSGVsdmV0aWNhLCBzYW5zLXNlcmlmO1xuICAgICAgICB9XG4gICAgICAgIC5pcy1kaXNhYmxlZCB7XG4gICAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB9XG4gICAgICAgIFtkYXRhLWxpdmUtYW5ub3VuY2VyXSB7XG4gICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBidXR0b246Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJidXR0b25cIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJyZXNldFwiXTpmb2N1cy12aXNpYmxlLFxuICAgICAgICBbdHlwZT1cInN1Ym1pdFwiXTpmb2N1cy12aXNpYmxlIHtcbiAgICAgICAgICBvdXRsaW5lOiAwO1xuICAgICAgICB9XG4gICAgICBgXG4gICAgfVxuICAvPlxuKTtcblxuLyoqXG4gKiBfTm90ZTogRm9yIFVJIExpYnJhcnkgYW5kIEFzdHJvIENTUyBjb25mbGljdHMsIHdlIHN1cHBseSBhIHRoZW1lIG92ZXJyaWRlIGxvY2F0ZWQgYXRfXG4gKiBgQHBpbmd1eC9hc3Ryby9saWIvc3R5bGVzL3RoZW1lT3ZlcnJpZGVzL3VpTGlicmFyeU92ZXJyaWRlLmpzYFxuICovXG5jb25zdCBBc3Ryb1Byb3ZpZGVyID0gZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xuICBjb25zdCB7XG4gICAgZGVmYXVsdFRoZW1lLFxuICAgIHRoZW1lT3ZlcnJpZGVzLFxuICAgIGNoaWxkcmVuLFxuICAgIC4uLm90aGVyc1xuICB9ID0gcHJvcHM7XG5cbiAgLy8gVW5mb3J0dW5hdGVseSBiZWNhdXNlIHRoaXMgaXMgYWRkaW5nIHN0eWxlcywgd2UgY2Fubm90IHdyaXRlIGEgcHJvcGVyIHRlc3QgZm9yIHRoaXMuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuXG4gIHJldHVybiAoXG4gICAgPFRoZW1lUHJvdmlkZXIgdGhlbWU9e3RoZW1lfSB7Li4ub3RoZXJzfT5cbiAgICAgIDxHbG9iYWxTdHlsZXMgLz5cbiAgICAgIDxCb3ggcmVmPXtyZWZ9IGJnPVwiYmFja2dyb3VuZFwiIGhlaWdodD1cIjEwMCVcIiB7Li4ucHJvcHN9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuQXN0cm9Qcm92aWRlci5wcm9wVHlwZXMgPSB7XG4gIC8qKiBBcnJheSBvZiB0aGVtZSBvYmplY3RzIHdoaWNoIHdpbGwgYmUgbWVyZ2VkIHdpdGggdGhlIGRlZmF1bHQgdGhlbWUuXG4gICAgICogSW4gdGhlIGNhc2Ugb2YgY2xhc2hlcywgdGhlc2Ugd2lsbCB0YWtlIHByaW9yaXR5LlxuICAgICAqIFVzZWZ1bCBmb3IgY3VzdG9taXppbmcgdGhlIGRlZmF1bHQgdmFyaWFudHMsIGFkZGluZyBuZXcgb25lcyxcbiAgICAgKiAgb3Igb3ZlcnJpZGluZyBvdGhlciB0aGVtZSB2YWx1ZXMuICovXG4gIHRoZW1lT3ZlcnJpZGVzOiBQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMuc2hhcGUoe30pKSxcbiAgLyoqIFRoZSBkZWZhdWx0IHRoZW1lIGFwcGxpZWQgdG8gdGhlIEFzdHJvIGNvbXBvbmVudHMuXG4gICAqIE92ZXJyaWRpbmcgdGhpcyBpcyBhbiBhZHZhbmNlZCB1c2UgY2FzZSBzb1xuICAgKiBwbGVhc2UgdW5kZXJzdGFuZCBwb3RlbnRpYWwgcmVwcmVjdXNzaW9ucyBiZWZvcmUgZWRpdGluZyAqL1xuICBkZWZhdWx0VGhlbWU6IFByb3BUeXBlcy5zaGFwZSh7fSksXG59O1xuXG5Bc3Ryb1Byb3ZpZGVyLmRlZmF1bHRQcm9wcyA9IHtcbiAgZGVmYXVsdFRoZW1lOiBhc3Ryb1RoZW1lLFxuICB0aGVtZU92ZXJyaWRlczogW3t9XSxcbn07XG5cbi8qKlxuICogV3JhcHBlciBmb3IgdGhlIEFzdHJvIGFwcGxpY2F0aW9uIHcvbyBnbG9iYWwgc3R5bGVzLlxuICogSXQgcHJvdmlkZXMgdGhlIHN0YW5kYXJkIGJhY2tncm91bmQgYW5kIHRoZSBBc3RybyB0aGVtZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBhZ2VXcmFwcGVyID0gZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xuICBjb25zdCB7XG4gICAgZGVmYXVsdFRoZW1lLFxuICAgIHRoZW1lT3ZlcnJpZGVzLFxuICAgIGNoaWxkcmVuLFxuICAgIC4uLm90aGVyc1xuICB9ID0gcHJvcHM7XG5cbiAgY29uc3QgdGhlbWUgPSB1c2VNZW1vKCgpID0+IG1lcmdlKGRlZmF1bHRUaGVtZSwgLi4udGhlbWVPdmVycmlkZXMpLFxuICAgIFtkZWZhdWx0VGhlbWUsIHRoZW1lT3ZlcnJpZGVzXSk7XG4gIHJldHVybiAoXG4gICAgPFRoZW1lUHJvdmlkZXIgcmVmPXtyZWZ9IHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsXG4gICAgICAgIHN0eWxlcz17XG4gIGNzc2BcbiAgICBAaW1wb3J0IHVybChcImh0dHBzOi8vdXNlLnR5cGVraXQubmV0L2ljejhjbmkuY3NzXCIpO1xuXG4gICAgW2RhdGEtdGlwcHktcm9vdF0ge1xuICAgICAgbWF4LXdpZHRoOiBjYWxjKDEwMHZ3IC0gMTBweCk7XG4gICAgfVxuICBgXG59XG4gICAgICAvPlxuICAgICAgPEJveFxuICAgICAgICBjc3M9e1xuICBjc3NgXG4gICAgJHtlbW90aW9uTm9ybWFsaXplfVxuXG4gICAgKiB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgZm9udC1mYW1pbHk6IFwiSGVsdmV0aWNhIE5ldWVcIiwgSGVsdmV0aWNhLCBzYW5zLXNlcmlmO1xuXG4gICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgfVxuICAgIH1cbiAgYFxufVxuICAgICAgICB7Li4ucHJvcHN9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvQm94PlxuICAgIDwvVGhlbWVQcm92aWRlcj5cbiAgKTtcbn0pO1xuXG5QYWdlV3JhcHBlci5wcm9wVHlwZXMgPSB7XG4gIC8qKiBBcnJheSBvZiB0aGVtZSBvYmplY3RzIHdoaWNoIHdpbGwgYmUgbWVyZ2VkIHdpdGggdGhlIGRlZmF1bHQgdGhlbWUuXG4gICAgICogSW4gdGhlIGNhc2Ugb2YgY2xhc2hlcywgdGhlc2Ugd2lsbCB0YWtlIHByaW9yaXR5LlxuICAgICAqIFVzZWZ1bCBmb3IgY3VzdG9taXppbmcgdGhlIGRlZmF1bHQgdmFyaWFudHMsIGFkZGluZyBuZXcgb25lcyxcbiAgICAgKiAgb3Igb3ZlcnJpZGluZyBvdGhlciB0aGVtZSB2YWx1ZXMuICovXG4gIHRoZW1lT3ZlcnJpZGVzOiBQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMuc2hhcGUoe30pKSxcbiAgLyoqIFRoZSBkZWZhdWx0IHRoZW1lIGFwcGxpZWQgdG8gdGhlIEFzdHJvIGNvbXBvbmVudHMuXG4gICAqIE92ZXJyaWRpbmcgdGhpcyBpcyBhbiBhZHZhbmNlZCB1c2UgY2FzZSBzb1xuICAgKiBwbGVhc2UgdW5kZXJzdGFuZCBwb3RlbnRpYWwgcmVwcmVjdXNzaW9ucyBiZWZvcmUgZWRpdGluZyAqL1xuICBkZWZhdWx0VGhlbWU6IFByb3BUeXBlcy5zaGFwZSh7fSksXG59O1xuXG5QYWdlV3JhcHBlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG5leHBvcnQgeyBUaGVtZVByb3ZpZGVyIH07XG5leHBvcnQgZGVmYXVsdCBBc3Ryb1Byb3ZpZGVyO1xuIl19 */")
38
+ styles: /*#__PURE__*/(0, _react2.css)("@import url(\"https://use.typekit.net/icz8cni.css\");{}", _emotionNormalize["default"], " ", isEndUserTheme && pingitoFont, " *{box-sizing:border-box;}html,body{padding:0;margin:0;background:white;min-height:100%;font-family:", isEndUserTheme && 'pingito, ', "\"Helvetica Neue\",Helvetica,sans-serif;}.is-disabled{opacity:0.5;pointer-events:none;}[data-live-announcer]{display:none;}button:focus-visible,[type=\"button\"]:focus-visible,[type=\"reset\"]:focus-visible,[type=\"submit\"]:focus-visible{outline:0;}" + (process.env.NODE_ENV === "production" ? "" : ";label:GlobalStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AAiFiB","file":"../../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */")
37
39
  });
38
40
  };
41
+ exports.GlobalStyles = GlobalStyles;
42
+ GlobalStyles.propTypes = {
43
+ isEndUserTheme: _propTypes["default"].bool
44
+ };
45
+ GlobalStyles.defaultProps = {
46
+ isEndUserTheme: false
47
+ };
39
48
 
40
49
  /**
41
50
  * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_
42
51
  * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`
43
52
  */
44
- exports.GlobalStyles = GlobalStyles;
45
53
  var AstroProvider = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
46
54
  var defaultTheme = props.defaultTheme,
47
55
  themeOverrides = props.themeOverrides,
@@ -54,9 +62,12 @@ var AstroProvider = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
54
62
  var _context;
55
63
  return _themeUi.merge.apply(void 0, (0, _concat["default"])(_context = [defaultTheme]).call(_context, themeOverrides));
56
64
  }, [defaultTheme, themeOverrides]);
65
+ var isEndUserTheme = theme && theme.name === 'End User';
57
66
  return (0, _react2.jsx)(_react2.ThemeProvider, (0, _extends2["default"])({
58
67
  theme: theme
59
- }, others), (0, _react2.jsx)(GlobalStyles, null), (0, _react2.jsx)(_Box["default"], (0, _extends2["default"])({
68
+ }, others), (0, _react2.jsx)(GlobalStyles, {
69
+ isEndUserTheme: isEndUserTheme
70
+ }), (0, _react2.jsx)(_Box["default"], (0, _extends2["default"])({
60
71
  ref: ref,
61
72
  bg: "background",
62
73
  height: "100%"
@@ -64,9 +75,9 @@ var AstroProvider = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
64
75
  });
65
76
  AstroProvider.propTypes = {
66
77
  /** Array of theme objects which will be merged with the default theme.
67
- * In the case of clashes, these will take priority.
68
- * Useful for customizing the default variants, adding new ones,
69
- * or overriding other theme values. */
78
+ * In the case of clashes, these will take priority.
79
+ * Useful for customizing the default variants, adding new ones,
80
+ * or overriding other theme values. */
70
81
  themeOverrides: _propTypes["default"].arrayOf(_propTypes["default"].shape({})),
71
82
  /** The default theme applied to the Astro components.
72
83
  * Overriding this is an advanced use case so
@@ -88,7 +99,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
88
99
  } : {
89
100
  name: "1385fa1-PageWrapper",
90
101
  styles: "@import url(\"https://use.typekit.net/icz8cni.css\");{}[data-tippy-root]{max-width:calc(100vw - 10px);};label:PageWrapper;",
91
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwR0siLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXN0cm9Qcm92aWRlci9Bc3Ryb1Byb3ZpZGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MsIEdsb2JhbCwgVGhlbWVQcm92aWRlciB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBlbW90aW9uTm9ybWFsaXplIGZyb20gJ2Vtb3Rpb24tbm9ybWFsaXplJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBtZXJnZSB9IGZyb20gJ3RoZW1lLXVpJztcblxuaW1wb3J0IGFzdHJvVGhlbWUgZnJvbSAnLi4vLi4vc3R5bGVzL3RoZW1lJztcbmltcG9ydCBCb3ggZnJvbSAnLi4vQm94JztcblxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IChcbiAgPEdsb2JhbFxuICAgIHN0eWxlcz17XG4gICAgICBjc3NgXG4gICAgICAgIEBpbXBvcnQgdXJsKFwiaHR0cHM6Ly91c2UudHlwZWtpdC5uZXQvaWN6OGNuaS5jc3NcIik7XG4gICAgICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cbiAgICAgICAgKiB7XG4gICAgICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgICAgfVxuICAgICAgICBodG1sLFxuICAgICAgICBib2R5IHtcbiAgICAgICAgICBwYWRkaW5nOiAwO1xuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiB3aGl0ZTtcbiAgICAgICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcbiAgICAgICAgfVxuICAgICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICAgIG9wYWNpdHk6IDAuNTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBbZGF0YS1saXZlLWFubm91bmNlcl0ge1xuICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICAgICAgYnV0dG9uOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwiYnV0dG9uXCJdOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwicmVzZXRcIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJzdWJtaXRcIl06Zm9jdXMtdmlzaWJsZSB7XG4gICAgICAgICAgb3V0bGluZTogMDtcbiAgICAgICAgfVxuICAgICAgYFxuICAgIH1cbiAgLz5cbik7XG5cbi8qKlxuICogX05vdGU6IEZvciBVSSBMaWJyYXJ5IGFuZCBBc3RybyBDU1MgY29uZmxpY3RzLCB3ZSBzdXBwbHkgYSB0aGVtZSBvdmVycmlkZSBsb2NhdGVkIGF0X1xuICogYEBwaW5ndXgvYXN0cm8vbGliL3N0eWxlcy90aGVtZU92ZXJyaWRlcy91aUxpYnJhcnlPdmVycmlkZS5qc2BcbiAqL1xuY29uc3QgQXN0cm9Qcm92aWRlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIC8vIFVuZm9ydHVuYXRlbHkgYmVjYXVzZSB0aGlzIGlzIGFkZGluZyBzdHlsZXMsIHdlIGNhbm5vdCB3cml0ZSBhIHByb3BlciB0ZXN0IGZvciB0aGlzLlxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdCB0aGVtZSA9IHVzZU1lbW8oKCkgPT4gbWVyZ2UoZGVmYXVsdFRoZW1lLCAuLi50aGVtZU92ZXJyaWRlcyksXG4gICAgW2RlZmF1bHRUaGVtZSwgdGhlbWVPdmVycmlkZXNdKTtcblxuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsU3R5bGVzIC8+XG4gICAgICA8Qm94IHJlZj17cmVmfSBiZz1cImJhY2tncm91bmRcIiBoZWlnaHQ9XCIxMDAlXCIgey4uLnByb3BzfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9Cb3g+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufSk7XG5cbkFzdHJvUHJvdmlkZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuQXN0cm9Qcm92aWRlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG4vKipcbiAqIFdyYXBwZXIgZm9yIHRoZSBBc3RybyBhcHBsaWNhdGlvbiB3L28gZ2xvYmFsIHN0eWxlcy5cbiAqIEl0IHByb3ZpZGVzIHRoZSBzdGFuZGFyZCBiYWNrZ3JvdW5kIGFuZCB0aGUgQXN0cm8gdGhlbWUuXG4gKi9cbmV4cG9ydCBjb25zdCBQYWdlV3JhcHBlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHJlZj17cmVmfSB0aGVtZT17dGhlbWV9IHsuLi5vdGhlcnN9PlxuICAgICAgPEdsb2JhbFxuICAgICAgICBzdHlsZXM9e1xuICBjc3NgXG4gICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcblxuICAgIFtkYXRhLXRpcHB5LXJvb3RdIHtcbiAgICAgIG1heC13aWR0aDogY2FsYygxMDB2dyAtIDEwcHgpO1xuICAgIH1cbiAgYFxufVxuICAgICAgLz5cbiAgICAgIDxCb3hcbiAgICAgICAgY3NzPXtcbiAgY3NzYFxuICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cblxuICAgICoge1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcblxuICAgICAgLmlzLWRpc2FibGVkIHtcbiAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbn1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuUGFnZVdyYXBwZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuUGFnZVdyYXBwZXIuZGVmYXVsdFByb3BzID0ge1xuICBkZWZhdWx0VGhlbWU6IGFzdHJvVGhlbWUsXG4gIHRoZW1lT3ZlcnJpZGVzOiBbe31dLFxufTtcblxuZXhwb3J0IHsgVGhlbWVQcm92aWRlciB9O1xuZXhwb3J0IGRlZmF1bHQgQXN0cm9Qcm92aWRlcjtcbiJdfQ== */",
102
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AAmLmB","file":"../../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */",
92
103
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
104
  };
94
105
  var PageWrapper = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
@@ -106,15 +117,15 @@ var PageWrapper = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
106
117
  }, others), (0, _react2.jsx)(_react2.Global, {
107
118
  styles: _ref
108
119
  }), (0, _react2.jsx)(_Box["default"], (0, _extends2["default"])({
109
- css: /*#__PURE__*/(0, _react2.css)(_emotionNormalize["default"], " *{box-sizing:border-box;font-family:\"Helvetica Neue\",Helvetica,sans-serif;.is-disabled{opacity:0.5;pointer-events:none;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:PageWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSEsiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXN0cm9Qcm92aWRlci9Bc3Ryb1Byb3ZpZGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MsIEdsb2JhbCwgVGhlbWVQcm92aWRlciB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBlbW90aW9uTm9ybWFsaXplIGZyb20gJ2Vtb3Rpb24tbm9ybWFsaXplJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBtZXJnZSB9IGZyb20gJ3RoZW1lLXVpJztcblxuaW1wb3J0IGFzdHJvVGhlbWUgZnJvbSAnLi4vLi4vc3R5bGVzL3RoZW1lJztcbmltcG9ydCBCb3ggZnJvbSAnLi4vQm94JztcblxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IChcbiAgPEdsb2JhbFxuICAgIHN0eWxlcz17XG4gICAgICBjc3NgXG4gICAgICAgIEBpbXBvcnQgdXJsKFwiaHR0cHM6Ly91c2UudHlwZWtpdC5uZXQvaWN6OGNuaS5jc3NcIik7XG4gICAgICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cbiAgICAgICAgKiB7XG4gICAgICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgICAgfVxuICAgICAgICBodG1sLFxuICAgICAgICBib2R5IHtcbiAgICAgICAgICBwYWRkaW5nOiAwO1xuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiB3aGl0ZTtcbiAgICAgICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcbiAgICAgICAgfVxuICAgICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICAgIG9wYWNpdHk6IDAuNTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBbZGF0YS1saXZlLWFubm91bmNlcl0ge1xuICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICAgICAgYnV0dG9uOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwiYnV0dG9uXCJdOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwicmVzZXRcIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJzdWJtaXRcIl06Zm9jdXMtdmlzaWJsZSB7XG4gICAgICAgICAgb3V0bGluZTogMDtcbiAgICAgICAgfVxuICAgICAgYFxuICAgIH1cbiAgLz5cbik7XG5cbi8qKlxuICogX05vdGU6IEZvciBVSSBMaWJyYXJ5IGFuZCBBc3RybyBDU1MgY29uZmxpY3RzLCB3ZSBzdXBwbHkgYSB0aGVtZSBvdmVycmlkZSBsb2NhdGVkIGF0X1xuICogYEBwaW5ndXgvYXN0cm8vbGliL3N0eWxlcy90aGVtZU92ZXJyaWRlcy91aUxpYnJhcnlPdmVycmlkZS5qc2BcbiAqL1xuY29uc3QgQXN0cm9Qcm92aWRlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIC8vIFVuZm9ydHVuYXRlbHkgYmVjYXVzZSB0aGlzIGlzIGFkZGluZyBzdHlsZXMsIHdlIGNhbm5vdCB3cml0ZSBhIHByb3BlciB0ZXN0IGZvciB0aGlzLlxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdCB0aGVtZSA9IHVzZU1lbW8oKCkgPT4gbWVyZ2UoZGVmYXVsdFRoZW1lLCAuLi50aGVtZU92ZXJyaWRlcyksXG4gICAgW2RlZmF1bHRUaGVtZSwgdGhlbWVPdmVycmlkZXNdKTtcblxuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsU3R5bGVzIC8+XG4gICAgICA8Qm94IHJlZj17cmVmfSBiZz1cImJhY2tncm91bmRcIiBoZWlnaHQ9XCIxMDAlXCIgey4uLnByb3BzfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9Cb3g+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufSk7XG5cbkFzdHJvUHJvdmlkZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuQXN0cm9Qcm92aWRlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG4vKipcbiAqIFdyYXBwZXIgZm9yIHRoZSBBc3RybyBhcHBsaWNhdGlvbiB3L28gZ2xvYmFsIHN0eWxlcy5cbiAqIEl0IHByb3ZpZGVzIHRoZSBzdGFuZGFyZCBiYWNrZ3JvdW5kIGFuZCB0aGUgQXN0cm8gdGhlbWUuXG4gKi9cbmV4cG9ydCBjb25zdCBQYWdlV3JhcHBlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHJlZj17cmVmfSB0aGVtZT17dGhlbWV9IHsuLi5vdGhlcnN9PlxuICAgICAgPEdsb2JhbFxuICAgICAgICBzdHlsZXM9e1xuICBjc3NgXG4gICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcblxuICAgIFtkYXRhLXRpcHB5LXJvb3RdIHtcbiAgICAgIG1heC13aWR0aDogY2FsYygxMDB2dyAtIDEwcHgpO1xuICAgIH1cbiAgYFxufVxuICAgICAgLz5cbiAgICAgIDxCb3hcbiAgICAgICAgY3NzPXtcbiAgY3NzYFxuICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cblxuICAgICoge1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcblxuICAgICAgLmlzLWRpc2FibGVkIHtcbiAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbn1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuUGFnZVdyYXBwZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuUGFnZVdyYXBwZXIuZGVmYXVsdFByb3BzID0ge1xuICBkZWZhdWx0VGhlbWU6IGFzdHJvVGhlbWUsXG4gIHRoZW1lT3ZlcnJpZGVzOiBbe31dLFxufTtcblxuZXhwb3J0IHsgVGhlbWVQcm92aWRlciB9O1xuZXhwb3J0IGRlZmF1bHQgQXN0cm9Qcm92aWRlcjtcbiJdfQ== */")
120
+ css: /*#__PURE__*/(0, _react2.css)(_emotionNormalize["default"], " *{box-sizing:border-box;font-family:\"Helvetica Neue\",Helvetica,sans-serif;.is-disabled{opacity:0.5;pointer-events:none;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:PageWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AA4LgB","file":"../../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */")
110
121
  }, props), children));
111
122
  });
112
123
  exports.PageWrapper = PageWrapper;
113
124
  PageWrapper.propTypes = {
114
125
  /** Array of theme objects which will be merged with the default theme.
115
- * In the case of clashes, these will take priority.
116
- * Useful for customizing the default variants, adding new ones,
117
- * or overriding other theme values. */
126
+ * In the case of clashes, these will take priority.
127
+ * Useful for customizing the default variants, adding new ones,
128
+ * or overriding other theme values. */
118
129
  themeOverrides: _propTypes["default"].arrayOf(_propTypes["default"].shape({})),
119
130
  /** The default theme applied to the Astro components.
120
131
  * Overriding this is an advanced use case so
@@ -14,12 +14,14 @@ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequ
14
14
  _Object$defineProperty(exports, "__esModule", {
15
15
  value: true
16
16
  });
17
- exports["default"] = exports.Required = exports.Indeterminate = exports.HelperText = exports.DefaultSelected = exports.Default = exports.Controlled = void 0;
17
+ exports["default"] = exports.Required = exports.Indeterminate = exports.HelperText = exports.ExpandableAndToggleableIndeterminate = exports.DefaultSelected = exports.Default = exports.Controlled = void 0;
18
18
  var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
19
19
  var _every = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/every"));
20
20
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
21
21
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
22
22
  var _react = _interopRequireWildcard(require("react"));
23
+ var _MenuDownIcon = _interopRequireDefault(require("@pingux/mdi-react/MenuDownIcon"));
24
+ var _MenuRightIcon = _interopRequireDefault(require("@pingux/mdi-react/MenuRightIcon"));
23
25
  var _storybookDocsLayout = _interopRequireDefault(require("../../../.storybook/storybookDocsLayout"));
24
26
  var _index = require("../../index");
25
27
  var _ariaAttributes = require("../../utils/docUtils/ariaAttributes");
@@ -121,19 +123,139 @@ var HelperText = function HelperText() {
121
123
  });
122
124
  };
123
125
  exports.HelperText = HelperText;
126
+ var ExpandableAndToggleableIndeterminate = function ExpandableAndToggleableIndeterminate() {
127
+ var _useState = (0, _react.useState)(false),
128
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
129
+ isReadOnly = _useState2[0],
130
+ setIsReadOnly = _useState2[1];
131
+ var _useState3 = (0, _react.useState)(true),
132
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
133
+ isExpanded = _useState4[0],
134
+ setIsExpanded = _useState4[1];
135
+ // Whether the parent checkbox is indeterminate (default is true for our example)
136
+ var _useState5 = (0, _react.useState)(true),
137
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
138
+ isIndeterminate = _useState6[0],
139
+ setIsIndeterminate = _useState6[1];
140
+ // Whether the parent checkbox should be checked, this is set independently from indeterminism
141
+ var _useState7 = (0, _react.useState)(false),
142
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
143
+ isCompleted = _useState8[0],
144
+ setIsCompleted = _useState8[1];
145
+ // The state of the sub-checkboxes
146
+ var _useState9 = (0, _react.useState)([{
147
+ label: 'Apple Chunks',
148
+ isSelected: true
149
+ }, {
150
+ label: 'Blueberries',
151
+ isSelected: false
152
+ }, {
153
+ label: 'Grapes',
154
+ isSelected: false
155
+ }, {
156
+ label: 'Strawberry Slices',
157
+ isSelected: true
158
+ }]),
159
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
160
+ subCheckboxes = _useState10[0],
161
+ setSubCheckboxes = _useState10[1];
162
+
163
+ // Determine which checkbox needs its state updated
164
+ var handleSubCheckboxChange = function handleSubCheckboxChange(isSelected, changedIndex) {
165
+ var changeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
166
+ var newSubCheckboxes = (0, _map["default"])(subCheckboxes).call(subCheckboxes, function (checkbox, index) {
167
+ if (changeAll || index === changedIndex) return _objectSpread(_objectSpread({}, checkbox), {}, {
168
+ isSelected: isSelected
169
+ });
170
+ return checkbox;
171
+ });
172
+ setSubCheckboxes(newSubCheckboxes);
173
+ };
174
+
175
+ // Update all sub-checkbox states when the parent checkbox is pressed
176
+ var handleParentCheckboxChange = function handleParentCheckboxChange(isSelected) {
177
+ handleSubCheckboxChange(isSelected, null, true);
178
+ };
179
+ (0, _react.useEffect)(function () {
180
+ // Determine if all sub-checkboxes are selected / unselected or if there is a mix
181
+ // and update the parent checkbox
182
+ if ((0, _every["default"])(subCheckboxes).call(subCheckboxes, function (item) {
183
+ return item.isSelected;
184
+ })) {
185
+ setIsIndeterminate(false);
186
+ setIsCompleted(true);
187
+ } else if ((0, _every["default"])(subCheckboxes).call(subCheckboxes, function (item) {
188
+ return !item.isSelected;
189
+ })) {
190
+ setIsIndeterminate(false);
191
+ setIsCompleted(false);
192
+ } else {
193
+ setIsIndeterminate(true);
194
+ setIsCompleted(false);
195
+ }
196
+ }, [isIndeterminate, subCheckboxes]);
197
+ return (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)(_index.SwitchField, {
198
+ isSelected: isReadOnly,
199
+ label: "Is Read Only",
200
+ onChange: setIsReadOnly,
201
+ value: "my-switch"
202
+ }), (0, _react2.jsx)("br", null), (0, _react2.jsx)(_index.Box, {
203
+ isRow: true,
204
+ alignItems: "center"
205
+ }, (0, _react2.jsx)(_index.IconButtonToggle, {
206
+ toggledIcon: _MenuDownIcon["default"],
207
+ defaultIcon: _MenuRightIcon["default"],
208
+ onToggle: setIsExpanded,
209
+ isToggled: isExpanded,
210
+ buttonProps: {
211
+ 'aria-label': isExpanded ? 'menu down' : 'menu up',
212
+ 'aria-controls': 'expanded-checkboxes',
213
+ 'aria-expanded': isExpanded
214
+ },
215
+ iconProps: {
216
+ size: 'sm'
217
+ }
218
+ }), isReadOnly ? (0, _react2.jsx)(_index.Text, null, "Fruit Salad Recipe") : (0, _react2.jsx)(_index.CheckboxField, {
219
+ label: "Fruit Salad Recipe",
220
+ isIndeterminate: isIndeterminate,
221
+ isSelected: isCompleted,
222
+ onChange: handleParentCheckboxChange
223
+ }), (0, _react2.jsx)(_index.Box, null, (0, _react2.jsx)(_index.Badge, {
224
+ ml: "sm",
225
+ label: subCheckboxes.length,
226
+ variant: "countNeutral"
227
+ }))), (0, _react2.jsx)(_index.Box, {
228
+ ml: "50px",
229
+ id: "expanded-checkboxes"
230
+ }, isExpanded && (0, _map["default"])(subCheckboxes).call(subCheckboxes, function (checkbox, index) {
231
+ return (0, _react2.jsx)(_index.Box, {
232
+ isRow: true,
233
+ alignItems: "center",
234
+ height: "24px"
235
+ }, isReadOnly ? (0, _react2.jsx)(_index.Text, null, checkbox.label) : (0, _react2.jsx)(_index.CheckboxField, {
236
+ key: checkbox.label,
237
+ label: checkbox.label,
238
+ isSelected: checkbox.isSelected,
239
+ onChange: function onChange(isSelected) {
240
+ return handleSubCheckboxChange(isSelected, index);
241
+ }
242
+ }));
243
+ })));
244
+ };
245
+ exports.ExpandableAndToggleableIndeterminate = ExpandableAndToggleableIndeterminate;
124
246
  var Indeterminate = function Indeterminate() {
125
247
  // Whether the parent checkbox is indeterminate (default is true for our example)
126
- var _useState = (0, _react.useState)(true),
127
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
128
- isIndeterminate = _useState2[0],
129
- setIsIndeterminate = _useState2[1];
248
+ var _useState11 = (0, _react.useState)(true),
249
+ _useState12 = (0, _slicedToArray2["default"])(_useState11, 2),
250
+ isIndeterminate = _useState12[0],
251
+ setIsIndeterminate = _useState12[1];
130
252
  // Whether the parent checkbox should be checked, this is set independently from indeterminism
131
- var _useState3 = (0, _react.useState)(false),
132
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
133
- isCompleted = _useState4[0],
134
- setIsCompleted = _useState4[1];
253
+ var _useState13 = (0, _react.useState)(false),
254
+ _useState14 = (0, _slicedToArray2["default"])(_useState13, 2),
255
+ isCompleted = _useState14[0],
256
+ setIsCompleted = _useState14[1];
135
257
  // The state of the sub-checkboxes
136
- var _useState5 = (0, _react.useState)([{
258
+ var _useState15 = (0, _react.useState)([{
137
259
  label: 'Apple Chunks',
138
260
  isSelected: true
139
261
  }, {
@@ -146,9 +268,9 @@ var Indeterminate = function Indeterminate() {
146
268
  label: 'Strawberry Slices',
147
269
  isSelected: true
148
270
  }]),
149
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
150
- subCheckboxes = _useState6[0],
151
- setSubCheckboxes = _useState6[1];
271
+ _useState16 = (0, _slicedToArray2["default"])(_useState15, 2),
272
+ subCheckboxes = _useState16[0],
273
+ setSubCheckboxes = _useState16[1];
152
274
 
153
275
  // Determine which checkbox needs its state updated
154
276
  var handleSubCheckboxChange = function handleSubCheckboxChange(isSelected, changedIndex) {
@@ -12,11 +12,19 @@ import { merge } from 'theme-ui';
12
12
  import astroTheme from '../../styles/theme';
13
13
  import Box from '../Box';
14
14
  import { jsx as ___EmotionJSX } from "@emotion/react";
15
- export var GlobalStyles = function GlobalStyles() {
15
+ var pingitoFont = "\n @font-face {\n font-weight: 200;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Light.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 400;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 600;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 700;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 900;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 200;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 400;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 600;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n size-adjust: 100%;\n }\n\n @font-face {\n font-weight: 700;\n font-style: italic;\n font-family: \"pingito\";\n src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n size-adjust: 100%;\n }\n";
16
+ export var GlobalStyles = function GlobalStyles(_ref2) {
17
+ var isEndUserTheme = _ref2.isEndUserTheme;
16
18
  return ___EmotionJSX(Global, {
17
- styles: /*#__PURE__*/css("@import url(\"https://use.typekit.net/icz8cni.css\");{}", emotionNormalize, " *{box-sizing:border-box;}html,body{padding:0;margin:0;background:white;min-height:100%;font-family:\"Helvetica Neue\",Helvetica,sans-serif;}.is-disabled{opacity:0.5;pointer-events:none;}[data-live-announcer]{display:none;}button:focus-visible,[type=\"button\"]:focus-visible,[type=\"reset\"]:focus-visible,[type=\"submit\"]:focus-visible{outline:0;}" + (process.env.NODE_ENV === "production" ? "" : ";label:GlobalStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZUyIsImZpbGUiOiIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Bc3Ryb1Byb3ZpZGVyL0FzdHJvUHJvdmlkZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcywgR2xvYmFsLCBUaGVtZVByb3ZpZGVyIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGVtb3Rpb25Ob3JtYWxpemUgZnJvbSAnZW1vdGlvbi1ub3JtYWxpemUnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IG1lcmdlIH0gZnJvbSAndGhlbWUtdWknO1xuXG5pbXBvcnQgYXN0cm9UaGVtZSBmcm9tICcuLi8uLi9zdHlsZXMvdGhlbWUnO1xuaW1wb3J0IEJveCBmcm9tICcuLi9Cb3gnO1xuXG5leHBvcnQgY29uc3QgR2xvYmFsU3R5bGVzID0gKCkgPT4gKFxuICA8R2xvYmFsXG4gICAgc3R5bGVzPXtcbiAgICAgIGNzc2BcbiAgICAgICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcbiAgICAgICAgJHtlbW90aW9uTm9ybWFsaXplfVxuICAgICAgICAqIHtcbiAgICAgICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgICB9XG4gICAgICAgIGh0bWwsXG4gICAgICAgIGJvZHkge1xuICAgICAgICAgIHBhZGRpbmc6IDA7XG4gICAgICAgICAgbWFyZ2luOiAwO1xuICAgICAgICAgIGJhY2tncm91bmQ6IHdoaXRlO1xuICAgICAgICAgIG1pbi1oZWlnaHQ6IDEwMCU7XG4gICAgICAgICAgZm9udC1mYW1pbHk6IFwiSGVsdmV0aWNhIE5ldWVcIiwgSGVsdmV0aWNhLCBzYW5zLXNlcmlmO1xuICAgICAgICB9XG4gICAgICAgIC5pcy1kaXNhYmxlZCB7XG4gICAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB9XG4gICAgICAgIFtkYXRhLWxpdmUtYW5ub3VuY2VyXSB7XG4gICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBidXR0b246Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJidXR0b25cIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJyZXNldFwiXTpmb2N1cy12aXNpYmxlLFxuICAgICAgICBbdHlwZT1cInN1Ym1pdFwiXTpmb2N1cy12aXNpYmxlIHtcbiAgICAgICAgICBvdXRsaW5lOiAwO1xuICAgICAgICB9XG4gICAgICBgXG4gICAgfVxuICAvPlxuKTtcblxuLyoqXG4gKiBfTm90ZTogRm9yIFVJIExpYnJhcnkgYW5kIEFzdHJvIENTUyBjb25mbGljdHMsIHdlIHN1cHBseSBhIHRoZW1lIG92ZXJyaWRlIGxvY2F0ZWQgYXRfXG4gKiBgQHBpbmd1eC9hc3Ryby9saWIvc3R5bGVzL3RoZW1lT3ZlcnJpZGVzL3VpTGlicmFyeU92ZXJyaWRlLmpzYFxuICovXG5jb25zdCBBc3Ryb1Byb3ZpZGVyID0gZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xuICBjb25zdCB7XG4gICAgZGVmYXVsdFRoZW1lLFxuICAgIHRoZW1lT3ZlcnJpZGVzLFxuICAgIGNoaWxkcmVuLFxuICAgIC4uLm90aGVyc1xuICB9ID0gcHJvcHM7XG5cbiAgLy8gVW5mb3J0dW5hdGVseSBiZWNhdXNlIHRoaXMgaXMgYWRkaW5nIHN0eWxlcywgd2UgY2Fubm90IHdyaXRlIGEgcHJvcGVyIHRlc3QgZm9yIHRoaXMuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuXG4gIHJldHVybiAoXG4gICAgPFRoZW1lUHJvdmlkZXIgdGhlbWU9e3RoZW1lfSB7Li4ub3RoZXJzfT5cbiAgICAgIDxHbG9iYWxTdHlsZXMgLz5cbiAgICAgIDxCb3ggcmVmPXtyZWZ9IGJnPVwiYmFja2dyb3VuZFwiIGhlaWdodD1cIjEwMCVcIiB7Li4ucHJvcHN9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuQXN0cm9Qcm92aWRlci5wcm9wVHlwZXMgPSB7XG4gIC8qKiBBcnJheSBvZiB0aGVtZSBvYmplY3RzIHdoaWNoIHdpbGwgYmUgbWVyZ2VkIHdpdGggdGhlIGRlZmF1bHQgdGhlbWUuXG4gICAgICogSW4gdGhlIGNhc2Ugb2YgY2xhc2hlcywgdGhlc2Ugd2lsbCB0YWtlIHByaW9yaXR5LlxuICAgICAqIFVzZWZ1bCBmb3IgY3VzdG9taXppbmcgdGhlIGRlZmF1bHQgdmFyaWFudHMsIGFkZGluZyBuZXcgb25lcyxcbiAgICAgKiAgb3Igb3ZlcnJpZGluZyBvdGhlciB0aGVtZSB2YWx1ZXMuICovXG4gIHRoZW1lT3ZlcnJpZGVzOiBQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMuc2hhcGUoe30pKSxcbiAgLyoqIFRoZSBkZWZhdWx0IHRoZW1lIGFwcGxpZWQgdG8gdGhlIEFzdHJvIGNvbXBvbmVudHMuXG4gICAqIE92ZXJyaWRpbmcgdGhpcyBpcyBhbiBhZHZhbmNlZCB1c2UgY2FzZSBzb1xuICAgKiBwbGVhc2UgdW5kZXJzdGFuZCBwb3RlbnRpYWwgcmVwcmVjdXNzaW9ucyBiZWZvcmUgZWRpdGluZyAqL1xuICBkZWZhdWx0VGhlbWU6IFByb3BUeXBlcy5zaGFwZSh7fSksXG59O1xuXG5Bc3Ryb1Byb3ZpZGVyLmRlZmF1bHRQcm9wcyA9IHtcbiAgZGVmYXVsdFRoZW1lOiBhc3Ryb1RoZW1lLFxuICB0aGVtZU92ZXJyaWRlczogW3t9XSxcbn07XG5cbi8qKlxuICogV3JhcHBlciBmb3IgdGhlIEFzdHJvIGFwcGxpY2F0aW9uIHcvbyBnbG9iYWwgc3R5bGVzLlxuICogSXQgcHJvdmlkZXMgdGhlIHN0YW5kYXJkIGJhY2tncm91bmQgYW5kIHRoZSBBc3RybyB0aGVtZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBhZ2VXcmFwcGVyID0gZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xuICBjb25zdCB7XG4gICAgZGVmYXVsdFRoZW1lLFxuICAgIHRoZW1lT3ZlcnJpZGVzLFxuICAgIGNoaWxkcmVuLFxuICAgIC4uLm90aGVyc1xuICB9ID0gcHJvcHM7XG5cbiAgY29uc3QgdGhlbWUgPSB1c2VNZW1vKCgpID0+IG1lcmdlKGRlZmF1bHRUaGVtZSwgLi4udGhlbWVPdmVycmlkZXMpLFxuICAgIFtkZWZhdWx0VGhlbWUsIHRoZW1lT3ZlcnJpZGVzXSk7XG4gIHJldHVybiAoXG4gICAgPFRoZW1lUHJvdmlkZXIgcmVmPXtyZWZ9IHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsXG4gICAgICAgIHN0eWxlcz17XG4gIGNzc2BcbiAgICBAaW1wb3J0IHVybChcImh0dHBzOi8vdXNlLnR5cGVraXQubmV0L2ljejhjbmkuY3NzXCIpO1xuXG4gICAgW2RhdGEtdGlwcHktcm9vdF0ge1xuICAgICAgbWF4LXdpZHRoOiBjYWxjKDEwMHZ3IC0gMTBweCk7XG4gICAgfVxuICBgXG59XG4gICAgICAvPlxuICAgICAgPEJveFxuICAgICAgICBjc3M9e1xuICBjc3NgXG4gICAgJHtlbW90aW9uTm9ybWFsaXplfVxuXG4gICAgKiB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgICAgZm9udC1mYW1pbHk6IFwiSGVsdmV0aWNhIE5ldWVcIiwgSGVsdmV0aWNhLCBzYW5zLXNlcmlmO1xuXG4gICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgfVxuICAgIH1cbiAgYFxufVxuICAgICAgICB7Li4ucHJvcHN9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvQm94PlxuICAgIDwvVGhlbWVQcm92aWRlcj5cbiAgKTtcbn0pO1xuXG5QYWdlV3JhcHBlci5wcm9wVHlwZXMgPSB7XG4gIC8qKiBBcnJheSBvZiB0aGVtZSBvYmplY3RzIHdoaWNoIHdpbGwgYmUgbWVyZ2VkIHdpdGggdGhlIGRlZmF1bHQgdGhlbWUuXG4gICAgICogSW4gdGhlIGNhc2Ugb2YgY2xhc2hlcywgdGhlc2Ugd2lsbCB0YWtlIHByaW9yaXR5LlxuICAgICAqIFVzZWZ1bCBmb3IgY3VzdG9taXppbmcgdGhlIGRlZmF1bHQgdmFyaWFudHMsIGFkZGluZyBuZXcgb25lcyxcbiAgICAgKiAgb3Igb3ZlcnJpZGluZyBvdGhlciB0aGVtZSB2YWx1ZXMuICovXG4gIHRoZW1lT3ZlcnJpZGVzOiBQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMuc2hhcGUoe30pKSxcbiAgLyoqIFRoZSBkZWZhdWx0IHRoZW1lIGFwcGxpZWQgdG8gdGhlIEFzdHJvIGNvbXBvbmVudHMuXG4gICAqIE92ZXJyaWRpbmcgdGhpcyBpcyBhbiBhZHZhbmNlZCB1c2UgY2FzZSBzb1xuICAgKiBwbGVhc2UgdW5kZXJzdGFuZCBwb3RlbnRpYWwgcmVwcmVjdXNzaW9ucyBiZWZvcmUgZWRpdGluZyAqL1xuICBkZWZhdWx0VGhlbWU6IFByb3BUeXBlcy5zaGFwZSh7fSksXG59O1xuXG5QYWdlV3JhcHBlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG5leHBvcnQgeyBUaGVtZVByb3ZpZGVyIH07XG5leHBvcnQgZGVmYXVsdCBBc3Ryb1Byb3ZpZGVyO1xuIl19 */")
19
+ styles: /*#__PURE__*/css("@import url(\"https://use.typekit.net/icz8cni.css\");{}", emotionNormalize, " ", isEndUserTheme && pingitoFont, " *{box-sizing:border-box;}html,body{padding:0;margin:0;background:white;min-height:100%;font-family:", isEndUserTheme && 'pingito, ', "\"Helvetica Neue\",Helvetica,sans-serif;}.is-disabled{opacity:0.5;pointer-events:none;}[data-live-announcer]{display:none;}button:focus-visible,[type=\"button\"]:focus-visible,[type=\"reset\"]:focus-visible,[type=\"submit\"]:focus-visible{outline:0;}" + (process.env.NODE_ENV === "production" ? "" : ";label:GlobalStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AAiFiB","file":"../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */")
18
20
  });
19
21
  };
22
+ GlobalStyles.propTypes = {
23
+ isEndUserTheme: PropTypes.bool
24
+ };
25
+ GlobalStyles.defaultProps = {
26
+ isEndUserTheme: false
27
+ };
20
28
 
21
29
  /**
22
30
  * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_
@@ -34,9 +42,12 @@ var AstroProvider = /*#__PURE__*/forwardRef(function (props, ref) {
34
42
  var _context;
35
43
  return merge.apply(void 0, _concatInstanceProperty(_context = [defaultTheme]).call(_context, themeOverrides));
36
44
  }, [defaultTheme, themeOverrides]);
45
+ var isEndUserTheme = theme && theme.name === 'End User';
37
46
  return ___EmotionJSX(ThemeProvider, _extends({
38
47
  theme: theme
39
- }, others), ___EmotionJSX(GlobalStyles, null), ___EmotionJSX(Box, _extends({
48
+ }, others), ___EmotionJSX(GlobalStyles, {
49
+ isEndUserTheme: isEndUserTheme
50
+ }), ___EmotionJSX(Box, _extends({
40
51
  ref: ref,
41
52
  bg: "background",
42
53
  height: "100%"
@@ -44,9 +55,9 @@ var AstroProvider = /*#__PURE__*/forwardRef(function (props, ref) {
44
55
  });
45
56
  AstroProvider.propTypes = {
46
57
  /** Array of theme objects which will be merged with the default theme.
47
- * In the case of clashes, these will take priority.
48
- * Useful for customizing the default variants, adding new ones,
49
- * or overriding other theme values. */
58
+ * In the case of clashes, these will take priority.
59
+ * Useful for customizing the default variants, adding new ones,
60
+ * or overriding other theme values. */
50
61
  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),
51
62
  /** The default theme applied to the Astro components.
52
63
  * Overriding this is an advanced use case so
@@ -68,7 +79,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
68
79
  } : {
69
80
  name: "1385fa1-PageWrapper",
70
81
  styles: "@import url(\"https://use.typekit.net/icz8cni.css\");{}[data-tippy-root]{max-width:calc(100vw - 10px);};label:PageWrapper;",
71
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwR0siLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXN0cm9Qcm92aWRlci9Bc3Ryb1Byb3ZpZGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MsIEdsb2JhbCwgVGhlbWVQcm92aWRlciB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBlbW90aW9uTm9ybWFsaXplIGZyb20gJ2Vtb3Rpb24tbm9ybWFsaXplJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBtZXJnZSB9IGZyb20gJ3RoZW1lLXVpJztcblxuaW1wb3J0IGFzdHJvVGhlbWUgZnJvbSAnLi4vLi4vc3R5bGVzL3RoZW1lJztcbmltcG9ydCBCb3ggZnJvbSAnLi4vQm94JztcblxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IChcbiAgPEdsb2JhbFxuICAgIHN0eWxlcz17XG4gICAgICBjc3NgXG4gICAgICAgIEBpbXBvcnQgdXJsKFwiaHR0cHM6Ly91c2UudHlwZWtpdC5uZXQvaWN6OGNuaS5jc3NcIik7XG4gICAgICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cbiAgICAgICAgKiB7XG4gICAgICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgICAgfVxuICAgICAgICBodG1sLFxuICAgICAgICBib2R5IHtcbiAgICAgICAgICBwYWRkaW5nOiAwO1xuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiB3aGl0ZTtcbiAgICAgICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcbiAgICAgICAgfVxuICAgICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICAgIG9wYWNpdHk6IDAuNTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBbZGF0YS1saXZlLWFubm91bmNlcl0ge1xuICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICAgICAgYnV0dG9uOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwiYnV0dG9uXCJdOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwicmVzZXRcIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJzdWJtaXRcIl06Zm9jdXMtdmlzaWJsZSB7XG4gICAgICAgICAgb3V0bGluZTogMDtcbiAgICAgICAgfVxuICAgICAgYFxuICAgIH1cbiAgLz5cbik7XG5cbi8qKlxuICogX05vdGU6IEZvciBVSSBMaWJyYXJ5IGFuZCBBc3RybyBDU1MgY29uZmxpY3RzLCB3ZSBzdXBwbHkgYSB0aGVtZSBvdmVycmlkZSBsb2NhdGVkIGF0X1xuICogYEBwaW5ndXgvYXN0cm8vbGliL3N0eWxlcy90aGVtZU92ZXJyaWRlcy91aUxpYnJhcnlPdmVycmlkZS5qc2BcbiAqL1xuY29uc3QgQXN0cm9Qcm92aWRlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIC8vIFVuZm9ydHVuYXRlbHkgYmVjYXVzZSB0aGlzIGlzIGFkZGluZyBzdHlsZXMsIHdlIGNhbm5vdCB3cml0ZSBhIHByb3BlciB0ZXN0IGZvciB0aGlzLlxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdCB0aGVtZSA9IHVzZU1lbW8oKCkgPT4gbWVyZ2UoZGVmYXVsdFRoZW1lLCAuLi50aGVtZU92ZXJyaWRlcyksXG4gICAgW2RlZmF1bHRUaGVtZSwgdGhlbWVPdmVycmlkZXNdKTtcblxuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsU3R5bGVzIC8+XG4gICAgICA8Qm94IHJlZj17cmVmfSBiZz1cImJhY2tncm91bmRcIiBoZWlnaHQ9XCIxMDAlXCIgey4uLnByb3BzfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9Cb3g+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufSk7XG5cbkFzdHJvUHJvdmlkZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuQXN0cm9Qcm92aWRlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG4vKipcbiAqIFdyYXBwZXIgZm9yIHRoZSBBc3RybyBhcHBsaWNhdGlvbiB3L28gZ2xvYmFsIHN0eWxlcy5cbiAqIEl0IHByb3ZpZGVzIHRoZSBzdGFuZGFyZCBiYWNrZ3JvdW5kIGFuZCB0aGUgQXN0cm8gdGhlbWUuXG4gKi9cbmV4cG9ydCBjb25zdCBQYWdlV3JhcHBlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHJlZj17cmVmfSB0aGVtZT17dGhlbWV9IHsuLi5vdGhlcnN9PlxuICAgICAgPEdsb2JhbFxuICAgICAgICBzdHlsZXM9e1xuICBjc3NgXG4gICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcblxuICAgIFtkYXRhLXRpcHB5LXJvb3RdIHtcbiAgICAgIG1heC13aWR0aDogY2FsYygxMDB2dyAtIDEwcHgpO1xuICAgIH1cbiAgYFxufVxuICAgICAgLz5cbiAgICAgIDxCb3hcbiAgICAgICAgY3NzPXtcbiAgY3NzYFxuICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cblxuICAgICoge1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcblxuICAgICAgLmlzLWRpc2FibGVkIHtcbiAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbn1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuUGFnZVdyYXBwZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuUGFnZVdyYXBwZXIuZGVmYXVsdFByb3BzID0ge1xuICBkZWZhdWx0VGhlbWU6IGFzdHJvVGhlbWUsXG4gIHRoZW1lT3ZlcnJpZGVzOiBbe31dLFxufTtcblxuZXhwb3J0IHsgVGhlbWVQcm92aWRlciB9O1xuZXhwb3J0IGRlZmF1bHQgQXN0cm9Qcm92aWRlcjtcbiJdfQ== */",
82
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AAmLmB","file":"../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */",
72
83
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
73
84
  };
74
85
  export var PageWrapper = /*#__PURE__*/forwardRef(function (props, ref) {
@@ -86,14 +97,14 @@ export var PageWrapper = /*#__PURE__*/forwardRef(function (props, ref) {
86
97
  }, others), ___EmotionJSX(Global, {
87
98
  styles: _ref
88
99
  }), ___EmotionJSX(Box, _extends({
89
- css: /*#__PURE__*/css(emotionNormalize, " *{box-sizing:border-box;font-family:\"Helvetica Neue\",Helvetica,sans-serif;.is-disabled{opacity:0.5;pointer-events:none;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:PageWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FzdHJvUHJvdmlkZXIvQXN0cm9Qcm92aWRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSEsiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXN0cm9Qcm92aWRlci9Bc3Ryb1Byb3ZpZGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MsIEdsb2JhbCwgVGhlbWVQcm92aWRlciB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBlbW90aW9uTm9ybWFsaXplIGZyb20gJ2Vtb3Rpb24tbm9ybWFsaXplJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBtZXJnZSB9IGZyb20gJ3RoZW1lLXVpJztcblxuaW1wb3J0IGFzdHJvVGhlbWUgZnJvbSAnLi4vLi4vc3R5bGVzL3RoZW1lJztcbmltcG9ydCBCb3ggZnJvbSAnLi4vQm94JztcblxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IChcbiAgPEdsb2JhbFxuICAgIHN0eWxlcz17XG4gICAgICBjc3NgXG4gICAgICAgIEBpbXBvcnQgdXJsKFwiaHR0cHM6Ly91c2UudHlwZWtpdC5uZXQvaWN6OGNuaS5jc3NcIik7XG4gICAgICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cbiAgICAgICAgKiB7XG4gICAgICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgICAgfVxuICAgICAgICBodG1sLFxuICAgICAgICBib2R5IHtcbiAgICAgICAgICBwYWRkaW5nOiAwO1xuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgICBiYWNrZ3JvdW5kOiB3aGl0ZTtcbiAgICAgICAgICBtaW4taGVpZ2h0OiAxMDAlO1xuICAgICAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcbiAgICAgICAgfVxuICAgICAgICAuaXMtZGlzYWJsZWQge1xuICAgICAgICAgIG9wYWNpdHk6IDAuNTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgfVxuICAgICAgICBbZGF0YS1saXZlLWFubm91bmNlcl0ge1xuICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICAgICAgYnV0dG9uOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwiYnV0dG9uXCJdOmZvY3VzLXZpc2libGUsXG4gICAgICAgIFt0eXBlPVwicmVzZXRcIl06Zm9jdXMtdmlzaWJsZSxcbiAgICAgICAgW3R5cGU9XCJzdWJtaXRcIl06Zm9jdXMtdmlzaWJsZSB7XG4gICAgICAgICAgb3V0bGluZTogMDtcbiAgICAgICAgfVxuICAgICAgYFxuICAgIH1cbiAgLz5cbik7XG5cbi8qKlxuICogX05vdGU6IEZvciBVSSBMaWJyYXJ5IGFuZCBBc3RybyBDU1MgY29uZmxpY3RzLCB3ZSBzdXBwbHkgYSB0aGVtZSBvdmVycmlkZSBsb2NhdGVkIGF0X1xuICogYEBwaW5ndXgvYXN0cm8vbGliL3N0eWxlcy90aGVtZU92ZXJyaWRlcy91aUxpYnJhcnlPdmVycmlkZS5qc2BcbiAqL1xuY29uc3QgQXN0cm9Qcm92aWRlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIC8vIFVuZm9ydHVuYXRlbHkgYmVjYXVzZSB0aGlzIGlzIGFkZGluZyBzdHlsZXMsIHdlIGNhbm5vdCB3cml0ZSBhIHByb3BlciB0ZXN0IGZvciB0aGlzLlxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBjb25zdCB0aGVtZSA9IHVzZU1lbW8oKCkgPT4gbWVyZ2UoZGVmYXVsdFRoZW1lLCAuLi50aGVtZU92ZXJyaWRlcyksXG4gICAgW2RlZmF1bHRUaGVtZSwgdGhlbWVPdmVycmlkZXNdKTtcblxuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHRoZW1lPXt0aGVtZX0gey4uLm90aGVyc30+XG4gICAgICA8R2xvYmFsU3R5bGVzIC8+XG4gICAgICA8Qm94IHJlZj17cmVmfSBiZz1cImJhY2tncm91bmRcIiBoZWlnaHQ9XCIxMDAlXCIgey4uLnByb3BzfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9Cb3g+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufSk7XG5cbkFzdHJvUHJvdmlkZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuQXN0cm9Qcm92aWRlci5kZWZhdWx0UHJvcHMgPSB7XG4gIGRlZmF1bHRUaGVtZTogYXN0cm9UaGVtZSxcbiAgdGhlbWVPdmVycmlkZXM6IFt7fV0sXG59O1xuXG4vKipcbiAqIFdyYXBwZXIgZm9yIHRoZSBBc3RybyBhcHBsaWNhdGlvbiB3L28gZ2xvYmFsIHN0eWxlcy5cbiAqIEl0IHByb3ZpZGVzIHRoZSBzdGFuZGFyZCBiYWNrZ3JvdW5kIGFuZCB0aGUgQXN0cm8gdGhlbWUuXG4gKi9cbmV4cG9ydCBjb25zdCBQYWdlV3JhcHBlciA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3Qge1xuICAgIGRlZmF1bHRUaGVtZSxcbiAgICB0aGVtZU92ZXJyaWRlcyxcbiAgICBjaGlsZHJlbixcbiAgICAuLi5vdGhlcnNcbiAgfSA9IHByb3BzO1xuXG4gIGNvbnN0IHRoZW1lID0gdXNlTWVtbygoKSA9PiBtZXJnZShkZWZhdWx0VGhlbWUsIC4uLnRoZW1lT3ZlcnJpZGVzKSxcbiAgICBbZGVmYXVsdFRoZW1lLCB0aGVtZU92ZXJyaWRlc10pO1xuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHJlZj17cmVmfSB0aGVtZT17dGhlbWV9IHsuLi5vdGhlcnN9PlxuICAgICAgPEdsb2JhbFxuICAgICAgICBzdHlsZXM9e1xuICBjc3NgXG4gICAgQGltcG9ydCB1cmwoXCJodHRwczovL3VzZS50eXBla2l0Lm5ldC9pY3o4Y25pLmNzc1wiKTtcblxuICAgIFtkYXRhLXRpcHB5LXJvb3RdIHtcbiAgICAgIG1heC13aWR0aDogY2FsYygxMDB2dyAtIDEwcHgpO1xuICAgIH1cbiAgYFxufVxuICAgICAgLz5cbiAgICAgIDxCb3hcbiAgICAgICAgY3NzPXtcbiAgY3NzYFxuICAgICR7ZW1vdGlvbk5vcm1hbGl6ZX1cblxuICAgICoge1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICAgIGZvbnQtZmFtaWx5OiBcIkhlbHZldGljYSBOZXVlXCIsIEhlbHZldGljYSwgc2Fucy1zZXJpZjtcblxuICAgICAgLmlzLWRpc2FibGVkIHtcbiAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgIH1cbiAgICB9XG4gIGBcbn1cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L0JveD5cbiAgICA8L1RoZW1lUHJvdmlkZXI+XG4gICk7XG59KTtcblxuUGFnZVdyYXBwZXIucHJvcFR5cGVzID0ge1xuICAvKiogQXJyYXkgb2YgdGhlbWUgb2JqZWN0cyB3aGljaCB3aWxsIGJlIG1lcmdlZCB3aXRoIHRoZSBkZWZhdWx0IHRoZW1lLlxuICAgICAqIEluIHRoZSBjYXNlIG9mIGNsYXNoZXMsIHRoZXNlIHdpbGwgdGFrZSBwcmlvcml0eS5cbiAgICAgKiBVc2VmdWwgZm9yIGN1c3RvbWl6aW5nIHRoZSBkZWZhdWx0IHZhcmlhbnRzLCBhZGRpbmcgbmV3IG9uZXMsXG4gICAgICogIG9yIG92ZXJyaWRpbmcgb3RoZXIgdGhlbWUgdmFsdWVzLiAqL1xuICB0aGVtZU92ZXJyaWRlczogUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLnNoYXBlKHt9KSksXG4gIC8qKiBUaGUgZGVmYXVsdCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBBc3RybyBjb21wb25lbnRzLlxuICAgKiBPdmVycmlkaW5nIHRoaXMgaXMgYW4gYWR2YW5jZWQgdXNlIGNhc2Ugc29cbiAgICogcGxlYXNlIHVuZGVyc3RhbmQgcG90ZW50aWFsIHJlcHJlY3Vzc2lvbnMgYmVmb3JlIGVkaXRpbmcgKi9cbiAgZGVmYXVsdFRoZW1lOiBQcm9wVHlwZXMuc2hhcGUoe30pLFxufTtcblxuUGFnZVdyYXBwZXIuZGVmYXVsdFByb3BzID0ge1xuICBkZWZhdWx0VGhlbWU6IGFzdHJvVGhlbWUsXG4gIHRoZW1lT3ZlcnJpZGVzOiBbe31dLFxufTtcblxuZXhwb3J0IHsgVGhlbWVQcm92aWRlciB9O1xuZXhwb3J0IGRlZmF1bHQgQXN0cm9Qcm92aWRlcjtcbiJdfQ== */")
100
+ css: /*#__PURE__*/css(emotionNormalize, " *{box-sizing:border-box;font-family:\"Helvetica Neue\",Helvetica,sans-serif;.is-disabled{opacity:0.5;pointer-events:none;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:PageWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/AstroProvider/AstroProvider.js"],"names":[],"mappings":"AA4LgB","file":"../../../src/components/AstroProvider/AstroProvider.js","sourcesContent":["import React, { forwardRef, useMemo } from 'react';\nimport { css, Global, ThemeProvider } from '@emotion/react';\nimport emotionNormalize from 'emotion-normalize';\nimport PropTypes from 'prop-types';\nimport { merge } from 'theme-ui';\n\nimport astroTheme from '../../styles/theme';\nimport Box from '../Box';\n\nconst pingitoFont = `\n  @font-face {\n    font-weight: 200;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Light.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Regular.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-SemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Bold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 900;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ExtraBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 200;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicLight.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 400;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-Italic.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 600;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicSemiBold.ttf\");\n    size-adjust: 100%;\n  }\n\n  @font-face {\n    font-weight: 700;\n    font-style: italic;\n    font-family: \"pingito\";\n    src: url(\"fonts/pingito/Pingito-ItalicBold.ttf\");\n    size-adjust: 100%;\n  }\n`;\n\nexport const GlobalStyles = ({ isEndUserTheme }) => {\n  return (\n    <Global\n      styles={css`\n        @import url(\"https://use.typekit.net/icz8cni.css\");\n        ${emotionNormalize}\n        ${isEndUserTheme && pingitoFont}\n        * {\n          box-sizing: border-box;\n        }\n        html,\n        body {\n          padding: 0;\n          margin: 0;\n          background: white;\n          min-height: 100%;\n          font-family: ${isEndUserTheme && 'pingito, '}\"Helvetica Neue\", Helvetica, sans-serif;\n        }\n        .is-disabled {\n          opacity: 0.5;\n          pointer-events: none;\n        }\n        [data-live-announcer] {\n          display: none;\n        }\n        button:focus-visible,\n        [type=\"button\"]:focus-visible,\n        [type=\"reset\"]:focus-visible,\n        [type=\"submit\"]:focus-visible {\n          outline: 0;\n        }\n      `}\n    />\n  );\n};\n\nGlobalStyles.propTypes = {\n  isEndUserTheme: PropTypes.bool,\n};\n\nGlobalStyles.defaultProps = {\n  isEndUserTheme: false,\n};\n\n/**\n * _Note: For UI Library and Astro CSS conflicts, we supply a theme override located at_\n * `@pingux/astro/lib/styles/themeOverrides/uiLibraryOverride.js`\n */\nconst AstroProvider = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  // Unfortunately because this is adding styles, we cannot write a proper test for this.\n  /* istanbul ignore next */\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n  const isEndUserTheme = theme && theme.name === 'End User';\n\n  return (\n    <ThemeProvider theme={theme} {...others}>\n      <GlobalStyles isEndUserTheme={isEndUserTheme} />\n      <Box ref={ref} bg=\"background\" height=\"100%\" {...props}>\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nAstroProvider.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nAstroProvider.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\n/**\n * Wrapper for the Astro application w/o global styles.\n * It provides the standard background and the Astro theme.\n */\nexport const PageWrapper = forwardRef((props, ref) => {\n  const { defaultTheme, themeOverrides, children, ...others } = props;\n\n  const theme = useMemo(\n    () => merge(defaultTheme, ...themeOverrides),\n    [defaultTheme, themeOverrides],\n  );\n\n  return (\n    <ThemeProvider ref={ref} theme={theme} {...others}>\n      <Global\n        styles={css`\n          @import url(\"https://use.typekit.net/icz8cni.css\");\n\n          [data-tippy-root] {\n            max-width: calc(100vw - 10px);\n          }\n        `}\n      />\n      <Box\n        css={css`\n          ${emotionNormalize}\n\n          * {\n            box-sizing: border-box;\n            font-family: \"Helvetica Neue\", Helvetica, sans-serif;\n\n            .is-disabled {\n              opacity: 0.5;\n              pointer-events: none;\n            }\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </Box>\n    </ThemeProvider>\n  );\n});\n\nPageWrapper.propTypes = {\n  /** Array of theme objects which will be merged with the default theme.\n   * In the case of clashes, these will take priority.\n   * Useful for customizing the default variants, adding new ones,\n   *  or overriding other theme values. */\n  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),\n  /** The default theme applied to the Astro components.\n   * Overriding this is an advanced use case so\n   * please understand potential reprecussions before editing */\n  defaultTheme: PropTypes.shape({}),\n};\n\nPageWrapper.defaultProps = {\n  defaultTheme: astroTheme,\n  themeOverrides: [{}],\n};\n\nexport { ThemeProvider };\nexport default AstroProvider;\n"]} */")
90
101
  }, props), children));
91
102
  });
92
103
  PageWrapper.propTypes = {
93
104
  /** Array of theme objects which will be merged with the default theme.
94
- * In the case of clashes, these will take priority.
95
- * Useful for customizing the default variants, adding new ones,
96
- * or overriding other theme values. */
105
+ * In the case of clashes, these will take priority.
106
+ * Useful for customizing the default variants, adding new ones,
107
+ * or overriding other theme values. */
97
108
  themeOverrides: PropTypes.arrayOf(PropTypes.shape({})),
98
109
  /** The default theme applied to the Astro components.
99
110
  * Overriding this is an advanced use case so
@@ -13,8 +13,10 @@ import _everyInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instan
13
13
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
14
14
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
15
15
  import React, { useEffect, useState } from 'react';
16
+ import MenuDown from '@pingux/mdi-react/MenuDownIcon';
17
+ import MenuRight from '@pingux/mdi-react/MenuRightIcon';
16
18
  import DocsLayout from '../../../.storybook/storybookDocsLayout';
17
- import { Box, CheckboxField, Link, Text } from '../../index';
19
+ import { Badge, Box, CheckboxField, IconButtonToggle, Link, SwitchField, Text } from '../../index';
18
20
  import { ariaAttributeBaseArgTypes } from '../../utils/docUtils/ariaAttributes';
19
21
  import { inputFieldAttributeBaseArgTypes } from '../../utils/docUtils/fieldAttributes';
20
22
  import { statusArgTypes } from '../../utils/docUtils/statusProp';
@@ -104,19 +106,138 @@ export var HelperText = function HelperText() {
104
106
  label: "Click me"
105
107
  });
106
108
  };
109
+ export var ExpandableAndToggleableIndeterminate = function ExpandableAndToggleableIndeterminate() {
110
+ var _useState = useState(false),
111
+ _useState2 = _slicedToArray(_useState, 2),
112
+ isReadOnly = _useState2[0],
113
+ setIsReadOnly = _useState2[1];
114
+ var _useState3 = useState(true),
115
+ _useState4 = _slicedToArray(_useState3, 2),
116
+ isExpanded = _useState4[0],
117
+ setIsExpanded = _useState4[1];
118
+ // Whether the parent checkbox is indeterminate (default is true for our example)
119
+ var _useState5 = useState(true),
120
+ _useState6 = _slicedToArray(_useState5, 2),
121
+ isIndeterminate = _useState6[0],
122
+ setIsIndeterminate = _useState6[1];
123
+ // Whether the parent checkbox should be checked, this is set independently from indeterminism
124
+ var _useState7 = useState(false),
125
+ _useState8 = _slicedToArray(_useState7, 2),
126
+ isCompleted = _useState8[0],
127
+ setIsCompleted = _useState8[1];
128
+ // The state of the sub-checkboxes
129
+ var _useState9 = useState([{
130
+ label: 'Apple Chunks',
131
+ isSelected: true
132
+ }, {
133
+ label: 'Blueberries',
134
+ isSelected: false
135
+ }, {
136
+ label: 'Grapes',
137
+ isSelected: false
138
+ }, {
139
+ label: 'Strawberry Slices',
140
+ isSelected: true
141
+ }]),
142
+ _useState10 = _slicedToArray(_useState9, 2),
143
+ subCheckboxes = _useState10[0],
144
+ setSubCheckboxes = _useState10[1];
145
+
146
+ // Determine which checkbox needs its state updated
147
+ var handleSubCheckboxChange = function handleSubCheckboxChange(isSelected, changedIndex) {
148
+ var changeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
149
+ var newSubCheckboxes = _mapInstanceProperty(subCheckboxes).call(subCheckboxes, function (checkbox, index) {
150
+ if (changeAll || index === changedIndex) return _objectSpread(_objectSpread({}, checkbox), {}, {
151
+ isSelected: isSelected
152
+ });
153
+ return checkbox;
154
+ });
155
+ setSubCheckboxes(newSubCheckboxes);
156
+ };
157
+
158
+ // Update all sub-checkbox states when the parent checkbox is pressed
159
+ var handleParentCheckboxChange = function handleParentCheckboxChange(isSelected) {
160
+ handleSubCheckboxChange(isSelected, null, true);
161
+ };
162
+ useEffect(function () {
163
+ // Determine if all sub-checkboxes are selected / unselected or if there is a mix
164
+ // and update the parent checkbox
165
+ if (_everyInstanceProperty(subCheckboxes).call(subCheckboxes, function (item) {
166
+ return item.isSelected;
167
+ })) {
168
+ setIsIndeterminate(false);
169
+ setIsCompleted(true);
170
+ } else if (_everyInstanceProperty(subCheckboxes).call(subCheckboxes, function (item) {
171
+ return !item.isSelected;
172
+ })) {
173
+ setIsIndeterminate(false);
174
+ setIsCompleted(false);
175
+ } else {
176
+ setIsIndeterminate(true);
177
+ setIsCompleted(false);
178
+ }
179
+ }, [isIndeterminate, subCheckboxes]);
180
+ return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SwitchField, {
181
+ isSelected: isReadOnly,
182
+ label: "Is Read Only",
183
+ onChange: setIsReadOnly,
184
+ value: "my-switch"
185
+ }), ___EmotionJSX("br", null), ___EmotionJSX(Box, {
186
+ isRow: true,
187
+ alignItems: "center"
188
+ }, ___EmotionJSX(IconButtonToggle, {
189
+ toggledIcon: MenuDown,
190
+ defaultIcon: MenuRight,
191
+ onToggle: setIsExpanded,
192
+ isToggled: isExpanded,
193
+ buttonProps: {
194
+ 'aria-label': isExpanded ? 'menu down' : 'menu up',
195
+ 'aria-controls': 'expanded-checkboxes',
196
+ 'aria-expanded': isExpanded
197
+ },
198
+ iconProps: {
199
+ size: 'sm'
200
+ }
201
+ }), isReadOnly ? ___EmotionJSX(Text, null, "Fruit Salad Recipe") : ___EmotionJSX(CheckboxField, {
202
+ label: "Fruit Salad Recipe",
203
+ isIndeterminate: isIndeterminate,
204
+ isSelected: isCompleted,
205
+ onChange: handleParentCheckboxChange
206
+ }), ___EmotionJSX(Box, null, ___EmotionJSX(Badge, {
207
+ ml: "sm",
208
+ label: subCheckboxes.length,
209
+ variant: "countNeutral"
210
+ }))), ___EmotionJSX(Box, {
211
+ ml: "50px",
212
+ id: "expanded-checkboxes"
213
+ }, isExpanded && _mapInstanceProperty(subCheckboxes).call(subCheckboxes, function (checkbox, index) {
214
+ return ___EmotionJSX(Box, {
215
+ isRow: true,
216
+ alignItems: "center",
217
+ height: "24px"
218
+ }, isReadOnly ? ___EmotionJSX(Text, null, checkbox.label) : ___EmotionJSX(CheckboxField, {
219
+ key: checkbox.label,
220
+ label: checkbox.label,
221
+ isSelected: checkbox.isSelected,
222
+ onChange: function onChange(isSelected) {
223
+ return handleSubCheckboxChange(isSelected, index);
224
+ }
225
+ }));
226
+ })));
227
+ };
107
228
  export var Indeterminate = function Indeterminate() {
108
229
  // Whether the parent checkbox is indeterminate (default is true for our example)
109
- var _useState = useState(true),
110
- _useState2 = _slicedToArray(_useState, 2),
111
- isIndeterminate = _useState2[0],
112
- setIsIndeterminate = _useState2[1];
230
+ var _useState11 = useState(true),
231
+ _useState12 = _slicedToArray(_useState11, 2),
232
+ isIndeterminate = _useState12[0],
233
+ setIsIndeterminate = _useState12[1];
113
234
  // Whether the parent checkbox should be checked, this is set independently from indeterminism
114
- var _useState3 = useState(false),
115
- _useState4 = _slicedToArray(_useState3, 2),
116
- isCompleted = _useState4[0],
117
- setIsCompleted = _useState4[1];
235
+ var _useState13 = useState(false),
236
+ _useState14 = _slicedToArray(_useState13, 2),
237
+ isCompleted = _useState14[0],
238
+ setIsCompleted = _useState14[1];
118
239
  // The state of the sub-checkboxes
119
- var _useState5 = useState([{
240
+ var _useState15 = useState([{
120
241
  label: 'Apple Chunks',
121
242
  isSelected: true
122
243
  }, {
@@ -129,9 +250,9 @@ export var Indeterminate = function Indeterminate() {
129
250
  label: 'Strawberry Slices',
130
251
  isSelected: true
131
252
  }]),
132
- _useState6 = _slicedToArray(_useState5, 2),
133
- subCheckboxes = _useState6[0],
134
- setSubCheckboxes = _useState6[1];
253
+ _useState16 = _slicedToArray(_useState15, 2),
254
+ subCheckboxes = _useState16[0],
255
+ setSubCheckboxes = _useState16[1];
135
256
 
136
257
  // Determine which checkbox needs its state updated
137
258
  var handleSubCheckboxChange = function handleSubCheckboxChange(isSelected, changedIndex) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pingux/astro",
3
- "version": "2.51.0",
3
+ "version": "2.52.0-alpha.1",
4
4
  "description": "React component library for Ping Identity's design system",
5
5
  "repository": {
6
6
  "type": "git",