eddev 2.0.0-beta.2 → 2.0.0-beta.200
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/css/editor-styles.css +4 -0
- package/dist/app/entry/HydrationOverlay.d.ts +2 -0
- package/dist/app/entry/HydrationOverlay.d.ts.map +1 -0
- package/dist/app/entry/HydrationOverlay.js +2 -0
- package/dist/app/entry/MetaTags.d.ts +8 -0
- package/dist/app/entry/MetaTags.d.ts.map +1 -0
- package/dist/app/entry/MetaTags.js +30 -0
- package/dist/app/entry/boot-admin.d.ts +2 -0
- package/dist/app/entry/boot-admin.d.ts.map +1 -0
- package/dist/app/entry/boot-admin.js +12 -0
- package/dist/app/entry/hydration-script.d.ts +2 -0
- package/dist/app/entry/hydration-script.d.ts.map +1 -0
- package/dist/app/entry/hydration-script.js +18 -0
- package/dist/app/entry/spa-root.d.ts +2 -0
- package/dist/app/entry/spa-root.d.ts.map +1 -0
- package/dist/app/entry/spa-root.js +7 -0
- package/dist/app/entry/ssr-root-client.d.ts +7 -0
- package/dist/app/entry/ssr-root-client.d.ts.map +1 -0
- package/dist/app/entry/ssr-root-client.js +21 -0
- package/dist/app/entry/ssr-root.d.ts +11 -0
- package/dist/app/entry/ssr-root.d.ts.map +1 -0
- package/dist/app/entry/ssr-root.js +22 -0
- package/dist/app/lib/admin/defineField.d.ts +1 -0
- package/dist/app/lib/admin/defineField.d.ts.map +1 -0
- package/dist/app/lib/admin/defineWidget.d.ts +1 -0
- package/dist/app/lib/admin/defineWidget.d.ts.map +1 -0
- package/dist/app/lib/admin/index.d.ts +3 -2
- package/dist/app/lib/admin/index.d.ts.map +1 -0
- package/dist/app/lib/admin/index.js +2 -2
- package/dist/app/lib/admin/installFieldTypes.d.ts +1 -0
- package/dist/app/lib/admin/installFieldTypes.d.ts.map +1 -0
- package/dist/app/lib/admin/installFieldTypes.js +3 -1
- package/dist/app/lib/admin/runWidgets.d.ts +1 -0
- package/dist/app/lib/admin/runWidgets.d.ts.map +1 -0
- package/dist/app/lib/admin/runWidgets.js +8 -3
- package/dist/app/lib/blocks/ContentBlocks.d.ts +7 -4
- package/dist/app/lib/blocks/ContentBlocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/ContentBlocks.js +19 -6
- package/dist/app/lib/blocks/EditableText.d.ts +31 -6
- package/dist/app/lib/blocks/EditableText.d.ts.map +1 -0
- package/dist/app/lib/blocks/EditableText.js +36 -7
- package/dist/app/lib/blocks/InnerBlocks.d.ts +23 -8
- package/dist/app/lib/blocks/InnerBlocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/InnerBlocks.js +76 -28
- package/dist/app/lib/blocks/SlotBlocks.d.ts +8 -0
- package/dist/app/lib/blocks/SlotBlocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/SlotBlocks.js +46 -0
- package/dist/app/lib/blocks/block-utils.d.ts +3 -2
- package/dist/app/lib/blocks/block-utils.d.ts.map +1 -0
- package/dist/app/lib/blocks/block-utils.js +4 -2
- package/dist/app/lib/blocks/builtin-blocks.d.ts +2 -0
- package/dist/app/lib/blocks/builtin-blocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/builtin-blocks.js +55 -0
- package/dist/app/lib/blocks/defineBlock.d.ts +4 -0
- package/dist/app/lib/blocks/defineBlock.d.ts.map +1 -0
- package/dist/app/lib/blocks/defineBlock.js +9 -0
- package/dist/app/lib/blocks/editor/EditorHighlights.d.ts +8 -0
- package/dist/app/lib/blocks/editor/EditorHighlights.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/EditorHighlights.js +164 -0
- package/dist/app/lib/blocks/editor/EditorSupport.d.ts +1 -0
- package/dist/app/lib/blocks/editor/EditorSupport.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/EditorSupport.js +19 -12
- package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.d.ts +1 -0
- package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/block-templates.d.ts +8 -1
- package/dist/app/lib/blocks/editor/block-templates.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/block-templates.js +71 -2
- package/dist/app/lib/blocks/editor/blocks-by-tag.d.ts +1 -0
- package/dist/app/lib/blocks/editor/blocks-by-tag.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/controls.d.ts +1 -0
- package/dist/app/lib/blocks/editor/controls.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/create-block.d.ts +10 -0
- package/dist/app/lib/blocks/editor/create-block.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/create-block.js +13 -0
- package/dist/app/lib/blocks/editor/editor-config.d.ts +78 -9
- package/dist/app/lib/blocks/editor/editor-config.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/editor-config.js +29 -62
- package/dist/app/lib/blocks/editor/installGutenbergHooks.d.ts +4 -0
- package/dist/app/lib/blocks/editor/installGutenbergHooks.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/installGutenbergHooks.js +130 -25
- package/dist/app/lib/blocks/editor/root-blocks.d.ts +7 -0
- package/dist/app/lib/blocks/editor/root-blocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/root-blocks.js +30 -0
- package/dist/app/lib/blocks/editor/usePostEditor.d.ts +13 -2
- package/dist/app/lib/blocks/editor/usePostEditor.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/usePostEditor.js +28 -13
- package/dist/app/lib/blocks/index.d.ts +12 -9
- package/dist/app/lib/blocks/index.d.ts.map +1 -0
- package/dist/app/lib/blocks/index.js +11 -9
- package/dist/app/lib/blocks/inline-editing.d.ts +11 -1
- package/dist/app/lib/blocks/inline-editing.d.ts.map +1 -0
- package/dist/app/lib/blocks/inline-editing.js +15 -5
- package/dist/app/lib/devtools/components/BreakpointIndicator.d.ts +1 -0
- package/dist/app/lib/devtools/components/BreakpointIndicator.d.ts.map +1 -0
- package/dist/app/lib/devtools/components/BreakpointIndicator.js +7 -5
- package/dist/app/lib/devtools/components/DevUI.d.ts +1 -0
- package/dist/app/lib/devtools/components/DevUI.d.ts.map +1 -0
- package/dist/app/lib/devtools/components/DevUI.js +4 -3
- package/dist/app/lib/devtools/components/GridIndicator.d.ts +2 -0
- package/dist/app/lib/devtools/components/GridIndicator.d.ts.map +1 -0
- package/dist/app/lib/devtools/components/GridIndicator.js +29 -0
- package/dist/app/lib/devtools/dev-tools-store.d.ts +10 -0
- package/dist/app/lib/devtools/dev-tools-store.d.ts.map +1 -0
- package/dist/app/lib/devtools/dev-tools-store.js +8 -0
- package/dist/app/lib/devtools/hooks/usePersistState.d.ts +2 -1
- package/dist/app/lib/devtools/hooks/usePersistState.d.ts.map +1 -0
- package/dist/app/lib/devtools/hooks/usePersistState.js +11 -2
- package/dist/app/lib/devtools/hooks/useTailwind.d.ts +2311 -1267
- package/dist/app/lib/devtools/hooks/useTailwind.d.ts.map +1 -0
- package/dist/app/lib/devtools/hooks/useTailwind.js +6 -3
- package/dist/app/lib/devtools/index.d.ts +2 -0
- package/dist/app/lib/devtools/index.d.ts.map +1 -0
- package/dist/app/lib/devtools/index.js +1 -1
- package/dist/app/lib/devtools/loader.d.ts +1 -0
- package/dist/app/lib/devtools/loader.d.ts.map +1 -0
- package/dist/app/lib/devtools/loader.js +8 -7
- package/dist/app/lib/devtools/tailwind.config.d.ts +1 -0
- package/dist/app/lib/devtools/tailwind.config.d.ts.map +1 -0
- package/dist/app/lib/devtools/useQueryDebug.d.ts +8 -1
- package/dist/app/lib/devtools/useQueryDebug.d.ts.map +1 -0
- package/dist/app/lib/devtools/useQueryDebug.js +5 -8
- package/dist/app/lib/dynamic/dynamic.d.ts +2 -1
- package/dist/app/lib/dynamic/dynamic.d.ts.map +1 -0
- package/dist/app/lib/dynamic/dynamic.js +5 -1
- package/dist/app/lib/dynamic/index.d.ts +2 -1
- package/dist/app/lib/dynamic/index.d.ts.map +1 -0
- package/dist/app/lib/dynamic/index.js +1 -1
- package/dist/app/lib/hooks/index.d.ts +5 -5
- package/dist/app/lib/hooks/index.d.ts.map +1 -0
- package/dist/app/lib/hooks/index.js +4 -5
- package/dist/app/lib/hooks/{queryUtils.d.ts → query-hooks.d.ts} +46 -4
- package/dist/app/lib/hooks/query-hooks.d.ts.map +1 -0
- package/dist/app/lib/hooks/{queryUtils.js → query-hooks.js} +99 -40
- package/dist/app/lib/hooks/useAppData.d.ts +1 -0
- package/dist/app/lib/hooks/useAppData.d.ts.map +1 -0
- package/dist/app/lib/hooks/useAppData.js +12 -1
- package/dist/app/lib/hooks/useRPC.d.ts +1 -4
- package/dist/app/lib/hooks/useRPC.d.ts.map +1 -0
- package/dist/app/lib/hooks/useRPC.js +0 -8
- package/dist/app/lib/integrations/gravityforms/index.d.ts +3 -0
- package/dist/app/lib/integrations/gravityforms/index.d.ts.map +1 -0
- package/dist/app/lib/integrations/gravityforms/index.js +2 -0
- package/dist/app/lib/integrations/gravityforms/types.d.ts +145 -0
- package/dist/app/lib/integrations/gravityforms/types.d.ts.map +1 -0
- package/dist/app/lib/integrations/gravityforms/types.js +1 -0
- package/dist/app/lib/integrations/gravityforms/useGravityForm.d.ts +31 -0
- package/dist/app/lib/integrations/gravityforms/useGravityForm.d.ts.map +1 -0
- package/dist/app/lib/integrations/gravityforms/useGravityForm.js +295 -0
- package/dist/app/lib/internal/finalize-rpc.d.ts +18 -0
- package/dist/app/lib/internal/finalize-rpc.d.ts.map +1 -0
- package/dist/app/lib/internal/finalize-rpc.js +3 -0
- package/dist/app/lib/internal/index.d.ts +6 -4
- package/dist/app/lib/internal/index.d.ts.map +1 -0
- package/dist/app/lib/internal/index.js +5 -4
- package/dist/app/lib/internal/internal-store.d.ts +1 -2
- package/dist/app/lib/internal/internal-store.d.ts.map +1 -0
- package/dist/app/lib/internal/internal-store.js +1 -3
- package/dist/app/lib/internal/read-admin-manifest.d.ts +2 -1
- package/dist/app/lib/internal/read-admin-manifest.d.ts.map +1 -0
- package/dist/app/lib/internal/read-block-manifest.d.ts +1 -0
- package/dist/app/lib/internal/read-block-manifest.d.ts.map +1 -0
- package/dist/app/lib/internal/read-view-manifest.d.ts +1 -0
- package/dist/app/lib/internal/read-view-manifest.d.ts.map +1 -0
- package/dist/app/lib/legacy-stitches/createStitches.d.ts +22 -21
- package/dist/app/lib/legacy-stitches/createStitches.d.ts.map +1 -0
- package/dist/app/lib/legacy-stitches/createStitches.js +1 -1
- package/dist/app/lib/legacy-stitches/index.d.ts +2 -1
- package/dist/app/lib/legacy-stitches/index.d.ts.map +1 -0
- package/dist/app/lib/legacy-stitches/index.js +1 -1
- package/dist/app/lib/routing/components/BackButton.d.ts +50 -0
- package/dist/app/lib/routing/components/BackButton.d.ts.map +1 -0
- package/dist/app/lib/routing/components/BackButton.js +47 -0
- package/dist/app/lib/routing/components/BrowserRouter.d.ts +10 -1
- package/dist/app/lib/routing/components/BrowserRouter.d.ts.map +1 -0
- package/dist/app/lib/routing/components/BrowserRouter.js +138 -23
- package/dist/app/lib/routing/components/ClientOnly.d.ts +1 -0
- package/dist/app/lib/routing/components/ClientOnly.d.ts.map +1 -0
- package/dist/app/lib/routing/components/ClientOnly.js +2 -2
- package/dist/app/lib/routing/components/Link.d.ts +19 -2
- package/dist/app/lib/routing/components/Link.d.ts.map +1 -0
- package/dist/app/lib/routing/components/Link.js +47 -27
- package/dist/app/lib/routing/components/NativeLinkHandler.d.ts +10 -0
- package/dist/app/lib/routing/components/NativeLinkHandler.d.ts.map +1 -0
- package/dist/app/lib/routing/components/NativeLinkHandler.js +23 -0
- package/dist/app/lib/routing/components/RouteRenderer.d.ts +2 -1
- package/dist/app/lib/routing/components/RouteRenderer.d.ts.map +1 -0
- package/dist/app/lib/routing/components/RouteRenderer.js +20 -6
- package/dist/app/lib/routing/components/SSRRouter.d.ts +5 -2
- package/dist/app/lib/routing/components/SSRRouter.d.ts.map +1 -0
- package/dist/app/lib/routing/components/SSRRouter.js +7 -6
- package/dist/app/lib/routing/components/ScrollRestoration.d.ts +1 -0
- package/dist/app/lib/routing/components/ScrollRestoration.d.ts.map +1 -0
- package/dist/app/lib/routing/components/ScrollRestoration.js +5 -2
- package/dist/app/lib/routing/context.d.ts +9 -5
- package/dist/app/lib/routing/context.d.ts.map +1 -0
- package/dist/app/lib/routing/context.js +13 -96
- package/dist/app/lib/routing/hooks/useIsSSR.d.ts +1 -0
- package/dist/app/lib/routing/hooks/useIsSSR.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRestorableState.d.ts +3 -1
- package/dist/app/lib/routing/hooks/useRestorableState.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRestorableState.js +2 -1
- package/dist/app/lib/routing/hooks/useRoute.d.ts +17 -1
- package/dist/app/lib/routing/hooks/useRoute.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRoute.js +22 -1
- package/dist/app/lib/routing/hooks/useRouteMeta.d.ts +6 -0
- package/dist/app/lib/routing/hooks/useRouteMeta.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouteMeta.js +9 -0
- package/dist/app/lib/routing/hooks/useRouteTransition.d.ts +2 -1
- package/dist/app/lib/routing/hooks/useRouteTransition.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouteTransition.js +1 -1
- package/dist/app/lib/routing/hooks/useRouter.d.ts +2 -1
- package/dist/app/lib/routing/hooks/useRouter.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouter.js +1 -1
- package/dist/app/lib/routing/hooks/useRouterEvents.d.ts +2 -1
- package/dist/app/lib/routing/hooks/useRouterEvents.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouterEvents.js +1 -1
- package/dist/app/lib/routing/hooks/useRouterState.d.ts +2 -1
- package/dist/app/lib/routing/hooks/useRouterState.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouterState.js +1 -1
- package/dist/app/lib/routing/hooks/useSearchParams.d.ts +78 -6
- package/dist/app/lib/routing/hooks/useSearchParams.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useSearchParams.js +77 -17
- package/dist/app/lib/routing/index.d.ts +16 -13
- package/dist/app/lib/routing/index.d.ts.map +1 -0
- package/dist/app/lib/routing/index.js +15 -13
- package/dist/app/lib/routing/loader.d.ts +3 -2
- package/dist/app/lib/routing/loader.d.ts.map +1 -0
- package/dist/app/lib/routing/loader.js +26 -15
- package/dist/app/lib/routing/types.d.ts +62 -14
- package/dist/app/lib/routing/types.d.ts.map +1 -0
- package/dist/app/lib/routing/utils.d.ts +7 -2
- package/dist/app/lib/routing/utils.d.ts.map +1 -0
- package/dist/app/lib/routing/utils.js +41 -4
- package/dist/app/lib/{hooks → runtime}/apiConfig.d.ts +11 -2
- package/dist/app/lib/runtime/apiConfig.d.ts.map +1 -0
- package/dist/app/lib/runtime/apiConfig.js +6 -0
- package/dist/app/lib/runtime/errorHandling.d.ts +40 -0
- package/dist/app/lib/runtime/errorHandling.d.ts.map +1 -0
- package/dist/app/lib/runtime/errorHandling.js +6 -0
- package/dist/app/lib/runtime/index.d.ts +3 -0
- package/dist/app/lib/runtime/index.d.ts.map +1 -0
- package/dist/app/lib/runtime/index.js +2 -0
- package/dist/app/lib/views/defineView.d.ts +2 -1
- package/dist/app/lib/views/defineView.d.ts.map +1 -0
- package/dist/app/lib/views/index.d.ts +2 -1
- package/dist/app/lib/views/index.d.ts.map +1 -0
- package/dist/app/lib/views/index.js +1 -1
- package/dist/app/server/index.d.ts +6 -0
- package/dist/app/server/index.d.ts.map +1 -0
- package/dist/app/server/index.js +5 -0
- package/dist/app/server/proxy-wp-admin.d.ts +3 -0
- package/dist/app/server/proxy-wp-admin.d.ts.map +1 -0
- package/dist/app/server/proxy-wp-admin.js +138 -0
- package/dist/app/server/render-ai-page.d.ts +13 -0
- package/dist/app/server/render-ai-page.d.ts.map +1 -0
- package/dist/app/server/render-ai-page.js +100 -0
- package/dist/app/server/render-ssr-page.d.ts +31 -0
- package/dist/app/server/render-ssr-page.d.ts.map +1 -0
- package/dist/app/server/render-ssr-page.js +237 -0
- package/dist/app/server/rpc.d.ts +52 -0
- package/dist/app/server/rpc.d.ts.map +1 -0
- package/dist/app/server/rpc.js +18 -0
- package/dist/app/server/server-context.d.ts +75 -0
- package/dist/app/server/server-context.d.ts.map +1 -0
- package/dist/app/server/server-context.js +417 -0
- package/dist/app/server/server-custom-config.d.ts +3 -0
- package/dist/app/server/server-custom-config.d.ts.map +1 -0
- package/dist/app/server/server-custom-config.js +1 -0
- package/dist/app/server/utils/content-security.d.ts +26 -0
- package/dist/app/server/utils/content-security.d.ts.map +1 -0
- package/dist/app/server/utils/content-security.js +124 -0
- package/dist/app/server/utils/headers.d.ts +2 -0
- package/dist/app/server/utils/headers.d.ts.map +1 -0
- package/dist/app/server/utils/headers.js +17 -0
- package/dist/app/server/utils/replace-host.d.ts +7 -4
- package/dist/app/server/utils/replace-host.d.ts.map +1 -0
- package/dist/app/server/utils/replace-host.js +66 -11
- package/dist/app/server/utils/swr-cache.d.ts +5 -0
- package/dist/app/server/utils/swr-cache.d.ts.map +1 -0
- package/dist/app/server/utils/swr-cache.js +31 -0
- package/dist/app/utils/APIProvider.d.ts +3 -0
- package/dist/app/utils/APIProvider.d.ts.map +1 -0
- package/dist/app/utils/APIProvider.js +5 -0
- package/dist/app/utils/BlockErrorBoundary.d.ts +20 -0
- package/dist/app/utils/BlockErrorBoundary.d.ts.map +1 -0
- package/dist/app/utils/BlockErrorBoundary.js +38 -0
- package/dist/app/utils/ErrorMessage.d.ts +6 -0
- package/dist/app/utils/ErrorMessage.d.ts.map +1 -0
- package/dist/app/utils/ErrorMessage.js +14 -0
- package/dist/app/utils/RouteErrorBoundary.d.ts +20 -0
- package/dist/app/utils/RouteErrorBoundary.d.ts.map +1 -0
- package/dist/app/utils/RouteErrorBoundary.js +41 -0
- package/dist/app/utils/asset-capture.d.ts +3 -0
- package/dist/app/utils/asset-capture.d.ts.map +1 -0
- package/dist/app/utils/asset-capture.js +5 -0
- package/dist/app/utils/hydration-debugger.d.ts +14 -0
- package/dist/app/utils/hydration-debugger.d.ts.map +1 -0
- package/dist/app/utils/hydration-debugger.js +11 -0
- package/dist/app/utils/query-client.d.ts +3 -0
- package/dist/app/utils/query-client.d.ts.map +1 -0
- package/dist/app/utils/query-client.js +5 -1
- package/dist/app/utils/query-monitor.d.ts +27 -0
- package/dist/app/utils/query-monitor.d.ts.map +1 -0
- package/dist/app/utils/query-monitor.js +7 -0
- package/dist/app/utils/trpc-client.d.ts +3 -0
- package/dist/app/utils/trpc-client.d.ts.map +1 -0
- package/dist/app/utils/trpc-client.js +39 -0
- package/dist/app/utils/wp.d.ts +11 -10
- package/dist/app/utils/wp.d.ts.map +1 -0
- package/dist/node/cli/cli-mode.d.ts +1 -0
- package/dist/node/cli/cli-mode.d.ts.map +1 -0
- package/dist/node/cli/cli-worker.d.ts +2 -1
- package/dist/node/cli/cli-worker.d.ts.map +1 -0
- package/dist/node/cli/cli-worker.js +12 -3
- package/dist/node/cli/cli.d.ts +1 -0
- package/dist/node/cli/cli.d.ts.map +1 -0
- package/dist/node/cli/cli.js +195 -11
- package/dist/node/cli/display/CLIApp.d.ts +2 -1
- package/dist/node/cli/display/CLIApp.d.ts.map +1 -0
- package/dist/node/cli/display/CLIApp.js +4 -7
- package/dist/node/cli/display/boot-cli-app.d.ts +1 -0
- package/dist/node/cli/display/boot-cli-app.d.ts.map +1 -0
- package/dist/node/cli/display/boot-cli-app.js +1 -1
- package/dist/node/cli/display/components/Fullscreen.d.ts +1 -0
- package/dist/node/cli/display/components/Fullscreen.d.ts.map +1 -0
- package/dist/node/cli/display/components/LogEntries.d.ts +2 -1
- package/dist/node/cli/display/components/LogEntries.d.ts.map +1 -0
- package/dist/node/cli/display/components/MenuItem.d.ts +1 -0
- package/dist/node/cli/display/components/MenuItem.d.ts.map +1 -0
- package/dist/node/cli/display/components/TextInput.d.ts +1 -0
- package/dist/node/cli/display/components/TextInput.d.ts.map +1 -0
- package/dist/node/cli/display/hooks/useManifest.d.ts +1 -0
- package/dist/node/cli/display/hooks/useManifest.d.ts.map +1 -0
- package/dist/node/cli/display/hooks/useStatefulLog.d.ts +2 -1
- package/dist/node/cli/display/hooks/useStatefulLog.d.ts.map +1 -0
- package/dist/node/cli/display/tools/BlockList.d.ts +1 -0
- package/dist/node/cli/display/tools/BlockList.d.ts.map +1 -0
- package/dist/node/cli/display/tools/CreateBlock.d.ts +2 -1
- package/dist/node/cli/display/tools/CreateBlock.d.ts.map +1 -0
- package/dist/node/cli/display/tools/cli-tool-list.d.ts +1 -0
- package/dist/node/cli/display/tools/cli-tool-list.d.ts.map +1 -0
- package/dist/node/cli/display/tools/cli-tools.d.ts +2 -11
- package/dist/node/cli/display/tools/cli-tools.d.ts.map +1 -0
- package/dist/node/cli/display/tools/cli-tools.js +9 -9
- package/dist/node/cli/display/util/colors.d.ts +3 -2
- package/dist/node/cli/display/util/colors.d.ts.map +1 -0
- package/dist/node/cli/version.d.ts +2 -1
- package/dist/node/cli/version.d.ts.map +1 -0
- package/dist/node/cli/version.js +1 -1
- package/dist/node/compiler/build-vinxi.d.ts +9 -0
- package/dist/node/compiler/build-vinxi.d.ts.map +1 -0
- package/dist/node/compiler/build-vinxi.js +38 -0
- package/dist/node/compiler/bundler.admin.d.ts +3 -2
- package/dist/node/compiler/bundler.admin.d.ts.map +1 -0
- package/dist/node/compiler/bundler.admin.js +4 -4
- package/dist/node/compiler/bundler.frontend.d.ts +3 -1
- package/dist/node/compiler/bundler.frontend.d.ts.map +1 -0
- package/dist/node/compiler/bundler.frontend.js +29 -15
- package/dist/node/compiler/dev-server.d.ts +19 -0
- package/dist/node/compiler/dev-server.d.ts.map +1 -0
- package/dist/node/compiler/dev-server.js +113 -0
- package/dist/node/compiler/get-vite-config.d.ts +30 -0
- package/dist/node/compiler/get-vite-config.d.ts.map +1 -0
- package/dist/node/compiler/get-vite-config.js +332 -0
- package/dist/node/compiler/vinxi-app.d.ts +23 -0
- package/dist/node/compiler/vinxi-app.d.ts.map +1 -0
- package/dist/node/compiler/vinxi-app.js +230 -0
- package/dist/node/compiler/vinxi-codegen.d.ts +13 -0
- package/dist/node/compiler/vinxi-codegen.d.ts.map +1 -0
- package/dist/node/compiler/vinxi-codegen.js +731 -0
- package/dist/node/graphql/graphql-codegen.d.ts +13 -2
- package/dist/node/graphql/graphql-codegen.d.ts.map +1 -0
- package/dist/node/graphql/graphql-codegen.js +242 -40
- package/dist/node/graphql/graphql-schema-loader.d.ts +3 -1
- package/dist/node/graphql/graphql-schema-loader.d.ts.map +1 -0
- package/dist/node/graphql/graphql-schema-loader.js +5 -19
- package/dist/node/graphql/plugins/gql-plugin-files.d.ts +3 -1
- package/dist/node/graphql/plugins/gql-plugin-files.d.ts.map +1 -0
- package/dist/node/graphql/plugins/gql-plugin-files.js +3 -2
- package/dist/node/graphql/plugins/gql-plugin-no-duplicates.d.ts +1 -0
- package/dist/node/graphql/plugins/gql-plugin-no-duplicates.d.ts.map +1 -0
- package/dist/node/graphql/plugins/gql-plugin-queries.d.ts +1 -0
- package/dist/node/graphql/plugins/gql-plugin-queries.d.ts.map +1 -0
- package/dist/node/graphql/plugins/gql-plugin-queries.js +2 -2
- package/dist/node/graphql/query-files-loader.d.ts +4 -0
- package/dist/node/graphql/query-files-loader.d.ts.map +1 -0
- package/dist/node/graphql/query-files-loader.js +5 -0
- package/dist/node/graphql/wp-info-query.d.ts +1 -0
- package/dist/node/graphql/wp-info-query.d.ts.map +1 -0
- package/dist/node/project/config.d.ts +207 -73
- package/dist/node/project/config.d.ts.map +1 -0
- package/dist/node/project/config.js +95 -21
- package/dist/node/project/eddev-build-file.d.ts +1 -0
- package/dist/node/project/eddev-build-file.d.ts.map +1 -0
- package/dist/node/project/eddev-build-file.js +4 -2
- package/dist/node/project/env.d.ts +6 -1
- package/dist/node/project/env.d.ts.map +1 -0
- package/dist/node/project/env.js +2 -1
- package/dist/node/project/favicons.d.ts +1 -0
- package/dist/node/project/favicons.d.ts.map +1 -0
- package/dist/node/project/manifest/block-manifest.d.ts +1 -0
- package/dist/node/project/manifest/block-manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/block-manifest.js +8 -4
- package/dist/node/project/manifest/field-manifest.d.ts +1 -0
- package/dist/node/project/manifest/field-manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/manifest.d.ts +3 -1
- package/dist/node/project/manifest/manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/manifest.js +15 -11
- package/dist/node/project/manifest/routes-manifest.d.ts +21 -0
- package/dist/node/project/manifest/routes-manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/routes-manifest.js +74 -0
- package/dist/node/project/manifest/view-manifest.d.ts +1 -0
- package/dist/node/project/manifest/view-manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/view-manifest.js +2 -2
- package/dist/node/project/manifest/widget-manifest.d.ts +1 -0
- package/dist/node/project/manifest/widget-manifest.d.ts.map +1 -0
- package/dist/node/project/project.d.ts +15 -2
- package/dist/node/project/project.d.ts.map +1 -0
- package/dist/node/project/project.js +73 -21
- package/dist/node/project/wp-info.d.ts +3 -0
- package/dist/node/project/wp-info.d.ts.map +1 -0
- package/dist/node/project/wp-info.js +13 -3
- package/dist/node/storybook/index.d.ts +3 -0
- package/dist/node/storybook/index.d.ts.map +1 -0
- package/dist/node/storybook/index.js +13 -0
- package/dist/node/types/block-type.d.ts +57 -25
- package/dist/node/types/block-type.d.ts.map +1 -0
- package/dist/node/types/block-type.js +4 -1
- package/dist/node/types/view-type.d.ts +8 -7
- package/dist/node/types/view-type.d.ts.map +1 -0
- package/dist/node/types/view-type.js +3 -4
- package/dist/node/utils/fetch-wp.d.ts +2 -0
- package/dist/node/utils/fetch-wp.d.ts.map +1 -0
- package/dist/node/utils/fetch-wp.js +28 -0
- package/dist/node/utils/{formatZodError.d.ts → format-zod-error.d.ts} +1 -0
- package/dist/node/utils/format-zod-error.d.ts.map +1 -0
- package/dist/node/utils/fs-codegen.d.ts +44 -0
- package/dist/node/utils/fs-codegen.d.ts.map +1 -0
- package/dist/node/utils/fs-codegen.js +105 -0
- package/dist/node/utils/fs.d.ts +5 -0
- package/dist/node/utils/fs.d.ts.map +1 -0
- package/dist/node/utils/fs.js +2 -0
- package/dist/node/utils/{getRepoInfo.d.ts → get-repo-info.d.ts} +1 -0
- package/dist/node/utils/get-repo-info.d.ts.map +1 -0
- package/dist/node/utils/helpers.d.ts +1 -0
- package/dist/node/utils/helpers.d.ts.map +1 -0
- package/dist/node/utils/{highlightCode.d.ts → highlight-code.d.ts} +1 -0
- package/dist/node/utils/highlight-code.d.ts.map +1 -0
- package/dist/node/utils/{isDeploying.d.ts → is-deploying.d.ts} +1 -0
- package/dist/node/utils/is-deploying.d.ts.map +1 -0
- package/dist/node/utils/{isDeploying.js → is-deploying.js} +1 -1
- package/dist/node/utils/report-builder.d.ts +7 -6
- package/dist/node/utils/report-builder.d.ts.map +1 -0
- package/dist/node/utils/self-signed-cert.d.ts +9 -0
- package/dist/node/utils/self-signed-cert.d.ts.map +1 -0
- package/dist/node/utils/{selfSignedCert.js → self-signed-cert.js} +29 -5
- package/dist/node/utils/{statefulLog.d.ts → stateful-log.d.ts} +1 -0
- package/dist/node/utils/stateful-log.d.ts.map +1 -0
- package/dist/node/utils/{statefulLog.js → stateful-log.js} +3 -1
- package/dist/node/utils/{export-extractor.d.ts → ts-export-extractor.d.ts} +1 -0
- package/dist/node/utils/ts-export-extractor.d.ts.map +1 -0
- package/dist/node/utils/watch-file-tree.d.ts +26 -0
- package/dist/node/utils/watch-file-tree.d.ts.map +1 -0
- package/dist/node/utils/{watchFileTree.js → watch-file-tree.js} +12 -5
- package/package.json +62 -47
- package/tsconfig.app.json +8 -3
- package/tsconfig.node.json +1 -0
- package/types.app.d.ts +4 -2
- package/types.app.internal.d.ts +2 -2
- package/types.meta.d.ts +449 -136
- package/types.node.d.ts +3 -3
- package/dist/app/entry/Root.d.ts +0 -1
- package/dist/app/entry/Root.js +0 -9
- package/dist/app/entry/main.admin.d.ts +0 -3
- package/dist/app/entry/main.admin.js +0 -10
- package/dist/app/entry/main.frontend.spa.d.ts +0 -3
- package/dist/app/entry/main.frontend.spa.js +0 -13
- package/dist/app/entry/main.frontend.ssr.d.ts +0 -21
- package/dist/app/entry/main.frontend.ssr.js +0 -79
- package/dist/app/entry/main.serverless.dev.d.ts +0 -4
- package/dist/app/entry/main.serverless.dev.js +0 -21
- package/dist/app/lib/blocks/ErrorBoundaryFrontend.d.ts +0 -15
- package/dist/app/lib/blocks/ErrorBoundaryFrontend.js +0 -35
- package/dist/app/lib/hooks/apiConfig.js +0 -4
- package/dist/app/lib/hooks/usePageLoad.d.ts +0 -6
- package/dist/app/lib/hooks/usePageLoad.js +0 -5
- package/dist/app/server/create-api-builtin-hono.d.ts +0 -8
- package/dist/app/server/create-api-builtin-hono.js +0 -80
- package/dist/app/server/create-ssr-hono.d.ts +0 -18
- package/dist/app/server/create-ssr-hono.js +0 -104
- package/dist/app/server/utils/index.html.d.ts +0 -2
- package/dist/app/server/utils/index.html.js +0 -14
- package/dist/node/compiler/index.html.d.ts +0 -2
- package/dist/node/compiler/index.html.js +0 -15
- package/dist/node/compiler/serverless.dev.d.ts +0 -16
- package/dist/node/compiler/serverless.dev.js +0 -215
- package/dist/node/compiler/vite/get-vite-config.d.ts +0 -13
- package/dist/node/compiler/vite/get-vite-config.js +0 -315
- package/dist/node/compiler/vite/plugin-admin.d.ts +0 -4
- package/dist/node/compiler/vite/plugin-admin.js +0 -67
- package/dist/node/compiler/vite/plugin-blocks.d.ts +0 -4
- package/dist/node/compiler/vite/plugin-blocks.js +0 -73
- package/dist/node/compiler/vite/plugin-entry.d.ts +0 -6
- package/dist/node/compiler/vite/plugin-entry.js +0 -16
- package/dist/node/compiler/vite/plugin-resolved-tailwind.d.ts +0 -4
- package/dist/node/compiler/vite/plugin-resolved-tailwind.js +0 -29
- package/dist/node/compiler/vite/plugin-theme.d.ts +0 -4
- package/dist/node/compiler/vite/plugin-theme.js +0 -40
- package/dist/node/compiler/vite/plugin-views.d.ts +0 -4
- package/dist/node/compiler/vite/plugin-views.js +0 -51
- package/dist/node/utils/console.d.ts +0 -21
- package/dist/node/utils/console.js +0 -28
- package/dist/node/utils/selfSignedCert.d.ts +0 -4
- package/dist/node/utils/unsafe-fetch.d.ts +0 -2
- package/dist/node/utils/unsafe-fetch.js +0 -19
- package/dist/node/utils/watchFileTree.d.ts +0 -11
- package/tsup.config.ts +0 -40
- package/types.manifests.d.ts +0 -22
- /package/dist/node/utils/{formatZodError.js → format-zod-error.js} +0 -0
- /package/dist/node/utils/{getRepoInfo.js → get-repo-info.js} +0 -0
- /package/dist/node/utils/{highlightCode.js → highlight-code.js} +0 -0
- /package/dist/node/utils/{export-extractor.js → ts-export-extractor.js} +0 -0
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ContentBlock } from "../blocks";
|
|
2
|
+
import { ReactNode } from "react";
|
|
3
|
+
import { RouteState } from "../routing";
|
|
4
|
+
export type ErrorEvent = {
|
|
5
|
+
/** The runtime error that occurred */
|
|
6
|
+
error: Error;
|
|
7
|
+
/** The Component stack (not available in renderBlockError) */
|
|
8
|
+
componentStack?: string;
|
|
9
|
+
} & ({
|
|
10
|
+
type: "block";
|
|
11
|
+
/** The block which had an error, including it's type information, props, content and children */
|
|
12
|
+
block: ContentBlock;
|
|
13
|
+
} | {
|
|
14
|
+
type: "route";
|
|
15
|
+
/** The route which had an error */
|
|
16
|
+
route: RouteState;
|
|
17
|
+
});
|
|
18
|
+
/**
|
|
19
|
+
* Configuration options for manipulating how the client interacts with the GraphQL API
|
|
20
|
+
*/
|
|
21
|
+
export type ErrorHandlingConfig = {
|
|
22
|
+
/**
|
|
23
|
+
* Triggered when a runtime error occurs in a block
|
|
24
|
+
* @param event The error event, containing the error and block information
|
|
25
|
+
**/
|
|
26
|
+
onReactError?(event: ErrorEvent): void;
|
|
27
|
+
/**
|
|
28
|
+
* Triggered when a React rendering error occurs, and allows you to return some JSX to render as a fallback.
|
|
29
|
+
* If not provided, the block will be hidden from the user.
|
|
30
|
+
* @param error The error event, containing the error and contextual information
|
|
31
|
+
* @param defaultDisplay The default display for the block — in development, this will display the error message. In production, this will be `null`.
|
|
32
|
+
*/
|
|
33
|
+
renderFallback?(event: ErrorEvent, defaultDisplay: ReactNode): ReactNode;
|
|
34
|
+
/**
|
|
35
|
+
* Update the error handling configuration all at once
|
|
36
|
+
*/
|
|
37
|
+
set: (config: Partial<ErrorHandlingConfig>) => void;
|
|
38
|
+
};
|
|
39
|
+
export declare const errorHandling: ErrorHandlingConfig;
|
|
40
|
+
//# sourceMappingURL=errorHandling.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorHandling.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/runtime/errorHandling.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAEvC,MAAM,MAAM,UAAU,GAAG;IACvB,sCAAsC;IACtC,KAAK,EAAE,KAAK,CAAA;IACZ,8DAA8D;IAC9D,cAAc,CAAC,EAAE,MAAM,CAAA;CACxB,GAAG,CACA;IACE,IAAI,EAAE,OAAO,CAAA;IACb,iGAAiG;IACjG,KAAK,EAAE,YAAY,CAAA;CACpB,GACD;IACE,IAAI,EAAE,OAAO,CAAA;IACb,mCAAmC;IACnC,KAAK,EAAE,UAAU,CAAA;CAClB,CACJ,CAAA;AAED;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG;IAChC;;;QAGI;IACJ,YAAY,CAAC,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI,CAAA;IACtC;;;;;OAKG;IACH,cAAc,CAAC,CAAC,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,GAAG,SAAS,CAAA;IAExE;;OAEG;IACH,GAAG,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,mBAAmB,CAAC,KAAK,IAAI,CAAA;CACpD,CAAA;AAED,eAAO,MAAM,aAAa,qBAIxB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/runtime/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAA;AAC3B,cAAc,iBAAiB,CAAA"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ComponentType, PropsWithChildren, ReactNode } from "react";
|
|
2
|
-
type ExtendedViewProps<TName extends keyof ViewProps> = TName extends "_app" ? PropsWithChildren<ViewProps[TName]> : ViewProps[TName];
|
|
2
|
+
type ExtendedViewProps<TName extends keyof ViewProps> = TName extends "_app" ? PropsWithChildren<ViewProps[TName]> : TName extends "_error" ? ViewProps[TName] : ViewProps[TName];
|
|
3
3
|
export declare function defineView<Name extends keyof ViewProps>(name: Name, component: (props: ExtendedViewProps<Name>) => ReactNode): ComponentType<ExtendedViewProps<Name>>;
|
|
4
4
|
export {};
|
|
5
|
+
//# sourceMappingURL=defineView.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defineView.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/views/defineView.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEnE,KAAK,iBAAiB,CAAC,KAAK,SAAS,MAAM,SAAS,IAAI,KAAK,SAAS,MAAM,GACxE,iBAAiB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GACnC,KAAK,SAAS,QAAQ,GACpB,SAAS,CAAC,KAAK,CAAC,GAChB,SAAS,CAAC,KAAK,CAAC,CAAA;AAEtB,wBAAgB,UAAU,CAAC,IAAI,SAAS,MAAM,SAAS,EACrD,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,CAAC,KAAK,EAAE,iBAAiB,CAAC,IAAI,CAAC,KAAK,SAAS,GACvD,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAExC"}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export * from "./defineView";
|
|
1
|
+
export * from "./defineView.js";
|
|
2
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/views/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from "./defineView";
|
|
1
|
+
export * from "./defineView.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/app/server/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AACnC,cAAc,qBAAqB,CAAA;AACnC,cAAc,sBAAsB,CAAA;AACpC,cAAc,UAAU,CAAA;AACxB,cAAc,qBAAqB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy-wp-admin.d.ts","sourceRoot":"","sources":["../../../src/app/server/proxy-wp-admin.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAwD,OAAO,EAAE,MAAM,YAAY,CAAA;AAI/G,wBAAsB,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,mBAAmB,CAAC,qBA+GrE"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/// <reference types="vinxi/types/server" />
|
|
2
|
+
import { splitSetCookieString } from "cookie-es";
|
|
3
|
+
import { getProxyRequestHeaders, getRequestURL, getWebRequest } from "vinxi/http";
|
|
4
|
+
import { ServerContext } from "./server-context.js";
|
|
5
|
+
import { renderErrorPage } from "./render-ssr-page.js";
|
|
6
|
+
export async function proxyWpAdmin(event) {
|
|
7
|
+
const serverContext = ServerContext.main;
|
|
8
|
+
const req = getWebRequest(event);
|
|
9
|
+
const reqUrl = getRequestURL(event);
|
|
10
|
+
const serverlessConfig = serverContext.config.serverless;
|
|
11
|
+
if (!serverContext.dev) {
|
|
12
|
+
if (reqUrl.pathname.toLowerCase().match(/\/+(graphql|xmlrpc|\.php|wp\-(admin|login|json|cron))/)) {
|
|
13
|
+
if (serverlessConfig.admin === "hide") {
|
|
14
|
+
//
|
|
15
|
+
return renderErrorPage({
|
|
16
|
+
statusCode: 404,
|
|
17
|
+
title: "Not found",
|
|
18
|
+
userMessage: "The requested resource could not be found.",
|
|
19
|
+
pathname: reqUrl.pathname,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
const proxyUrl = serverContext.getOriginUrl(reqUrl.href);
|
|
25
|
+
// Prepare request headers to be sent to the origin server
|
|
26
|
+
const proxyHeaders = getProxyRequestHeaders(event);
|
|
27
|
+
proxyHeaders["X-ED-Dev-Proxy"] = "true";
|
|
28
|
+
const followRedirects = !reqUrl.pathname.match(/\.[a-z0-9]$/) && !reqUrl.pathname.match(/(^\/wp-|\.php$)/);
|
|
29
|
+
// Forward the request to the origin server
|
|
30
|
+
// console.log("Proxying request", proxyUrl, {
|
|
31
|
+
// method: req.method,
|
|
32
|
+
// referrer: req.referrer,
|
|
33
|
+
// referrerPolicy: req.referrerPolicy,
|
|
34
|
+
// headers: proxyHeaders,
|
|
35
|
+
// // body: req.method.match(/get|head|options/i) ? undefined : await req.blob(),
|
|
36
|
+
// redirect: followRedirects ? "follow" : "manual",
|
|
37
|
+
// cache: "no-cache",
|
|
38
|
+
// })
|
|
39
|
+
const response = await fetch(proxyUrl, {
|
|
40
|
+
method: req.method,
|
|
41
|
+
referrer: req.referrer,
|
|
42
|
+
referrerPolicy: req.referrerPolicy,
|
|
43
|
+
headers: proxyHeaders,
|
|
44
|
+
body: req.method.match(/get|head|options/i) ? undefined : await req.blob(),
|
|
45
|
+
redirect: followRedirects ? "follow" : "manual",
|
|
46
|
+
cache: "no-cache",
|
|
47
|
+
});
|
|
48
|
+
const contentType = response.headers.get("content-type");
|
|
49
|
+
let body;
|
|
50
|
+
let res = { status: response.status, statusText: response.statusText, headers: new Headers() };
|
|
51
|
+
const cookies = [];
|
|
52
|
+
response.headers.forEach((value, key) => {
|
|
53
|
+
if (key === "content-encoding" || key === "content-length" || key === "transfer-encoding") {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (key === "set-cookie") {
|
|
57
|
+
cookies.push(...splitSetCookieString(value));
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (key === "location") {
|
|
61
|
+
value = serverContext.replaceUrls(value);
|
|
62
|
+
}
|
|
63
|
+
res.headers.set(key, value);
|
|
64
|
+
});
|
|
65
|
+
// Set cookies in the response headers
|
|
66
|
+
// TODO: May need to rewrite cookie domain here before setting.
|
|
67
|
+
if (cookies.length > 0) {
|
|
68
|
+
for (const cookie of cookies) {
|
|
69
|
+
res.headers.append("set-cookie", cookie);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
// Replace URLs pointing to the origin server from the response itself
|
|
73
|
+
// This is only done for text-based content types, like application/json, text/plain, text/html etc
|
|
74
|
+
if (contentType?.match(/(application|text)\//)) {
|
|
75
|
+
body = serverContext.replaceUrls((await response.text()) ?? "", reqUrl.origin);
|
|
76
|
+
// If the content type is text/html, inject the Vite assets into the response — assuming the placeholder comments are found
|
|
77
|
+
if (contentType.startsWith("text/html")) {
|
|
78
|
+
const clientManifest = serverContext.runtime.getManifest("admin");
|
|
79
|
+
const assets = await clientManifest.inputs[clientManifest.handler].assets();
|
|
80
|
+
const getViteHeader = () => assets.map((asset) => renderAsset(asset)).join("\n");
|
|
81
|
+
const getViteFooter = () => renderAsset({
|
|
82
|
+
tag: "script",
|
|
83
|
+
attrs: {
|
|
84
|
+
type: "module",
|
|
85
|
+
src: clientManifest.inputs[clientManifest.handler].output.path,
|
|
86
|
+
},
|
|
87
|
+
children: "",
|
|
88
|
+
});
|
|
89
|
+
const encodeForJSON = (str) => JSON.stringify(str).slice(1, -1).replaceAll("/", "\\/");
|
|
90
|
+
const viteHeader = getViteHeader();
|
|
91
|
+
const viteFooter = getViteFooter();
|
|
92
|
+
const baseDirective = `<base href="${reqUrl.origin}">`;
|
|
93
|
+
body = body.replaceAll("<!---VITE_HEADER--->", viteHeader);
|
|
94
|
+
body = body.replaceAll("<!---VITE_FOOTER--->", viteFooter);
|
|
95
|
+
body = body.replaceAll("<script id='vite-iframe-header'><\\/script>", encodeForJSON(baseDirective + viteHeader));
|
|
96
|
+
body = body.replaceAll("<script id='vite-iframe-footer'><\\/script>", encodeForJSON(viteFooter));
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
// Otherwise just stream the response as is
|
|
101
|
+
body = response.body;
|
|
102
|
+
}
|
|
103
|
+
return new Response(body, res);
|
|
104
|
+
}
|
|
105
|
+
function printElement(element, props, innerText) {
|
|
106
|
+
if (typeof innerText === "string") {
|
|
107
|
+
return `<${element}${Object.entries(props)
|
|
108
|
+
.map(([key, value]) => ` ${key}="${value}"`)
|
|
109
|
+
.join("")}>${innerText}</${element}>`;
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
return `<${element}${Object.entries(props)
|
|
113
|
+
.map(([key, value]) => ` ${key}="${value}"`)
|
|
114
|
+
.join("")} />`;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
function renderAsset({ tag, attrs: { key, ...attrs } = {}, children, }) {
|
|
118
|
+
switch (tag) {
|
|
119
|
+
case "script":
|
|
120
|
+
if (attrs.src) {
|
|
121
|
+
return printElement("script", { ...attrs, key: attrs.src }, "");
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
return printElement("script", {
|
|
125
|
+
...attrs,
|
|
126
|
+
key: key,
|
|
127
|
+
}, children ?? "");
|
|
128
|
+
}
|
|
129
|
+
case "link":
|
|
130
|
+
return printElement("link", { ...attrs, key: key });
|
|
131
|
+
case "style":
|
|
132
|
+
return printElement("style", {
|
|
133
|
+
...attrs,
|
|
134
|
+
key: key,
|
|
135
|
+
}, children ?? "");
|
|
136
|
+
}
|
|
137
|
+
return "";
|
|
138
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
type RenderArgs = {
|
|
2
|
+
pathname: string;
|
|
3
|
+
statusCode?: number;
|
|
4
|
+
newOrigin?: string;
|
|
5
|
+
propData?: Record<string, any>;
|
|
6
|
+
};
|
|
7
|
+
export type IndexablePage = {
|
|
8
|
+
shouldIndex: boolean;
|
|
9
|
+
contents: string;
|
|
10
|
+
};
|
|
11
|
+
export declare function renderPageForIndexing(args: RenderArgs): Promise<IndexablePage>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=render-ai-page.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-ai-page.d.ts","sourceRoot":"","sources":["../../../src/app/server/render-ai-page.tsx"],"names":[],"mappings":"AAmGA,KAAK,UAAU,GAAG;IAChB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAC/B,CAAA;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,WAAW,EAAE,OAAO,CAAA;IACpB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,wBAAsB,qBAAqB,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,CA0CpF"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Suspense } from "react";
|
|
3
|
+
import { renderToPipeableStream, renderToString } from "react-dom/server";
|
|
4
|
+
import { Writable } from "stream";
|
|
5
|
+
import { MetaTags } from "../entry/MetaTags.js";
|
|
6
|
+
import { SSRRoot } from "../entry/ssr-root.js";
|
|
7
|
+
import { RouteLoader } from "../lib/routing/loader.js";
|
|
8
|
+
import { ServerContext } from "./server-context.js";
|
|
9
|
+
import { parseHTML } from "linkedom";
|
|
10
|
+
async function getAiSsrStream(args) {
|
|
11
|
+
const jsx = (_jsx(Suspense, { children: _jsx(SSRRoot, { metaTags: args.initialData?.meta?.head || [], pathname: args.pathname, initialData: args.initialData, loader: new RouteLoader(), isAI: true }) }));
|
|
12
|
+
const stream = await new Promise(async (resolve, reject) => {
|
|
13
|
+
// console.log("Rendering to pipable")
|
|
14
|
+
const stream = renderToPipeableStream(jsx, {
|
|
15
|
+
identifierPrefix: "ed",
|
|
16
|
+
onShellReady() {
|
|
17
|
+
// console.log("Shell ready")
|
|
18
|
+
resolve(stream);
|
|
19
|
+
},
|
|
20
|
+
onShellError(err) {
|
|
21
|
+
console.log("onShellError", err);
|
|
22
|
+
reject(err);
|
|
23
|
+
},
|
|
24
|
+
onError(err, errInfo) {
|
|
25
|
+
console.log("Error occurred after shell ready", err, errInfo);
|
|
26
|
+
console.error(err);
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
const [initial, middle, end] = renderToString(_jsxs("html", { lang: "en", children: [_jsxs("head", { children: ["%%$%%", _jsx(MetaTags, { tags: args.initialData.meta?.head ?? [] })] }), _jsx("body", { children: _jsx("div", { id: "root", children: "%%$%%" }) })] })).split("%%$%%");
|
|
31
|
+
const inner = await new Promise((resolve, reject) => {
|
|
32
|
+
let buffer = [];
|
|
33
|
+
const writableStream = new Writable({
|
|
34
|
+
emitClose: true,
|
|
35
|
+
write(chunk, encoding, callback) {
|
|
36
|
+
buffer.push(new TextDecoder().decode(chunk));
|
|
37
|
+
callback();
|
|
38
|
+
},
|
|
39
|
+
final(callback) {
|
|
40
|
+
resolve(buffer.join("\n"));
|
|
41
|
+
callback();
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
stream.pipe(writableStream);
|
|
45
|
+
});
|
|
46
|
+
const renderedContent = initial + "\n" + middle + "\n" + inner + "\n" + end;
|
|
47
|
+
return processRenderedContent(renderedContent);
|
|
48
|
+
}
|
|
49
|
+
function processRenderedContent(content) {
|
|
50
|
+
const { document } = parseHTML(content);
|
|
51
|
+
// Immediately remove unnecessary tags
|
|
52
|
+
document.querySelectorAll("script, link, style, svg, img, video, [data-ai-hidden]").forEach((el) => {
|
|
53
|
+
el.remove();
|
|
54
|
+
});
|
|
55
|
+
document.querySelectorAll("*").forEach((el) => {
|
|
56
|
+
el.removeAttribute("style");
|
|
57
|
+
el.removeAttribute("class");
|
|
58
|
+
});
|
|
59
|
+
const pageContents = document.querySelectorAll("#ai-page-contents");
|
|
60
|
+
document.body.innerHTML = "";
|
|
61
|
+
document.body.append(...Array.from(pageContents));
|
|
62
|
+
return document.toString();
|
|
63
|
+
}
|
|
64
|
+
export async function renderPageForIndexing(args) {
|
|
65
|
+
const serverContext = ServerContext.main;
|
|
66
|
+
let responseInit = {};
|
|
67
|
+
const [{ appData }, response] = await Promise.all([
|
|
68
|
+
serverContext.fetchAppData(),
|
|
69
|
+
serverContext.fetchRouteData({
|
|
70
|
+
pathname: args.pathname,
|
|
71
|
+
newOrigin: args.newOrigin,
|
|
72
|
+
}),
|
|
73
|
+
]);
|
|
74
|
+
let data = await response.json();
|
|
75
|
+
data.appData = appData;
|
|
76
|
+
if (args.propData) {
|
|
77
|
+
data = {
|
|
78
|
+
...data,
|
|
79
|
+
...args.propData,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
responseInit.status = response.status;
|
|
83
|
+
if (data.redirect) {
|
|
84
|
+
return {
|
|
85
|
+
shouldIndex: false,
|
|
86
|
+
contents: "",
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
const headers = new Headers();
|
|
90
|
+
headers.set("Content-Type", "text/html; charset=utf-8");
|
|
91
|
+
responseInit.headers = headers;
|
|
92
|
+
const result = await getAiSsrStream({
|
|
93
|
+
...args,
|
|
94
|
+
initialData: data,
|
|
95
|
+
});
|
|
96
|
+
return {
|
|
97
|
+
shouldIndex: true,
|
|
98
|
+
contents: result,
|
|
99
|
+
};
|
|
100
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { ErrorRouteProps, RouteDataWithTrackers } from "../lib/routing/types.js";
|
|
2
|
+
type SSRArgs = {
|
|
3
|
+
pathname: string;
|
|
4
|
+
hostname?: string;
|
|
5
|
+
initialData: RouteDataWithTrackers;
|
|
6
|
+
nonce?: string;
|
|
7
|
+
};
|
|
8
|
+
export declare function getSsrStream(args: SSRArgs): Promise<ReadableStream<Uint8Array<ArrayBufferLike>>>;
|
|
9
|
+
type RenderArgs = {
|
|
10
|
+
pathname: string;
|
|
11
|
+
statusCode?: number;
|
|
12
|
+
newOrigin?: string;
|
|
13
|
+
hostname?: string;
|
|
14
|
+
propData?: Record<string, any>;
|
|
15
|
+
};
|
|
16
|
+
export declare function renderPage(args: RenderArgs): Promise<Response>;
|
|
17
|
+
type RenderErrorPageArgs = {
|
|
18
|
+
pathname: string;
|
|
19
|
+
hostname?: string;
|
|
20
|
+
newOrigin?: string;
|
|
21
|
+
realError?: any;
|
|
22
|
+
} & ErrorRouteProps;
|
|
23
|
+
export declare function renderErrorPage(args: RenderErrorPageArgs): Promise<Response>;
|
|
24
|
+
type Asset = {
|
|
25
|
+
tag: string;
|
|
26
|
+
attrs: Record<string, string | boolean>;
|
|
27
|
+
children?: string;
|
|
28
|
+
};
|
|
29
|
+
export declare function renderAsset({ tag, attrs, children }: Asset): string;
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=render-ssr-page.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-ssr-page.d.ts","sourceRoot":"","sources":["../../../src/app/server/render-ssr-page.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAOrF,KAAK,OAAO,GAAG;IACb,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAA;AAED,wBAAsB,YAAY,CAAC,IAAI,EAAE,OAAO,wDAyH/C;AAED,KAAK,UAAU,GAAG;IAChB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAC/B,CAAA;AAED,wBAAsB,UAAU,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,CA2FpE;AAED,KAAK,mBAAmB,GAAG;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,GAAG,CAAA;CAChB,GAAG,eAAe,CAAA;AAEnB,wBAAsB,eAAe,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,QAAQ,CAAC,CAiBlF;AAED,KAAK,KAAK,GAAG;IACX,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,CAAA;IACvC,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,wBAAgB,WAAW,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,KAAK,UA6B1D"}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { renderToPipeableStream, renderToString } from "react-dom/server";
|
|
3
|
+
import { Writable } from "stream";
|
|
4
|
+
import { MetaTags } from "../entry/MetaTags.js";
|
|
5
|
+
import { SSRRoot } from "../entry/ssr-root.js";
|
|
6
|
+
import { RouteLoader } from "../lib/routing/loader.js";
|
|
7
|
+
import { AssetCaptureContext } from "../utils/asset-capture.js";
|
|
8
|
+
import { ServerContext } from "./server-context.js";
|
|
9
|
+
import { Suspense } from "react";
|
|
10
|
+
import { SecureHeaderBuilder } from "./utils/content-security.js";
|
|
11
|
+
export async function getSsrStream(args) {
|
|
12
|
+
const clientManifest = ServerContext.main.runtime.getManifest("client");
|
|
13
|
+
const preloadAssets = new Set([clientManifest.handler]);
|
|
14
|
+
const includedAssets = new Set();
|
|
15
|
+
const jsx = (_jsx(Suspense, { children: _jsx(AssetCaptureContext.Provider, { value: preloadAssets, children: _jsx(SSRRoot, { metaTags: args.initialData?.meta?.head || [], pathname: args.pathname, hostname: args.hostname, initialData: args.initialData, loader: new RouteLoader() }) }) }));
|
|
16
|
+
const stream = await new Promise(async (resolve, reject) => {
|
|
17
|
+
// console.log("Rendering to pipable")
|
|
18
|
+
const stream = renderToPipeableStream(jsx, {
|
|
19
|
+
identifierPrefix: "ed",
|
|
20
|
+
onShellReady() {
|
|
21
|
+
// console.log("Shell ready")
|
|
22
|
+
resolve(stream);
|
|
23
|
+
},
|
|
24
|
+
onShellError(err) {
|
|
25
|
+
console.log("onShellError", err);
|
|
26
|
+
reject(err);
|
|
27
|
+
},
|
|
28
|
+
onError(err, errInfo) {
|
|
29
|
+
console.log("Error occurred after shell ready", err, errInfo);
|
|
30
|
+
console.error(err);
|
|
31
|
+
},
|
|
32
|
+
bootstrapModules: [clientManifest.inputs[clientManifest.handler].output.path],
|
|
33
|
+
nonce: args.nonce,
|
|
34
|
+
bootstrapScriptContent: `\nwindow.manifest = ${JSON.stringify(await clientManifest.json())};\nwindow._PAGE_DATA = ${JSON.stringify({
|
|
35
|
+
...args.initialData,
|
|
36
|
+
trackers: undefined,
|
|
37
|
+
hostname: args.hostname,
|
|
38
|
+
})};\n`,
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
const [initial, middle, end] = renderToString(_jsxs("html", { lang: "en", children: [_jsxs("head", { children: ["%%$%%", _jsx(MetaTags, { tags: args.initialData.meta?.head ?? [] }), "%%trackers_head%%"] }), _jsxs("body", { children: ["%%trackers_body%%", _jsx("div", { id: "root", children: "%%$%%" }), "%%trackers_footer%%"] })] }))
|
|
42
|
+
.replace(/%%trackers_(head|body|footer)%%/g, (_, name) => {
|
|
43
|
+
return args.initialData.trackers?.[name] || "";
|
|
44
|
+
})
|
|
45
|
+
.split("%%$%%");
|
|
46
|
+
return new ReadableStream({
|
|
47
|
+
async start(controller) {
|
|
48
|
+
controller.enqueue(new TextEncoder().encode("<!doctype html>" + initial));
|
|
49
|
+
const inner = await new Promise((resolve, reject) => {
|
|
50
|
+
let buffer = [];
|
|
51
|
+
const writableStream = new Writable({
|
|
52
|
+
emitClose: true,
|
|
53
|
+
write(chunk, encoding, callback) {
|
|
54
|
+
buffer.push(chunk);
|
|
55
|
+
// controller.enqueue(chunk)
|
|
56
|
+
callback();
|
|
57
|
+
},
|
|
58
|
+
final(callback) {
|
|
59
|
+
resolve(buffer);
|
|
60
|
+
// controller.close()
|
|
61
|
+
callback();
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
stream.pipe(writableStream);
|
|
65
|
+
});
|
|
66
|
+
for (const input of preloadAssets) {
|
|
67
|
+
const assets = await clientManifest.inputs[input].assets();
|
|
68
|
+
// controller.enqueue(new TextEncoder().encode(`\n<!-- for ${input} -->`))
|
|
69
|
+
for (const _asset of assets) {
|
|
70
|
+
const asset = _asset;
|
|
71
|
+
if (args.nonce)
|
|
72
|
+
asset.attrs.nonce = args.nonce;
|
|
73
|
+
// Ensure that each asset is only included once
|
|
74
|
+
const key = asset?.attrs?.key;
|
|
75
|
+
if (!key) {
|
|
76
|
+
throw new Error("Asset must have a key: " + JSON.stringify(asset));
|
|
77
|
+
}
|
|
78
|
+
if (includedAssets.has(key))
|
|
79
|
+
continue;
|
|
80
|
+
includedAssets.add(key);
|
|
81
|
+
// Render the asset
|
|
82
|
+
try {
|
|
83
|
+
const tag = renderAsset(asset);
|
|
84
|
+
controller.enqueue(new TextEncoder().encode(tag + "\n"));
|
|
85
|
+
}
|
|
86
|
+
catch (err) {
|
|
87
|
+
controller.enqueue(new TextEncoder().encode(`\n<!-- ${JSON.stringify(err)} -->\n`));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
// console.log("ASSETS", await clientManifest)
|
|
92
|
+
controller.enqueue(new TextEncoder().encode(middle));
|
|
93
|
+
for (const chunk of inner) {
|
|
94
|
+
controller.enqueue(chunk);
|
|
95
|
+
}
|
|
96
|
+
controller.enqueue(new TextEncoder().encode(end));
|
|
97
|
+
// console.log("Assets", dynamicAssets)
|
|
98
|
+
controller.close();
|
|
99
|
+
},
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
export async function renderPage(args) {
|
|
103
|
+
const serverContext = ServerContext.main;
|
|
104
|
+
const cspHeaders = new SecureHeaderBuilder(serverContext.config);
|
|
105
|
+
let responseInit = {};
|
|
106
|
+
try {
|
|
107
|
+
const [{ appData, trackers }, response] = await Promise.all([
|
|
108
|
+
serverContext.fetchAppData(),
|
|
109
|
+
serverContext.fetchRouteData({
|
|
110
|
+
pathname: args.pathname,
|
|
111
|
+
newOrigin: args.newOrigin,
|
|
112
|
+
}),
|
|
113
|
+
]);
|
|
114
|
+
if (trackers) {
|
|
115
|
+
cspHeaders.addTrackingTags(trackers);
|
|
116
|
+
}
|
|
117
|
+
let data;
|
|
118
|
+
try {
|
|
119
|
+
data = await response.json();
|
|
120
|
+
data.appData = appData;
|
|
121
|
+
data.trackers = cspHeaders.addTrackingTags(trackers);
|
|
122
|
+
if (args.propData) {
|
|
123
|
+
data = {
|
|
124
|
+
...data,
|
|
125
|
+
...args.propData,
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
if (data.meta?.head)
|
|
129
|
+
data.meta.head = cspHeaders.addMetaTags(data.meta.head);
|
|
130
|
+
if (data.meta?.footer)
|
|
131
|
+
data.meta.footer = cspHeaders.addMetaTags(data.meta.footer);
|
|
132
|
+
responseInit.status = response.status;
|
|
133
|
+
}
|
|
134
|
+
catch (err) {
|
|
135
|
+
console.log("Error rendering", err);
|
|
136
|
+
console.error(err);
|
|
137
|
+
return renderErrorPage({
|
|
138
|
+
pathname: args.pathname,
|
|
139
|
+
statusCode: 500,
|
|
140
|
+
title: "Internal Server Error",
|
|
141
|
+
newOrigin: args.newOrigin,
|
|
142
|
+
report: {
|
|
143
|
+
details: err,
|
|
144
|
+
message: err.message,
|
|
145
|
+
},
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
if (data.redirect) {
|
|
149
|
+
return new Response(null, {
|
|
150
|
+
status: data.status || 302,
|
|
151
|
+
headers: {
|
|
152
|
+
Location: data.redirect,
|
|
153
|
+
},
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
const headers = cspHeaders.getHeaders();
|
|
157
|
+
headers.set("Content-Type", "text/html; charset=utf-8");
|
|
158
|
+
responseInit.headers = headers;
|
|
159
|
+
const stream = await getSsrStream({
|
|
160
|
+
...args,
|
|
161
|
+
hostname: args.hostname,
|
|
162
|
+
initialData: data,
|
|
163
|
+
nonce: cspHeaders.nonce,
|
|
164
|
+
});
|
|
165
|
+
return new Response(stream, responseInit);
|
|
166
|
+
}
|
|
167
|
+
catch (err) {
|
|
168
|
+
console.error(err);
|
|
169
|
+
if (args.statusCode !== 500) {
|
|
170
|
+
return renderErrorPage({
|
|
171
|
+
pathname: args.pathname,
|
|
172
|
+
statusCode: 500,
|
|
173
|
+
realError: err,
|
|
174
|
+
newOrigin: args.newOrigin,
|
|
175
|
+
title: "Internal Server Error",
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
return new Response('<!DOCTYPE html><html><head><title>500 Internal Server Error</title></head><body><h1>500 Internal Server Error</h1><p>"' +
|
|
179
|
+
String(err) +
|
|
180
|
+
'"</p></body></html>', {
|
|
181
|
+
status: 500,
|
|
182
|
+
statusText: "Internal Server Error",
|
|
183
|
+
headers: {
|
|
184
|
+
"Content-Type": "text/html; charset=utf-8",
|
|
185
|
+
},
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
export async function renderErrorPage(args) {
|
|
190
|
+
const props = {
|
|
191
|
+
statusCode: args.statusCode,
|
|
192
|
+
report: args.report ?? {
|
|
193
|
+
message: args.realError?.message,
|
|
194
|
+
details: args.realError,
|
|
195
|
+
},
|
|
196
|
+
title: args.title,
|
|
197
|
+
userMessage: args.userMessage,
|
|
198
|
+
};
|
|
199
|
+
return renderPage({
|
|
200
|
+
pathname: "/_error",
|
|
201
|
+
statusCode: args.statusCode,
|
|
202
|
+
newOrigin: args.newOrigin,
|
|
203
|
+
propData: props,
|
|
204
|
+
hostname: args.hostname,
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
export function renderAsset({ tag, attrs, children }) {
|
|
208
|
+
const formatAttributes = (attributes) => {
|
|
209
|
+
return Object.entries(attributes)
|
|
210
|
+
.map(([attr, value]) => {
|
|
211
|
+
if (value === true) {
|
|
212
|
+
return attr;
|
|
213
|
+
}
|
|
214
|
+
else if (value !== false && value != null) {
|
|
215
|
+
return `${attr}="${String(value).replace(/"/g, """)}"`;
|
|
216
|
+
}
|
|
217
|
+
return "";
|
|
218
|
+
})
|
|
219
|
+
.filter(Boolean)
|
|
220
|
+
.join(" ");
|
|
221
|
+
};
|
|
222
|
+
switch (tag) {
|
|
223
|
+
case "script":
|
|
224
|
+
if (attrs.src) {
|
|
225
|
+
return `<script ${formatAttributes(attrs)}></script>`;
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
return `<script ${formatAttributes(attrs)}>${children ?? ""}</script>`;
|
|
229
|
+
}
|
|
230
|
+
case "link":
|
|
231
|
+
return `<link ${formatAttributes(attrs)} />`;
|
|
232
|
+
case "style":
|
|
233
|
+
return `<style ${formatAttributes(attrs)}>${children ?? ""}</style>`;
|
|
234
|
+
default:
|
|
235
|
+
return "";
|
|
236
|
+
}
|
|
237
|
+
}
|