eddev 2.0.0-beta.23 → 2.0.0-beta.231
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 +1 -0
- package/dist/app/entry/boot-admin.d.ts.map +1 -0
- package/dist/app/entry/boot-admin.js +7 -3
- 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 +1 -0
- package/dist/app/entry/spa-root.d.ts.map +1 -0
- package/dist/app/entry/spa-root.js +3 -5
- package/dist/app/entry/ssr-root-client.d.ts +4 -1
- package/dist/app/entry/ssr-root-client.d.ts.map +1 -0
- package/dist/app/entry/ssr-root-client.js +18 -6
- package/dist/app/entry/ssr-root.d.ts +6 -4
- package/dist/app/entry/ssr-root.d.ts.map +1 -0
- package/dist/app/entry/ssr-root.js +20 -19
- 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 +1 -0
- package/dist/app/lib/admin/index.d.ts.map +1 -0
- 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 +2 -0
- 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 +7 -2
- package/dist/app/lib/blocks/ContentBlocks.d.ts +8 -5
- package/dist/app/lib/blocks/ContentBlocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/ContentBlocks.js +16 -3
- package/dist/app/lib/blocks/EditableText.d.ts +30 -5
- package/dist/app/lib/blocks/EditableText.d.ts.map +1 -0
- package/dist/app/lib/blocks/EditableText.js +34 -5
- package/dist/app/lib/blocks/InnerBlocks.d.ts +21 -6
- package/dist/app/lib/blocks/InnerBlocks.d.ts.map +1 -0
- package/dist/app/lib/blocks/InnerBlocks.js +73 -25
- 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 +2 -1
- package/dist/app/lib/blocks/block-utils.d.ts.map +1 -0
- package/dist/app/lib/blocks/block-utils.js +3 -1
- 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 +17 -10
- package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.d.ts +2 -1
- 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 +77 -8
- 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 +126 -21
- 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 +12 -1
- package/dist/app/lib/blocks/editor/usePostEditor.d.ts.map +1 -0
- package/dist/app/lib/blocks/editor/usePostEditor.js +33 -13
- package/dist/app/lib/blocks/index.d.ts +8 -5
- package/dist/app/lib/blocks/index.d.ts.map +1 -0
- package/dist/app/lib/blocks/index.js +7 -5
- package/dist/app/lib/blocks/inline-editing.d.ts +10 -0
- package/dist/app/lib/blocks/inline-editing.d.ts.map +1 -0
- package/dist/app/lib/blocks/inline-editing.js +12 -2
- 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 +2 -2
- 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 +3 -2
- 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 +1 -0
- package/dist/app/lib/devtools/dev-tools-store.d.ts.map +1 -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 +1378 -333
- package/dist/app/lib/devtools/hooks/useTailwind.d.ts.map +1 -0
- package/dist/app/lib/devtools/index.d.ts +1 -0
- package/dist/app/lib/devtools/index.d.ts.map +1 -0
- 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 +1 -0
- package/dist/app/lib/dynamic/index.d.ts.map +1 -0
- package/dist/app/lib/hooks/index.d.ts +3 -3
- package/dist/app/lib/hooks/index.d.ts.map +1 -0
- package/dist/app/lib/hooks/index.js +2 -3
- package/dist/app/lib/hooks/{queryUtils.d.ts → query-hooks.d.ts} +42 -3
- package/dist/app/lib/hooks/query-hooks.d.ts.map +1 -0
- package/dist/app/lib/hooks/{queryUtils.js → query-hooks.js} +90 -28
- 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 +11 -0
- 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 +2 -0
- package/dist/app/lib/internal/index.d.ts.map +1 -0
- package/dist/app/lib/internal/index.js +1 -0
- package/dist/app/lib/internal/internal-store.d.ts +1 -0
- package/dist/app/lib/internal/internal-store.d.ts.map +1 -0
- package/dist/app/lib/internal/read-admin-manifest.d.ts +1 -0
- package/dist/app/lib/internal/read-admin-manifest.d.ts.map +1 -0
- package/dist/app/lib/internal/read-block-manifest.d.ts +2 -0
- package/dist/app/lib/internal/read-block-manifest.d.ts.map +1 -0
- package/dist/app/lib/internal/read-block-manifest.js +7 -0
- package/dist/app/lib/internal/read-view-manifest.d.ts +7 -4
- package/dist/app/lib/internal/read-view-manifest.d.ts.map +1 -0
- package/dist/app/lib/internal/read-view-manifest.js +18 -0
- package/dist/app/lib/legacy-stitches/createStitches.d.ts +510 -1
- package/dist/app/lib/legacy-stitches/createStitches.d.ts.map +1 -0
- package/dist/app/lib/legacy-stitches/index.d.ts +1 -0
- package/dist/app/lib/legacy-stitches/index.d.ts.map +1 -0
- 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 +170 -25
- package/dist/app/lib/routing/components/ClientOnly.d.ts +2 -1
- package/dist/app/lib/routing/components/ClientOnly.d.ts.map +1 -0
- package/dist/app/lib/routing/components/ClientOnly.js +3 -3
- package/dist/app/lib/routing/components/Link.d.ts +22 -2
- package/dist/app/lib/routing/components/Link.d.ts.map +1 -0
- package/dist/app/lib/routing/components/Link.js +53 -25
- 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 +1 -0
- package/dist/app/lib/routing/components/RouteRenderer.d.ts.map +1 -0
- package/dist/app/lib/routing/components/RouteRenderer.js +17 -3
- package/dist/app/lib/routing/components/SSRRouter.d.ts +3 -0
- package/dist/app/lib/routing/components/SSRRouter.d.ts.map +1 -0
- package/dist/app/lib/routing/components/SSRRouter.js +3 -2
- 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 +4 -1
- 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 +12 -95
- package/dist/app/lib/routing/hooks/{useIsSSR.d.ts → useHydrating.d.ts} +7 -0
- package/dist/app/lib/routing/hooks/useHydrating.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/{useIsSSR.js → useHydrating.js} +9 -1
- 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/useRoute.d.ts +16 -0
- package/dist/app/lib/routing/hooks/useRoute.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRoute.js +21 -0
- 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 +1 -0
- package/dist/app/lib/routing/hooks/useRouteTransition.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouter.d.ts +1 -0
- package/dist/app/lib/routing/hooks/useRouter.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouterEvents.d.ts +1 -0
- package/dist/app/lib/routing/hooks/useRouterEvents.d.ts.map +1 -0
- package/dist/app/lib/routing/hooks/useRouterState.d.ts +1 -0
- package/dist/app/lib/routing/hooks/useRouterState.d.ts.map +1 -0
- 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 +75 -15
- package/dist/app/lib/routing/index.d.ts +5 -1
- package/dist/app/lib/routing/index.d.ts.map +1 -0
- package/dist/app/lib/routing/index.js +4 -1
- package/dist/app/lib/routing/loader.d.ts +1 -0
- package/dist/app/lib/routing/loader.d.ts.map +1 -0
- package/dist/app/lib/routing/loader.js +19 -10
- package/dist/app/lib/routing/types.d.ts +73 -13
- 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 +1 -0
- package/dist/app/lib/views/index.d.ts.map +1 -0
- package/dist/app/server/index.d.ts +4 -1
- package/dist/app/server/index.d.ts.map +1 -0
- package/dist/app/server/index.js +3 -1
- package/dist/app/server/proxy-wp-admin.d.ts +2 -2
- package/dist/app/server/proxy-wp-admin.d.ts.map +1 -0
- package/dist/app/server/proxy-wp-admin.js +46 -13
- 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 +102 -0
- package/dist/app/server/render-ssr-page.d.ts +32 -3
- package/dist/app/server/render-ssr-page.d.ts.map +1 -0
- package/dist/app/server/render-ssr-page.js +237 -10
- 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 +53 -7
- package/dist/app/server/server-context.d.ts.map +1 -0
- package/dist/app/server/server-context.js +375 -37
- 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 +1 -0
- package/dist/app/server/utils/headers.d.ts.map +1 -0
- package/dist/app/server/utils/replace-host.d.ts +2 -1
- package/dist/app/server/utils/replace-host.d.ts.map +1 -0
- package/dist/app/server/utils/replace-host.js +10 -2
- 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 +1 -0
- package/dist/node/cli/cli-worker.d.ts.map +1 -0
- package/dist/node/cli/cli-worker.js +7 -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 +120 -7
- package/dist/node/cli/display/CLIApp.d.ts +1 -0
- package/dist/node/cli/display/CLIApp.d.ts.map +1 -0
- package/dist/node/cli/display/CLIApp.js +1 -1
- 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 +1 -0
- 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 +1 -0
- 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 +1 -0
- 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 +1 -0
- package/dist/node/cli/display/tools/cli-tools.d.ts.map +1 -0
- package/dist/node/cli/display/util/colors.d.ts +1 -0
- 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 +1 -0
- package/dist/node/compiler/build-vinxi.d.ts.map +1 -0
- package/dist/node/compiler/build-vinxi.js +2 -1
- package/dist/node/compiler/bundler.admin.d.ts +1 -0
- package/dist/node/compiler/bundler.admin.d.ts.map +1 -0
- package/dist/node/compiler/bundler.admin.js +1 -0
- package/dist/node/compiler/bundler.frontend.d.ts +2 -0
- package/dist/node/compiler/bundler.frontend.d.ts.map +1 -0
- package/dist/node/compiler/bundler.frontend.js +26 -11
- package/dist/node/compiler/cache-config.d.ts +3 -0
- package/dist/node/compiler/cache-config.d.ts.map +1 -0
- package/dist/node/compiler/cache-config.js +16 -0
- package/dist/node/compiler/dev-server.d.ts +4 -1
- package/dist/node/compiler/dev-server.d.ts.map +1 -0
- package/dist/node/compiler/dev-server.js +34 -11
- package/dist/node/compiler/get-vite-config.d.ts +12 -1
- package/dist/node/compiler/get-vite-config.d.ts.map +1 -0
- package/dist/node/compiler/get-vite-config.js +176 -42
- package/dist/node/compiler/vinxi-app.d.ts +13 -0
- package/dist/node/compiler/vinxi-app.d.ts.map +1 -0
- package/dist/node/compiler/vinxi-app.js +151 -32
- package/dist/node/compiler/vinxi-codegen.d.ts +1 -0
- package/dist/node/compiler/vinxi-codegen.d.ts.map +1 -0
- package/dist/node/compiler/vinxi-codegen.js +394 -108
- package/dist/node/graphql/graphql-codegen.d.ts +12 -1
- package/dist/node/graphql/graphql-codegen.d.ts.map +1 -0
- package/dist/node/graphql/graphql-codegen.js +239 -37
- 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 -16
- 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 +260 -69
- package/dist/node/project/config.d.ts.map +1 -0
- package/dist/node/project/config.js +100 -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 +5 -0
- package/dist/node/project/env.d.ts.map +1 -0
- package/dist/node/project/env.js +1 -0
- package/dist/node/project/favicons.d.ts +1 -1
- package/dist/node/project/favicons.d.ts.map +1 -0
- package/dist/node/project/favicons.js +1 -1
- 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 +6 -2
- 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 +2 -0
- package/dist/node/project/manifest/manifest.d.ts.map +1 -0
- package/dist/node/project/manifest/manifest.js +14 -10
- 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/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 +12 -0
- package/dist/node/project/project.d.ts.map +1 -0
- package/dist/node/project/project.js +55 -1
- 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 +10 -1
- 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 +37 -5
- 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 +1 -0
- package/dist/node/types/view-type.d.ts.map +1 -0
- 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/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 +4 -0
- package/dist/node/utils/fs-codegen.d.ts.map +1 -0
- package/dist/node/utils/fs-codegen.js +10 -2
- package/dist/node/utils/fs.d.ts +6 -1
- package/dist/node/utils/fs.d.ts.map +1 -0
- package/dist/node/utils/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/highlight-code.d.ts +1 -0
- package/dist/node/utils/highlight-code.d.ts.map +1 -0
- package/dist/node/utils/is-deploying.d.ts +1 -0
- package/dist/node/utils/is-deploying.d.ts.map +1 -0
- package/dist/node/utils/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 +5 -0
- package/dist/node/utils/self-signed-cert.d.ts.map +1 -0
- package/dist/node/utils/self-signed-cert.js +28 -4
- package/dist/node/utils/stateful-log.d.ts +1 -0
- package/dist/node/utils/stateful-log.d.ts.map +1 -0
- package/dist/node/utils/stateful-log.js +2 -0
- package/dist/node/utils/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 +18 -3
- package/dist/node/utils/watch-file-tree.d.ts.map +1 -0
- package/dist/node/utils/watch-file-tree.js +12 -5
- package/package.json +40 -24
- package/tsconfig.app.json +10 -5
- package/tsconfig.node.json +3 -2
- package/types.app.d.ts +2 -0
- package/types.env.d.ts +3 -0
- package/types.meta.d.ts +449 -136
- 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
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { camelCase, pascalCase } from "change-case-all";
|
|
2
|
+
import { code, imp } from "ts-poet";
|
|
3
|
+
import { ProjectEnvUtils } from "../project/env.js";
|
|
2
4
|
import { FSCodegen } from "../utils/fs-codegen.js";
|
|
5
|
+
import { getCacheConfig } from "./cache-config.js";
|
|
3
6
|
export function getVinxiFolder(opts) {
|
|
4
7
|
return (opts.mode === "development" ? "dev" : "prod") + (opts.serverless ? "" : "-spa");
|
|
5
8
|
}
|
|
@@ -17,28 +20,37 @@ export function createVinxiCodegen(opts) {
|
|
|
17
20
|
if (opts.serverless) {
|
|
18
21
|
codegen.registerFile({
|
|
19
22
|
name: "context.ts",
|
|
20
|
-
generate: () => {
|
|
23
|
+
generate: async () => {
|
|
21
24
|
const args = {
|
|
22
|
-
dev:
|
|
25
|
+
dev: opts.mode === "development",
|
|
23
26
|
origin: project.origin,
|
|
24
27
|
replaceUrls: {
|
|
25
28
|
from: project.origin,
|
|
26
29
|
to: opts.endpoint ?? "",
|
|
27
30
|
prefixes: [
|
|
28
|
-
{ prefix: "/wp-content/uploads", replace: project.config?.serverless.uploads === "
|
|
29
|
-
{ prefix: "/wp-content/plugins", replace: project.config?.serverless.plugins === "
|
|
31
|
+
{ prefix: "/wp-content/uploads", replace: project.config?.serverless.uploads === "remote" },
|
|
32
|
+
{ prefix: "/wp-content/plugins", replace: project.config?.serverless.plugins === "remote" },
|
|
30
33
|
],
|
|
31
34
|
},
|
|
35
|
+
rpcBases: (await project.serverRoutes.get()).bases ?? [],
|
|
36
|
+
config: project.config,
|
|
37
|
+
cacheConfig: getCacheConfig(project.origin, project.config),
|
|
32
38
|
};
|
|
33
39
|
return code /* tsx */ `
|
|
34
40
|
import { ServerContext } from "eddev/server"
|
|
35
41
|
import { getManifest } from "vinxi/manifest"
|
|
42
|
+
import { apiConfig } from 'eddev/hooks'
|
|
43
|
+
|
|
44
|
+
ServerContext.setRuntime({
|
|
45
|
+
getManifest
|
|
46
|
+
})
|
|
36
47
|
|
|
37
48
|
export const serverContext = new ServerContext({${Object.entries(args)
|
|
38
49
|
.map(([key, value]) => `${key}: ${JSON.stringify(value)}`)
|
|
39
|
-
.join(",\n")}
|
|
40
|
-
getManifest
|
|
50
|
+
.join(",\n")}
|
|
41
51
|
})
|
|
52
|
+
|
|
53
|
+
apiConfig.apiKey = ${JSON.stringify(ProjectEnvUtils.getSafe("SITE_API_KEY") ?? "")}
|
|
42
54
|
`.toString();
|
|
43
55
|
},
|
|
44
56
|
});
|
|
@@ -54,13 +66,31 @@ export function createVinxiCodegen(opts) {
|
|
|
54
66
|
`,
|
|
55
67
|
});
|
|
56
68
|
}
|
|
69
|
+
if (opts.serverless) {
|
|
70
|
+
// codegen.registerFile({
|
|
71
|
+
// name: "manifest/extra-routes.ts",
|
|
72
|
+
// generate: code/* tsx */ `
|
|
73
|
+
// import { createRouter, eventHandler, getRouterParam, getQuery, getWebRequest, getRequestHeaders } from "vinxi/http"
|
|
74
|
+
// import { serverContext } from "./context.js"
|
|
75
|
+
// export const routes = [
|
|
76
|
+
// {
|
|
77
|
+
// pattern: '/test1',
|
|
78
|
+
// handler: () => import('../../../test.ts')
|
|
79
|
+
// }
|
|
80
|
+
// ]
|
|
81
|
+
// export default eventHandler((event) => {
|
|
82
|
+
// routes
|
|
83
|
+
// })
|
|
84
|
+
// `,
|
|
85
|
+
// })
|
|
86
|
+
}
|
|
57
87
|
codegen.registerFile({
|
|
58
88
|
name: "entry.admin.tsx",
|
|
59
89
|
generate: () => {
|
|
60
90
|
return code /* tsx */ `
|
|
61
91
|
${opts.serverless ? `import "./react-shim.js"` : ""}
|
|
62
92
|
${opts.serverless ? `import "vinxi/client"` : ""}
|
|
63
|
-
import "
|
|
93
|
+
import "../../${project.cssEntryFile}"
|
|
64
94
|
import "./manifest/admin"
|
|
65
95
|
import "./manifest/blocks"
|
|
66
96
|
import "./manifest/styles"
|
|
@@ -85,7 +115,7 @@ export function createVinxiCodegen(opts) {
|
|
|
85
115
|
* Also ensures that the assets used during SSR are loaded.
|
|
86
116
|
*/
|
|
87
117
|
import "vinxi/client"
|
|
88
|
-
import "
|
|
118
|
+
import "../../${project.cssEntryFile}"
|
|
89
119
|
import "./manifest/blocks"
|
|
90
120
|
import "./manifest/views"
|
|
91
121
|
|
|
@@ -96,6 +126,16 @@ export function createVinxiCodegen(opts) {
|
|
|
96
126
|
import { createAssets } from "@vinxi/react"
|
|
97
127
|
import { devToolsStore } from 'eddev/devtools'
|
|
98
128
|
|
|
129
|
+
${process.env.VERCEL_SKEW_PROTECTION_ENABLED &&
|
|
130
|
+
code /* tsx*/ `
|
|
131
|
+
// Skew protection
|
|
132
|
+
const updateSkewCookie = () => {
|
|
133
|
+
document.cookie = "__vdpl=${process.env.VERCEL_DEPLOYMENT_ID}; expires=" + new Date(Date.now() + 24 * 60 * 60 * 1000).toUTCString() + "; path=/"
|
|
134
|
+
}
|
|
135
|
+
window.onfocus = updateSkewCookie
|
|
136
|
+
updateSkewCookie()
|
|
137
|
+
`}
|
|
138
|
+
|
|
99
139
|
// Set up a dynamic entry which will load the configured tailwind manifest
|
|
100
140
|
devToolsStore.loadTailwindConfig = () => import('./manifest/tailwind-config.js')
|
|
101
141
|
|
|
@@ -108,15 +148,17 @@ export function createVinxiCodegen(opts) {
|
|
|
108
148
|
window.$reactRoot =
|
|
109
149
|
window.$reactRoot ||
|
|
110
150
|
hydrateRoot(
|
|
111
|
-
document
|
|
112
|
-
<SSRClientRoot assets={getAssets()}
|
|
151
|
+
document.getElementById('root')!,
|
|
152
|
+
<React.Suspense><SSRClientRoot assets={getAssets()} metaTags={window._PAGE_DATA?.meta?.head} /></React.Suspense>,
|
|
153
|
+
{
|
|
154
|
+
identifierPrefix: "ed",
|
|
155
|
+
}
|
|
113
156
|
)
|
|
114
157
|
|
|
115
158
|
if (import.meta.hot) {
|
|
116
159
|
import.meta.hot.accept((mod) => {
|
|
117
160
|
if (mod) {
|
|
118
|
-
const
|
|
119
|
-
const app = <SSRClientRoot assets={getAssets()} />
|
|
161
|
+
const app = <React.Suspense><SSRClientRoot assets={getAssets()} metaTags={window._PAGE_DATA?.meta?.head} /></React.Suspense>
|
|
120
162
|
window.$reactRoot?.render(app)
|
|
121
163
|
}
|
|
122
164
|
})
|
|
@@ -125,6 +167,7 @@ export function createVinxiCodegen(opts) {
|
|
|
125
167
|
declare global {
|
|
126
168
|
interface Window {
|
|
127
169
|
$reactRoot?: Root
|
|
170
|
+
_PAGE_DATA: any
|
|
128
171
|
}
|
|
129
172
|
}
|
|
130
173
|
|
|
@@ -138,7 +181,7 @@ export function createVinxiCodegen(opts) {
|
|
|
138
181
|
*/
|
|
139
182
|
import "./manifest/blocks"
|
|
140
183
|
import "./manifest/views"
|
|
141
|
-
import "
|
|
184
|
+
import "../../${project.cssEntryFile}"
|
|
142
185
|
import { devToolsStore } from 'eddev/devtools'
|
|
143
186
|
import { createRoot } from "react-dom/client"
|
|
144
187
|
import { SPARoot } from "eddev/_internal/spa-root.js"
|
|
@@ -146,149 +189,293 @@ export function createVinxiCodegen(opts) {
|
|
|
146
189
|
|
|
147
190
|
devToolsStore.loadTailwindConfig = () => import('./manifest/tailwind-config')
|
|
148
191
|
|
|
149
|
-
createRoot(document.getElementById("root")!).render(<SPARoot
|
|
192
|
+
createRoot(document.getElementById("root")!).render(<React.Suspense><SPARoot /></React.Suspense>)
|
|
150
193
|
`;
|
|
151
194
|
}
|
|
152
195
|
},
|
|
153
196
|
});
|
|
154
197
|
if (opts.serverless) {
|
|
155
198
|
codegen.registerFile({
|
|
156
|
-
name: "handler.
|
|
199
|
+
name: "handler.bypass.ts",
|
|
157
200
|
generate: code /* tsx */ `
|
|
158
201
|
/// <reference types="vinxi/types/server" />
|
|
159
|
-
import { createRouter, eventHandler,
|
|
202
|
+
import { createRouter, eventHandler, getCookie, setCookie } from "vinxi/http"
|
|
203
|
+
|
|
204
|
+
const BYPASS_TOKEN = process.env.VERCEL_BYPASS_TOKEN
|
|
205
|
+
const COOKIE_NAME = "__prerender_bypass"
|
|
206
|
+
|
|
207
|
+
const router = createRouter()
|
|
208
|
+
.get(
|
|
209
|
+
"/enable",
|
|
210
|
+
eventHandler(async (event) => {
|
|
211
|
+
if (!BYPASS_TOKEN) return false
|
|
212
|
+
|
|
213
|
+
setCookie(event, COOKIE_NAME, BYPASS_TOKEN, {
|
|
214
|
+
expires: new Date(Date.now() + 1000 * 60 * 60 * 24),
|
|
215
|
+
})
|
|
216
|
+
|
|
217
|
+
return true
|
|
218
|
+
}),
|
|
219
|
+
)
|
|
220
|
+
.get(
|
|
221
|
+
"/disable",
|
|
222
|
+
eventHandler(async (event) => {
|
|
223
|
+
setCookie(event, COOKIE_NAME, "")
|
|
224
|
+
|
|
225
|
+
return true
|
|
226
|
+
}),
|
|
227
|
+
)
|
|
228
|
+
.get(
|
|
229
|
+
"/check",
|
|
230
|
+
eventHandler(async (event) => {
|
|
231
|
+
const cookie = getCookie(event, COOKIE_NAME)
|
|
232
|
+
|
|
233
|
+
if (cookie === BYPASS_TOKEN) {
|
|
234
|
+
return true
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
return false
|
|
238
|
+
}),
|
|
239
|
+
)
|
|
240
|
+
export default router.handler
|
|
241
|
+
`,
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
if (opts.serverless) {
|
|
245
|
+
codegen.registerFile({
|
|
246
|
+
name: "handler.ssr-page.ts",
|
|
247
|
+
generate: code /* tsx */ `
|
|
248
|
+
/// <reference types="vinxi/types/server" />
|
|
249
|
+
import "../../${project.cssEntryFile}"
|
|
250
|
+
import "./manifest/blocks.js"
|
|
251
|
+
import "./manifest/styles.js"
|
|
252
|
+
import "./manifest/views.js"
|
|
253
|
+
import "./context.js"
|
|
254
|
+
import { proxyWpAdmin, renderPage, renderPageForIndexing, ServerContext } from "eddev/server"
|
|
255
|
+
import {
|
|
256
|
+
createRouter,
|
|
257
|
+
eventHandler,
|
|
258
|
+
getQuery,
|
|
259
|
+
getRequestHeaders,
|
|
260
|
+
getRequestURL,
|
|
261
|
+
getRouterParam,
|
|
262
|
+
getWebRequest,
|
|
263
|
+
getCookie,
|
|
264
|
+
setCookie
|
|
265
|
+
} from "vinxi/http"
|
|
266
|
+
import { handleRPC } from "./rpc.js"
|
|
160
267
|
import { serverContext } from "./context.js"
|
|
268
|
+
import { getManifest } from "vinxi/manifest"
|
|
269
|
+
import { inspect } from "node:util"
|
|
270
|
+
import { withTrailingSlash } from 'ufo'
|
|
271
|
+
import { viewManifestReader, blockManifestReader } from 'eddev/_internal'
|
|
161
272
|
|
|
162
273
|
const router = createRouter()
|
|
163
274
|
.get(
|
|
164
|
-
"/route/",
|
|
275
|
+
"/_data/route/",
|
|
165
276
|
eventHandler(async (event) => {
|
|
166
277
|
const id = "/"
|
|
278
|
+
const url = getRequestURL(event)
|
|
167
279
|
|
|
168
|
-
return await serverContext.fetchRouteData({
|
|
169
|
-
pathname: id,
|
|
170
|
-
withAppData: false,
|
|
171
|
-
})
|
|
280
|
+
return await serverContext.fetchRouteData({ pathname: id, newOrigin: url.origin, bypass: serverContext.shouldBypass(event) })
|
|
172
281
|
}),
|
|
173
282
|
)
|
|
174
283
|
.get(
|
|
175
|
-
"/route/**:name",
|
|
284
|
+
"/_data/route/**:name",
|
|
176
285
|
eventHandler(async (event) => {
|
|
177
286
|
const id = "/" + getRouterParam(event, "name")
|
|
287
|
+
const url = getRequestURL(event)
|
|
178
288
|
|
|
179
|
-
return await serverContext.fetchRouteData({
|
|
180
|
-
pathname: id,
|
|
181
|
-
withAppData: false,
|
|
182
|
-
})
|
|
289
|
+
return await serverContext.fetchRouteData({ pathname: id, newOrigin: url.origin, bypass: serverContext.shouldBypass(event) })
|
|
183
290
|
}),
|
|
184
291
|
)
|
|
185
292
|
.get(
|
|
186
|
-
"/query/**:name",
|
|
293
|
+
"/_data/query/**:name",
|
|
187
294
|
eventHandler(async (event) => {
|
|
188
295
|
const id = "/" + getRouterParam(event, "name")
|
|
296
|
+
const url = getRequestURL(event)
|
|
189
297
|
const paramString = getQuery(event).params
|
|
190
298
|
|
|
191
|
-
const
|
|
299
|
+
const req = getWebRequest(event)
|
|
192
300
|
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
params:
|
|
196
|
-
|
|
197
|
-
|
|
301
|
+
let params = {}
|
|
302
|
+
try {
|
|
303
|
+
params = typeof paramString === "string" && paramString.length ? JSON.parse(paramString) : {}
|
|
304
|
+
} catch (e) {
|
|
305
|
+
throw new Error("Invalid query parameters")
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
return await serverContext.fetchNamedQuery({ name: id, newOrigin: url.origin, params: params, headers: getRequestHeaders(event), bypass: serverContext.shouldBypass(event) })
|
|
309
|
+
}),
|
|
310
|
+
)
|
|
311
|
+
.get(
|
|
312
|
+
"/_data/manifest/**:input",
|
|
313
|
+
eventHandler(async (event) => {
|
|
314
|
+
const manifest = getManifest("client")
|
|
315
|
+
const id = getRouterParam(event, "input")
|
|
316
|
+
const input = manifest.inputs[id === 'handler' ? manifest.handler : id]
|
|
317
|
+
const result = {
|
|
318
|
+
...input,
|
|
319
|
+
id,
|
|
320
|
+
assets: await input.assets(),
|
|
321
|
+
}
|
|
322
|
+
const code = inspect(result, { depth: 10 })
|
|
323
|
+
return new Response(code, { headers: { "Content-Type": "text/plain" } })
|
|
198
324
|
}),
|
|
199
325
|
)
|
|
200
326
|
.post(
|
|
201
|
-
"/mutation/**:name",
|
|
327
|
+
"/_data/mutation/**:name",
|
|
202
328
|
eventHandler(async (event) => {
|
|
203
329
|
const id = "/" + getRouterParam(event, "name")
|
|
204
330
|
const body = await getWebRequest(event).json()
|
|
205
|
-
return await serverContext.fetchMutation({
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
331
|
+
return await serverContext.fetchMutation({ name: id, body, headers: getRequestHeaders(event) })
|
|
332
|
+
}),
|
|
333
|
+
)
|
|
334
|
+
.post(
|
|
335
|
+
"/_data/submit-gf",
|
|
336
|
+
eventHandler(async (event) => {
|
|
337
|
+
const req = getWebRequest(event)
|
|
338
|
+
const headers = new Headers(req.headers)
|
|
339
|
+
headers.delete("content-length")
|
|
340
|
+
headers.delete("host")
|
|
341
|
+
headers.delete("connection")
|
|
342
|
+
headers.delete("pragma")
|
|
343
|
+
return await serverContext.fetchOrigin("/wp-json/ed/v1/gf/submit/", {
|
|
344
|
+
method: "POST",
|
|
345
|
+
headers: headers,
|
|
346
|
+
body: await req.blob(),
|
|
347
|
+
})
|
|
348
|
+
}),
|
|
349
|
+
)
|
|
350
|
+
|
|
351
|
+
const aiRouter = createRouter()
|
|
352
|
+
.get(
|
|
353
|
+
"/_ai/page",
|
|
354
|
+
eventHandler(async (event) => {
|
|
355
|
+
const id = "/"
|
|
356
|
+
const url = getRequestURL(event)
|
|
357
|
+
const page = await renderPageForIndexing({ pathname: id, newOrigin: url.origin, hostname: url.hostname })
|
|
358
|
+
return new Response(page.contents, {
|
|
359
|
+
headers: {
|
|
360
|
+
"Content-Type": "text/html; charset=utf-8",
|
|
361
|
+
"Cache-Control": "no-store",
|
|
362
|
+
},
|
|
363
|
+
})
|
|
364
|
+
}),
|
|
365
|
+
)
|
|
366
|
+
.get(
|
|
367
|
+
"/_ai/page/**:name",
|
|
368
|
+
eventHandler(async (event) => {
|
|
369
|
+
const id = "/" + getRouterParam(event, "name")
|
|
370
|
+
const url = getRequestURL(event)
|
|
371
|
+
|
|
372
|
+
const page = await renderPageForIndexing({ pathname: id, newOrigin: url.origin, hostname: url.hostname })
|
|
373
|
+
return new Response(page.contents, {
|
|
374
|
+
headers: {
|
|
375
|
+
"Content-Type": "text/html; charset=utf-8",
|
|
376
|
+
"Cache-Control": "no-store",
|
|
377
|
+
},
|
|
209
378
|
})
|
|
210
379
|
}),
|
|
211
380
|
)
|
|
212
381
|
|
|
213
|
-
export default
|
|
382
|
+
export default eventHandler({
|
|
383
|
+
handler: async (event) => {
|
|
384
|
+
const serverContext = ServerContext.main
|
|
385
|
+
const url = getRequestURL(event)
|
|
214
386
|
|
|
215
|
-
|
|
216
|
-
});
|
|
217
|
-
}
|
|
218
|
-
if (opts.serverless) {
|
|
219
|
-
codegen.registerFile({
|
|
220
|
-
name: "handler.ssr-page.ts",
|
|
221
|
-
generate: code /* tsx */ `
|
|
222
|
-
/// <reference types="vinxi/types/server" />
|
|
223
|
-
import "../../views/index.css"
|
|
224
|
-
import "./manifest/blocks.js"
|
|
225
|
-
import "./manifest/styles.js"
|
|
226
|
-
import "./manifest/views.js"
|
|
227
|
-
|
|
228
|
-
import { renderPageToSSRStream, proxyWpAdmin } from "eddev/server"
|
|
229
|
-
import { eventHandler, setResponseHeader, setResponseStatus, getRequestURL } from "vinxi/http"
|
|
230
|
-
import { serverContext } from "./context.js"
|
|
231
|
-
import { getManifest } from "vinxi/manifest"
|
|
232
|
-
|
|
233
|
-
export default eventHandler({
|
|
234
|
-
handler: async (event) => {
|
|
235
|
-
const url = getRequestURL(event)
|
|
236
|
-
|
|
237
|
-
if (url.pathname.includes('.')) {
|
|
238
|
-
return proxyWpAdmin(event, serverContext)
|
|
239
|
-
}
|
|
387
|
+
await Promise.allSettled([viewManifestReader.preloadAll(), blockManifestReader.preloadAll()])
|
|
240
388
|
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
389
|
+
// RPC
|
|
390
|
+
const isRPC = serverContext.rpcBases.some((base) => url.pathname.startsWith(base))
|
|
391
|
+
if (isRPC) {
|
|
392
|
+
return handleRPC(event)
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
// Data API
|
|
396
|
+
if (url.pathname.startsWith("/_data/")) {
|
|
397
|
+
return router.handler(event)
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
// LLM indexing route
|
|
401
|
+
if (url.pathname.startsWith("/_ai/")) {
|
|
402
|
+
return aiRouter.handler(event)
|
|
403
|
+
}
|
|
256
404
|
|
|
405
|
+
// Outdated build assets
|
|
406
|
+
if (url.pathname.match(/^\\/(_build|_admin)/)) {
|
|
407
|
+
return new Response("", { status: 404 })
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
// Proxy WordPress
|
|
411
|
+
if (url.pathname.includes(".") || url.pathname.startsWith("/graphql") || url.pathname.startsWith("/wp-")) {
|
|
412
|
+
return proxyWpAdmin(event)
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
// Enforce trailing slashes
|
|
416
|
+
if (!url.pathname.endsWith("/")) {
|
|
417
|
+
url.pathname = withTrailingSlash(url.pathname)
|
|
418
|
+
return Response.redirect(url, 301)
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
${process.env.VERCEL_SKEW_PROTECTION_ENABLED &&
|
|
422
|
+
code /* tsx*/ `
|
|
423
|
+
// Skew protection
|
|
424
|
+
setCookie(event, "__vdpl", ${JSON.stringify(process.env.VERCEL_DEPLOYMENT_ID ?? "")}, {
|
|
425
|
+
httpOnly: false,
|
|
426
|
+
path: "/",
|
|
427
|
+
})
|
|
428
|
+
`}
|
|
429
|
+
|
|
430
|
+
// SSR
|
|
431
|
+
return renderPage({ pathname: url.pathname, newOrigin: url.origin, hostname: url.hostname, bypass: serverContext.shouldBypass(event) })
|
|
432
|
+
},
|
|
433
|
+
})
|
|
257
434
|
`,
|
|
258
435
|
});
|
|
259
436
|
}
|
|
260
437
|
if (opts.serverless) {
|
|
261
|
-
codegen.registerFile({
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
});
|
|
438
|
+
// codegen.registerFile({
|
|
439
|
+
// name: "handler.wp-proxy.ts",
|
|
440
|
+
// generate: code/* tsx */ `
|
|
441
|
+
// /// <reference types="vinxi/types/server" />
|
|
442
|
+
// import { proxyWpAdmin } from "eddev/server"
|
|
443
|
+
// import { eventHandler } from "vinxi/http"
|
|
444
|
+
// import "./context.js"
|
|
445
|
+
// export default eventHandler(async (event) => {
|
|
446
|
+
// return proxyWpAdmin(event)
|
|
447
|
+
// })
|
|
448
|
+
// `,
|
|
449
|
+
// })
|
|
274
450
|
}
|
|
275
451
|
codegen.registerFile({
|
|
276
452
|
name: "manifest/blocks.ts",
|
|
277
453
|
generate: async () => {
|
|
278
454
|
const blockManifest = await project.blocks.get();
|
|
455
|
+
let blockImports = [];
|
|
456
|
+
let blockEntries = [];
|
|
457
|
+
for (const [name, block] of Object.entries(blockManifest.blocks)) {
|
|
458
|
+
if (name.match(/^_[a-z]+$/i))
|
|
459
|
+
continue;
|
|
460
|
+
const importSource = JSON.stringify("../../../" + block.fileName);
|
|
461
|
+
const jsName = pascalCase(name);
|
|
462
|
+
if (block.dynamic) {
|
|
463
|
+
const importStatement = `dynamic(() => import(${importSource}), ${JSON.stringify(block.fileName)})`;
|
|
464
|
+
blockEntries.push(JSON.stringify(block.acfName) + ": " + importStatement);
|
|
465
|
+
}
|
|
466
|
+
else {
|
|
467
|
+
blockImports.push(`import ${jsName} from ${importSource}`);
|
|
468
|
+
blockEntries.push(JSON.stringify(block.acfName) + ": " + jsName);
|
|
469
|
+
}
|
|
470
|
+
}
|
|
279
471
|
return code /* ts */ `
|
|
280
472
|
import { blockManifestReader } from 'eddev/_internal'
|
|
281
473
|
import { dynamic } from 'eddev/dynamic'
|
|
282
474
|
import core from '../../../blocks/_core'
|
|
475
|
+
${blockImports.join("\n")}
|
|
283
476
|
|
|
284
477
|
const manifest = {
|
|
285
|
-
${
|
|
286
|
-
.filter(([name]) => !name.match(/^_[a-z]+$/i))
|
|
287
|
-
.map(([name, block]) => {
|
|
288
|
-
const importStatement = `dynamic(() => import(${JSON.stringify("../../../" + block.fileName)}))`;
|
|
289
|
-
return JSON.stringify(block.acfName) + ": " + importStatement;
|
|
290
|
-
})
|
|
291
|
-
.join(",\n")},
|
|
478
|
+
${blockEntries.join(",\n")},
|
|
292
479
|
...core
|
|
293
480
|
}
|
|
294
481
|
|
|
@@ -369,14 +556,19 @@ export function createVinxiCodegen(opts) {
|
|
|
369
556
|
return code /* ts */ `
|
|
370
557
|
import { viewManifestReader } from 'eddev/_internal'
|
|
371
558
|
import { dynamic } from 'eddev/dynamic'
|
|
372
|
-
const manifest = {${Object.entries(viewManifest.views)
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
559
|
+
const manifest = {${Object.entries(viewManifest.views).map(([name, view]) => {
|
|
560
|
+
const src = "../../../" + view.fileName;
|
|
561
|
+
let importStatement;
|
|
562
|
+
if (name.startsWith("_")) {
|
|
563
|
+
importStatement = imp(name + "=" + src);
|
|
564
|
+
}
|
|
565
|
+
else {
|
|
566
|
+
importStatement = code `dynamic(() => import(${JSON.stringify(src)}), ${JSON.stringify(view.fileName)})`;
|
|
567
|
+
}
|
|
568
|
+
return code `${JSON.stringify(view.slug)}: ${importStatement},\n`;
|
|
569
|
+
})}}
|
|
570
|
+
|
|
571
|
+
viewManifestReader.set(manifest)
|
|
380
572
|
|
|
381
573
|
export default manifest
|
|
382
574
|
|
|
@@ -413,5 +605,99 @@ export function createVinxiCodegen(opts) {
|
|
|
413
605
|
`;
|
|
414
606
|
},
|
|
415
607
|
});
|
|
608
|
+
if (opts.serverless) {
|
|
609
|
+
codegen.registerFile({
|
|
610
|
+
name: "manifest/routes.ts",
|
|
611
|
+
generate: async () => {
|
|
612
|
+
const routeManifest = await project.serverRoutes.get();
|
|
613
|
+
return code /* ts */ `
|
|
614
|
+
import { instantiateRouter } from "eddev/server"
|
|
615
|
+
${routeManifest.contextFileName
|
|
616
|
+
? code /*ts*/ `
|
|
617
|
+
import createContext from "../../../${routeManifest.contextFileName}"
|
|
618
|
+
`
|
|
619
|
+
: code /*ts*/ `
|
|
620
|
+
const createContext = () => ({})
|
|
621
|
+
`}
|
|
622
|
+
|
|
623
|
+
const router = instantiateRouter({${Object.entries(routeManifest.routes).map(([name, route]) => {
|
|
624
|
+
const src = "../../../" + route.fileName;
|
|
625
|
+
const importStatement = imp(camelCase(name) + "=" + src);
|
|
626
|
+
return code `${JSON.stringify(route.prefix)}: ${importStatement},\n`;
|
|
627
|
+
})}})
|
|
628
|
+
|
|
629
|
+
export { createContext, router }
|
|
630
|
+
`;
|
|
631
|
+
},
|
|
632
|
+
subscribe: project.serverRoutes.subscribe,
|
|
633
|
+
});
|
|
634
|
+
codegen.registerFile({
|
|
635
|
+
name: "rpc.ts",
|
|
636
|
+
generate: code /* tsx */ `
|
|
637
|
+
/// <reference types="vinxi/types/server" />
|
|
638
|
+
import "./context.js"
|
|
639
|
+
import { fetchRequestHandler } from "@trpc/server/adapters/fetch"
|
|
640
|
+
import { parseURL, stringifyParsedURL } from "ufo"
|
|
641
|
+
import { EventHandlerRequest, getWebRequest, H3Event, setResponseHeaders } from "vinxi/http"
|
|
642
|
+
import { createContext, router } from "./manifest/routes.ts"
|
|
643
|
+
import { ServerContext } from "eddev/server"
|
|
644
|
+
|
|
645
|
+
export function handleRPC(event: H3Event<EventHandlerRequest>) {
|
|
646
|
+
const serverContext = ServerContext.main
|
|
647
|
+
|
|
648
|
+
// Handle CORS
|
|
649
|
+
setResponseHeaders(event, serverContext.getCorsHeaders(event.headers.get("origin") ?? event.headers.get("referer") ?? ""))
|
|
650
|
+
if (event.method === "OPTIONS") {
|
|
651
|
+
event.node.res.statusCode = 204
|
|
652
|
+
event.node.res.statusMessage = "No Content."
|
|
653
|
+
return "OK"
|
|
654
|
+
}
|
|
655
|
+
|
|
656
|
+
// Update URLs with dots, which tRPC prefers
|
|
657
|
+
const originalReq = getWebRequest(event)
|
|
658
|
+
const parsed = parseURL(originalReq.url)
|
|
659
|
+
parsed.pathname = "/" + parsed.pathname.replace(/(^\\/|\\/$)/g, "").replace(/\\//g, ".")
|
|
660
|
+
const req = new Request(stringifyParsedURL(parsed), originalReq)
|
|
661
|
+
|
|
662
|
+
// Handle any early results which are Responses
|
|
663
|
+
function processEarlyResult(value: any): Response | undefined {
|
|
664
|
+
if (value instanceof Response) {
|
|
665
|
+
return value
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
|
|
669
|
+
return new Promise(async (resolve) => {
|
|
670
|
+
let sent = false
|
|
671
|
+
const defaultResponse = await fetchRequestHandler({
|
|
672
|
+
endpoint: "/",
|
|
673
|
+
req: req,
|
|
674
|
+
router: router,
|
|
675
|
+
createContext: async (opts) => {
|
|
676
|
+
return {
|
|
677
|
+
...(await createContext(opts)),
|
|
678
|
+
searchParams: opts.info.url?.searchParams,
|
|
679
|
+
server: serverContext,
|
|
680
|
+
}
|
|
681
|
+
},
|
|
682
|
+
onError: (err) => console.error(err),
|
|
683
|
+
batching: { enabled: false },
|
|
684
|
+
// If a Response object is returned by a route, it will be sent as the response
|
|
685
|
+
responseMeta(opts) {
|
|
686
|
+
const value = opts?.data?.[0]?.["result"]?.["data"]
|
|
687
|
+
const response = processEarlyResult(value)
|
|
688
|
+
if (response) {
|
|
689
|
+
sent = true
|
|
690
|
+
resolve(response)
|
|
691
|
+
}
|
|
692
|
+
return {}
|
|
693
|
+
},
|
|
694
|
+
})
|
|
695
|
+
if (sent) return
|
|
696
|
+
resolve(defaultResponse)
|
|
697
|
+
})
|
|
698
|
+
}
|
|
699
|
+
`,
|
|
700
|
+
});
|
|
701
|
+
}
|
|
416
702
|
return codegen;
|
|
417
703
|
}
|