eddev 0.3.35 → 2.0.0-beta.1
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/Root.d.ts +1 -0
- package/dist/app/entry/Root.js +9 -0
- package/dist/app/entry/main.admin.d.ts +3 -0
- package/dist/app/entry/main.admin.js +10 -0
- package/dist/app/entry/main.frontend.spa.d.ts +3 -0
- package/dist/app/entry/main.frontend.spa.js +13 -0
- package/dist/app/entry/main.frontend.ssr.d.ts +21 -0
- package/dist/app/entry/main.frontend.ssr.js +79 -0
- package/dist/app/entry/main.serverless.dev.d.ts +4 -0
- package/dist/app/entry/main.serverless.dev.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 +79 -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/hooks/usePersistState.js +31 -0
- package/dist/app/lib/devtools/hooks/useTailwind.d.ts +4184 -0
- package/dist/app/lib/devtools/hooks/useTailwind.js +6 -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 +46 -0
- package/dist/app/lib/hooks/queryUtils.js +183 -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 +11 -0
- package/dist/app/lib/internal/internal-store.js +9 -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 +106 -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/create-api-builtin-hono.d.ts +8 -0
- package/dist/app/server/create-api-builtin-hono.js +80 -0
- package/dist/app/server/create-ssr-hono.d.ts +18 -0
- package/dist/app/server/create-ssr-hono.js +104 -0
- package/dist/app/server/utils/headers.d.ts +4 -0
- package/dist/app/server/utils/headers.js +11 -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 +8 -0
- package/dist/app/server/utils/replace-host.js +14 -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 +114 -0
- package/dist/node/cli/cli.js +166 -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/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/index.html.d.ts +2 -0
- package/dist/node/compiler/index.html.js +15 -0
- package/dist/node/compiler/serverless.dev.d.ts +16 -0
- package/dist/node/compiler/serverless.dev.js +215 -0
- package/dist/node/compiler/vite/get-vite-config.d.ts +13 -0
- package/dist/node/compiler/vite/get-vite-config.js +315 -0
- package/dist/node/compiler/vite/plugin-admin.d.ts +4 -0
- package/dist/node/compiler/vite/plugin-admin.js +67 -0
- package/dist/node/compiler/vite/plugin-blocks.d.ts +4 -0
- package/dist/node/compiler/vite/plugin-blocks.js +73 -0
- package/dist/node/compiler/vite/plugin-entry.d.ts +6 -0
- package/dist/node/compiler/vite/plugin-entry.js +16 -0
- package/dist/node/compiler/vite/plugin-resolved-tailwind.d.ts +4 -0
- package/dist/node/compiler/vite/plugin-resolved-tailwind.js +29 -0
- package/dist/node/compiler/vite/plugin-theme.d.ts +4 -0
- package/dist/node/compiler/vite/plugin-theme.js +40 -0
- package/dist/node/compiler/vite/plugin-views.d.ts +4 -0
- package/dist/node/compiler/vite/plugin-views.js +51 -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 +94 -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.d.ts +0 -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 +57 -0
- package/dist/node/project/project.js +115 -0
- package/dist/node/project/wp-info.d.ts +32 -0
- package/dist/node/project/wp-info.js +34 -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 +54 -0
- package/dist/node/utils/console.d.ts +21 -0
- package/dist/node/utils/console.js +28 -0
- package/dist/node/utils/export-extractor.d.ts +9 -0
- package/dist/node/utils/export-extractor.js +71 -0
- package/dist/node/utils/formatZodError.d.ts +3 -0
- package/dist/node/utils/formatZodError.js +33 -0
- package/dist/node/utils/fs.d.ts +106 -0
- package/dist/node/utils/fs.js +56 -0
- package/dist/node/utils/getRepoInfo.d.ts +7 -0
- package/dist/node/utils/getRepoInfo.js +21 -0
- package/dist/node/utils/helpers.d.ts +2 -0
- package/dist/node/utils/helpers.js +14 -0
- package/dist/node/utils/highlightCode.d.ts +10 -0
- package/dist/node/utils/highlightCode.js +30 -0
- package/dist/node/utils/isDeploying.d.ts +4 -0
- package/dist/node/utils/isDeploying.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/selfSignedCert.d.ts +4 -0
- package/dist/node/utils/selfSignedCert.js +35 -0
- package/dist/node/utils/statefulLog.d.ts +65 -0
- package/dist/node/utils/statefulLog.js +223 -0
- package/dist/node/utils/unsafe-fetch.d.ts +2 -0
- package/dist/node/utils/unsafe-fetch.js +19 -0
- package/dist/node/utils/watchFileTree.d.ts +11 -0
- package/dist/node/utils/watchFileTree.js +58 -0
- package/package.json +123 -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/tsup.config.ts +40 -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.manifests.d.ts +22 -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 -54
- 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/{entry/entry.publicPath.d.ts → dist/app/lib/devtools/index.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
|
@@ -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,8 @@
|
|
|
1
|
+
import { Hono } from "hono";
|
|
2
|
+
import { UrlReplacerConf } from "./utils/replace-host";
|
|
3
|
+
type Conf = {
|
|
4
|
+
fetch: typeof fetch;
|
|
5
|
+
replaceUrls?: UrlReplacerConf;
|
|
6
|
+
};
|
|
7
|
+
export declare function createHonoStdAPI(conf: Conf): Hono<import("hono").Env, {}, "/">;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Hono } from "hono";
|
|
2
|
+
import { joinURL, withQuery } from "ufo";
|
|
3
|
+
import { BRANDED_HEADERS, filterHeader } from "./utils/headers";
|
|
4
|
+
import { createUrlReplacer } from "./utils/replace-host";
|
|
5
|
+
let standardFetch = fetch;
|
|
6
|
+
const PROXY_RESPONSE_HEADERS = ["content-type", "set-cookie", /^x-/, "cache-control", ...Object.keys(BRANDED_HEADERS)];
|
|
7
|
+
function extractHeaders(rawHeaders) {
|
|
8
|
+
const headers = {};
|
|
9
|
+
rawHeaders.forEach((value, key) => {
|
|
10
|
+
headers[key] = value;
|
|
11
|
+
});
|
|
12
|
+
return headers;
|
|
13
|
+
}
|
|
14
|
+
export function createHonoStdAPI(conf) {
|
|
15
|
+
const fetch = conf.fetch ?? standardFetch;
|
|
16
|
+
const replaceUrls = conf.replaceUrls ? createUrlReplacer(conf.replaceUrls) : undefined;
|
|
17
|
+
const app = new Hono();
|
|
18
|
+
app.get("/api/rest/query/:name{.+}", async (c) => {
|
|
19
|
+
const name = c.req.param("name");
|
|
20
|
+
const paramString = c.req.query("params");
|
|
21
|
+
const fetchUrl = withQuery(joinURL(env.origin ?? "", `/wp-json/ed/v1/query/${name}`), { params: paramString });
|
|
22
|
+
const response = await fetch(fetchUrl, {
|
|
23
|
+
referrer: c.req.raw.referrer,
|
|
24
|
+
cache: "no-cache",
|
|
25
|
+
headers: {
|
|
26
|
+
"Content-Type": "application/json",
|
|
27
|
+
Accept: "application/json",
|
|
28
|
+
...extractHeaders(c.req.raw.headers),
|
|
29
|
+
// Authorization: c.req.header("Authorization") ?? "",
|
|
30
|
+
// Cookie: c.req.header("Cookie") ?? "",
|
|
31
|
+
// ...c.req.raw.headers,
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
c.status(response.status);
|
|
35
|
+
response.headers.forEach((value, key) => {
|
|
36
|
+
if (filterHeader(key, PROXY_RESPONSE_HEADERS)) {
|
|
37
|
+
c.header(key, value);
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
Object.entries(BRANDED_HEADERS).forEach(([key, value]) => c.header(key, value));
|
|
41
|
+
let text = await response.text();
|
|
42
|
+
if (replaceUrls) {
|
|
43
|
+
text = replaceUrls(text);
|
|
44
|
+
}
|
|
45
|
+
return c.body(text);
|
|
46
|
+
});
|
|
47
|
+
app.post("/api/rest/mutation/:name{.+}", async (c) => {
|
|
48
|
+
const name = c.req.param("name");
|
|
49
|
+
const fetchUrl = joinURL(env.origin ?? "", `/wp-json/ed/v1/mutation/${name}`);
|
|
50
|
+
const response = await fetch(fetchUrl, {
|
|
51
|
+
method: "POST",
|
|
52
|
+
referrer: c.req.raw.referrer,
|
|
53
|
+
cache: "no-cache",
|
|
54
|
+
headers: {
|
|
55
|
+
"Content-Type": "application/json",
|
|
56
|
+
Accept: "application/json",
|
|
57
|
+
...extractHeaders(c.req.raw.headers),
|
|
58
|
+
// Authorization: c.req.header("Authorization") ?? "",
|
|
59
|
+
// Cookie: c.req.header("Cookie") ?? "",
|
|
60
|
+
},
|
|
61
|
+
body: JSON.stringify({
|
|
62
|
+
name: name,
|
|
63
|
+
...(await c.req.json()),
|
|
64
|
+
}),
|
|
65
|
+
});
|
|
66
|
+
c.status(response.status);
|
|
67
|
+
response.headers.forEach((value, key) => {
|
|
68
|
+
if (filterHeader(key, PROXY_RESPONSE_HEADERS)) {
|
|
69
|
+
c.header(key, value);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
Object.entries(BRANDED_HEADERS).forEach(([key, value]) => c.header(key, value));
|
|
73
|
+
let text = await response.text();
|
|
74
|
+
if (replaceUrls) {
|
|
75
|
+
text = replaceUrls(text);
|
|
76
|
+
}
|
|
77
|
+
return c.body(text);
|
|
78
|
+
});
|
|
79
|
+
return app;
|
|
80
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Hono } from "hono";
|
|
2
|
+
import { ReactElement } from "react";
|
|
3
|
+
type Conf = {
|
|
4
|
+
render: (args: {
|
|
5
|
+
pathname: string;
|
|
6
|
+
}) => Promise<{
|
|
7
|
+
jsx: ReactElement;
|
|
8
|
+
getCollectedOutput(): {
|
|
9
|
+
head: string;
|
|
10
|
+
foot: string;
|
|
11
|
+
};
|
|
12
|
+
indexTemplate: string;
|
|
13
|
+
data: any;
|
|
14
|
+
}>;
|
|
15
|
+
manifest: any;
|
|
16
|
+
};
|
|
17
|
+
export declare function createSSRHono(conf: Conf): Hono<import("hono").Env, {}, "/">;
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Hono } from "hono";
|
|
2
|
+
import ReactDOMServer from "react-dom/server";
|
|
3
|
+
import { stream } from "hono/streaming";
|
|
4
|
+
export function createSSRHono(conf) {
|
|
5
|
+
const app = new Hono();
|
|
6
|
+
app.get("*", async (c) => {
|
|
7
|
+
const isPropsRequest = c.req.query("_props");
|
|
8
|
+
const result = await conf.render({ pathname: c.req.path });
|
|
9
|
+
let didError = false;
|
|
10
|
+
async function propsResponse() {
|
|
11
|
+
c.status(200);
|
|
12
|
+
c.header("Content-Type", "application/json");
|
|
13
|
+
return c.json(result.data);
|
|
14
|
+
}
|
|
15
|
+
const getTemplateParts = () => {
|
|
16
|
+
const collected = result.getCollectedOutput();
|
|
17
|
+
let [head, foot] = result.indexTemplate.split("<!--ssr-outlet-->");
|
|
18
|
+
head = head.replace("<!--ssr-meta-->", collected.head);
|
|
19
|
+
const dataPayload = `\n<script type="text/javascript">window._PAGE_DATA = ${JSON.stringify(result.data, null, 2)}</script>\n`;
|
|
20
|
+
foot = foot.replace("<!--ssr-meta-->", dataPayload + collected.foot);
|
|
21
|
+
return [head, foot];
|
|
22
|
+
};
|
|
23
|
+
// For Web Stream environments, and when react-dom/server exports renderToReadableStream for Node.js
|
|
24
|
+
// (Even though Node 20+ supports Web Streams, ReactDOM doesn't yet export it for Node)
|
|
25
|
+
if (ReactDOMServer.renderToReadableStream) {
|
|
26
|
+
const reactStream = await ReactDOMServer.renderToReadableStream(result.jsx, {
|
|
27
|
+
onError: (err) => {
|
|
28
|
+
didError = true;
|
|
29
|
+
console.warn("Failed to server-render React frontend");
|
|
30
|
+
console.error(err);
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
await reactStream.allReady;
|
|
34
|
+
if (isPropsRequest) {
|
|
35
|
+
return propsResponse();
|
|
36
|
+
}
|
|
37
|
+
const [head, foot] = getTemplateParts();
|
|
38
|
+
return stream(c, async (stream) => {
|
|
39
|
+
await stream.write(head);
|
|
40
|
+
await stream.pipe(reactStream);
|
|
41
|
+
await stream.write(foot);
|
|
42
|
+
stream.close();
|
|
43
|
+
});
|
|
44
|
+
// const result = await stream.getReader().read()
|
|
45
|
+
// const result = { value: "test" }
|
|
46
|
+
// return finalize(result.value)
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
return new Promise((resolve, reject) => {
|
|
50
|
+
const reactStream = ReactDOMServer.renderToPipeableStream(result.jsx, {
|
|
51
|
+
onError: (err) => {
|
|
52
|
+
didError = true;
|
|
53
|
+
console.warn("Failed to server-render React frontend");
|
|
54
|
+
console.error(err);
|
|
55
|
+
// setModuleCollector(() => {})
|
|
56
|
+
},
|
|
57
|
+
onShellError: (err) => {
|
|
58
|
+
console.warn("Shell");
|
|
59
|
+
console.error(err);
|
|
60
|
+
},
|
|
61
|
+
onAllReady: async () => {
|
|
62
|
+
if (isPropsRequest) {
|
|
63
|
+
resolve(propsResponse());
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
c.status(200);
|
|
67
|
+
c.header("Content-Type", "text/html");
|
|
68
|
+
resolve(stream(c, async (stream) => {
|
|
69
|
+
const [head, foot] = getTemplateParts();
|
|
70
|
+
stream.write(head);
|
|
71
|
+
reactStream.pipe({
|
|
72
|
+
write(chunk) {
|
|
73
|
+
stream.write(chunk);
|
|
74
|
+
},
|
|
75
|
+
close() {
|
|
76
|
+
// stream.close()
|
|
77
|
+
},
|
|
78
|
+
destroy() { },
|
|
79
|
+
on(event, cb) { },
|
|
80
|
+
async end() {
|
|
81
|
+
stream.write(foot);
|
|
82
|
+
stream.close();
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
}));
|
|
86
|
+
// reac.pipe(new WritableStream((chunk) => {
|
|
87
|
+
// chunk
|
|
88
|
+
// }))
|
|
89
|
+
// resolve(stream())
|
|
90
|
+
// const collected = getCollectedOutput()
|
|
91
|
+
// res.status(200).set({ "Content-Type": "text/html" })
|
|
92
|
+
// res.write(htmlParts[0].replace("<!--ssr-meta-->", collected.head ?? ""))
|
|
93
|
+
// stream.pipe(res)
|
|
94
|
+
// res.write(htmlParts[1].replace("<!--ssr-meta-->", collected.footer ?? ""))
|
|
95
|
+
// res.end()
|
|
96
|
+
}
|
|
97
|
+
// setModuleCollector(() => {})
|
|
98
|
+
},
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
return app;
|
|
104
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
};
|
|
@@ -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,14 @@
|
|
|
1
|
+
export function createUrlReplacer(conf) {
|
|
2
|
+
const from = conf.from;
|
|
3
|
+
const to = conf.to;
|
|
4
|
+
const https = conf.https;
|
|
5
|
+
const ignoreUploads = conf.ignoreUploads;
|
|
6
|
+
const ignorePlugins = conf.ignorePlugins;
|
|
7
|
+
const replaceTargetString = from.replaceAll(/https?:/g, "https?:").replaceAll("/", "\\/");
|
|
8
|
+
const replaceTargetEscapedString = from.replaceAll(/https?:/g, "https?:").replaceAll("/", "\\\\/");
|
|
9
|
+
const replaceTarget = new RegExp(replaceTargetString, "g");
|
|
10
|
+
const replaceTargetEscaped = new RegExp(replaceTargetEscapedString, "g");
|
|
11
|
+
return (value) => {
|
|
12
|
+
return value.replaceAll(replaceTarget, to).replace(replaceTargetEscaped, to.replaceAll("/", "\\/"));
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -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/statefulLog.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 {};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { Worker, isMainThread, parentPort, workerData } from "node:worker_threads";
|
|
2
|
+
import { AdminBundler, adminLog } from "../compiler/bundler.admin.js";
|
|
3
|
+
import { FrontendBundler, frontendLog } from "../compiler/bundler.frontend.js";
|
|
4
|
+
import { GraphQLGenerator, graphqlLog } from "../graphql/graphql-codegen.js";
|
|
5
|
+
import { Project } from "../project/project.js";
|
|
6
|
+
import { configureCliMode } from "./cli-mode.js";
|
|
7
|
+
export class CLIWorker {
|
|
8
|
+
worker;
|
|
9
|
+
constructor({ log, mode, verbose }) {
|
|
10
|
+
const worker = new Worker(new URL(import.meta.url), {
|
|
11
|
+
workerData: {
|
|
12
|
+
mode,
|
|
13
|
+
verbose,
|
|
14
|
+
},
|
|
15
|
+
stdout: true,
|
|
16
|
+
stderr: true,
|
|
17
|
+
});
|
|
18
|
+
this.worker = worker;
|
|
19
|
+
worker.stdout?.on("data", (data) => {
|
|
20
|
+
log.log(data.toString());
|
|
21
|
+
});
|
|
22
|
+
worker.stderr?.on("data", (data) => {
|
|
23
|
+
log.warn(data.toString());
|
|
24
|
+
});
|
|
25
|
+
worker.on("message", (msg) => {
|
|
26
|
+
try {
|
|
27
|
+
const payload = JSON.parse(msg);
|
|
28
|
+
if (payload && typeof payload === "object" && payload.type === "log") {
|
|
29
|
+
log.copy(payload.log);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
log.warn("Unknown worker message:", msg);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
worker.on("error", (err) => {
|
|
37
|
+
log.error("Worker error", err);
|
|
38
|
+
});
|
|
39
|
+
worker.on("exit", (code) => {
|
|
40
|
+
log.info("Worker exited", code);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async shutdown() {
|
|
44
|
+
await this.worker.terminate();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
if (!isMainThread) {
|
|
48
|
+
const mode = workerData.mode;
|
|
49
|
+
configureCliMode({
|
|
50
|
+
interactive: true,
|
|
51
|
+
readonly: false,
|
|
52
|
+
exitOnValidationError: true,
|
|
53
|
+
detailed: false,
|
|
54
|
+
verbose: workerData.verbose,
|
|
55
|
+
watch: true,
|
|
56
|
+
rootDir: process.cwd(),
|
|
57
|
+
});
|
|
58
|
+
// Load the project info
|
|
59
|
+
const project = await Project.create({
|
|
60
|
+
rootDir: process.cwd(),
|
|
61
|
+
reportPluginCompatibility: false,
|
|
62
|
+
});
|
|
63
|
+
function serializeLogData(data) {
|
|
64
|
+
if (data instanceof Error) {
|
|
65
|
+
return {
|
|
66
|
+
__is_error: true,
|
|
67
|
+
message: data.message,
|
|
68
|
+
stack: data.stack,
|
|
69
|
+
name: data.name,
|
|
70
|
+
cause: data.cause,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
else if (data && Array.isArray(data)) {
|
|
74
|
+
return data.map(serializeLogData);
|
|
75
|
+
}
|
|
76
|
+
else if (data && typeof data === "object") {
|
|
77
|
+
const obj = { ...data };
|
|
78
|
+
for (const key in obj) {
|
|
79
|
+
obj[key] = serializeLogData(obj[key]);
|
|
80
|
+
}
|
|
81
|
+
return obj;
|
|
82
|
+
}
|
|
83
|
+
return data;
|
|
84
|
+
}
|
|
85
|
+
function pipeLog(log) {
|
|
86
|
+
log.subscribe((log) => {
|
|
87
|
+
parentPort?.postMessage(JSON.stringify({ type: "log", log: serializeLogData(log) }));
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
if (mode === "admin") {
|
|
91
|
+
new AdminBundler(project, {
|
|
92
|
+
mode: "development",
|
|
93
|
+
});
|
|
94
|
+
pipeLog(adminLog);
|
|
95
|
+
}
|
|
96
|
+
else if (mode === "frontend") {
|
|
97
|
+
new FrontendBundler(project, {
|
|
98
|
+
mode: "development",
|
|
99
|
+
watch: true,
|
|
100
|
+
});
|
|
101
|
+
pipeLog(frontendLog);
|
|
102
|
+
}
|
|
103
|
+
else if (mode === "graphql") {
|
|
104
|
+
const codegen = new GraphQLGenerator(project);
|
|
105
|
+
codegen.start();
|
|
106
|
+
pipeLog(graphqlLog);
|
|
107
|
+
}
|
|
108
|
+
else if (mode === "serverless") {
|
|
109
|
+
// new ServerlessDevServer(project, {
|
|
110
|
+
// mode: "development",
|
|
111
|
+
// })
|
|
112
|
+
// pipeLog(serverlessLog)
|
|
113
|
+
}
|
|
114
|
+
}
|