eddev 2.0.0-beta.22 → 2.0.0-beta.220

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