exports.id = "vendors-node_modules_next_document_js"; exports.ids = ["vendors-node_modules_next_document_js"]; exports.modules = { /***/ "./node_modules/next/dist/client/experimental-script.js": /*!**************************************************************!*\ !*** ./node_modules/next/dist/client/experimental-script.js ***! \**************************************************************/ /***/ (function(__unused_webpack_module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js"); exports.__esModule = true; exports.initScriptLoader = initScriptLoader; exports.default = void 0; var _extends2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/extends */ "./node_modules/next/node_modules/@babel/runtime/helpers/extends.js")); var _objectWithoutPropertiesLoose2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/objectWithoutPropertiesLoose */ "./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js")); var _react = __webpack_require__(/*! react */ "react"); var _headManagerContext = __webpack_require__(/*! ../next-server/lib/head-manager-context */ "../next-server/lib/head-manager-context"); var _headManager = __webpack_require__(/*! ./head-manager */ "./node_modules/next/dist/client/head-manager.js"); var _requestIdleCallback = __webpack_require__(/*! ./request-idle-callback */ "./node_modules/next/dist/client/request-idle-callback.js"); const ScriptCache = new Map(); const LoadCache = new Set(); const ignoreProps = ['onLoad', 'dangerouslySetInnerHTML', 'children', 'onError', 'strategy']; const loadScript = props => { const { src, id, onLoad = () => {}, dangerouslySetInnerHTML, children = '', onError } = props; const cacheKey = id || src; if (ScriptCache.has(src)) { if (!LoadCache.has(cacheKey)) { LoadCache.add(cacheKey); // Execute onLoad since the script loading has begun ScriptCache.get(src).then(onLoad, onError); } return; } const el = document.createElement('script'); const loadPromise = new Promise((resolve, reject) => { el.addEventListener('load', function () { resolve(); if (onLoad) { onLoad.call(this); } }); el.addEventListener('error', function () { reject(); if (onError) { onError(); } }); }); if (src) { ScriptCache.set(src, loadPromise); LoadCache.add(cacheKey); } if (dangerouslySetInnerHTML) { el.innerHTML = dangerouslySetInnerHTML.__html || ''; } else if (children) { el.textContent = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : ''; } else if (src) { el.src = src; } for (const [k, value] of Object.entries(props)) { if (value === undefined || ignoreProps.includes(k)) { continue; } const attr = _headManager.DOMAttributeNames[k] || k.toLowerCase(); el.setAttribute(attr, value); } document.body.appendChild(el); }; function handleClientScriptLoad(props) { const { strategy = 'afterInteractive' } = props; if (strategy === 'afterInteractive') { loadScript(props); } else if (strategy === 'lazyOnload') { window.addEventListener('load', () => { (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props)); }); } } function loadLazyScript(props) { if (document.readyState === 'complete') { (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props)); } else { window.addEventListener('load', () => { (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props)); }); } } function initScriptLoader(scriptLoaderItems) { scriptLoaderItems.forEach(handleClientScriptLoad); } function Script(props) { const { src = '', onLoad = () => {}, strategy = 'afterInteractive', onError } = props, restProps = (0, _objectWithoutPropertiesLoose2.default)(props, ["src", "onLoad", "dangerouslySetInnerHTML", "strategy", "onError"]); // Context is available only during SSR const { updateScripts, scripts } = (0, _react.useContext)(_headManagerContext.HeadManagerContext); (0, _react.useEffect)(() => { if (strategy === 'afterInteractive') { loadScript(props); } else if (strategy === 'lazyOnload') { loadLazyScript(props); } }, [props, strategy]); if (true) { return null; } if (strategy === 'beforeInteractive') { if (updateScripts) { scripts.beforeInteractive = (scripts.beforeInteractive || []).concat([(0, _extends2.default)({ src, onLoad, onError }, restProps)]); updateScripts(scripts); } } return null; } var _default = Script; exports.default = _default; /***/ }), /***/ "./node_modules/next/dist/client/head-manager.js": /*!*******************************************************!*\ !*** ./node_modules/next/dist/client/head-manager.js ***! \*******************************************************/ /***/ (function(__unused_webpack_module, exports) { "use strict"; exports.__esModule = true; exports.default = initHeadManager; exports.DOMAttributeNames = void 0; const DOMAttributeNames = { acceptCharset: 'accept-charset', className: 'class', htmlFor: 'for', httpEquiv: 'http-equiv', noModule: 'noModule' }; exports.DOMAttributeNames = DOMAttributeNames; function reactElementToDOM({ type, props }) { const el = document.createElement(type); for (const p in props) { if (!props.hasOwnProperty(p)) continue; if (p === 'children' || p === 'dangerouslySetInnerHTML') continue; // we don't render undefined props to the DOM if (props[p] === undefined) continue; const attr = DOMAttributeNames[p] || p.toLowerCase(); if (type === 'script' && (attr === 'async' || attr === 'defer' || attr === 'noModule')) { ; el[attr] = !!props[p]; } else { el.setAttribute(attr, props[p]); } } const { children, dangerouslySetInnerHTML } = props; if (dangerouslySetInnerHTML) { el.innerHTML = dangerouslySetInnerHTML.__html || ''; } else if (children) { el.textContent = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : ''; } return el; } function updateElements(type, components) { const headEl = document.getElementsByTagName('head')[0]; const headCountEl = headEl.querySelector('meta[name=next-head-count]'); if (true) { if (!headCountEl) { console.error('Warning: next-head-count is missing. https://nextjs.org/docs/messages/next-head-count-missing'); return; } } const headCount = Number(headCountEl.content); const oldTags = []; for (let i = 0, j = headCountEl.previousElementSibling; i < headCount; i++, j = j.previousElementSibling) { if (j.tagName.toLowerCase() === type) { oldTags.push(j); } } const newTags = components.map(reactElementToDOM).filter(newTag => { for (let k = 0, len = oldTags.length; k < len; k++) { const oldTag = oldTags[k]; if (oldTag.isEqualNode(newTag)) { oldTags.splice(k, 1); return false; } } return true; }); oldTags.forEach(t => t.parentNode.removeChild(t)); newTags.forEach(t => headEl.insertBefore(t, headCountEl)); headCountEl.content = (headCount - oldTags.length + newTags.length).toString(); } function initHeadManager() { let updatePromise = null; return { mountedInstances: new Set(), updateHead: head => { const promise = updatePromise = Promise.resolve().then(() => { if (promise !== updatePromise) return; updatePromise = null; const tags = {}; head.forEach(h => { if ( // If the font tag is loaded only on client navigation // it won't be inlined. In this case revert to the original behavior h.type === 'link' && h.props['data-optimized-fonts'] && !document.querySelector(`style[data-href="${h.props['data-href']}"]`)) { h.props.href = h.props['data-href']; h.props['data-href'] = undefined; } const components = tags[h.type] || []; components.push(h); tags[h.type] = components; }); const titleComponent = tags.title ? tags.title[0] : null; let title = ''; if (titleComponent) { const { children } = titleComponent.props; title = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : ''; } if (title !== document.title) document.title = title; ['meta', 'base', 'link', 'style', 'script'].forEach(type => { updateElements(type, tags[type] || []); }); }); } }; } /***/ }), /***/ "./node_modules/next/dist/client/request-idle-callback.js": /*!****************************************************************!*\ !*** ./node_modules/next/dist/client/request-idle-callback.js ***! \****************************************************************/ /***/ (function(__unused_webpack_module, exports) { "use strict"; exports.__esModule = true; exports.cancelIdleCallback = exports.requestIdleCallback = void 0; const requestIdleCallback = typeof self !== 'undefined' && self.requestIdleCallback || function (cb) { let start = Date.now(); return setTimeout(function () { cb({ didTimeout: false, timeRemaining: function () { return Math.max(0, 50 - (Date.now() - start)); } }); }, 1); }; exports.requestIdleCallback = requestIdleCallback; const cancelIdleCallback = typeof self !== 'undefined' && self.cancelIdleCallback || function (id) { return clearTimeout(id); }; exports.cancelIdleCallback = cancelIdleCallback; /***/ }), /***/ "./node_modules/next/dist/pages/_document.js": /*!***************************************************!*\ !*** ./node_modules/next/dist/pages/_document.js ***! \***************************************************/ /***/ (function(__unused_webpack_module, exports, __webpack_require__) { "use strict"; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } exports.__esModule = true; exports.Html = Html; exports.Main = Main; exports.NextScript = exports.Head = exports.default = void 0; var _propTypes = _interopRequireDefault(__webpack_require__(/*! prop-types */ "prop-types")); var _react = _interopRequireWildcard(__webpack_require__(/*! react */ "react")); var _server = _interopRequireDefault(__webpack_require__(/*! styled-jsx/server */ "styled-jsx/server")); var _constants = __webpack_require__(/*! ../next-server/lib/constants */ "../next-server/lib/constants"); var _documentContext = __webpack_require__(/*! ../next-server/lib/document-context */ "../next-server/lib/document-context"); var _utils = __webpack_require__(/*! ../next-server/lib/utils */ "../next-server/lib/utils"); exports.DocumentContext = _utils.DocumentContext; exports.DocumentInitialProps = _utils.DocumentInitialProps; exports.DocumentProps = _utils.DocumentProps; var _getPageFiles = __webpack_require__(/*! ../next-server/server/get-page-files */ "../next-server/server/get-page-files"); var _utils2 = __webpack_require__(/*! ../next-server/server/utils */ "../next-server/server/utils"); var _htmlescape = __webpack_require__(/*! ../server/htmlescape */ "./node_modules/next/dist/server/htmlescape.js"); var _experimentalScript = _interopRequireDefault(__webpack_require__(/*! ../client/experimental-script */ "./node_modules/next/dist/client/experimental-script.js")); function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function getDocumentFiles(buildManifest, pathname, inAmpMode) { const sharedFiles = (0, _getPageFiles.getPageFiles)(buildManifest, '/_app'); const pageFiles = inAmpMode ? [] : (0, _getPageFiles.getPageFiles)(buildManifest, pathname); return { sharedFiles, pageFiles, allFiles: [...new Set([...sharedFiles, ...pageFiles])] }; } function getPolyfillScripts(context, props) { // polyfills.js has to be rendered as nomodule without async // It also has to be the first script to load const { assetPrefix, buildManifest, devOnlyCacheBusterQueryString, disableOptimizedLoading } = context; return buildManifest.polyfillFiles.filter(polyfill => polyfill.endsWith('.js') && !polyfill.endsWith('.module.js')).map(polyfill => /*#__PURE__*/_react.default.createElement("script", { key: polyfill, defer: !disableOptimizedLoading, nonce: props.nonce, crossOrigin: props.crossOrigin || undefined, noModule: true, src: `${assetPrefix}/_next/${polyfill}${devOnlyCacheBusterQueryString}` })); } function getPreNextScripts(context, props) { const { scriptLoader, disableOptimizedLoading } = context; return (scriptLoader.beforeInteractive || []).map(file => { const { strategy } = file, scriptProps = _objectWithoutProperties(file, ["strategy"]); return /*#__PURE__*/_react.default.createElement("script", Object.assign({}, scriptProps, { defer: !disableOptimizedLoading, nonce: props.nonce, crossOrigin: props.crossOrigin || undefined })); }); } function getDynamicChunks(context, props, files) { const { dynamicImports, assetPrefix, isDevelopment, devOnlyCacheBusterQueryString, disableOptimizedLoading } = context; return dynamicImports.map(file => { if (!file.endsWith('.js') || files.allFiles.includes(file)) return null; return /*#__PURE__*/_react.default.createElement("script", { async: !isDevelopment && disableOptimizedLoading, defer: !disableOptimizedLoading, key: file, src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, nonce: props.nonce, crossOrigin: props.crossOrigin || undefined }); }); } function getScripts(context, props, files) { var _buildManifest$lowPri; const { assetPrefix, buildManifest, isDevelopment, devOnlyCacheBusterQueryString, disableOptimizedLoading } = context; const normalScripts = files.allFiles.filter(file => file.endsWith('.js')); const lowPriorityScripts = (_buildManifest$lowPri = buildManifest.lowPriorityFiles) == null ? void 0 : _buildManifest$lowPri.filter(file => file.endsWith('.js')); return [...normalScripts, ...lowPriorityScripts].map(file => { return /*#__PURE__*/_react.default.createElement("script", { key: file, src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, nonce: props.nonce, async: !isDevelopment && disableOptimizedLoading, defer: !disableOptimizedLoading, crossOrigin: props.crossOrigin || undefined }); }); } /** * `Document` component handles the initial `document` markup and renders only on the server side. * Commonly used for implementing server side rendering for `css-in-js` libraries. */ class Document extends _react.Component { /** * `getInitialProps` hook returns the context object with the addition of `renderPage`. * `renderPage` callback executes `React` rendering logic synchronously to support server-rendering wrappers */ static async getInitialProps(ctx) { const enhanceApp = App => { return props => /*#__PURE__*/_react.default.createElement(App, props); }; const { html, head } = await ctx.renderPage({ enhanceApp }); const styles = [...(0, _server.default)()]; return { html, head, styles }; } static renderDocument(DocumentComponent, props) { return /*#__PURE__*/_react.default.createElement(_documentContext.DocumentContext.Provider, { value: props }, /*#__PURE__*/_react.default.createElement(DocumentComponent, props)); } render() { return /*#__PURE__*/_react.default.createElement(Html, null, /*#__PURE__*/_react.default.createElement(Head, null), /*#__PURE__*/_react.default.createElement("body", null, /*#__PURE__*/_react.default.createElement(Main, null), /*#__PURE__*/_react.default.createElement(NextScript, null))); } } exports.default = Document; function Html(props) { const { inAmpMode, docComponentsRendered, locale } = (0, _react.useContext)(_documentContext.DocumentContext); docComponentsRendered.Html = true; return /*#__PURE__*/_react.default.createElement("html", Object.assign({}, props, { lang: props.lang || locale || undefined, amp: inAmpMode ? '' : undefined, "data-ampdevmode": inAmpMode && true ? '' : undefined })); } class Head extends _react.Component { constructor(...args) { super(...args); this.context = void 0; } getCssLinks(files) { const { assetPrefix, devOnlyCacheBusterQueryString, dynamicImports } = this.context; const cssFiles = files.allFiles.filter(f => f.endsWith('.css')); const sharedFiles = new Set(files.sharedFiles); // Unmanaged files are CSS files that will be handled directly by the // webpack runtime (`mini-css-extract-plugin`). let unmangedFiles = new Set([]); let dynamicCssFiles = Array.from(new Set(dynamicImports.filter(file => file.endsWith('.css')))); if (dynamicCssFiles.length) { const existing = new Set(cssFiles); dynamicCssFiles = dynamicCssFiles.filter(f => !(existing.has(f) || sharedFiles.has(f))); unmangedFiles = new Set(dynamicCssFiles); cssFiles.push(...dynamicCssFiles); } let cssLinkElements = []; cssFiles.forEach(file => { const isSharedFile = sharedFiles.has(file); if (true) { cssLinkElements.push( /*#__PURE__*/_react.default.createElement("link", { key: `${file}-preload`, nonce: this.props.nonce, rel: "preload", href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, as: "style", crossOrigin: this.props.crossOrigin || undefined })); } const isUnmanagedFile = unmangedFiles.has(file); cssLinkElements.push( /*#__PURE__*/_react.default.createElement("link", { key: file, nonce: this.props.nonce, rel: "stylesheet", href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, crossOrigin: this.props.crossOrigin || undefined, "data-n-g": isUnmanagedFile ? undefined : isSharedFile ? '' : undefined, "data-n-p": isUnmanagedFile ? undefined : isSharedFile ? undefined : '' })); }); if (false) {} return cssLinkElements.length === 0 ? null : cssLinkElements; } getPreloadDynamicChunks() { const { dynamicImports, assetPrefix, devOnlyCacheBusterQueryString } = this.context; return dynamicImports.map(file => { if (!file.endsWith('.js')) { return null; } return /*#__PURE__*/_react.default.createElement("link", { rel: "preload", key: file, href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, as: "script", nonce: this.props.nonce, crossOrigin: this.props.crossOrigin || undefined }); }) // Filter out nulled scripts .filter(Boolean); } getPreloadMainLinks(files) { const { assetPrefix, devOnlyCacheBusterQueryString, scriptLoader } = this.context; const preloadFiles = files.allFiles.filter(file => { return file.endsWith('.js'); }); return [...(scriptLoader.beforeInteractive || []).map(file => /*#__PURE__*/_react.default.createElement("link", { key: file.src, nonce: this.props.nonce, rel: "preload", href: file.src, as: "script", crossOrigin: this.props.crossOrigin || undefined })), ...preloadFiles.map(file => /*#__PURE__*/_react.default.createElement("link", { key: file, nonce: this.props.nonce, rel: "preload", href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, as: "script", crossOrigin: this.props.crossOrigin || undefined }))]; } getDynamicChunks(files) { return getDynamicChunks(this.context, this.props, files); } getPreNextScripts() { return getPreNextScripts(this.context, this.props); } getScripts(files) { return getScripts(this.context, this.props, files); } getPolyfillScripts() { return getPolyfillScripts(this.context, this.props); } handleDocumentScriptLoaderItems(children) { const { scriptLoader } = this.context; const scriptLoaderItems = []; const filteredChildren = []; _react.default.Children.forEach(children, child => { if (child.type === _experimentalScript.default) { if (child.props.strategy === 'beforeInteractive') { scriptLoader.beforeInteractive = (scriptLoader.beforeInteractive || []).concat([_objectSpread({}, child.props)]); return; } else if (['lazyOnload', 'afterInteractive'].includes(child.props.strategy)) { scriptLoaderItems.push(child.props); return; } } filteredChildren.push(child); }); this.context.__NEXT_DATA__.scriptLoader = scriptLoaderItems; return filteredChildren; } makeStylesheetInert(node) { return _react.default.Children.map(node, c => { if (c.type === 'link' && c.props['href'] && _constants.OPTIMIZED_FONT_PROVIDERS.some(url => c.props['href'].startsWith(url))) { const newProps = _objectSpread({}, c.props || {}); newProps['data-href'] = newProps['href']; newProps['href'] = undefined; return /*#__PURE__*/_react.default.cloneElement(c, newProps); } else if (c.props && c.props['children']) { c.props['children'] = this.makeStylesheetInert(c.props['children']); } return c; }); } render() { var _this$props$nonce, _this$props$nonce2; const { styles, ampPath, inAmpMode, hybridAmp, canonicalBase, __NEXT_DATA__, dangerousAsPath, headTags, unstable_runtimeJS, unstable_JsPreload, disableOptimizedLoading } = this.context; const disableRuntimeJS = unstable_runtimeJS === false; const disableJsPreload = unstable_JsPreload === false || !disableOptimizedLoading; this.context.docComponentsRendered.Head = true; let { head } = this.context; let cssPreloads = []; let otherHeadElements = []; if (head) { head.forEach(c => { if (c && c.type === 'link' && c.props['rel'] === 'preload' && c.props['as'] === 'style') { cssPreloads.push(c); } else { c && otherHeadElements.push(c); } }); head = cssPreloads.concat(otherHeadElements); } let children = _react.default.Children.toArray(this.props.children).filter(Boolean); // show a warning if Head contains (only in development) if (true) { children = _react.default.Children.map(children, child => { var _child$props; const isReactHelmet = child == null ? void 0 : (_child$props = child.props) == null ? void 0 : _child$props['data-react-helmet']; if (!isReactHelmet) { var _child$props2; if ((child == null ? void 0 : child.type) === 'title') { console.warn("Warning: <title> should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-title"); } else if ((child == null ? void 0 : child.type) === 'meta' && (child == null ? void 0 : (_child$props2 = child.props) == null ? void 0 : _child$props2.name) === 'viewport') { console.warn("Warning: viewport meta tags should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-viewport-meta"); } } return child; }); if (this.props.crossOrigin) console.warn('Warning: `Head` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated'); } if (false) {} if (false) {} let hasAmphtmlRel = false; let hasCanonicalRel = false; // show warning and remove conflicting amp head tags head = _react.default.Children.map(head || [], child => { if (!child) return child; const { type, props } = child; if (inAmpMode) { let badProp = ''; if (type === 'meta' && props.name === 'viewport') { badProp = 'name="viewport"'; } else if (type === 'link' && props.rel === 'canonical') { hasCanonicalRel = true; } else if (type === 'script') { // only block if // 1. it has a src and isn't pointing to ampproject's CDN // 2. it is using dangerouslySetInnerHTML without a type or // a type of text/javascript if (props.src && props.src.indexOf('ampproject') < -1 || props.dangerouslySetInnerHTML && (!props.type || props.type === 'text/javascript')) { badProp = '<script'; Object.keys(props).forEach(prop => { badProp += ` ${prop}="${props[prop]}"`; }); badProp += '/>'; } } if (badProp) { console.warn(`Found conflicting amp tag "${child.type}" with conflicting prop ${badProp} in ${__NEXT_DATA__.page}. https://nextjs.org/docs/messages/conflicting-amp-tag`); return null; } } else { // non-amp mode if (type === 'link' && props.rel === 'amphtml') { hasAmphtmlRel = true; } } return child; }); // try to parse styles from fragment for backwards compat const curStyles = Array.isArray(styles) ? styles : []; if (inAmpMode && styles && // @ts-ignore Property 'props' does not exist on type ReactElement styles.props && // @ts-ignore Property 'props' does not exist on type ReactElement Array.isArray(styles.props.children)) { const hasStyles = el => { var _el$props, _el$props$dangerously; return el == null ? void 0 : (_el$props = el.props) == null ? void 0 : (_el$props$dangerously = _el$props.dangerouslySetInnerHTML) == null ? void 0 : _el$props$dangerously.__html; }; // @ts-ignore Property 'props' does not exist on type ReactElement styles.props.children.forEach(child => { if (Array.isArray(child)) { child.forEach(el => hasStyles(el) && curStyles.push(el)); } else if (hasStyles(child)) { curStyles.push(child); } }); } const files = getDocumentFiles(this.context.buildManifest, this.context.__NEXT_DATA__.page, inAmpMode); return /*#__PURE__*/_react.default.createElement("head", this.props, this.context.isDevelopment && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("style", { "data-next-hide-fouc": true, "data-ampdevmode": inAmpMode ? 'true' : undefined, dangerouslySetInnerHTML: { __html: `body{display:none}` } }), /*#__PURE__*/_react.default.createElement("noscript", { "data-next-hide-fouc": true, "data-ampdevmode": inAmpMode ? 'true' : undefined }, /*#__PURE__*/_react.default.createElement("style", { dangerouslySetInnerHTML: { __html: `body{display:block}` } }))), children, head, /*#__PURE__*/_react.default.createElement("meta", { name: "next-head-count", content: _react.default.Children.count(head || []).toString() }), inAmpMode && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("meta", { name: "viewport", content: "width=device-width,minimum-scale=1,initial-scale=1" }), !hasCanonicalRel && /*#__PURE__*/_react.default.createElement("link", { rel: "canonical", href: canonicalBase + (0, _utils2.cleanAmpPath)(dangerousAsPath) }), /*#__PURE__*/_react.default.createElement("link", { rel: "preload", as: "script", href: "https://cdn.ampproject.org/v0.js" }), styles && /*#__PURE__*/_react.default.createElement("style", { "amp-custom": "", dangerouslySetInnerHTML: { __html: curStyles.map(style => style.props.dangerouslySetInnerHTML.__html).join('').replace(/\/\*# sourceMappingURL=.*\*\//g, '').replace(/\/\*@ sourceURL=.*?\*\//g, '') } }), /*#__PURE__*/_react.default.createElement("style", { "amp-boilerplate": "", dangerouslySetInnerHTML: { __html: `body{-webkit-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:-amp-start 8s steps(1,end) 0s 1 normal both;animation:-amp-start 8s steps(1,end) 0s 1 normal both}@-webkit-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}` } }), /*#__PURE__*/_react.default.createElement("noscript", null, /*#__PURE__*/_react.default.createElement("style", { "amp-boilerplate": "", dangerouslySetInnerHTML: { __html: `body{-webkit-animation:none;-moz-animation:none;-ms-animation:none;animation:none}` } })), /*#__PURE__*/_react.default.createElement("script", { async: true, src: "https://cdn.ampproject.org/v0.js" })), !inAmpMode && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !hasAmphtmlRel && hybridAmp && /*#__PURE__*/_react.default.createElement("link", { rel: "amphtml", href: canonicalBase + getAmpPath(ampPath, dangerousAsPath) }), true && this.getCssLinks(files), true && /*#__PURE__*/_react.default.createElement("noscript", { "data-n-css": (_this$props$nonce = this.props.nonce) != null ? _this$props$nonce : '' }), !disableRuntimeJS && !disableJsPreload && this.getPreloadDynamicChunks(), !disableRuntimeJS && !disableJsPreload && this.getPreloadMainLinks(files), !disableOptimizedLoading && !disableRuntimeJS && this.getPolyfillScripts(), !disableOptimizedLoading && !disableRuntimeJS && this.getPreNextScripts(), !disableOptimizedLoading && !disableRuntimeJS && this.getDynamicChunks(files), !disableOptimizedLoading && !disableRuntimeJS && this.getScripts(files), false && 0, false && /*#__PURE__*/0, this.context.isDevelopment && /*#__PURE__*/ // this element is used to mount development styles so the // ordering matches production // (by default, style-loader injects at the bottom of <head />) _react.default.createElement("noscript", { id: "__next_css__DO_NOT_USE__" }), styles || null), /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {}, ...(headTags || []))); } } exports.Head = Head; Head.contextType = _documentContext.DocumentContext; Head.propTypes = { nonce: _propTypes.default.string, crossOrigin: _propTypes.default.string }; function Main() { const { inAmpMode, html, docComponentsRendered } = (0, _react.useContext)(_documentContext.DocumentContext); docComponentsRendered.Main = true; if (inAmpMode) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, _constants.AMP_RENDER_TARGET); return /*#__PURE__*/_react.default.createElement("div", { id: "__next", dangerouslySetInnerHTML: { __html: html } }); } class NextScript extends _react.Component { constructor(...args) { super(...args); this.context = void 0; } getDynamicChunks(files) { return getDynamicChunks(this.context, this.props, files); } getPreNextScripts() { return getPreNextScripts(this.context, this.props); } getScripts(files) { return getScripts(this.context, this.props, files); } getPolyfillScripts() { return getPolyfillScripts(this.context, this.props); } static getInlineScriptSource(documentProps) { const { __NEXT_DATA__ } = documentProps; try { const data = JSON.stringify(__NEXT_DATA__); return (0, _htmlescape.htmlEscapeJsonString)(data); } catch (err) { if (err.message.indexOf('circular structure')) { throw new Error(`Circular structure in "getInitialProps" result of page "${__NEXT_DATA__.page}". https://nextjs.org/docs/messages/circular-structure`); } throw err; } } render() { const { assetPrefix, inAmpMode, buildManifest, unstable_runtimeJS, docComponentsRendered, devOnlyCacheBusterQueryString, disableOptimizedLoading } = this.context; const disableRuntimeJS = unstable_runtimeJS === false; docComponentsRendered.NextScript = true; if (inAmpMode) { if (false) {} const ampDevFiles = [...buildManifest.devFiles, ...buildManifest.polyfillFiles, ...buildManifest.ampDevFiles]; return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, disableRuntimeJS ? null : /*#__PURE__*/_react.default.createElement("script", { id: "__NEXT_DATA__", type: "application/json", nonce: this.props.nonce, crossOrigin: this.props.crossOrigin || undefined, dangerouslySetInnerHTML: { __html: NextScript.getInlineScriptSource(this.context) }, "data-ampdevmode": true }), ampDevFiles.map(file => /*#__PURE__*/_react.default.createElement("script", { key: file, src: `${assetPrefix}/_next/${file}${devOnlyCacheBusterQueryString}`, nonce: this.props.nonce, crossOrigin: this.props.crossOrigin || undefined, "data-ampdevmode": true }))); } if (true) { if (this.props.crossOrigin) console.warn('Warning: `NextScript` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated'); } const files = getDocumentFiles(this.context.buildManifest, this.context.__NEXT_DATA__.page, inAmpMode); return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !disableRuntimeJS && buildManifest.devFiles ? buildManifest.devFiles.map(file => /*#__PURE__*/_react.default.createElement("script", { key: file, src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`, nonce: this.props.nonce, crossOrigin: this.props.crossOrigin || undefined })) : null, disableRuntimeJS ? null : /*#__PURE__*/_react.default.createElement("script", { id: "__NEXT_DATA__", type: "application/json", nonce: this.props.nonce, crossOrigin: this.props.crossOrigin || undefined, dangerouslySetInnerHTML: { __html: NextScript.getInlineScriptSource(this.context) } }), disableOptimizedLoading && !disableRuntimeJS && this.getPolyfillScripts(), disableOptimizedLoading && !disableRuntimeJS && this.getPreNextScripts(), disableOptimizedLoading && !disableRuntimeJS && this.getDynamicChunks(files), disableOptimizedLoading && !disableRuntimeJS && this.getScripts(files)); } } exports.NextScript = NextScript; NextScript.contextType = _documentContext.DocumentContext; NextScript.propTypes = { nonce: _propTypes.default.string, crossOrigin: _propTypes.default.string }; NextScript.safariNomoduleFix = '!function(){var e=document,t=e.createElement("script");if(!("noModule"in t)&&"onbeforeload"in t){var n=!1;e.addEventListener("beforeload",function(e){if(e.target===t)n=!0;else if(!e.target.hasAttribute("nomodule")||!n)return;e.preventDefault()},!0),t.type="module",t.src=".",e.head.appendChild(t),t.remove()}}();'; function getAmpPath(ampPath, asPath) { return ampPath || `${asPath}${asPath.includes('?') ? '&' : '?'}amp=1`; } /***/ }), /***/ "./node_modules/next/dist/server/htmlescape.js": /*!*****************************************************!*\ !*** ./node_modules/next/dist/server/htmlescape.js ***! \*****************************************************/ /***/ (function(__unused_webpack_module, exports) { "use strict"; exports.__esModule=true;exports.htmlEscapeJsonString=htmlEscapeJsonString;// This utility is based on https://github.com/zertosh/htmlescape // License: https://github.com/zertosh/htmlescape/blob/0527ca7156a524d256101bb310a9f970f63078ad/LICENSE const ESCAPE_LOOKUP={'&':'\\u0026','>':'\\u003e','<':'\\u003c','\u2028':'\\u2028','\u2029':'\\u2029'};const ESCAPE_REGEX=/[&><\u2028\u2029]/g;function htmlEscapeJsonString(str){return str.replace(ESCAPE_REGEX,match=>ESCAPE_LOOKUP[match]);} //# sourceMappingURL=htmlescape.js.map /***/ }), /***/ "./node_modules/next/document.js": /*!***************************************!*\ !*** ./node_modules/next/document.js ***! \***************************************/ /***/ (function(module, __unused_webpack_exports, __webpack_require__) { module.exports = __webpack_require__(/*! ./dist/pages/_document */ "./node_modules/next/dist/pages/_document.js") /***/ }), /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/extends.js": /*!**************************************************************************!*\ !*** ./node_modules/next/node_modules/@babel/runtime/helpers/extends.js ***! \**************************************************************************/ /***/ (function(module) { function _extends() { module.exports = _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } module.exports = _extends; /***/ }), /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js": /*!****************************************************************************************!*\ !*** ./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js ***! \****************************************************************************************/ /***/ (function(module) { function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } module.exports = _interopRequireDefault; /***/ }), /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js": /*!***********************************************************************************************!*\ !*** ./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js ***! \***********************************************************************************************/ /***/ (function(module) { function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } module.exports = _objectWithoutPropertiesLoose; /***/ }) }; ; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://startp/../client/experimental-script.tsx","webpack://startp/../client/head-manager.ts","webpack://startp/../client/request-idle-callback.ts","webpack://startp/../pages/_document.tsx","webpack://startp/./node_modules/next/dist/server/htmlescape.js","webpack://startp/./node_modules/next/document.js","webpack://startp/./node_modules/next/node_modules/@babel/runtime/helpers/extends.js","webpack://startp/./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js","webpack://startp/./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js"],"names":["ScriptCache","LoadCache","ignoreProps","loadScript","props","onLoad","children","cacheKey","id","el","document","loadPromise","resolve","reject","onError","dangerouslySetInnerHTML","Array","Object","value","attr","DOMAttributeNames","k","strategy","window","scriptLoaderItems","src","restProps","HeadManagerContext","loadLazyScript","scripts","updateScripts","Script","acceptCharset","className","htmlFor","httpEquiv","noModule","p","type","headEl","headCountEl","console","headCount","Number","oldTags","i","j","newTags","components","newTag","len","oldTag","t","updatePromise","mountedInstances","updateHead","head","promise","tags","h","titleComponent","title","updateElements","requestIdleCallback","self","start","Date","setTimeout","cb","didTimeout","timeRemaining","Math","cancelIdleCallback","clearTimeout","sharedFiles","pageFiles","inAmpMode","allFiles","buildManifest","polyfill","process","assetPrefix","devOnlyCacheBusterQueryString","scriptLoader","file","dynamicImports","files","encodeURI","normalScripts","lowPriorityScripts","Component","enhanceApp","App","ctx","styles","render","DocumentComponentContext","docComponentsRendered","getCssLinks","cssFiles","f","unmangedFiles","dynamicCssFiles","existing","cssLinkElements","isSharedFile","isUnmanagedFile","getPreloadDynamicChunks","getPreloadMainLinks","preloadFiles","getDynamicChunks","getPreNextScripts","getScripts","getPolyfillScripts","handleDocumentScriptLoaderItems","filteredChildren","React","child","makeStylesheetInert","c","OPTIMIZED_FONT_PROVIDERS","url","newProps","disableRuntimeJS","unstable_runtimeJS","disableJsPreload","unstable_JsPreload","cssPreloads","otherHeadElements","isReactHelmet","hasAmphtmlRel","hasCanonicalRel","badProp","prop","__NEXT_DATA__","page","curStyles","hasStyles","getDocumentFiles","__html","canonicalBase","style","getAmpPath","headTags","Head","contextType","propTypes","nonce","PropTypes","crossOrigin","AMP_RENDER_TARGET","data","JSON","err","ampDevFiles","NextScript","disableOptimizedLoading","safariNomoduleFix","ampPath","asPath"],"mappings":"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","file":"vendors-node_modules_next_document_js.js","sourcesContent":["import React, { useEffect, useContext } from 'react'\nimport { ScriptHTMLAttributes } from 'react'\nimport { HeadManagerContext } from '../next-server/lib/head-manager-context'\nimport { DOMAttributeNames } from './head-manager'\nimport { requestIdleCallback } from './request-idle-callback'\n\nconst ScriptCache = new Map()\nconst LoadCache = new Set()\n\nexport interface Props extends ScriptHTMLAttributes<HTMLScriptElement> {\n  strategy?: 'afterInteractive' | 'lazyOnload' | 'beforeInteractive'\n  id?: string\n  onLoad?: () => void\n  onError?: () => void\n  children?: React.ReactNode\n}\n\nconst ignoreProps = [\n  'onLoad',\n  'dangerouslySetInnerHTML',\n  'children',\n  'onError',\n  'strategy',\n]\n\nconst loadScript = (props: Props): void => {\n  const {\n    src,\n    id,\n    onLoad = () => {},\n    dangerouslySetInnerHTML,\n    children = '',\n    onError,\n  } = props\n\n  const cacheKey = id || src\n  if (ScriptCache.has(src)) {\n    if (!LoadCache.has(cacheKey)) {\n      LoadCache.add(cacheKey)\n      // Execute onLoad since the script loading has begun\n      ScriptCache.get(src).then(onLoad, onError)\n    }\n    return\n  }\n\n  const el = document.createElement('script')\n\n  const loadPromise = new Promise((resolve, reject) => {\n    el.addEventListener('load', function () {\n      resolve()\n      if (onLoad) {\n        onLoad.call(this)\n      }\n    })\n    el.addEventListener('error', function () {\n      reject()\n      if (onError) {\n        onError()\n      }\n    })\n  })\n\n  if (src) {\n    ScriptCache.set(src, loadPromise)\n    LoadCache.add(cacheKey)\n  }\n\n  if (dangerouslySetInnerHTML) {\n    el.innerHTML = dangerouslySetInnerHTML.__html || ''\n  } else if (children) {\n    el.textContent =\n      typeof children === 'string'\n        ? children\n        : Array.isArray(children)\n        ? children.join('')\n        : ''\n  } else if (src) {\n    el.src = src\n  }\n\n  for (const [k, value] of Object.entries(props)) {\n    if (value === undefined || ignoreProps.includes(k)) {\n      continue\n    }\n\n    const attr = DOMAttributeNames[k] || k.toLowerCase()\n    el.setAttribute(attr, value)\n  }\n\n  document.body.appendChild(el)\n}\n\nfunction handleClientScriptLoad(props: Props) {\n  const { strategy = 'afterInteractive' } = props\n  if (strategy === 'afterInteractive') {\n    loadScript(props)\n  } else if (strategy === 'lazyOnload') {\n    window.addEventListener('load', () => {\n      requestIdleCallback(() => loadScript(props))\n    })\n  }\n}\n\nfunction loadLazyScript(props: Props) {\n  if (document.readyState === 'complete') {\n    requestIdleCallback(() => loadScript(props))\n  } else {\n    window.addEventListener('load', () => {\n      requestIdleCallback(() => loadScript(props))\n    })\n  }\n}\n\nexport function initScriptLoader(scriptLoaderItems: Props[]) {\n  scriptLoaderItems.forEach(handleClientScriptLoad)\n}\n\nfunction Script(props: Props): JSX.Element | null {\n  const {\n    src = '',\n    onLoad = () => {},\n    dangerouslySetInnerHTML,\n    strategy = 'afterInteractive',\n    onError,\n    ...restProps\n  } = props\n\n  // Context is available only during SSR\n  const { updateScripts, scripts } = useContext(HeadManagerContext)\n\n  useEffect(() => {\n    if (strategy === 'afterInteractive') {\n      loadScript(props)\n    } else if (strategy === 'lazyOnload') {\n      loadLazyScript(props)\n    }\n  }, [props, strategy])\n\n  if (!process.env.__NEXT_SCRIPT_LOADER) {\n    return null\n  }\n\n  if (strategy === 'beforeInteractive') {\n    if (updateScripts) {\n      scripts.beforeInteractive = (scripts.beforeInteractive || []).concat([\n        {\n          src,\n          onLoad,\n          onError,\n          ...restProps,\n        },\n      ])\n      updateScripts(scripts)\n    }\n  }\n\n  return null\n}\n\nexport default Script\n","export const DOMAttributeNames: Record<string, string> = {\n  acceptCharset: 'accept-charset',\n  className: 'class',\n  htmlFor: 'for',\n  httpEquiv: 'http-equiv',\n  noModule: 'noModule',\n}\n\nfunction reactElementToDOM({ type, props }: JSX.Element): HTMLElement {\n  const el: HTMLElement = document.createElement(type)\n  for (const p in props) {\n    if (!props.hasOwnProperty(p)) continue\n    if (p === 'children' || p === 'dangerouslySetInnerHTML') continue\n\n    // we don't render undefined props to the DOM\n    if (props[p] === undefined) continue\n\n    const attr = DOMAttributeNames[p] || p.toLowerCase()\n    if (\n      type === 'script' &&\n      (attr === 'async' || attr === 'defer' || attr === 'noModule')\n    ) {\n      ;(el as HTMLScriptElement)[attr] = !!props[p]\n    } else {\n      el.setAttribute(attr, props[p])\n    }\n  }\n\n  const { children, dangerouslySetInnerHTML } = props\n  if (dangerouslySetInnerHTML) {\n    el.innerHTML = dangerouslySetInnerHTML.__html || ''\n  } else if (children) {\n    el.textContent =\n      typeof children === 'string'\n        ? children\n        : Array.isArray(children)\n        ? children.join('')\n        : ''\n  }\n  return el\n}\n\nfunction updateElements(type: string, components: JSX.Element[]): void {\n  const headEl = document.getElementsByTagName('head')[0]\n  const headCountEl: HTMLMetaElement = headEl.querySelector(\n    'meta[name=next-head-count]'\n  ) as HTMLMetaElement\n  if (process.env.NODE_ENV !== 'production') {\n    if (!headCountEl) {\n      console.error(\n        'Warning: next-head-count is missing. https://nextjs.org/docs/messages/next-head-count-missing'\n      )\n      return\n    }\n  }\n\n  const headCount = Number(headCountEl.content)\n  const oldTags: Element[] = []\n\n  for (\n    let i = 0, j = headCountEl.previousElementSibling;\n    i < headCount;\n    i++, j = j!.previousElementSibling\n  ) {\n    if (j!.tagName.toLowerCase() === type) {\n      oldTags.push(j!)\n    }\n  }\n  const newTags = (components.map(reactElementToDOM) as HTMLElement[]).filter(\n    (newTag) => {\n      for (let k = 0, len = oldTags.length; k < len; k++) {\n        const oldTag = oldTags[k]\n        if (oldTag.isEqualNode(newTag)) {\n          oldTags.splice(k, 1)\n          return false\n        }\n      }\n      return true\n    }\n  )\n\n  oldTags.forEach((t) => t.parentNode!.removeChild(t))\n  newTags.forEach((t) => headEl.insertBefore(t, headCountEl))\n  headCountEl.content = (headCount - oldTags.length + newTags.length).toString()\n}\n\nexport default function initHeadManager(): {\n  mountedInstances: Set<unknown>\n  updateHead: (head: JSX.Element[]) => void\n} {\n  let updatePromise: Promise<void> | null = null\n\n  return {\n    mountedInstances: new Set(),\n    updateHead: (head: JSX.Element[]) => {\n      const promise = (updatePromise = Promise.resolve().then(() => {\n        if (promise !== updatePromise) return\n\n        updatePromise = null\n        const tags: Record<string, JSX.Element[]> = {}\n\n        head.forEach((h) => {\n          if (\n            // If the font tag is loaded only on client navigation\n            // it won't be inlined. In this case revert to the original behavior\n            h.type === 'link' &&\n            h.props['data-optimized-fonts'] &&\n            !document.querySelector(\n              `style[data-href=\"${h.props['data-href']}\"]`\n            )\n          ) {\n            h.props.href = h.props['data-href']\n            h.props['data-href'] = undefined\n          }\n          const components = tags[h.type] || []\n          components.push(h)\n          tags[h.type] = components\n        })\n\n        const titleComponent = tags.title ? tags.title[0] : null\n        let title = ''\n        if (titleComponent) {\n          const { children } = titleComponent.props\n          title =\n            typeof children === 'string'\n              ? children\n              : Array.isArray(children)\n              ? children.join('')\n              : ''\n        }\n        if (title !== document.title) document.title = title\n        ;['meta', 'base', 'link', 'style', 'script'].forEach((type) => {\n          updateElements(type, tags[type] || [])\n        })\n      }))\n    },\n  }\n}\n","type RequestIdleCallbackHandle = any\ntype RequestIdleCallbackOptions = {\n  timeout: number\n}\ntype RequestIdleCallbackDeadline = {\n  readonly didTimeout: boolean\n  timeRemaining: () => number\n}\n\ndeclare global {\n  interface Window {\n    requestIdleCallback: (\n      callback: (deadline: RequestIdleCallbackDeadline) => void,\n      opts?: RequestIdleCallbackOptions\n    ) => RequestIdleCallbackHandle\n    cancelIdleCallback: (id: RequestIdleCallbackHandle) => void\n  }\n}\n\nexport const requestIdleCallback =\n  (typeof self !== 'undefined' && self.requestIdleCallback) ||\n  function (\n    cb: (deadline: RequestIdleCallbackDeadline) => void\n  ): NodeJS.Timeout {\n    let start = Date.now()\n    return setTimeout(function () {\n      cb({\n        didTimeout: false,\n        timeRemaining: function () {\n          return Math.max(0, 50 - (Date.now() - start))\n        },\n      })\n    }, 1)\n  }\n\nexport const cancelIdleCallback =\n  (typeof self !== 'undefined' && self.cancelIdleCallback) ||\n  function (id: RequestIdleCallbackHandle) {\n    return clearTimeout(id)\n  }\n","import PropTypes from 'prop-types'\nimport React, { Component, ReactElement, ReactNode, useContext } from 'react'\nimport flush from 'styled-jsx/server'\nimport {\n  AMP_RENDER_TARGET,\n  OPTIMIZED_FONT_PROVIDERS,\n} from '../next-server/lib/constants'\nimport { DocumentContext as DocumentComponentContext } from '../next-server/lib/document-context'\nimport {\n  DocumentContext,\n  DocumentInitialProps,\n  DocumentProps,\n} from '../next-server/lib/utils'\nimport {\n  BuildManifest,\n  getPageFiles,\n} from '../next-server/server/get-page-files'\nimport { cleanAmpPath } from '../next-server/server/utils'\nimport { htmlEscapeJsonString } from '../server/htmlescape'\nimport Script, {\n  Props as ScriptLoaderProps,\n} from '../client/experimental-script'\n\nexport { DocumentContext, DocumentInitialProps, DocumentProps }\n\nexport type OriginProps = {\n  nonce?: string\n  crossOrigin?: string\n}\n\ntype DocumentFiles = {\n  sharedFiles: readonly string[]\n  pageFiles: readonly string[]\n  allFiles: readonly string[]\n}\n\nfunction getDocumentFiles(\n  buildManifest: BuildManifest,\n  pathname: string,\n  inAmpMode: boolean\n): DocumentFiles {\n  const sharedFiles: readonly string[] = getPageFiles(buildManifest, '/_app')\n  const pageFiles: readonly string[] = inAmpMode\n    ? []\n    : getPageFiles(buildManifest, pathname)\n\n  return {\n    sharedFiles,\n    pageFiles,\n    allFiles: [...new Set([...sharedFiles, ...pageFiles])],\n  }\n}\n\nfunction getPolyfillScripts(context: DocumentProps, props: OriginProps) {\n  // polyfills.js has to be rendered as nomodule without async\n  // It also has to be the first script to load\n  const {\n    assetPrefix,\n    buildManifest,\n    devOnlyCacheBusterQueryString,\n    disableOptimizedLoading,\n  } = context\n\n  return buildManifest.polyfillFiles\n    .filter(\n      (polyfill) => polyfill.endsWith('.js') && !polyfill.endsWith('.module.js')\n    )\n    .map((polyfill) => (\n      <script\n        key={polyfill}\n        defer={!disableOptimizedLoading}\n        nonce={props.nonce}\n        crossOrigin={props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN}\n        noModule={true}\n        src={`${assetPrefix}/_next/${polyfill}${devOnlyCacheBusterQueryString}`}\n      />\n    ))\n}\n\nfunction getPreNextScripts(context: DocumentProps, props: OriginProps) {\n  const { scriptLoader, disableOptimizedLoading } = context\n\n  return (scriptLoader.beforeInteractive || []).map(\n    (file: ScriptLoaderProps) => {\n      const { strategy, ...scriptProps } = file\n      return (\n        <script\n          {...scriptProps}\n          defer={!disableOptimizedLoading}\n          nonce={props.nonce}\n          crossOrigin={props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN}\n        />\n      )\n    }\n  )\n}\n\nfunction getDynamicChunks(\n  context: DocumentProps,\n  props: OriginProps,\n  files: DocumentFiles\n) {\n  const {\n    dynamicImports,\n    assetPrefix,\n    isDevelopment,\n    devOnlyCacheBusterQueryString,\n    disableOptimizedLoading,\n  } = context\n\n  return dynamicImports.map((file) => {\n    if (!file.endsWith('.js') || files.allFiles.includes(file)) return null\n\n    return (\n      <script\n        async={!isDevelopment && disableOptimizedLoading}\n        defer={!disableOptimizedLoading}\n        key={file}\n        src={`${assetPrefix}/_next/${encodeURI(\n          file\n        )}${devOnlyCacheBusterQueryString}`}\n        nonce={props.nonce}\n        crossOrigin={props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN}\n      />\n    )\n  })\n}\n\nfunction getScripts(\n  context: DocumentProps,\n  props: OriginProps,\n  files: DocumentFiles\n) {\n  const {\n    assetPrefix,\n    buildManifest,\n    isDevelopment,\n    devOnlyCacheBusterQueryString,\n    disableOptimizedLoading,\n  } = context\n\n  const normalScripts = files.allFiles.filter((file) => file.endsWith('.js'))\n  const lowPriorityScripts = buildManifest.lowPriorityFiles?.filter((file) =>\n    file.endsWith('.js')\n  )\n\n  return [...normalScripts, ...lowPriorityScripts].map((file) => {\n    return (\n      <script\n        key={file}\n        src={`${assetPrefix}/_next/${encodeURI(\n          file\n        )}${devOnlyCacheBusterQueryString}`}\n        nonce={props.nonce}\n        async={!isDevelopment && disableOptimizedLoading}\n        defer={!disableOptimizedLoading}\n        crossOrigin={props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN}\n      />\n    )\n  })\n}\n\n/**\n * `Document` component handles the initial `document` markup and renders only on the server side.\n * Commonly used for implementing server side rendering for `css-in-js` libraries.\n */\nexport default class Document<P = {}> extends Component<DocumentProps & P> {\n  /**\n   * `getInitialProps` hook returns the context object with the addition of `renderPage`.\n   * `renderPage` callback executes `React` rendering logic synchronously to support server-rendering wrappers\n   */\n  static async getInitialProps(\n    ctx: DocumentContext\n  ): Promise<DocumentInitialProps> {\n    const enhanceApp = (App: any) => {\n      return (props: any) => <App {...props} />\n    }\n\n    const { html, head } = await ctx.renderPage({ enhanceApp })\n    const styles = [...flush()]\n    return { html, head, styles }\n  }\n\n  static renderDocument<Y>(\n    DocumentComponent: new () => Document<Y>,\n    props: DocumentProps & Y\n  ): React.ReactElement {\n    return (\n      <DocumentComponentContext.Provider value={props}>\n        <DocumentComponent {...props} />\n      </DocumentComponentContext.Provider>\n    )\n  }\n\n  render() {\n    return (\n      <Html>\n        <Head />\n        <body>\n          <Main />\n          <NextScript />\n        </body>\n      </Html>\n    )\n  }\n}\n\nexport function Html(\n  props: React.DetailedHTMLProps<\n    React.HtmlHTMLAttributes<HTMLHtmlElement>,\n    HTMLHtmlElement\n  >\n) {\n  const { inAmpMode, docComponentsRendered, locale } = useContext(\n    DocumentComponentContext\n  )\n\n  docComponentsRendered.Html = true\n\n  return (\n    <html\n      {...props}\n      lang={props.lang || locale || undefined}\n      amp={inAmpMode ? '' : undefined}\n      data-ampdevmode={\n        inAmpMode && process.env.NODE_ENV !== 'production' ? '' : undefined\n      }\n    />\n  )\n}\n\nexport class Head extends Component<\n  OriginProps &\n    React.DetailedHTMLProps<\n      React.HTMLAttributes<HTMLHeadElement>,\n      HTMLHeadElement\n    >\n> {\n  static contextType = DocumentComponentContext\n\n  static propTypes = {\n    nonce: PropTypes.string,\n    crossOrigin: PropTypes.string,\n  }\n\n  context!: React.ContextType<typeof DocumentComponentContext>\n\n  getCssLinks(files: DocumentFiles): JSX.Element[] | null {\n    const {\n      assetPrefix,\n      devOnlyCacheBusterQueryString,\n      dynamicImports,\n    } = this.context\n    const cssFiles = files.allFiles.filter((f) => f.endsWith('.css'))\n    const sharedFiles: Set<string> = new Set(files.sharedFiles)\n\n    // Unmanaged files are CSS files that will be handled directly by the\n    // webpack runtime (`mini-css-extract-plugin`).\n    let unmangedFiles: Set<string> = new Set([])\n    let dynamicCssFiles = Array.from(\n      new Set(dynamicImports.filter((file) => file.endsWith('.css')))\n    )\n    if (dynamicCssFiles.length) {\n      const existing = new Set(cssFiles)\n      dynamicCssFiles = dynamicCssFiles.filter(\n        (f) => !(existing.has(f) || sharedFiles.has(f))\n      )\n      unmangedFiles = new Set(dynamicCssFiles)\n      cssFiles.push(...dynamicCssFiles)\n    }\n\n    let cssLinkElements: JSX.Element[] = []\n    cssFiles.forEach((file) => {\n      const isSharedFile = sharedFiles.has(file)\n\n      if (!process.env.__NEXT_OPTIMIZE_CSS) {\n        cssLinkElements.push(\n          <link\n            key={`${file}-preload`}\n            nonce={this.props.nonce}\n            rel=\"preload\"\n            href={`${assetPrefix}/_next/${encodeURI(\n              file\n            )}${devOnlyCacheBusterQueryString}`}\n            as=\"style\"\n            crossOrigin={\n              this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n            }\n          />\n        )\n      }\n\n      const isUnmanagedFile = unmangedFiles.has(file)\n      cssLinkElements.push(\n        <link\n          key={file}\n          nonce={this.props.nonce}\n          rel=\"stylesheet\"\n          href={`${assetPrefix}/_next/${encodeURI(\n            file\n          )}${devOnlyCacheBusterQueryString}`}\n          crossOrigin={\n            this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n          }\n          data-n-g={isUnmanagedFile ? undefined : isSharedFile ? '' : undefined}\n          data-n-p={isUnmanagedFile ? undefined : isSharedFile ? undefined : ''}\n        />\n      )\n    })\n\n    if (\n      process.env.NODE_ENV !== 'development' &&\n      process.env.__NEXT_OPTIMIZE_FONTS\n    ) {\n      cssLinkElements = this.makeStylesheetInert(\n        cssLinkElements\n      ) as ReactElement[]\n    }\n\n    return cssLinkElements.length === 0 ? null : cssLinkElements\n  }\n\n  getPreloadDynamicChunks() {\n    const {\n      dynamicImports,\n      assetPrefix,\n      devOnlyCacheBusterQueryString,\n    } = this.context\n\n    return (\n      dynamicImports\n        .map((file) => {\n          if (!file.endsWith('.js')) {\n            return null\n          }\n\n          return (\n            <link\n              rel=\"preload\"\n              key={file}\n              href={`${assetPrefix}/_next/${encodeURI(\n                file\n              )}${devOnlyCacheBusterQueryString}`}\n              as=\"script\"\n              nonce={this.props.nonce}\n              crossOrigin={\n                this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n              }\n            />\n          )\n        })\n        // Filter out nulled scripts\n        .filter(Boolean)\n    )\n  }\n\n  getPreloadMainLinks(files: DocumentFiles): JSX.Element[] | null {\n    const {\n      assetPrefix,\n      devOnlyCacheBusterQueryString,\n      scriptLoader,\n    } = this.context\n    const preloadFiles = files.allFiles.filter((file: string) => {\n      return file.endsWith('.js')\n    })\n\n    return [\n      ...(scriptLoader.beforeInteractive || []).map((file) => (\n        <link\n          key={file.src}\n          nonce={this.props.nonce}\n          rel=\"preload\"\n          href={file.src}\n          as=\"script\"\n          crossOrigin={\n            this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n          }\n        />\n      )),\n      ...preloadFiles.map((file: string) => (\n        <link\n          key={file}\n          nonce={this.props.nonce}\n          rel=\"preload\"\n          href={`${assetPrefix}/_next/${encodeURI(\n            file\n          )}${devOnlyCacheBusterQueryString}`}\n          as=\"script\"\n          crossOrigin={\n            this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n          }\n        />\n      )),\n    ]\n  }\n\n  getDynamicChunks(files: DocumentFiles) {\n    return getDynamicChunks(this.context, this.props, files)\n  }\n\n  getPreNextScripts() {\n    return getPreNextScripts(this.context, this.props)\n  }\n\n  getScripts(files: DocumentFiles) {\n    return getScripts(this.context, this.props, files)\n  }\n\n  getPolyfillScripts() {\n    return getPolyfillScripts(this.context, this.props)\n  }\n\n  handleDocumentScriptLoaderItems(children: React.ReactNode): ReactNode[] {\n    const { scriptLoader } = this.context\n    const scriptLoaderItems: ScriptLoaderProps[] = []\n    const filteredChildren: ReactNode[] = []\n\n    React.Children.forEach(children, (child: any) => {\n      if (child.type === Script) {\n        if (child.props.strategy === 'beforeInteractive') {\n          scriptLoader.beforeInteractive = (\n            scriptLoader.beforeInteractive || []\n          ).concat([\n            {\n              ...child.props,\n            },\n          ])\n          return\n        } else if (\n          ['lazyOnload', 'afterInteractive'].includes(child.props.strategy)\n        ) {\n          scriptLoaderItems.push(child.props)\n          return\n        }\n      }\n\n      filteredChildren.push(child)\n    })\n\n    this.context.__NEXT_DATA__.scriptLoader = scriptLoaderItems\n\n    return filteredChildren\n  }\n\n  makeStylesheetInert(node: ReactNode): ReactNode[] {\n    return React.Children.map(node, (c: any) => {\n      if (\n        c.type === 'link' &&\n        c.props['href'] &&\n        OPTIMIZED_FONT_PROVIDERS.some((url) => c.props['href'].startsWith(url))\n      ) {\n        const newProps = { ...(c.props || {}) }\n        newProps['data-href'] = newProps['href']\n        newProps['href'] = undefined\n        return React.cloneElement(c, newProps)\n      } else if (c.props && c.props['children']) {\n        c.props['children'] = this.makeStylesheetInert(c.props['children'])\n      }\n      return c\n    })\n  }\n\n  render() {\n    const {\n      styles,\n      ampPath,\n      inAmpMode,\n      hybridAmp,\n      canonicalBase,\n      __NEXT_DATA__,\n      dangerousAsPath,\n      headTags,\n      unstable_runtimeJS,\n      unstable_JsPreload,\n      disableOptimizedLoading,\n    } = this.context\n\n    const disableRuntimeJS = unstable_runtimeJS === false\n    const disableJsPreload =\n      unstable_JsPreload === false || !disableOptimizedLoading\n\n    this.context.docComponentsRendered.Head = true\n\n    let { head } = this.context\n    let cssPreloads: Array<JSX.Element> = []\n    let otherHeadElements: Array<JSX.Element> = []\n    if (head) {\n      head.forEach((c) => {\n        if (\n          c &&\n          c.type === 'link' &&\n          c.props['rel'] === 'preload' &&\n          c.props['as'] === 'style'\n        ) {\n          cssPreloads.push(c)\n        } else {\n          c && otherHeadElements.push(c)\n        }\n      })\n      head = cssPreloads.concat(otherHeadElements)\n    }\n    let children = React.Children.toArray(this.props.children).filter(Boolean)\n    // show a warning if Head contains <title> (only in development)\n    if (process.env.NODE_ENV !== 'production') {\n      children = React.Children.map(children, (child: any) => {\n        const isReactHelmet = child?.props?.['data-react-helmet']\n        if (!isReactHelmet) {\n          if (child?.type === 'title') {\n            console.warn(\n              \"Warning: <title> should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-title\"\n            )\n          } else if (\n            child?.type === 'meta' &&\n            child?.props?.name === 'viewport'\n          ) {\n            console.warn(\n              \"Warning: viewport meta tags should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-viewport-meta\"\n            )\n          }\n        }\n        return child\n      })\n      if (this.props.crossOrigin)\n        console.warn(\n          'Warning: `Head` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated'\n        )\n    }\n\n    if (\n      process.env.NODE_ENV !== 'development' &&\n      process.env.__NEXT_OPTIMIZE_FONTS &&\n      !inAmpMode\n    ) {\n      children = this.makeStylesheetInert(children)\n    }\n\n    if (process.env.__NEXT_SCRIPT_LOADER) {\n      children = this.handleDocumentScriptLoaderItems(children)\n    }\n\n    let hasAmphtmlRel = false\n    let hasCanonicalRel = false\n\n    // show warning and remove conflicting amp head tags\n    head = React.Children.map(head || [], (child) => {\n      if (!child) return child\n      const { type, props } = child\n      if (inAmpMode) {\n        let badProp: string = ''\n\n        if (type === 'meta' && props.name === 'viewport') {\n          badProp = 'name=\"viewport\"'\n        } else if (type === 'link' && props.rel === 'canonical') {\n          hasCanonicalRel = true\n        } else if (type === 'script') {\n          // only block if\n          // 1. it has a src and isn't pointing to ampproject's CDN\n          // 2. it is using dangerouslySetInnerHTML without a type or\n          // a type of text/javascript\n          if (\n            (props.src && props.src.indexOf('ampproject') < -1) ||\n            (props.dangerouslySetInnerHTML &&\n              (!props.type || props.type === 'text/javascript'))\n          ) {\n            badProp = '<script'\n            Object.keys(props).forEach((prop) => {\n              badProp += ` ${prop}=\"${props[prop]}\"`\n            })\n            badProp += '/>'\n          }\n        }\n\n        if (badProp) {\n          console.warn(\n            `Found conflicting amp tag \"${child.type}\" with conflicting prop ${badProp} in ${__NEXT_DATA__.page}. https://nextjs.org/docs/messages/conflicting-amp-tag`\n          )\n          return null\n        }\n      } else {\n        // non-amp mode\n        if (type === 'link' && props.rel === 'amphtml') {\n          hasAmphtmlRel = true\n        }\n      }\n      return child\n    })\n\n    // try to parse styles from fragment for backwards compat\n    const curStyles: React.ReactElement[] = Array.isArray(styles)\n      ? (styles as React.ReactElement[])\n      : []\n    if (\n      inAmpMode &&\n      styles &&\n      // @ts-ignore Property 'props' does not exist on type ReactElement\n      styles.props &&\n      // @ts-ignore Property 'props' does not exist on type ReactElement\n      Array.isArray(styles.props.children)\n    ) {\n      const hasStyles = (el: React.ReactElement) =>\n        el?.props?.dangerouslySetInnerHTML?.__html\n      // @ts-ignore Property 'props' does not exist on type ReactElement\n      styles.props.children.forEach((child: React.ReactElement) => {\n        if (Array.isArray(child)) {\n          child.forEach((el) => hasStyles(el) && curStyles.push(el))\n        } else if (hasStyles(child)) {\n          curStyles.push(child)\n        }\n      })\n    }\n\n    const files: DocumentFiles = getDocumentFiles(\n      this.context.buildManifest,\n      this.context.__NEXT_DATA__.page,\n      inAmpMode\n    )\n\n    return (\n      <head {...this.props}>\n        {this.context.isDevelopment && (\n          <>\n            <style\n              data-next-hide-fouc\n              data-ampdevmode={inAmpMode ? 'true' : undefined}\n              dangerouslySetInnerHTML={{\n                __html: `body{display:none}`,\n              }}\n            />\n            <noscript\n              data-next-hide-fouc\n              data-ampdevmode={inAmpMode ? 'true' : undefined}\n            >\n              <style\n                dangerouslySetInnerHTML={{\n                  __html: `body{display:block}`,\n                }}\n              />\n            </noscript>\n          </>\n        )}\n        {children}\n        {head}\n        <meta\n          name=\"next-head-count\"\n          content={React.Children.count(head || []).toString()}\n        />\n        {inAmpMode && (\n          <>\n            <meta\n              name=\"viewport\"\n              content=\"width=device-width,minimum-scale=1,initial-scale=1\"\n            />\n            {!hasCanonicalRel && (\n              <link\n                rel=\"canonical\"\n                href={canonicalBase + cleanAmpPath(dangerousAsPath)}\n              />\n            )}\n            {/* https://www.ampproject.org/docs/fundamentals/optimize_amp#optimize-the-amp-runtime-loading */}\n            <link\n              rel=\"preload\"\n              as=\"script\"\n              href=\"https://cdn.ampproject.org/v0.js\"\n            />\n            {/* Add custom styles before AMP styles to prevent accidental overrides */}\n            {styles && (\n              <style\n                amp-custom=\"\"\n                dangerouslySetInnerHTML={{\n                  __html: curStyles\n                    .map((style) => style.props.dangerouslySetInnerHTML.__html)\n                    .join('')\n                    .replace(/\\/\\*# sourceMappingURL=.*\\*\\//g, '')\n                    .replace(/\\/\\*@ sourceURL=.*?\\*\\//g, ''),\n                }}\n              />\n            )}\n            <style\n              amp-boilerplate=\"\"\n              dangerouslySetInnerHTML={{\n                __html: `body{-webkit-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:-amp-start 8s steps(1,end) 0s 1 normal both;animation:-amp-start 8s steps(1,end) 0s 1 normal both}@-webkit-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}`,\n              }}\n            />\n            <noscript>\n              <style\n                amp-boilerplate=\"\"\n                dangerouslySetInnerHTML={{\n                  __html: `body{-webkit-animation:none;-moz-animation:none;-ms-animation:none;animation:none}`,\n                }}\n              />\n            </noscript>\n            <script async src=\"https://cdn.ampproject.org/v0.js\" />\n          </>\n        )}\n        {!inAmpMode && (\n          <>\n            {!hasAmphtmlRel && hybridAmp && (\n              <link\n                rel=\"amphtml\"\n                href={canonicalBase + getAmpPath(ampPath, dangerousAsPath)}\n              />\n            )}\n            {!process.env.__NEXT_OPTIMIZE_CSS && this.getCssLinks(files)}\n            {!process.env.__NEXT_OPTIMIZE_CSS && (\n              <noscript data-n-css={this.props.nonce ?? ''} />\n            )}\n            {!disableRuntimeJS &&\n              !disableJsPreload &&\n              this.getPreloadDynamicChunks()}\n            {!disableRuntimeJS &&\n              !disableJsPreload &&\n              this.getPreloadMainLinks(files)}\n            {!disableOptimizedLoading &&\n              !disableRuntimeJS &&\n              this.getPolyfillScripts()}\n            {!disableOptimizedLoading &&\n              !disableRuntimeJS &&\n              this.getPreNextScripts()}\n            {!disableOptimizedLoading &&\n              !disableRuntimeJS &&\n              this.getDynamicChunks(files)}\n            {!disableOptimizedLoading &&\n              !disableRuntimeJS &&\n              this.getScripts(files)}\n            {process.env.__NEXT_OPTIMIZE_CSS && this.getCssLinks(files)}\n            {process.env.__NEXT_OPTIMIZE_CSS && (\n              <noscript data-n-css={this.props.nonce ?? ''} />\n            )}\n            {this.context.isDevelopment && (\n              // this element is used to mount development styles so the\n              // ordering matches production\n              // (by default, style-loader injects at the bottom of <head />)\n              <noscript id=\"__next_css__DO_NOT_USE__\" />\n            )}\n            {styles || null}\n          </>\n        )}\n        {React.createElement(React.Fragment, {}, ...(headTags || []))}\n      </head>\n    )\n  }\n}\n\nexport function Main() {\n  const { inAmpMode, html, docComponentsRendered } = useContext(\n    DocumentComponentContext\n  )\n\n  docComponentsRendered.Main = true\n\n  if (inAmpMode) return <>{AMP_RENDER_TARGET}</>\n  return <div id=\"__next\" dangerouslySetInnerHTML={{ __html: html }} />\n}\n\nexport class NextScript extends Component<OriginProps> {\n  static contextType = DocumentComponentContext\n\n  static propTypes = {\n    nonce: PropTypes.string,\n    crossOrigin: PropTypes.string,\n  }\n\n  context!: React.ContextType<typeof DocumentComponentContext>\n\n  // Source: https://gist.github.com/samthor/64b114e4a4f539915a95b91ffd340acc\n  static safariNomoduleFix =\n    '!function(){var e=document,t=e.createElement(\"script\");if(!(\"noModule\"in t)&&\"onbeforeload\"in t){var n=!1;e.addEventListener(\"beforeload\",function(e){if(e.target===t)n=!0;else if(!e.target.hasAttribute(\"nomodule\")||!n)return;e.preventDefault()},!0),t.type=\"module\",t.src=\".\",e.head.appendChild(t),t.remove()}}();'\n\n  getDynamicChunks(files: DocumentFiles) {\n    return getDynamicChunks(this.context, this.props, files)\n  }\n\n  getPreNextScripts() {\n    return getPreNextScripts(this.context, this.props)\n  }\n\n  getScripts(files: DocumentFiles) {\n    return getScripts(this.context, this.props, files)\n  }\n\n  getPolyfillScripts() {\n    return getPolyfillScripts(this.context, this.props)\n  }\n\n  static getInlineScriptSource(documentProps: Readonly<DocumentProps>): string {\n    const { __NEXT_DATA__ } = documentProps\n    try {\n      const data = JSON.stringify(__NEXT_DATA__)\n      return htmlEscapeJsonString(data)\n    } catch (err) {\n      if (err.message.indexOf('circular structure')) {\n        throw new Error(\n          `Circular structure in \"getInitialProps\" result of page \"${__NEXT_DATA__.page}\". https://nextjs.org/docs/messages/circular-structure`\n        )\n      }\n      throw err\n    }\n  }\n\n  render() {\n    const {\n      assetPrefix,\n      inAmpMode,\n      buildManifest,\n      unstable_runtimeJS,\n      docComponentsRendered,\n      devOnlyCacheBusterQueryString,\n      disableOptimizedLoading,\n    } = this.context\n    const disableRuntimeJS = unstable_runtimeJS === false\n\n    docComponentsRendered.NextScript = true\n\n    if (inAmpMode) {\n      if (process.env.NODE_ENV === 'production') {\n        return null\n      }\n\n      const ampDevFiles = [\n        ...buildManifest.devFiles,\n        ...buildManifest.polyfillFiles,\n        ...buildManifest.ampDevFiles,\n      ]\n\n      return (\n        <>\n          {disableRuntimeJS ? null : (\n            <script\n              id=\"__NEXT_DATA__\"\n              type=\"application/json\"\n              nonce={this.props.nonce}\n              crossOrigin={\n                this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n              }\n              dangerouslySetInnerHTML={{\n                __html: NextScript.getInlineScriptSource(this.context),\n              }}\n              data-ampdevmode\n            />\n          )}\n          {ampDevFiles.map((file) => (\n            <script\n              key={file}\n              src={`${assetPrefix}/_next/${file}${devOnlyCacheBusterQueryString}`}\n              nonce={this.props.nonce}\n              crossOrigin={\n                this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n              }\n              data-ampdevmode\n            />\n          ))}\n        </>\n      )\n    }\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (this.props.crossOrigin)\n        console.warn(\n          'Warning: `NextScript` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated'\n        )\n    }\n\n    const files: DocumentFiles = getDocumentFiles(\n      this.context.buildManifest,\n      this.context.__NEXT_DATA__.page,\n      inAmpMode\n    )\n\n    return (\n      <>\n        {!disableRuntimeJS && buildManifest.devFiles\n          ? buildManifest.devFiles.map((file: string) => (\n              <script\n                key={file}\n                src={`${assetPrefix}/_next/${encodeURI(\n                  file\n                )}${devOnlyCacheBusterQueryString}`}\n                nonce={this.props.nonce}\n                crossOrigin={\n                  this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n                }\n              />\n            ))\n          : null}\n        {disableRuntimeJS ? null : (\n          <script\n            id=\"__NEXT_DATA__\"\n            type=\"application/json\"\n            nonce={this.props.nonce}\n            crossOrigin={\n              this.props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN\n            }\n            dangerouslySetInnerHTML={{\n              __html: NextScript.getInlineScriptSource(this.context),\n            }}\n          />\n        )}\n        {disableOptimizedLoading &&\n          !disableRuntimeJS &&\n          this.getPolyfillScripts()}\n        {disableOptimizedLoading &&\n          !disableRuntimeJS &&\n          this.getPreNextScripts()}\n        {disableOptimizedLoading &&\n          !disableRuntimeJS &&\n          this.getDynamicChunks(files)}\n        {disableOptimizedLoading && !disableRuntimeJS && this.getScripts(files)}\n      </>\n    )\n  }\n}\n\nfunction getAmpPath(ampPath: string, asPath: string): string {\n  return ampPath || `${asPath}${asPath.includes('?') ? '&' : '?'}amp=1`\n}\n","\"use strict\";exports.__esModule=true;exports.htmlEscapeJsonString=htmlEscapeJsonString;// This utility is based on https://github.com/zertosh/htmlescape\n// License: https://github.com/zertosh/htmlescape/blob/0527ca7156a524d256101bb310a9f970f63078ad/LICENSE\nconst ESCAPE_LOOKUP={'&':'\\\\u0026','>':'\\\\u003e','<':'\\\\u003c','\\u2028':'\\\\u2028','\\u2029':'\\\\u2029'};const ESCAPE_REGEX=/[&><\\u2028\\u2029]/g;function htmlEscapeJsonString(str){return str.replace(ESCAPE_REGEX,match=>ESCAPE_LOOKUP[match]);}\n//# sourceMappingURL=htmlescape.js.map","module.exports = require('./dist/pages/_document')\n","function _extends() {\n  module.exports = _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends;","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n}\n\nmodule.exports = _interopRequireDefault;","function _objectWithoutPropertiesLoose(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose;"],"sourceRoot":""}