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.
- package/dist/cjs/client/shared/getPageContextProxyForUser.js +1 -1
- package/dist/cjs/node/api/prepareViteApiCall.js +1 -1
- package/dist/cjs/node/plugin/index.js +6 -4
- package/dist/cjs/node/plugin/plugins/baseUrls.js +9 -2
- package/dist/cjs/node/plugin/plugins/buildApp.js +14 -7
- package/dist/cjs/node/plugin/plugins/buildConfig/fixServerAssets.js +49 -19
- package/dist/cjs/node/plugin/plugins/buildConfig.js +6 -1
- package/dist/cjs/node/plugin/plugins/commonConfig.js +17 -1
- package/dist/cjs/node/plugin/plugins/devConfig/determineOptimizeDeps.js +1 -1
- package/dist/cjs/node/plugin/plugins/envVars.js +2 -18
- package/dist/cjs/node/plugin/plugins/extractAssetsPlugin.js +2 -2
- package/dist/cjs/node/plugin/plugins/extractExportNamesPlugin.js +1 -1
- package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/assertExtensions.js +4 -4
- package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/configDefinitionsBuiltIn.js +6 -1
- package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/crawlPlusFiles.js +11 -10
- package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/transpileAndExecuteFile.js +8 -5
- package/dist/cjs/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.js +36 -71
- package/dist/cjs/node/plugin/shared/findPageFiles.js +3 -3
- package/dist/cjs/node/plugin/shared/getHttpRequestAsyncStore.js +1 -1
- package/dist/cjs/node/plugin/shared/viteIsSSR.js +19 -10
- package/dist/cjs/node/prerender/runPrerender.js +3 -1
- package/dist/cjs/node/runtime/globalContext.js +19 -8
- package/dist/cjs/node/runtime/renderPage/createHttpResponse/assertNoInfiniteHttpRedirect.js +1 -1
- package/dist/cjs/node/runtime/renderPage/createHttpResponse.js +24 -0
- package/dist/cjs/node/runtime/renderPage/getPageAssets.js +1 -1
- package/dist/cjs/node/runtime/renderPage/handlePageContextRequestUrl.js +1 -1
- package/dist/cjs/node/runtime/renderPage/isNewError.js +1 -1
- package/dist/cjs/node/runtime/renderPage/isVikeConfigInvalid.js +10 -0
- package/dist/cjs/node/runtime/renderPage/loadUserFilesServerSide.js +1 -1
- package/dist/cjs/node/runtime/renderPage/logErrorHint.js +7 -1
- package/dist/cjs/node/runtime/renderPage/renderPageAlreadyRouted.js +2 -4
- package/dist/cjs/node/runtime/renderPage.js +63 -49
- package/dist/cjs/node/runtime/universal-middleware.js +14 -0
- package/dist/cjs/node/shared/resolveBase.js +0 -13
- package/dist/cjs/shared/getPageConfigsRuntime.js +2 -8
- package/dist/cjs/shared/getPageContextRequestUrl.js +1 -1
- package/dist/cjs/shared/getPageContextUrlComputed.js +12 -9
- package/dist/cjs/shared/hooks/getHook.js +1 -1
- package/dist/cjs/shared/page-configs/getPageConfigUserFriendly.js +44 -12
- package/dist/cjs/shared/page-configs/serialize/parsePageConfigs.js +2 -8
- package/dist/cjs/shared/page-configs/serialize/serializeConfigValues.js +16 -6
- package/dist/cjs/shared/route/loadPageRoutes.js +1 -1
- package/dist/cjs/utils/PROJECT_VERSION.js +1 -1
- package/dist/cjs/utils/assert.js +1 -1
- package/dist/cjs/utils/assertSetup.js +1 -1
- package/dist/cjs/utils/assertSingleInstance.js +2 -2
- package/dist/cjs/utils/findFile.js +1 -1
- package/dist/cjs/utils/getGlobalObject.js +2 -6
- package/dist/cjs/utils/parseUrl-extras.js +2 -2
- package/dist/cjs/utils/parseUrl.js +5 -5
- package/dist/esm/client/client-routing-runtime/getPageContextCurrent.d.ts +2 -2
- package/dist/esm/client/client-routing-runtime/getPageContextCurrent.js +1 -1
- package/dist/esm/client/client-routing-runtime/getPageContextFromHooks.d.ts +4 -4
- package/dist/esm/client/client-routing-runtime/getPageContextFromHooks.js +1 -1
- package/dist/esm/client/client-routing-runtime/history.js +1 -1
- package/dist/esm/client/client-routing-runtime/index.d.ts +1 -0
- package/dist/esm/client/client-routing-runtime/index.js +1 -0
- package/dist/esm/client/client-routing-runtime/prefetch/getPrefetchSettings.d.ts +2 -2
- package/dist/esm/client/client-routing-runtime/prefetch.d.ts +2 -2
- package/dist/esm/client/client-routing-runtime/prefetch.js +3 -3
- package/dist/esm/client/client-routing-runtime/renderPageClientSide.d.ts +8 -0
- package/dist/esm/client/client-routing-runtime/renderPageClientSide.js +12 -3
- package/dist/esm/client/client-routing-runtime/scrollRestoration.js +1 -1
- package/dist/esm/client/client-routing-runtime/skipLink.js +2 -2
- package/dist/esm/client/server-routing-runtime/getPageContext.d.ts +1 -1
- package/dist/esm/client/shared/executeOnRenderClientHook.d.ts +2 -2
- package/dist/esm/client/shared/getPageContextProxyForUser.js +1 -1
- package/dist/esm/client/shared/loadUserFilesClientSide.d.ts +2 -2
- package/dist/esm/client/shared/loadUserFilesClientSide.js +2 -2
- package/dist/esm/client/shared/preparePageContextForUserConsumptionClientSide.d.ts +2 -2
- package/dist/esm/node/api/prepareViteApiCall.js +1 -1
- package/dist/esm/node/plugin/index.d.ts +6 -2
- package/dist/esm/node/plugin/index.js +2 -1
- package/dist/esm/node/plugin/plugins/baseUrls.js +9 -2
- package/dist/esm/node/plugin/plugins/buildApp.js +14 -7
- package/dist/esm/node/plugin/plugins/buildConfig/fixServerAssets.js +49 -19
- package/dist/esm/node/plugin/plugins/buildConfig.js +6 -1
- package/dist/esm/node/plugin/plugins/commonConfig.d.ts +14 -6
- package/dist/esm/node/plugin/plugins/commonConfig.js +17 -1
- package/dist/esm/node/plugin/plugins/devConfig/determineOptimizeDeps.js +1 -1
- package/dist/esm/node/plugin/plugins/envVars.js +2 -18
- package/dist/esm/node/plugin/plugins/extractAssetsPlugin.js +3 -3
- package/dist/esm/node/plugin/plugins/extractExportNamesPlugin.js +1 -1
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/assertExtensions.js +4 -4
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/configDefinitionsBuiltIn.js +6 -1
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/crawlPlusFiles.js +10 -9
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig/transpileAndExecuteFile.js +8 -5
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.d.ts +5 -5
- package/dist/esm/node/plugin/plugins/importUserCode/v1-design/getVikeConfig.js +38 -73
- package/dist/esm/node/plugin/shared/findPageFiles.js +3 -3
- package/dist/esm/node/plugin/shared/getHttpRequestAsyncStore.js +2 -2
- package/dist/esm/node/plugin/shared/viteIsSSR.d.ts +7 -4
- package/dist/esm/node/plugin/shared/viteIsSSR.js +20 -11
- package/dist/esm/node/prerender/runPrerender.js +3 -1
- package/dist/esm/node/runtime/globalContext.d.ts +9 -8
- package/dist/esm/node/runtime/globalContext.js +19 -8
- package/dist/esm/node/runtime/html/injectAssets/getViteDevScript.d.ts +2 -2
- package/dist/esm/node/runtime/html/injectAssets.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/analyzePage.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/createHttpResponse/assertNoInfiniteHttpRedirect.js +1 -1
- package/dist/esm/node/runtime/renderPage/createHttpResponse.d.ts +2 -0
- package/dist/esm/node/runtime/renderPage/createHttpResponse.js +24 -0
- package/dist/esm/node/runtime/renderPage/executeOnBeforeRenderAndDataHooks.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/getPageAssets.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/getPageAssets.js +1 -1
- package/dist/esm/node/runtime/renderPage/handleErrorWithoutErrorPage.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/handlePageContextRequestUrl.js +1 -1
- package/dist/esm/node/runtime/renderPage/isNewError.js +1 -1
- package/dist/esm/node/runtime/renderPage/isVikeConfigInvalid.d.ts +6 -0
- package/dist/esm/node/runtime/renderPage/isVikeConfigInvalid.js +8 -0
- package/dist/esm/node/runtime/renderPage/loadUserFilesServerSide.d.ts +3 -3
- package/dist/esm/node/runtime/renderPage/loadUserFilesServerSide.js +2 -2
- package/dist/esm/node/runtime/renderPage/log404/index.d.ts +2 -2
- package/dist/esm/node/runtime/renderPage/logErrorHint.js +7 -1
- package/dist/esm/node/runtime/renderPage/preparePageContextForUserConsumptionServerSide.d.ts +4 -4
- package/dist/esm/node/runtime/renderPage/renderPageAlreadyRouted.d.ts +12 -12
- package/dist/esm/node/runtime/renderPage/renderPageAlreadyRouted.js +2 -4
- package/dist/esm/node/runtime/renderPage.d.ts +5 -5
- package/dist/esm/node/runtime/renderPage.js +64 -49
- package/dist/esm/node/runtime/universal-middleware.d.ts +1 -0
- package/dist/esm/node/runtime/universal-middleware.js +11 -0
- package/dist/esm/node/shared/resolveBase.d.ts +1 -9
- package/dist/esm/node/shared/resolveBase.js +0 -13
- package/dist/esm/shared/getPageConfigsRuntime.d.ts +2 -2
- package/dist/esm/shared/getPageConfigsRuntime.js +3 -9
- package/dist/esm/shared/getPageContextRequestUrl.js +1 -1
- package/dist/esm/shared/getPageContextUrlComputed.js +12 -9
- package/dist/esm/shared/getPageFiles.d.ts +1 -1
- package/dist/esm/shared/hooks/getHook.d.ts +3 -3
- package/dist/esm/shared/hooks/getHook.js +1 -1
- package/dist/esm/shared/page-configs/Config.d.ts +3 -1
- package/dist/esm/shared/page-configs/PageConfig.d.ts +12 -4
- package/dist/esm/shared/page-configs/getPageConfigUserFriendly.d.ts +24 -16
- package/dist/esm/shared/page-configs/getPageConfigUserFriendly.js +44 -12
- package/dist/esm/shared/page-configs/serialize/PageConfigSerialized.d.ts +3 -2
- package/dist/esm/shared/page-configs/serialize/parsePageConfigs.js +2 -8
- package/dist/esm/shared/page-configs/serialize/serializeConfigValues.d.ts +2 -0
- package/dist/esm/shared/page-configs/serialize/serializeConfigValues.js +16 -6
- package/dist/esm/shared/route/executeGuardHook.d.ts +2 -2
- package/dist/esm/shared/route/loadPageRoutes.js +1 -1
- package/dist/esm/shared/types.d.ts +6 -0
- package/dist/esm/utils/PROJECT_VERSION.d.ts +1 -1
- package/dist/esm/utils/PROJECT_VERSION.js +1 -1
- package/dist/esm/utils/assert.js +1 -1
- package/dist/esm/utils/assertSetup.js +1 -1
- package/dist/esm/utils/assertSingleInstance.js +2 -2
- package/dist/esm/utils/findFile.js +1 -1
- package/dist/esm/utils/getGlobalObject.d.ts +3 -2
- package/dist/esm/utils/getGlobalObject.js +2 -6
- package/dist/esm/utils/parseUrl-extras.js +2 -2
- package/dist/esm/utils/parseUrl.d.ts +3 -4
- package/dist/esm/utils/parseUrl.js +5 -5
- package/dist/esm/utils/projectInfo.d.ts +1 -1
- package/package.json +16 -3
- package/universal-middleware.js +3 -0
- package/dist/cjs/node/runtime/renderPage/isConfigInvalid.js +0 -10
- package/dist/esm/node/runtime/renderPage/isConfigInvalid.d.ts +0 -6
- 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 {
|
|
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 {
|
|
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 {
|
|
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
|
-
|
|
38
|
-
|
|
39
|
-
if (
|
|
40
|
-
return
|
|
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
|
|
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
|
-
|
|
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
|
|
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
|
|
69
|
-
//
|
|
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 (
|
|
76
|
-
return
|
|
73
|
+
if (isVikeConfigInvalid) {
|
|
74
|
+
return renderInvalidVikeConfig(isVikeConfigInvalid.err, pageContextInit, httpRequestId);
|
|
77
75
|
}
|
|
78
76
|
else {
|
|
79
|
-
//
|
|
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
|
-
|
|
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
|
|
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
|
|
456
|
-
const { baseServer } =
|
|
445
|
+
async function checkBaseUrl(pageContextInit, globalContext) {
|
|
446
|
+
const { baseServer } = globalContext;
|
|
457
447
|
const { urlOriginal } = pageContextInit;
|
|
458
|
-
const {
|
|
459
|
-
|
|
460
|
-
|
|
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 {
|
|
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
|
|
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:
|
|
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 {
|
|
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 =
|
|
11
|
-
// TODO/now DEDUPE
|
|
10
|
+
const globalConfig = getPageConfigGlobalUserFriendly({ pageConfigGlobalValues: pageConfigGlobal.configValues });
|
|
12
11
|
const pageConfigsUserFriendly = Object.fromEntries(pageConfigs.map((pageConfig) => {
|
|
13
|
-
|
|
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
|
-
|
|
41
|
-
|
|
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
|
|
46
|
+
let isBaseToBeRemoved;
|
|
44
47
|
if (pageContext.urlLogical) {
|
|
45
48
|
// Set by onBeforeRoute()
|
|
46
49
|
urlResolved = pageContext.urlLogical;
|
|
47
|
-
|
|
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
|
-
|
|
56
|
+
isBaseToBeRemoved = false;
|
|
54
57
|
assertUrlResolved(2);
|
|
55
58
|
}
|
|
56
59
|
else {
|
|
57
60
|
// Set by renderPage()
|
|
58
61
|
urlResolved = pageContext.urlOriginal;
|
|
59
|
-
|
|
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 = !
|
|
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
|
|
90
|
-
|
|
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,
|
|
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 {
|
|
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:
|
|
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
|
|
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?:
|
|
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
|
-
|
|
27
|
-
|
|
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
|
-
|
|
97
|
+
valueIsLoadedWithImport: boolean;
|
|
91
98
|
/** Whether the config value is a file path, for example config.client */
|
|
92
99
|
valueIsFilePath?: true;
|
|
93
|
-
|
|
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 {
|
|
2
|
-
export {
|
|
3
|
-
export
|
|
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
|
|
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
|
|
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
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
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;
|