eddev 0.3.38 → 2.0.0-beta.10
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/bin/eddev.js +1 -3
- package/css/devtools.css +15 -0
- package/css/editor-styles.css +94 -0
- package/dist/app/entry/boot-admin.d.ts +1 -0
- package/dist/app/entry/boot-admin.js +8 -0
- package/dist/app/entry/spa-root.d.ts +1 -0
- package/dist/app/entry/spa-root.js +9 -0
- package/dist/app/entry/ssr-root-client.d.ts +4 -0
- package/dist/app/entry/ssr-root-client.js +9 -0
- package/dist/app/entry/ssr-root.d.ts +9 -0
- package/dist/app/entry/ssr-root.js +21 -0
- package/{admin → dist/app/lib/admin}/defineField.d.ts +2 -2
- package/dist/app/lib/admin/defineField.js +3 -0
- package/{admin → dist/app/lib/admin}/defineWidget.d.ts +1 -1
- package/dist/app/lib/admin/defineWidget.js +6 -0
- package/dist/app/lib/admin/index.d.ts +2 -0
- package/dist/app/lib/admin/index.js +2 -0
- package/dist/app/lib/admin/installFieldTypes.js +92 -0
- package/dist/app/lib/admin/runWidgets.js +38 -0
- package/dist/app/lib/blocks/ContentBlocks.d.ts +83 -0
- package/dist/app/lib/blocks/ContentBlocks.js +92 -0
- package/dist/app/lib/blocks/EditableText.d.ts +41 -0
- package/dist/app/lib/blocks/EditableText.js +50 -0
- package/{blocks → dist/app/lib/blocks}/ErrorBoundaryFrontend.d.ts +2 -2
- package/dist/app/lib/blocks/ErrorBoundaryFrontend.js +35 -0
- package/dist/app/lib/blocks/InnerBlocks.d.ts +42 -0
- package/dist/app/lib/blocks/InnerBlocks.js +55 -0
- package/dist/app/lib/blocks/block-utils.d.ts +24 -0
- package/dist/app/lib/blocks/block-utils.js +41 -0
- package/dist/app/lib/blocks/defineBlock.d.ts +2 -0
- package/dist/app/lib/blocks/defineBlock.js +3 -0
- package/dist/app/lib/blocks/editor/EditorSupport.d.ts +5 -0
- package/dist/app/lib/blocks/editor/EditorSupport.js +19 -0
- package/{blocks → dist/app/lib/blocks/editor}/ErrorBoundaryEditor.d.ts +1 -1
- package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.js +28 -0
- package/dist/app/lib/blocks/editor/block-templates.d.ts +3 -0
- package/dist/app/lib/blocks/editor/block-templates.js +9 -0
- package/dist/app/lib/blocks/editor/blocks-by-tag.d.ts +7 -0
- package/dist/app/lib/blocks/editor/blocks-by-tag.js +42 -0
- package/dist/app/lib/blocks/editor/controls.d.ts +10 -0
- package/dist/app/lib/blocks/editor/controls.js +20 -0
- package/dist/app/lib/blocks/editor/editor-config.d.ts +58 -0
- package/dist/app/lib/blocks/editor/editor-config.js +191 -0
- package/dist/app/lib/blocks/editor/installGutenbergHooks.d.ts +2 -0
- package/dist/app/lib/blocks/editor/installGutenbergHooks.js +131 -0
- package/dist/app/lib/blocks/editor/usePostEditor.d.ts +27 -0
- package/dist/app/lib/blocks/editor/usePostEditor.js +79 -0
- package/dist/app/lib/blocks/index.d.ts +9 -0
- package/dist/app/lib/blocks/index.js +9 -0
- package/dist/app/lib/blocks/inline-editing.d.ts +54 -0
- package/dist/app/lib/blocks/inline-editing.js +114 -0
- package/dist/app/lib/devtools/components/BreakpointIndicator.js +81 -0
- package/{dev-ui → dist/app/lib/devtools}/components/DevUI.d.ts +1 -0
- package/dist/app/lib/devtools/components/DevUI.js +6 -0
- package/dist/app/lib/devtools/dev-tools-store.d.ts +9 -0
- package/dist/app/lib/devtools/dev-tools-store.js +8 -0
- package/dist/app/lib/devtools/hooks/usePersistState.js +31 -0
- package/dist/app/lib/devtools/hooks/useTailwind.d.ts +4183 -0
- package/dist/app/lib/devtools/hooks/useTailwind.js +9 -0
- package/dist/app/lib/devtools/index.d.ts +1 -0
- package/dist/app/lib/devtools/index.js +1 -0
- package/dist/app/lib/devtools/loader.js +23 -0
- package/dist/app/lib/devtools/tailwind.config.d.ts +23 -0
- package/dist/app/lib/devtools/tailwind.config.js +24 -0
- package/{hooks → dist/app/lib/devtools}/useQueryDebug.d.ts +1 -1
- package/dist/app/lib/devtools/useQueryDebug.js +13 -0
- package/dist/app/lib/dynamic/dynamic.d.ts +8 -0
- package/dist/app/lib/dynamic/dynamic.js +25 -0
- package/dist/app/lib/dynamic/index.d.ts +1 -0
- package/dist/app/lib/dynamic/index.js +1 -0
- package/dist/app/lib/hooks/apiConfig.d.ts +18 -0
- package/dist/app/lib/hooks/apiConfig.js +4 -0
- package/{hooks → dist/app/lib/hooks}/index.d.ts +2 -0
- package/dist/app/lib/hooks/index.js +5 -0
- package/dist/app/lib/hooks/queryUtils.d.ts +49 -0
- package/dist/app/lib/hooks/queryUtils.js +180 -0
- package/dist/app/lib/hooks/useAppData.d.ts +4 -0
- package/dist/app/lib/hooks/useAppData.js +11 -0
- package/{hooks → dist/app/lib/hooks}/usePageLoad.d.ts +1 -1
- package/dist/app/lib/hooks/usePageLoad.js +5 -0
- package/dist/app/lib/hooks/useRPC.d.ts +9 -0
- package/dist/app/lib/hooks/useRPC.js +9 -0
- package/dist/app/lib/internal/index.d.ts +4 -0
- package/dist/app/lib/internal/index.js +4 -0
- package/dist/app/lib/internal/internal-store.d.ts +9 -0
- package/dist/app/lib/internal/internal-store.js +7 -0
- package/dist/app/lib/internal/read-admin-manifest.d.ts +19 -0
- package/dist/app/lib/internal/read-admin-manifest.js +17 -0
- package/dist/app/lib/internal/read-block-manifest.d.ts +15 -0
- package/dist/app/lib/internal/read-block-manifest.js +16 -0
- package/dist/app/lib/internal/read-view-manifest.d.ts +12 -0
- package/dist/app/lib/internal/read-view-manifest.js +3 -0
- package/dist/app/lib/legacy-stitches/createStitches.d.ts +615 -0
- package/dist/app/lib/legacy-stitches/createStitches.js +439 -0
- package/dist/app/lib/legacy-stitches/index.js +1 -0
- package/{components → dist/app/lib/routing/components}/BrowserRouter.d.ts +2 -4
- package/dist/app/lib/routing/components/BrowserRouter.js +351 -0
- package/dist/app/lib/routing/components/ClientOnly.d.ts +12 -0
- package/dist/app/lib/routing/components/ClientOnly.js +14 -0
- package/dist/app/lib/routing/components/Link.d.ts +26 -0
- package/dist/app/lib/routing/components/Link.js +93 -0
- package/dist/app/lib/routing/components/RouteRenderer.d.ts +9 -0
- package/dist/app/lib/routing/components/RouteRenderer.js +28 -0
- package/dist/app/lib/routing/components/SSRRouter.d.ts +9 -0
- package/dist/app/lib/routing/components/SSRRouter.js +14 -0
- package/dist/app/lib/routing/components/ScrollRestoration.d.ts +15 -0
- package/dist/app/lib/routing/components/ScrollRestoration.js +32 -0
- package/dist/app/lib/routing/context.d.ts +5 -0
- package/dist/app/lib/routing/context.js +129 -0
- package/dist/app/lib/routing/hooks/useIsSSR.d.ts +8 -0
- package/dist/app/lib/routing/hooks/useIsSSR.js +22 -0
- package/dist/app/lib/routing/hooks/useRestorableState.d.ts +5 -0
- package/dist/app/lib/routing/hooks/useRestorableState.js +17 -0
- package/dist/app/lib/routing/hooks/useRoute.d.ts +2 -0
- package/dist/app/lib/routing/hooks/useRoute.js +5 -0
- package/dist/app/lib/routing/hooks/useRouteTransition.d.ts +4 -0
- package/dist/app/lib/routing/hooks/useRouteTransition.js +12 -0
- package/dist/app/lib/routing/hooks/useRouter.d.ts +2 -0
- package/dist/app/lib/routing/hooks/useRouter.js +11 -0
- package/dist/app/lib/routing/hooks/useRouterEvents.d.ts +2 -0
- package/dist/app/lib/routing/hooks/useRouterEvents.js +10 -0
- package/dist/app/lib/routing/hooks/useRouterState.d.ts +2 -0
- package/dist/app/lib/routing/hooks/useRouterState.js +8 -0
- package/dist/app/lib/routing/hooks/useSearchParams.d.ts +10 -0
- package/dist/app/lib/routing/hooks/useSearchParams.js +30 -0
- package/dist/app/lib/routing/index.d.ts +13 -0
- package/dist/app/lib/routing/index.js +13 -0
- package/dist/app/lib/routing/loader.d.ts +30 -0
- package/dist/app/lib/routing/loader.js +108 -0
- package/dist/app/lib/routing/types.d.ts +138 -0
- package/dist/app/lib/routing/utils.d.ts +15 -0
- package/dist/app/lib/routing/utils.js +94 -0
- package/dist/app/lib/views/defineView.d.ts +4 -0
- package/dist/app/lib/views/defineView.js +3 -0
- package/dist/app/lib/views/index.js +1 -0
- package/dist/app/server/index.d.ts +3 -0
- package/dist/app/server/index.js +3 -0
- package/dist/app/server/proxy-wp-admin.d.ts +3 -0
- package/dist/app/server/proxy-wp-admin.js +106 -0
- package/dist/app/server/render-ssr-page.d.ts +2 -0
- package/dist/app/server/render-ssr-page.js +22 -0
- package/dist/app/server/server-context.d.ts +34 -0
- package/dist/app/server/server-context.js +116 -0
- package/dist/app/server/utils/headers.d.ts +5 -0
- package/dist/app/server/utils/headers.js +28 -0
- package/dist/app/server/utils/index.html.d.ts +2 -0
- package/dist/app/server/utils/index.html.js +14 -0
- package/dist/app/server/utils/replace-host.d.ts +10 -0
- package/dist/app/server/utils/replace-host.js +61 -0
- package/dist/app/utils/query-client.d.ts +2 -0
- package/dist/app/utils/query-client.js +16 -0
- package/dist/app/utils/wp.d.ts +26 -0
- package/dist/node/cli/cli-mode.d.ts +10 -0
- package/dist/node/cli/cli-mode.js +12 -0
- package/dist/node/cli/cli-worker.d.ts +13 -0
- package/dist/node/cli/cli-worker.js +117 -0
- package/dist/node/cli/cli.js +197 -0
- package/dist/node/cli/display/CLIApp.d.ts +16 -0
- package/dist/node/cli/display/CLIApp.js +117 -0
- package/dist/node/cli/display/boot-cli-app.d.ts +2 -0
- package/dist/node/cli/display/boot-cli-app.js +10 -0
- package/{cli → dist/node/cli}/display/components/Fullscreen.d.ts +1 -1
- package/dist/node/cli/display/components/Fullscreen.js +24 -0
- package/dist/node/cli/display/components/LogEntries.d.ts +13 -0
- package/dist/node/cli/display/components/LogEntries.js +87 -0
- package/dist/node/cli/display/components/MenuItem.d.ts +6 -0
- package/dist/node/cli/display/components/MenuItem.js +11 -0
- package/dist/node/cli/display/components/TextInput.d.ts +44 -0
- package/dist/node/cli/display/components/TextInput.js +105 -0
- package/dist/node/cli/display/hooks/useManifest.d.ts +2 -0
- package/dist/node/cli/display/hooks/useManifest.js +8 -0
- package/dist/node/cli/display/hooks/useStatefulLog.d.ts +11 -0
- package/dist/node/cli/display/hooks/useStatefulLog.js +51 -0
- package/dist/node/cli/display/tools/BlockList.d.ts +2 -0
- package/dist/node/cli/display/tools/BlockList.js +10 -0
- package/dist/node/cli/display/tools/CreateBlock.d.ts +2 -0
- package/dist/node/cli/display/tools/CreateBlock.js +8 -0
- package/dist/node/cli/display/tools/cli-tool-list.d.ts +2 -0
- package/dist/node/cli/display/tools/cli-tool-list.js +23 -0
- package/dist/node/cli/display/tools/cli-tools.d.ts +26 -0
- package/dist/node/cli/display/tools/cli-tools.js +15 -0
- package/dist/node/cli/display/util/colors.d.ts +4 -0
- package/dist/node/cli/display/util/colors.js +63 -0
- package/dist/node/cli/version.d.ts +1 -0
- package/dist/node/cli/version.js +1 -0
- package/dist/node/compiler/build-vinxi.d.ts +8 -0
- package/dist/node/compiler/build-vinxi.js +37 -0
- package/dist/node/compiler/bundler.admin.d.ts +13 -0
- package/dist/node/compiler/bundler.admin.js +37 -0
- package/dist/node/compiler/bundler.frontend.d.ts +13 -0
- package/dist/node/compiler/bundler.frontend.js +37 -0
- package/dist/node/compiler/dev-server.d.ts +18 -0
- package/dist/node/compiler/dev-server.js +97 -0
- package/dist/node/compiler/get-vite-config.d.ts +19 -0
- package/dist/node/compiler/get-vite-config.js +184 -0
- package/dist/node/compiler/vinxi-app.d.ts +10 -0
- package/dist/node/compiler/vinxi-app.js +121 -0
- package/dist/node/compiler/vinxi-codegen.d.ts +12 -0
- package/dist/node/compiler/vinxi-codegen.js +408 -0
- package/dist/node/graphql/graphql-codegen.d.ts +30 -0
- package/dist/node/graphql/graphql-codegen.js +503 -0
- package/dist/node/graphql/graphql-schema-loader.d.ts +17 -0
- package/dist/node/graphql/graphql-schema-loader.js +91 -0
- package/dist/node/graphql/plugins/gql-plugin-files.d.ts +14 -0
- package/dist/node/graphql/plugins/gql-plugin-files.js +66 -0
- package/dist/node/graphql/plugins/gql-plugin-no-duplicates.d.ts +8 -0
- package/dist/node/graphql/plugins/gql-plugin-no-duplicates.js +10 -0
- package/dist/node/graphql/plugins/gql-plugin-queries.d.ts +8 -0
- package/dist/node/graphql/plugins/gql-plugin-queries.js +263 -0
- package/dist/node/graphql/query-files-loader.d.ts +26 -0
- package/dist/node/graphql/query-files-loader.js +54 -0
- package/dist/node/graphql/wp-info-query.d.ts +1 -0
- package/dist/node/graphql/wp-info-query.js +29 -0
- package/{config/config-schema.d.ts → dist/node/project/config.d.ts} +54 -38
- package/dist/node/project/config.js +138 -0
- package/dist/node/project/eddev-build-file.d.ts +10 -0
- package/dist/node/project/eddev-build-file.js +79 -0
- package/dist/node/project/env.d.ts +39 -0
- package/dist/node/project/env.js +77 -0
- package/dist/node/project/favicons.js +1 -0
- package/dist/node/project/manifest/block-manifest.d.ts +19 -0
- package/dist/node/project/manifest/block-manifest.js +206 -0
- package/dist/node/project/manifest/field-manifest.d.ts +17 -0
- package/dist/node/project/manifest/field-manifest.js +42 -0
- package/dist/node/project/manifest/manifest.d.ts +30 -0
- package/dist/node/project/manifest/manifest.js +105 -0
- package/dist/node/project/manifest/view-manifest.d.ts +19 -0
- package/dist/node/project/manifest/view-manifest.js +152 -0
- package/dist/node/project/manifest/widget-manifest.d.ts +17 -0
- package/dist/node/project/manifest/widget-manifest.js +42 -0
- package/dist/node/project/project.d.ts +58 -0
- package/dist/node/project/project.js +113 -0
- package/dist/node/project/wp-info.d.ts +32 -0
- package/dist/node/project/wp-info.js +32 -0
- package/dist/node/types/block-type.d.ts +92 -0
- package/dist/node/types/block-type.js +82 -0
- package/dist/node/types/view-type.d.ts +31 -0
- package/dist/node/types/view-type.js +53 -0
- package/dist/node/utils/format-zod-error.d.ts +3 -0
- package/dist/node/utils/format-zod-error.js +33 -0
- package/dist/node/utils/fs-codegen.d.ts +40 -0
- package/dist/node/utils/fs-codegen.js +97 -0
- package/dist/node/utils/fs.d.ts +106 -0
- package/dist/node/utils/fs.js +58 -0
- package/dist/node/utils/get-repo-info.d.ts +7 -0
- package/dist/node/utils/get-repo-info.js +21 -0
- package/dist/node/utils/helpers.d.ts +2 -0
- package/dist/node/utils/helpers.js +14 -0
- package/dist/node/utils/highlight-code.d.ts +10 -0
- package/dist/node/utils/highlight-code.js +30 -0
- package/dist/node/utils/is-deploying.d.ts +4 -0
- package/dist/node/utils/is-deploying.js +6 -0
- package/dist/node/utils/report-builder.d.ts +9 -0
- package/dist/node/utils/report-builder.js +51 -0
- package/dist/node/utils/self-signed-cert.d.ts +4 -0
- package/dist/node/utils/self-signed-cert.js +35 -0
- package/dist/node/utils/stateful-log.d.ts +65 -0
- package/dist/node/utils/stateful-log.js +223 -0
- package/dist/node/utils/ts-export-extractor.d.ts +9 -0
- package/dist/node/utils/ts-export-extractor.js +71 -0
- package/dist/node/utils/watch-file-tree.d.ts +11 -0
- package/dist/node/utils/watch-file-tree.js +58 -0
- package/package.json +121 -102
- package/stitches-archive/config.d.ts +210 -0
- package/stitches-archive/css-util.d.ts +119 -0
- package/stitches-archive/css.d.ts +9797 -0
- package/stitches-archive/index.d.mts +144 -0
- package/stitches-archive/index.d.ts +82 -0
- package/stitches-archive/index.mjs +2 -0
- package/stitches-archive/stitches.d.ts +288 -0
- package/stitches-archive/styled-component.d.ts +163 -0
- package/stitches-archive/theme.d.ts +43 -0
- package/stitches-archive/util.d.ts +32 -0
- package/tsconfig.app.json +20 -0
- package/tsconfig.json +2 -104
- package/tsconfig.node.json +20 -0
- package/types.app.d.ts +22 -0
- package/types.app.internal.d.ts +13 -0
- package/types.env.d.ts +16 -0
- package/types.meta.d.ts +319 -0
- package/types.node.d.ts +3 -0
- package/admin/components/FileWell.d.ts +0 -8
- package/admin/components/FileWell.js +0 -189
- package/admin/components/ImageWell.d.ts +0 -9
- package/admin/components/ImageWell.js +0 -209
- package/admin/defineField.js +0 -7
- package/admin/defineWidget.js +0 -10
- package/admin/index.d.ts +0 -4
- package/admin/index.js +0 -16
- package/admin/installFieldTypes.js +0 -71
- package/admin/runWidgets.js +0 -55
- package/admin/selectMedia.d.ts +0 -31
- package/admin/selectMedia.js +0 -9
- package/blocks/ContentBlocks.d.ts +0 -40
- package/blocks/ContentBlocks.js +0 -125
- package/blocks/ErrorBoundaryEditor.js +0 -64
- package/blocks/ErrorBoundaryFrontend.js +0 -69
- package/blocks/InspectorControls.d.ts +0 -2
- package/blocks/InspectorControls.js +0 -13
- package/blocks/blockAttributes.d.ts +0 -20
- package/blocks/blockAttributes.js +0 -81
- package/blocks/defineBlock.d.ts +0 -2
- package/blocks/defineBlock.js +0 -7
- package/blocks/index.d.ts +0 -5
- package/blocks/index.js +0 -23
- package/blocks/inlineEditing.d.ts +0 -32
- package/blocks/inlineEditing.js +0 -141
- package/blocks/installGutenbergHooks.d.ts +0 -2
- package/blocks/installGutenbergHooks.js +0 -211
- package/build/babel/plugin-name-defined-components.d.ts +0 -7
- package/build/babel/plugin-name-defined-components.js +0 -47
- package/build/build-favicon.d.ts +0 -1
- package/build/build-favicon.js +0 -71
- package/build/clean.d.ts +0 -1
- package/build/clean.js +0 -60
- package/build/create-codegen-worker.d.ts +0 -3
- package/build/create-codegen-worker.js +0 -71
- package/build/create-serverless-dev-worker.d.ts +0 -3
- package/build/create-serverless-dev-worker.js +0 -99
- package/build/create-webpack-worker.d.ts +0 -3
- package/build/create-webpack-worker.js +0 -64
- package/build/file-tree.d.ts +0 -5
- package/build/file-tree.js +0 -45
- package/build/get-webpack-config.d.ts +0 -3
- package/build/get-webpack-config.js +0 -426
- package/build/graphql-codegen/graphql-codegen-blocks.d.ts +0 -1
- package/build/graphql-codegen/graphql-codegen-blocks.js +0 -7
- package/build/graphql-codegen/graphql-codegen-files.js +0 -64
- package/build/graphql-codegen/graphql-codegen-no-duplicates.js +0 -13
- package/build/graphql-codegen/graphql-codegen-queries.d.ts +0 -1
- package/build/graphql-codegen/graphql-codegen-queries.js +0 -248
- package/build/manifests/manifest-blocks.d.ts +0 -12
- package/build/manifests/manifest-blocks.js +0 -61
- package/build/manifests/manifest-fields.d.ts +0 -12
- package/build/manifests/manifest-fields.js +0 -42
- package/build/manifests/manifest-views.d.ts +0 -12
- package/build/manifests/manifest-views.js +0 -49
- package/build/manifests/manifest-widgets.d.ts +0 -12
- package/build/manifests/manifest-widgets.js +0 -42
- package/build/manifests/manifest.d.ts +0 -11
- package/build/manifests/manifest.js +0 -100
- package/build/reporter.d.ts +0 -12
- package/build/reporter.js +0 -102
- package/build/serverless/create-next-app.d.ts +0 -9
- package/build/serverless/create-next-app.js +0 -536
- package/build/state/codegen-state.d.ts +0 -32
- package/build/state/codegen-state.js +0 -2
- package/build/state/compiler-state.d.ts +0 -49
- package/build/state/compiler-state.js +0 -2
- package/build/state/serverless-state.d.ts +0 -26
- package/build/state/serverless-state.js +0 -2
- package/build/workers/codegen-worker-script.d.ts +0 -2
- package/build/workers/codegen-worker-script.js +0 -624
- package/build/workers/serverless-worker-dev-script.d.ts +0 -1
- package/build/workers/serverless-worker-dev-script.js +0 -21
- package/build/workers/webpack-worker-script.d.ts +0 -2
- package/build/workers/webpack-worker-script.js +0 -171
- package/cli/build.dev.d.ts +0 -7
- package/cli/build.dev.js +0 -136
- package/cli/build.prod.d.ts +0 -5
- package/cli/build.prod.js +0 -107
- package/cli/cli.js +0 -90
- package/cli/display/components/BundleDisplay.d.ts +0 -5
- package/cli/display/components/BundleDisplay.js +0 -56
- package/cli/display/components/CodegenDisplay.d.ts +0 -5
- package/cli/display/components/CodegenDisplay.js +0 -62
- package/cli/display/components/DevCLIDisplay.d.ts +0 -12
- package/cli/display/components/DevCLIDisplay.js +0 -42
- package/cli/display/components/Fullscreen.js +0 -39
- package/cli/display/components/ServerlessDisplay.d.ts +0 -8
- package/cli/display/components/ServerlessDisplay.js +0 -68
- package/cli/display/components/StatusIcon.d.ts +0 -5
- package/cli/display/components/StatusIcon.js +0 -9
- package/cli/preinstall.d.ts +0 -1
- package/cli/preinstall.js +0 -19
- package/cli/setup.d.ts +0 -1
- package/cli/setup.js +0 -90
- package/components/AdminBar.d.ts +0 -1
- package/components/AdminBar.js +0 -9
- package/components/BrowserRouter.js +0 -155
- package/components/InlinePage.d.ts +0 -11
- package/components/InlinePage.js +0 -70
- package/components/NextRouter.d.ts +0 -9
- package/components/NextRouter.js +0 -45
- package/components/index.d.ts +0 -2
- package/components/index.js +0 -14
- package/config/config-schema.js +0 -38
- package/config/create-schema-file.d.ts +0 -1
- package/config/create-schema-file.js +0 -20
- package/config/get-config.d.ts +0 -78
- package/config/get-config.js +0 -32
- package/config/index.d.ts +0 -2
- package/config/index.js +0 -14
- package/config/parse-config.d.ts +0 -51
- package/config/parse-config.js +0 -8
- package/config/print-zod-errors.d.ts +0 -2
- package/config/print-zod-errors.js +0 -14
- package/dev-ui/components/BreakpointColumnHeader.d.ts +0 -10
- package/dev-ui/components/BreakpointColumnHeader.js +0 -47
- package/dev-ui/components/BreakpointIndicator.js +0 -139
- package/dev-ui/components/DevUI.js +0 -28
- package/dev-ui/components/Launcher.d.ts +0 -98
- package/dev-ui/components/Launcher.js +0 -94
- package/dev-ui/components/PanelWrapper.d.ts +0 -8
- package/dev-ui/components/PanelWrapper.js +0 -37
- package/dev-ui/components/ResponsiveLerpControl.d.ts +0 -7
- package/dev-ui/components/ResponsiveLerpControl.js +0 -176
- package/dev-ui/components/ResponsiveScaleEditor.d.ts +0 -25
- package/dev-ui/components/ResponsiveScaleEditor.js +0 -238
- package/dev-ui/components/atoms/Button.d.ts +0 -47
- package/dev-ui/components/atoms/Button.js +0 -67
- package/dev-ui/components/atoms/Dropdown.d.ts +0 -13
- package/dev-ui/components/atoms/Dropdown.js +0 -50
- package/dev-ui/components/atoms/NumberField.d.ts +0 -11
- package/dev-ui/components/atoms/NumberField.js +0 -111
- package/dev-ui/components/atoms/Spacer.d.ts +0 -42
- package/dev-ui/components/atoms/Spacer.js +0 -8
- package/dev-ui/components/atoms/Text.d.ts +0 -45
- package/dev-ui/components/atoms/Text.js +0 -39
- package/dev-ui/components/atoms/ToggleButton.d.ts +0 -8
- package/dev-ui/components/atoms/ToggleButton.js +0 -41
- package/dev-ui/components/atoms/Tooltip.d.ts +0 -9
- package/dev-ui/components/atoms/Tooltip.js +0 -66
- package/dev-ui/components/panels/AppDataDebugger.d.ts +0 -1
- package/dev-ui/components/panels/AppDataDebugger.js +0 -29
- package/dev-ui/components/panels/ColorEditor.d.ts +0 -1
- package/dev-ui/components/panels/ColorEditor.js +0 -128
- package/dev-ui/components/panels/PageDataDebugger.d.ts +0 -1
- package/dev-ui/components/panels/PageDataDebugger.js +0 -30
- package/dev-ui/components/panels/QueryDebugger.d.ts +0 -1
- package/dev-ui/components/panels/QueryDebugger.js +0 -46
- package/dev-ui/components/panels/SpacingEditor.d.ts +0 -1
- package/dev-ui/components/panels/SpacingEditor.js +0 -88
- package/dev-ui/components/panels/TypographyEditor.d.ts +0 -1
- package/dev-ui/components/panels/TypographyEditor.js +0 -97
- package/dev-ui/hooks/useBreakpoint.d.ts +0 -11
- package/dev-ui/hooks/useBreakpoint.js +0 -59
- package/dev-ui/hooks/usePersistState.js +0 -36
- package/dev-ui/hooks/useStylesheet.d.ts +0 -4
- package/dev-ui/hooks/useStylesheet.js +0 -31
- package/dev-ui/icons.d.ts +0 -15
- package/dev-ui/icons.js +0 -30
- package/dev-ui/index.d.ts +0 -1
- package/dev-ui/index.js +0 -13
- package/dev-ui/loader.js +0 -44
- package/dev-ui/panels.d.ts +0 -11
- package/dev-ui/panels.js +0 -47
- package/dev-ui/theme.d.ts +0 -151
- package/dev-ui/theme.js +0 -50
- package/dynamic/dynamic-component.d.ts +0 -10
- package/dynamic/dynamic-component.js +0 -8
- package/dynamic/index.d.ts +0 -1
- package/dynamic/index.js +0 -13
- package/entry/Root.d.ts +0 -3
- package/entry/Root.js +0 -56
- package/entry/entry.admin.dev.d.ts +0 -1
- package/entry/entry.admin.dev.js +0 -26
- package/entry/entry.admin.prod.d.ts +0 -1
- package/entry/entry.admin.prod.js +0 -16
- package/entry/entry.monolith.dev.d.ts +0 -6
- package/entry/entry.monolith.dev.js +0 -19
- package/entry/entry.monolith.prod.d.ts +0 -6
- package/entry/entry.monolith.prod.js +0 -18
- package/entry/entry.publicPath.js +0 -6
- package/gravityforms/index.d.ts +0 -2
- package/gravityforms/index.js +0 -14
- package/gravityforms/types.d.ts +0 -140
- package/gravityforms/types.js +0 -2
- package/gravityforms/useGravityForm.d.ts +0 -30
- package/gravityforms/useGravityForm.js +0 -292
- package/hooks/index.js +0 -15
- package/hooks/queryUtils.d.ts +0 -63
- package/hooks/queryUtils.js +0 -281
- package/hooks/useAppData.d.ts +0 -10
- package/hooks/useAppData.js +0 -37
- package/hooks/usePageLoad.js +0 -11
- package/hooks/useQuery.d.ts +0 -1
- package/hooks/useQuery.js +0 -10
- package/hooks/useQueryDebug.js +0 -21
- package/hooks/useRPC.d.ts +0 -12
- package/hooks/useRPC.js +0 -20
- package/index.d.ts +0 -1
- package/index.js +0 -5
- package/routing/index.d.ts +0 -1
- package/routing/index.js +0 -13
- package/routing/remoteProps.d.ts +0 -22
- package/routing/remoteProps.js +0 -103
- package/routing/routing.d.ts +0 -96
- package/routing/routing.js +0 -442
- package/routing/updateEditLink.d.ts +0 -1
- package/routing/updateEditLink.js +0 -12
- package/routing/updateHeadTags.d.ts +0 -2
- package/routing/updateHeadTags.js +0 -11
- package/serverless/define-api.d.ts +0 -2
- package/serverless/define-api.js +0 -66
- package/serverless/define-rpc-router.d.ts +0 -6
- package/serverless/define-rpc-router.js +0 -35
- package/serverless/error-codes.d.ts +0 -2
- package/serverless/error-codes.js +0 -14
- package/serverless/index.d.ts +0 -5
- package/serverless/index.js +0 -18
- package/serverless/rpc-provider.d.ts +0 -1
- package/serverless/rpc-provider.js +0 -5
- package/serverless-template/README.md +0 -34
- package/serverless-template/_utils/PageMeta.tsx +0 -44
- package/serverless-template/_utils/ed-config.ts +0 -5
- package/serverless-template/_utils/fetch-wordpress-props.ts +0 -62
- package/serverless-template/_utils/fetch-wp.ts +0 -34
- package/serverless-template/_utils/swr.ts +0 -43
- package/serverless-template/global.d.ts +0 -15
- package/serverless-template/next-env.d.ts +0 -3
- package/serverless-template/next.config.js +0 -119
- package/serverless-template/null.ts +0 -1
- package/serverless-template/package.json +0 -21
- package/serverless-template/pages/404.tsx +0 -12
- package/serverless-template/pages/[...slug].tsx +0 -35
- package/serverless-template/pages/_app.tsx +0 -55
- package/serverless-template/pages/_document.tsx +0 -65
- package/serverless-template/pages/api/rest/[...method].ts +0 -59
- package/serverless-template/pages/api/robots.ts +0 -49
- package/serverless-template/pages/api/sitemap/[...sitemap].ts +0 -56
- package/serverless-template/pages/api/trpc/[...trpc].ts +0 -41
- package/serverless-template/pages/index.tsx +0 -15
- package/serverless-template/tsconfig.json +0 -39
- package/style/createStitches.d.ts +0 -1058
- package/style/createStitches.js +0 -443
- package/style/index.js +0 -13
- package/utils/Observable.d.ts +0 -11
- package/utils/Observable.js +0 -34
- package/utils/getRepoName.d.ts +0 -4
- package/utils/getRepoName.js +0 -30
- package/utils/merge-refs.d.ts +0 -2
- package/utils/merge-refs.js +0 -17
- package/utils/promptIfRepoNameIncorrect.d.ts +0 -1
- package/utils/promptIfRepoNameIncorrect.js +0 -72
- package/utils/refreshOverlayInterop.d.ts +0 -4
- package/utils/refreshOverlayInterop.js +0 -12
- package/utils/reportErrorStack.d.ts +0 -7
- package/utils/reportErrorStack.js +0 -13
- package/utils/serverlessAppContext.d.ts +0 -3
- package/utils/serverlessAppContext.js +0 -6
- package/utils/updateEnvFile.d.ts +0 -1
- package/utils/updateEnvFile.js +0 -76
- package/utils/useObservable.d.ts +0 -2
- package/utils/useObservable.js +0 -12
- package/views/defineView.d.ts +0 -2
- package/views/defineView.js +0 -7
- package/views/index.js +0 -13
- /package/{admin → dist/app/lib/admin}/installFieldTypes.d.ts +0 -0
- /package/{admin → dist/app/lib/admin}/runWidgets.d.ts +0 -0
- /package/{dev-ui → dist/app/lib/devtools}/components/BreakpointIndicator.d.ts +0 -0
- /package/{dev-ui → dist/app/lib/devtools}/hooks/usePersistState.d.ts +0 -0
- /package/{dev-ui → dist/app/lib/devtools}/loader.d.ts +0 -0
- /package/{style → dist/app/lib/legacy-stitches}/index.d.ts +0 -0
- /package/{build/graphql-codegen/graphql-codegen-files.d.ts → dist/app/lib/routing/types.js} +0 -0
- /package/{views → dist/app/lib/views}/index.d.ts +0 -0
- /package/{build/graphql-codegen/graphql-codegen-no-duplicates.d.ts → dist/app/utils/wp.js} +0 -0
- /package/{cli → dist/node/cli}/cli.d.ts +0 -0
- /package/{entry/entry.publicPath.d.ts → dist/node/project/favicons.d.ts} +0 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { parseURL, resolveURL, stringifyParsedURL, withoutTrailingSlash } from "ufo";
|
|
2
|
+
import { stringify as qsStringify, parse as qsParse } from "qs";
|
|
3
|
+
export function isSameOrigin(url) {
|
|
4
|
+
if (typeof document === "undefined") {
|
|
5
|
+
return url.startsWith("/");
|
|
6
|
+
}
|
|
7
|
+
else {
|
|
8
|
+
const resolved = resolveURL(document.location.href, url);
|
|
9
|
+
const parsed = parseURL(resolved);
|
|
10
|
+
return parsed.protocol === document.location.protocol && parsed.host === document.location.host;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export function getLinkHandlerMode(e, href) {
|
|
14
|
+
try {
|
|
15
|
+
// Attempt to get the link element, if there is one
|
|
16
|
+
let eventTarget = null;
|
|
17
|
+
if (e) {
|
|
18
|
+
if (e.target && e.target instanceof HTMLAnchorElement) {
|
|
19
|
+
eventTarget = e.target;
|
|
20
|
+
}
|
|
21
|
+
else if (e.currentTarget && e.currentTarget instanceof HTMLAnchorElement) {
|
|
22
|
+
eventTarget = e.currentTarget;
|
|
23
|
+
}
|
|
24
|
+
// Allow key modifiers to work normally
|
|
25
|
+
if (e.ctrlKey || e.metaKey)
|
|
26
|
+
return { mode: "native", href };
|
|
27
|
+
}
|
|
28
|
+
// If we have a target, but no href, use the target's href
|
|
29
|
+
if (!href && eventTarget)
|
|
30
|
+
href = eventTarget.href;
|
|
31
|
+
if (!href)
|
|
32
|
+
return { mode: "native", href };
|
|
33
|
+
// Resolve the URL and check if it's the same origin
|
|
34
|
+
const resolved = href.startsWith("http") ? href : resolveURL(document.location.href, href);
|
|
35
|
+
const parsed = parseURL(resolved);
|
|
36
|
+
const isSameOrigin = parsed.host?.replace(/:.+/, "") === document.location.host.replace(/:.+/, "");
|
|
37
|
+
// External links should be handled natively
|
|
38
|
+
if (!isSameOrigin)
|
|
39
|
+
return { mode: "native", href };
|
|
40
|
+
// If we're in the admin bundle, links shouldn't do anything
|
|
41
|
+
if (env.admin)
|
|
42
|
+
return { mode: "ignore", href };
|
|
43
|
+
// Allow target=_blank to work normally
|
|
44
|
+
if (eventTarget?.getAttribute("target") === "_blank")
|
|
45
|
+
return { mode: "native", href };
|
|
46
|
+
// If the event was already prevent-defaulted, do nothing
|
|
47
|
+
if (e && e.defaultPrevented)
|
|
48
|
+
return { mode: "ignore", href };
|
|
49
|
+
// If it looks like a file link, handle natively
|
|
50
|
+
if (parsed.pathname.match(/\.[a-z0-9]{2,5}$/i))
|
|
51
|
+
return { mode: "native", href };
|
|
52
|
+
// Starts with /wp-, use native (wp-content, wp-admin etc)
|
|
53
|
+
if (parsed.pathname.startsWith("/wp-"))
|
|
54
|
+
return { mode: "native", href };
|
|
55
|
+
return { mode: "navigate", href };
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
console.error(err);
|
|
59
|
+
return { mode: "native", href };
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
export function normalizeRoute(route) {
|
|
63
|
+
const pathname = withoutTrailingSlash(route.pathname);
|
|
64
|
+
const uri = stringifyRouteLink({
|
|
65
|
+
pathname: pathname,
|
|
66
|
+
query: route.query,
|
|
67
|
+
hash: route.hash,
|
|
68
|
+
});
|
|
69
|
+
return {
|
|
70
|
+
...route,
|
|
71
|
+
pathname,
|
|
72
|
+
uri,
|
|
73
|
+
key: route.key ?? route.view,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
export function stringifyRouteLink(route) {
|
|
77
|
+
return stringifyParsedURL({
|
|
78
|
+
...route,
|
|
79
|
+
search: stringifyQuery(route.query),
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
export function parseQuery(query) {
|
|
83
|
+
return qsParse(query.replace(/^\?/, ""), {
|
|
84
|
+
ignoreQueryPrefix: true,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
export function stringifyQuery(query) {
|
|
88
|
+
return qsStringify(query, {
|
|
89
|
+
encodeValuesOnly: true,
|
|
90
|
+
indices: false,
|
|
91
|
+
skipNulls: true,
|
|
92
|
+
arrayFormat: "brackets",
|
|
93
|
+
});
|
|
94
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { ComponentType, PropsWithChildren, ReactNode } from "react";
|
|
2
|
+
type ExtendedViewProps<TName extends keyof ViewProps> = TName extends "_app" ? PropsWithChildren<ViewProps[TName]> : ViewProps[TName];
|
|
3
|
+
export declare function defineView<Name extends keyof ViewProps>(name: Name, component: (props: ExtendedViewProps<Name>) => ReactNode): ComponentType<ExtendedViewProps<Name>>;
|
|
4
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./defineView";
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
/// <reference types="vinxi/types/server" />
|
|
2
|
+
import { splitSetCookieString } from "cookie-es";
|
|
3
|
+
import { getProxyRequestHeaders, getRequestURL, getWebRequest } from "vinxi/http";
|
|
4
|
+
import { getManifest } from "vinxi/manifest";
|
|
5
|
+
export async function proxyWpAdmin(event, serverContext) {
|
|
6
|
+
const replaceUrls = serverContext.replaceUrls;
|
|
7
|
+
const req = getWebRequest(event);
|
|
8
|
+
const proxyUrl = serverContext.getOriginUrl(getRequestURL(event).href);
|
|
9
|
+
// Prepare request headers to be sent to the origin server
|
|
10
|
+
const proxyHeaders = getProxyRequestHeaders(event);
|
|
11
|
+
proxyHeaders["X-ED-Dev-Proxy"] = "true";
|
|
12
|
+
// Forward the request to the origin server
|
|
13
|
+
const response = await fetch(proxyUrl, {
|
|
14
|
+
method: req.method,
|
|
15
|
+
referrer: req.referrer,
|
|
16
|
+
referrerPolicy: req.referrerPolicy,
|
|
17
|
+
headers: proxyHeaders,
|
|
18
|
+
body: req.method.match(/get|head|options/i) ? undefined : await req.blob(),
|
|
19
|
+
redirect: "manual",
|
|
20
|
+
cache: "no-cache",
|
|
21
|
+
});
|
|
22
|
+
const contentType = response.headers.get("content-type");
|
|
23
|
+
let body;
|
|
24
|
+
let res = { status: response.status, statusText: response.statusText, headers: new Headers() };
|
|
25
|
+
const cookies = [];
|
|
26
|
+
response.headers.forEach((value, key) => {
|
|
27
|
+
if (key === "content-encoding" || key === "content-length" || key === "transfer-encoding") {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
if (key === "set-cookie") {
|
|
31
|
+
cookies.push(...splitSetCookieString(value));
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (key === "location" && replaceUrls) {
|
|
35
|
+
value = replaceUrls(value);
|
|
36
|
+
}
|
|
37
|
+
res.headers.set(key, value);
|
|
38
|
+
});
|
|
39
|
+
// Set cookies in the response headers
|
|
40
|
+
// TODO: May need to rewrite cookie domain here before setting.
|
|
41
|
+
if (cookies.length > 0) {
|
|
42
|
+
for (const cookie of cookies) {
|
|
43
|
+
res.headers.append("set-cookie", cookie);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// Replace URLs pointing to the origin server from the response itself
|
|
47
|
+
// This is only done for text-based content types, like application/json, text/plain, text/html etc
|
|
48
|
+
if (contentType?.match(/(application|text)\//)) {
|
|
49
|
+
if (replaceUrls) {
|
|
50
|
+
body = replaceUrls((await response.text()) ?? "");
|
|
51
|
+
}
|
|
52
|
+
// If the content type is text/html, inject the Vite assets into the response — assuming the placeholder comments are found
|
|
53
|
+
if (contentType.startsWith("text/html")) {
|
|
54
|
+
const clientManifest = getManifest("admin");
|
|
55
|
+
const assets = await clientManifest.inputs[clientManifest.handler].assets();
|
|
56
|
+
body = body.replace("<!---VITE_HEADER--->", () => assets.map((asset) => renderAsset(asset)).join("\n"));
|
|
57
|
+
body = body.replace("<!---VITE_FOOTER--->", () => renderAsset({
|
|
58
|
+
tag: "script",
|
|
59
|
+
attrs: {
|
|
60
|
+
type: "module",
|
|
61
|
+
src: clientManifest.inputs[clientManifest.handler].output.path,
|
|
62
|
+
},
|
|
63
|
+
children: "",
|
|
64
|
+
}));
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
// Otherwise just stream the response as is
|
|
69
|
+
body = response.body;
|
|
70
|
+
}
|
|
71
|
+
return new Response(body, res);
|
|
72
|
+
}
|
|
73
|
+
function printElement(element, props, innerText) {
|
|
74
|
+
if (typeof innerText === "string") {
|
|
75
|
+
return `<${element}${Object.entries(props)
|
|
76
|
+
.map(([key, value]) => ` ${key}="${value}"`)
|
|
77
|
+
.join("")}>${innerText}</${element}>`;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
return `<${element}${Object.entries(props)
|
|
81
|
+
.map(([key, value]) => ` ${key}="${value}"`)
|
|
82
|
+
.join("")} />`;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
function renderAsset({ tag, attrs: { key, ...attrs } = {}, children, }) {
|
|
86
|
+
switch (tag) {
|
|
87
|
+
case "script":
|
|
88
|
+
if (attrs.src) {
|
|
89
|
+
return printElement("script", { ...attrs, key: attrs.src }, "");
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
return printElement("script", {
|
|
93
|
+
...attrs,
|
|
94
|
+
key: key,
|
|
95
|
+
}, children ?? "");
|
|
96
|
+
}
|
|
97
|
+
case "link":
|
|
98
|
+
return printElement("link", { ...attrs, key: key });
|
|
99
|
+
case "style":
|
|
100
|
+
return printElement("style", {
|
|
101
|
+
...attrs,
|
|
102
|
+
key: key,
|
|
103
|
+
}, children ?? "");
|
|
104
|
+
}
|
|
105
|
+
return "";
|
|
106
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { renderAsset } from "@vinxi/react";
|
|
3
|
+
import { Suspense } from "react";
|
|
4
|
+
import { renderToPipeableStream } from "react-dom/server";
|
|
5
|
+
import { getManifest } from "vinxi/manifest";
|
|
6
|
+
import { SSRRoot } from "../entry/ssr-root.js";
|
|
7
|
+
import { RouteLoader } from "../lib/routing/loader.js";
|
|
8
|
+
export async function renderPageToSSRStream(pathname, initialData) {
|
|
9
|
+
const clientManifest = getManifest("client");
|
|
10
|
+
const assets = await clientManifest.inputs[clientManifest.handler].assets();
|
|
11
|
+
const jsx = (_jsx(SSRRoot, { assets: _jsx(Suspense, { children: assets.map((m) => renderAsset(m)) }), pathname: pathname, initialData: initialData, loader: new RouteLoader() }));
|
|
12
|
+
const stream = await new Promise(async (resolve) => {
|
|
13
|
+
const stream = renderToPipeableStream(jsx, {
|
|
14
|
+
onShellReady() {
|
|
15
|
+
resolve(stream);
|
|
16
|
+
},
|
|
17
|
+
bootstrapModules: [clientManifest.inputs[clientManifest.handler].output.path],
|
|
18
|
+
bootstrapScriptContent: `window.manifest = ${JSON.stringify(await clientManifest.json())}; window._PAGE_DATA = ${JSON.stringify(initialData)}`,
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
return stream;
|
|
22
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { UrlReplacerConf } from "./utils/replace-host.js";
|
|
2
|
+
import { RequestHeaders } from "vinxi/http";
|
|
3
|
+
export type ServerContextArgs = {
|
|
4
|
+
dev: boolean;
|
|
5
|
+
origin: string;
|
|
6
|
+
replaceUrls?: UrlReplacerConf;
|
|
7
|
+
};
|
|
8
|
+
export declare class ServerContext {
|
|
9
|
+
dev: boolean;
|
|
10
|
+
origin: string;
|
|
11
|
+
replaceUrls?: (text: string) => string;
|
|
12
|
+
constructor(conf: ServerContextArgs);
|
|
13
|
+
getOriginUrl(url: string): string;
|
|
14
|
+
fetchOrigin(url: string, opts?: RequestInit & {
|
|
15
|
+
replaceUrls?: boolean;
|
|
16
|
+
}): Promise<Response>;
|
|
17
|
+
fetchRouteData(req: {
|
|
18
|
+
pathname: string;
|
|
19
|
+
query?: Record<string, any>;
|
|
20
|
+
headers?: RequestHeaders;
|
|
21
|
+
withAppData?: boolean;
|
|
22
|
+
}): Promise<Response>;
|
|
23
|
+
extractRequestHeaders(req?: RequestHeaders): Partial<Record<import("vinxi/http").HTTPHeaderName, string | undefined>>;
|
|
24
|
+
fetchNamedQuery(req: {
|
|
25
|
+
name: string;
|
|
26
|
+
params: object;
|
|
27
|
+
headers: RequestHeaders;
|
|
28
|
+
}): Promise<Response>;
|
|
29
|
+
fetchMutation(req: {
|
|
30
|
+
name: string;
|
|
31
|
+
body: object;
|
|
32
|
+
headers: RequestHeaders;
|
|
33
|
+
}): Promise<Response>;
|
|
34
|
+
}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { parseURL, stringifyParsedURL, withQuery } from "ufo";
|
|
2
|
+
import { filterHeader } from "./utils/headers.js";
|
|
3
|
+
import { createUrlReplacer } from "./utils/replace-host.js";
|
|
4
|
+
const PROXY_RESPONSE_HEADERS = ["content-type", "set-cookie", /^x-/, "cache-control"];
|
|
5
|
+
const PROXY_REQUEST_HEADERS = [
|
|
6
|
+
"content-type",
|
|
7
|
+
"accept",
|
|
8
|
+
"accept-encoding",
|
|
9
|
+
"accept-language",
|
|
10
|
+
"origin",
|
|
11
|
+
"referer",
|
|
12
|
+
"user-agent",
|
|
13
|
+
"authorization",
|
|
14
|
+
];
|
|
15
|
+
export class ServerContext {
|
|
16
|
+
dev;
|
|
17
|
+
origin;
|
|
18
|
+
replaceUrls;
|
|
19
|
+
constructor(conf) {
|
|
20
|
+
this.dev = conf.dev;
|
|
21
|
+
this.origin = conf.origin;
|
|
22
|
+
if (conf.replaceUrls) {
|
|
23
|
+
this.replaceUrls = createUrlReplacer(conf.replaceUrls);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
getOriginUrl(url) {
|
|
27
|
+
const parsed = parseURL(url);
|
|
28
|
+
const parsedOrigin = parseURL(env.origin);
|
|
29
|
+
parsed.host = parsedOrigin.host;
|
|
30
|
+
parsed.protocol = parsedOrigin.protocol;
|
|
31
|
+
return stringifyParsedURL(parsed);
|
|
32
|
+
}
|
|
33
|
+
async fetchOrigin(url, opts) {
|
|
34
|
+
url = this.getOriginUrl(url);
|
|
35
|
+
const response = await fetch(url, {
|
|
36
|
+
...opts,
|
|
37
|
+
headers: {
|
|
38
|
+
"Content-Type": "application/json",
|
|
39
|
+
Accept: "application/json",
|
|
40
|
+
...opts?.headers,
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
if (!response.ok) {
|
|
44
|
+
return response;
|
|
45
|
+
}
|
|
46
|
+
const headers = {};
|
|
47
|
+
response.headers.forEach((value, key) => {
|
|
48
|
+
if (filterHeader(key, PROXY_RESPONSE_HEADERS)) {
|
|
49
|
+
headers[key] = value;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
let text = await response.text();
|
|
53
|
+
if (opts?.replaceUrls && this.replaceUrls) {
|
|
54
|
+
text = this.replaceUrls(text);
|
|
55
|
+
}
|
|
56
|
+
return new Response(text, {
|
|
57
|
+
status: response.status,
|
|
58
|
+
statusText: response.statusText,
|
|
59
|
+
headers,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
async fetchRouteData(req) {
|
|
63
|
+
const fetchUrl = withQuery(req.pathname, {
|
|
64
|
+
...req.query,
|
|
65
|
+
_props: req.withAppData ? "all" : "1",
|
|
66
|
+
_ssr: "1",
|
|
67
|
+
_debug: this.dev ? "1" : undefined,
|
|
68
|
+
});
|
|
69
|
+
return this.fetchOrigin(fetchUrl, {
|
|
70
|
+
cache: "no-cache",
|
|
71
|
+
replaceUrls: true,
|
|
72
|
+
headers: {
|
|
73
|
+
"Content-Type": "application/json",
|
|
74
|
+
Accept: "application/json",
|
|
75
|
+
...this.extractRequestHeaders(req.headers),
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
extractRequestHeaders(req) {
|
|
80
|
+
const headers = {};
|
|
81
|
+
if (req) {
|
|
82
|
+
for (let key of PROXY_REQUEST_HEADERS) {
|
|
83
|
+
if (req[key]) {
|
|
84
|
+
headers[key] = req[key];
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return headers;
|
|
89
|
+
}
|
|
90
|
+
async fetchNamedQuery(req) {
|
|
91
|
+
const url = `/wp-json/ed/v1/query/${req.name}?params=${encodeURIComponent(JSON.stringify(req.params))}`;
|
|
92
|
+
return this.fetchOrigin(url, {
|
|
93
|
+
cache: "no-cache",
|
|
94
|
+
replaceUrls: true,
|
|
95
|
+
headers: {
|
|
96
|
+
...this.extractRequestHeaders(req.headers),
|
|
97
|
+
"Content-Type": "application/json",
|
|
98
|
+
Accept: "application/json",
|
|
99
|
+
},
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
async fetchMutation(req) {
|
|
103
|
+
const url = `/wp-json/ed/v1/mutation/${req.name}`;
|
|
104
|
+
return this.fetchOrigin(url, {
|
|
105
|
+
method: "POST",
|
|
106
|
+
cache: "no-cache",
|
|
107
|
+
replaceUrls: true,
|
|
108
|
+
headers: {
|
|
109
|
+
...this.extractRequestHeaders(req.headers),
|
|
110
|
+
"Content-Type": "application/json",
|
|
111
|
+
Accept: "application/json",
|
|
112
|
+
},
|
|
113
|
+
body: JSON.stringify(req.body),
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function filterHeader(key, allowed) {
|
|
2
|
+
return allowed.some((allowedKey) => {
|
|
3
|
+
if (allowedKey instanceof RegExp) {
|
|
4
|
+
return allowedKey.test(key);
|
|
5
|
+
}
|
|
6
|
+
return allowedKey === key;
|
|
7
|
+
});
|
|
8
|
+
}
|
|
9
|
+
export const BRANDED_HEADERS = {
|
|
10
|
+
"X-Powered-By": "ed.studio",
|
|
11
|
+
};
|
|
12
|
+
const IGNORE_REQUEST_HEADERS = [
|
|
13
|
+
"host",
|
|
14
|
+
"connection",
|
|
15
|
+
"accept-encoding",
|
|
16
|
+
"accept-language",
|
|
17
|
+
"origin",
|
|
18
|
+
"referer",
|
|
19
|
+
"user-agent",
|
|
20
|
+
];
|
|
21
|
+
export function extractHeaders(rawHeaders) {
|
|
22
|
+
const headers = {};
|
|
23
|
+
rawHeaders.forEach((value, key) => {
|
|
24
|
+
headers[key] = value;
|
|
25
|
+
});
|
|
26
|
+
IGNORE_REQUEST_HEADERS.forEach((key) => delete headers[key]);
|
|
27
|
+
return headers;
|
|
28
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: "<!doctype html>\n<html lang=\"en\">\n <head>\n <meta charset=\"UTF-8\" />\n <link rel=\"icon\" type=\"image/svg+xml\" href=\"/vite.svg\" />\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n <!--ssr-meta-->\n </head>\n <body>\n <div id=\"root\"><!--ssr-outlet--></div>\n <!--ssr-meta-->\n <script type=\"module\" src=\"/_boot.js\"></script>\n </body>\n</html>";
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export default `<!doctype html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8" />
|
|
5
|
+
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
|
6
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
7
|
+
<!--ssr-meta-->
|
|
8
|
+
</head>
|
|
9
|
+
<body>
|
|
10
|
+
<div id="root"><!--ssr-outlet--></div>
|
|
11
|
+
<!--ssr-meta-->
|
|
12
|
+
<script type="module" src="/_boot.js"></script>
|
|
13
|
+
</body>
|
|
14
|
+
</html>`;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type UrlReplacerConf = {
|
|
2
|
+
from: string;
|
|
3
|
+
to: string;
|
|
4
|
+
/** A dictionary of prefixes (eg /wp-content), and whether to replace them (true/false) */
|
|
5
|
+
prefixes: {
|
|
6
|
+
prefix: string;
|
|
7
|
+
replace: boolean;
|
|
8
|
+
}[];
|
|
9
|
+
};
|
|
10
|
+
export declare function createUrlReplacer(conf: UrlReplacerConf): (text: string) => string;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
export function createUrlReplacer(conf) {
|
|
2
|
+
// Create a regular expression to match the URL
|
|
3
|
+
// Note that that the regex doesn't necessarily match the entire URL
|
|
4
|
+
const lookup = new RegExp(conf.from.replace(/https?[:\\\/]+/, "https?[:\\/\\\\]+") + "([a-z0-9\\-_/\\\\]+)", "ig");
|
|
5
|
+
return (text) => {
|
|
6
|
+
return text.replace(lookup, (url) => {
|
|
7
|
+
// Strip out the origin, to create a relative path
|
|
8
|
+
const path = url.replace(/https?:[\/\\]+[^\/\\]+/, "");
|
|
9
|
+
const isEscaped = url.includes(":\\/\\/");
|
|
10
|
+
const key = "/" +
|
|
11
|
+
path
|
|
12
|
+
.split(/[\/\\]+/g)
|
|
13
|
+
.filter((v) => v)
|
|
14
|
+
.join("/");
|
|
15
|
+
for (let item of conf.prefixes) {
|
|
16
|
+
if (key.startsWith(item.prefix)) {
|
|
17
|
+
if (item.replace) {
|
|
18
|
+
return url;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
return path;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return path;
|
|
26
|
+
// if (path.startsWith("/wp-content/uploads/")) {
|
|
27
|
+
// if (!conf.ignoreUploads) {
|
|
28
|
+
// return path
|
|
29
|
+
// } else {
|
|
30
|
+
// return url
|
|
31
|
+
// }
|
|
32
|
+
// // } else if (path.startsWith("/wp-content/themes/")) {
|
|
33
|
+
// // if (settings?.uploads === "proxy") {
|
|
34
|
+
// // return path
|
|
35
|
+
// // } else if (settings?.uploads === "remote") {
|
|
36
|
+
// // return url
|
|
37
|
+
// // }
|
|
38
|
+
// // } else if (path.startsWith("/wp-content/plugins/")) {
|
|
39
|
+
// // if (settings?.uploads === "proxy") {
|
|
40
|
+
// // return path
|
|
41
|
+
// // } else if (settings?.uploads === "remote") {
|
|
42
|
+
// // return url
|
|
43
|
+
// // }
|
|
44
|
+
// } else {
|
|
45
|
+
// return path
|
|
46
|
+
// }
|
|
47
|
+
});
|
|
48
|
+
};
|
|
49
|
+
// const from = conf.from
|
|
50
|
+
// const to = conf.to
|
|
51
|
+
// const https = conf.https
|
|
52
|
+
// const ignoreUploads = conf.ignoreUploads
|
|
53
|
+
// const ignorePlugins = conf.ignorePlugins
|
|
54
|
+
// const replaceTargetString = from.replaceAll(/https?:/g, "https?:").replaceAll("/", "\\/")
|
|
55
|
+
// const replaceTargetEscapedString = from.replaceAll(/https?:/g, "https?:").replaceAll("/", "\\\\/")
|
|
56
|
+
// const replaceTarget = new RegExp(replaceTargetString, "g")
|
|
57
|
+
// const replaceTargetEscaped = new RegExp(replaceTargetEscapedString, "g")
|
|
58
|
+
// return (value: string) => {
|
|
59
|
+
// return value.replaceAll(replaceTarget, to).replace(replaceTargetEscaped, to.replaceAll("/", "\\/"))
|
|
60
|
+
// }
|
|
61
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { QueryClient } from "@tanstack/react-query";
|
|
2
|
+
let queryClient = null;
|
|
3
|
+
export function getQueryClient() {
|
|
4
|
+
if (!queryClient) {
|
|
5
|
+
queryClient = new QueryClient({
|
|
6
|
+
defaultOptions: env.serverless && env.dev && !env.client
|
|
7
|
+
? {
|
|
8
|
+
queries: {
|
|
9
|
+
staleTime: 1,
|
|
10
|
+
},
|
|
11
|
+
}
|
|
12
|
+
: {},
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
return queryClient;
|
|
16
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type * as BlockEditor from "@wordpress/block-editor";
|
|
2
|
+
import type * as Blocks from "@wordpress/blocks";
|
|
3
|
+
import type * as Hooks from "@wordpress/hooks";
|
|
4
|
+
import type * as Element from "@wordpress/element";
|
|
5
|
+
import type * as Components from "@wordpress/components";
|
|
6
|
+
import type * as Data from "@wordpress/data";
|
|
7
|
+
import type * as CoreData from "@wordpress/core-data";
|
|
8
|
+
import type * as Editor from "@wordpress/editor";
|
|
9
|
+
import type * as Compose from "@wordpress/compose";
|
|
10
|
+
import type * as RichText from "@wordpress/rich-text";
|
|
11
|
+
type WordPressGlobal = {
|
|
12
|
+
blockEditor: typeof BlockEditor;
|
|
13
|
+
blocks: typeof Blocks;
|
|
14
|
+
hooks: typeof Hooks;
|
|
15
|
+
element: typeof Element;
|
|
16
|
+
data: typeof Data;
|
|
17
|
+
components: typeof Components;
|
|
18
|
+
compose: typeof Compose;
|
|
19
|
+
coreData: typeof CoreData;
|
|
20
|
+
editor: typeof Editor;
|
|
21
|
+
richText: typeof RichText;
|
|
22
|
+
};
|
|
23
|
+
declare global {
|
|
24
|
+
const wp: WordPressGlobal;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare const cliMode: {
|
|
2
|
+
interactive: boolean;
|
|
3
|
+
readonly: boolean;
|
|
4
|
+
exitOnValidationError: boolean;
|
|
5
|
+
detailed: boolean;
|
|
6
|
+
verbose: boolean;
|
|
7
|
+
watch: boolean;
|
|
8
|
+
rootDir: string;
|
|
9
|
+
};
|
|
10
|
+
export declare function configureCliMode(options: typeof cliMode): void;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Worker } from "node:worker_threads";
|
|
2
|
+
import { StatefulLog } from "../utils/stateful-log.js";
|
|
3
|
+
type WorkerMode = "admin" | "frontend" | "graphql" | "serverless";
|
|
4
|
+
export declare class CLIWorker {
|
|
5
|
+
worker: Worker;
|
|
6
|
+
constructor({ log, mode, verbose }: {
|
|
7
|
+
log: StatefulLog<any>;
|
|
8
|
+
mode: WorkerMode;
|
|
9
|
+
verbose: boolean;
|
|
10
|
+
});
|
|
11
|
+
shutdown(): Promise<void>;
|
|
12
|
+
}
|
|
13
|
+
export {};
|