Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

1183 строки
122 KiB

  1. exports.id = "vendors-node_modules_next_document_js";
  2. exports.ids = ["vendors-node_modules_next_document_js"];
  3. exports.modules = {
  4. /***/ "./node_modules/next/dist/client/experimental-script.js":
  5. /*!**************************************************************!*\
  6. !*** ./node_modules/next/dist/client/experimental-script.js ***!
  7. \**************************************************************/
  8. /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
  9. "use strict";
  10. var _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ "./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js");
  11. exports.__esModule = true;
  12. exports.initScriptLoader = initScriptLoader;
  13. exports.default = void 0;
  14. var _extends2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/extends */ "./node_modules/next/node_modules/@babel/runtime/helpers/extends.js"));
  15. var _objectWithoutPropertiesLoose2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/objectWithoutPropertiesLoose */ "./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js"));
  16. var _react = __webpack_require__(/*! react */ "react");
  17. var _headManagerContext = __webpack_require__(/*! ../next-server/lib/head-manager-context */ "../next-server/lib/head-manager-context");
  18. var _headManager = __webpack_require__(/*! ./head-manager */ "./node_modules/next/dist/client/head-manager.js");
  19. var _requestIdleCallback = __webpack_require__(/*! ./request-idle-callback */ "./node_modules/next/dist/client/request-idle-callback.js");
  20. const ScriptCache = new Map();
  21. const LoadCache = new Set();
  22. const ignoreProps = ['onLoad', 'dangerouslySetInnerHTML', 'children', 'onError', 'strategy'];
  23. const loadScript = props => {
  24. const {
  25. src,
  26. id,
  27. onLoad = () => {},
  28. dangerouslySetInnerHTML,
  29. children = '',
  30. onError
  31. } = props;
  32. const cacheKey = id || src;
  33. if (ScriptCache.has(src)) {
  34. if (!LoadCache.has(cacheKey)) {
  35. LoadCache.add(cacheKey); // Execute onLoad since the script loading has begun
  36. ScriptCache.get(src).then(onLoad, onError);
  37. }
  38. return;
  39. }
  40. const el = document.createElement('script');
  41. const loadPromise = new Promise((resolve, reject) => {
  42. el.addEventListener('load', function () {
  43. resolve();
  44. if (onLoad) {
  45. onLoad.call(this);
  46. }
  47. });
  48. el.addEventListener('error', function () {
  49. reject();
  50. if (onError) {
  51. onError();
  52. }
  53. });
  54. });
  55. if (src) {
  56. ScriptCache.set(src, loadPromise);
  57. LoadCache.add(cacheKey);
  58. }
  59. if (dangerouslySetInnerHTML) {
  60. el.innerHTML = dangerouslySetInnerHTML.__html || '';
  61. } else if (children) {
  62. el.textContent = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : '';
  63. } else if (src) {
  64. el.src = src;
  65. }
  66. for (const [k, value] of Object.entries(props)) {
  67. if (value === undefined || ignoreProps.includes(k)) {
  68. continue;
  69. }
  70. const attr = _headManager.DOMAttributeNames[k] || k.toLowerCase();
  71. el.setAttribute(attr, value);
  72. }
  73. document.body.appendChild(el);
  74. };
  75. function handleClientScriptLoad(props) {
  76. const {
  77. strategy = 'afterInteractive'
  78. } = props;
  79. if (strategy === 'afterInteractive') {
  80. loadScript(props);
  81. } else if (strategy === 'lazyOnload') {
  82. window.addEventListener('load', () => {
  83. (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props));
  84. });
  85. }
  86. }
  87. function loadLazyScript(props) {
  88. if (document.readyState === 'complete') {
  89. (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props));
  90. } else {
  91. window.addEventListener('load', () => {
  92. (0, _requestIdleCallback.requestIdleCallback)(() => loadScript(props));
  93. });
  94. }
  95. }
  96. function initScriptLoader(scriptLoaderItems) {
  97. scriptLoaderItems.forEach(handleClientScriptLoad);
  98. }
  99. function Script(props) {
  100. const {
  101. src = '',
  102. onLoad = () => {},
  103. strategy = 'afterInteractive',
  104. onError
  105. } = props,
  106. restProps = (0, _objectWithoutPropertiesLoose2.default)(props, ["src", "onLoad", "dangerouslySetInnerHTML", "strategy", "onError"]); // Context is available only during SSR
  107. const {
  108. updateScripts,
  109. scripts
  110. } = (0, _react.useContext)(_headManagerContext.HeadManagerContext);
  111. (0, _react.useEffect)(() => {
  112. if (strategy === 'afterInteractive') {
  113. loadScript(props);
  114. } else if (strategy === 'lazyOnload') {
  115. loadLazyScript(props);
  116. }
  117. }, [props, strategy]);
  118. if (true) {
  119. return null;
  120. }
  121. if (strategy === 'beforeInteractive') {
  122. if (updateScripts) {
  123. scripts.beforeInteractive = (scripts.beforeInteractive || []).concat([(0, _extends2.default)({
  124. src,
  125. onLoad,
  126. onError
  127. }, restProps)]);
  128. updateScripts(scripts);
  129. }
  130. }
  131. return null;
  132. }
  133. var _default = Script;
  134. exports.default = _default;
  135. /***/ }),
  136. /***/ "./node_modules/next/dist/client/head-manager.js":
  137. /*!*******************************************************!*\
  138. !*** ./node_modules/next/dist/client/head-manager.js ***!
  139. \*******************************************************/
  140. /***/ (function(__unused_webpack_module, exports) {
  141. "use strict";
  142. exports.__esModule = true;
  143. exports.default = initHeadManager;
  144. exports.DOMAttributeNames = void 0;
  145. const DOMAttributeNames = {
  146. acceptCharset: 'accept-charset',
  147. className: 'class',
  148. htmlFor: 'for',
  149. httpEquiv: 'http-equiv',
  150. noModule: 'noModule'
  151. };
  152. exports.DOMAttributeNames = DOMAttributeNames;
  153. function reactElementToDOM({
  154. type,
  155. props
  156. }) {
  157. const el = document.createElement(type);
  158. for (const p in props) {
  159. if (!props.hasOwnProperty(p)) continue;
  160. if (p === 'children' || p === 'dangerouslySetInnerHTML') continue; // we don't render undefined props to the DOM
  161. if (props[p] === undefined) continue;
  162. const attr = DOMAttributeNames[p] || p.toLowerCase();
  163. if (type === 'script' && (attr === 'async' || attr === 'defer' || attr === 'noModule')) {
  164. ;
  165. el[attr] = !!props[p];
  166. } else {
  167. el.setAttribute(attr, props[p]);
  168. }
  169. }
  170. const {
  171. children,
  172. dangerouslySetInnerHTML
  173. } = props;
  174. if (dangerouslySetInnerHTML) {
  175. el.innerHTML = dangerouslySetInnerHTML.__html || '';
  176. } else if (children) {
  177. el.textContent = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : '';
  178. }
  179. return el;
  180. }
  181. function updateElements(type, components) {
  182. const headEl = document.getElementsByTagName('head')[0];
  183. const headCountEl = headEl.querySelector('meta[name=next-head-count]');
  184. if (true) {
  185. if (!headCountEl) {
  186. console.error('Warning: next-head-count is missing. https://nextjs.org/docs/messages/next-head-count-missing');
  187. return;
  188. }
  189. }
  190. const headCount = Number(headCountEl.content);
  191. const oldTags = [];
  192. for (let i = 0, j = headCountEl.previousElementSibling; i < headCount; i++, j = j.previousElementSibling) {
  193. if (j.tagName.toLowerCase() === type) {
  194. oldTags.push(j);
  195. }
  196. }
  197. const newTags = components.map(reactElementToDOM).filter(newTag => {
  198. for (let k = 0, len = oldTags.length; k < len; k++) {
  199. const oldTag = oldTags[k];
  200. if (oldTag.isEqualNode(newTag)) {
  201. oldTags.splice(k, 1);
  202. return false;
  203. }
  204. }
  205. return true;
  206. });
  207. oldTags.forEach(t => t.parentNode.removeChild(t));
  208. newTags.forEach(t => headEl.insertBefore(t, headCountEl));
  209. headCountEl.content = (headCount - oldTags.length + newTags.length).toString();
  210. }
  211. function initHeadManager() {
  212. let updatePromise = null;
  213. return {
  214. mountedInstances: new Set(),
  215. updateHead: head => {
  216. const promise = updatePromise = Promise.resolve().then(() => {
  217. if (promise !== updatePromise) return;
  218. updatePromise = null;
  219. const tags = {};
  220. head.forEach(h => {
  221. if ( // If the font tag is loaded only on client navigation
  222. // it won't be inlined. In this case revert to the original behavior
  223. h.type === 'link' && h.props['data-optimized-fonts'] && !document.querySelector(`style[data-href="${h.props['data-href']}"]`)) {
  224. h.props.href = h.props['data-href'];
  225. h.props['data-href'] = undefined;
  226. }
  227. const components = tags[h.type] || [];
  228. components.push(h);
  229. tags[h.type] = components;
  230. });
  231. const titleComponent = tags.title ? tags.title[0] : null;
  232. let title = '';
  233. if (titleComponent) {
  234. const {
  235. children
  236. } = titleComponent.props;
  237. title = typeof children === 'string' ? children : Array.isArray(children) ? children.join('') : '';
  238. }
  239. if (title !== document.title) document.title = title;
  240. ['meta', 'base', 'link', 'style', 'script'].forEach(type => {
  241. updateElements(type, tags[type] || []);
  242. });
  243. });
  244. }
  245. };
  246. }
  247. /***/ }),
  248. /***/ "./node_modules/next/dist/client/request-idle-callback.js":
  249. /*!****************************************************************!*\
  250. !*** ./node_modules/next/dist/client/request-idle-callback.js ***!
  251. \****************************************************************/
  252. /***/ (function(__unused_webpack_module, exports) {
  253. "use strict";
  254. exports.__esModule = true;
  255. exports.cancelIdleCallback = exports.requestIdleCallback = void 0;
  256. const requestIdleCallback = typeof self !== 'undefined' && self.requestIdleCallback || function (cb) {
  257. let start = Date.now();
  258. return setTimeout(function () {
  259. cb({
  260. didTimeout: false,
  261. timeRemaining: function () {
  262. return Math.max(0, 50 - (Date.now() - start));
  263. }
  264. });
  265. }, 1);
  266. };
  267. exports.requestIdleCallback = requestIdleCallback;
  268. const cancelIdleCallback = typeof self !== 'undefined' && self.cancelIdleCallback || function (id) {
  269. return clearTimeout(id);
  270. };
  271. exports.cancelIdleCallback = cancelIdleCallback;
  272. /***/ }),
  273. /***/ "./node_modules/next/dist/pages/_document.js":
  274. /*!***************************************************!*\
  275. !*** ./node_modules/next/dist/pages/_document.js ***!
  276. \***************************************************/
  277. /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
  278. "use strict";
  279. 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; }
  280. 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; }
  281. 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; }
  282. 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; }
  283. 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; }
  284. exports.__esModule = true;
  285. exports.Html = Html;
  286. exports.Main = Main;
  287. exports.NextScript = exports.Head = exports.default = void 0;
  288. var _propTypes = _interopRequireDefault(__webpack_require__(/*! prop-types */ "prop-types"));
  289. var _react = _interopRequireWildcard(__webpack_require__(/*! react */ "react"));
  290. var _server = _interopRequireDefault(__webpack_require__(/*! styled-jsx/server */ "styled-jsx/server"));
  291. var _constants = __webpack_require__(/*! ../next-server/lib/constants */ "../next-server/lib/constants");
  292. var _documentContext = __webpack_require__(/*! ../next-server/lib/document-context */ "../next-server/lib/document-context");
  293. var _utils = __webpack_require__(/*! ../next-server/lib/utils */ "../next-server/lib/utils");
  294. exports.DocumentContext = _utils.DocumentContext;
  295. exports.DocumentInitialProps = _utils.DocumentInitialProps;
  296. exports.DocumentProps = _utils.DocumentProps;
  297. var _getPageFiles = __webpack_require__(/*! ../next-server/server/get-page-files */ "../next-server/server/get-page-files");
  298. var _utils2 = __webpack_require__(/*! ../next-server/server/utils */ "../next-server/server/utils");
  299. var _htmlescape = __webpack_require__(/*! ../server/htmlescape */ "./node_modules/next/dist/server/htmlescape.js");
  300. var _experimentalScript = _interopRequireDefault(__webpack_require__(/*! ../client/experimental-script */ "./node_modules/next/dist/client/experimental-script.js"));
  301. function _getRequireWildcardCache() {
  302. if (typeof WeakMap !== "function") return null;
  303. var cache = new WeakMap();
  304. _getRequireWildcardCache = function () {
  305. return cache;
  306. };
  307. return cache;
  308. }
  309. function _interopRequireWildcard(obj) {
  310. if (obj && obj.__esModule) {
  311. return obj;
  312. }
  313. if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
  314. return {
  315. default: obj
  316. };
  317. }
  318. var cache = _getRequireWildcardCache();
  319. if (cache && cache.has(obj)) {
  320. return cache.get(obj);
  321. }
  322. var newObj = {};
  323. var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
  324. for (var key in obj) {
  325. if (Object.prototype.hasOwnProperty.call(obj, key)) {
  326. var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
  327. if (desc && (desc.get || desc.set)) {
  328. Object.defineProperty(newObj, key, desc);
  329. } else {
  330. newObj[key] = obj[key];
  331. }
  332. }
  333. }
  334. newObj.default = obj;
  335. if (cache) {
  336. cache.set(obj, newObj);
  337. }
  338. return newObj;
  339. }
  340. function _interopRequireDefault(obj) {
  341. return obj && obj.__esModule ? obj : {
  342. default: obj
  343. };
  344. }
  345. function getDocumentFiles(buildManifest, pathname, inAmpMode) {
  346. const sharedFiles = (0, _getPageFiles.getPageFiles)(buildManifest, '/_app');
  347. const pageFiles = inAmpMode ? [] : (0, _getPageFiles.getPageFiles)(buildManifest, pathname);
  348. return {
  349. sharedFiles,
  350. pageFiles,
  351. allFiles: [...new Set([...sharedFiles, ...pageFiles])]
  352. };
  353. }
  354. function getPolyfillScripts(context, props) {
  355. // polyfills.js has to be rendered as nomodule without async
  356. // It also has to be the first script to load
  357. const {
  358. assetPrefix,
  359. buildManifest,
  360. devOnlyCacheBusterQueryString,
  361. disableOptimizedLoading
  362. } = context;
  363. return buildManifest.polyfillFiles.filter(polyfill => polyfill.endsWith('.js') && !polyfill.endsWith('.module.js')).map(polyfill => /*#__PURE__*/_react.default.createElement("script", {
  364. key: polyfill,
  365. defer: !disableOptimizedLoading,
  366. nonce: props.nonce,
  367. crossOrigin: props.crossOrigin || undefined,
  368. noModule: true,
  369. src: `${assetPrefix}/_next/${polyfill}${devOnlyCacheBusterQueryString}`
  370. }));
  371. }
  372. function getPreNextScripts(context, props) {
  373. const {
  374. scriptLoader,
  375. disableOptimizedLoading
  376. } = context;
  377. return (scriptLoader.beforeInteractive || []).map(file => {
  378. const {
  379. strategy
  380. } = file,
  381. scriptProps = _objectWithoutProperties(file, ["strategy"]);
  382. return /*#__PURE__*/_react.default.createElement("script", Object.assign({}, scriptProps, {
  383. defer: !disableOptimizedLoading,
  384. nonce: props.nonce,
  385. crossOrigin: props.crossOrigin || undefined
  386. }));
  387. });
  388. }
  389. function getDynamicChunks(context, props, files) {
  390. const {
  391. dynamicImports,
  392. assetPrefix,
  393. isDevelopment,
  394. devOnlyCacheBusterQueryString,
  395. disableOptimizedLoading
  396. } = context;
  397. return dynamicImports.map(file => {
  398. if (!file.endsWith('.js') || files.allFiles.includes(file)) return null;
  399. return /*#__PURE__*/_react.default.createElement("script", {
  400. async: !isDevelopment && disableOptimizedLoading,
  401. defer: !disableOptimizedLoading,
  402. key: file,
  403. src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  404. nonce: props.nonce,
  405. crossOrigin: props.crossOrigin || undefined
  406. });
  407. });
  408. }
  409. function getScripts(context, props, files) {
  410. var _buildManifest$lowPri;
  411. const {
  412. assetPrefix,
  413. buildManifest,
  414. isDevelopment,
  415. devOnlyCacheBusterQueryString,
  416. disableOptimizedLoading
  417. } = context;
  418. const normalScripts = files.allFiles.filter(file => file.endsWith('.js'));
  419. const lowPriorityScripts = (_buildManifest$lowPri = buildManifest.lowPriorityFiles) == null ? void 0 : _buildManifest$lowPri.filter(file => file.endsWith('.js'));
  420. return [...normalScripts, ...lowPriorityScripts].map(file => {
  421. return /*#__PURE__*/_react.default.createElement("script", {
  422. key: file,
  423. src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  424. nonce: props.nonce,
  425. async: !isDevelopment && disableOptimizedLoading,
  426. defer: !disableOptimizedLoading,
  427. crossOrigin: props.crossOrigin || undefined
  428. });
  429. });
  430. }
  431. /**
  432. * `Document` component handles the initial `document` markup and renders only on the server side.
  433. * Commonly used for implementing server side rendering for `css-in-js` libraries.
  434. */
  435. class Document extends _react.Component {
  436. /**
  437. * `getInitialProps` hook returns the context object with the addition of `renderPage`.
  438. * `renderPage` callback executes `React` rendering logic synchronously to support server-rendering wrappers
  439. */
  440. static async getInitialProps(ctx) {
  441. const enhanceApp = App => {
  442. return props => /*#__PURE__*/_react.default.createElement(App, props);
  443. };
  444. const {
  445. html,
  446. head
  447. } = await ctx.renderPage({
  448. enhanceApp
  449. });
  450. const styles = [...(0, _server.default)()];
  451. return {
  452. html,
  453. head,
  454. styles
  455. };
  456. }
  457. static renderDocument(DocumentComponent, props) {
  458. return /*#__PURE__*/_react.default.createElement(_documentContext.DocumentContext.Provider, {
  459. value: props
  460. }, /*#__PURE__*/_react.default.createElement(DocumentComponent, props));
  461. }
  462. render() {
  463. 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)));
  464. }
  465. }
  466. exports.default = Document;
  467. function Html(props) {
  468. const {
  469. inAmpMode,
  470. docComponentsRendered,
  471. locale
  472. } = (0, _react.useContext)(_documentContext.DocumentContext);
  473. docComponentsRendered.Html = true;
  474. return /*#__PURE__*/_react.default.createElement("html", Object.assign({}, props, {
  475. lang: props.lang || locale || undefined,
  476. amp: inAmpMode ? '' : undefined,
  477. "data-ampdevmode": inAmpMode && true ? '' : undefined
  478. }));
  479. }
  480. class Head extends _react.Component {
  481. constructor(...args) {
  482. super(...args);
  483. this.context = void 0;
  484. }
  485. getCssLinks(files) {
  486. const {
  487. assetPrefix,
  488. devOnlyCacheBusterQueryString,
  489. dynamicImports
  490. } = this.context;
  491. const cssFiles = files.allFiles.filter(f => f.endsWith('.css'));
  492. const sharedFiles = new Set(files.sharedFiles); // Unmanaged files are CSS files that will be handled directly by the
  493. // webpack runtime (`mini-css-extract-plugin`).
  494. let unmangedFiles = new Set([]);
  495. let dynamicCssFiles = Array.from(new Set(dynamicImports.filter(file => file.endsWith('.css'))));
  496. if (dynamicCssFiles.length) {
  497. const existing = new Set(cssFiles);
  498. dynamicCssFiles = dynamicCssFiles.filter(f => !(existing.has(f) || sharedFiles.has(f)));
  499. unmangedFiles = new Set(dynamicCssFiles);
  500. cssFiles.push(...dynamicCssFiles);
  501. }
  502. let cssLinkElements = [];
  503. cssFiles.forEach(file => {
  504. const isSharedFile = sharedFiles.has(file);
  505. if (true) {
  506. cssLinkElements.push( /*#__PURE__*/_react.default.createElement("link", {
  507. key: `${file}-preload`,
  508. nonce: this.props.nonce,
  509. rel: "preload",
  510. href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  511. as: "style",
  512. crossOrigin: this.props.crossOrigin || undefined
  513. }));
  514. }
  515. const isUnmanagedFile = unmangedFiles.has(file);
  516. cssLinkElements.push( /*#__PURE__*/_react.default.createElement("link", {
  517. key: file,
  518. nonce: this.props.nonce,
  519. rel: "stylesheet",
  520. href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  521. crossOrigin: this.props.crossOrigin || undefined,
  522. "data-n-g": isUnmanagedFile ? undefined : isSharedFile ? '' : undefined,
  523. "data-n-p": isUnmanagedFile ? undefined : isSharedFile ? undefined : ''
  524. }));
  525. });
  526. if (false) {}
  527. return cssLinkElements.length === 0 ? null : cssLinkElements;
  528. }
  529. getPreloadDynamicChunks() {
  530. const {
  531. dynamicImports,
  532. assetPrefix,
  533. devOnlyCacheBusterQueryString
  534. } = this.context;
  535. return dynamicImports.map(file => {
  536. if (!file.endsWith('.js')) {
  537. return null;
  538. }
  539. return /*#__PURE__*/_react.default.createElement("link", {
  540. rel: "preload",
  541. key: file,
  542. href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  543. as: "script",
  544. nonce: this.props.nonce,
  545. crossOrigin: this.props.crossOrigin || undefined
  546. });
  547. }) // Filter out nulled scripts
  548. .filter(Boolean);
  549. }
  550. getPreloadMainLinks(files) {
  551. const {
  552. assetPrefix,
  553. devOnlyCacheBusterQueryString,
  554. scriptLoader
  555. } = this.context;
  556. const preloadFiles = files.allFiles.filter(file => {
  557. return file.endsWith('.js');
  558. });
  559. return [...(scriptLoader.beforeInteractive || []).map(file => /*#__PURE__*/_react.default.createElement("link", {
  560. key: file.src,
  561. nonce: this.props.nonce,
  562. rel: "preload",
  563. href: file.src,
  564. as: "script",
  565. crossOrigin: this.props.crossOrigin || undefined
  566. })), ...preloadFiles.map(file => /*#__PURE__*/_react.default.createElement("link", {
  567. key: file,
  568. nonce: this.props.nonce,
  569. rel: "preload",
  570. href: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  571. as: "script",
  572. crossOrigin: this.props.crossOrigin || undefined
  573. }))];
  574. }
  575. getDynamicChunks(files) {
  576. return getDynamicChunks(this.context, this.props, files);
  577. }
  578. getPreNextScripts() {
  579. return getPreNextScripts(this.context, this.props);
  580. }
  581. getScripts(files) {
  582. return getScripts(this.context, this.props, files);
  583. }
  584. getPolyfillScripts() {
  585. return getPolyfillScripts(this.context, this.props);
  586. }
  587. handleDocumentScriptLoaderItems(children) {
  588. const {
  589. scriptLoader
  590. } = this.context;
  591. const scriptLoaderItems = [];
  592. const filteredChildren = [];
  593. _react.default.Children.forEach(children, child => {
  594. if (child.type === _experimentalScript.default) {
  595. if (child.props.strategy === 'beforeInteractive') {
  596. scriptLoader.beforeInteractive = (scriptLoader.beforeInteractive || []).concat([_objectSpread({}, child.props)]);
  597. return;
  598. } else if (['lazyOnload', 'afterInteractive'].includes(child.props.strategy)) {
  599. scriptLoaderItems.push(child.props);
  600. return;
  601. }
  602. }
  603. filteredChildren.push(child);
  604. });
  605. this.context.__NEXT_DATA__.scriptLoader = scriptLoaderItems;
  606. return filteredChildren;
  607. }
  608. makeStylesheetInert(node) {
  609. return _react.default.Children.map(node, c => {
  610. if (c.type === 'link' && c.props['href'] && _constants.OPTIMIZED_FONT_PROVIDERS.some(url => c.props['href'].startsWith(url))) {
  611. const newProps = _objectSpread({}, c.props || {});
  612. newProps['data-href'] = newProps['href'];
  613. newProps['href'] = undefined;
  614. return /*#__PURE__*/_react.default.cloneElement(c, newProps);
  615. } else if (c.props && c.props['children']) {
  616. c.props['children'] = this.makeStylesheetInert(c.props['children']);
  617. }
  618. return c;
  619. });
  620. }
  621. render() {
  622. var _this$props$nonce, _this$props$nonce2;
  623. const {
  624. styles,
  625. ampPath,
  626. inAmpMode,
  627. hybridAmp,
  628. canonicalBase,
  629. __NEXT_DATA__,
  630. dangerousAsPath,
  631. headTags,
  632. unstable_runtimeJS,
  633. unstable_JsPreload,
  634. disableOptimizedLoading
  635. } = this.context;
  636. const disableRuntimeJS = unstable_runtimeJS === false;
  637. const disableJsPreload = unstable_JsPreload === false || !disableOptimizedLoading;
  638. this.context.docComponentsRendered.Head = true;
  639. let {
  640. head
  641. } = this.context;
  642. let cssPreloads = [];
  643. let otherHeadElements = [];
  644. if (head) {
  645. head.forEach(c => {
  646. if (c && c.type === 'link' && c.props['rel'] === 'preload' && c.props['as'] === 'style') {
  647. cssPreloads.push(c);
  648. } else {
  649. c && otherHeadElements.push(c);
  650. }
  651. });
  652. head = cssPreloads.concat(otherHeadElements);
  653. }
  654. let children = _react.default.Children.toArray(this.props.children).filter(Boolean); // show a warning if Head contains <title> (only in development)
  655. if (true) {
  656. children = _react.default.Children.map(children, child => {
  657. var _child$props;
  658. const isReactHelmet = child == null ? void 0 : (_child$props = child.props) == null ? void 0 : _child$props['data-react-helmet'];
  659. if (!isReactHelmet) {
  660. var _child$props2;
  661. if ((child == null ? void 0 : child.type) === 'title') {
  662. console.warn("Warning: <title> should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-title");
  663. } else if ((child == null ? void 0 : child.type) === 'meta' && (child == null ? void 0 : (_child$props2 = child.props) == null ? void 0 : _child$props2.name) === 'viewport') {
  664. console.warn("Warning: viewport meta tags should not be used in _document.js's <Head>. https://nextjs.org/docs/messages/no-document-viewport-meta");
  665. }
  666. }
  667. return child;
  668. });
  669. if (this.props.crossOrigin) console.warn('Warning: `Head` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated');
  670. }
  671. if (false) {}
  672. if (false) {}
  673. let hasAmphtmlRel = false;
  674. let hasCanonicalRel = false; // show warning and remove conflicting amp head tags
  675. head = _react.default.Children.map(head || [], child => {
  676. if (!child) return child;
  677. const {
  678. type,
  679. props
  680. } = child;
  681. if (inAmpMode) {
  682. let badProp = '';
  683. if (type === 'meta' && props.name === 'viewport') {
  684. badProp = 'name="viewport"';
  685. } else if (type === 'link' && props.rel === 'canonical') {
  686. hasCanonicalRel = true;
  687. } else if (type === 'script') {
  688. // only block if
  689. // 1. it has a src and isn't pointing to ampproject's CDN
  690. // 2. it is using dangerouslySetInnerHTML without a type or
  691. // a type of text/javascript
  692. if (props.src && props.src.indexOf('ampproject') < -1 || props.dangerouslySetInnerHTML && (!props.type || props.type === 'text/javascript')) {
  693. badProp = '<script';
  694. Object.keys(props).forEach(prop => {
  695. badProp += ` ${prop}="${props[prop]}"`;
  696. });
  697. badProp += '/>';
  698. }
  699. }
  700. if (badProp) {
  701. console.warn(`Found conflicting amp tag "${child.type}" with conflicting prop ${badProp} in ${__NEXT_DATA__.page}. https://nextjs.org/docs/messages/conflicting-amp-tag`);
  702. return null;
  703. }
  704. } else {
  705. // non-amp mode
  706. if (type === 'link' && props.rel === 'amphtml') {
  707. hasAmphtmlRel = true;
  708. }
  709. }
  710. return child;
  711. }); // try to parse styles from fragment for backwards compat
  712. const curStyles = Array.isArray(styles) ? styles : [];
  713. if (inAmpMode && styles && // @ts-ignore Property 'props' does not exist on type ReactElement
  714. styles.props && // @ts-ignore Property 'props' does not exist on type ReactElement
  715. Array.isArray(styles.props.children)) {
  716. const hasStyles = el => {
  717. var _el$props, _el$props$dangerously;
  718. 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;
  719. }; // @ts-ignore Property 'props' does not exist on type ReactElement
  720. styles.props.children.forEach(child => {
  721. if (Array.isArray(child)) {
  722. child.forEach(el => hasStyles(el) && curStyles.push(el));
  723. } else if (hasStyles(child)) {
  724. curStyles.push(child);
  725. }
  726. });
  727. }
  728. const files = getDocumentFiles(this.context.buildManifest, this.context.__NEXT_DATA__.page, inAmpMode);
  729. return /*#__PURE__*/_react.default.createElement("head", this.props, this.context.isDevelopment && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("style", {
  730. "data-next-hide-fouc": true,
  731. "data-ampdevmode": inAmpMode ? 'true' : undefined,
  732. dangerouslySetInnerHTML: {
  733. __html: `body{display:none}`
  734. }
  735. }), /*#__PURE__*/_react.default.createElement("noscript", {
  736. "data-next-hide-fouc": true,
  737. "data-ampdevmode": inAmpMode ? 'true' : undefined
  738. }, /*#__PURE__*/_react.default.createElement("style", {
  739. dangerouslySetInnerHTML: {
  740. __html: `body{display:block}`
  741. }
  742. }))), children, head, /*#__PURE__*/_react.default.createElement("meta", {
  743. name: "next-head-count",
  744. content: _react.default.Children.count(head || []).toString()
  745. }), inAmpMode && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("meta", {
  746. name: "viewport",
  747. content: "width=device-width,minimum-scale=1,initial-scale=1"
  748. }), !hasCanonicalRel && /*#__PURE__*/_react.default.createElement("link", {
  749. rel: "canonical",
  750. href: canonicalBase + (0, _utils2.cleanAmpPath)(dangerousAsPath)
  751. }), /*#__PURE__*/_react.default.createElement("link", {
  752. rel: "preload",
  753. as: "script",
  754. href: "https://cdn.ampproject.org/v0.js"
  755. }), styles && /*#__PURE__*/_react.default.createElement("style", {
  756. "amp-custom": "",
  757. dangerouslySetInnerHTML: {
  758. __html: curStyles.map(style => style.props.dangerouslySetInnerHTML.__html).join('').replace(/\/\*# sourceMappingURL=.*\*\//g, '').replace(/\/\*@ sourceURL=.*?\*\//g, '')
  759. }
  760. }), /*#__PURE__*/_react.default.createElement("style", {
  761. "amp-boilerplate": "",
  762. dangerouslySetInnerHTML: {
  763. __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}}`
  764. }
  765. }), /*#__PURE__*/_react.default.createElement("noscript", null, /*#__PURE__*/_react.default.createElement("style", {
  766. "amp-boilerplate": "",
  767. dangerouslySetInnerHTML: {
  768. __html: `body{-webkit-animation:none;-moz-animation:none;-ms-animation:none;animation:none}`
  769. }
  770. })), /*#__PURE__*/_react.default.createElement("script", {
  771. async: true,
  772. src: "https://cdn.ampproject.org/v0.js"
  773. })), !inAmpMode && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !hasAmphtmlRel && hybridAmp && /*#__PURE__*/_react.default.createElement("link", {
  774. rel: "amphtml",
  775. href: canonicalBase + getAmpPath(ampPath, dangerousAsPath)
  776. }), true && this.getCssLinks(files), true && /*#__PURE__*/_react.default.createElement("noscript", {
  777. "data-n-css": (_this$props$nonce = this.props.nonce) != null ? _this$props$nonce : ''
  778. }), !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 &&
  779. /*#__PURE__*/
  780. // this element is used to mount development styles so the
  781. // ordering matches production
  782. // (by default, style-loader injects at the bottom of <head />)
  783. _react.default.createElement("noscript", {
  784. id: "__next_css__DO_NOT_USE__"
  785. }), styles || null), /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {}, ...(headTags || [])));
  786. }
  787. }
  788. exports.Head = Head;
  789. Head.contextType = _documentContext.DocumentContext;
  790. Head.propTypes = {
  791. nonce: _propTypes.default.string,
  792. crossOrigin: _propTypes.default.string
  793. };
  794. function Main() {
  795. const {
  796. inAmpMode,
  797. html,
  798. docComponentsRendered
  799. } = (0, _react.useContext)(_documentContext.DocumentContext);
  800. docComponentsRendered.Main = true;
  801. if (inAmpMode) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, _constants.AMP_RENDER_TARGET);
  802. return /*#__PURE__*/_react.default.createElement("div", {
  803. id: "__next",
  804. dangerouslySetInnerHTML: {
  805. __html: html
  806. }
  807. });
  808. }
  809. class NextScript extends _react.Component {
  810. constructor(...args) {
  811. super(...args);
  812. this.context = void 0;
  813. }
  814. getDynamicChunks(files) {
  815. return getDynamicChunks(this.context, this.props, files);
  816. }
  817. getPreNextScripts() {
  818. return getPreNextScripts(this.context, this.props);
  819. }
  820. getScripts(files) {
  821. return getScripts(this.context, this.props, files);
  822. }
  823. getPolyfillScripts() {
  824. return getPolyfillScripts(this.context, this.props);
  825. }
  826. static getInlineScriptSource(documentProps) {
  827. const {
  828. __NEXT_DATA__
  829. } = documentProps;
  830. try {
  831. const data = JSON.stringify(__NEXT_DATA__);
  832. return (0, _htmlescape.htmlEscapeJsonString)(data);
  833. } catch (err) {
  834. if (err.message.indexOf('circular structure')) {
  835. throw new Error(`Circular structure in "getInitialProps" result of page "${__NEXT_DATA__.page}". https://nextjs.org/docs/messages/circular-structure`);
  836. }
  837. throw err;
  838. }
  839. }
  840. render() {
  841. const {
  842. assetPrefix,
  843. inAmpMode,
  844. buildManifest,
  845. unstable_runtimeJS,
  846. docComponentsRendered,
  847. devOnlyCacheBusterQueryString,
  848. disableOptimizedLoading
  849. } = this.context;
  850. const disableRuntimeJS = unstable_runtimeJS === false;
  851. docComponentsRendered.NextScript = true;
  852. if (inAmpMode) {
  853. if (false) {}
  854. const ampDevFiles = [...buildManifest.devFiles, ...buildManifest.polyfillFiles, ...buildManifest.ampDevFiles];
  855. return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, disableRuntimeJS ? null : /*#__PURE__*/_react.default.createElement("script", {
  856. id: "__NEXT_DATA__",
  857. type: "application/json",
  858. nonce: this.props.nonce,
  859. crossOrigin: this.props.crossOrigin || undefined,
  860. dangerouslySetInnerHTML: {
  861. __html: NextScript.getInlineScriptSource(this.context)
  862. },
  863. "data-ampdevmode": true
  864. }), ampDevFiles.map(file => /*#__PURE__*/_react.default.createElement("script", {
  865. key: file,
  866. src: `${assetPrefix}/_next/${file}${devOnlyCacheBusterQueryString}`,
  867. nonce: this.props.nonce,
  868. crossOrigin: this.props.crossOrigin || undefined,
  869. "data-ampdevmode": true
  870. })));
  871. }
  872. if (true) {
  873. if (this.props.crossOrigin) console.warn('Warning: `NextScript` attribute `crossOrigin` is deprecated. https://nextjs.org/docs/messages/doc-crossorigin-deprecated');
  874. }
  875. const files = getDocumentFiles(this.context.buildManifest, this.context.__NEXT_DATA__.page, inAmpMode);
  876. return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !disableRuntimeJS && buildManifest.devFiles ? buildManifest.devFiles.map(file => /*#__PURE__*/_react.default.createElement("script", {
  877. key: file,
  878. src: `${assetPrefix}/_next/${encodeURI(file)}${devOnlyCacheBusterQueryString}`,
  879. nonce: this.props.nonce,
  880. crossOrigin: this.props.crossOrigin || undefined
  881. })) : null, disableRuntimeJS ? null : /*#__PURE__*/_react.default.createElement("script", {
  882. id: "__NEXT_DATA__",
  883. type: "application/json",
  884. nonce: this.props.nonce,
  885. crossOrigin: this.props.crossOrigin || undefined,
  886. dangerouslySetInnerHTML: {
  887. __html: NextScript.getInlineScriptSource(this.context)
  888. }
  889. }), disableOptimizedLoading && !disableRuntimeJS && this.getPolyfillScripts(), disableOptimizedLoading && !disableRuntimeJS && this.getPreNextScripts(), disableOptimizedLoading && !disableRuntimeJS && this.getDynamicChunks(files), disableOptimizedLoading && !disableRuntimeJS && this.getScripts(files));
  890. }
  891. }
  892. exports.NextScript = NextScript;
  893. NextScript.contextType = _documentContext.DocumentContext;
  894. NextScript.propTypes = {
  895. nonce: _propTypes.default.string,
  896. crossOrigin: _propTypes.default.string
  897. };
  898. 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()}}();';
  899. function getAmpPath(ampPath, asPath) {
  900. return ampPath || `${asPath}${asPath.includes('?') ? '&' : '?'}amp=1`;
  901. }
  902. /***/ }),
  903. /***/ "./node_modules/next/dist/server/htmlescape.js":
  904. /*!*****************************************************!*\
  905. !*** ./node_modules/next/dist/server/htmlescape.js ***!
  906. \*****************************************************/
  907. /***/ (function(__unused_webpack_module, exports) {
  908. "use strict";
  909. exports.__esModule=true;exports.htmlEscapeJsonString=htmlEscapeJsonString;// This utility is based on https://github.com/zertosh/htmlescape
  910. // License: https://github.com/zertosh/htmlescape/blob/0527ca7156a524d256101bb310a9f970f63078ad/LICENSE
  911. 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]);}
  912. //# sourceMappingURL=htmlescape.js.map
  913. /***/ }),
  914. /***/ "./node_modules/next/document.js":
  915. /*!***************************************!*\
  916. !*** ./node_modules/next/document.js ***!
  917. \***************************************/
  918. /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
  919. module.exports = __webpack_require__(/*! ./dist/pages/_document */ "./node_modules/next/dist/pages/_document.js")
  920. /***/ }),
  921. /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/extends.js":
  922. /*!**************************************************************************!*\
  923. !*** ./node_modules/next/node_modules/@babel/runtime/helpers/extends.js ***!
  924. \**************************************************************************/
  925. /***/ (function(module) {
  926. function _extends() {
  927. module.exports = _extends = Object.assign || function (target) {
  928. for (var i = 1; i < arguments.length; i++) {
  929. var source = arguments[i];
  930. for (var key in source) {
  931. if (Object.prototype.hasOwnProperty.call(source, key)) {
  932. target[key] = source[key];
  933. }
  934. }
  935. }
  936. return target;
  937. };
  938. return _extends.apply(this, arguments);
  939. }
  940. module.exports = _extends;
  941. /***/ }),
  942. /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js":
  943. /*!****************************************************************************************!*\
  944. !*** ./node_modules/next/node_modules/@babel/runtime/helpers/interopRequireDefault.js ***!
  945. \****************************************************************************************/
  946. /***/ (function(module) {
  947. function _interopRequireDefault(obj) {
  948. return obj && obj.__esModule ? obj : {
  949. "default": obj
  950. };
  951. }
  952. module.exports = _interopRequireDefault;
  953. /***/ }),
  954. /***/ "./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js":
  955. /*!***********************************************************************************************!*\
  956. !*** ./node_modules/next/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js ***!
  957. \***********************************************************************************************/
  958. /***/ (function(module) {
  959. function _objectWithoutPropertiesLoose(source, excluded) {
  960. if (source == null) return {};
  961. var target = {};
  962. var sourceKeys = Object.keys(source);
  963. var key, i;
  964. for (i = 0; i < sourceKeys.length; i++) {
  965. key = sourceKeys[i];
  966. if (excluded.indexOf(key) >= 0) continue;
  967. target[key] = source[key];
  968. }
  969. return target;
  970. }
  971. module.exports = _objectWithoutPropertiesLoose;
  972. /***/ })
  973. };
  974. ;
  975. //# 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":""}