(our hidden element)\n // react-dom in dev mode will warn about this. There doesn't seem to be a way to render arbitrary\n // user Head without hitting this issue (our hidden element could be just \"new Document()\", but\n // this can only have 1 child, and we don't control what is being rendered so that's not an option)\n // instead we continue to render to
, and just silence warnings for and elements\n // https://github.com/facebook/react/blob/e2424f33b3ad727321fc12e75c5e94838e84c2b5/packages/react-dom-bindings/src/client/validateDOMNesting.js#L498-L520\n const originalConsoleError = console.error.bind(console)\n console.error = (...args) => {\n if (\n Array.isArray(args) &&\n args.length >= 2 &&\n args[0]?.includes?.(`validateDOMNesting(...): %s cannot appear as`) &&\n (args[1] === `` || args[1] === ``)\n ) {\n return undefined\n }\n return originalConsoleError(...args)\n }\n\n /* We set up observer to be able to regenerate after react-refresh\n updates our hidden element.\n */\n const observer = new MutationObserver(onHeadRendered)\n observer.observe(hiddenRoot, {\n attributes: true,\n childList: true,\n characterData: true,\n subtree: true,\n })\n}\n\nexport function headHandlerForBrowser({\n pageComponent,\n staticQueryResults,\n pageComponentProps,\n}) {\n useEffect(() => {\n if (pageComponent?.Head) {\n headExportValidator(pageComponent.Head)\n\n const { render } = reactDOMUtils()\n\n const HeadElement = (\n
\n )\n\n const WrapHeadElement = apiRunner(\n `wrapRootElement`,\n { element: HeadElement },\n HeadElement,\n ({ result }) => {\n return { element: result }\n }\n ).pop()\n\n render(\n // just a hack to call the callback after react has done first render\n // Note: In dev, we call onHeadRendered twice( in FireCallbackInEffect and after mutualution observer dectects initail render into hiddenRoot) this is for hot reloading\n // In Prod we only call onHeadRendered in FireCallbackInEffect to render to head\n
\n \n {WrapHeadElement}\n \n ,\n hiddenRoot\n )\n }\n\n return () => {\n removePrevHeadElements()\n removeHtmlAndBodyAttributes(keysOfHtmlAndBodyAttributes)\n }\n })\n}\n","import React, { Suspense, createElement } from \"react\"\nimport PropTypes from \"prop-types\"\nimport { apiRunner } from \"./api-runner-browser\"\nimport { grabMatchParams } from \"./find-path\"\nimport { headHandlerForBrowser } from \"./head/head-export-handler-for-browser\"\n\n// Renders page\nfunction PageRenderer(props) {\n const pageComponentProps = {\n ...props,\n params: {\n ...grabMatchParams(props.location.pathname),\n ...props.pageResources.json.pageContext.__params,\n },\n }\n\n const preferDefault = m => (m && m.default) || m\n\n let pageElement\n if (props.pageResources.partialHydration) {\n pageElement = props.pageResources.partialHydration\n } else {\n pageElement = createElement(preferDefault(props.pageResources.component), {\n ...pageComponentProps,\n key: props.path || props.pageResources.page.path,\n })\n }\n\n const pageComponent = props.pageResources.head\n\n headHandlerForBrowser({\n pageComponent,\n staticQueryResults: props.pageResources.staticQueryResults,\n pageComponentProps,\n })\n\n const wrappedPage = apiRunner(\n `wrapPageElement`,\n {\n element: pageElement,\n props: pageComponentProps,\n },\n pageElement,\n ({ result }) => {\n return { element: result, props: pageComponentProps }\n }\n ).pop()\n\n return wrappedPage\n}\n\nPageRenderer.propTypes = {\n location: PropTypes.object.isRequired,\n pageResources: PropTypes.object.isRequired,\n data: PropTypes.object,\n pageContext: PropTypes.object.isRequired,\n}\n\nexport default PageRenderer\n","// This is extracted to separate module because it's shared\n// between browser and SSR code\nexport const RouteAnnouncerProps = {\n id: `gatsby-announcer`,\n style: {\n position: `absolute`,\n top: 0,\n width: 1,\n height: 1,\n padding: 0,\n overflow: `hidden`,\n clip: `rect(0, 0, 0, 0)`,\n whiteSpace: `nowrap`,\n border: 0,\n },\n \"aria-live\": `assertive`,\n \"aria-atomic\": `true`,\n}\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\nimport loader, { PageResourceStatus } from \"./loader\"\nimport { maybeGetBrowserRedirect } from \"./redirect-utils.js\"\nimport { apiRunner } from \"./api-runner-browser\"\nimport emitter from \"./emitter\"\nimport { RouteAnnouncerProps } from \"./route-announcer-props\"\nimport {\n navigate as reachNavigate,\n globalHistory,\n} from \"@gatsbyjs/reach-router\"\nimport { parsePath } from \"gatsby-link\"\n\nfunction maybeRedirect(pathname) {\n const redirect = maybeGetBrowserRedirect(pathname)\n const { hash, search } = window.location\n\n if (redirect != null) {\n window.___replace(redirect.toPath + search + hash)\n return true\n } else {\n return false\n }\n}\n\n// Catch unhandled chunk loading errors and force a restart of the app.\nlet nextRoute = ``\n\nwindow.addEventListener(`unhandledrejection`, event => {\n if (/loading chunk \\d* failed./i.test(event.reason)) {\n if (nextRoute) {\n window.location.pathname = nextRoute\n }\n }\n})\n\nconst onPreRouteUpdate = (location, prevLocation) => {\n if (!maybeRedirect(location.pathname)) {\n nextRoute = location.pathname\n apiRunner(`onPreRouteUpdate`, { location, prevLocation })\n }\n}\n\nconst onRouteUpdate = (location, prevLocation) => {\n if (!maybeRedirect(location.pathname)) {\n apiRunner(`onRouteUpdate`, { location, prevLocation })\n if (\n process.env.GATSBY_QUERY_ON_DEMAND &&\n process.env.GATSBY_QUERY_ON_DEMAND_LOADING_INDICATOR === `true`\n ) {\n emitter.emit(`onRouteUpdate`, { location, prevLocation })\n }\n }\n}\n\nconst navigate = (to, options = {}) => {\n // Support forward/backward navigation with numbers\n // navigate(-2) (jumps back 2 history steps)\n // navigate(2) (jumps forward 2 history steps)\n if (typeof to === `number`) {\n globalHistory.navigate(to)\n return\n }\n\n const { pathname, search, hash } = parsePath(to)\n const redirect = maybeGetBrowserRedirect(pathname)\n\n // If we're redirecting, just replace the passed in pathname\n // to the one we want to redirect to.\n if (redirect) {\n to = redirect.toPath + search + hash\n }\n\n // If we had a service worker update, no matter the path, reload window and\n // reset the pathname whitelist\n if (window.___swUpdated) {\n window.location = pathname + search + hash\n return\n }\n\n // Start a timer to wait for a second before transitioning and showing a\n // loader in case resources aren't around yet.\n const timeoutId = setTimeout(() => {\n emitter.emit(`onDelayedLoadPageResources`, { pathname })\n apiRunner(`onRouteUpdateDelayed`, {\n location: window.location,\n })\n }, 1000)\n\n loader.loadPage(pathname + search).then(pageResources => {\n // If no page resources, then refresh the page\n // Do this, rather than simply `window.location.reload()`, so that\n // pressing the back/forward buttons work - otherwise when pressing\n // back, the browser will just change the URL and expect JS to handle\n // the change, which won't always work since it might not be a Gatsby\n // page.\n if (!pageResources || pageResources.status === PageResourceStatus.Error) {\n window.history.replaceState({}, ``, location.href)\n window.location = pathname\n clearTimeout(timeoutId)\n return\n }\n\n // If the loaded page has a different compilation hash to the\n // window, then a rebuild has occurred on the server. Reload.\n if (process.env.NODE_ENV === `production` && pageResources) {\n if (\n pageResources.page.webpackCompilationHash !==\n window.___webpackCompilationHash\n ) {\n // Purge plugin-offline cache\n if (\n `serviceWorker` in navigator &&\n navigator.serviceWorker.controller !== null &&\n navigator.serviceWorker.controller.state === `activated`\n ) {\n navigator.serviceWorker.controller.postMessage({\n gatsbyApi: `clearPathResources`,\n })\n }\n\n window.location = pathname + search + hash\n }\n }\n reachNavigate(to, options)\n clearTimeout(timeoutId)\n })\n}\n\nfunction shouldUpdateScroll(prevRouterProps, { location }) {\n const { pathname, hash } = location\n const results = apiRunner(`shouldUpdateScroll`, {\n prevRouterProps,\n // `pathname` for backwards compatibility\n pathname,\n routerProps: { location },\n getSavedScrollPosition: args => [\n 0,\n // FIXME this is actually a big code smell, we should fix this\n // eslint-disable-next-line @babel/no-invalid-this\n this._stateStorage.read(args, args.key),\n ],\n })\n if (results.length > 0) {\n // Use the latest registered shouldUpdateScroll result, this allows users to override plugin's configuration\n // @see https://github.com/gatsbyjs/gatsby/issues/12038\n return results[results.length - 1]\n }\n\n if (prevRouterProps) {\n const {\n location: { pathname: oldPathname },\n } = prevRouterProps\n if (oldPathname === pathname) {\n // Scroll to element if it exists, if it doesn't, or no hash is provided,\n // scroll to top.\n return hash ? decodeURI(hash.slice(1)) : [0, 0]\n }\n }\n return true\n}\n\nfunction init() {\n // The \"scroll-behavior\" package expects the \"action\" to be on the location\n // object so let's copy it over.\n globalHistory.listen(args => {\n args.location.action = args.action\n })\n\n window.___push = to => navigate(to, { replace: false })\n window.___replace = to => navigate(to, { replace: true })\n window.___navigate = (to, options) => navigate(to, options)\n}\n\nclass RouteAnnouncer extends React.Component {\n constructor(props) {\n super(props)\n this.announcementRef = React.createRef()\n }\n\n componentDidUpdate(prevProps, nextProps) {\n requestAnimationFrame(() => {\n let pageName = `new page at ${this.props.location.pathname}`\n if (document.title) {\n pageName = document.title\n }\n const pageHeadings = document.querySelectorAll(`#gatsby-focus-wrapper h1`)\n if (pageHeadings && pageHeadings.length) {\n pageName = pageHeadings[0].textContent\n }\n const newAnnouncement = `Navigated to ${pageName}`\n if (this.announcementRef.current) {\n const oldAnnouncement = this.announcementRef.current.innerText\n if (oldAnnouncement !== newAnnouncement) {\n this.announcementRef.current.innerText = newAnnouncement\n }\n }\n })\n }\n\n render() {\n return
\n }\n}\n\nconst compareLocationProps = (prevLocation, nextLocation) => {\n if (prevLocation.href !== nextLocation.href) {\n return true\n }\n\n if (prevLocation?.state?.key !== nextLocation?.state?.key) {\n return true\n }\n\n return false\n}\n\n// Fire on(Pre)RouteUpdate APIs\nclass RouteUpdates extends React.Component {\n constructor(props) {\n super(props)\n onPreRouteUpdate(props.location, null)\n }\n\n componentDidMount() {\n onRouteUpdate(this.props.location, null)\n }\n\n shouldComponentUpdate(nextProps) {\n if (compareLocationProps(this.props.location, nextProps.location)) {\n onPreRouteUpdate(nextProps.location, this.props.location)\n return true\n }\n return false\n }\n\n componentDidUpdate(prevProps) {\n if (compareLocationProps(prevProps.location, this.props.location)) {\n onRouteUpdate(this.props.location, prevProps.location)\n }\n }\n\n render() {\n return (\n
\n {this.props.children}\n \n \n )\n }\n}\n\nRouteUpdates.propTypes = {\n location: PropTypes.object.isRequired,\n}\n\nexport { init, shouldUpdateScroll, RouteUpdates, maybeGetBrowserRedirect }\n","// Pulled from react-compat\n// https://github.com/developit/preact-compat/blob/7c5de00e7c85e2ffd011bf3af02899b63f699d3a/src/index.js#L349\nfunction shallowDiffers(a, b) {\n for (var i in a) {\n if (!(i in b)) return true;\n }for (var _i in b) {\n if (a[_i] !== b[_i]) return true;\n }return false;\n}\n\nexport default (function (instance, nextProps, nextState) {\n return shallowDiffers(instance.props, nextProps) || shallowDiffers(instance.state, nextState);\n});","import React from \"react\"\nimport loader, { PageResourceStatus } from \"./loader\"\nimport shallowCompare from \"shallow-compare\"\n\nclass EnsureResources extends React.Component {\n constructor(props) {\n super()\n const { location, pageResources } = props\n this.state = {\n location: { ...location },\n pageResources:\n pageResources ||\n loader.loadPageSync(location.pathname + location.search, {\n withErrorDetails: true,\n }),\n }\n }\n\n static getDerivedStateFromProps({ location }, prevState) {\n if (prevState.location.href !== location.href) {\n const pageResources = loader.loadPageSync(\n location.pathname + location.search,\n {\n withErrorDetails: true,\n }\n )\n\n return {\n pageResources,\n location: { ...location },\n }\n }\n\n return {\n location: { ...location },\n }\n }\n\n loadResources(rawPath) {\n loader.loadPage(rawPath).then(pageResources => {\n if (pageResources && pageResources.status !== PageResourceStatus.Error) {\n this.setState({\n location: { ...window.location },\n pageResources,\n })\n } else {\n window.history.replaceState({}, ``, location.href)\n window.location = rawPath\n }\n })\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n // Always return false if we're missing resources.\n if (!nextState.pageResources) {\n this.loadResources(\n nextProps.location.pathname + nextProps.location.search\n )\n return false\n }\n\n if (\n process.env.BUILD_STAGE === `develop` &&\n nextState.pageResources.stale\n ) {\n this.loadResources(\n nextProps.location.pathname + nextProps.location.search\n )\n return false\n }\n\n // Check if the component or json have changed.\n if (this.state.pageResources !== nextState.pageResources) {\n return true\n }\n if (\n this.state.pageResources.component !== nextState.pageResources.component\n ) {\n return true\n }\n\n if (this.state.pageResources.json !== nextState.pageResources.json) {\n return true\n }\n // Check if location has changed on a page using internal routing\n // via matchPath configuration.\n if (\n this.state.location.key !== nextState.location.key &&\n nextState.pageResources.page &&\n (nextState.pageResources.page.matchPath ||\n nextState.pageResources.page.path)\n ) {\n return true\n }\n return shallowCompare(this, nextProps, nextState)\n }\n\n render() {\n if (\n process.env.NODE_ENV !== `production` &&\n (!this.state.pageResources ||\n this.state.pageResources.status === PageResourceStatus.Error)\n ) {\n const message = `EnsureResources was not able to find resources for path: \"${this.props.location.pathname}\"\nThis typically means that an issue occurred building components for that path.\nRun \\`gatsby clean\\` to remove any cached elements.`\n if (this.state.pageResources?.error) {\n console.error(message)\n throw this.state.pageResources.error\n }\n\n throw new Error(message)\n }\n\n return this.props.children(this.state)\n }\n}\n\nexport default EnsureResources\n","import { apiRunner, apiRunnerAsync } from \"./api-runner-browser\"\nimport React from \"react\"\nimport { Router, navigate, Location, BaseContext } from \"@gatsbyjs/reach-router\"\nimport { ScrollContext } from \"gatsby-react-router-scroll\"\nimport { StaticQueryContext } from \"./static-query\"\nimport {\n SlicesMapContext,\n SlicesContext,\n SlicesResultsContext,\n} from \"./slice/context\"\nimport {\n shouldUpdateScroll,\n init as navigationInit,\n RouteUpdates,\n} from \"./navigation\"\nimport emitter from \"./emitter\"\nimport PageRenderer from \"./page-renderer\"\nimport asyncRequires from \"$virtual/async-requires\"\nimport {\n setLoader,\n ProdLoader,\n publicLoader,\n PageResourceStatus,\n getStaticQueryResults,\n getSliceResults,\n} from \"./loader\"\nimport EnsureResources from \"./ensure-resources\"\nimport stripPrefix from \"./strip-prefix\"\n\n// Generated during bootstrap\nimport matchPaths from \"$virtual/match-paths.json\"\nimport { reactDOMUtils } from \"./react-dom-utils\"\n\nconst loader = new ProdLoader(asyncRequires, matchPaths, window.pageData)\nsetLoader(loader)\nloader.setApiRunner(apiRunner)\n\nconst { render, hydrate } = reactDOMUtils()\n\nwindow.asyncRequires = asyncRequires\nwindow.___emitter = emitter\nwindow.___loader = publicLoader\n\nnavigationInit()\n\nconst reloadStorageKey = `gatsby-reload-compilation-hash-match`\n\napiRunnerAsync(`onClientEntry`).then(() => {\n // Let plugins register a service worker. The plugin just needs\n // to return true.\n if (apiRunner(`registerServiceWorker`).filter(Boolean).length > 0) {\n require(`./register-service-worker`)\n }\n\n // In gatsby v2 if Router is used in page using matchPaths\n // paths need to contain full path.\n // For example:\n // - page have `/app/*` matchPath\n // - inside template user needs to use `/app/xyz` as path\n // Resetting `basepath`/`baseuri` keeps current behaviour\n // to not introduce breaking change.\n // Remove this in v3\n const RouteHandler = props => (\n
\n \n \n )\n\n const DataContext = React.createContext({})\n\n const slicesContext = {\n renderEnvironment: `browser`,\n }\n\n class GatsbyRoot extends React.Component {\n render() {\n const { children } = this.props\n return (\n
\n {({ location }) => (\n \n {({ pageResources, location }) => {\n const staticQueryResults = getStaticQueryResults()\n const sliceResults = getSliceResults()\n\n return (\n \n \n \n \n \n {children}\n \n \n \n \n \n )\n }}\n \n )}\n \n )\n }\n }\n\n class LocationHandler extends React.Component {\n render() {\n return (\n
\n {({ pageResources, location }) => (\n \n \n \n \n \n \n \n )}\n \n )\n }\n }\n\n const { pagePath, location: browserLoc } = window\n\n // Explicitly call navigate if the canonical path (window.pagePath)\n // is different to the browser path (window.location.pathname). SSR\n // page paths might include search params, while SSG and DSG won't.\n // If page path include search params we also compare query params.\n // But only if NONE of the following conditions hold:\n //\n // - The url matches a client side route (page.matchPath)\n // - it's a 404 page\n // - it's the offline plugin shell (/offline-plugin-app-shell-fallback/)\n if (\n pagePath &&\n __BASE_PATH__ + pagePath !==\n browserLoc.pathname + (pagePath.includes(`?`) ? browserLoc.search : ``) &&\n !(\n loader.findMatchPath(stripPrefix(browserLoc.pathname, __BASE_PATH__)) ||\n pagePath.match(/^\\/(404|500)(\\/?|.html)$/) ||\n pagePath.match(/^\\/offline-plugin-app-shell-fallback\\/?$/)\n )\n ) {\n navigate(\n __BASE_PATH__ +\n pagePath +\n (!pagePath.includes(`?`) ? browserLoc.search : ``) +\n browserLoc.hash,\n {\n replace: true,\n }\n )\n }\n\n // It's possible that sessionStorage can throw an exception if access is not granted, see https://github.com/gatsbyjs/gatsby/issues/34512\n const getSessionStorage = () => {\n try {\n return sessionStorage\n } catch {\n return null\n }\n }\n\n publicLoader.loadPage(browserLoc.pathname + browserLoc.search).then(page => {\n const sessionStorage = getSessionStorage()\n\n if (\n page?.page?.webpackCompilationHash &&\n page.page.webpackCompilationHash !== window.___webpackCompilationHash\n ) {\n // Purge plugin-offline cache\n if (\n `serviceWorker` in navigator &&\n navigator.serviceWorker.controller !== null &&\n navigator.serviceWorker.controller.state === `activated`\n ) {\n navigator.serviceWorker.controller.postMessage({\n gatsbyApi: `clearPathResources`,\n })\n }\n\n // We have not matching html + js (inlined `window.___webpackCompilationHash`)\n // with our data (coming from `app-data.json` file). This can cause issues such as\n // errors trying to load static queries (as list of static queries is inside `page-data`\n // which might not match to currently loaded `.js` scripts).\n // We are making attempt to reload if hashes don't match, but we also have to handle case\n // when reload doesn't fix it (possibly broken deploy) so we don't end up in infinite reload loop\n if (sessionStorage) {\n const isReloaded = sessionStorage.getItem(reloadStorageKey) === `1`\n\n if (!isReloaded) {\n sessionStorage.setItem(reloadStorageKey, `1`)\n window.location.reload(true)\n return\n }\n }\n }\n\n if (sessionStorage) {\n sessionStorage.removeItem(reloadStorageKey)\n }\n\n if (!page || page.status === PageResourceStatus.Error) {\n const message = `page resources for ${browserLoc.pathname} not found. Not rendering React`\n\n // if the chunk throws an error we want to capture the real error\n // This should help with https://github.com/gatsbyjs/gatsby/issues/19618\n if (page && page.error) {\n console.error(message)\n throw page.error\n }\n\n throw new Error(message)\n }\n\n const SiteRoot = apiRunner(\n `wrapRootElement`,\n { element:
},\n
,\n ({ result }) => {\n return { element: result }\n }\n ).pop()\n\n const App = function App() {\n const onClientEntryRanRef = React.useRef(false)\n\n React.useEffect(() => {\n if (!onClientEntryRanRef.current) {\n onClientEntryRanRef.current = true\n if (performance.mark) {\n performance.mark(`onInitialClientRender`)\n }\n\n apiRunner(`onInitialClientRender`)\n }\n }, [])\n\n return
{SiteRoot}\n }\n\n const focusEl = document.getElementById(`gatsby-focus-wrapper`)\n\n // Client only pages have any empty body so we just do a normal\n // render to avoid React complaining about hydration mis-matches.\n let defaultRenderer = render\n if (focusEl && focusEl.children.length) {\n defaultRenderer = hydrate\n }\n\n const renderer = apiRunner(\n `replaceHydrateFunction`,\n undefined,\n defaultRenderer\n )[0]\n\n function runRender() {\n const rootElement =\n typeof window !== `undefined`\n ? document.getElementById(`___gatsby`)\n : null\n\n renderer(
, rootElement)\n }\n\n // https://github.com/madrobby/zepto/blob/b5ed8d607f67724788ec9ff492be297f64d47dfc/src/zepto.js#L439-L450\n // TODO remove IE 10 support\n const doc = document\n if (\n doc.readyState === `complete` ||\n (doc.readyState !== `loading` && !doc.documentElement.doScroll)\n ) {\n setTimeout(function () {\n runRender()\n }, 0)\n } else {\n const handler = function () {\n doc.removeEventListener(`DOMContentLoaded`, handler, false)\n window.removeEventListener(`load`, handler, false)\n\n runRender()\n }\n\n doc.addEventListener(`DOMContentLoaded`, handler, false)\n window.addEventListener(`load`, handler, false)\n }\n\n return\n })\n})\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\n\nimport loader from \"./loader\"\nimport InternalPageRenderer from \"./page-renderer\"\n\nconst ProdPageRenderer = ({ location }) => {\n const pageResources = loader.loadPageSync(location.pathname)\n if (!pageResources) {\n return null\n }\n return React.createElement(InternalPageRenderer, {\n location,\n pageResources,\n ...pageResources.json,\n })\n}\n\nProdPageRenderer.propTypes = {\n location: PropTypes.shape({\n pathname: PropTypes.string.isRequired,\n }).isRequired,\n}\n\nexport default ProdPageRenderer\n","const preferDefault = m => (m && m.default) || m\n\nif (process.env.BUILD_STAGE === `develop`) {\n module.exports = preferDefault(require(`./public-page-renderer-dev`))\n} else if (process.env.BUILD_STAGE === `build-javascript`) {\n module.exports = preferDefault(require(`./public-page-renderer-prod`))\n} else {\n module.exports = () => null\n}\n","const map = new WeakMap()\n\nexport function reactDOMUtils() {\n const reactDomClient = require(`react-dom/client`)\n\n const render = (Component, el) => {\n let root = map.get(el)\n if (!root) {\n map.set(el, (root = reactDomClient.createRoot(el)))\n }\n root.render(Component)\n }\n\n const hydrate = (Component, el) => reactDomClient.hydrateRoot(el, Component)\n\n return { render, hydrate }\n}\n","import redirects from \"./redirects.json\"\n\n// Convert to a map for faster lookup in maybeRedirect()\n\nconst redirectMap = new Map()\nconst redirectIgnoreCaseMap = new Map()\n\nredirects.forEach(redirect => {\n if (redirect.ignoreCase) {\n redirectIgnoreCaseMap.set(redirect.fromPath, redirect)\n } else {\n redirectMap.set(redirect.fromPath, redirect)\n }\n})\n\nexport function maybeGetBrowserRedirect(pathname) {\n let redirect = redirectMap.get(pathname)\n if (!redirect) {\n redirect = redirectIgnoreCaseMap.get(pathname.toLowerCase())\n }\n return redirect\n}\n","import { apiRunner } from \"./api-runner-browser\"\n\nif (\n window.location.protocol !== `https:` &&\n window.location.hostname !== `localhost`\n) {\n console.error(\n `Service workers can only be used over HTTPS, or on localhost for development`\n )\n} else if (`serviceWorker` in navigator) {\n navigator.serviceWorker\n .register(`${__BASE_PATH__}/sw.js`)\n .then(function (reg) {\n reg.addEventListener(`updatefound`, () => {\n apiRunner(`onServiceWorkerUpdateFound`, { serviceWorker: reg })\n // The updatefound event implies that reg.installing is set; see\n // https://w3c.github.io/ServiceWorker/#service-worker-registration-updatefound-event\n const installingWorker = reg.installing\n console.log(`installingWorker`, installingWorker)\n installingWorker.addEventListener(`statechange`, () => {\n switch (installingWorker.state) {\n case `installed`:\n if (navigator.serviceWorker.controller) {\n // At this point, the old content will have been purged and the fresh content will\n // have been added to the cache.\n\n // We set a flag so Gatsby Link knows to refresh the page on next navigation attempt\n window.___swUpdated = true\n // We call the onServiceWorkerUpdateReady API so users can show update prompts.\n apiRunner(`onServiceWorkerUpdateReady`, { serviceWorker: reg })\n\n // If resources failed for the current page, reload.\n if (window.___failedResources) {\n console.log(`resources failed, SW updated - reloading`)\n window.location.reload()\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a \"Content is cached for offline use.\" message.\n console.log(`Content is now available offline!`)\n\n // Post to service worker that install is complete.\n // Delay to allow time for the event listener to be added --\n // otherwise fetch is called too soon and resources aren't cached.\n apiRunner(`onServiceWorkerInstalled`, { serviceWorker: reg })\n }\n break\n\n case `redundant`:\n console.error(`The installing service worker became redundant.`)\n apiRunner(`onServiceWorkerRedundant`, { serviceWorker: reg })\n break\n\n case `activated`:\n apiRunner(`onServiceWorkerActive`, { serviceWorker: reg })\n break\n }\n })\n })\n })\n .catch(function (e) {\n console.error(`Error during service worker registration:`, e)\n })\n}\n","import React from \"react\"\n\nconst SlicesResultsContext = React.createContext({})\nconst SlicesContext = React.createContext({})\nconst SlicesMapContext = React.createContext({})\nconst SlicesPropsContext = React.createContext({})\n\nexport {\n SlicesResultsContext,\n SlicesContext,\n SlicesMapContext,\n SlicesPropsContext,\n}\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\nimport { createServerOrClientContext } from \"./context-utils\"\n\nconst StaticQueryContext = createServerOrClientContext(`StaticQuery`, {})\n\nfunction StaticQueryDataRenderer({ staticQueryData, data, query, render }) {\n const finalData = data\n ? data.data\n : staticQueryData[query] && staticQueryData[query].data\n\n return (\n
\n {finalData && render(finalData)}\n {!finalData && Loading (StaticQuery)
}\n \n )\n}\n\nlet warnedAboutStaticQuery = false\n\n// TODO(v6): Remove completely\nconst StaticQuery = props => {\n const { data, query, render, children } = props\n\n if (process.env.NODE_ENV === `development` && !warnedAboutStaticQuery) {\n console.warn(\n `The
component is deprecated and will be removed in Gatsby v6. Use useStaticQuery instead. Refer to the migration guide for more information: https://gatsby.dev/migrating-4-to-5/#staticquery--is-deprecated`\n )\n warnedAboutStaticQuery = true\n }\n\n return (\n
\n {staticQueryData => (\n \n )}\n \n )\n}\n\nStaticQuery.propTypes = {\n data: PropTypes.object,\n query: PropTypes.string.isRequired,\n render: PropTypes.func,\n children: PropTypes.func,\n}\n\nconst useStaticQuery = query => {\n if (\n typeof React.useContext !== `function` &&\n process.env.NODE_ENV === `development`\n ) {\n // TODO(v5): Remove since we require React >= 18\n throw new Error(\n `You're likely using a version of React that doesn't support Hooks\\n` +\n `Please update React and ReactDOM to 16.8.0 or later to use the useStaticQuery hook.`\n )\n }\n\n const context = React.useContext(StaticQueryContext)\n\n // query is a stringified number like `3303882` when wrapped with graphql, If a user forgets\n // to wrap the query in a grqphql, then casting it to a Number results in `NaN` allowing us to\n // catch the misuse of the API and give proper direction\n if (isNaN(Number(query))) {\n throw new Error(`useStaticQuery was called with a string but expects to be called using \\`graphql\\`. Try this:\n\nimport { useStaticQuery, graphql } from 'gatsby';\n\nuseStaticQuery(graphql\\`${query}\\`);\n`)\n }\n\n if (context[query]?.data) {\n return context[query].data\n } else {\n throw new Error(\n `The result of this StaticQuery could not be fetched.\\n\\n` +\n `This is likely a bug in Gatsby and if refreshing the page does not fix it, ` +\n `please open an issue in https://github.com/gatsbyjs/gatsby/issues`\n )\n }\n}\n\nexport { StaticQuery, StaticQueryContext, useStaticQuery }\n","import React from \"react\"\n\n// Ensure serverContext is not created more than once as React will throw when creating it more than once\n// https://github.com/facebook/react/blob/dd2d6522754f52c70d02c51db25eb7cbd5d1c8eb/packages/react/src/ReactServerContext.js#L101\nconst createServerContext = (name, defaultValue = null) => {\n /* eslint-disable no-undef */\n if (!globalThis.__SERVER_CONTEXT) {\n globalThis.__SERVER_CONTEXT = {}\n }\n\n if (!globalThis.__SERVER_CONTEXT[name]) {\n globalThis.__SERVER_CONTEXT[name] = React.createServerContext(\n name,\n defaultValue\n )\n }\n\n return globalThis.__SERVER_CONTEXT[name]\n}\n\nfunction createServerOrClientContext(name, defaultValue) {\n if (React.createServerContext) {\n return createServerContext(name, defaultValue)\n }\n\n return React.createContext(defaultValue)\n}\n\nexport { createServerOrClientContext }\n","/**\n * Remove a prefix from a string. Return the input string if the given prefix\n * isn't found.\n */\n\nexport default function stripPrefix(str, prefix = ``) {\n if (!prefix) {\n return str\n }\n\n if (str === prefix) {\n return `/`\n }\n\n if (str.startsWith(`${prefix}/`)) {\n return str.slice(prefix.length)\n }\n\n return str\n}\n","/* global __MANIFEST_PLUGIN_HAS_LOCALISATION__ */\nimport { withPrefix } from \"gatsby\";\nimport getManifestForPathname from \"./get-manifest-pathname\";\n\n// when we don't have localisation in our manifest, we tree shake everything away\nexport const onRouteUpdate = function onRouteUpdate({\n location\n}, pluginOptions) {\n if (__MANIFEST_PLUGIN_HAS_LOCALISATION__) {\n const {\n localize\n } = pluginOptions;\n const manifestFilename = getManifestForPathname(location.pathname, localize, true);\n const manifestEl = document.head.querySelector(`link[rel=\"manifest\"]`);\n if (manifestEl) {\n manifestEl.setAttribute(`href`, withPrefix(manifestFilename));\n }\n }\n};","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\nvar _gatsby = require(\"gatsby\");\n/**\n * Get a manifest filename depending on localized pathname\n *\n * @param {string} pathname\n * @param {Array<{start_url: string, lang: string}>} localizedManifests\n * @param {boolean} shouldPrependPathPrefix\n * @return string\n */\nvar _default = (pathname, localizedManifests, shouldPrependPathPrefix = false) => {\n const defaultFilename = `manifest.webmanifest`;\n if (!Array.isArray(localizedManifests)) {\n return defaultFilename;\n }\n const localizedManifest = localizedManifests.find(app => {\n let startUrl = app.start_url;\n if (shouldPrependPathPrefix) {\n startUrl = (0, _gatsby.withPrefix)(startUrl);\n }\n return pathname.startsWith(startUrl);\n });\n if (!localizedManifest) {\n return defaultFilename;\n }\n return `manifest_${localizedManifest.lang}.webmanifest`;\n};\nexports.default = _default;","export default class SequentialIDGenerator {\n constructor(prefix = \"\") {\n // ensure start with \"ae\" so \"ad\" is never produced\n this.prefix = prefix;\n this.count = 0;\n this.offset = 374;\n this.msb = 1295;\n this.power = 2;\n }\n\n next() {\n const id = this.increment().toString(36);\n return this.prefix ? `${this.prefix}${id}` : id;\n }\n\n increment() {\n const id = this.count + this.offset;\n\n if (id === this.msb) {\n this.offset += (this.msb + 1) * 9;\n this.msb = Math.pow(36, ++this.power) - 1;\n }\n\n this.count++;\n return id;\n }\n\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTZXF1ZW50aWFsSURHZW5lcmF0b3IiLCJjb25zdHJ1Y3RvciIsInByZWZpeCIsImNvdW50Iiwib2Zmc2V0IiwibXNiIiwicG93ZXIiLCJuZXh0IiwiaWQiLCJpbmNyZW1lbnQiLCJ0b1N0cmluZyIsIk1hdGgiLCJwb3ciXSwic291cmNlcyI6WyJzcmMvc2VxdWVudGlhbC1pZC1nZW5lcmF0b3IudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgY2xhc3MgU2VxdWVudGlhbElER2VuZXJhdG9yIHtcbiAgcHJlZml4OiBzdHJpbmc7XG4gIGNvdW50OiBudW1iZXI7XG4gIG9mZnNldDogbnVtYmVyO1xuICBtc2I6IG51bWJlcjtcbiAgcG93ZXI6IG51bWJlcjtcblxuICBjb25zdHJ1Y3RvcihwcmVmaXg6IHN0cmluZyA9IFwiXCIpIHtcbiAgICAvLyBlbnN1cmUgc3RhcnQgd2l0aCBcImFlXCIgc28gXCJhZFwiIGlzIG5ldmVyIHByb2R1Y2VkXG4gICAgdGhpcy5wcmVmaXggPSBwcmVmaXg7XG4gICAgdGhpcy5jb3VudCA9IDA7XG4gICAgdGhpcy5vZmZzZXQgPSAzNzQ7XG4gICAgdGhpcy5tc2IgPSAxMjk1O1xuICAgIHRoaXMucG93ZXIgPSAyO1xuICB9XG5cbiAgbmV4dCgpIHtcbiAgICBjb25zdCBpZCA9IHRoaXMuaW5jcmVtZW50KCkudG9TdHJpbmcoMzYpO1xuICAgIHJldHVybiB0aGlzLnByZWZpeCA/IGAke3RoaXMucHJlZml4fSR7aWR9YCA6IGlkO1xuICB9XG5cbiAgaW5jcmVtZW50KCkge1xuICAgIGNvbnN0IGlkID0gdGhpcy5jb3VudCArIHRoaXMub2Zmc2V0O1xuICAgIGlmIChpZCA9PT0gdGhpcy5tc2IpIHtcbiAgICAgIHRoaXMub2Zmc2V0ICs9ICh0aGlzLm1zYiArIDEpICogOTtcbiAgICAgIHRoaXMubXNiID0gTWF0aC5wb3coMzYsICsrdGhpcy5wb3dlcikgLSAxO1xuICAgIH1cbiAgICB0aGlzLmNvdW50Kys7XG4gICAgcmV0dXJuIGlkO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLGVBQWUsTUFBTUEscUJBQU4sQ0FBNEI7RUFPekNDLFdBQVcsQ0FBQ0MsTUFBYyxHQUFHLEVBQWxCLEVBQXNCO0lBQy9CO0lBQ0EsS0FBS0EsTUFBTCxHQUFjQSxNQUFkO0lBQ0EsS0FBS0MsS0FBTCxHQUFhLENBQWI7SUFDQSxLQUFLQyxNQUFMLEdBQWMsR0FBZDtJQUNBLEtBQUtDLEdBQUwsR0FBVyxJQUFYO0lBQ0EsS0FBS0MsS0FBTCxHQUFhLENBQWI7RUFDRDs7RUFFREMsSUFBSSxHQUFHO0lBQ0wsTUFBTUMsRUFBRSxHQUFHLEtBQUtDLFNBQUwsR0FBaUJDLFFBQWpCLENBQTBCLEVBQTFCLENBQVg7SUFDQSxPQUFPLEtBQUtSLE1BQUwsR0FBZSxHQUFFLEtBQUtBLE1BQU8sR0FBRU0sRUFBRyxFQUFsQyxHQUFzQ0EsRUFBN0M7RUFDRDs7RUFFREMsU0FBUyxHQUFHO0lBQ1YsTUFBTUQsRUFBRSxHQUFHLEtBQUtMLEtBQUwsR0FBYSxLQUFLQyxNQUE3Qjs7SUFDQSxJQUFJSSxFQUFFLEtBQUssS0FBS0gsR0FBaEIsRUFBcUI7TUFDbkIsS0FBS0QsTUFBTCxJQUFlLENBQUMsS0FBS0MsR0FBTCxHQUFXLENBQVosSUFBaUIsQ0FBaEM7TUFDQSxLQUFLQSxHQUFMLEdBQVdNLElBQUksQ0FBQ0MsR0FBTCxDQUFTLEVBQVQsRUFBYSxFQUFFLEtBQUtOLEtBQXBCLElBQTZCLENBQXhDO0lBQ0Q7O0lBQ0QsS0FBS0gsS0FBTDtJQUNBLE9BQU9LLEVBQVA7RUFDRDs7QUE3QndDIn0=","// adapted from https://github.com/dutchenkoOleg/sort-css-media-queries\nconst minMaxWidth = /(!?\\(\\s*min(-device-)?-width).+\\(\\s*max(-device)?-width/i;\nconst minWidth = /\\(\\s*min(-device)?-width/i;\nconst maxMinWidth = /(!?\\(\\s*max(-device)?-width).+\\(\\s*min(-device)?-width/i;\nconst maxWidth = /\\(\\s*max(-device)?-width/i;\n\nconst isMinWidth = _testQuery(minMaxWidth, maxMinWidth, minWidth);\n\nconst isMaxWidth = _testQuery(maxMinWidth, minMaxWidth, maxWidth);\n\nconst minMaxHeight = /(!?\\(\\s*min(-device)?-height).+\\(\\s*max(-device)?-height/i;\nconst minHeight = /\\(\\s*min(-device)?-height/i;\nconst maxMinHeight = /(!?\\(\\s*max(-device)?-height).+\\(\\s*min(-device)?-height/i;\nconst maxHeight = /\\(\\s*max(-device)?-height/i;\n\nconst isMinHeight = _testQuery(minMaxHeight, maxMinHeight, minHeight);\n\nconst isMaxHeight = _testQuery(maxMinHeight, minMaxHeight, maxHeight);\n\nconst isPrint = /print/i;\nconst isPrintOnly = /^print$/i;\nconst maxValue = Number.MAX_VALUE;\n\nfunction _getQueryLength(length) {\n const matches = /(-?\\d*\\.?\\d+)(ch|em|ex|px|rem)/.exec(length);\n\n if (matches === null) {\n return maxValue;\n }\n\n let number = matches[1];\n const unit = matches[2];\n\n switch (unit) {\n case \"ch\":\n number = parseFloat(number) * 8.8984375;\n break;\n\n case \"em\":\n case \"rem\":\n number = parseFloat(number) * 16;\n break;\n\n case \"ex\":\n number = parseFloat(number) * 8.296875;\n break;\n\n case \"px\":\n number = parseFloat(number);\n break;\n }\n\n return +number;\n}\n\nfunction _testQuery(doubleTestTrue, doubleTestFalse, singleTest) {\n return function (query) {\n if (doubleTestTrue.test(query)) {\n return true;\n } else if (doubleTestFalse.test(query)) {\n return false;\n }\n\n return singleTest.test(query);\n };\n}\n\nfunction _testIsPrint(a, b) {\n const isPrintA = isPrint.test(a);\n const isPrintOnlyA = isPrintOnly.test(a);\n const isPrintB = isPrint.test(b);\n const isPrintOnlyB = isPrintOnly.test(b);\n\n if (isPrintA && isPrintB) {\n if (!isPrintOnlyA && isPrintOnlyB) {\n return 1;\n }\n\n if (isPrintOnlyA && !isPrintOnlyB) {\n return -1;\n }\n\n return a.localeCompare(b);\n }\n\n if (isPrintA) {\n return 1;\n }\n\n if (isPrintB) {\n return -1;\n }\n\n return null;\n}\n\nexport default function sortCSSmq(a, b) {\n if (a === \"\") {\n return -1;\n }\n\n if (b === \"\") {\n return 1;\n }\n\n const testIsPrint = _testIsPrint(a, b);\n\n if (testIsPrint !== null) {\n return testIsPrint;\n }\n\n const minA = isMinWidth(a) || isMinHeight(a);\n const maxA = isMaxWidth(a) || isMaxHeight(a);\n const minB = isMinWidth(b) || isMinHeight(b);\n const maxB = isMaxWidth(b) || isMaxHeight(b);\n\n if (minA && maxB) {\n return -1;\n }\n\n if (maxA && minB) {\n return 1;\n }\n\n const lengthA = _getQueryLength(a);\n\n const lengthB = _getQueryLength(b);\n\n if (lengthA === maxValue && lengthB === maxValue) {\n return a.localeCompare(b);\n } else if (lengthA === maxValue) {\n return 1;\n } else if (lengthB === maxValue) {\n return -1;\n }\n\n if (lengthA > lengthB) {\n if (maxA) {\n return -1;\n }\n\n return 1;\n }\n\n if (lengthA < lengthB) {\n if (maxA) {\n return 1;\n }\n\n return -1;\n }\n\n return a.localeCompare(b);\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["minMaxWidth","minWidth","maxMinWidth","maxWidth","isMinWidth","_testQuery","isMaxWidth","minMaxHeight","minHeight","maxMinHeight","maxHeight","isMinHeight","isMaxHeight","isPrint","isPrintOnly","maxValue","Number","MAX_VALUE","_getQueryLength","length","matches","exec","number","unit","parseFloat","doubleTestTrue","doubleTestFalse","singleTest","query","test","_testIsPrint","a","b","isPrintA","isPrintOnlyA","isPrintB","isPrintOnlyB","localeCompare","sortCSSmq","testIsPrint","minA","maxA","minB","maxB","lengthA","lengthB"],"sources":["src/sort-css-media-queries.ts"],"sourcesContent":["// adapted from https://github.com/dutchenkoOleg/sort-css-media-queries\n\nconst minMaxWidth = /(!?\\(\\s*min(-device-)?-width).+\\(\\s*max(-device)?-width/i;\nconst minWidth = /\\(\\s*min(-device)?-width/i;\nconst maxMinWidth = /(!?\\(\\s*max(-device)?-width).+\\(\\s*min(-device)?-width/i;\nconst maxWidth = /\\(\\s*max(-device)?-width/i;\n\nconst isMinWidth = _testQuery(minMaxWidth, maxMinWidth, minWidth);\nconst isMaxWidth = _testQuery(maxMinWidth, minMaxWidth, maxWidth);\n\nconst minMaxHeight =\n  /(!?\\(\\s*min(-device)?-height).+\\(\\s*max(-device)?-height/i;\nconst minHeight = /\\(\\s*min(-device)?-height/i;\nconst maxMinHeight =\n  /(!?\\(\\s*max(-device)?-height).+\\(\\s*min(-device)?-height/i;\nconst maxHeight = /\\(\\s*max(-device)?-height/i;\n\nconst isMinHeight = _testQuery(minMaxHeight, maxMinHeight, minHeight);\nconst isMaxHeight = _testQuery(maxMinHeight, minMaxHeight, maxHeight);\n\nconst isPrint = /print/i;\nconst isPrintOnly = /^print$/i;\nconst maxValue = Number.MAX_VALUE;\n\nfunction _getQueryLength(length: string) {\n  const matches = /(-?\\d*\\.?\\d+)(ch|em|ex|px|rem)/.exec(length);\n  if (matches === null) {\n    return maxValue;\n  }\n  let number: number | string = matches[1];\n  const unit = matches[2];\n  switch (unit) {\n    case \"ch\":\n      number = parseFloat(number) * 8.8984375;\n      break;\n    case \"em\":\n    case \"rem\":\n      number = parseFloat(number) * 16;\n      break;\n    case \"ex\":\n      number = parseFloat(number) * 8.296875;\n      break;\n    case \"px\":\n      number = parseFloat(number);\n      break;\n  }\n  return +number;\n}\n\nfunction _testQuery(\n  doubleTestTrue: RegExp,\n  doubleTestFalse: RegExp,\n  singleTest: RegExp,\n) {\n  return function (query: string) {\n    if (doubleTestTrue.test(query)) {\n      return true;\n    } else if (doubleTestFalse.test(query)) {\n      return false;\n    }\n    return singleTest.test(query);\n  };\n}\n\nfunction _testIsPrint(a: string, b: string) {\n  const isPrintA = isPrint.test(a);\n  const isPrintOnlyA = isPrintOnly.test(a);\n  const isPrintB = isPrint.test(b);\n  const isPrintOnlyB = isPrintOnly.test(b);\n\n  if (isPrintA && isPrintB) {\n    if (!isPrintOnlyA && isPrintOnlyB) {\n      return 1;\n    }\n    if (isPrintOnlyA && !isPrintOnlyB) {\n      return -1;\n    }\n    return a.localeCompare(b);\n  }\n  if (isPrintA) {\n    return 1;\n  }\n  if (isPrintB) {\n    return -1;\n  }\n  return null;\n}\n\nexport default function sortCSSmq(a: string, b: string) {\n  if (a === \"\") {\n    return -1;\n  }\n  if (b === \"\") {\n    return 1;\n  }\n  const testIsPrint = _testIsPrint(a, b);\n  if (testIsPrint !== null) {\n    return testIsPrint;\n  }\n\n  const minA = isMinWidth(a) || isMinHeight(a);\n  const maxA = isMaxWidth(a) || isMaxHeight(a);\n  const minB = isMinWidth(b) || isMinHeight(b);\n  const maxB = isMaxWidth(b) || isMaxHeight(b);\n\n  if (minA && maxB) {\n    return -1;\n  }\n  if (maxA && minB) {\n    return 1;\n  }\n\n  const lengthA = _getQueryLength(a);\n  const lengthB = _getQueryLength(b);\n\n  if (lengthA === maxValue && lengthB === maxValue) {\n    return a.localeCompare(b);\n  } else if (lengthA === maxValue) {\n    return 1;\n  } else if (lengthB === maxValue) {\n    return -1;\n  }\n\n  if (lengthA > lengthB) {\n    if (maxA) {\n      return -1;\n    }\n    return 1;\n  }\n\n  if (lengthA < lengthB) {\n    if (maxA) {\n      return 1;\n    }\n    return -1;\n  }\n\n  return a.localeCompare(b);\n}\n"],"mappings":"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"}","import SequentialIDGenerator from \"./sequential-id-generator\";\nimport sortMq from \"./sort-css-media-queries\";\nexport class MultiCache {\n constructor(idGenerator, onNewCache, onNewValue) {\n this.idGenerator = idGenerator;\n this.onNewCache = onNewCache;\n this.onNewValue = onNewValue;\n this.sortedCacheKeys = [];\n this.caches = {};\n }\n\n getCache(key) {\n if (!this.caches[key]) {\n const cache = new Cache(this.idGenerator, this.onNewValue);\n cache.key = key;\n this.sortedCacheKeys.push(key);\n this.sortedCacheKeys.sort(sortMq);\n const keyIndex = this.sortedCacheKeys.indexOf(key);\n const insertBeforeMedia = keyIndex < this.sortedCacheKeys.length - 1 ? this.sortedCacheKeys[keyIndex + 1] : void 0;\n this.caches[key] = cache;\n this.onNewCache(key, cache, insertBeforeMedia);\n }\n\n return this.caches[key];\n }\n\n getSortedCacheKeys() {\n return this.sortedCacheKeys;\n }\n\n}\nexport class Cache {\n constructor(idGenerator, onNewValue) {\n this.cache = {};\n this.idGenerator = idGenerator;\n this.onNewValue = onNewValue;\n }\n\n addValue(key, value) {\n const cached = this.cache[key];\n\n if (cached) {\n return cached;\n }\n\n const id = this.idGenerator.next();\n this.cache[key] = id;\n this.onNewValue(this, id, value);\n return id;\n }\n\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTZXF1ZW50aWFsSURHZW5lcmF0b3IiLCJzb3J0TXEiLCJNdWx0aUNhY2hlIiwiY29uc3RydWN0b3IiLCJpZEdlbmVyYXRvciIsIm9uTmV3Q2FjaGUiLCJvbk5ld1ZhbHVlIiwic29ydGVkQ2FjaGVLZXlzIiwiY2FjaGVzIiwiZ2V0Q2FjaGUiLCJrZXkiLCJjYWNoZSIsIkNhY2hlIiwicHVzaCIsInNvcnQiLCJrZXlJbmRleCIsImluZGV4T2YiLCJpbnNlcnRCZWZvcmVNZWRpYSIsImxlbmd0aCIsImdldFNvcnRlZENhY2hlS2V5cyIsImFkZFZhbHVlIiwidmFsdWUiLCJjYWNoZWQiLCJpZCIsIm5leHQiXSwic291cmNlcyI6WyJzcmMvY2FjaGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFNlcXVlbnRpYWxJREdlbmVyYXRvciBmcm9tIFwiLi9zZXF1ZW50aWFsLWlkLWdlbmVyYXRvclwiO1xuaW1wb3J0IHNvcnRNcSBmcm9tIFwiLi9zb3J0LWNzcy1tZWRpYS1xdWVyaWVzXCI7XG5cbnR5cGUgT25OZXdDYWNoZUZuPFQ+ID0gKFxuICBrZXk6IHN0cmluZyxcbiAgY2FjaGU6IENhY2hlPFQ+LFxuICB2YWx1ZT86IHN0cmluZyB8IG51bGwsXG4pID0+IGFueTtcbnR5cGUgT25OZXdWYWx1ZUZuPFQ+ID0gKGNhY2hlOiBDYWNoZTxUPiwgaWQ6IHN0cmluZywgdmFsdWU6IFQpID0+IGFueTtcblxuZXhwb3J0IGNsYXNzIE11bHRpQ2FjaGU8VD4ge1xuICBjYWNoZXM6IHtcbiAgICBbeDogc3RyaW5nXTogQ2FjaGU8VD47XG4gIH07XG4gIGlkR2VuZXJhdG9yOiBTZXF1ZW50aWFsSURHZW5lcmF0b3I7XG4gIG9uTmV3Q2FjaGU6IE9uTmV3Q2FjaGVGbjxUPjtcbiAgb25OZXdWYWx1ZTogT25OZXdWYWx1ZUZuPFQ+O1xuICBzb3J0ZWRDYWNoZUtleXM6IHN0cmluZ1tdO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGlkR2VuZXJhdG9yOiBTZXF1ZW50aWFsSURHZW5lcmF0b3IsXG4gICAgb25OZXdDYWNoZTogT25OZXdDYWNoZUZuPFQ+LFxuICAgIG9uTmV3VmFsdWU6IE9uTmV3VmFsdWVGbjxUPixcbiAgKSB7XG4gICAgdGhpcy5pZEdlbmVyYXRvciA9IGlkR2VuZXJhdG9yO1xuICAgIHRoaXMub25OZXdDYWNoZSA9IG9uTmV3Q2FjaGU7XG4gICAgdGhpcy5vbk5ld1ZhbHVlID0gb25OZXdWYWx1ZTtcbiAgICB0aGlzLnNvcnRlZENhY2hlS2V5cyA9IFtdO1xuICAgIHRoaXMuY2FjaGVzID0ge307XG4gIH1cblxuICBnZXRDYWNoZShrZXk6IHN0cmluZyk6IENhY2hlPFQ+IHtcbiAgICBpZiAoIXRoaXMuY2FjaGVzW2tleV0pIHtcbiAgICAgIGNvbnN0IGNhY2hlID0gbmV3IENhY2hlKHRoaXMuaWRHZW5lcmF0b3IsIHRoaXMub25OZXdWYWx1ZSk7XG4gICAgICBjYWNoZS5rZXkgPSBrZXk7XG4gICAgICB0aGlzLnNvcnRlZENhY2hlS2V5cy5wdXNoKGtleSk7XG4gICAgICB0aGlzLnNvcnRlZENhY2hlS2V5cy5zb3J0KHNvcnRNcSk7XG4gICAgICBjb25zdCBrZXlJbmRleCA9IHRoaXMuc29ydGVkQ2FjaGVLZXlzLmluZGV4T2Yoa2V5KTtcbiAgICAgIGNvbnN0IGluc2VydEJlZm9yZU1lZGlhID1cbiAgICAgICAga2V5SW5kZXggPCB0aGlzLnNvcnRlZENhY2hlS2V5cy5sZW5ndGggLSAxXG4gICAgICAgICAgPyB0aGlzLnNvcnRlZENhY2hlS2V5c1trZXlJbmRleCArIDFdXG4gICAgICAgICAgOiB2b2lkIDA7XG4gICAgICB0aGlzLmNhY2hlc1trZXldID0gY2FjaGU7XG4gICAgICB0aGlzLm9uTmV3Q2FjaGUoa2V5LCBjYWNoZSwgaW5zZXJ0QmVmb3JlTWVkaWEpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5jYWNoZXNba2V5XTtcbiAgfVxuXG4gIGdldFNvcnRlZENhY2hlS2V5cygpIHtcbiAgICByZXR1cm4gdGhpcy5zb3J0ZWRDYWNoZUtleXM7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENhY2hlPFQ+IHtcbiAgY2FjaGU6IHtcbiAgICBbeDogc3RyaW5nXTogc3RyaW5nO1xuICB9O1xuICBpZEdlbmVyYXRvcjogU2VxdWVudGlhbElER2VuZXJhdG9yO1xuICBrZXk6IHN0cmluZztcbiAgb25OZXdWYWx1ZTogKGNhY2hlOiBDYWNoZTxUPiwgaWQ6IHN0cmluZywgdmFsdWU6IGFueSkgPT4gYW55O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGlkR2VuZXJhdG9yOiBTZXF1ZW50aWFsSURHZW5lcmF0b3IsXG4gICAgb25OZXdWYWx1ZTogKGNhY2hlOiBDYWNoZTxUPiwgaWQ6IHN0cmluZywgdmFsdWU6IGFueSkgPT4gYW55LFxuICApIHtcbiAgICB0aGlzLmNhY2hlID0ge307XG4gICAgdGhpcy5pZEdlbmVyYXRvciA9IGlkR2VuZXJhdG9yO1xuICAgIHRoaXMub25OZXdWYWx1ZSA9IG9uTmV3VmFsdWU7XG4gIH1cblxuICBhZGRWYWx1ZShrZXk6IHN0cmluZywgdmFsdWU6IFQpIHtcbiAgICBjb25zdCBjYWNoZWQgPSB0aGlzLmNhY2hlW2tleV07XG4gICAgaWYgKGNhY2hlZCkge1xuICAgICAgcmV0dXJuIGNhY2hlZDtcbiAgICB9XG4gICAgY29uc3QgaWQgPSB0aGlzLmlkR2VuZXJhdG9yLm5leHQoKTtcbiAgICB0aGlzLmNhY2hlW2tleV0gPSBpZDtcbiAgICB0aGlzLm9uTmV3VmFsdWUodGhpcywgaWQsIHZhbHVlKTtcbiAgICByZXR1cm4gaWQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EscUJBQVAsTUFBa0MsMkJBQWxDO0FBQ0EsT0FBT0MsTUFBUCxNQUFtQiwwQkFBbkI7QUFTQSxPQUFPLE1BQU1DLFVBQU4sQ0FBb0I7RUFTekJDLFdBQVcsQ0FDVEMsV0FEUyxFQUVUQyxVQUZTLEVBR1RDLFVBSFMsRUFJVDtJQUNBLEtBQUtGLFdBQUwsR0FBbUJBLFdBQW5CO0lBQ0EsS0FBS0MsVUFBTCxHQUFrQkEsVUFBbEI7SUFDQSxLQUFLQyxVQUFMLEdBQWtCQSxVQUFsQjtJQUNBLEtBQUtDLGVBQUwsR0FBdUIsRUFBdkI7SUFDQSxLQUFLQyxNQUFMLEdBQWMsRUFBZDtFQUNEOztFQUVEQyxRQUFRLENBQUNDLEdBQUQsRUFBd0I7SUFDOUIsSUFBSSxDQUFDLEtBQUtGLE1BQUwsQ0FBWUUsR0FBWixDQUFMLEVBQXVCO01BQ3JCLE1BQU1DLEtBQUssR0FBRyxJQUFJQyxLQUFKLENBQVUsS0FBS1IsV0FBZixFQUE0QixLQUFLRSxVQUFqQyxDQUFkO01BQ0FLLEtBQUssQ0FBQ0QsR0FBTixHQUFZQSxHQUFaO01BQ0EsS0FBS0gsZUFBTCxDQUFxQk0sSUFBckIsQ0FBMEJILEdBQTFCO01BQ0EsS0FBS0gsZUFBTCxDQUFxQk8sSUFBckIsQ0FBMEJiLE1BQTFCO01BQ0EsTUFBTWMsUUFBUSxHQUFHLEtBQUtSLGVBQUwsQ0FBcUJTLE9BQXJCLENBQTZCTixHQUE3QixDQUFqQjtNQUNBLE1BQU1PLGlCQUFpQixHQUNyQkYsUUFBUSxHQUFHLEtBQUtSLGVBQUwsQ0FBcUJXLE1BQXJCLEdBQThCLENBQXpDLEdBQ0ksS0FBS1gsZUFBTCxDQUFxQlEsUUFBUSxHQUFHLENBQWhDLENBREosR0FFSSxLQUFLLENBSFg7TUFJQSxLQUFLUCxNQUFMLENBQVlFLEdBQVosSUFBbUJDLEtBQW5CO01BQ0EsS0FBS04sVUFBTCxDQUFnQkssR0FBaEIsRUFBcUJDLEtBQXJCLEVBQTRCTSxpQkFBNUI7SUFDRDs7SUFDRCxPQUFPLEtBQUtULE1BQUwsQ0FBWUUsR0FBWixDQUFQO0VBQ0Q7O0VBRURTLGtCQUFrQixHQUFHO0lBQ25CLE9BQU8sS0FBS1osZUFBWjtFQUNEOztBQXhDd0I7QUEyQzNCLE9BQU8sTUFBTUssS0FBTixDQUFlO0VBUXBCVCxXQUFXLENBQ1RDLFdBRFMsRUFFVEUsVUFGUyxFQUdUO0lBQ0EsS0FBS0ssS0FBTCxHQUFhLEVBQWI7SUFDQSxLQUFLUCxXQUFMLEdBQW1CQSxXQUFuQjtJQUNBLEtBQUtFLFVBQUwsR0FBa0JBLFVBQWxCO0VBQ0Q7O0VBRURjLFFBQVEsQ0FBQ1YsR0FBRCxFQUFjVyxLQUFkLEVBQXdCO0lBQzlCLE1BQU1DLE1BQU0sR0FBRyxLQUFLWCxLQUFMLENBQVdELEdBQVgsQ0FBZjs7SUFDQSxJQUFJWSxNQUFKLEVBQVk7TUFDVixPQUFPQSxNQUFQO0lBQ0Q7O0lBQ0QsTUFBTUMsRUFBRSxHQUFHLEtBQUtuQixXQUFMLENBQWlCb0IsSUFBakIsRUFBWDtJQUNBLEtBQUtiLEtBQUwsQ0FBV0QsR0FBWCxJQUFrQmEsRUFBbEI7SUFDQSxLQUFLakIsVUFBTCxDQUFnQixJQUFoQixFQUFzQmlCLEVBQXRCLEVBQTBCRixLQUExQjtJQUNBLE9BQU9FLEVBQVA7RUFDRDs7QUExQm1CIn0=","const uppercasePattern = /[A-Z]/g;\nconst msPattern = /^ms-/;\nconst cache = {};\nexport default function hyphenateStyleName(prop) {\n return prop in cache ? cache[prop] : cache[prop] = prop.replace(uppercasePattern, \"-$&\").toLowerCase().replace(msPattern, \"-ms-\");\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1cHBlcmNhc2VQYXR0ZXJuIiwibXNQYXR0ZXJuIiwiY2FjaGUiLCJoeXBoZW5hdGVTdHlsZU5hbWUiLCJwcm9wIiwicmVwbGFjZSIsInRvTG93ZXJDYXNlIl0sInNvdXJjZXMiOlsic3JjL2h5cGhlbmF0ZS1zdHlsZS1uYW1lLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHVwcGVyY2FzZVBhdHRlcm4gPSAvW0EtWl0vZztcbmNvbnN0IG1zUGF0dGVybiA9IC9ebXMtLztcbmNvbnN0IGNhY2hlID0ge307XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGh5cGhlbmF0ZVN0eWxlTmFtZShwcm9wOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gcHJvcCBpbiBjYWNoZVxuICAgID8gY2FjaGVbcHJvcF1cbiAgICA6IChjYWNoZVtwcm9wXSA9IHByb3BcbiAgICAgICAgLnJlcGxhY2UodXBwZXJjYXNlUGF0dGVybiwgXCItJCZcIilcbiAgICAgICAgLnRvTG93ZXJDYXNlKClcbiAgICAgICAgLnJlcGxhY2UobXNQYXR0ZXJuLCBcIi1tcy1cIikpO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxNQUFNQSxnQkFBZ0IsR0FBRyxRQUF6QjtBQUNBLE1BQU1DLFNBQVMsR0FBRyxNQUFsQjtBQUNBLE1BQU1DLEtBQUssR0FBRyxFQUFkO0FBRUEsZUFBZSxTQUFTQyxrQkFBVCxDQUE0QkMsSUFBNUIsRUFBa0Q7RUFDL0QsT0FBT0EsSUFBSSxJQUFJRixLQUFSLEdBQ0hBLEtBQUssQ0FBQ0UsSUFBRCxDQURGLEdBRUZGLEtBQUssQ0FBQ0UsSUFBRCxDQUFMLEdBQWNBLElBQUksQ0FDaEJDLE9BRFksQ0FDSkwsZ0JBREksRUFDYyxLQURkLEVBRVpNLFdBRlksR0FHWkQsT0FIWSxDQUdKSixTQUhJLEVBR08sTUFIUCxDQUZuQjtBQU1EIn0=","export default function capitalizeString(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}","import capitalizeString from './capitalizeString';\n\n\nexport default function prefixProperty(prefixProperties, property, style) {\n if (prefixProperties.hasOwnProperty(property)) {\n var newStyle = {};\n var requiredPrefixes = prefixProperties[property];\n var capitalizedProperty = capitalizeString(property);\n var keys = Object.keys(style);\n for (var i = 0; i < keys.length; i++) {\n var styleProperty = keys[i];\n if (styleProperty === property) {\n for (var j = 0; j < requiredPrefixes.length; j++) {\n newStyle[requiredPrefixes[j] + capitalizedProperty] = style[property];\n }\n }\n newStyle[styleProperty] = style[styleProperty];\n }\n return newStyle;\n }\n return style;\n}","export default function prefixValue(plugins, property, value, style, metaData) {\n for (var i = 0, len = plugins.length; i < len; ++i) {\n var processedValue = plugins[i](property, value, style, metaData);\n\n // we can stop processing if a value is returned\n // as all plugin criteria are unique\n if (processedValue) {\n return processedValue;\n }\n }\n}","function addIfNew(list, value) {\n if (list.indexOf(value) === -1) {\n list.push(value);\n }\n}\n\nexport default function addNewValuesOnly(list, values) {\n if (Array.isArray(values)) {\n for (var i = 0, len = values.length; i < len; ++i) {\n addIfNew(list, values[i]);\n }\n } else {\n addIfNew(list, values);\n }\n}","export default function isObject(value) {\n return value instanceof Object && !Array.isArray(value);\n}","\nvar w = [\"Webkit\"];\nvar m = [\"Moz\"];\nvar ms = [\"ms\"];\nvar wm = [\"Webkit\", \"Moz\"];\nvar wms = [\"Webkit\", \"ms\"];\nvar wmms = [\"Webkit\", \"Moz\", \"ms\"];\n\nexport default {\n plugins: [],\n prefixMap: { \"appearance\": wm, \"textEmphasisPosition\": w, \"textEmphasis\": w, \"textEmphasisStyle\": w, \"textEmphasisColor\": w, \"boxDecorationBreak\": w, \"maskImage\": w, \"maskMode\": w, \"maskRepeat\": w, \"maskPosition\": w, \"maskClip\": w, \"maskOrigin\": w, \"maskSize\": w, \"maskComposite\": w, \"mask\": w, \"maskBorderSource\": w, \"maskBorderMode\": w, \"maskBorderSlice\": w, \"maskBorderWidth\": w, \"maskBorderOutset\": w, \"maskBorderRepeat\": w, \"maskBorder\": w, \"maskType\": w, \"textDecorationStyle\": w, \"textDecorationSkip\": w, \"textDecorationLine\": w, \"textDecorationColor\": w, \"userSelect\": wmms, \"backdropFilter\": w, \"fontKerning\": w, \"scrollSnapType\": wms, \"scrollSnapPointsX\": wms, \"scrollSnapPointsY\": wms, \"scrollSnapDestination\": wms, \"scrollSnapCoordinate\": wms, \"clipPath\": w, \"shapeImageThreshold\": w, \"shapeImageMargin\": w, \"shapeImageOutside\": w, \"filter\": w, \"hyphens\": wms, \"flowInto\": wms, \"flowFrom\": wms, \"breakBefore\": wms, \"breakAfter\": wms, \"breakInside\": wms, \"regionFragment\": wms, \"writingMode\": wms, \"textOrientation\": w, \"tabSize\": m, \"fontFeatureSettings\": w, \"columnCount\": w, \"columnFill\": w, \"columnGap\": w, \"columnRule\": w, \"columnRuleColor\": w, \"columnRuleStyle\": w, \"columnRuleWidth\": w, \"columns\": w, \"columnSpan\": w, \"columnWidth\": w, \"wrapFlow\": ms, \"wrapThrough\": ms, \"wrapMargin\": ms, \"textSizeAdjust\": wms }\n};","var prefixes = ['-webkit-', '-moz-', ''];\n\nvar values = {\n 'zoom-in': true,\n 'zoom-out': true,\n grab: true,\n grabbing: true\n};\n\nexport default function cursor(property, value) {\n if (property === 'cursor' && values.hasOwnProperty(value)) {\n return prefixes.map(function (prefix) {\n return prefix + value;\n });\n }\n}","import isPrefixedValue from 'css-in-js-utils/lib/isPrefixedValue';\n\n// http://caniuse.com/#search=cross-fade\nvar prefixes = ['-webkit-', ''];\n\nexport default function crossFade(property, value) {\n if (typeof value === 'string' && !isPrefixedValue(value) && value.indexOf('cross-fade(') > -1) {\n return prefixes.map(function (prefix) {\n return value.replace(/cross-fade\\(/g, prefix + 'cross-fade(');\n });\n }\n}","import isPrefixedValue from 'css-in-js-utils/lib/isPrefixedValue';\n\n// http://caniuse.com/#feat=css-filter-function\nvar prefixes = ['-webkit-', ''];\n\nexport default function filter(property, value) {\n if (typeof value === 'string' && !isPrefixedValue(value) && value.indexOf('filter(') > -1) {\n return prefixes.map(function (prefix) {\n return value.replace(/filter\\(/g, prefix + 'filter(');\n });\n }\n}","var values = {\n flex: ['-webkit-box', '-moz-box', '-ms-flexbox', '-webkit-flex', 'flex'],\n 'inline-flex': ['-webkit-inline-box', '-moz-inline-box', '-ms-inline-flexbox', '-webkit-inline-flex', 'inline-flex']\n};\n\nexport default function flex(property, value) {\n if (property === 'display' && values.hasOwnProperty(value)) {\n return values[value];\n }\n}","var alternativeValues = {\n 'space-around': 'justify',\n 'space-between': 'justify',\n 'flex-start': 'start',\n 'flex-end': 'end',\n 'wrap-reverse': 'multiple',\n wrap: 'multiple'\n};\n\nvar alternativeProps = {\n alignItems: 'WebkitBoxAlign',\n justifyContent: 'WebkitBoxPack',\n flexWrap: 'WebkitBoxLines',\n flexGrow: 'WebkitBoxFlex'\n};\n\nexport default function flexboxOld(property, value, style) {\n if (property === 'flexDirection' && typeof value === 'string') {\n if (value.indexOf('column') > -1) {\n style.WebkitBoxOrient = 'vertical';\n } else {\n style.WebkitBoxOrient = 'horizontal';\n }\n if (value.indexOf('reverse') > -1) {\n style.WebkitBoxDirection = 'reverse';\n } else {\n style.WebkitBoxDirection = 'normal';\n }\n }\n if (alternativeProps.hasOwnProperty(property)) {\n style[alternativeProps[property]] = alternativeValues[value] || value;\n }\n}","import isPrefixedValue from 'css-in-js-utils/lib/isPrefixedValue';\n\nvar prefixes = ['-webkit-', '-moz-', ''];\nvar values = /linear-gradient|radial-gradient|repeating-linear-gradient|repeating-radial-gradient/gi;\n\nexport default function gradient(property, value) {\n if (typeof value === 'string' && !isPrefixedValue(value) && values.test(value)) {\n return prefixes.map(function (prefix) {\n return value.replace(values, function (grad) {\n return prefix + grad;\n });\n });\n }\n}","var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nfunction isSimplePositionValue(value) {\n return typeof value === 'number' && !isNaN(value);\n}\n\nfunction isComplexSpanValue(value) {\n return typeof value === 'string' && value.includes('/');\n}\n\nvar alignmentValues = ['center', 'end', 'start', 'stretch'];\n\nvar displayValues = {\n 'inline-grid': ['-ms-inline-grid', 'inline-grid'],\n grid: ['-ms-grid', 'grid']\n};\n\nvar propertyConverters = {\n alignSelf: function alignSelf(value, style) {\n if (alignmentValues.indexOf(value) > -1) {\n style.msGridRowAlign = value;\n }\n },\n\n gridColumn: function gridColumn(value, style) {\n if (isSimplePositionValue(value)) {\n style.msGridColumn = value;\n } else if (isComplexSpanValue(value)) {\n var _value$split = value.split('/'),\n _value$split2 = _slicedToArray(_value$split, 2),\n start = _value$split2[0],\n end = _value$split2[1];\n\n propertyConverters.gridColumnStart(+start, style);\n\n var _end$split = end.split(/ ?span /),\n _end$split2 = _slicedToArray(_end$split, 2),\n maybeSpan = _end$split2[0],\n maybeNumber = _end$split2[1];\n\n if (maybeSpan === '') {\n propertyConverters.gridColumnEnd(+start + +maybeNumber, style);\n } else {\n propertyConverters.gridColumnEnd(+end, style);\n }\n } else {\n propertyConverters.gridColumnStart(value, style);\n }\n },\n\n gridColumnEnd: function gridColumnEnd(value, style) {\n var msGridColumn = style.msGridColumn;\n\n if (isSimplePositionValue(value) && isSimplePositionValue(msGridColumn)) {\n style.msGridColumnSpan = value - msGridColumn;\n }\n },\n\n gridColumnStart: function gridColumnStart(value, style) {\n if (isSimplePositionValue(value)) {\n style.msGridColumn = value;\n }\n },\n\n gridRow: function gridRow(value, style) {\n if (isSimplePositionValue(value)) {\n style.msGridRow = value;\n } else if (isComplexSpanValue(value)) {\n var _value$split3 = value.split('/'),\n _value$split4 = _slicedToArray(_value$split3, 2),\n start = _value$split4[0],\n end = _value$split4[1];\n\n propertyConverters.gridRowStart(+start, style);\n\n var _end$split3 = end.split(/ ?span /),\n _end$split4 = _slicedToArray(_end$split3, 2),\n maybeSpan = _end$split4[0],\n maybeNumber = _end$split4[1];\n\n if (maybeSpan === '') {\n propertyConverters.gridRowEnd(+start + +maybeNumber, style);\n } else {\n propertyConverters.gridRowEnd(+end, style);\n }\n } else {\n propertyConverters.gridRowStart(value, style);\n }\n },\n\n gridRowEnd: function gridRowEnd(value, style) {\n var msGridRow = style.msGridRow;\n\n if (isSimplePositionValue(value) && isSimplePositionValue(msGridRow)) {\n style.msGridRowSpan = value - msGridRow;\n }\n },\n\n gridRowStart: function gridRowStart(value, style) {\n if (isSimplePositionValue(value)) {\n style.msGridRow = value;\n }\n },\n\n gridTemplateColumns: function gridTemplateColumns(value, style) {\n style.msGridColumns = value;\n },\n\n gridTemplateRows: function gridTemplateRows(value, style) {\n style.msGridRows = value;\n },\n\n justifySelf: function justifySelf(value, style) {\n if (alignmentValues.indexOf(value) > -1) {\n style.msGridColumnAlign = value;\n }\n }\n};\n\nexport default function grid(property, value, style) {\n if (property === 'display' && value in displayValues) {\n return displayValues[value];\n }\n\n if (property in propertyConverters) {\n var propertyConverter = propertyConverters[property];\n propertyConverter(value, style);\n }\n}","import isPrefixedValue from 'css-in-js-utils/lib/isPrefixedValue';\n\n// http://caniuse.com/#feat=css-image-set\nvar prefixes = ['-webkit-', ''];\n\nexport default function imageSet(property, value) {\n if (typeof value === 'string' && !isPrefixedValue(value) && value.indexOf('image-set(') > -1) {\n return prefixes.map(function (prefix) {\n return value.replace(/image-set\\(/g, prefix + 'image-set(');\n });\n }\n}","var alternativeProps = {\n marginBlockStart: ['WebkitMarginBefore'],\n marginBlockEnd: ['WebkitMarginAfter'],\n marginInlineStart: ['WebkitMarginStart', 'MozMarginStart'],\n marginInlineEnd: ['WebkitMarginEnd', 'MozMarginEnd'],\n paddingBlockStart: ['WebkitPaddingBefore'],\n paddingBlockEnd: ['WebkitPaddingAfter'],\n paddingInlineStart: ['WebkitPaddingStart', 'MozPaddingStart'],\n paddingInlineEnd: ['WebkitPaddingEnd', 'MozPaddingEnd'],\n borderBlockStart: ['WebkitBorderBefore'],\n borderBlockStartColor: ['WebkitBorderBeforeColor'],\n borderBlockStartStyle: ['WebkitBorderBeforeStyle'],\n borderBlockStartWidth: ['WebkitBorderBeforeWidth'],\n borderBlockEnd: ['WebkitBorderAfter'],\n borderBlockEndColor: ['WebkitBorderAfterColor'],\n borderBlockEndStyle: ['WebkitBorderAfterStyle'],\n borderBlockEndWidth: ['WebkitBorderAfterWidth'],\n borderInlineStart: ['WebkitBorderStart', 'MozBorderStart'],\n borderInlineStartColor: ['WebkitBorderStartColor', 'MozBorderStartColor'],\n borderInlineStartStyle: ['WebkitBorderStartStyle', 'MozBorderStartStyle'],\n borderInlineStartWidth: ['WebkitBorderStartWidth', 'MozBorderStartWidth'],\n borderInlineEnd: ['WebkitBorderEnd', 'MozBorderEnd'],\n borderInlineEndColor: ['WebkitBorderEndColor', 'MozBorderEndColor'],\n borderInlineEndStyle: ['WebkitBorderEndStyle', 'MozBorderEndStyle'],\n borderInlineEndWidth: ['WebkitBorderEndWidth', 'MozBorderEndWidth']\n};\n\nexport default function logical(property, value, style) {\n if (Object.prototype.hasOwnProperty.call(alternativeProps, property)) {\n var alternativePropList = alternativeProps[property];\n for (var i = 0, len = alternativePropList.length; i < len; ++i) {\n style[alternativePropList[i]] = value;\n }\n }\n}","var prefixes = ['-webkit-', '-moz-', ''];\n\nvar properties = {\n maxHeight: true,\n maxWidth: true,\n width: true,\n height: true,\n columnWidth: true,\n minWidth: true,\n minHeight: true\n};\nvar values = {\n 'min-content': true,\n 'max-content': true,\n 'fill-available': true,\n 'fit-content': true,\n 'contain-floats': true\n};\n\nexport default function sizing(property, value) {\n if (properties.hasOwnProperty(property) && values.hasOwnProperty(value)) {\n return prefixes.map(function (prefix) {\n return prefix + value;\n });\n }\n}","import hyphenateProperty from 'css-in-js-utils/lib/hyphenateProperty';\nimport isPrefixedValue from 'css-in-js-utils/lib/isPrefixedValue';\n\nimport capitalizeString from '../utils/capitalizeString';\n\nvar properties = {\n transition: true,\n transitionProperty: true,\n WebkitTransition: true,\n WebkitTransitionProperty: true,\n MozTransition: true,\n MozTransitionProperty: true\n};\n\nvar prefixMapping = {\n Webkit: '-webkit-',\n Moz: '-moz-',\n ms: '-ms-'\n};\n\nfunction prefixValue(value, propertyPrefixMap) {\n if (isPrefixedValue(value)) {\n return value;\n }\n\n // only split multi values, not cubic beziers\n var multipleValues = value.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g);\n\n for (var i = 0, len = multipleValues.length; i < len; ++i) {\n var singleValue = multipleValues[i];\n var values = [singleValue];\n for (var property in propertyPrefixMap) {\n var dashCaseProperty = hyphenateProperty(property);\n\n if (singleValue.indexOf(dashCaseProperty) > -1 && dashCaseProperty !== 'order') {\n var prefixes = propertyPrefixMap[property];\n for (var j = 0, pLen = prefixes.length; j < pLen; ++j) {\n // join all prefixes and create a new value\n values.unshift(singleValue.replace(dashCaseProperty, prefixMapping[prefixes[j]] + dashCaseProperty));\n }\n }\n }\n\n multipleValues[i] = values.join(',');\n }\n\n return multipleValues.join(',');\n}\n\nexport default function transition(property, value, style, propertyPrefixMap) {\n // also check for already prefixed transitions\n if (typeof value === 'string' && properties.hasOwnProperty(property)) {\n var outputValue = prefixValue(value, propertyPrefixMap);\n // if the property is already prefixed\n var webkitOutput = outputValue.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g).filter(function (val) {\n return !/-moz-|-ms-/.test(val);\n }).join(',');\n\n if (property.indexOf('Webkit') > -1) {\n return webkitOutput;\n }\n\n var mozOutput = outputValue.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g).filter(function (val) {\n return !/-webkit-|-ms-/.test(val);\n }).join(',');\n\n if (property.indexOf('Moz') > -1) {\n return mozOutput;\n }\n\n style['Webkit' + capitalizeString(property)] = webkitOutput;\n style['Moz' + capitalizeString(property)] = mozOutput;\n return outputValue;\n }\n}","import createPrefixer from './createPrefixer';\n\nimport data from './data';\n\nimport backgroundClip from './plugins/backgroundClip';\nimport cursor from './plugins/cursor';\nimport crossFade from './plugins/crossFade';\nimport filter from './plugins/filter';\nimport flex from './plugins/flex';\nimport flexboxOld from './plugins/flexboxOld';\nimport gradient from './plugins/gradient';\nimport grid from './plugins/grid';\nimport imageSet from './plugins/imageSet';\nimport logical from './plugins/logical';\nimport position from './plugins/position';\nimport sizing from './plugins/sizing';\nimport transition from './plugins/transition';\n\nvar plugins = [backgroundClip, crossFade, cursor, filter, flexboxOld, gradient, grid, imageSet, logical, position, sizing, transition, flex];\n\nvar prefix = createPrefixer({\n prefixMap: data.prefixMap,\n plugins: plugins\n});\n\nexport { createPrefixer, prefix };","\n// https://developer.mozilla.org/en-US/docs/Web/CSS/background-clip#Browser_compatibility\nexport default function backgroundClip(property, value) {\n if (typeof value === 'string' && value === 'text') {\n return ['-webkit-text', 'text'];\n }\n}","export default function position(property, value) {\n if (property === 'position' && value === 'sticky') {\n return ['-webkit-sticky', 'sticky'];\n }\n}","import prefixProperty from './utils/prefixProperty';\nimport prefixValue from './utils/prefixValue';\n\nimport addNewValuesOnly from './utils/addNewValuesOnly';\nimport isObject from './utils/isObject';\n\nexport default function createPrefixer(_ref) {\n var prefixMap = _ref.prefixMap,\n plugins = _ref.plugins;\n\n return function prefix(style) {\n for (var property in style) {\n var value = style[property];\n\n // handle nested objects\n if (isObject(value)) {\n style[property] = prefix(value);\n // handle array values\n } else if (Array.isArray(value)) {\n var combinedValue = [];\n\n for (var i = 0, len = value.length; i < len; ++i) {\n var processedValue = prefixValue(plugins, property, value[i], style, prefixMap);\n addNewValuesOnly(combinedValue, processedValue || value[i]);\n }\n\n // only modify the value if it was touched\n // by any plugin to prevent unnecessary mutations\n if (combinedValue.length > 0) {\n style[property] = combinedValue;\n }\n } else {\n var _processedValue = prefixValue(plugins, property, value, style, prefixMap);\n\n // only modify the value if it was touched\n // by any plugin to prevent unnecessary mutations\n if (_processedValue) {\n style[property] = _processedValue;\n }\n\n style = prefixProperty(prefixMap, property, style);\n }\n }\n\n return style;\n };\n}","import hyphenate from \"./hyphenate-style-name\";\nimport { validateNoMixedHand } from \"./validate-no-mixed-hand\";\nimport { prefix } from \"inline-style-prefixer\";\nimport { MultiCache } from \"./cache\";\nexport default function injectStylePrefixed(styleCache, styles, media, pseudo) {\n const cache = styleCache.getCache(media);\n let classString = \"\";\n\n for (const originalKey in styles) {\n const originalVal = styles[originalKey];\n\n if (originalVal === void 0 || originalVal === null) {\n continue;\n }\n\n if (typeof originalVal !== \"object\") {\n // Non-null and non-undefined primitive value\n if (process.env.NODE_ENV !== \"production\") {\n validateValueType(originalVal, originalKey);\n }\n\n const propValPair = `${hyphenate(originalKey)}:${originalVal}`;\n const key = `${pseudo}${propValPair}`;\n const cachedId = cache.cache[key];\n\n if (cachedId !== void 0) {\n // cache hit\n classString += \" \" + cachedId;\n continue;\n } else {\n // cache miss\n let block = \"\";\n const prefixed = prefix({\n [originalKey]: originalVal\n });\n\n for (const prefixedKey in prefixed) {\n const prefixedVal = prefixed[prefixedKey];\n const prefixedValType = typeof prefixedVal;\n\n if (prefixedValType === \"string\" || prefixedValType === \"number\") {\n const prefixedPair = `${hyphenate(prefixedKey)}:${prefixedVal}`;\n\n if (prefixedPair !== propValPair) {\n block += `${prefixedPair};`;\n }\n } else if (Array.isArray(prefixedVal)) {\n const hyphenated = hyphenate(prefixedKey);\n\n for (let i = 0; i < prefixedVal.length; i++) {\n const prefixedPair = `${hyphenated}:${prefixedVal[i]}`;\n\n if (prefixedPair !== propValPair) {\n block += `${prefixedPair};`;\n }\n }\n }\n }\n\n block += propValPair; // ensure original prop/val is last (for hydration)\n\n const id = cache.addValue(key, {\n pseudo,\n block\n });\n classString += \" \" + id;\n }\n } else {\n // Non-null object value\n if (originalKey[0] === \":\") {\n classString += \" \" + injectStylePrefixed(styleCache, originalVal, media, pseudo + originalKey);\n } else if (originalKey.substring(0, 6) === \"@media\") {\n classString += \" \" + injectStylePrefixed(styleCache, originalVal, originalKey.substr(7), pseudo);\n }\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n const conflicts = validateNoMixedHand(styles);\n\n if (conflicts.length) {\n conflicts.forEach(({\n shorthand,\n longhand\n }) => {\n const short = JSON.stringify({\n [shorthand.property]: shorthand.value\n });\n const long = JSON.stringify({\n [longhand.property]: longhand.value\n }); // eslint-disable-next-line no-console\n\n console.warn(`Styles \\`${short}\\` and \\`${long}\\` in object yielding class \"${classString.slice(1)}\" may result in unexpected behavior. Mixing shorthand and longhand properties within the same style object is unsupported with atomic rendering.`);\n });\n }\n } // remove leading space\n\n\n return classString.slice(1);\n}\n\nfunction validateValueType(value, key) {\n if (value === null || Array.isArray(value) || typeof value !== \"number\" && typeof value !== \"string\") {\n throw new Error(`Unsupported style value: ${JSON.stringify(value)} used in property ${JSON.stringify(key)}`);\n }\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["hyphenate","validateNoMixedHand","prefix","MultiCache","injectStylePrefixed","styleCache","styles","media","pseudo","cache","getCache","classString","originalKey","originalVal","validateValueType","propValPair","key","cachedId","block","prefixed","prefixedKey","prefixedVal","prefixedValType","prefixedPair","Array","isArray","hyphenated","i","length","id","addValue","substring","substr","conflicts","forEach","shorthand","longhand","short","JSON","stringify","property","value","long","console","warn","slice","Error"],"sources":["src/inject-style-prefixed.ts"],"sourcesContent":["declare var __DEV__: boolean;\n\nimport hyphenate from \"./hyphenate-style-name\";\nimport {validateNoMixedHand} from \"./validate-no-mixed-hand\";\nimport {prefix} from \"inline-style-prefixer\";\n\nimport type {StyleObject} from \"styletron-standard\";\n\nimport {MultiCache} from \"./cache\";\n\nexport default function injectStylePrefixed(\n  styleCache: MultiCache<{\n    pseudo: string;\n    block: string;\n  }>,\n  styles: StyleObject,\n  media: string,\n  pseudo: string,\n) {\n  const cache = styleCache.getCache(media);\n  let classString = \"\";\n  for (const originalKey in styles) {\n    const originalVal = styles[originalKey];\n\n    if (originalVal === void 0 || originalVal === null) {\n      continue;\n    }\n    if (typeof originalVal !== \"object\") {\n      // Non-null and non-undefined primitive value\n      if (__DEV__) {\n        validateValueType(originalVal, originalKey);\n      }\n\n      const propValPair = `${hyphenate(originalKey)}:${\n        originalVal as any as string\n      }`;\n      const key = `${pseudo}${propValPair}`;\n      const cachedId = cache.cache[key];\n      if (cachedId !== void 0) {\n        // cache hit\n        classString += \" \" + cachedId;\n        continue;\n      } else {\n        // cache miss\n        let block = \"\";\n        const prefixed = prefix({[originalKey]: originalVal});\n        for (const prefixedKey in prefixed) {\n          const prefixedVal = prefixed[prefixedKey];\n          const prefixedValType = typeof prefixedVal;\n          if (prefixedValType === \"string\" || prefixedValType === \"number\") {\n            const prefixedPair = `${hyphenate(prefixedKey)}:${prefixedVal}`;\n            if (prefixedPair !== propValPair) {\n              block += `${prefixedPair};`;\n            }\n          } else if (Array.isArray(prefixedVal)) {\n            const hyphenated = hyphenate(prefixedKey);\n            for (let i = 0; i < prefixedVal.length; i++) {\n              const prefixedPair = `${hyphenated}:${prefixedVal[i]}`;\n              if (prefixedPair !== propValPair) {\n                block += `${prefixedPair};`;\n              }\n            }\n          }\n        }\n        block += propValPair; // ensure original prop/val is last (for hydration)\n        const id = cache.addValue(key, {pseudo, block});\n        classString += \" \" + id;\n      }\n    } else {\n      // Non-null object value\n      if (originalKey[0] === \":\") {\n        classString +=\n          \" \" +\n          injectStylePrefixed(\n            styleCache,\n            originalVal as StyleObject,\n            media,\n            pseudo + originalKey,\n          );\n      } else if (originalKey.substring(0, 6) === \"@media\") {\n        classString +=\n          \" \" +\n          injectStylePrefixed(\n            styleCache,\n            originalVal as StyleObject,\n            originalKey.substr(7),\n            pseudo,\n          );\n      }\n    }\n  }\n\n  if (__DEV__) {\n    const conflicts = validateNoMixedHand(styles);\n    if (conflicts.length) {\n      conflicts.forEach(({shorthand, longhand}) => {\n        const short = JSON.stringify({[shorthand.property]: shorthand.value});\n        const long = JSON.stringify({[longhand.property]: longhand.value});\n        // eslint-disable-next-line no-console\n        console.warn(\n          `Styles \\`${short}\\` and \\`${long}\\` in object yielding class \"${classString.slice(\n            1,\n          )}\" may result in unexpected behavior. Mixing shorthand and longhand properties within the same style object is unsupported with atomic rendering.`,\n        );\n      });\n    }\n  }\n\n  // remove leading space\n  return classString.slice(1);\n}\n\nfunction validateValueType(value, key) {\n  if (\n    value === null ||\n    Array.isArray(value) ||\n    (typeof value !== \"number\" && typeof value !== \"string\")\n  ) {\n    throw new Error(\n      `Unsupported style value: ${JSON.stringify(\n        value,\n      )} used in property ${JSON.stringify(key)}`,\n    );\n  }\n}\n"],"mappings":"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"}","import hyphenate from \"./hyphenate-style-name\";\nimport validateKeyframesObject from \"./validate-keyframes-object\";\nexport function atomicSelector(id, pseudo) {\n let selector = `.${id}`;\n\n if (pseudo) {\n selector += pseudo;\n }\n\n return selector;\n}\nexport function keyframesToBlock(keyframes) {\n if (process.env.NODE_ENV !== \"production\") {\n validateKeyframesObject(keyframes);\n }\n\n if (process.env.NODE_ENV !== \"production\" && typeof Object.getPrototypeOf(keyframes) !== \"undefined\") {\n if (Object.getPrototypeOf(keyframes) !== Object.getPrototypeOf({})) {\n // eslint-disable-next-line no-console\n console.warn(\"Only plain objects should be used as animation values. Unexpectedly recieved:\", keyframes);\n }\n }\n\n let result = \"\";\n\n for (const animationState in keyframes) {\n result += `${animationState}{${declarationsToBlock(keyframes[animationState])}}`;\n }\n\n return result;\n}\nexport function declarationsToBlock(style) {\n let css = \"\";\n\n for (const prop in style) {\n const val = style[prop];\n\n if (typeof val === \"string\" || typeof val === \"number\") {\n css += `${hyphenate(prop)}:${val};`;\n }\n } // trim trailing semicolon\n\n\n return css.slice(0, -1);\n}\nexport function keyframesBlockToRule(id, block) {\n return `@keyframes ${id}{${block}}`;\n}\nexport function fontFaceBlockToRule(id, block) {\n return `@font-face{font-family:${id};${block}}`;\n}\nexport function styleBlockToRule(selector, block) {\n return `${selector}{${block}}`;\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJoeXBoZW5hdGUiLCJ2YWxpZGF0ZUtleWZyYW1lc09iamVjdCIsImF0b21pY1NlbGVjdG9yIiwiaWQiLCJwc2V1ZG8iLCJzZWxlY3RvciIsImtleWZyYW1lc1RvQmxvY2siLCJrZXlmcmFtZXMiLCJPYmplY3QiLCJnZXRQcm90b3R5cGVPZiIsImNvbnNvbGUiLCJ3YXJuIiwicmVzdWx0IiwiYW5pbWF0aW9uU3RhdGUiLCJkZWNsYXJhdGlvbnNUb0Jsb2NrIiwic3R5bGUiLCJjc3MiLCJwcm9wIiwidmFsIiwic2xpY2UiLCJrZXlmcmFtZXNCbG9ja1RvUnVsZSIsImJsb2NrIiwiZm9udEZhY2VCbG9ja1RvUnVsZSIsInN0eWxlQmxvY2tUb1J1bGUiXSwic291cmNlcyI6WyJzcmMvY3NzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImRlY2xhcmUgdmFyIF9fREVWX186IGJvb2xlYW47XG5cbmltcG9ydCBoeXBoZW5hdGUgZnJvbSBcIi4vaHlwaGVuYXRlLXN0eWxlLW5hbWVcIjtcbmltcG9ydCB2YWxpZGF0ZUtleWZyYW1lc09iamVjdCBmcm9tIFwiLi92YWxpZGF0ZS1rZXlmcmFtZXMtb2JqZWN0XCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBhdG9taWNTZWxlY3RvcihpZDogc3RyaW5nLCBwc2V1ZG86IHN0cmluZyk6IHN0cmluZyB7XG4gIGxldCBzZWxlY3RvciA9IGAuJHtpZH1gO1xuICBpZiAocHNldWRvKSB7XG4gICAgc2VsZWN0b3IgKz0gcHNldWRvO1xuICB9XG4gIHJldHVybiBzZWxlY3Rvcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGtleWZyYW1lc1RvQmxvY2soa2V5ZnJhbWVzOiB7W3g6IHN0cmluZ106IGFueX0pOiBzdHJpbmcge1xuICBpZiAoX19ERVZfXykge1xuICAgIHZhbGlkYXRlS2V5ZnJhbWVzT2JqZWN0KGtleWZyYW1lcyk7XG4gIH1cbiAgaWYgKF9fREVWX18gJiYgdHlwZW9mIE9iamVjdC5nZXRQcm90b3R5cGVPZihrZXlmcmFtZXMpICE9PSBcInVuZGVmaW5lZFwiKSB7XG4gICAgaWYgKE9iamVjdC5nZXRQcm90b3R5cGVPZihrZXlmcmFtZXMpICE9PSBPYmplY3QuZ2V0UHJvdG90eXBlT2Yoe30pKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICBcIk9ubHkgcGxhaW4gb2JqZWN0cyBzaG91bGQgYmUgdXNlZCBhcyBhbmltYXRpb24gdmFsdWVzLiBVbmV4cGVjdGVkbHkgcmVjaWV2ZWQ6XCIsXG4gICAgICAgIGtleWZyYW1lcyxcbiAgICAgICk7XG4gICAgfVxuICB9XG4gIGxldCByZXN1bHQgPSBcIlwiO1xuICBmb3IgKGNvbnN0IGFuaW1hdGlvblN0YXRlIGluIGtleWZyYW1lcykge1xuICAgIHJlc3VsdCArPSBgJHthbmltYXRpb25TdGF0ZX17JHtkZWNsYXJhdGlvbnNUb0Jsb2NrKFxuICAgICAga2V5ZnJhbWVzW2FuaW1hdGlvblN0YXRlXSxcbiAgICApfX1gO1xuICB9XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWNsYXJhdGlvbnNUb0Jsb2NrKHN0eWxlOiBhbnkpOiBzdHJpbmcge1xuICBsZXQgY3NzID0gXCJcIjtcbiAgZm9yIChjb25zdCBwcm9wIGluIHN0eWxlKSB7XG4gICAgY29uc3QgdmFsID0gc3R5bGVbcHJvcF07XG4gICAgaWYgKHR5cGVvZiB2YWwgPT09IFwic3RyaW5nXCIgfHwgdHlwZW9mIHZhbCA9PT0gXCJudW1iZXJcIikge1xuICAgICAgY3NzICs9IGAke2h5cGhlbmF0ZShwcm9wKX06JHt2YWx9O2A7XG4gICAgfVxuICB9XG4gIC8vIHRyaW0gdHJhaWxpbmcgc2VtaWNvbG9uXG4gIHJldHVybiBjc3Muc2xpY2UoMCwgLTEpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24ga2V5ZnJhbWVzQmxvY2tUb1J1bGUoaWQ6IHN0cmluZywgYmxvY2s6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgQGtleWZyYW1lcyAke2lkfXske2Jsb2NrfX1gO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9udEZhY2VCbG9ja1RvUnVsZShpZDogc3RyaW5nLCBibG9jazogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIGBAZm9udC1mYWNle2ZvbnQtZmFtaWx5OiR7aWR9OyR7YmxvY2t9fWA7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzdHlsZUJsb2NrVG9SdWxlKHNlbGVjdG9yOiBzdHJpbmcsIGJsb2NrOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gYCR7c2VsZWN0b3J9eyR7YmxvY2t9fWA7XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLE9BQU9BLFNBQVAsTUFBc0Isd0JBQXRCO0FBQ0EsT0FBT0MsdUJBQVAsTUFBb0MsNkJBQXBDO0FBRUEsT0FBTyxTQUFTQyxjQUFULENBQXdCQyxFQUF4QixFQUFvQ0MsTUFBcEMsRUFBNEQ7RUFDakUsSUFBSUMsUUFBUSxHQUFJLElBQUdGLEVBQUcsRUFBdEI7O0VBQ0EsSUFBSUMsTUFBSixFQUFZO0lBQ1ZDLFFBQVEsSUFBSUQsTUFBWjtFQUNEOztFQUNELE9BQU9DLFFBQVA7QUFDRDtBQUVELE9BQU8sU0FBU0MsZ0JBQVQsQ0FBMEJDLFNBQTFCLEVBQWlFO0VBQ3RFLDJDQUFhO0lBQ1hOLHVCQUF1QixDQUFDTSxTQUFELENBQXZCO0VBQ0Q7O0VBQ0QsSUFBSSx5Q0FBVyxPQUFPQyxNQUFNLENBQUNDLGNBQVAsQ0FBc0JGLFNBQXRCLENBQVAsS0FBNEMsV0FBM0QsRUFBd0U7SUFDdEUsSUFBSUMsTUFBTSxDQUFDQyxjQUFQLENBQXNCRixTQUF0QixNQUFxQ0MsTUFBTSxDQUFDQyxjQUFQLENBQXNCLEVBQXRCLENBQXpDLEVBQW9FO01BQ2xFO01BQ0FDLE9BQU8sQ0FBQ0MsSUFBUixDQUNFLCtFQURGLEVBRUVKLFNBRkY7SUFJRDtFQUNGOztFQUNELElBQUlLLE1BQU0sR0FBRyxFQUFiOztFQUNBLEtBQUssTUFBTUMsY0FBWCxJQUE2Qk4sU0FBN0IsRUFBd0M7SUFDdENLLE1BQU0sSUFBSyxHQUFFQyxjQUFlLElBQUdDLG1CQUFtQixDQUNoRFAsU0FBUyxDQUFDTSxjQUFELENBRHVDLENBRWhELEdBRkY7RUFHRDs7RUFDRCxPQUFPRCxNQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNFLG1CQUFULENBQTZCQyxLQUE3QixFQUFpRDtFQUN0RCxJQUFJQyxHQUFHLEdBQUcsRUFBVjs7RUFDQSxLQUFLLE1BQU1DLElBQVgsSUFBbUJGLEtBQW5CLEVBQTBCO0lBQ3hCLE1BQU1HLEdBQUcsR0FBR0gsS0FBSyxDQUFDRSxJQUFELENBQWpCOztJQUNBLElBQUksT0FBT0MsR0FBUCxLQUFlLFFBQWYsSUFBMkIsT0FBT0EsR0FBUCxLQUFlLFFBQTlDLEVBQXdEO01BQ3RERixHQUFHLElBQUssR0FBRWhCLFNBQVMsQ0FBQ2lCLElBQUQsQ0FBTyxJQUFHQyxHQUFJLEdBQWpDO0lBQ0Q7RUFDRixDQVBxRCxDQVF0RDs7O0VBQ0EsT0FBT0YsR0FBRyxDQUFDRyxLQUFKLENBQVUsQ0FBVixFQUFhLENBQUMsQ0FBZCxDQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNDLG9CQUFULENBQThCakIsRUFBOUIsRUFBMENrQixLQUExQyxFQUFpRTtFQUN0RSxPQUFRLGNBQWFsQixFQUFHLElBQUdrQixLQUFNLEdBQWpDO0FBQ0Q7QUFFRCxPQUFPLFNBQVNDLG1CQUFULENBQTZCbkIsRUFBN0IsRUFBeUNrQixLQUF6QyxFQUFnRTtFQUNyRSxPQUFRLDBCQUF5QmxCLEVBQUcsSUFBR2tCLEtBQU0sR0FBN0M7QUFDRDtBQUVELE9BQU8sU0FBU0UsZ0JBQVQsQ0FBMEJsQixRQUExQixFQUE0Q2dCLEtBQTVDLEVBQW1FO0VBQ3hFLE9BQVEsR0FBRWhCLFFBQVMsSUFBR2dCLEtBQU0sR0FBNUI7QUFDRCJ9","/* eslint-env browser */\nconst STYLES_HYDRATOR = /\\.([^{:]+)(:[^{]+)?{(?:[^}]*;)?([^}]*?)}/g;\nconst KEYFRAMES_HYRDATOR = /@keyframes ([^{]+){((?:(?:from|to|(?:\\d+\\.?\\d*%))\\{(?:[^}])*})*)}/g;\nconst FONT_FACE_HYDRATOR = /@font-face\\{font-family:([^;]+);([^}]*)\\}/g;\n\nfunction hydrateStyles(cache, hydrator, css) {\n let match;\n\n while (match = hydrator.exec(css)) {\n const [, id, pseudo, key] = match;\n\n if (true && process.env.NODE_ENV !== \"production\" && window.__STYLETRON_DEVTOOLS__) {\n hydrateDevtoolsRule(match[0]);\n }\n\n const fullKey = pseudo ? `${pseudo}${key}` : key;\n cache.cache[fullKey] = id; // set cache without triggering side effects\n\n cache.idGenerator.increment(); // increment id\n }\n}\n\nfunction hydrate(cache, hydrator, css) {\n let match;\n\n while (match = hydrator.exec(css)) {\n const [, id, key] = match;\n\n if (true && process.env.NODE_ENV !== \"production\" && window.__STYLETRON_DEVTOOLS__) {\n hydrateDevtoolsRule(match[0]);\n }\n\n cache.cache[key] = id; // set cache without triggering side effects\n\n cache.idGenerator.increment(); // increment id\n }\n}\n\nimport SequentialIDGenerator from \"../sequential-id-generator\";\nimport { Cache, MultiCache } from \"../cache\";\nimport injectStylePrefixed from \"../inject-style-prefixed\";\nimport { styleBlockToRule, atomicSelector, keyframesBlockToRule, declarationsToBlock, keyframesToBlock, fontFaceBlockToRule } from \"../css\";\nimport { insertRuleIntoDevtools, hydrateDevtoolsRule } from \"../dev-tool\";\n\nclass StyletronClient {\n constructor(opts = {}) {\n this.styleElements = {};\n const styleIdGenerator = new SequentialIDGenerator(opts.prefix);\n\n const onNewStyle = (cache, id, value) => {\n const {\n pseudo,\n block\n } = value;\n const sheet = this.styleElements[cache.key].sheet;\n const selector = atomicSelector(id, pseudo);\n const rule = styleBlockToRule(selector, block);\n\n try {\n sheet.insertRule(rule, sheet.cssRules.length);\n\n if (true && process.env.NODE_ENV !== \"production\" && window.__STYLETRON_DEVTOOLS__) {\n insertRuleIntoDevtools(selector, block);\n }\n } catch (e) {\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line no-console\n console.warn(`Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`);\n }\n }\n }; // Setup style cache\n\n\n this.styleCache = new MultiCache(styleIdGenerator, (media, _cache, insertBeforeMedia) => {\n const styleElement = document.createElement(\"style\");\n styleElement.media = media;\n\n if (insertBeforeMedia === void 0) {\n this.container.appendChild(styleElement);\n } else {\n const insertBeforeIndex = findSheetIndexWithMedia(this.container.children, insertBeforeMedia);\n this.container.insertBefore(styleElement, this.container.children[insertBeforeIndex]);\n }\n\n this.styleElements[media] = styleElement;\n }, onNewStyle);\n this.keyframesCache = new Cache(new SequentialIDGenerator(opts.prefix), (cache, id, value) => {\n this.styleCache.getCache(\"\");\n const sheet = this.styleElements[\"\"].sheet;\n const rule = keyframesBlockToRule(id, keyframesToBlock(value));\n\n try {\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line no-console\n console.warn(`Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`);\n }\n }\n });\n this.fontFaceCache = new Cache(new SequentialIDGenerator(opts.prefix), (cache, id, value) => {\n this.styleCache.getCache(\"\");\n const sheet = this.styleElements[\"\"].sheet;\n const rule = fontFaceBlockToRule(id, declarationsToBlock(value));\n\n try {\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line no-console\n console.warn(`Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`);\n }\n }\n });\n\n if (opts.container) {\n this.container = opts.container;\n } // Hydrate\n\n\n if (opts.hydrate && opts.hydrate.length > 0) {\n // infer container from parent element\n if (!this.container) {\n const parentElement = opts.hydrate[0].parentElement;\n\n if (parentElement !== null && parentElement !== void 0) {\n this.container = parentElement;\n }\n }\n\n for (let i = 0; i < opts.hydrate.length; i++) {\n const element = opts.hydrate[i];\n const hydrateType = element.getAttribute(\"data-hydrate\");\n\n if (hydrateType === \"font-face\") {\n hydrate(this.fontFaceCache, FONT_FACE_HYDRATOR, element.textContent);\n continue;\n }\n\n if (hydrateType === \"keyframes\") {\n hydrate(this.keyframesCache, KEYFRAMES_HYRDATOR, element.textContent);\n continue;\n }\n\n const key = element.media ? element.media : \"\";\n this.styleElements[key] = element;\n const cache = new Cache(styleIdGenerator, onNewStyle);\n cache.key = key;\n hydrateStyles(cache, STYLES_HYDRATOR, element.textContent);\n this.styleCache.sortedCacheKeys.push(key);\n this.styleCache.caches[key] = cache;\n }\n }\n\n if (!this.container) {\n if (document.head === null) {\n throw new Error(\"No container provided and `document.head` was null\");\n }\n\n this.container = document.head;\n }\n }\n\n renderStyle(style) {\n return injectStylePrefixed(this.styleCache, style, \"\", \"\");\n }\n\n renderFontFace(fontFace) {\n const key = declarationsToBlock(fontFace);\n return this.fontFaceCache.addValue(key, fontFace);\n }\n\n renderKeyframes(keyframes) {\n const key = keyframesToBlock(keyframes);\n return this.keyframesCache.addValue(key, keyframes);\n }\n\n}\n\nexport default StyletronClient;\n\nfunction findSheetIndexWithMedia(children, media) {\n let index = 0;\n\n for (; index < children.length; index++) {\n const child = children[index];\n\n if (child.tagName === \"STYLE\" && child.media === media) {\n return index;\n }\n }\n\n return -1;\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["STYLES_HYDRATOR","KEYFRAMES_HYRDATOR","FONT_FACE_HYDRATOR","hydrateStyles","cache","hydrator","css","match","exec","id","pseudo","key","window","__STYLETRON_DEVTOOLS__","hydrateDevtoolsRule","fullKey","idGenerator","increment","hydrate","SequentialIDGenerator","Cache","MultiCache","injectStylePrefixed","styleBlockToRule","atomicSelector","keyframesBlockToRule","declarationsToBlock","keyframesToBlock","fontFaceBlockToRule","insertRuleIntoDevtools","StyletronClient","constructor","opts","styleElements","styleIdGenerator","prefix","onNewStyle","value","block","sheet","selector","rule","insertRule","cssRules","length","e","console","warn","styleCache","media","_cache","insertBeforeMedia","styleElement","document","createElement","container","appendChild","insertBeforeIndex","findSheetIndexWithMedia","children","insertBefore","keyframesCache","getCache","fontFaceCache","parentElement","i","element","hydrateType","getAttribute","textContent","sortedCacheKeys","push","caches","head","Error","renderStyle","style","renderFontFace","fontFace","addValue","renderKeyframes","keyframes","index","child","tagName"],"sources":["src/client/client.ts"],"sourcesContent":["/* eslint-env browser */\n\ndeclare var __DEV__: boolean;\n\ndeclare var __BROWSER__: boolean;\n\nconst STYLES_HYDRATOR = /\\.([^{:]+)(:[^{]+)?{(?:[^}]*;)?([^}]*?)}/g;\nconst KEYFRAMES_HYRDATOR =\n  /@keyframes ([^{]+){((?:(?:from|to|(?:\\d+\\.?\\d*%))\\{(?:[^}])*})*)}/g;\nconst FONT_FACE_HYDRATOR = /@font-face\\{font-family:([^;]+);([^}]*)\\}/g;\n\ntype hydratorT =\n  | typeof STYLES_HYDRATOR\n  | typeof KEYFRAMES_HYRDATOR\n  | typeof FONT_FACE_HYDRATOR;\n\nfunction hydrateStyles<T>(cache: Cache<T>, hydrator: hydratorT, css: string) {\n  let match;\n  while ((match = hydrator.exec(css))) {\n    const [, id, pseudo, key] = match;\n    if (__BROWSER__ && __DEV__ && window.__STYLETRON_DEVTOOLS__) {\n      hydrateDevtoolsRule(match[0]);\n    }\n    const fullKey = pseudo ? `${pseudo}${key}` : key;\n    cache.cache[fullKey] = id; // set cache without triggering side effects\n    cache.idGenerator.increment(); // increment id\n  }\n}\n\nfunction hydrate<T>(cache: Cache<T>, hydrator: hydratorT, css: string) {\n  let match;\n  while ((match = hydrator.exec(css))) {\n    const [, id, key] = match;\n    if (__BROWSER__ && __DEV__ && window.__STYLETRON_DEVTOOLS__) {\n      hydrateDevtoolsRule(match[0]);\n    }\n    cache.cache[key] = id; // set cache without triggering side effects\n    cache.idGenerator.increment(); // increment id\n  }\n}\n\nimport SequentialIDGenerator from \"../sequential-id-generator\";\n\nimport type {\n  StandardEngine,\n  KeyframesObject,\n  FontFaceObject,\n  StyleObject,\n} from \"styletron-standard\";\n\nimport {Cache, MultiCache} from \"../cache\";\n\nimport injectStylePrefixed from \"../inject-style-prefixed\";\n\nimport {\n  styleBlockToRule,\n  atomicSelector,\n  keyframesBlockToRule,\n  declarationsToBlock,\n  keyframesToBlock,\n  fontFaceBlockToRule,\n} from \"../css\";\nimport {insertRuleIntoDevtools, hydrateDevtoolsRule} from \"../dev-tool\";\n\ntype hydrateT =\n  | HTMLCollectionOf<HTMLStyleElement>\n  | Array<HTMLStyleElement>\n  | NodeListOf<HTMLStyleElement>;\n\ntype optionsT = {\n  hydrate?: hydrateT;\n  container?: Element;\n  prefix?: string;\n};\n\nclass StyletronClient implements StandardEngine {\n  container: Element;\n  styleElements: {\n    [x: string]: HTMLStyleElement;\n  };\n  fontFaceSheet: HTMLStyleElement;\n  keyframesSheet: HTMLStyleElement;\n\n  styleCache: MultiCache<{\n    pseudo: string;\n    block: string;\n  }>;\n  keyframesCache: Cache<KeyframesObject>;\n  fontFaceCache: Cache<FontFaceObject>;\n\n  constructor(opts: optionsT = {}) {\n    this.styleElements = {};\n\n    const styleIdGenerator = new SequentialIDGenerator(opts.prefix);\n    const onNewStyle = (cache, id, value) => {\n      const {pseudo, block} = value;\n      const sheet: CSSStyleSheet = this.styleElements[cache.key].sheet as any;\n      const selector = atomicSelector(id, pseudo);\n      const rule = styleBlockToRule(selector, block);\n      try {\n        sheet.insertRule(rule, sheet.cssRules.length);\n        if (__BROWSER__ && __DEV__ && window.__STYLETRON_DEVTOOLS__) {\n          insertRuleIntoDevtools(selector, block);\n        }\n      } catch (e) {\n        if (__DEV__) {\n          // eslint-disable-next-line no-console\n          console.warn(\n            `Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`,\n          );\n        }\n      }\n    };\n\n    // Setup style cache\n    this.styleCache = new MultiCache(\n      styleIdGenerator,\n      (media, _cache, insertBeforeMedia) => {\n        const styleElement = document.createElement(\"style\");\n        styleElement.media = media;\n        if (insertBeforeMedia === void 0) {\n          this.container.appendChild(styleElement);\n        } else {\n          const insertBeforeIndex = findSheetIndexWithMedia(\n            this.container.children,\n            insertBeforeMedia,\n          );\n          this.container.insertBefore(\n            styleElement,\n            this.container.children[insertBeforeIndex],\n          );\n        }\n\n        this.styleElements[media] = styleElement;\n      },\n      onNewStyle,\n    );\n\n    this.keyframesCache = new Cache(\n      new SequentialIDGenerator(opts.prefix),\n      (cache, id, value) => {\n        this.styleCache.getCache(\"\");\n        const sheet: CSSStyleSheet = this.styleElements[\"\"].sheet as any;\n        const rule = keyframesBlockToRule(id, keyframesToBlock(value));\n        try {\n          sheet.insertRule(rule, sheet.cssRules.length);\n        } catch (e) {\n          if (__DEV__) {\n            // eslint-disable-next-line no-console\n            console.warn(\n              `Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`,\n            );\n          }\n        }\n      },\n    );\n\n    this.fontFaceCache = new Cache(\n      new SequentialIDGenerator(opts.prefix),\n      (cache, id, value) => {\n        this.styleCache.getCache(\"\");\n        const sheet: CSSStyleSheet = this.styleElements[\"\"].sheet as any;\n        const rule = fontFaceBlockToRule(id, declarationsToBlock(value));\n        try {\n          sheet.insertRule(rule, sheet.cssRules.length);\n        } catch (e) {\n          if (__DEV__) {\n            // eslint-disable-next-line no-console\n            console.warn(\n              `Failed to inject CSS: \"${rule}\". Perhaps this has invalid or un-prefixed properties?`,\n            );\n          }\n        }\n      },\n    );\n\n    if (opts.container) {\n      this.container = opts.container;\n    }\n\n    // Hydrate\n    if (opts.hydrate && opts.hydrate.length > 0) {\n      // infer container from parent element\n      if (!this.container) {\n        const parentElement = opts.hydrate[0].parentElement;\n        if (parentElement !== null && parentElement !== void 0) {\n          this.container = parentElement;\n        }\n      }\n\n      for (let i = 0; i < opts.hydrate.length; i++) {\n        const element = opts.hydrate[i];\n        const hydrateType = element.getAttribute(\"data-hydrate\");\n        if (hydrateType === \"font-face\") {\n          hydrate(this.fontFaceCache, FONT_FACE_HYDRATOR, element.textContent);\n          continue;\n        }\n        if (hydrateType === \"keyframes\") {\n          hydrate(this.keyframesCache, KEYFRAMES_HYRDATOR, element.textContent);\n          continue;\n        }\n        const key = element.media ? element.media : \"\";\n        this.styleElements[key] = element;\n        const cache = new Cache(styleIdGenerator, onNewStyle);\n        cache.key = key;\n        hydrateStyles(cache, STYLES_HYDRATOR, element.textContent);\n        this.styleCache.sortedCacheKeys.push(key);\n        this.styleCache.caches[key] = cache;\n      }\n    }\n\n    if (!this.container) {\n      if (document.head === null) {\n        throw new Error(\"No container provided and `document.head` was null\");\n      }\n      this.container = document.head;\n    }\n  }\n\n  renderStyle(style: StyleObject): string {\n    return injectStylePrefixed(this.styleCache, style, \"\", \"\");\n  }\n\n  renderFontFace(fontFace: FontFaceObject): string {\n    const key = declarationsToBlock(fontFace);\n    return this.fontFaceCache.addValue(key, fontFace);\n  }\n\n  renderKeyframes(keyframes: KeyframesObject): string {\n    const key = keyframesToBlock(keyframes);\n    return this.keyframesCache.addValue(key, keyframes);\n  }\n}\n\nexport default StyletronClient;\n\nfunction findSheetIndexWithMedia(children, media) {\n  let index = 0;\n  for (; index < children.length; index++) {\n    const child = children[index];\n    if (\n      child.tagName === \"STYLE\" &&\n      (child as any as HTMLStyleElement).media === media\n    ) {\n      return index;\n    }\n  }\n\n  return -1;\n}\n"],"mappings":"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"}","import * as React from \"react\";\nimport { Client as Styletron } from \"styletron-engine-atomic\";\nimport { Provider, DebugEngine } from \"styletron-react\";\nconst debugEngine = process.env.NODE_ENV !== `production` ? new DebugEngine() : undefined;\nexport function wrapRootElement({\n element\n}, {\n prefix,\n debug\n}) {\n const enableDebug = debug === true || typeof debug === `undefined`;\n const styleElements = document.querySelectorAll(`._styletron_hydrate_`);\n return /*#__PURE__*/React.createElement(Provider, {\n value: new Styletron({\n hydrate: styleElements,\n prefix\n }),\n debugMode: enableDebug ? debugEngine : undefined,\n debugAfterHydration: enableDebug\n }, element);\n}","const WebFont = require('webfontloader')\n\nexports.onInitialClientRender = (a, options) => {\n\toptions = { ...options }\n\tdelete options.plugins\n\tWebFont.load(options)\n}","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (process.env.NODE_ENV !== 'production') {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n","/**\n * @license React\n * react-server-dom-webpack.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var k=require(\"react\"),l={stream:!0},n=new Map,p=Symbol.for(\"react.element\"),q=Symbol.for(\"react.lazy\"),r=Symbol.for(\"react.default_value\"),t=k.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ContextRegistry;function u(a){t[a]||(t[a]=k.createServerContext(a,r));return t[a]}function v(a,b,c){this._status=a;this._value=b;this._response=c}v.prototype.then=function(a){0===this._status?(null===this._value&&(this._value=[]),this._value.push(a)):a()};\nfunction w(a){switch(a._status){case 3:return a._value;case 1:var b=JSON.parse(a._value,a._response._fromJSON);a._status=3;return a._value=b;case 2:b=a._value;for(var c=b.chunks,d=0;d
\"\",\n renderKeyframes: () => \"\",\n renderFontFace: () => \"\"\n};\nconst StyletronContext = /*#__PURE__*/React.createContext(noopEngine);\nconst HydrationContext = /*#__PURE__*/React.createContext(false);\nconst DebugEngineContext = /*#__PURE__*/React.createContext(undefined); //todo: theme context removed\n\nclass DevProvider extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n hydrating: Boolean(props.debugAfterHydration)\n };\n }\n\n componentDidMount() {\n if (true) {\n if (this.state.hydrating === true) {\n this.setState({\n hydrating: false\n });\n }\n }\n }\n\n render() {\n return /*#__PURE__*/React.createElement(StyletronContext.Provider, {\n value: this.props.value\n }, /*#__PURE__*/React.createElement(DebugEngineContext.Provider, {\n value: this.props.debug\n }, /*#__PURE__*/React.createElement(HydrationContext.Provider, {\n value: this.state.hydrating\n }, this.props.children)));\n }\n\n}\n\nexport const Provider = true && process.env.NODE_ENV !== \"production\" ? DevProvider : StyletronContext.Provider;\n\nif (true && process.env.NODE_ENV !== \"production\" && !window.__STYLETRON_DEVTOOLS__) {\n setupDevtoolsExtension();\n}\n\nfunction checkNoopEngine(engine) {\n // if no engine provided, we default to no-op, handy for tests\n // however, print a warning in other envs\n if (process.env.NODE_ENV !== \"test\") {\n engine === noopEngine && // eslint-disable-next-line no-console\n console.warn(process.env.NODE_ENV !== \"production\" ? `\nStyletron has been switched to a no-op (test) mode.\n\nA Styletron styled component was rendered, but no Styletron engine instance was provided in React context.\n\nDid you forget to provide a Styletron engine instance to React context via using the Styletron provider component?\n\nNote: Providers and Consumers must come from the exact same React.createContext call to work.\nIf your app has multiple instances of the \"styletron-react\" package in your node_module tree,\nyour Provider may be coming from a different React.createContext call, which means the styled components\nwill not recieve the provided engine instance. This scenario can arise, for example, when using \"npm link\".\n` : `Styletron Provider is not set up. Defaulting to no-op.`);\n }\n}\n\nexport function useStyletron() {\n const styletronEngine = React.useContext(StyletronContext);\n const debugEngine = React.useContext(DebugEngineContext);\n const hydrating = React.useContext(HydrationContext);\n checkNoopEngine(styletronEngine);\n const debugClassName = React.useRef(\"\");\n const prevDebugClassNameDeps = React.useRef([]);\n return [function css(style) {\n const className = driver(style, styletronEngine);\n\n if (!(true && process.env.NODE_ENV !== \"production\")) {\n return className;\n }\n\n const {\n stack,\n message\n } = new Error(\"stacktrace source\");\n const nextDeps = [debugEngine, hydrating];\n\n if (prevDebugClassNameDeps.current[0] !== nextDeps[0] || prevDebugClassNameDeps.current[1] !== nextDeps[1]) {\n if (debugEngine && !hydrating) {\n debugClassName.current = debugEngine.debug({\n stackInfo: {\n stack,\n message\n },\n stackIndex: 1\n });\n }\n\n prevDebugClassNameDeps.current = nextDeps;\n }\n\n if (debugClassName.current) {\n return `${debugClassName.current} ${className}`;\n }\n\n return className;\n }];\n}\nexport function createStyled({\n getInitialStyle,\n driver,\n wrapper\n}) {\n function styled(base, styleArg) {\n if (process.env.NODE_ENV !== \"production\") {\n if (base.__STYLETRON__) {\n /* eslint-disable no-console */\n console.warn(\"It appears you are passing a styled component into `styled`.\");\n console.warn(\"For composition with existing styled components, use `withStyle` or `withTransform` instead.\");\n /* eslint-enable no-console */\n }\n }\n\n const baseStyletron = {\n reducers: [],\n base: base,\n driver,\n getInitialStyle,\n wrapper\n };\n\n if (true && process.env.NODE_ENV !== \"production\") {\n addDebugMetadata(baseStyletron, 2);\n }\n\n return createStyledElementComponent(autoComposeShallow(baseStyletron, styleArg));\n }\n\n return styled;\n}\nexport const styled = createStyled({\n getInitialStyle,\n driver,\n wrapper: Component => Component\n});\nexport const withTransform = (component, transformer) => {\n const styletron = component.__STYLETRON__;\n\n if (true && process.env.NODE_ENV !== \"production\") {\n addDebugMetadata(styletron, 2);\n }\n\n return createStyledElementComponent(composeDynamic(styletron, transformer));\n};\nexport const withStyleDeep = (component, styleArg) => {\n // @ts-ignore\n const styletron = component.__STYLETRON__;\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!styletron) {\n /* eslint-disable no-console */\n console.warn(\"The first parameter to `withStyle` must be a styled component (without extra wrappers).\");\n /* eslint-enable no-console */\n }\n }\n\n if (true && process.env.NODE_ENV !== \"production\") {\n addDebugMetadata(styletron, 2);\n return createStyledElementComponent(addExtension(autoComposeDeep(styletron, styleArg), component, styleArg));\n } else {\n return createStyledElementComponent(autoComposeDeep(styletron, styleArg));\n }\n};\nexport const withStyle = withStyleDeep;\nexport const withWrapper = (component, wrapper) => {\n const styletron = component.__STYLETRON__;\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!styletron) {\n /* eslint-disable no-console */\n console.warn(\"The first parameter to `withWrapper` must be a styled component (without extra wrappers).\");\n /* eslint-enable no-console */\n }\n }\n\n const composed = {\n getInitialStyle: styletron.getInitialStyle,\n base: styletron.base,\n driver: styletron.driver,\n wrapper: wrapper,\n reducers: styletron.reducers\n };\n\n if (true && process.env.NODE_ENV !== \"production\") {\n addDebugMetadata(composed, 2);\n }\n\n return createStyledElementComponent(composed);\n};\nexport function autoComposeShallow(styletron, styleArg) {\n if (typeof styleArg === \"function\") {\n return dynamicComposeShallow(styletron, styleArg);\n }\n\n return staticComposeShallow(styletron, styleArg);\n}\n\nfunction addExtension(composed, component, styleArg) {\n return { ...composed,\n ext: {\n with: styleArg,\n name: component.displayName,\n base: component.__STYLETRON__.base,\n getInitialStyle: component.__STYLETRON__.reducers.length ? component.__STYLETRON__.reducers[0].reducer : component.__STYLETRON__.getInitialStyle\n }\n };\n}\n\nexport function autoComposeDeep(styletron, styleArg) {\n if (typeof styleArg === \"function\") {\n return dynamicComposeDeep(styletron, styleArg);\n }\n\n return staticComposeDeep(styletron, styleArg);\n}\nexport function staticComposeShallow(styletron, style) {\n return composeStatic(styletron, createShallowMergeReducer(style));\n}\nexport function staticComposeDeep(styletron, style) {\n return composeStatic(styletron, createDeepMergeReducer(style));\n}\nexport function dynamicComposeShallow(styletron, styleFn) {\n return composeDynamic(styletron, (style, props) => shallowMerge(style, styleFn(props)));\n}\nexport function dynamicComposeDeep(styletron, styleFn) {\n return composeDynamic(styletron, (style, props) => deepMerge(style, styleFn(props)));\n}\nexport function createShallowMergeReducer(style) {\n return {\n reducer: inputStyle => shallowMerge(inputStyle, style),\n assignmentCommutative: true,\n factory: createShallowMergeReducer,\n style: style\n };\n}\nexport function createDeepMergeReducer(style) {\n return {\n reducer: inputStyle => deepMerge(inputStyle, style),\n assignmentCommutative: true,\n factory: createDeepMergeReducer,\n style: style\n };\n}\nexport function composeStatic(styletron, reducerContainer) {\n if (styletron.reducers.length === 0) {\n const style = reducerContainer.reducer(styletron.getInitialStyle());\n const result = {\n reducers: styletron.reducers,\n base: styletron.base,\n driver: styletron.driver,\n wrapper: styletron.wrapper,\n getInitialStyle: () => style\n };\n\n if (true && process.env.NODE_ENV !== \"production\") {\n result.debug = styletron.debug;\n }\n\n return result;\n } else {\n const last = styletron.reducers[0];\n\n if (last.assignmentCommutative === true && reducerContainer.assignmentCommutative === true) {\n const composed = reducerContainer.reducer(last.style);\n const result = {\n getInitialStyle: styletron.getInitialStyle,\n base: styletron.base,\n driver: styletron.driver,\n wrapper: styletron.wrapper,\n reducers: [last.factory(composed)].concat(styletron.reducers.slice(1))\n };\n\n if (true && process.env.NODE_ENV !== \"production\") {\n result.debug = styletron.debug;\n }\n\n return result;\n }\n\n return composeDynamic(styletron, reducerContainer.reducer);\n }\n}\nexport function composeDynamic(styletron, reducer) {\n const composed = {\n getInitialStyle: styletron.getInitialStyle,\n base: styletron.base,\n driver: styletron.driver,\n wrapper: styletron.wrapper,\n // @ts-ignore\n reducers: [{\n assignmentCommutative: false,\n reducer\n }].concat(styletron.reducers)\n };\n\n if (true && process.env.NODE_ENV !== \"production\") {\n composed.debug = styletron.debug;\n }\n\n return composed;\n}\nexport function createStyledElementComponent(styletron) {\n const {\n reducers,\n base,\n driver,\n wrapper,\n getInitialStyle,\n ext\n } = styletron;\n\n if (true && process.env.NODE_ENV !== \"production\") {\n var debugStackInfo, debugStackIndex;\n\n if (styletron.debug) {\n debugStackInfo = styletron.debug.stackInfo;\n debugStackIndex = styletron.debug.stackIndex;\n }\n }\n\n if (true && process.env.NODE_ENV !== \"production\") {\n var debugClassName;\n }\n\n const StyledElement = /*#__PURE__*/React.forwardRef((props, ref) => {\n const styletron = React.useContext(StyletronContext);\n const debugEngine = React.useContext(DebugEngineContext);\n const hydrating = React.useContext(HydrationContext);\n checkNoopEngine(styletron);\n const elementProps = omitPrefixedKeys(props);\n let style = resolveStyle(getInitialStyle, reducers, props);\n\n if (props.$style) {\n if (typeof props.$style === \"function\") {\n style = deepMerge(style, props.$style(props));\n } else {\n style = deepMerge(style, props.$style);\n }\n }\n\n const styleClassString = driver(style, styletron);\n const Element = props.$as ? props.$as : base;\n elementProps.className = props.className ? `${props.className} ${styleClassString}` : styleClassString;\n\n if (true && process.env.NODE_ENV !== \"production\" && debugEngine && !hydrating) {\n if (!debugClassName) {\n debugClassName = debugEngine.debug({\n stackInfo: debugStackInfo,\n stackIndex: debugStackIndex\n });\n }\n\n const joined = `${debugClassName} ${elementProps.className}`;\n elementProps.className = joined;\n }\n\n if (true && process.env.NODE_ENV !== \"production\" && window.__STYLETRON_DEVTOOLS__) {\n window.__STYLETRON_DEVTOOLS__.stylesMap.set(elementProps.className, style);\n\n if (ext) {\n window.__STYLETRON_DEVTOOLS__.extensionsMap.set(elementProps.className, {\n base: ext.base,\n displayName: ext.name,\n initialStyles: ext.getInitialStyle({}, props),\n styleOverrides: typeof ext.with === \"function\" ? ext.with(props) : ext.with\n });\n }\n }\n\n if (props.$ref) {\n // eslint-disable-next-line no-console\n console.warn(\"The prop `$ref` has been deprecated. Use `ref` instead. Refs are now forwarded with React.forwardRef.\");\n }\n\n return /*#__PURE__*/React.createElement(Element, _extends({}, elementProps, {\n ref: ref || props.$ref\n }));\n });\n const Wrapped = wrapper(StyledElement);\n Wrapped.__STYLETRON__ = {\n base,\n reducers,\n driver,\n wrapper,\n getInitialStyle\n };\n\n if (process.env.NODE_ENV !== \"production\") {\n let displayName;\n\n if (typeof base === \"string\") {\n displayName = base;\n } else if (base.displayName) {\n displayName = base.displayName;\n } else if (base.name) {\n displayName = base.name;\n } else {\n displayName = \"Unknown\";\n }\n\n Wrapped.displayName = `Styled(${displayName})`;\n }\n\n return Wrapped;\n} // Utility functions\n\nexport function resolveStyle(getInitialStyle, reducers, props) {\n let result = getInitialStyle();\n let i = reducers.length;\n\n while (i--) {\n // Cast to allow passing unused props param in case of static reducer\n const reducer = reducers[i].reducer;\n result = reducer(result, props);\n }\n\n return result;\n}\n\nfunction isObject(x) {\n return typeof x === \"object\" && x !== null;\n}\n\nfunction omitPrefixedKeys(source) {\n const result = {};\n\n for (const key in source) {\n if (key[0] !== \"$\") {\n result[key] = source[key];\n }\n }\n\n return result;\n}\n\nfunction deepMerge(a, b) {\n const result = assign({}, a);\n\n for (const key in b) {\n const val = b[key];\n\n if (isObject(val) && isObject(a[key])) {\n result[key] = deepMerge(a[key], val);\n } else {\n result[key] = val;\n }\n }\n\n return result;\n}\n\nfunction shallowMerge(a, b) {\n return assign(assign({}, a), b);\n}\n\nfunction assign(target, source) {\n for (const key in source) {\n target[key] = source[key];\n }\n\n return target;\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","driver","getInitialStyle","addDebugMetadata","setupDevtoolsExtension","DebugEngine","noopEngine","renderStyle","renderKeyframes","renderFontFace","StyletronContext","createContext","HydrationContext","DebugEngineContext","undefined","DevProvider","Component","constructor","props","state","hydrating","Boolean","debugAfterHydration","componentDidMount","setState","render","value","debug","children","Provider","window","__STYLETRON_DEVTOOLS__","checkNoopEngine","engine","process","env","NODE_ENV","console","warn","useStyletron","styletronEngine","useContext","debugEngine","debugClassName","useRef","prevDebugClassNameDeps","css","style","className","stack","message","Error","nextDeps","current","stackInfo","stackIndex","createStyled","wrapper","styled","base","styleArg","__STYLETRON__","baseStyletron","reducers","createStyledElementComponent","autoComposeShallow","withTransform","component","transformer","styletron","composeDynamic","withStyleDeep","addExtension","autoComposeDeep","withStyle","withWrapper","composed","dynamicComposeShallow","staticComposeShallow","ext","with","name","displayName","length","reducer","dynamicComposeDeep","staticComposeDeep","composeStatic","createShallowMergeReducer","createDeepMergeReducer","styleFn","shallowMerge","deepMerge","inputStyle","assignmentCommutative","factory","reducerContainer","result","last","concat","slice","debugStackInfo","debugStackIndex","StyledElement","forwardRef","ref","elementProps","omitPrefixedKeys","resolveStyle","$style","styleClassString","Element","$as","joined","stylesMap","set","extensionsMap","initialStyles","styleOverrides","$ref","Wrapped","i","isObject","x","source","key","a","b","assign","val","target"],"sources":["src/index.tsx"],"sourcesContent":["/* eslint-env browser */\n/* eslint-disable no-unused-vars, no-redeclare, no-shadow */\n\ndeclare var __DEV__: boolean;\n\ndeclare var __BROWSER__: boolean;\ndeclare global {\n  interface Window {\n    __STYLETRON_DEVTOOLS__: any;\n  }\n}\n\ndeclare var process: any;\n\nimport * as React from \"react\";\nimport {\n  driver,\n  getInitialStyle,\n  type StandardEngine,\n  type StyleObject,\n} from \"styletron-standard\";\n\nimport type {\n  Styletron,\n  StyletronComponent,\n  ReducerContainer,\n  AssignmentCommutativeReducerContainer,\n  NonAssignmentCommutativeReducerContainer,\n  StyledFn,\n  WithStyleFn,\n  WithTransformFn,\n  WithWrapperFn,\n  StyletronProps,\n} from \"./types\";\nimport {\n  addDebugMetadata,\n  setupDevtoolsExtension,\n  DebugEngine,\n} from \"./dev-tool\";\n\nexport {DebugEngine};\nexport type {StyleObject};\nexport type {StyletronProps};\nexport type {StyletronComponent};\n\nconst noopEngine = {\n  renderStyle: () => \"\",\n  renderKeyframes: () => \"\",\n  renderFontFace: () => \"\",\n};\n\nconst StyletronContext = React.createContext<StandardEngine>(noopEngine);\nconst HydrationContext = React.createContext(false);\nconst DebugEngineContext = React.createContext<\n  InstanceType<typeof DebugEngine> | undefined\n>(undefined);\n//todo: theme context removed\n\ntype DevProviderProps = {\n  children: React.ReactNode;\n  value: StandardEngine;\n  debugAfterHydration?: boolean;\n  debug?: any;\n};\n\nclass DevProvider extends React.Component<\n  DevProviderProps,\n  {\n    hydrating: boolean;\n  }\n> {\n  constructor(props: DevProviderProps) {\n    super(props);\n    this.state = {\n      hydrating: Boolean(props.debugAfterHydration),\n    };\n  }\n\n  componentDidMount() {\n    if (__BROWSER__) {\n      if (this.state.hydrating === true) {\n        this.setState({\n          hydrating: false,\n        });\n      }\n    }\n  }\n\n  render() {\n    return (\n      <StyletronContext.Provider value={this.props.value}>\n        <DebugEngineContext.Provider value={this.props.debug}>\n          <HydrationContext.Provider value={this.state.hydrating}>\n            {this.props.children}\n          </HydrationContext.Provider>\n        </DebugEngineContext.Provider>\n      </StyletronContext.Provider>\n    );\n  }\n}\n\nexport const Provider =\n  __BROWSER__ && __DEV__ ? DevProvider : StyletronContext.Provider;\n\nif (__BROWSER__ && __DEV__ && !window.__STYLETRON_DEVTOOLS__) {\n  setupDevtoolsExtension();\n}\n\ntype createStyledOpts = {\n  getInitialStyle: () => StyleObject;\n  driver: typeof driver;\n  wrapper: (fc: React.FC<any>) => React.ComponentType<any>;\n};\n\nfunction checkNoopEngine(engine: StandardEngine) {\n  // if no engine provided, we default to no-op, handy for tests\n  // however, print a warning in other envs\n  if (process.env.NODE_ENV !== \"test\") {\n    engine === noopEngine &&\n      // eslint-disable-next-line no-console\n      console.warn(\n        __DEV__\n          ? `\nStyletron has been switched to a no-op (test) mode.\n\nA Styletron styled component was rendered, but no Styletron engine instance was provided in React context.\n\nDid you forget to provide a Styletron engine instance to React context via using the Styletron provider component?\n\nNote: Providers and Consumers must come from the exact same React.createContext call to work.\nIf your app has multiple instances of the \"styletron-react\" package in your node_module tree,\nyour Provider may be coming from a different React.createContext call, which means the styled components\nwill not recieve the provided engine instance. This scenario can arise, for example, when using \"npm link\".\n`\n          : `Styletron Provider is not set up. Defaulting to no-op.`,\n      );\n  }\n}\n\nexport function useStyletron(): [(style: StyleObject) => string] {\n  const styletronEngine: StandardEngine = React.useContext(StyletronContext);\n  const debugEngine = React.useContext(DebugEngineContext);\n  const hydrating = React.useContext(HydrationContext);\n  checkNoopEngine(styletronEngine);\n\n  const debugClassName = React.useRef<string | undefined>(\"\");\n  const prevDebugClassNameDeps = React.useRef([]);\n\n  return [\n    function css(style: StyleObject) {\n      const className = driver(style, styletronEngine);\n      if (!(__BROWSER__ && __DEV__)) {\n        return className;\n      }\n      const {stack, message} = new Error(\"stacktrace source\");\n\n      const nextDeps = [debugEngine, hydrating];\n      if (\n        prevDebugClassNameDeps.current[0] !== nextDeps[0] ||\n        prevDebugClassNameDeps.current[1] !== nextDeps[1]\n      ) {\n        if (debugEngine && !hydrating) {\n          debugClassName.current = debugEngine.debug({\n            stackInfo: {stack, message},\n            stackIndex: 1,\n          });\n        }\n        prevDebugClassNameDeps.current = nextDeps;\n      }\n\n      if (debugClassName.current) {\n        return `${debugClassName.current} ${className}`;\n      }\n\n      return className;\n    },\n  ];\n}\n\nexport function createStyled({\n  getInitialStyle,\n  driver,\n  wrapper,\n}: createStyledOpts): StyledFn {\n  function styled(base: any, styleArg) {\n    if (__DEV__) {\n      if (base.__STYLETRON__) {\n        /* eslint-disable no-console */\n        console.warn(\n          \"It appears you are passing a styled component into `styled`.\",\n        );\n        console.warn(\n          \"For composition with existing styled components, use `withStyle` or `withTransform` instead.\",\n        );\n        /* eslint-enable no-console */\n      }\n    }\n\n    const baseStyletron: Styletron = {\n      reducers: [],\n      base: base,\n      driver,\n      getInitialStyle,\n      wrapper,\n    };\n\n    if (__BROWSER__ && __DEV__) {\n      addDebugMetadata(baseStyletron, 2);\n    }\n\n    return createStyledElementComponent(\n      autoComposeShallow(baseStyletron, styleArg),\n    );\n  }\n\n  return styled;\n}\n\nexport const styled: StyledFn = createStyled({\n  getInitialStyle,\n  driver,\n  wrapper: Component => Component,\n});\n\nexport const withTransform: WithTransformFn = (component, transformer) => {\n  const styletron = component.__STYLETRON__;\n\n  if (__BROWSER__ && __DEV__) {\n    addDebugMetadata(styletron, 2);\n  }\n\n  return createStyledElementComponent(composeDynamic(styletron, transformer));\n};\n\nexport const withStyleDeep: WithStyleFn = (component, styleArg) => {\n  // @ts-ignore\n  const styletron = component.__STYLETRON__;\n\n  if (__DEV__) {\n    if (!styletron) {\n      /* eslint-disable no-console */\n      console.warn(\n        \"The first parameter to `withStyle` must be a styled component (without extra wrappers).\",\n      );\n      /* eslint-enable no-console */\n    }\n  }\n\n  if (__BROWSER__ && __DEV__) {\n    addDebugMetadata(styletron, 2);\n    return createStyledElementComponent(\n      addExtension(autoComposeDeep(styletron, styleArg), component, styleArg),\n    );\n  } else {\n    return createStyledElementComponent(autoComposeDeep(styletron, styleArg));\n  }\n};\n\nexport const withStyle = withStyleDeep;\n\nexport const withWrapper: WithWrapperFn = (component, wrapper) => {\n  const styletron = component.__STYLETRON__;\n\n  if (__DEV__) {\n    if (!styletron) {\n      /* eslint-disable no-console */\n      console.warn(\n        \"The first parameter to `withWrapper` must be a styled component (without extra wrappers).\",\n      );\n      /* eslint-enable no-console */\n    }\n  }\n\n  const composed = {\n    getInitialStyle: styletron.getInitialStyle,\n    base: styletron.base,\n    driver: styletron.driver,\n    wrapper: wrapper,\n    reducers: styletron.reducers,\n  };\n\n  if (__BROWSER__ && __DEV__) {\n    addDebugMetadata(composed, 2);\n  }\n\n  return createStyledElementComponent(composed);\n};\n\nexport function autoComposeShallow<Props>(\n  styletron: Styletron,\n  styleArg: StyleObject | ((a: Props) => StyleObject),\n) {\n  if (typeof styleArg === \"function\") {\n    return dynamicComposeShallow(styletron, styleArg);\n  }\n\n  return staticComposeShallow(styletron, styleArg);\n}\n\nfunction addExtension(composed, component, styleArg) {\n  return {\n    ...composed,\n    ext: {\n      with: styleArg,\n      name: component.displayName,\n      base: component.__STYLETRON__.base,\n      getInitialStyle: component.__STYLETRON__.reducers.length\n        ? component.__STYLETRON__.reducers[0].reducer\n        : component.__STYLETRON__.getInitialStyle,\n    },\n  };\n}\n\nexport function autoComposeDeep<Props>(\n  styletron: Styletron,\n  styleArg: StyleObject | ((a: Props) => StyleObject),\n) {\n  if (typeof styleArg === \"function\") {\n    return dynamicComposeDeep(styletron, styleArg);\n  }\n\n  return staticComposeDeep(styletron, styleArg);\n}\n\nexport function staticComposeShallow(styletron: Styletron, style: StyleObject) {\n  return composeStatic(styletron, createShallowMergeReducer(style));\n}\n\nexport function staticComposeDeep(styletron: Styletron, style: StyleObject) {\n  return composeStatic(styletron, createDeepMergeReducer(style));\n}\n\nexport function dynamicComposeShallow<Props>(\n  styletron: Styletron,\n  styleFn: (a: Props) => StyleObject,\n) {\n  return composeDynamic<Props>(styletron, (style, props) =>\n    shallowMerge(style, styleFn(props)),\n  );\n}\n\nexport function dynamicComposeDeep<Props>(\n  styletron: Styletron,\n  styleFn: (a: Props) => StyleObject,\n) {\n  return composeDynamic<Props>(styletron, (style, props) =>\n    deepMerge(style, styleFn(props)),\n  );\n}\n\nexport function createShallowMergeReducer(\n  style: StyleObject,\n): AssignmentCommutativeReducerContainer {\n  return {\n    reducer: inputStyle => shallowMerge(inputStyle, style),\n    assignmentCommutative: true,\n    factory: createShallowMergeReducer,\n    style: style,\n  };\n}\n\nexport function createDeepMergeReducer(\n  style: StyleObject,\n): AssignmentCommutativeReducerContainer {\n  return {\n    reducer: inputStyle => deepMerge(inputStyle, style),\n    assignmentCommutative: true,\n    factory: createDeepMergeReducer,\n    style: style,\n  };\n}\n\nexport function composeStatic(\n  styletron: Styletron,\n  reducerContainer: AssignmentCommutativeReducerContainer,\n) {\n  if (styletron.reducers.length === 0) {\n    const style = reducerContainer.reducer(styletron.getInitialStyle());\n    const result: Styletron = {\n      reducers: styletron.reducers,\n      base: styletron.base,\n      driver: styletron.driver,\n      wrapper: styletron.wrapper,\n      getInitialStyle: () => style,\n    };\n    if (__BROWSER__ && __DEV__) {\n      result.debug = styletron.debug;\n    }\n    return result;\n  } else {\n    const last = styletron.reducers[0];\n\n    if (\n      last.assignmentCommutative === true &&\n      reducerContainer.assignmentCommutative === true\n    ) {\n      const composed = reducerContainer.reducer(last.style);\n\n      const result: Styletron = {\n        getInitialStyle: styletron.getInitialStyle,\n        base: styletron.base,\n        driver: styletron.driver,\n        wrapper: styletron.wrapper,\n        reducers: [last.factory(composed)].concat(\n          styletron.reducers.slice(1) as any,\n        ),\n      };\n\n      if (__BROWSER__ && __DEV__) {\n        result.debug = styletron.debug;\n      }\n\n      return result;\n    }\n\n    return composeDynamic(styletron, reducerContainer.reducer);\n  }\n}\n\nexport function composeDynamic<Props>(\n  styletron: Styletron,\n  reducer: (b: StyleObject, a: Props) => StyleObject,\n) {\n  const composed: Styletron = {\n    getInitialStyle: styletron.getInitialStyle,\n    base: styletron.base,\n    driver: styletron.driver,\n    wrapper: styletron.wrapper,\n    // @ts-ignore\n    reducers: [{assignmentCommutative: false, reducer}].concat(\n      styletron.reducers,\n    ),\n  };\n  if (__BROWSER__ && __DEV__) {\n    composed.debug = styletron.debug;\n  }\n  return composed;\n}\n\nexport function createStyledElementComponent(styletron: Styletron) {\n  const {reducers, base, driver, wrapper, getInitialStyle, ext} = styletron;\n\n  if (__BROWSER__ && __DEV__) {\n    var debugStackInfo, debugStackIndex;\n    if (styletron.debug) {\n      debugStackInfo = styletron.debug.stackInfo;\n      debugStackIndex = styletron.debug.stackIndex;\n    }\n  }\n\n  if (__BROWSER__ && __DEV__) {\n    var debugClassName;\n  }\n\n  const StyledElement = React.forwardRef<StyletronProps, any>((props, ref) => {\n    const styletron: StandardEngine = React.useContext(StyletronContext);\n    const debugEngine = React.useContext(DebugEngineContext);\n    const hydrating = React.useContext(HydrationContext);\n    checkNoopEngine(styletron);\n\n    const elementProps: any = omitPrefixedKeys(props);\n    let style = resolveStyle(getInitialStyle, reducers, props);\n\n    if (props.$style) {\n      if (typeof props.$style === \"function\") {\n        style = deepMerge(style, props.$style(props));\n      } else {\n        style = deepMerge(style, props.$style);\n      }\n    }\n\n    const styleClassString = driver(style, styletron);\n    const Element = props.$as ? props.$as : base;\n    elementProps.className = props.className\n      ? `${props.className} ${styleClassString}`\n      : styleClassString;\n\n    if (__BROWSER__ && __DEV__ && debugEngine && !hydrating) {\n      if (!debugClassName) {\n        debugClassName = debugEngine.debug({\n          stackInfo: debugStackInfo,\n          stackIndex: debugStackIndex,\n        });\n      }\n\n      const joined = `${debugClassName} ${elementProps.className}`;\n      elementProps.className = joined;\n    }\n\n    if (__BROWSER__ && __DEV__ && window.__STYLETRON_DEVTOOLS__) {\n      window.__STYLETRON_DEVTOOLS__.stylesMap.set(\n        elementProps.className,\n        style,\n      );\n      if (ext) {\n        window.__STYLETRON_DEVTOOLS__.extensionsMap.set(\n          elementProps.className,\n          {\n            base: ext.base,\n            displayName: ext.name,\n            initialStyles: ext.getInitialStyle({}, props),\n            styleOverrides:\n              typeof ext.with === \"function\" ? ext.with(props) : ext.with,\n          },\n        );\n      }\n    }\n\n    if (props.$ref) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"The prop `$ref` has been deprecated. Use `ref` instead. Refs are now forwarded with React.forwardRef.\",\n      );\n    }\n    return <Element {...elementProps} ref={ref || props.$ref} />;\n  });\n\n  const Wrapped = wrapper(StyledElement);\n  Wrapped.__STYLETRON__ = {\n    base,\n    reducers,\n    driver,\n    wrapper,\n    getInitialStyle,\n  };\n\n  if (__DEV__) {\n    let displayName;\n\n    if (typeof base === \"string\") {\n      displayName = base;\n    } else if (base.displayName) {\n      displayName = base.displayName;\n    } else if (base.name) {\n      displayName = base.name;\n    } else {\n      displayName = \"Unknown\";\n    }\n\n    Wrapped.displayName = `Styled(${displayName})`;\n  }\n\n  return Wrapped;\n}\n\n// Utility functions\n\nexport function resolveStyle(\n  getInitialStyle: (a: void) => StyleObject,\n  reducers: Array<ReducerContainer>,\n  props: any,\n): StyleObject {\n  let result = getInitialStyle();\n  let i = reducers.length;\n  while (i--) {\n    // Cast to allow passing unused props param in case of static reducer\n    const reducer = reducers[i].reducer as (\n      b: StyleObject,\n      a: any,\n    ) => StyleObject;\n    result = reducer(result, props);\n  }\n  return result;\n}\n\nfunction isObject(x: any) {\n  return typeof x === \"object\" && x !== null;\n}\n\nfunction omitPrefixedKeys(source) {\n  const result = {};\n\n  for (const key in source) {\n    if (key[0] !== \"$\") {\n      result[key] = source[key];\n    }\n  }\n\n  return result;\n}\n\nfunction deepMerge(a, b) {\n  const result = assign({}, a);\n\n  for (const key in b) {\n    const val = b[key];\n\n    if (isObject(val) && isObject(a[key])) {\n      result[key] = deepMerge(a[key], val);\n    } else {\n      result[key] = val;\n    }\n  }\n\n  return result;\n}\n\nfunction shallowMerge(a, b) {\n  return assign(assign({}, a), b);\n}\n\nfunction assign(target, source) {\n  for (const key in source) {\n    target[key] = source[key];\n  }\n  return target;\n}\n"],"mappings":";;AAAA;;AACA;AAaA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AACA,SACEC,MADF,EAEEC,eAFF,QAKO,oBALP;AAmBA,SACEC,gBADF,EAEEC,sBAFF,EAGEC,WAHF,QAIO,YAJP;AAMA,SAAQA,WAAR;AAKA,MAAMC,UAAU,GAAG;EACjBC,WAAW,EAAE,MAAM,EADF;EAEjBC,eAAe,EAAE,MAAM,EAFN;EAGjBC,cAAc,EAAE,MAAM;AAHL,CAAnB;AAMA,MAAMC,gBAAgB,gBAAGV,KAAK,CAACW,aAAN,CAAoCL,UAApC,CAAzB;AACA,MAAMM,gBAAgB,gBAAGZ,KAAK,CAACW,aAAN,CAAoB,KAApB,CAAzB;AACA,MAAME,kBAAkB,gBAAGb,KAAK,CAACW,aAAN,CAEzBG,SAFyB,CAA3B,C,CAGA;;AASA,MAAMC,WAAN,SAA0Bf,KAAK,CAACgB,SAAhC,CAKE;EACAC,WAAW,CAACC,KAAD,EAA0B;IACnC,MAAMA,KAAN;IACA,KAAKC,KAAL,GAAa;MACXC,SAAS,EAAEC,OAAO,CAACH,KAAK,CAACI,mBAAP;IADP,CAAb;EAGD;;EAEDC,iBAAiB,GAAG;IAClB,UAAiB;MACf,IAAI,KAAKJ,KAAL,CAAWC,SAAX,KAAyB,IAA7B,EAAmC;QACjC,KAAKI,QAAL,CAAc;UACZJ,SAAS,EAAE;QADC,CAAd;MAGD;IACF;EACF;;EAEDK,MAAM,GAAG;IACP,oBACE,oBAAC,gBAAD,CAAkB,QAAlB;MAA2B,KAAK,EAAE,KAAKP,KAAL,CAAWQ;IAA7C,gBACE,oBAAC,kBAAD,CAAoB,QAApB;MAA6B,KAAK,EAAE,KAAKR,KAAL,CAAWS;IAA/C,gBACE,oBAAC,gBAAD,CAAkB,QAAlB;MAA2B,KAAK,EAAE,KAAKR,KAAL,CAAWC;IAA7C,GACG,KAAKF,KAAL,CAAWU,QADd,CADF,CADF,CADF;EASD;;AA5BD;;AA+BF,OAAO,MAAMC,QAAQ,GACnB,gDAAyBd,WAAzB,GAAuCL,gBAAgB,CAACmB,QADnD;;AAGP,IAAI,iDAA0B,CAACC,MAAM,CAACC,sBAAtC,EAA8D;EAC5D3B,sBAAsB;AACvB;;AAQD,SAAS4B,eAAT,CAAyBC,MAAzB,EAAiD;EAC/C;EACA;EACA,IAAIC,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,MAA7B,EAAqC;IACnCH,MAAM,KAAK3B,UAAX,IACE;IACA+B,OAAO,CAACC,IAAR,CACE,wCACK;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAZQ,GAaK,wDAdP,CAFF;EAkBD;AACF;;AAED,OAAO,SAASC,YAAT,GAA0D;EAC/D,MAAMC,eAA+B,GAAGxC,KAAK,CAACyC,UAAN,CAAiB/B,gBAAjB,CAAxC;EACA,MAAMgC,WAAW,GAAG1C,KAAK,CAACyC,UAAN,CAAiB5B,kBAAjB,CAApB;EACA,MAAMO,SAAS,GAAGpB,KAAK,CAACyC,UAAN,CAAiB7B,gBAAjB,CAAlB;EACAoB,eAAe,CAACQ,eAAD,CAAf;EAEA,MAAMG,cAAc,GAAG3C,KAAK,CAAC4C,MAAN,CAAiC,EAAjC,CAAvB;EACA,MAAMC,sBAAsB,GAAG7C,KAAK,CAAC4C,MAAN,CAAa,EAAb,CAA/B;EAEA,OAAO,CACL,SAASE,GAAT,CAAaC,KAAb,EAAiC;IAC/B,MAAMC,SAAS,GAAG/C,MAAM,CAAC8C,KAAD,EAAQP,eAAR,CAAxB;;IACA,IAAI,EAAE,6CAAF,CAAJ,EAA+B;MAC7B,OAAOQ,SAAP;IACD;;IACD,MAAM;MAACC,KAAD;MAAQC;IAAR,IAAmB,IAAIC,KAAJ,CAAU,mBAAV,CAAzB;IAEA,MAAMC,QAAQ,GAAG,CAACV,WAAD,EAActB,SAAd,CAAjB;;IACA,IACEyB,sBAAsB,CAACQ,OAAvB,CAA+B,CAA/B,MAAsCD,QAAQ,CAAC,CAAD,CAA9C,IACAP,sBAAsB,CAACQ,OAAvB,CAA+B,CAA/B,MAAsCD,QAAQ,CAAC,CAAD,CAFhD,EAGE;MACA,IAAIV,WAAW,IAAI,CAACtB,SAApB,EAA+B;QAC7BuB,cAAc,CAACU,OAAf,GAAyBX,WAAW,CAACf,KAAZ,CAAkB;UACzC2B,SAAS,EAAE;YAACL,KAAD;YAAQC;UAAR,CAD8B;UAEzCK,UAAU,EAAE;QAF6B,CAAlB,CAAzB;MAID;;MACDV,sBAAsB,CAACQ,OAAvB,GAAiCD,QAAjC;IACD;;IAED,IAAIT,cAAc,CAACU,OAAnB,EAA4B;MAC1B,OAAQ,GAAEV,cAAc,CAACU,OAAQ,IAAGL,SAAU,EAA9C;IACD;;IAED,OAAOA,SAAP;EACD,CA3BI,CAAP;AA6BD;AAED,OAAO,SAASQ,YAAT,CAAsB;EAC3BtD,eAD2B;EAE3BD,MAF2B;EAG3BwD;AAH2B,CAAtB,EAIwB;EAC7B,SAASC,MAAT,CAAgBC,IAAhB,EAA2BC,QAA3B,EAAqC;IACnC,2CAAa;MACX,IAAID,IAAI,CAACE,aAAT,EAAwB;QACtB;QACAxB,OAAO,CAACC,IAAR,CACE,8DADF;QAGAD,OAAO,CAACC,IAAR,CACE,8FADF;QAGA;MACD;IACF;;IAED,MAAMwB,aAAwB,GAAG;MAC/BC,QAAQ,EAAE,EADqB;MAE/BJ,IAAI,EAAEA,IAFyB;MAG/B1D,MAH+B;MAI/BC,eAJ+B;MAK/BuD;IAL+B,CAAjC;;IAQA,IAAI,6CAAJ,EAA4B;MAC1BtD,gBAAgB,CAAC2D,aAAD,EAAgB,CAAhB,CAAhB;IACD;;IAED,OAAOE,4BAA4B,CACjCC,kBAAkB,CAACH,aAAD,EAAgBF,QAAhB,CADe,CAAnC;EAGD;;EAED,OAAOF,MAAP;AACD;AAED,OAAO,MAAMA,MAAgB,GAAGF,YAAY,CAAC;EAC3CtD,eAD2C;EAE3CD,MAF2C;EAG3CwD,OAAO,EAAEzC,SAAS,IAAIA;AAHqB,CAAD,CAArC;AAMP,OAAO,MAAMkD,aAA8B,GAAG,CAACC,SAAD,EAAYC,WAAZ,KAA4B;EACxE,MAAMC,SAAS,GAAGF,SAAS,CAACN,aAA5B;;EAEA,IAAI,6CAAJ,EAA4B;IAC1B1D,gBAAgB,CAACkE,SAAD,EAAY,CAAZ,CAAhB;EACD;;EAED,OAAOL,4BAA4B,CAACM,cAAc,CAACD,SAAD,EAAYD,WAAZ,CAAf,CAAnC;AACD,CARM;AAUP,OAAO,MAAMG,aAA0B,GAAG,CAACJ,SAAD,EAAYP,QAAZ,KAAyB;EACjE;EACA,MAAMS,SAAS,GAAGF,SAAS,CAACN,aAA5B;;EAEA,2CAAa;IACX,IAAI,CAACQ,SAAL,EAAgB;MACd;MACAhC,OAAO,CAACC,IAAR,CACE,yFADF;MAGA;IACD;EACF;;EAED,IAAI,6CAAJ,EAA4B;IAC1BnC,gBAAgB,CAACkE,SAAD,EAAY,CAAZ,CAAhB;IACA,OAAOL,4BAA4B,CACjCQ,YAAY,CAACC,eAAe,CAACJ,SAAD,EAAYT,QAAZ,CAAhB,EAAuCO,SAAvC,EAAkDP,QAAlD,CADqB,CAAnC;EAGD,CALD,MAKO;IACL,OAAOI,4BAA4B,CAACS,eAAe,CAACJ,SAAD,EAAYT,QAAZ,CAAhB,CAAnC;EACD;AACF,CAtBM;AAwBP,OAAO,MAAMc,SAAS,GAAGH,aAAlB;AAEP,OAAO,MAAMI,WAA0B,GAAG,CAACR,SAAD,EAAYV,OAAZ,KAAwB;EAChE,MAAMY,SAAS,GAAGF,SAAS,CAACN,aAA5B;;EAEA,2CAAa;IACX,IAAI,CAACQ,SAAL,EAAgB;MACd;MACAhC,OAAO,CAACC,IAAR,CACE,2FADF;MAGA;IACD;EACF;;EAED,MAAMsC,QAAQ,GAAG;IACf1E,eAAe,EAAEmE,SAAS,CAACnE,eADZ;IAEfyD,IAAI,EAAEU,SAAS,CAACV,IAFD;IAGf1D,MAAM,EAAEoE,SAAS,CAACpE,MAHH;IAIfwD,OAAO,EAAEA,OAJM;IAKfM,QAAQ,EAAEM,SAAS,CAACN;EALL,CAAjB;;EAQA,IAAI,6CAAJ,EAA4B;IAC1B5D,gBAAgB,CAACyE,QAAD,EAAW,CAAX,CAAhB;EACD;;EAED,OAAOZ,4BAA4B,CAACY,QAAD,CAAnC;AACD,CA1BM;AA4BP,OAAO,SAASX,kBAAT,CACLI,SADK,EAELT,QAFK,EAGL;EACA,IAAI,OAAOA,QAAP,KAAoB,UAAxB,EAAoC;IAClC,OAAOiB,qBAAqB,CAACR,SAAD,EAAYT,QAAZ,CAA5B;EACD;;EAED,OAAOkB,oBAAoB,CAACT,SAAD,EAAYT,QAAZ,CAA3B;AACD;;AAED,SAASY,YAAT,CAAsBI,QAAtB,EAAgCT,SAAhC,EAA2CP,QAA3C,EAAqD;EACnD,OAAO,EACL,GAAGgB,QADE;IAELG,GAAG,EAAE;MACHC,IAAI,EAAEpB,QADH;MAEHqB,IAAI,EAAEd,SAAS,CAACe,WAFb;MAGHvB,IAAI,EAAEQ,SAAS,CAACN,aAAV,CAAwBF,IAH3B;MAIHzD,eAAe,EAAEiE,SAAS,CAACN,aAAV,CAAwBE,QAAxB,CAAiCoB,MAAjC,GACbhB,SAAS,CAACN,aAAV,CAAwBE,QAAxB,CAAiC,CAAjC,EAAoCqB,OADvB,GAEbjB,SAAS,CAACN,aAAV,CAAwB3D;IANzB;EAFA,CAAP;AAWD;;AAED,OAAO,SAASuE,eAAT,CACLJ,SADK,EAELT,QAFK,EAGL;EACA,IAAI,OAAOA,QAAP,KAAoB,UAAxB,EAAoC;IAClC,OAAOyB,kBAAkB,CAAChB,SAAD,EAAYT,QAAZ,CAAzB;EACD;;EAED,OAAO0B,iBAAiB,CAACjB,SAAD,EAAYT,QAAZ,CAAxB;AACD;AAED,OAAO,SAASkB,oBAAT,CAA8BT,SAA9B,EAAoDtB,KAApD,EAAwE;EAC7E,OAAOwC,aAAa,CAAClB,SAAD,EAAYmB,yBAAyB,CAACzC,KAAD,CAArC,CAApB;AACD;AAED,OAAO,SAASuC,iBAAT,CAA2BjB,SAA3B,EAAiDtB,KAAjD,EAAqE;EAC1E,OAAOwC,aAAa,CAAClB,SAAD,EAAYoB,sBAAsB,CAAC1C,KAAD,CAAlC,CAApB;AACD;AAED,OAAO,SAAS8B,qBAAT,CACLR,SADK,EAELqB,OAFK,EAGL;EACA,OAAOpB,cAAc,CAAQD,SAAR,EAAmB,CAACtB,KAAD,EAAQ7B,KAAR,KACtCyE,YAAY,CAAC5C,KAAD,EAAQ2C,OAAO,CAACxE,KAAD,CAAf,CADO,CAArB;AAGD;AAED,OAAO,SAASmE,kBAAT,CACLhB,SADK,EAELqB,OAFK,EAGL;EACA,OAAOpB,cAAc,CAAQD,SAAR,EAAmB,CAACtB,KAAD,EAAQ7B,KAAR,KACtC0E,SAAS,CAAC7C,KAAD,EAAQ2C,OAAO,CAACxE,KAAD,CAAf,CADU,CAArB;AAGD;AAED,OAAO,SAASsE,yBAAT,CACLzC,KADK,EAEkC;EACvC,OAAO;IACLqC,OAAO,EAAES,UAAU,IAAIF,YAAY,CAACE,UAAD,EAAa9C,KAAb,CAD9B;IAEL+C,qBAAqB,EAAE,IAFlB;IAGLC,OAAO,EAAEP,yBAHJ;IAILzC,KAAK,EAAEA;EAJF,CAAP;AAMD;AAED,OAAO,SAAS0C,sBAAT,CACL1C,KADK,EAEkC;EACvC,OAAO;IACLqC,OAAO,EAAES,UAAU,IAAID,SAAS,CAACC,UAAD,EAAa9C,KAAb,CAD3B;IAEL+C,qBAAqB,EAAE,IAFlB;IAGLC,OAAO,EAAEN,sBAHJ;IAIL1C,KAAK,EAAEA;EAJF,CAAP;AAMD;AAED,OAAO,SAASwC,aAAT,CACLlB,SADK,EAEL2B,gBAFK,EAGL;EACA,IAAI3B,SAAS,CAACN,QAAV,CAAmBoB,MAAnB,KAA8B,CAAlC,EAAqC;IACnC,MAAMpC,KAAK,GAAGiD,gBAAgB,CAACZ,OAAjB,CAAyBf,SAAS,CAACnE,eAAV,EAAzB,CAAd;IACA,MAAM+F,MAAiB,GAAG;MACxBlC,QAAQ,EAAEM,SAAS,CAACN,QADI;MAExBJ,IAAI,EAAEU,SAAS,CAACV,IAFQ;MAGxB1D,MAAM,EAAEoE,SAAS,CAACpE,MAHM;MAIxBwD,OAAO,EAAEY,SAAS,CAACZ,OAJK;MAKxBvD,eAAe,EAAE,MAAM6C;IALC,CAA1B;;IAOA,IAAI,6CAAJ,EAA4B;MAC1BkD,MAAM,CAACtE,KAAP,GAAe0C,SAAS,CAAC1C,KAAzB;IACD;;IACD,OAAOsE,MAAP;EACD,CAbD,MAaO;IACL,MAAMC,IAAI,GAAG7B,SAAS,CAACN,QAAV,CAAmB,CAAnB,CAAb;;IAEA,IACEmC,IAAI,CAACJ,qBAAL,KAA+B,IAA/B,IACAE,gBAAgB,CAACF,qBAAjB,KAA2C,IAF7C,EAGE;MACA,MAAMlB,QAAQ,GAAGoB,gBAAgB,CAACZ,OAAjB,CAAyBc,IAAI,CAACnD,KAA9B,CAAjB;MAEA,MAAMkD,MAAiB,GAAG;QACxB/F,eAAe,EAAEmE,SAAS,CAACnE,eADH;QAExByD,IAAI,EAAEU,SAAS,CAACV,IAFQ;QAGxB1D,MAAM,EAAEoE,SAAS,CAACpE,MAHM;QAIxBwD,OAAO,EAAEY,SAAS,CAACZ,OAJK;QAKxBM,QAAQ,EAAE,CAACmC,IAAI,CAACH,OAAL,CAAanB,QAAb,CAAD,EAAyBuB,MAAzB,CACR9B,SAAS,CAACN,QAAV,CAAmBqC,KAAnB,CAAyB,CAAzB,CADQ;MALc,CAA1B;;MAUA,IAAI,6CAAJ,EAA4B;QAC1BH,MAAM,CAACtE,KAAP,GAAe0C,SAAS,CAAC1C,KAAzB;MACD;;MAED,OAAOsE,MAAP;IACD;;IAED,OAAO3B,cAAc,CAACD,SAAD,EAAY2B,gBAAgB,CAACZ,OAA7B,CAArB;EACD;AACF;AAED,OAAO,SAASd,cAAT,CACLD,SADK,EAELe,OAFK,EAGL;EACA,MAAMR,QAAmB,GAAG;IAC1B1E,eAAe,EAAEmE,SAAS,CAACnE,eADD;IAE1ByD,IAAI,EAAEU,SAAS,CAACV,IAFU;IAG1B1D,MAAM,EAAEoE,SAAS,CAACpE,MAHQ;IAI1BwD,OAAO,EAAEY,SAAS,CAACZ,OAJO;IAK1B;IACAM,QAAQ,EAAE,CAAC;MAAC+B,qBAAqB,EAAE,KAAxB;MAA+BV;IAA/B,CAAD,EAA0Ce,MAA1C,CACR9B,SAAS,CAACN,QADF;EANgB,CAA5B;;EAUA,IAAI,6CAAJ,EAA4B;IAC1Ba,QAAQ,CAACjD,KAAT,GAAiB0C,SAAS,CAAC1C,KAA3B;EACD;;EACD,OAAOiD,QAAP;AACD;AAED,OAAO,SAASZ,4BAAT,CAAsCK,SAAtC,EAA4D;EACjE,MAAM;IAACN,QAAD;IAAWJ,IAAX;IAAiB1D,MAAjB;IAAyBwD,OAAzB;IAAkCvD,eAAlC;IAAmD6E;EAAnD,IAA0DV,SAAhE;;EAEA,IAAI,6CAAJ,EAA4B;IAC1B,IAAIgC,cAAJ,EAAoBC,eAApB;;IACA,IAAIjC,SAAS,CAAC1C,KAAd,EAAqB;MACnB0E,cAAc,GAAGhC,SAAS,CAAC1C,KAAV,CAAgB2B,SAAjC;MACAgD,eAAe,GAAGjC,SAAS,CAAC1C,KAAV,CAAgB4B,UAAlC;IACD;EACF;;EAED,IAAI,6CAAJ,EAA4B;IAC1B,IAAIZ,cAAJ;EACD;;EAED,MAAM4D,aAAa,gBAAGvG,KAAK,CAACwG,UAAN,CAAsC,CAACtF,KAAD,EAAQuF,GAAR,KAAgB;IAC1E,MAAMpC,SAAyB,GAAGrE,KAAK,CAACyC,UAAN,CAAiB/B,gBAAjB,CAAlC;IACA,MAAMgC,WAAW,GAAG1C,KAAK,CAACyC,UAAN,CAAiB5B,kBAAjB,CAApB;IACA,MAAMO,SAAS,GAAGpB,KAAK,CAACyC,UAAN,CAAiB7B,gBAAjB,CAAlB;IACAoB,eAAe,CAACqC,SAAD,CAAf;IAEA,MAAMqC,YAAiB,GAAGC,gBAAgB,CAACzF,KAAD,CAA1C;IACA,IAAI6B,KAAK,GAAG6D,YAAY,CAAC1G,eAAD,EAAkB6D,QAAlB,EAA4B7C,KAA5B,CAAxB;;IAEA,IAAIA,KAAK,CAAC2F,MAAV,EAAkB;MAChB,IAAI,OAAO3F,KAAK,CAAC2F,MAAb,KAAwB,UAA5B,EAAwC;QACtC9D,KAAK,GAAG6C,SAAS,CAAC7C,KAAD,EAAQ7B,KAAK,CAAC2F,MAAN,CAAa3F,KAAb,CAAR,CAAjB;MACD,CAFD,MAEO;QACL6B,KAAK,GAAG6C,SAAS,CAAC7C,KAAD,EAAQ7B,KAAK,CAAC2F,MAAd,CAAjB;MACD;IACF;;IAED,MAAMC,gBAAgB,GAAG7G,MAAM,CAAC8C,KAAD,EAAQsB,SAAR,CAA/B;IACA,MAAM0C,OAAO,GAAG7F,KAAK,CAAC8F,GAAN,GAAY9F,KAAK,CAAC8F,GAAlB,GAAwBrD,IAAxC;IACA+C,YAAY,CAAC1D,SAAb,GAAyB9B,KAAK,CAAC8B,SAAN,GACpB,GAAE9B,KAAK,CAAC8B,SAAU,IAAG8D,gBAAiB,EADlB,GAErBA,gBAFJ;;IAIA,IAAI,iDAA0BpE,WAA1B,IAAyC,CAACtB,SAA9C,EAAyD;MACvD,IAAI,CAACuB,cAAL,EAAqB;QACnBA,cAAc,GAAGD,WAAW,CAACf,KAAZ,CAAkB;UACjC2B,SAAS,EAAE+C,cADsB;UAEjC9C,UAAU,EAAE+C;QAFqB,CAAlB,CAAjB;MAID;;MAED,MAAMW,MAAM,GAAI,GAAEtE,cAAe,IAAG+D,YAAY,CAAC1D,SAAU,EAA3D;MACA0D,YAAY,CAAC1D,SAAb,GAAyBiE,MAAzB;IACD;;IAED,IAAI,iDAA0BnF,MAAM,CAACC,sBAArC,EAA6D;MAC3DD,MAAM,CAACC,sBAAP,CAA8BmF,SAA9B,CAAwCC,GAAxC,CACET,YAAY,CAAC1D,SADf,EAEED,KAFF;;MAIA,IAAIgC,GAAJ,EAAS;QACPjD,MAAM,CAACC,sBAAP,CAA8BqF,aAA9B,CAA4CD,GAA5C,CACET,YAAY,CAAC1D,SADf,EAEE;UACEW,IAAI,EAAEoB,GAAG,CAACpB,IADZ;UAEEuB,WAAW,EAAEH,GAAG,CAACE,IAFnB;UAGEoC,aAAa,EAAEtC,GAAG,CAAC7E,eAAJ,CAAoB,EAApB,EAAwBgB,KAAxB,CAHjB;UAIEoG,cAAc,EACZ,OAAOvC,GAAG,CAACC,IAAX,KAAoB,UAApB,GAAiCD,GAAG,CAACC,IAAJ,CAAS9D,KAAT,CAAjC,GAAmD6D,GAAG,CAACC;QAL3D,CAFF;MAUD;IACF;;IAED,IAAI9D,KAAK,CAACqG,IAAV,EAAgB;MACd;MACAlF,OAAO,CAACC,IAAR,CACE,uGADF;IAGD;;IACD,oBAAO,oBAAC,OAAD,eAAaoE,YAAb;MAA2B,GAAG,EAAED,GAAG,IAAIvF,KAAK,CAACqG;IAA7C,GAAP;EACD,CA7DqB,CAAtB;EA+DA,MAAMC,OAAO,GAAG/D,OAAO,CAAC8C,aAAD,CAAvB;EACAiB,OAAO,CAAC3D,aAAR,GAAwB;IACtBF,IADsB;IAEtBI,QAFsB;IAGtB9D,MAHsB;IAItBwD,OAJsB;IAKtBvD;EALsB,CAAxB;;EAQA,2CAAa;IACX,IAAIgF,WAAJ;;IAEA,IAAI,OAAOvB,IAAP,KAAgB,QAApB,EAA8B;MAC5BuB,WAAW,GAAGvB,IAAd;IACD,CAFD,MAEO,IAAIA,IAAI,CAACuB,WAAT,EAAsB;MAC3BA,WAAW,GAAGvB,IAAI,CAACuB,WAAnB;IACD,CAFM,MAEA,IAAIvB,IAAI,CAACsB,IAAT,EAAe;MACpBC,WAAW,GAAGvB,IAAI,CAACsB,IAAnB;IACD,CAFM,MAEA;MACLC,WAAW,GAAG,SAAd;IACD;;IAEDsC,OAAO,CAACtC,WAAR,GAAuB,UAASA,WAAY,GAA5C;EACD;;EAED,OAAOsC,OAAP;AACD,C,CAED;;AAEA,OAAO,SAASZ,YAAT,CACL1G,eADK,EAEL6D,QAFK,EAGL7C,KAHK,EAIQ;EACb,IAAI+E,MAAM,GAAG/F,eAAe,EAA5B;EACA,IAAIuH,CAAC,GAAG1D,QAAQ,CAACoB,MAAjB;;EACA,OAAOsC,CAAC,EAAR,EAAY;IACV;IACA,MAAMrC,OAAO,GAAGrB,QAAQ,CAAC0D,CAAD,CAAR,CAAYrC,OAA5B;IAIAa,MAAM,GAAGb,OAAO,CAACa,MAAD,EAAS/E,KAAT,CAAhB;EACD;;EACD,OAAO+E,MAAP;AACD;;AAED,SAASyB,QAAT,CAAkBC,CAAlB,EAA0B;EACxB,OAAO,OAAOA,CAAP,KAAa,QAAb,IAAyBA,CAAC,KAAK,IAAtC;AACD;;AAED,SAAShB,gBAAT,CAA0BiB,MAA1B,EAAkC;EAChC,MAAM3B,MAAM,GAAG,EAAf;;EAEA,KAAK,MAAM4B,GAAX,IAAkBD,MAAlB,EAA0B;IACxB,IAAIC,GAAG,CAAC,CAAD,CAAH,KAAW,GAAf,EAAoB;MAClB5B,MAAM,CAAC4B,GAAD,CAAN,GAAcD,MAAM,CAACC,GAAD,CAApB;IACD;EACF;;EAED,OAAO5B,MAAP;AACD;;AAED,SAASL,SAAT,CAAmBkC,CAAnB,EAAsBC,CAAtB,EAAyB;EACvB,MAAM9B,MAAM,GAAG+B,MAAM,CAAC,EAAD,EAAKF,CAAL,CAArB;;EAEA,KAAK,MAAMD,GAAX,IAAkBE,CAAlB,EAAqB;IACnB,MAAME,GAAG,GAAGF,CAAC,CAACF,GAAD,CAAb;;IAEA,IAAIH,QAAQ,CAACO,GAAD,CAAR,IAAiBP,QAAQ,CAACI,CAAC,CAACD,GAAD,CAAF,CAA7B,EAAuC;MACrC5B,MAAM,CAAC4B,GAAD,CAAN,GAAcjC,SAAS,CAACkC,CAAC,CAACD,GAAD,CAAF,EAASI,GAAT,CAAvB;IACD,CAFD,MAEO;MACLhC,MAAM,CAAC4B,GAAD,CAAN,GAAcI,GAAd;IACD;EACF;;EAED,OAAOhC,MAAP;AACD;;AAED,SAASN,YAAT,CAAsBmC,CAAtB,EAAyBC,CAAzB,EAA4B;EAC1B,OAAOC,MAAM,CAACA,MAAM,CAAC,EAAD,EAAKF,CAAL,CAAP,EAAgBC,CAAhB,CAAb;AACD;;AAED,SAASC,MAAT,CAAgBE,MAAhB,EAAwBN,MAAxB,EAAgC;EAC9B,KAAK,MAAMC,GAAX,IAAkBD,MAAlB,EAA0B;IACxBM,MAAM,CAACL,GAAD,CAAN,GAAcD,MAAM,CAACC,GAAD,CAApB;EACD;;EACD,OAAOK,MAAP;AACD"}","export function driver(style, styletron) {\n const tx = renderDeclarativeRules(style, styletron);\n return styletron.renderStyle(tx);\n}\nexport function getInitialStyle() {\n return {};\n}\nexport function renderDeclarativeRules(style, styletron) {\n for (const key in style) {\n const val = style[key];\n\n if (key === \"animationName\" && typeof val !== \"string\") {\n style.animationName = styletron.renderKeyframes(val);\n continue;\n }\n\n if (key === \"fontFamily\" && typeof val !== \"string\") {\n if (Array.isArray(val)) {\n let result = \"\";\n\n for (const font of val) {\n if (typeof font === \"object\") {\n result += `${styletron.renderFontFace(font)},`;\n } else if (typeof font === \"string\") {\n result += `${font},`;\n }\n }\n\n style.fontFamily = result.slice(0, -1);\n continue;\n } else if (val === void 0) {\n continue;\n } else {\n style.fontFamily = styletron.renderFontFace(val);\n continue;\n }\n }\n\n if (typeof val === \"object\" && val !== null) {\n renderDeclarativeRules(val, styletron);\n }\n }\n\n return style;\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkcml2ZXIiLCJzdHlsZSIsInN0eWxldHJvbiIsInR4IiwicmVuZGVyRGVjbGFyYXRpdmVSdWxlcyIsInJlbmRlclN0eWxlIiwiZ2V0SW5pdGlhbFN0eWxlIiwia2V5IiwidmFsIiwiYW5pbWF0aW9uTmFtZSIsInJlbmRlcktleWZyYW1lcyIsIkFycmF5IiwiaXNBcnJheSIsInJlc3VsdCIsImZvbnQiLCJyZW5kZXJGb250RmFjZSIsImZvbnRGYW1pbHkiLCJzbGljZSJdLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFByb3BlcnRpZXMsXG4gIEZvbnRGYWNlIGFzIEZvbnRGYWNlT2JqZWN0LFxuICBLZXlmcmFtZXNPYmplY3QsXG59IGZyb20gXCIuL3N0eWxlLXR5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIHtGb250RmFjZU9iamVjdCwgS2V5ZnJhbWVzT2JqZWN0fTtcblxuZXhwb3J0IHR5cGUgU3R5bGVPYmplY3QgPSBQcm9wZXJ0aWVzICYge1xuICBba2V5IGluIHN0cmluZ106IFByb3BlcnRpZXNba2V5b2YgUHJvcGVydGllc10gfCBTdHlsZU9iamVjdDtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RhbmRhcmRFbmdpbmUge1xuICByZW5kZXJTdHlsZShzdHlsZTogU3R5bGVPYmplY3QpOiBzdHJpbmc7XG4gIHJlbmRlcktleWZyYW1lcyhrZXlmcmFtZXM6IEtleWZyYW1lc09iamVjdCk6IHN0cmluZztcbiAgcmVuZGVyRm9udEZhY2UoZm9udEZhY2U6IEZvbnRGYWNlT2JqZWN0KTogc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZHJpdmVyKHN0eWxlOiBTdHlsZU9iamVjdCwgc3R5bGV0cm9uOiBTdGFuZGFyZEVuZ2luZSk6IHN0cmluZyB7XG4gIGNvbnN0IHR4ID0gcmVuZGVyRGVjbGFyYXRpdmVSdWxlcyhzdHlsZSwgc3R5bGV0cm9uKTtcbiAgcmV0dXJuIHN0eWxldHJvbi5yZW5kZXJTdHlsZSh0eCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRJbml0aWFsU3R5bGUoKTogU3R5bGVPYmplY3Qge1xuICByZXR1cm4ge307XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJEZWNsYXJhdGl2ZVJ1bGVzKFxuICBzdHlsZTogU3R5bGVPYmplY3QsXG4gIHN0eWxldHJvbjogU3RhbmRhcmRFbmdpbmUsXG4pIHtcbiAgZm9yIChjb25zdCBrZXkgaW4gc3R5bGUpIHtcbiAgICBjb25zdCB2YWwgPSBzdHlsZVtrZXldO1xuICAgIGlmIChrZXkgPT09IFwiYW5pbWF0aW9uTmFtZVwiICYmIHR5cGVvZiB2YWwgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgIHN0eWxlLmFuaW1hdGlvbk5hbWUgPSBzdHlsZXRyb24ucmVuZGVyS2V5ZnJhbWVzKHZhbCBhcyBhbnkpO1xuICAgICAgY29udGludWU7XG4gICAgfVxuICAgIGlmIChrZXkgPT09IFwiZm9udEZhbWlseVwiICYmIHR5cGVvZiB2YWwgIT09IFwic3RyaW5nXCIpIHtcbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHZhbCkpIHtcbiAgICAgICAgbGV0IHJlc3VsdCA9IFwiXCI7XG4gICAgICAgIGZvciAoY29uc3QgZm9udCBvZiB2YWwpIHtcbiAgICAgICAgICBpZiAodHlwZW9mIGZvbnQgPT09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgICAgIHJlc3VsdCArPSBgJHtzdHlsZXRyb24ucmVuZGVyRm9udEZhY2UoZm9udCBhcyBhbnkpfSxgO1xuICAgICAgICAgIH0gZWxzZSBpZiAodHlwZW9mIGZvbnQgPT09IFwic3RyaW5nXCIpIHtcbiAgICAgICAgICAgIHJlc3VsdCArPSBgJHtmb250fSxgO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBzdHlsZS5mb250RmFtaWx5ID0gcmVzdWx0LnNsaWNlKDAsIC0xKTtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9IGVsc2UgaWYgKHZhbCA9PT0gdm9pZCAwKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgc3R5bGUuZm9udEZhbWlseSA9IHN0eWxldHJvbi5yZW5kZXJGb250RmFjZSh2YWwgYXMgYW55KTtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgfVxuICAgIGlmICh0eXBlb2YgdmFsID09PSBcIm9iamVjdFwiICYmIHZhbCAhPT0gbnVsbCkge1xuICAgICAgcmVuZGVyRGVjbGFyYXRpdmVSdWxlcyh2YWwgYXMgU3R5bGVPYmplY3QsIHN0eWxldHJvbik7XG4gICAgfVxuICB9XG4gIHJldHVybiBzdHlsZTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBa0JBLE9BQU8sU0FBU0EsTUFBVCxDQUFnQkMsS0FBaEIsRUFBb0NDLFNBQXBDLEVBQXVFO0VBQzVFLE1BQU1DLEVBQUUsR0FBR0Msc0JBQXNCLENBQUNILEtBQUQsRUFBUUMsU0FBUixDQUFqQztFQUNBLE9BQU9BLFNBQVMsQ0FBQ0csV0FBVixDQUFzQkYsRUFBdEIsQ0FBUDtBQUNEO0FBRUQsT0FBTyxTQUFTRyxlQUFULEdBQXdDO0VBQzdDLE9BQU8sRUFBUDtBQUNEO0FBRUQsT0FBTyxTQUFTRixzQkFBVCxDQUNMSCxLQURLLEVBRUxDLFNBRkssRUFHTDtFQUNBLEtBQUssTUFBTUssR0FBWCxJQUFrQk4sS0FBbEIsRUFBeUI7SUFDdkIsTUFBTU8sR0FBRyxHQUFHUCxLQUFLLENBQUNNLEdBQUQsQ0FBakI7O0lBQ0EsSUFBSUEsR0FBRyxLQUFLLGVBQVIsSUFBMkIsT0FBT0MsR0FBUCxLQUFlLFFBQTlDLEVBQXdEO01BQ3REUCxLQUFLLENBQUNRLGFBQU4sR0FBc0JQLFNBQVMsQ0FBQ1EsZUFBVixDQUEwQkYsR0FBMUIsQ0FBdEI7TUFDQTtJQUNEOztJQUNELElBQUlELEdBQUcsS0FBSyxZQUFSLElBQXdCLE9BQU9DLEdBQVAsS0FBZSxRQUEzQyxFQUFxRDtNQUNuRCxJQUFJRyxLQUFLLENBQUNDLE9BQU4sQ0FBY0osR0FBZCxDQUFKLEVBQXdCO1FBQ3RCLElBQUlLLE1BQU0sR0FBRyxFQUFiOztRQUNBLEtBQUssTUFBTUMsSUFBWCxJQUFtQk4sR0FBbkIsRUFBd0I7VUFDdEIsSUFBSSxPQUFPTSxJQUFQLEtBQWdCLFFBQXBCLEVBQThCO1lBQzVCRCxNQUFNLElBQUssR0FBRVgsU0FBUyxDQUFDYSxjQUFWLENBQXlCRCxJQUF6QixDQUFzQyxHQUFuRDtVQUNELENBRkQsTUFFTyxJQUFJLE9BQU9BLElBQVAsS0FBZ0IsUUFBcEIsRUFBOEI7WUFDbkNELE1BQU0sSUFBSyxHQUFFQyxJQUFLLEdBQWxCO1VBQ0Q7UUFDRjs7UUFDRGIsS0FBSyxDQUFDZSxVQUFOLEdBQW1CSCxNQUFNLENBQUNJLEtBQVAsQ0FBYSxDQUFiLEVBQWdCLENBQUMsQ0FBakIsQ0FBbkI7UUFDQTtNQUNELENBWEQsTUFXTyxJQUFJVCxHQUFHLEtBQUssS0FBSyxDQUFqQixFQUFvQjtRQUN6QjtNQUNELENBRk0sTUFFQTtRQUNMUCxLQUFLLENBQUNlLFVBQU4sR0FBbUJkLFNBQVMsQ0FBQ2EsY0FBVixDQUF5QlAsR0FBekIsQ0FBbkI7UUFDQTtNQUNEO0lBQ0Y7O0lBQ0QsSUFBSSxPQUFPQSxHQUFQLEtBQWUsUUFBZixJQUEyQkEsR0FBRyxLQUFLLElBQXZDLEVBQTZDO01BQzNDSixzQkFBc0IsQ0FBQ0ksR0FBRCxFQUFxQk4sU0FBckIsQ0FBdEI7SUFDRDtFQUNGOztFQUNELE9BQU9ELEtBQVA7QUFDRCJ9","/* Web Font Loader v1.6.28 - (c) Adobe Systems, Google. License: Apache 2.0 */(function(){function aa(a,b,c){return a.call.apply(a.bind,arguments)}function ba(a,b,c){if(!a)throw Error();if(2=b.f?e():a.fonts.load(fa(b.a),b.h).then(function(a){1<=a.length?d():setTimeout(f,25)},function(){e()})}f()}),e=null,f=new Promise(function(a,d){e=setTimeout(d,b.f)});Promise.race([f,d]).then(function(){e&&(clearTimeout(e),e=null);b.g(b.a)},function(){b.j(b.a)})};function Q(a,b,c,d,e,f,g){this.v=a;this.B=b;this.c=c;this.a=d;this.s=g||\"BESbswy\";this.f={};this.w=e||3E3;this.u=f||null;this.m=this.j=this.h=this.g=null;this.g=new M(this.c,this.s);this.h=new M(this.c,this.s);this.j=new M(this.c,this.s);this.m=new M(this.c,this.s);a=new G(this.a.c+\",serif\",J(this.a));a=O(a);this.g.a.style.cssText=a;a=new G(this.a.c+\",sans-serif\",J(this.a));a=O(a);this.h.a.style.cssText=a;a=new G(\"serif\",J(this.a));a=O(a);this.j.a.style.cssText=a;a=new G(\"sans-serif\",J(this.a));a=\nO(a);this.m.a.style.cssText=a;N(this.g);N(this.h);N(this.j);N(this.m)}var R={D:\"serif\",C:\"sans-serif\"},S=null;function T(){if(null===S){var a=/AppleWebKit\\/([0-9]+)(?:\\.([0-9]+))/.exec(window.navigator.userAgent);S=!!a&&(536>parseInt(a[1],10)||536===parseInt(a[1],10)&&11>=parseInt(a[2],10))}return S}Q.prototype.start=function(){this.f.serif=this.j.a.offsetWidth;this.f[\"sans-serif\"]=this.m.a.offsetWidth;this.A=q();U(this)};\nfunction la(a,b,c){for(var d in R)if(R.hasOwnProperty(d)&&b===a.f[R[d]]&&c===a.f[R[d]])return!0;return!1}function U(a){var b=a.g.a.offsetWidth,c=a.h.a.offsetWidth,d;(d=b===a.f.serif&&c===a.f[\"sans-serif\"])||(d=T()&&la(a,b,c));d?q()-a.A>=a.w?T()&&la(a,b,c)&&(null===a.u||a.u.hasOwnProperty(a.a.c))?V(a,a.v):V(a,a.B):ma(a):V(a,a.v)}function ma(a){setTimeout(p(function(){U(this)},a),50)}function V(a,b){setTimeout(p(function(){v(this.g.a);v(this.h.a);v(this.j.a);v(this.m.a);b(this.a)},a),0)};function W(a,b,c){this.c=a;this.a=b;this.f=0;this.m=this.j=!1;this.s=c}var X=null;W.prototype.g=function(a){var b=this.a;b.g&&w(b.f,[b.a.c(\"wf\",a.c,J(a).toString(),\"active\")],[b.a.c(\"wf\",a.c,J(a).toString(),\"loading\"),b.a.c(\"wf\",a.c,J(a).toString(),\"inactive\")]);K(b,\"fontactive\",a);this.m=!0;na(this)};\nW.prototype.h=function(a){var b=this.a;if(b.g){var c=y(b.f,b.a.c(\"wf\",a.c,J(a).toString(),\"active\")),d=[],e=[b.a.c(\"wf\",a.c,J(a).toString(),\"loading\")];c||d.push(b.a.c(\"wf\",a.c,J(a).toString(),\"inactive\"));w(b.f,d,e)}K(b,\"fontinactive\",a);na(this)};function na(a){0==--a.f&&a.j&&(a.m?(a=a.a,a.g&&w(a.f,[a.a.c(\"wf\",\"active\")],[a.a.c(\"wf\",\"loading\"),a.a.c(\"wf\",\"inactive\")]),K(a,\"active\")):L(a.a))};function oa(a){this.j=a;this.a=new ja;this.h=0;this.f=this.g=!0}oa.prototype.load=function(a){this.c=new ca(this.j,a.context||this.j);this.g=!1!==a.events;this.f=!1!==a.classes;pa(this,new ha(this.c,a),a)};\nfunction qa(a,b,c,d,e){var f=0==--a.h;(a.f||a.g)&&setTimeout(function(){var a=e||null,m=d||null||{};if(0===c.length&&f)L(b.a);else{b.f+=c.length;f&&(b.j=f);var h,l=[];for(h=0;h {\n const { forward = [], ...filteredConfig } = config || {};\n const configStr = JSON.stringify(filteredConfig, (k, v) => {\n if (typeof v === 'function') {\n v = String(v);\n if (v.startsWith(k + '(')) {\n v = 'function ' + v;\n }\n }\n return v;\n });\n return [\n `!(function(w,p,f,c){`,\n Object.keys(filteredConfig).length > 0\n ? `c=w[p]=Object.assign(w[p]||{},${configStr});`\n : `c=w[p]=w[p]||{};`,\n `c[f]=(c[f]||[])`,\n forward.length > 0 ? `.concat(${JSON.stringify(forward)})` : ``,\n `})(window,'partytown','forward');`,\n snippetCode,\n ].join('');\n};\n\n/**\n * The `type` attribute for Partytown scripts, which does two things:\n *\n * 1. Prevents the `