vike 0.4.222 → 0.4.223-commit-6f064ad

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (158) hide show
  1. package/dist/cjs/client/shared/getPageContextProxyForUser.js +1 -1
  2. package/dist/cjs/node/api/prepareViteApiCall.js +1 -1
  3. package/dist/cjs/node/plugin/index.js +6 -4
  4. package/dist/cjs/node/plugin/plugins/baseUrls.js +9 -2
  5. package/dist/cjs/node/plugin/plugins/buildApp.js +14 -7
  6. package/dist/cjs/node/plugin/plugins/buildConfig/fixServerAssets.js +49 -19
  7. package/dist/cjs/node/plugin/plugins/buildConfig.js +6 -1
  8. package/dist/cjs/node/plugin/plugins/commonConfig.js +17 -1
  9. package/dist/cjs/node/plugin/plugins/devConfig/determineOptimizeDeps.js +1 -1
  10. package/dist/cjs/node/plugin/plugins/envVars.js +2 -18
  11. package/dist/cjs/node/plugin/plugins/extractAssetsPlugin.js +2 -2
  12. package/dist/cjs/node/plugin/plugins/extractExportNamesPlugin.js +1 -1
  13. package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/assertExtensions.js +4 -4
  14. package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/configDefinitionsBuiltIn.js +6 -1
  15. package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/crawlPlusFiles.js +11 -10
  16. package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/transpileAndExecuteFile.js +8 -5
  17. package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.js +36 -71
  18. package/dist/cjs/node/plugin/shared/findPageFiles.js +3 -3
  19. package/dist/cjs/node/plugin/shared/getHttpRequestAsyncStore.js +1 -1
  20. package/dist/cjs/node/plugin/shared/viteIsSSR.js +19 -10
  21. package/dist/cjs/node/prerender/runPrerender.js +3 -1
  22. package/dist/cjs/node/runtime/globalContext.js +19 -8
  23. package/dist/cjs/node/runtime/renderPage/createHttpResponse/assertNoInfiniteHttpRedirect.js +1 -1
  24. package/dist/cjs/node/runtime/renderPage/createHttpResponse.js +24 -0
  25. package/dist/cjs/node/runtime/renderPage/getPageAssets.js +1 -1
  26. package/dist/cjs/node/runtime/renderPage/handlePageContextRequestUrl.js +1 -1
  27. package/dist/cjs/node/runtime/renderPage/isNewError.js +1 -1
  28. package/dist/cjs/node/runtime/renderPage/isVikeConfigInvalid.js +10 -0
  29. package/dist/cjs/node/runtime/renderPage/loadUserFilesServerSide.js +1 -1
  30. package/dist/cjs/node/runtime/renderPage/logErrorHint.js +7 -1
  31. package/dist/cjs/node/runtime/renderPage/renderPageAlreadyRouted.js +2 -4
  32. package/dist/cjs/node/runtime/renderPage.js +63 -49
  33. package/dist/cjs/node/runtime/universal-middleware.js +14 -0
  34. package/dist/cjs/node/shared/resolveBase.js +0 -13
  35. package/dist/cjs/shared/getPageConfigsRuntime.js +2 -8
  36. package/dist/cjs/shared/getPageContextRequestUrl.js +1 -1
  37. package/dist/cjs/shared/getPageContextUrlComputed.js +12 -9
  38. package/dist/cjs/shared/hooks/getHook.js +1 -1
  39. package/dist/cjs/shared/page-configs/getPageConfigUserFriendly.js +44 -12
  40. package/dist/cjs/shared/page-configs/serialize/parsePageConfigs.js +2 -8
  41. package/dist/cjs/shared/page-configs/serialize/serializeConfigValues.js +16 -6
  42. package/dist/cjs/shared/route/loadPageRoutes.js +1 -1
  43. package/dist/cjs/utils/PROJECT_VERSION.js +1 -1
  44. package/dist/cjs/utils/assert.js +1 -1
  45. package/dist/cjs/utils/assertSetup.js +1 -1
  46. package/dist/cjs/utils/assertSingleInstance.js +2 -2
  47. package/dist/cjs/utils/findFile.js +1 -1
  48. package/dist/cjs/utils/getGlobalObject.js +2 -6
  49. package/dist/cjs/utils/parseUrl-extras.js +2 -2
  50. package/dist/cjs/utils/parseUrl.js +5 -5
  51. package/dist/esm/client/client-routing-runtime/getPageContextCurrent.d.ts +2 -2
  52. package/dist/esm/client/client-routing-runtime/getPageContextCurrent.js +1 -1
  53. package/dist/esm/client/client-routing-runtime/getPageContextFromHooks.d.ts +4 -4
  54. package/dist/esm/client/client-routing-runtime/getPageContextFromHooks.js +1 -1
  55. package/dist/esm/client/client-routing-runtime/history.js +1 -1
  56. package/dist/esm/client/client-routing-runtime/index.d.ts +1 -0
  57. package/dist/esm/client/client-routing-runtime/index.js +1 -0
  58. package/dist/esm/client/client-routing-runtime/prefetch/getPrefetchSettings.d.ts +2 -2
  59. package/dist/esm/client/client-routing-runtime/prefetch.d.ts +2 -2
  60. package/dist/esm/client/client-routing-runtime/prefetch.js +3 -3
  61. package/dist/esm/client/client-routing-runtime/renderPageClientSide.d.ts +8 -0
  62. package/dist/esm/client/client-routing-runtime/renderPageClientSide.js +12 -3
  63. package/dist/esm/client/client-routing-runtime/scrollRestoration.js +1 -1
  64. package/dist/esm/client/client-routing-runtime/skipLink.js +2 -2
  65. package/dist/esm/client/server-routing-runtime/getPageContext.d.ts +1 -1
  66. package/dist/esm/client/shared/executeOnRenderClientHook.d.ts +2 -2
  67. package/dist/esm/client/shared/getPageContextProxyForUser.js +1 -1
  68. package/dist/esm/client/shared/loadUserFilesClientSide.d.ts +2 -2
  69. package/dist/esm/client/shared/loadUserFilesClientSide.js +2 -2
  70. package/dist/esm/client/shared/preparePageContextForUserConsumptionClientSide.d.ts +2 -2
  71. package/dist/esm/node/api/prepareViteApiCall.js +1 -1
  72. package/dist/esm/node/plugin/index.d.ts +6 -2
  73. package/dist/esm/node/plugin/index.js +2 -1
  74. package/dist/esm/node/plugin/plugins/baseUrls.js +9 -2
  75. package/dist/esm/node/plugin/plugins/buildApp.js +14 -7
  76. package/dist/esm/node/plugin/plugins/buildConfig/fixServerAssets.js +49 -19
  77. package/dist/esm/node/plugin/plugins/buildConfig.js +6 -1
  78. package/dist/esm/node/plugin/plugins/commonConfig.d.ts +14 -6
  79. package/dist/esm/node/plugin/plugins/commonConfig.js +17 -1
  80. package/dist/esm/node/plugin/plugins/devConfig/determineOptimizeDeps.js +1 -1
  81. package/dist/esm/node/plugin/plugins/envVars.js +2 -18
  82. package/dist/esm/node/plugin/plugins/extractAssetsPlugin.js +3 -3
  83. package/dist/esm/node/plugin/plugins/extractExportNamesPlugin.js +1 -1
  84. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/assertExtensions.js +4 -4
  85. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/configDefinitionsBuiltIn.js +6 -1
  86. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/crawlPlusFiles.js +10 -9
  87. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/transpileAndExecuteFile.js +8 -5
  88. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.d.ts +5 -5
  89. package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.js +38 -73
  90. package/dist/esm/node/plugin/shared/findPageFiles.js +3 -3
  91. package/dist/esm/node/plugin/shared/getHttpRequestAsyncStore.js +2 -2
  92. package/dist/esm/node/plugin/shared/viteIsSSR.d.ts +7 -4
  93. package/dist/esm/node/plugin/shared/viteIsSSR.js +20 -11
  94. package/dist/esm/node/prerender/runPrerender.js +3 -1
  95. package/dist/esm/node/runtime/globalContext.d.ts +9 -8
  96. package/dist/esm/node/runtime/globalContext.js +19 -8
  97. package/dist/esm/node/runtime/html/injectAssets/getViteDevScript.d.ts +2 -2
  98. package/dist/esm/node/runtime/html/injectAssets.d.ts +2 -2
  99. package/dist/esm/node/runtime/renderPage/analyzePage.d.ts +2 -2
  100. package/dist/esm/node/runtime/renderPage/createHttpResponse/assertNoInfiniteHttpRedirect.js +1 -1
  101. package/dist/esm/node/runtime/renderPage/createHttpResponse.d.ts +2 -0
  102. package/dist/esm/node/runtime/renderPage/createHttpResponse.js +24 -0
  103. package/dist/esm/node/runtime/renderPage/executeOnBeforeRenderAndDataHooks.d.ts +2 -2
  104. package/dist/esm/node/runtime/renderPage/getPageAssets.d.ts +2 -2
  105. package/dist/esm/node/runtime/renderPage/getPageAssets.js +1 -1
  106. package/dist/esm/node/runtime/renderPage/handleErrorWithoutErrorPage.d.ts +2 -2
  107. package/dist/esm/node/runtime/renderPage/handlePageContextRequestUrl.js +1 -1
  108. package/dist/esm/node/runtime/renderPage/isNewError.js +1 -1
  109. package/dist/esm/node/runtime/renderPage/isVikeConfigInvalid.d.ts +6 -0
  110. package/dist/esm/node/runtime/renderPage/isVikeConfigInvalid.js +8 -0
  111. package/dist/esm/node/runtime/renderPage/loadUserFilesServerSide.d.ts +3 -3
  112. package/dist/esm/node/runtime/renderPage/loadUserFilesServerSide.js +2 -2
  113. package/dist/esm/node/runtime/renderPage/log404/index.d.ts +2 -2
  114. package/dist/esm/node/runtime/renderPage/logErrorHint.js +7 -1
  115. package/dist/esm/node/runtime/renderPage/preparePageContextForUserConsumptionServerSide.d.ts +4 -4
  116. package/dist/esm/node/runtime/renderPage/renderPageAlreadyRouted.d.ts +12 -12
  117. package/dist/esm/node/runtime/renderPage/renderPageAlreadyRouted.js +2 -4
  118. package/dist/esm/node/runtime/renderPage.d.ts +5 -5
  119. package/dist/esm/node/runtime/renderPage.js +64 -49
  120. package/dist/esm/node/runtime/universal-middleware.d.ts +1 -0
  121. package/dist/esm/node/runtime/universal-middleware.js +11 -0
  122. package/dist/esm/node/shared/resolveBase.d.ts +1 -9
  123. package/dist/esm/node/shared/resolveBase.js +0 -13
  124. package/dist/esm/shared/getPageConfigsRuntime.d.ts +2 -2
  125. package/dist/esm/shared/getPageConfigsRuntime.js +3 -9
  126. package/dist/esm/shared/getPageContextRequestUrl.js +1 -1
  127. package/dist/esm/shared/getPageContextUrlComputed.js +12 -9
  128. package/dist/esm/shared/getPageFiles.d.ts +1 -1
  129. package/dist/esm/shared/hooks/getHook.d.ts +3 -3
  130. package/dist/esm/shared/hooks/getHook.js +1 -1
  131. package/dist/esm/shared/page-configs/Config.d.ts +3 -1
  132. package/dist/esm/shared/page-configs/PageConfig.d.ts +12 -4
  133. package/dist/esm/shared/page-configs/getPageConfigUserFriendly.d.ts +24 -16
  134. package/dist/esm/shared/page-configs/getPageConfigUserFriendly.js +44 -12
  135. package/dist/esm/shared/page-configs/serialize/PageConfigSerialized.d.ts +3 -2
  136. package/dist/esm/shared/page-configs/serialize/parsePageConfigs.js +2 -8
  137. package/dist/esm/shared/page-configs/serialize/serializeConfigValues.d.ts +2 -0
  138. package/dist/esm/shared/page-configs/serialize/serializeConfigValues.js +16 -6
  139. package/dist/esm/shared/route/executeGuardHook.d.ts +2 -2
  140. package/dist/esm/shared/route/loadPageRoutes.js +1 -1
  141. package/dist/esm/shared/types.d.ts +6 -0
  142. package/dist/esm/utils/PROJECT_VERSION.d.ts +1 -1
  143. package/dist/esm/utils/PROJECT_VERSION.js +1 -1
  144. package/dist/esm/utils/assert.js +1 -1
  145. package/dist/esm/utils/assertSetup.js +1 -1
  146. package/dist/esm/utils/assertSingleInstance.js +2 -2
  147. package/dist/esm/utils/findFile.js +1 -1
  148. package/dist/esm/utils/getGlobalObject.d.ts +3 -2
  149. package/dist/esm/utils/getGlobalObject.js +2 -6
  150. package/dist/esm/utils/parseUrl-extras.js +2 -2
  151. package/dist/esm/utils/parseUrl.d.ts +3 -4
  152. package/dist/esm/utils/parseUrl.js +5 -5
  153. package/dist/esm/utils/projectInfo.d.ts +1 -1
  154. package/package.json +16 -3
  155. package/universal-middleware.js +3 -0
  156. package/dist/cjs/node/runtime/renderPage/isConfigInvalid.js +0 -10
  157. package/dist/esm/node/runtime/renderPage/isConfigInvalid.d.ts +0 -6
  158. package/dist/esm/node/runtime/renderPage/isConfigInvalid.js +0 -8
@@ -17,7 +17,6 @@ import { preparePageContextForUserConsumptionServerSide } from './preparePageCon
17
17
  import { executeGuardHook } from '../../../shared/route/executeGuardHook.js';
18
18
  import pc from '@brillout/picocolors';
19
19
  import { isServerSideError } from '../../../shared/misc/isServerSideError.js';
20
- import { resolveBaseRuntime } from '../../shared/resolveBase.js';
21
20
  async function renderPageAlreadyRouted(pageContext) {
22
21
  // pageContext.pageId can either be the:
23
22
  // - ID of the page matching the routing, or the
@@ -112,14 +111,13 @@ async function getPageContextInitEnhanced(pageContextInit, globalContext, { ssr:
112
111
  isClientSideNavigation: false
113
112
  } } = {}) {
114
113
  assert(pageContextInit.urlOriginal);
115
- const { baseServer, baseAssets } = resolveBaseRuntime(globalContext);
116
114
  const pageContextInitEnhanced = {};
117
115
  objectAssign(pageContextInitEnhanced, pageContextInit);
118
116
  objectAssign(pageContextInitEnhanced, {
119
117
  _objectCreatedByVike: true,
120
118
  // The following is defined on `pageContext` because we can eventually make these non-global
121
- _baseServer: baseServer,
122
- _baseAssets: baseAssets,
119
+ _baseServer: globalContext.baseServer,
120
+ _baseAssets: globalContext.baseAssets,
123
121
  // TODO/now: add meta.default
124
122
  _includeAssetsImportedByServer: globalContext.config.includeAssetsImportedByServer ?? true,
125
123
  // TODO/soon: use GloablContext instead
@@ -1,11 +1,7 @@
1
1
  export { renderPage };
2
- export { renderPage_addWrapper };
2
+ export { renderPage_addAsyncHookwrapper };
3
3
  import { HttpResponse } from './renderPage/createHttpResponse.js';
4
4
  import type { PageContextServer } from '../../types/index.js';
5
- declare let renderPage_wrapper: <PageContext>(_httpRequestId: number, ret: () => Promise<PageContext>) => Promise<{
6
- pageContextReturn: Awaited<PageContext>;
7
- }>;
8
- declare const renderPage_addWrapper: (wrapper: typeof renderPage_wrapper) => void;
9
5
  declare function renderPage<PageContextUserAdded extends {}, PageContextInit extends {
10
6
  /** @deprecated */
11
7
  url?: string;
@@ -14,3 +10,7 @@ declare function renderPage<PageContextUserAdded extends {}, PageContextInit ext
14
10
  }>(pageContextInit: PageContextInit): Promise<PageContextInit & {
15
11
  httpResponse: HttpResponse;
16
12
  } & Partial<PageContextServer & PageContextUserAdded>>;
13
+ declare let asyncHookWrapper: <PageContext>(_httpRequestId: number, ret: () => Promise<PageContext>) => Promise<{
14
+ pageContextReturn: Awaited<PageContext>;
15
+ }>;
16
+ declare function renderPage_addAsyncHookwrapper(wrapper: typeof asyncHookWrapper): void;
@@ -1,63 +1,58 @@
1
1
  export { renderPage };
2
- export { renderPage_addWrapper };
2
+ export { renderPage_addAsyncHookwrapper };
3
3
  import { getPageContextInitEnhanced, renderPageAlreadyRouted } from './renderPage/renderPageAlreadyRouted.js';
4
4
  import { route } from '../../shared/route/index.js';
5
5
  import { assert, hasProp, objectAssign, isUrl, parseUrl, onSetupRuntime, assertWarning, getGlobalObject, checkType, assertUsage, normalizeUrlPathname, removeBaseServer, modifyUrlPathname, prependBase, removeUrlOrigin, setUrlOrigin, createUrlFromComponents, isUri, getUrlPretty } from './utils.js';
6
6
  import { assertNoInfiniteAbortLoop, getPageContextFromAllRewrites, isAbortError, logAbortErrorHandled } from '../../shared/route/abort.js';
7
7
  import { getGlobalContextInternal, initGlobalContext_renderPage } from './globalContext.js';
8
8
  import { handlePageContextRequestUrl } from './renderPage/handlePageContextRequestUrl.js';
9
- import { createHttpResponseFavicon404, createHttpResponseRedirect, createHttpResponsePageContextJson, createHttpResponseError } from './renderPage/createHttpResponse.js';
9
+ import { createHttpResponseFavicon404, createHttpResponseRedirect, createHttpResponsePageContextJson, createHttpResponseError, createHttpResponseBaseIsMissing } from './renderPage/createHttpResponse.js';
10
10
  import { logRuntimeError, logRuntimeInfo } from './renderPage/loggerRuntime.js';
11
11
  import { isNewError } from './renderPage/isNewError.js';
12
12
  import { assertArguments } from './renderPage/assertArguments.js';
13
13
  import { log404 } from './renderPage/log404/index.js';
14
- import { isConfigInvalid } from './renderPage/isConfigInvalid.js';
14
+ import { isVikeConfigInvalid } from './renderPage/isVikeConfigInvalid.js';
15
15
  import pc from '@brillout/picocolors';
16
16
  import { serializePageContextAbort, serializePageContextClientSide } from './html/serializePageContextClientSide.js';
17
17
  import { getErrorPageId } from '../../shared/error-page.js';
18
18
  import { handleErrorWithoutErrorPage } from './renderPage/handleErrorWithoutErrorPage.js';
19
19
  import { loadUserFilesServerSide } from './renderPage/loadUserFilesServerSide.js';
20
20
  import { resolveRedirects } from './renderPage/resolveRedirects.js';
21
- import { resolveBaseRuntime } from '../shared/resolveBase.js';
22
21
  const globalObject = getGlobalObject('runtime/renderPage.ts', {
23
22
  httpRequestsCount: 0
24
23
  });
25
- let renderPage_wrapper = async (_httpRequestId, ret) => ({
26
- pageContextReturn: await ret()
27
- });
28
- const renderPage_addWrapper = (wrapper) => {
29
- renderPage_wrapper = wrapper;
30
- };
31
24
  // `renderPage()` calls `renderPageNominal()` while ensuring that errors are `console.error(err)` instead of `throw err`, so that Vike never triggers a server shut down. (Throwing an error in an Express.js middleware shuts down the whole Express.js server.)
32
25
  async function renderPage(pageContextInit) {
33
26
  assertArguments(...arguments);
34
27
  assert(hasProp(pageContextInit, 'urlOriginal', 'string')); // assertUsage() already implemented at assertArguments()
35
- onSetupRuntime();
36
28
  assertIsUrl(pageContextInit.urlOriginal);
37
- const urlPathnameWithBase = parseUrl(pageContextInit.urlOriginal, '/').pathname;
38
- assertIsNotViteRequest(urlPathnameWithBase, pageContextInit.urlOriginal);
39
- if (urlPathnameWithBase.endsWith('/favicon.ico'))
40
- return getPageContextHttpResponseFavicon404(pageContextInit);
29
+ onSetupRuntime();
30
+ const pageContextInvalidRequest = renderInvalidRequest(pageContextInit);
31
+ if (pageContextInvalidRequest)
32
+ return pageContextInvalidRequest;
41
33
  const httpRequestId = getRequestId();
42
34
  const urlOriginalPretty = getUrlPretty(pageContextInit.urlOriginal);
43
35
  logHttpRequest(urlOriginalPretty, httpRequestId);
44
- const { pageContextReturn } = await renderPage_wrapper(httpRequestId, () => renderPageAndPrepare(pageContextInit, httpRequestId));
36
+ const { pageContextReturn } = await asyncHookWrapper(httpRequestId, () => renderPageAndPrepare(pageContextInit, httpRequestId));
45
37
  logHttpResponse(urlOriginalPretty, httpRequestId, pageContextReturn);
46
38
  checkType(pageContextReturn);
47
39
  assert(pageContextReturn.httpResponse);
48
40
  return pageContextReturn;
49
41
  }
42
+ // Fallback wrapper if node:async_hooks isn't available
43
+ let asyncHookWrapper = async (_httpRequestId, ret) => ({
44
+ pageContextReturn: await ret()
45
+ });
46
+ // Add node:async_hooks wrapper
47
+ function renderPage_addAsyncHookwrapper(wrapper) {
48
+ asyncHookWrapper = wrapper;
49
+ }
50
50
  async function renderPageAndPrepare(pageContextInit, httpRequestId) {
51
51
  // Invalid config
52
- const handleInvalidConfig = (err) => {
53
- logRuntimeInfo?.(pc.bold(pc.red('Error while loading a Vike config file, see error above.')), httpRequestId, 'error');
54
- const pageContextWithError = getPageContextHttpResponseError(err, pageContextInit, null);
55
- return pageContextWithError;
56
- };
57
- if (isConfigInvalid) {
52
+ if (isVikeConfigInvalid) {
58
53
  if (1 < 2 // Make TS happy
59
54
  ) {
60
- return handleInvalidConfig(isConfigInvalid.err);
55
+ return renderInvalidVikeConfig(isVikeConfigInvalid.err, pageContextInit, httpRequestId);
61
56
  }
62
57
  }
63
58
  // Prepare context
@@ -65,22 +60,29 @@ async function renderPageAndPrepare(pageContextInit, httpRequestId) {
65
60
  await initGlobalContext_renderPage();
66
61
  }
67
62
  catch (err) {
68
- // Errors are expected since assertUsage() is used in both initGlobalContext_renderPage() and getRenderContext().
69
- // initGlobalContext_renderPage() and getRenderContext() don't call any user hooks => err isn't thrown from user code.
63
+ // Errors are expected since assertUsage() is used in initGlobalContext_renderPage() such as:
64
+ // ```bash
65
+ // Re-build your app (you're using 1.2.3 but your app was built with 1.2.2)
66
+ // ```
67
+ // initGlobalContext_renderPage() doens't call any user hook => err isn't thrown from user code.
70
68
  assert(!isAbortError(err));
71
69
  logRuntimeError(err, httpRequestId);
72
70
  const pageContextWithError = getPageContextHttpResponseError(err, pageContextInit, null);
73
71
  return pageContextWithError;
74
72
  }
75
- if (isConfigInvalid) {
76
- return handleInvalidConfig(isConfigInvalid.err);
73
+ if (isVikeConfigInvalid) {
74
+ return renderInvalidVikeConfig(isVikeConfigInvalid.err, pageContextInit, httpRequestId);
77
75
  }
78
76
  else {
79
- // From now on, globalContext contains all the configuration data; getVikeConfig() isn't called anymore for this request
77
+ // `globalContext` now contains the entire Vike config and getVikeConfig() isn't called anymore for this request.
80
78
  }
81
79
  const globalContext = await getGlobalContextInternal();
82
80
  // Check Base URL
83
- await assertBaseUrl(pageContextInit, globalContext);
81
+ {
82
+ const pageContextHttpResponse = await checkBaseUrl(pageContextInit, globalContext);
83
+ if (pageContextHttpResponse)
84
+ return pageContextHttpResponse;
85
+ }
84
86
  // Normalize URL
85
87
  {
86
88
  const pageContextHttpResponse = await normalizeUrl(pageContextInit, globalContext, httpRequestId);
@@ -248,15 +250,6 @@ function getPageContextHttpResponseError(err, pageContextInit, pageContext) {
248
250
  });
249
251
  return pageContextWithError;
250
252
  }
251
- function getPageContextHttpResponseFavicon404(pageContextInit) {
252
- const pageContext = createPageContext(pageContextInit);
253
- const httpResponse = createHttpResponseFavicon404();
254
- objectAssign(pageContext, {
255
- httpResponse
256
- });
257
- checkType(pageContext);
258
- return pageContext;
259
- }
260
253
  function createPageContext(pageContextInit) {
261
254
  const pageContext = {
262
255
  _isPageContextObject: true
@@ -337,7 +330,6 @@ function assertIsNotViteRequest(urlPathname, urlOriginal) {
337
330
  assertUsage(false, `${pc.code('renderPage(pageContextInit)')} called with ${pc.code(`pageContextInit.urlOriginal===${JSON.stringify(urlOriginal)}`)} which is unexpected because the URL ${pc.bold(urlOriginal)} should have already been handled by the development middleware: make sure the ${pc.cyan('createDevMiddleware()')} middleware is executed *before* the ${pc.cyan('renderPage()')} middleware, see ${pc.underline('https://vike.dev/renderPage')}`);
338
331
  }
339
332
  async function normalizeUrl(pageContextInit, globalContext, httpRequestId) {
340
- const { baseServer } = resolveBaseRuntime(globalContext);
341
333
  const { trailingSlash, disableUrlNormalization } = globalContext.config;
342
334
  if (disableUrlNormalization)
343
335
  return null;
@@ -345,7 +337,7 @@ async function normalizeUrl(pageContextInit, globalContext, httpRequestId) {
345
337
  const { isPageContextRequest } = handlePageContextRequestUrl(urlOriginal);
346
338
  if (isPageContextRequest)
347
339
  return null;
348
- const urlNormalized = normalizeUrlPathname(urlOriginal, trailingSlash ?? false, baseServer);
340
+ const urlNormalized = normalizeUrlPathname(urlOriginal, trailingSlash ?? false, globalContext.baseServer);
349
341
  if (!urlNormalized)
350
342
  return null;
351
343
  logRuntimeInfo?.(`URL normalized from ${pc.cyan(urlOriginal)} to ${pc.cyan(urlNormalized)} (https://vike.dev/url-normalization)`, httpRequestId, 'info');
@@ -355,8 +347,7 @@ async function normalizeUrl(pageContextInit, globalContext, httpRequestId) {
355
347
  return pageContextHttpResponse;
356
348
  }
357
349
  async function getPermanentRedirect(pageContextInit, globalContext, httpRequestId) {
358
- const { baseServer } = resolveBaseRuntime(globalContext);
359
- const urlWithoutBase = removeBaseServer(pageContextInit.urlOriginal, baseServer);
350
+ const urlWithoutBase = removeBaseServer(pageContextInit.urlOriginal, globalContext.baseServer);
360
351
  let origin = null;
361
352
  let urlTargetExternal = null;
362
353
  let urlTarget = modifyUrlPathname(urlWithoutBase, (urlPathname) => {
@@ -387,9 +378,8 @@ async function getPermanentRedirect(pageContextInit, globalContext, httpRequestI
387
378
  }
388
379
  if (normalize(urlTarget) === normalize(urlWithoutBase))
389
380
  return null;
390
- const { baseServer } = resolveBaseRuntime(globalContext);
391
381
  if (!originChanged)
392
- urlTarget = prependBase(urlTarget, baseServer);
382
+ urlTarget = prependBase(urlTarget, globalContext.baseServer);
393
383
  assert(urlTarget !== pageContextInit.urlOriginal);
394
384
  }
395
385
  logRuntimeInfo?.(`Permanent redirection defined by config.redirects (https://vike.dev/redirects)`, httpRequestId, 'info');
@@ -452,10 +442,35 @@ pageContextNominalPageInit, httpRequestId, pageContextErrorPageInit, globalConte
452
442
  assert(pageContextAbort.abortStatusCode);
453
443
  return { pageContextAbort };
454
444
  }
455
- async function assertBaseUrl(pageContextInit, globalContext) {
456
- const { baseServer } = resolveBaseRuntime(globalContext);
445
+ async function checkBaseUrl(pageContextInit, globalContext) {
446
+ const { baseServer } = globalContext;
457
447
  const { urlOriginal } = pageContextInit;
458
- const { urlWithoutPageContextRequestSuffix } = handlePageContextRequestUrl(urlOriginal);
459
- const { hasBaseServer } = parseUrl(urlWithoutPageContextRequestSuffix, baseServer);
460
- assertUsage(hasBaseServer, `${pc.code('renderPage(pageContextInit)')} (https://vike.dev/renderPage) called with ${pc.code(`pageContextInit.urlOriginal===${JSON.stringify(urlOriginal)}`)} which doesn't start with Base URL ${pc.code(baseServer)} (https://vike.dev/base-url)`);
448
+ const { isBaseMissing } = parseUrl(urlOriginal, baseServer);
449
+ if (!isBaseMissing)
450
+ return;
451
+ const pageContext = createPageContext(pageContextInit);
452
+ const httpResponse = createHttpResponseBaseIsMissing(urlOriginal, baseServer);
453
+ objectAssign(pageContext, {
454
+ httpResponse,
455
+ isBaseMissing: true
456
+ });
457
+ checkType(pageContext);
458
+ return pageContext;
459
+ }
460
+ function renderInvalidRequest(pageContextInit) {
461
+ const urlPathnameWithBase = parseUrl(pageContextInit.urlOriginal, '/').pathname;
462
+ assertIsNotViteRequest(urlPathnameWithBase, pageContextInit.urlOriginal);
463
+ if (urlPathnameWithBase.endsWith('/favicon.ico')) {
464
+ const pageContext = createPageContext(pageContextInit);
465
+ const httpResponse = createHttpResponseFavicon404();
466
+ objectAssign(pageContext, { httpResponse });
467
+ checkType(pageContext);
468
+ return pageContext;
469
+ }
470
+ return null;
471
+ }
472
+ function renderInvalidVikeConfig(err, pageContextInit, httpRequestId) {
473
+ logRuntimeInfo?.(pc.bold(pc.red('Error while loading a Vike config file, see error above.')), httpRequestId, 'error');
474
+ const pageContextWithError = getPageContextHttpResponseError(err, pageContextInit, null);
475
+ return pageContextWithError;
461
476
  }
@@ -0,0 +1 @@
1
+ export default function universalVikeHandler(request: Request, context: Record<string, unknown>, runtime: Record<string, unknown>): Promise<Response>;
@@ -0,0 +1,11 @@
1
+ import { renderPage } from './index.js';
2
+ export default async function universalVikeHandler(request, context, runtime) {
3
+ const pageContextInit = { ...context, ...runtime, urlOriginal: request.url, headersOriginal: request.headers };
4
+ const pageContext = await renderPage(pageContextInit);
5
+ const response = pageContext.httpResponse;
6
+ const readable = response.getReadableWebStream();
7
+ return new Response(readable, {
8
+ status: response.statusCode,
9
+ headers: response.headers
10
+ });
11
+ }
@@ -1,15 +1,7 @@
1
1
  export { resolveBase };
2
- export { resolveBaseRuntime };
3
- export { resolveBaseFromResolvedConfig };
4
- import type { ResolvedConfig } from 'vite';
5
- import type { GlobalContext } from '../runtime/globalContext.js';
6
- declare function resolveBaseFromResolvedConfig(baseServer: string | null, baseAssets: string | null, config: ResolvedConfig): {
7
- baseServer: string;
8
- baseAssets: string;
9
- };
2
+ export type { BaseUrlsResolved };
10
3
  type BaseUrlsResolved = {
11
4
  baseServer: string;
12
5
  baseAssets: string;
13
6
  };
14
- declare function resolveBaseRuntime(globalContext: GlobalContext): BaseUrlsResolved;
15
7
  declare function resolveBase(baseViteOriginal: string | null, baseServerUnresolved: string | null, baseAssetsUnresolved: string | null): BaseUrlsResolved;
@@ -1,19 +1,6 @@
1
1
  export { resolveBase };
2
- export { resolveBaseRuntime };
3
- export { resolveBaseFromResolvedConfig };
4
2
  import { assert, assertUsage, isBaseServer, isBaseAssets } from './utils.js';
5
3
  import pc from '@brillout/picocolors';
6
- function resolveBaseFromResolvedConfig(baseServer, baseAssets, config) {
7
- let baseViteOriginal = config._baseViteOriginal;
8
- assert(baseViteOriginal === null || typeof baseViteOriginal == 'string');
9
- return resolveBase(baseViteOriginal, baseServer, baseAssets);
10
- }
11
- function resolveBaseRuntime(globalContext) {
12
- const baseViteOriginal = globalContext.viteConfigRuntime._baseViteOriginal;
13
- const baseServerUnresolved = globalContext.config.baseServer ?? null;
14
- const baseAssetsUnresolved = globalContext.config.baseAssets ?? null;
15
- return resolveBase(baseViteOriginal, baseServerUnresolved, baseAssetsUnresolved);
16
- }
17
4
  function resolveBase(baseViteOriginal, baseServerUnresolved, baseAssetsUnresolved) {
18
5
  if (baseViteOriginal === '/__UNSET__')
19
6
  baseViteOriginal = null;
@@ -1,14 +1,14 @@
1
1
  export { getPageConfigsRuntime };
2
2
  export { getAllPageIds };
3
3
  import type { PageFile } from './getPageFiles.js';
4
- import { type ConfigUserFriendly, type PageConfigsUserFriendly } from './page-configs/getPageConfigUserFriendly.js';
4
+ import { type PageConfigUserFriendly, type PageConfigsUserFriendly } from './page-configs/getPageConfigUserFriendly.js';
5
5
  import type { PageConfigGlobalRuntime, PageConfigRuntime } from './page-configs/PageConfig.js';
6
6
  declare function getPageConfigsRuntime(virtualFileExports: unknown): {
7
7
  pageFilesAll: PageFile[];
8
8
  allPageIds: string[];
9
9
  pageConfigs: PageConfigRuntime[];
10
10
  pageConfigGlobal: PageConfigGlobalRuntime;
11
- globalConfig: ConfigUserFriendly;
11
+ globalConfig: PageConfigUserFriendly;
12
12
  pageConfigsUserFriendly: PageConfigsUserFriendly;
13
13
  };
14
14
  declare function getAllPageIds(pageFilesAll: PageFile[], pageConfigs: PageConfigRuntime[]): string[];
@@ -1,21 +1,15 @@
1
1
  export { getPageConfigsRuntime };
2
2
  export { getAllPageIds };
3
3
  import { parseGlobResults } from './getPageFiles/parseGlobResults.js';
4
- import { getPageConfigUserFriendlyNew } from './page-configs/getPageConfigUserFriendly.js';
4
+ import { getPageConfigGlobalUserFriendly, getPageConfigUserFriendly } from './page-configs/getPageConfigUserFriendly.js';
5
5
  import { unique } from './utils.js';
6
6
  function getPageConfigsRuntime(virtualFileExports) {
7
7
  const { pageFilesAll, pageConfigs, pageConfigGlobal } = parseGlobResults(virtualFileExports);
8
8
  const allPageIds = getAllPageIds(pageFilesAll, pageConfigs);
9
9
  // TODO/now: re-use this call, instead of calling it twice
10
- const globalConfig = getPageConfigUserFriendlyNew(pageConfigGlobal);
11
- // TODO/now DEDUPE
10
+ const globalConfig = getPageConfigGlobalUserFriendly({ pageConfigGlobalValues: pageConfigGlobal.configValues });
12
11
  const pageConfigsUserFriendly = Object.fromEntries(pageConfigs.map((pageConfig) => {
13
- const configValues = { ...pageConfigGlobal.configValues, ...pageConfig.configValues };
14
- const page = {
15
- ...getPageConfigUserFriendlyNew({ configValues }),
16
- route: pageConfig.routeFilesystem?.routeString ?? null
17
- };
18
- return [pageConfig.pageId, page];
12
+ return getPageConfigUserFriendly(pageConfigGlobal.configValues, pageConfig, pageConfig.configValues);
19
13
  }));
20
14
  return { pageFilesAll, allPageIds, pageConfigs, pageConfigGlobal, globalConfig, pageConfigsUserFriendly };
21
15
  }
@@ -6,7 +6,7 @@ import { urlToFile } from '../utils/urlToFile.js';
6
6
  const pageContextJsonFileExtension = '.pageContext.json';
7
7
  // `/some-base-url/index.pageContext.json` instead of `/some-base-url.pageContext.json` in order to comply to common reverse proxy setups, see https://github.com/vikejs/vike/issues/443
8
8
  const doNotCreateExtraDirectory = false;
9
- // See node/renderPage/handlePageContextRequestUrl.ts
9
+ // See also node/renderPage/handlePageContextRequestUrl.ts
10
10
  function getPageContextRequestUrl(url) {
11
11
  const pageContextRequestUrl = urlToFile(url, pageContextJsonFileExtension, doNotCreateExtraDirectory);
12
12
  return pageContextRequestUrl;
@@ -37,26 +37,29 @@ function getUrlParsed(pageContext) {
37
37
  // 6. The value of pageContext.urlPathname is now '/login': the pathname of `pageContext.urlLogical`. (While pageContext.urlOriginal is still '/fr-FR/admin'.)
38
38
  // Reproduction: https://github.com/vikejs/vike/discussions/1436#discussioncomment-8142023
39
39
  // Determine logical URL
40
- // TODO/soon: revert https://github.com/vikejs/vike/issues/2138#issuecomment-2631713411
41
- const assertUrlResolved = (src) => assert(urlResolved && typeof urlResolved === 'string', { src, urlResolved });
40
+ const assertUrlResolved = (src) => assert(typeof urlResolved === 'string',
41
+ // TODO/eventually: remove debug logs, see:
42
+ // - https://github.com/vikejs/vike/issues/2138#issuecomment-2631713411
43
+ // - https://github.com/vikejs/vike/commit/5c7810f3080ab62536950f26e019bb2a3a517082
44
+ { src, urlResolved });
42
45
  let urlResolved;
43
- let baseToBeRemoved;
46
+ let isBaseToBeRemoved;
44
47
  if (pageContext.urlLogical) {
45
48
  // Set by onBeforeRoute()
46
49
  urlResolved = pageContext.urlLogical;
47
- baseToBeRemoved = false;
50
+ isBaseToBeRemoved = false;
48
51
  assertUrlResolved(1);
49
52
  }
50
53
  else if (pageContext._urlRewrite) {
51
54
  // Set by `throw render()`
52
55
  urlResolved = pageContext._urlRewrite;
53
- baseToBeRemoved = false;
56
+ isBaseToBeRemoved = false;
54
57
  assertUrlResolved(2);
55
58
  }
56
59
  else {
57
60
  // Set by renderPage()
58
61
  urlResolved = pageContext.urlOriginal;
59
- baseToBeRemoved = true;
62
+ isBaseToBeRemoved = true;
60
63
  assertUrlResolved(3);
61
64
  }
62
65
  assertUrlResolved(4);
@@ -69,7 +72,7 @@ function getUrlParsed(pageContext) {
69
72
  // - We assume there isn't any Base URL to the URLs set by the user at `throw render()` and onBeforeRoute()
70
73
  // - This makes sense because the Base URL is merely a setting: ideally the user should write code that doesn't know anything about it (so that the user can remove/add/change Base URL without having to modify any code).
71
74
  // - pageContext.urlOriginal is the URL of the HTTP request and thus contains the Base URL.
72
- const baseServer = !baseToBeRemoved ? '/' : pageContext._baseServer;
75
+ const baseServer = !isBaseToBeRemoved ? '/' : pageContext._baseServer;
73
76
  // Parse URL
74
77
  return parseUrl(urlResolved, baseServer);
75
78
  }
@@ -86,8 +89,8 @@ function urlGetter() {
86
89
  }
87
90
  function urlParsedGetter() {
88
91
  const {
89
- // remove hasBaseServer as it isn't part of UrlPublic
90
- hasBaseServer: _, ...urlParsed } = getUrlParsed(this);
92
+ // remove isBaseMissing as it isn't part of UrlPublic
93
+ isBaseMissing: _, ...urlParsed } = getUrlParsed(this);
91
94
  const hashIsAvailable = isBrowser();
92
95
  const warnHashNotAvailable = (prop) => {
93
96
  assertWarning(hashIsAvailable, `pageContext.urlParsed.${prop} isn't available on the server-side (HTTP requests don't include the URL hash)`, { onlyOnce: true, showStackTrace: true });
@@ -1,4 +1,4 @@
1
1
  export type { PageFile } from './getPageFiles/getPageFileObject.js';
2
- export type { ExportsAll, PageConfigUserFriendly } from './page-configs/getPageConfigUserFriendly.js';
2
+ export type { ExportsAll, PageConfigUserFriendlyOld } from './page-configs/getPageConfigUserFriendly.js';
3
3
  export { getPageFilesClientSide } from './getPageFiles/getAllPageIdFiles.js';
4
4
  export { getPageFilesServerSide } from './getPageFiles/getAllPageIdFiles.js';
@@ -9,7 +9,7 @@ export type { HookLoc };
9
9
  export type { HookTimeout };
10
10
  export type { HooksTimeoutProvidedByUser };
11
11
  export { getHookTimeoutDefault };
12
- import type { PageConfigUserFriendly } from '../getPageFiles.js';
12
+ import type { PageConfigUserFriendlyOld } from '../getPageFiles.js';
13
13
  import type { HookName, HookNamePage, HookNameGlobal } from '../page-configs/Config.js';
14
14
  import type { PageConfigGlobalRuntime, PageConfigRuntime } from '../page-configs/PageConfig.js';
15
15
  type Hook = HookLoc & {
@@ -26,10 +26,10 @@ type HookTimeout = {
26
26
  warning: number | false;
27
27
  };
28
28
  type HooksTimeoutProvidedByUser = false | Partial<Record<HookName, false | Partial<HookTimeout>>>;
29
- declare function getHook(pageContext: PageConfigUserFriendly, hookName: HookName): null | Hook;
29
+ declare function getHook(pageContext: PageConfigUserFriendlyOld, hookName: HookName): null | Hook;
30
30
  declare function getHookFromPageConfig(pageConfig: PageConfigRuntime, hookName: HookNamePage): null | Hook;
31
31
  declare function getHookFromPageConfigGlobal(pageConfigGlobal: PageConfigGlobalRuntime, hookName: HookNameGlobal): null | Hook;
32
- declare function assertHook<TPageContext extends PageConfigUserFriendly, THookName extends PropertyKey & HookName>(pageContext: TPageContext, hookName: THookName): asserts pageContext is TPageContext & {
32
+ declare function assertHook<TPageContext extends PageConfigUserFriendlyOld, THookName extends PropertyKey & HookName>(pageContext: TPageContext, hookName: THookName): asserts pageContext is TPageContext & {
33
33
  exports: Record<THookName, Function | undefined>;
34
34
  };
35
35
  declare function getHookTimeoutDefault(hookName: HookName): HookTimeout;
@@ -11,7 +11,7 @@ import { getHookFilePathToShowToUser } from '../page-configs/helpers.js';
11
11
  import { getConfigValueRuntime } from '../page-configs/getConfigValueRuntime.js';
12
12
  import { assert, assertUsage, checkType, isCallable, isObject } from '../utils.js';
13
13
  import pc from '@brillout/picocolors';
14
- const globalObject = getGlobalObject('getHook.ts', {});
14
+ const globalObject = getGlobalObject('hooks/getHook.ts', {});
15
15
  function getHook(pageContext, hookName) {
16
16
  if (!(hookName in pageContext.exports)) {
17
17
  return null;
@@ -32,6 +32,7 @@ export type { OnRenderHtmlAsync };
32
32
  export type { OnRenderHtmlSync };
33
33
  export type { RouteAsync };
34
34
  export type { RouteSync };
35
+ export type { Route };
35
36
  export type { KeepScrollPosition };
36
37
  import type { PrefetchSetting, PrefetchStaticAssets } from '../../client/client-routing-runtime/prefetch/PrefetchSetting.js';
37
38
  import type { ConfigDefinition } from '../../node/plugin/plugins/importUserCode/v1-design/getVikeConfig/configDefinitionsBuiltIn.js';
@@ -223,6 +224,7 @@ type RouteSync = (pageContext: PageContextServer | PageContextClient) => {
223
224
  routeParams?: Record<string, string>;
224
225
  precedence?: number;
225
226
  } | boolean;
227
+ type Route = string | RouteSync | RouteAsync;
226
228
  /** Whether the page scrolls to the top upon navigation.
227
229
  *
228
230
  * https://vike.dev/keepScrollPosition
@@ -239,7 +241,7 @@ type ConfigBuiltIn = {
239
241
  *
240
242
  * https://vike.dev/route
241
243
  */
242
- route?: string | RouteAsync | RouteSync | ImportString;
244
+ route?: Route | ImportString;
243
245
  /** Protect page(s), e.g. forbid unauthorized access.
244
246
  *
245
247
  * https://vike.dev/guard
@@ -1,6 +1,8 @@
1
1
  export type { PageConfigRuntime };
2
2
  export type { PageConfigRuntimeLoaded };
3
3
  export type { PageConfigBuildTime };
4
+ export type { PageConfigCommon };
5
+ export type { PageConfigRoute };
4
6
  export type { ConfigEnv };
5
7
  export type { ConfigEnvInternal };
6
8
  export type { PageConfigGlobalRuntime };
@@ -23,8 +25,13 @@ import type { ConfigDefinitions } from '../../node/plugin/plugins/importUserCode
23
25
  import type { PlusFile, PlusFilesByLocationId } from '../../node/plugin/plugins/importUserCode/v1-design/getVikeConfig/getPlusFilesAll.js';
24
26
  type PageConfigCommon = {
25
27
  pageId: string;
26
- isErrorPage?: true;
27
- routeFilesystem?: {
28
+ } & PageConfigRoute;
29
+ type PageConfigRoute = {
30
+ isErrorPage: true;
31
+ routeFilesystem?: undefined;
32
+ } | {
33
+ isErrorPage?: undefined;
34
+ routeFilesystem: {
28
35
  routeString: string;
29
36
  definedBy: string;
30
37
  };
@@ -87,10 +94,11 @@ type ConfigValueSource = {
87
94
  locationId: LocationId;
88
95
  isOverriden: boolean;
89
96
  /** Wether the config value is loaded at runtime, for example config.Page or config.onBeforeRender */
90
- valueIsImportedAtRuntime: boolean;
97
+ valueIsLoadedWithImport: boolean;
91
98
  /** Whether the config value is a file path, for example config.client */
92
99
  valueIsFilePath?: true;
93
- valueIsDefinedByPlusFile: boolean;
100
+ /** Whether the config value is defined by a +{configName}.js file */
101
+ valueIsDefinedByPlusValueFile: boolean;
94
102
  } & ({
95
103
  valueIsLoaded: false;
96
104
  } | {
@@ -1,8 +1,9 @@
1
- export { getPageConfigUserFriendlyOld };
2
- export { getPageConfigUserFriendlyNew };
3
- export type { ConfigUserFriendly };
4
- export type { PageConfigUserFriendly };
1
+ export { getPageConfigUserFriendly };
2
+ export { getPageConfigUserFriendly_oldDesign };
3
+ export { getPageConfigGlobalUserFriendly };
5
4
  export type { PageConfigsUserFriendly };
5
+ export type { PageConfigUserFriendly };
6
+ export type { PageConfigUserFriendlyOld };
6
7
  export type { Source };
7
8
  export type { Sources };
8
9
  export type { From };
@@ -10,9 +11,10 @@ export type { ExportsAll };
10
11
  export type { ConfigEntries };
11
12
  import type { FileType } from '../getPageFiles/fileTypes.js';
12
13
  import type { PageFile } from '../getPageFiles/getPageFileObject.js';
13
- import type { ConfigValues, PageConfigGlobalRuntime, PageConfigRuntimeLoaded } from './PageConfig.js';
14
+ import type { ConfigValues, PageConfigBuildTime, PageConfigGlobalRuntime, PageConfigRuntime, PageConfigRuntimeLoaded } from './PageConfig.js';
14
15
  import { type ConfigDefinedAtOptional } from './getConfigDefinedAt.js';
15
16
  import type { ConfigResolved } from './Config/PageContextConfig.js';
17
+ import type { Route } from './Config.js';
16
18
  type ExportsAll = Record<string, {
17
19
  exportValue: unknown;
18
20
  exportSource: string;
@@ -33,7 +35,7 @@ type ConfigEntries = Record<string, {
33
35
  configDefinedAt: ConfigDefinedAtOptional;
34
36
  configDefinedByFile: string | null;
35
37
  }[]>;
36
- type PageConfigUserFriendly = {
38
+ type PageConfigUserFriendlyOld = {
37
39
  config: ConfigResolved;
38
40
  source: Source;
39
41
  sources: Sources;
@@ -74,18 +76,24 @@ type SourceConfigsComputed = {
74
76
  type: 'configsComputed';
75
77
  value: unknown;
76
78
  };
77
- type PageConfigsUserFriendly = Record<string, // pageId
78
- // pageId
79
- ConfigUserFriendly & {
80
- route: string | null;
81
- }>;
82
- type ConfigUserFriendly = {
79
+ type PageConfigUserFriendly = {
83
80
  config: ConfigResolved;
84
81
  _source: Source;
85
82
  _sources: Sources;
86
83
  _from: From;
87
84
  };
88
- declare function getPageConfigUserFriendlyNew(pageConfig: {
89
- configValues: ConfigValues;
90
- }): ConfigUserFriendly;
91
- declare function getPageConfigUserFriendlyOld(pageFiles: PageFile[], pageConfig: PageConfigRuntimeLoaded | null, pageConfigGlobal: PageConfigGlobalRuntime): PageConfigUserFriendly;
85
+ type PageConfigsUserFriendly = Record<string, // pageId
86
+ PageConfigUserFriendlyWithRoute>;
87
+ type WithRoute = {
88
+ route: Route;
89
+ isErrorPage?: undefined;
90
+ } | {
91
+ route?: undefined;
92
+ isErrorPage: true;
93
+ };
94
+ type PageConfigUserFriendlyWithRoute = PageConfigUserFriendly & WithRoute;
95
+ declare function getPageConfigUserFriendly(pageConfigGlobalValues: ConfigValues, pageConfig: PageConfigRuntime | PageConfigBuildTime, pageConfigValues: ConfigValues): [string, PageConfigUserFriendlyWithRoute];
96
+ declare function getPageConfigGlobalUserFriendly({ pageConfigGlobalValues }: {
97
+ pageConfigGlobalValues: ConfigValues;
98
+ }): PageConfigUserFriendly;
99
+ declare function getPageConfigUserFriendly_oldDesign(pageFiles: PageFile[], pageConfig: PageConfigRuntimeLoaded | null, pageConfigGlobal: PageConfigGlobalRuntime): PageConfigUserFriendlyOld;