eddev 2.0.0-beta.98 → 2.1.0

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 (429) hide show
  1. package/css/editor-styles.css +4 -0
  2. package/dist/app/entry/HydrationOverlay.d.ts +1 -0
  3. package/dist/app/entry/HydrationOverlay.d.ts.map +1 -0
  4. package/dist/app/entry/MetaTags.d.ts +1 -0
  5. package/dist/app/entry/MetaTags.d.ts.map +1 -0
  6. package/dist/app/entry/MetaTags.js +18 -3
  7. package/dist/app/entry/boot-admin.d.ts +1 -0
  8. package/dist/app/entry/boot-admin.d.ts.map +1 -0
  9. package/dist/app/entry/boot-admin.js +0 -1
  10. package/dist/app/entry/hydration-script.d.ts +1 -0
  11. package/dist/app/entry/hydration-script.d.ts.map +1 -0
  12. package/dist/app/entry/spa-root.d.ts +1 -0
  13. package/dist/app/entry/spa-root.d.ts.map +1 -0
  14. package/dist/app/entry/spa-root.js +1 -2
  15. package/dist/app/entry/ssr-root-client.d.ts +1 -0
  16. package/dist/app/entry/ssr-root-client.d.ts.map +1 -0
  17. package/dist/app/entry/ssr-root-client.js +3 -2
  18. package/dist/app/entry/ssr-root.d.ts +3 -0
  19. package/dist/app/entry/ssr-root.d.ts.map +1 -0
  20. package/dist/app/entry/ssr-root.js +3 -3
  21. package/dist/app/lib/admin/defineField.d.ts +1 -0
  22. package/dist/app/lib/admin/defineField.d.ts.map +1 -0
  23. package/dist/app/lib/admin/defineWidget.d.ts +1 -0
  24. package/dist/app/lib/admin/defineWidget.d.ts.map +1 -0
  25. package/dist/app/lib/admin/index.d.ts +1 -0
  26. package/dist/app/lib/admin/index.d.ts.map +1 -0
  27. package/dist/app/lib/admin/installFieldTypes.d.ts +1 -0
  28. package/dist/app/lib/admin/installFieldTypes.d.ts.map +1 -0
  29. package/dist/app/lib/admin/installFieldTypes.js +2 -0
  30. package/dist/app/lib/admin/runWidgets.d.ts +1 -0
  31. package/dist/app/lib/admin/runWidgets.d.ts.map +1 -0
  32. package/dist/app/lib/admin/runWidgets.js +7 -2
  33. package/dist/app/lib/blocks/BlockPropMutator.d.ts +33 -0
  34. package/dist/app/lib/blocks/BlockPropMutator.d.ts.map +1 -0
  35. package/dist/app/lib/blocks/BlockPropMutator.js +20 -0
  36. package/dist/app/lib/blocks/ContentBlocks.d.ts +7 -4
  37. package/dist/app/lib/blocks/ContentBlocks.d.ts.map +1 -0
  38. package/dist/app/lib/blocks/ContentBlocks.js +14 -1
  39. package/dist/app/lib/blocks/EditableText.d.ts +30 -5
  40. package/dist/app/lib/blocks/EditableText.d.ts.map +1 -0
  41. package/dist/app/lib/blocks/EditableText.js +34 -5
  42. package/dist/app/lib/blocks/InnerBlocks.d.ts +11 -6
  43. package/dist/app/lib/blocks/InnerBlocks.d.ts.map +1 -0
  44. package/dist/app/lib/blocks/InnerBlocks.js +67 -27
  45. package/dist/app/lib/blocks/SlotBlocks.d.ts +8 -0
  46. package/dist/app/lib/blocks/SlotBlocks.d.ts.map +1 -0
  47. package/dist/app/lib/blocks/SlotBlocks.js +45 -0
  48. package/dist/app/lib/blocks/block-utils.d.ts +1 -0
  49. package/dist/app/lib/blocks/block-utils.d.ts.map +1 -0
  50. package/dist/app/lib/blocks/block-utils.js +18 -1
  51. package/dist/app/lib/blocks/builtin-blocks.d.ts +2 -0
  52. package/dist/app/lib/blocks/builtin-blocks.d.ts.map +1 -0
  53. package/dist/app/lib/blocks/builtin-blocks.js +55 -0
  54. package/dist/app/lib/blocks/defineBlock.d.ts +4 -0
  55. package/dist/app/lib/blocks/defineBlock.d.ts.map +1 -0
  56. package/dist/app/lib/blocks/defineBlock.js +9 -0
  57. package/dist/app/lib/blocks/editor/EditingContext.d.ts +2 -0
  58. package/dist/app/lib/blocks/editor/EditingContext.d.ts.map +1 -0
  59. package/dist/app/lib/blocks/editor/EditingContext.js +31 -0
  60. package/dist/app/lib/blocks/editor/EditorHighlights.d.ts +1 -0
  61. package/dist/app/lib/blocks/editor/EditorHighlights.d.ts.map +1 -0
  62. package/dist/app/lib/blocks/editor/EditorHighlights.js +43 -9
  63. package/dist/app/lib/blocks/editor/EditorSupport.d.ts +1 -4
  64. package/dist/app/lib/blocks/editor/EditorSupport.d.ts.map +1 -0
  65. package/dist/app/lib/blocks/editor/EditorSupport.js +23 -9
  66. package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.d.ts +1 -0
  67. package/dist/app/lib/blocks/editor/ErrorBoundaryEditor.d.ts.map +1 -0
  68. package/dist/app/lib/blocks/editor/block-templates.d.ts +8 -1
  69. package/dist/app/lib/blocks/editor/block-templates.d.ts.map +1 -0
  70. package/dist/app/lib/blocks/editor/block-templates.js +71 -2
  71. package/dist/app/lib/blocks/editor/blocks-by-tag.d.ts +1 -0
  72. package/dist/app/lib/blocks/editor/blocks-by-tag.d.ts.map +1 -0
  73. package/dist/app/lib/blocks/editor/controls.d.ts +1 -0
  74. package/dist/app/lib/blocks/editor/controls.d.ts.map +1 -0
  75. package/dist/app/lib/blocks/editor/create-block.d.ts +10 -0
  76. package/dist/app/lib/blocks/editor/create-block.d.ts.map +1 -0
  77. package/dist/app/lib/blocks/editor/create-block.js +13 -0
  78. package/dist/app/lib/blocks/editor/editor-config.d.ts +64 -7
  79. package/dist/app/lib/blocks/editor/editor-config.d.ts.map +1 -0
  80. package/dist/app/lib/blocks/editor/editor-config.js +28 -73
  81. package/dist/app/lib/blocks/editor/installGutenbergHooks.d.ts +4 -0
  82. package/dist/app/lib/blocks/editor/installGutenbergHooks.d.ts.map +1 -0
  83. package/dist/app/lib/blocks/editor/installGutenbergHooks.js +152 -27
  84. package/dist/app/lib/blocks/editor/root-blocks.d.ts +1 -0
  85. package/dist/app/lib/blocks/editor/root-blocks.d.ts.map +1 -0
  86. package/dist/app/lib/blocks/editor/usePostEditor.d.ts +12 -1
  87. package/dist/app/lib/blocks/editor/usePostEditor.d.ts.map +1 -0
  88. package/dist/app/lib/blocks/editor/usePostEditor.js +38 -13
  89. package/dist/app/lib/blocks/index.d.ts +8 -5
  90. package/dist/app/lib/blocks/index.d.ts.map +1 -0
  91. package/dist/app/lib/blocks/index.js +8 -5
  92. package/dist/app/lib/blocks/inline-editing.d.ts +16 -1
  93. package/dist/app/lib/blocks/inline-editing.d.ts.map +1 -0
  94. package/dist/app/lib/blocks/inline-editing.js +14 -1
  95. package/dist/app/lib/devtools/components/BreakpointIndicator.d.ts +1 -0
  96. package/dist/app/lib/devtools/components/BreakpointIndicator.d.ts.map +1 -0
  97. package/dist/app/lib/devtools/components/BreakpointIndicator.js +1 -1
  98. package/dist/app/lib/devtools/components/DevUI.d.ts +1 -0
  99. package/dist/app/lib/devtools/components/DevUI.d.ts.map +1 -0
  100. package/dist/app/lib/devtools/components/DevUI.js +1 -1
  101. package/dist/app/lib/devtools/components/GridIndicator.d.ts +1 -0
  102. package/dist/app/lib/devtools/components/GridIndicator.d.ts.map +1 -0
  103. package/dist/app/lib/devtools/components/GridIndicator.js +1 -1
  104. package/dist/app/lib/devtools/dev-tools-store.d.ts +1 -0
  105. package/dist/app/lib/devtools/dev-tools-store.d.ts.map +1 -0
  106. package/dist/app/lib/devtools/hooks/usePersistState.d.ts +1 -0
  107. package/dist/app/lib/devtools/hooks/usePersistState.d.ts.map +1 -0
  108. package/dist/app/lib/devtools/hooks/useTailwind.d.ts +1358 -313
  109. package/dist/app/lib/devtools/hooks/useTailwind.d.ts.map +1 -0
  110. package/dist/app/lib/devtools/index.d.ts +1 -0
  111. package/dist/app/lib/devtools/index.d.ts.map +1 -0
  112. package/dist/app/lib/devtools/loader.d.ts +2 -1
  113. package/dist/app/lib/devtools/loader.d.ts.map +1 -0
  114. package/dist/app/lib/devtools/loader.js +4 -3
  115. package/dist/app/lib/devtools/tailwind.config.d.ts +1 -0
  116. package/dist/app/lib/devtools/tailwind.config.d.ts.map +1 -0
  117. package/dist/app/lib/devtools/useQueryDebug.d.ts +2 -1
  118. package/dist/app/lib/devtools/useQueryDebug.d.ts.map +1 -0
  119. package/dist/app/lib/dynamic/dynamic.d.ts +1 -0
  120. package/dist/app/lib/dynamic/dynamic.d.ts.map +1 -0
  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 +2 -1
  124. package/dist/app/lib/hooks/index.d.ts.map +1 -0
  125. package/dist/app/lib/hooks/index.js +1 -1
  126. package/dist/app/lib/hooks/{queryUtils.d.ts → query-hooks.d.ts} +8 -2
  127. package/dist/app/lib/hooks/query-hooks.d.ts.map +1 -0
  128. package/dist/app/lib/hooks/{queryUtils.js → query-hooks.js} +43 -11
  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 -0
  133. package/dist/app/lib/hooks/useRPC.d.ts.map +1 -0
  134. package/dist/app/lib/hooks/useRPC.js +0 -1
  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 +298 -0
  144. package/dist/app/lib/internal/finalize-rpc.d.ts +1 -0
  145. package/dist/app/lib/internal/finalize-rpc.d.ts.map +1 -0
  146. package/dist/app/lib/internal/index.d.ts +1 -0
  147. package/dist/app/lib/internal/index.d.ts.map +1 -0
  148. package/dist/app/lib/internal/internal-store.d.ts +1 -0
  149. package/dist/app/lib/internal/internal-store.d.ts.map +1 -0
  150. package/dist/app/lib/internal/read-admin-manifest.d.ts +1 -0
  151. package/dist/app/lib/internal/read-admin-manifest.d.ts.map +1 -0
  152. package/dist/app/lib/internal/read-block-manifest.d.ts +2 -0
  153. package/dist/app/lib/internal/read-block-manifest.d.ts.map +1 -0
  154. package/dist/app/lib/internal/read-block-manifest.js +7 -0
  155. package/dist/app/lib/internal/read-view-manifest.d.ts +7 -4
  156. package/dist/app/lib/internal/read-view-manifest.d.ts.map +1 -0
  157. package/dist/app/lib/internal/read-view-manifest.js +18 -0
  158. package/dist/app/lib/legacy-stitches/createStitches.d.ts +8 -7
  159. package/dist/app/lib/legacy-stitches/createStitches.d.ts.map +1 -0
  160. package/dist/app/lib/legacy-stitches/index.d.ts +1 -0
  161. package/dist/app/lib/legacy-stitches/index.d.ts.map +1 -0
  162. package/dist/app/lib/routing/components/BackButton.d.ts +1 -0
  163. package/dist/app/lib/routing/components/BackButton.d.ts.map +1 -0
  164. package/dist/app/lib/routing/components/BrowserRouter.d.ts +7 -1
  165. package/dist/app/lib/routing/components/BrowserRouter.d.ts.map +1 -0
  166. package/dist/app/lib/routing/components/BrowserRouter.js +85 -14
  167. package/dist/app/lib/routing/components/ClientOnly.d.ts +1 -0
  168. package/dist/app/lib/routing/components/ClientOnly.d.ts.map +1 -0
  169. package/dist/app/lib/routing/components/ClientOnly.js +3 -3
  170. package/dist/app/lib/routing/components/Link.d.ts +21 -2
  171. package/dist/app/lib/routing/components/Link.d.ts.map +1 -0
  172. package/dist/app/lib/routing/components/Link.js +52 -23
  173. package/dist/app/lib/routing/components/NativeLinkHandler.d.ts +10 -0
  174. package/dist/app/lib/routing/components/NativeLinkHandler.d.ts.map +1 -0
  175. package/dist/app/lib/routing/components/NativeLinkHandler.js +23 -0
  176. package/dist/app/lib/routing/components/RouteRenderer.d.ts +1 -0
  177. package/dist/app/lib/routing/components/RouteRenderer.d.ts.map +1 -0
  178. package/dist/app/lib/routing/components/RouteRenderer.js +14 -1
  179. package/dist/app/lib/routing/components/SSRRouter.d.ts +3 -0
  180. package/dist/app/lib/routing/components/SSRRouter.d.ts.map +1 -0
  181. package/dist/app/lib/routing/components/SSRRouter.js +2 -0
  182. package/dist/app/lib/routing/components/ScrollRestoration.d.ts +1 -0
  183. package/dist/app/lib/routing/components/ScrollRestoration.d.ts.map +1 -0
  184. package/dist/app/lib/routing/context.d.ts +1 -0
  185. package/dist/app/lib/routing/context.d.ts.map +1 -0
  186. package/dist/app/lib/routing/hooks/{useIsSSR.d.ts → useHydrating.d.ts} +7 -0
  187. package/dist/app/lib/routing/hooks/useHydrating.d.ts.map +1 -0
  188. package/dist/app/lib/routing/hooks/{useIsSSR.js → useHydrating.js} +13 -3
  189. package/dist/app/lib/routing/hooks/useRestorableState.d.ts +1 -0
  190. package/dist/app/lib/routing/hooks/useRestorableState.d.ts.map +1 -0
  191. package/dist/app/lib/routing/hooks/useRestorableState.js +7 -2
  192. package/dist/app/lib/routing/hooks/useRoute.d.ts +1 -0
  193. package/dist/app/lib/routing/hooks/useRoute.d.ts.map +1 -0
  194. package/dist/app/lib/routing/hooks/useRouteMeta.d.ts +1 -0
  195. package/dist/app/lib/routing/hooks/useRouteMeta.d.ts.map +1 -0
  196. package/dist/app/lib/routing/hooks/useRouteTransition.d.ts +1 -0
  197. package/dist/app/lib/routing/hooks/useRouteTransition.d.ts.map +1 -0
  198. package/dist/app/lib/routing/hooks/useRouter.d.ts +1 -0
  199. package/dist/app/lib/routing/hooks/useRouter.d.ts.map +1 -0
  200. package/dist/app/lib/routing/hooks/useRouterEvents.d.ts +1 -0
  201. package/dist/app/lib/routing/hooks/useRouterEvents.d.ts.map +1 -0
  202. package/dist/app/lib/routing/hooks/useRouterState.d.ts +1 -0
  203. package/dist/app/lib/routing/hooks/useRouterState.d.ts.map +1 -0
  204. package/dist/app/lib/routing/hooks/useSearchParams.d.ts +78 -6
  205. package/dist/app/lib/routing/hooks/useSearchParams.d.ts.map +1 -0
  206. package/dist/app/lib/routing/hooks/useSearchParams.js +75 -15
  207. package/dist/app/lib/routing/index.d.ts +4 -1
  208. package/dist/app/lib/routing/index.d.ts.map +1 -0
  209. package/dist/app/lib/routing/index.js +3 -1
  210. package/dist/app/lib/routing/loader.d.ts +1 -0
  211. package/dist/app/lib/routing/loader.d.ts.map +1 -0
  212. package/dist/app/lib/routing/loader.js +1 -1
  213. package/dist/app/lib/routing/types.d.ts +40 -6
  214. package/dist/app/lib/routing/types.d.ts.map +1 -0
  215. package/dist/app/lib/routing/utils.d.ts +2 -0
  216. package/dist/app/lib/routing/utils.d.ts.map +1 -0
  217. package/dist/app/lib/routing/utils.js +5 -1
  218. package/dist/app/lib/runtime/apiConfig.d.ts +5 -0
  219. package/dist/app/lib/runtime/apiConfig.d.ts.map +1 -0
  220. package/dist/app/lib/runtime/errorHandling.d.ts +1 -0
  221. package/dist/app/lib/runtime/errorHandling.d.ts.map +1 -0
  222. package/dist/app/lib/runtime/index.d.ts +1 -0
  223. package/dist/app/lib/runtime/index.d.ts.map +1 -0
  224. package/dist/app/lib/views/defineView.d.ts +2 -1
  225. package/dist/app/lib/views/defineView.d.ts.map +1 -0
  226. package/dist/app/lib/views/index.d.ts +1 -0
  227. package/dist/app/lib/views/index.d.ts.map +1 -0
  228. package/dist/app/server/index.d.ts +4 -3
  229. package/dist/app/server/index.d.ts.map +1 -0
  230. package/dist/app/server/index.js +3 -3
  231. package/dist/app/server/proxy-wp-admin.d.ts +1 -0
  232. package/dist/app/server/proxy-wp-admin.d.ts.map +1 -0
  233. package/dist/app/server/proxy-wp-admin.js +23 -9
  234. package/dist/app/server/render-ai-page.d.ts +13 -0
  235. package/dist/app/server/render-ai-page.d.ts.map +1 -0
  236. package/dist/app/server/render-ai-page.js +102 -0
  237. package/dist/app/server/render-ssr-page.d.ts +17 -6
  238. package/dist/app/server/render-ssr-page.d.ts.map +1 -0
  239. package/dist/app/server/render-ssr-page.js +119 -36
  240. package/dist/app/server/rpc.d.ts +18 -41
  241. package/dist/app/server/rpc.d.ts.map +1 -0
  242. package/dist/app/server/server-context.d.ts +14 -3
  243. package/dist/app/server/server-context.d.ts.map +1 -0
  244. package/dist/app/server/server-context.js +204 -21
  245. package/dist/app/server/server-custom-config.d.ts +3 -0
  246. package/dist/app/server/server-custom-config.d.ts.map +1 -0
  247. package/dist/app/server/server-custom-config.js +1 -0
  248. package/dist/app/server/utils/content-security.d.ts +26 -0
  249. package/dist/app/server/utils/content-security.d.ts.map +1 -0
  250. package/dist/app/server/utils/content-security.js +124 -0
  251. package/dist/app/server/utils/headers.d.ts +1 -0
  252. package/dist/app/server/utils/headers.d.ts.map +1 -0
  253. package/dist/app/server/utils/replace-host.d.ts +1 -0
  254. package/dist/app/server/utils/replace-host.d.ts.map +1 -0
  255. package/dist/app/server/utils/swr-cache.d.ts +1 -0
  256. package/dist/app/server/utils/swr-cache.d.ts.map +1 -0
  257. package/dist/app/utils/APIProvider.d.ts +1 -0
  258. package/dist/app/utils/APIProvider.d.ts.map +1 -0
  259. package/dist/app/utils/BlockErrorBoundary.d.ts +1 -0
  260. package/dist/app/utils/BlockErrorBoundary.d.ts.map +1 -0
  261. package/dist/app/utils/ErrorMessage.d.ts +1 -0
  262. package/dist/app/utils/ErrorMessage.d.ts.map +1 -0
  263. package/dist/app/utils/RouteErrorBoundary.d.ts +2 -0
  264. package/dist/app/utils/RouteErrorBoundary.d.ts.map +1 -0
  265. package/dist/app/utils/RouteErrorBoundary.js +3 -0
  266. package/dist/app/utils/asset-capture.d.ts +1 -0
  267. package/dist/app/utils/asset-capture.d.ts.map +1 -0
  268. package/dist/app/utils/hydration-debugger.d.ts +1 -0
  269. package/dist/app/utils/hydration-debugger.d.ts.map +1 -0
  270. package/dist/app/utils/query-client.d.ts +1 -0
  271. package/dist/app/utils/query-client.d.ts.map +1 -0
  272. package/dist/app/utils/query-monitor.d.ts +27 -0
  273. package/dist/app/utils/query-monitor.d.ts.map +1 -0
  274. package/dist/app/utils/query-monitor.js +7 -0
  275. package/dist/app/utils/trpc-client.d.ts +1 -0
  276. package/dist/app/utils/trpc-client.d.ts.map +1 -0
  277. package/dist/app/utils/trpc-client.js +1 -1
  278. package/dist/app/utils/wp.d.ts +11 -10
  279. package/dist/app/utils/wp.d.ts.map +1 -0
  280. package/dist/node/cli/cli-mode.d.ts +1 -0
  281. package/dist/node/cli/cli-mode.d.ts.map +1 -0
  282. package/dist/node/cli/cli-worker.d.ts +1 -0
  283. package/dist/node/cli/cli-worker.d.ts.map +1 -0
  284. package/dist/node/cli/cli-worker.js +1 -0
  285. package/dist/node/cli/cli.d.ts +1 -0
  286. package/dist/node/cli/cli.d.ts.map +1 -0
  287. package/dist/node/cli/cli.js +100 -11
  288. package/dist/node/cli/display/CLIApp.d.ts +1 -0
  289. package/dist/node/cli/display/CLIApp.d.ts.map +1 -0
  290. package/dist/node/cli/display/boot-cli-app.d.ts +1 -0
  291. package/dist/node/cli/display/boot-cli-app.d.ts.map +1 -0
  292. package/dist/node/cli/display/components/Fullscreen.d.ts +1 -0
  293. package/dist/node/cli/display/components/Fullscreen.d.ts.map +1 -0
  294. package/dist/node/cli/display/components/LogEntries.d.ts +1 -0
  295. package/dist/node/cli/display/components/LogEntries.d.ts.map +1 -0
  296. package/dist/node/cli/display/components/MenuItem.d.ts +1 -0
  297. package/dist/node/cli/display/components/MenuItem.d.ts.map +1 -0
  298. package/dist/node/cli/display/components/TextInput.d.ts +1 -0
  299. package/dist/node/cli/display/components/TextInput.d.ts.map +1 -0
  300. package/dist/node/cli/display/hooks/useManifest.d.ts +1 -0
  301. package/dist/node/cli/display/hooks/useManifest.d.ts.map +1 -0
  302. package/dist/node/cli/display/hooks/useStatefulLog.d.ts +1 -0
  303. package/dist/node/cli/display/hooks/useStatefulLog.d.ts.map +1 -0
  304. package/dist/node/cli/display/tools/BlockList.d.ts +1 -0
  305. package/dist/node/cli/display/tools/BlockList.d.ts.map +1 -0
  306. package/dist/node/cli/display/tools/CreateBlock.d.ts +1 -0
  307. package/dist/node/cli/display/tools/CreateBlock.d.ts.map +1 -0
  308. package/dist/node/cli/display/tools/cli-tool-list.d.ts +1 -0
  309. package/dist/node/cli/display/tools/cli-tool-list.d.ts.map +1 -0
  310. package/dist/node/cli/display/tools/cli-tools.d.ts +1 -0
  311. package/dist/node/cli/display/tools/cli-tools.d.ts.map +1 -0
  312. package/dist/node/cli/display/util/colors.d.ts +1 -0
  313. package/dist/node/cli/display/util/colors.d.ts.map +1 -0
  314. package/dist/node/cli/version.d.ts +2 -1
  315. package/dist/node/cli/version.d.ts.map +1 -0
  316. package/dist/node/cli/version.js +1 -1
  317. package/dist/node/compiler/build-vinxi.d.ts +1 -0
  318. package/dist/node/compiler/build-vinxi.d.ts.map +1 -0
  319. package/dist/node/compiler/build-vinxi.js +1 -0
  320. package/dist/node/compiler/bundler.admin.d.ts +1 -0
  321. package/dist/node/compiler/bundler.admin.d.ts.map +1 -0
  322. package/dist/node/compiler/bundler.frontend.d.ts +2 -0
  323. package/dist/node/compiler/bundler.frontend.d.ts.map +1 -0
  324. package/dist/node/compiler/bundler.frontend.js +25 -11
  325. package/dist/node/compiler/cache-config.d.ts +3 -0
  326. package/dist/node/compiler/cache-config.d.ts.map +1 -0
  327. package/dist/node/compiler/cache-config.js +16 -0
  328. package/dist/node/compiler/dev-server.d.ts +4 -1
  329. package/dist/node/compiler/dev-server.d.ts.map +1 -0
  330. package/dist/node/compiler/dev-server.js +26 -13
  331. package/dist/node/compiler/get-vite-config.d.ts +11 -1
  332. package/dist/node/compiler/get-vite-config.d.ts.map +1 -0
  333. package/dist/node/compiler/get-vite-config.js +164 -36
  334. package/dist/node/compiler/vinxi-app.d.ts +1 -0
  335. package/dist/node/compiler/vinxi-app.d.ts.map +1 -0
  336. package/dist/node/compiler/vinxi-app.js +56 -39
  337. package/dist/node/compiler/vinxi-codegen.d.ts +1 -0
  338. package/dist/node/compiler/vinxi-codegen.d.ts.map +1 -0
  339. package/dist/node/compiler/vinxi-codegen.js +152 -85
  340. package/dist/node/graphql/graphql-codegen.d.ts +1 -0
  341. package/dist/node/graphql/graphql-codegen.d.ts.map +1 -0
  342. package/dist/node/graphql/graphql-codegen.js +52 -24
  343. package/dist/node/graphql/graphql-schema-loader.d.ts +1 -0
  344. package/dist/node/graphql/graphql-schema-loader.d.ts.map +1 -0
  345. package/dist/node/graphql/plugins/gql-plugin-files.d.ts +3 -1
  346. package/dist/node/graphql/plugins/gql-plugin-files.d.ts.map +1 -0
  347. package/dist/node/graphql/plugins/gql-plugin-files.js +3 -2
  348. package/dist/node/graphql/plugins/gql-plugin-no-duplicates.d.ts +1 -0
  349. package/dist/node/graphql/plugins/gql-plugin-no-duplicates.d.ts.map +1 -0
  350. package/dist/node/graphql/plugins/gql-plugin-queries.d.ts +1 -0
  351. package/dist/node/graphql/plugins/gql-plugin-queries.d.ts.map +1 -0
  352. package/dist/node/graphql/plugins/gql-plugin-queries.js +1 -1
  353. package/dist/node/graphql/query-files-loader.d.ts +1 -0
  354. package/dist/node/graphql/query-files-loader.d.ts.map +1 -0
  355. package/dist/node/graphql/wp-info-query.d.ts +1 -0
  356. package/dist/node/graphql/wp-info-query.d.ts.map +1 -0
  357. package/dist/node/project/config.d.ts +112 -7
  358. package/dist/node/project/config.d.ts.map +1 -0
  359. package/dist/node/project/config.js +54 -24
  360. package/dist/node/project/eddev-build-file.d.ts +1 -0
  361. package/dist/node/project/eddev-build-file.d.ts.map +1 -0
  362. package/dist/node/project/eddev-build-file.js +4 -2
  363. package/dist/node/project/env.d.ts +1 -0
  364. package/dist/node/project/env.d.ts.map +1 -0
  365. package/dist/node/project/favicons.d.ts +1 -0
  366. package/dist/node/project/favicons.d.ts.map +1 -0
  367. package/dist/node/project/manifest/block-manifest.d.ts +1 -0
  368. package/dist/node/project/manifest/block-manifest.d.ts.map +1 -0
  369. package/dist/node/project/manifest/block-manifest.js +7 -2
  370. package/dist/node/project/manifest/field-manifest.d.ts +1 -0
  371. package/dist/node/project/manifest/field-manifest.d.ts.map +1 -0
  372. package/dist/node/project/manifest/manifest.d.ts +1 -0
  373. package/dist/node/project/manifest/manifest.d.ts.map +1 -0
  374. package/dist/node/project/manifest/routes-manifest.d.ts +1 -0
  375. package/dist/node/project/manifest/routes-manifest.d.ts.map +1 -0
  376. package/dist/node/project/manifest/routes-manifest.js +1 -1
  377. package/dist/node/project/manifest/view-manifest.d.ts +1 -0
  378. package/dist/node/project/manifest/view-manifest.d.ts.map +1 -0
  379. package/dist/node/project/manifest/widget-manifest.d.ts +1 -0
  380. package/dist/node/project/manifest/widget-manifest.d.ts.map +1 -0
  381. package/dist/node/project/project.d.ts +4 -0
  382. package/dist/node/project/project.d.ts.map +1 -0
  383. package/dist/node/project/project.js +24 -1
  384. package/dist/node/project/wp-info.d.ts +2 -0
  385. package/dist/node/project/wp-info.d.ts.map +1 -0
  386. package/dist/node/storybook/index.d.ts +3 -0
  387. package/dist/node/storybook/index.d.ts.map +1 -0
  388. package/dist/node/storybook/index.js +13 -0
  389. package/dist/node/types/block-type.d.ts +33 -6
  390. package/dist/node/types/block-type.d.ts.map +1 -0
  391. package/dist/node/types/block-type.js +3 -1
  392. package/dist/node/types/view-type.d.ts +1 -0
  393. package/dist/node/types/view-type.d.ts.map +1 -0
  394. package/dist/node/utils/fetch-wp.d.ts +1 -0
  395. package/dist/node/utils/fetch-wp.d.ts.map +1 -0
  396. package/dist/node/utils/fetch-wp.js +4 -3
  397. package/dist/node/utils/format-zod-error.d.ts +1 -0
  398. package/dist/node/utils/format-zod-error.d.ts.map +1 -0
  399. package/dist/node/utils/fs-codegen.d.ts +2 -0
  400. package/dist/node/utils/fs-codegen.d.ts.map +1 -0
  401. package/dist/node/utils/fs-codegen.js +8 -1
  402. package/dist/node/utils/fs.d.ts +24 -16
  403. package/dist/node/utils/fs.d.ts.map +1 -0
  404. package/dist/node/utils/get-repo-info.d.ts +1 -0
  405. package/dist/node/utils/get-repo-info.d.ts.map +1 -0
  406. package/dist/node/utils/helpers.d.ts +1 -0
  407. package/dist/node/utils/helpers.d.ts.map +1 -0
  408. package/dist/node/utils/highlight-code.d.ts +1 -0
  409. package/dist/node/utils/highlight-code.d.ts.map +1 -0
  410. package/dist/node/utils/is-deploying.d.ts +1 -0
  411. package/dist/node/utils/is-deploying.d.ts.map +1 -0
  412. package/dist/node/utils/report-builder.d.ts +7 -6
  413. package/dist/node/utils/report-builder.d.ts.map +1 -0
  414. package/dist/node/utils/self-signed-cert.d.ts +5 -0
  415. package/dist/node/utils/self-signed-cert.d.ts.map +1 -0
  416. package/dist/node/utils/self-signed-cert.js +28 -4
  417. package/dist/node/utils/stateful-log.d.ts +1 -0
  418. package/dist/node/utils/stateful-log.d.ts.map +1 -0
  419. package/dist/node/utils/ts-export-extractor.d.ts +1 -0
  420. package/dist/node/utils/ts-export-extractor.d.ts.map +1 -0
  421. package/dist/node/utils/watch-file-tree.d.ts +1 -0
  422. package/dist/node/utils/watch-file-tree.d.ts.map +1 -0
  423. package/package.json +34 -24
  424. package/tsconfig.app.json +8 -3
  425. package/tsconfig.node.json +1 -0
  426. package/types.env.d.ts +3 -0
  427. package/types.meta.d.ts +449 -136
  428. package/dist/app/server/defineRouter.d.ts +0 -2
  429. package/dist/app/server/defineRouter.js +0 -4
@@ -1,25 +1,59 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useMemo } from "react";
2
3
  import { ContentBlocks } from "./ContentBlocks.js";
3
- import { transformBlockTemplate } from "./editor/block-templates.js";
4
+ import { applyTemplateBlocks, transformBlockTemplate } from "./editor/block-templates.js";
4
5
  import { blocksByTag } from "./editor/blocks-by-tag.js";
5
6
  import { useBlockContext, useInnerBlocks } from "./inline-editing.js";
6
- const Appender = (props) => {
7
+ import { hash } from "object-code";
8
+ const Appender = ({ config, ...props }) => {
7
9
  const clientId = useBlockContext()?.block[1].clientId;
8
- if (props.type === "button") {
9
- return _jsx(wp.blockEditor.ButtonBlockAppender, { className: props.className, rootClientId: clientId });
10
+ if (config?.type === "button") {
11
+ return _jsx(wp.blockEditor.ButtonBlockAppender, { ...props, rootClientId: clientId, className: config.className });
10
12
  }
11
- else if (typeof props.type === "function") {
12
- const Type = props.type;
13
- return (_jsx(wp.blockEditor.Inserter, { renderToggle: (p) => {
13
+ else if (config?.type === "button2") {
14
+ return _jsx(wp.blockEditor.InnerBlocks.ButtonBlockAppender, {});
15
+ }
16
+ else if (config?.type === "simple") {
17
+ return (_jsx(wp.blockEditor.ButtonBlockAppender, { ...props, rootClientId: clientId, className: (props.className || "") + " block-editor-inserter__toggle has-icon simple-appender" }));
18
+ }
19
+ else if (typeof config?.type === "function") {
20
+ const Type = config?.type;
21
+ return (_jsx(wp.blockEditor.Inserter, { rootClientId: clientId, renderToggle: (p) => {
14
22
  return _jsx(Type, { ...p });
15
- }, rootClientId: clientId }));
23
+ }, isAppender: true, disabled: false }));
24
+ // } else if (config?.type === "simple") {
25
+ // return (
26
+ // <wp.blockEditor.Inserter
27
+ // clientId={clientId}
28
+ // rootClientId={clientId}
29
+ // renderToggle={(p: any) => {
30
+ // return (
31
+ // <button
32
+ // className="simple-appender components-button block-editor-inserter__toggle !inline-flex has-icon"
33
+ // onClick={() => p.onToggle()}
34
+ // >
35
+ // <svg
36
+ // xmlns="http://www.w3.org/2000/svg"
37
+ // viewBox="0 0 24 24"
38
+ // width="24"
39
+ // height="24"
40
+ // aria-hidden="true"
41
+ // focusable="false"
42
+ // >
43
+ // <path d="M11 12.5V17.5H12.5V12.5H17.5V11H12.5V6H11V11H6V12.5H11Z"></path>
44
+ // </svg>
45
+ // </button>
46
+ // )
47
+ // }}
48
+ // isAppender
49
+ // // @ts-ignore
50
+ // __experimentalIsQuick
51
+ // />
52
+ // )
16
53
  }
17
54
  else {
18
- return (_jsx(wp.blockEditor.DefaultBlockAppender
19
55
  // @ts-ignore
20
- , {
21
- // @ts-ignore
22
- className: props.className, rootClientId: clientId, lastBlockClientId: clientId }));
56
+ return _jsx(wp.blockEditor.InnerBlocks.DefaultBlockAppender, { ...props });
23
57
  }
24
58
  };
25
59
  export function createAppender(comp) {
@@ -33,29 +67,35 @@ export function createAppender(comp) {
33
67
  export function InnerBlocks(props) {
34
68
  if (env.admin) {
35
69
  const inlineContext = useBlockContext();
70
+ const appender = useMemo(() => {
71
+ return (p) => _jsx(Appender, { config: props.appender, ...p });
72
+ }, [props.appender]);
36
73
  if (!inlineContext?.readonly) {
37
74
  const innerBlocksProps = wp.blockEditor.useInnerBlocksProps({}, {
38
75
  orientation: props.orientation ?? "vertical",
39
76
  allowedBlocks: props.allowedBlocks ? blocksByTag.expand(props.allowedBlocks) : undefined,
40
77
  prioritizedInserterBlocks: props.prioritizedInserterBlocks,
41
- renderAppender: props.appender
42
- ? () => _jsx(Appender, { ...props.appender })
43
- : wp.blockEditor.InnerBlocks.ButtonBlockAppender,
44
- templateLock: props.templateLock ?? false,
78
+ renderAppender: appender,
79
+ templateLock: props.templateLock === "none" ? false : (props.templateLock ?? false),
45
80
  template: props.template ? transformBlockTemplate(props.template) : undefined,
46
81
  });
82
+ /**
83
+ * A little bit experimental
84
+ *
85
+ * Adds support for headerTemplate/defaultBlocks/footerTemplate, which was first introduced in `_editor.tsx` for generate templates.
86
+ */
87
+ const blockId = inlineContext?.block[1].clientId;
88
+ useEffect(() => {
89
+ if (props.defaultBlocks || props.headerTemplate || props.footerTemplate) {
90
+ const newBlocks = applyTemplateBlocks(inlineContext?.innerBlocks ?? [], props);
91
+ wp.data.dispatch(wp.blockEditor.store).replaceInnerBlocks(blockId, newBlocks);
92
+ }
93
+ }, [
94
+ hash(inlineContext?.innerBlocks.filter((b) => !!b).map((b) => [b.blockName, b.clientId])),
95
+ hash([props.template, props.defaultBlocks, props.headerTemplate, props.footerTemplate]),
96
+ blockId,
97
+ ]);
47
98
  return (_jsx("div", { ...innerBlocksProps, className: [innerBlocksProps.className, props.adminClassName].filter(Boolean).join(" ") }));
48
- // return (
49
- // <wp.blockEditor.InnerBlocks
50
- // // @ts-ignore
51
- // orientation={props.orientation}
52
- // prioritizedInserterBlocks={props.prioritizedInserterBlocks}
53
- // allowedBlocks={props.allowedBlocks ? blocksByTag.expand(props.allowedBlocks) : undefined}
54
- // renderAppender={props.appender ? () => <Appender {...props.appender!} /> : undefined}
55
- // templateLock={(props.templateLock as any) ?? false}
56
- // template={props.template ? transformBlockTemplate(props.template) : undefined}
57
- // />
58
- // )
59
99
  }
60
100
  }
61
101
  const blocks = useInnerBlocks();
@@ -0,0 +1,8 @@
1
+ import { InnerBlocksProps } from "./InnerBlocks";
2
+ type SlotProps = {
3
+ id: string;
4
+ title?: string;
5
+ } & InnerBlocksProps;
6
+ export declare function SlotBlocks(props: SlotProps): import("react/jsx-runtime").JSX.Element | null;
7
+ export {};
8
+ //# sourceMappingURL=SlotBlocks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SlotBlocks.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/blocks/SlotBlocks.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAEhD,KAAK,SAAS,GAAG;IACf,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,GAAG,gBAAgB,CAAA;AAEpB,wBAAgB,UAAU,CAAC,KAAK,EAAE,SAAS,kDAyD1C"}
@@ -0,0 +1,45 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { hash } from "object-code";
3
+ import { useEffect } from "react";
4
+ import { ContentBlocks } from "./ContentBlocks";
5
+ import { InlineEditingContextProvider, useBlockContext, useInnerBlocks } from "./inline-editing";
6
+ export function SlotBlocks(props) {
7
+ if (env.admin) {
8
+ const clientId = useBlockContext()?.block[1].clientId;
9
+ const block = wp.data.useSelect((select) => {
10
+ const { getBlocks } = select("core/block-editor");
11
+ return getBlocks(clientId).find((block) => block.name === "core/slot-group" && block.attributes?.props?.id === props.id);
12
+ }, [clientId, props.id]);
13
+ useEffect(() => {
14
+ const blocks = wp.data.select("core/block-editor").getBlocks(clientId);
15
+ const block = blocks.find((block) => block.name === "core/slot-group" && block.attributes?.props?.id === props.id);
16
+ let changed = false;
17
+ if (block && hash(block.attributes.props) !== hash(props)) {
18
+ block.attributes.props = props;
19
+ changed = true;
20
+ }
21
+ else if (!block) {
22
+ const newBlock = wp.blocks.createBlock("core/slot-group", { props }, []);
23
+ blocks.push(newBlock);
24
+ changed = true;
25
+ }
26
+ else {
27
+ return;
28
+ }
29
+ if (changed) {
30
+ wp.data.dispatch("core/block-editor").replaceInnerBlocks(clientId, blocks);
31
+ }
32
+ }, [block?.clientId, hash(props)]);
33
+ if (block) {
34
+ return (_jsx(InlineEditingContextProvider, { values: {}, innerBlocks: block.innerBlocks, block: ["core/slot-group", block], index: -1, onChange: (attrs) => { }, insertBlocksAfter: () => { }, children: _jsx(wp.blockEditor.BlockEdit, { ...block }) }));
35
+ }
36
+ else {
37
+ return null;
38
+ }
39
+ }
40
+ else {
41
+ const blocks = useInnerBlocks();
42
+ const block = blocks.find((block) => block.blockName === "core/slot-group" && block.slotId === props.id);
43
+ return _jsx(ContentBlocks, { blocks: block?.innerBlocks });
44
+ }
45
+ }
@@ -22,3 +22,4 @@ export declare function getBlockMetadata(blockName: string): {
22
22
  flags: DefinedBlockFlags;
23
23
  slug: BlockTypeName;
24
24
  };
25
+ //# sourceMappingURL=block-utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block-utils.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/blocks/block-utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAEjD;;;GAGG;AACH,wBAAgB,kBAAkB;;EAEjC;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI,GAAG,SAAS,GAAG,YAAY,EAAE,CA4B1F;AAED,wBAAgB,gBAAgB,CAAC,SAAS,EAAE,MAAM;;;;;;;;EAYjD"}
@@ -16,13 +16,30 @@ export function addBlockMetadata(blocks) {
16
16
  const out = (blocks ?? []);
17
17
  const infos = getPublicBlockInfo();
18
18
  for (let block of out) {
19
- const info = infos[block.blockName];
19
+ if (!block)
20
+ continue;
21
+ const info = infos[block.blockName ?? block.name];
20
22
  block.tags = info?.tags ?? [];
21
23
  block.flags = info?.flags ?? {};
22
24
  block.slug = (info?.slug ?? block.blockName);
23
25
  if (block.innerBlocks && block.innerBlocks.length) {
24
26
  addBlockMetadata(block.innerBlocks);
25
27
  }
28
+ if (env.admin) {
29
+ if (!Object.hasOwn(block, "props")) {
30
+ Object.defineProperty(block, "props", {
31
+ // @ts-ignore
32
+ get: () => block.attributes?.props || {},
33
+ set: (value) => {
34
+ // @ts-ignore
35
+ if (!block.attributes)
36
+ block.attributes = {};
37
+ // @ts-ignore
38
+ block.attributes.props = value;
39
+ },
40
+ });
41
+ }
42
+ }
26
43
  }
27
44
  return out;
28
45
  }
@@ -0,0 +1,2 @@
1
+ export declare function registerBuiltinBlocks(): void;
2
+ //# sourceMappingURL=builtin-blocks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"builtin-blocks.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/blocks/builtin-blocks.tsx"],"names":[],"mappings":"AAEA,wBAAgB,qBAAqB,SAqDpC"}
@@ -0,0 +1,55 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { InnerBlocks } from "./InnerBlocks";
3
+ export function registerBuiltinBlocks() {
4
+ /**
5
+ * Register the Slot Group block, used by SlotBlocks.tsx
6
+ */
7
+ // @ts-ignore
8
+ wp.blocks.registerBlockType("core/slot-group", {
9
+ title: "Slot",
10
+ icon: "editor-insertmore",
11
+ attributes: {
12
+ props: { type: "object" },
13
+ },
14
+ category: "text",
15
+ // @ts-ignore
16
+ __experimentalLabel: (attributes) => {
17
+ if (attributes?.props?.title) {
18
+ return attributes?.props?.title;
19
+ }
20
+ },
21
+ edit: (props) => {
22
+ const { id, ...innerProps } = props.attributes.props ?? {};
23
+ return _jsx(InnerBlocks, { appender: { type: "simple" }, ...innerProps });
24
+ },
25
+ save: () => _jsx(wp.blockEditor.InnerBlocks.Content, {}),
26
+ supports: {
27
+ inserter: false,
28
+ reusable: false,
29
+ className: false,
30
+ customClassName: false,
31
+ renaming: false,
32
+ },
33
+ });
34
+ // wp.blocks.registerBlockType("core/link", {
35
+ // title: "Link",
36
+ // icon :"admin-links",
37
+ // attributes: {
38
+ // label: { type: "string" },
39
+ // url: { type: "string" },
40
+ // target: { type: "string" },
41
+ // },
42
+ // edit: (props) => {
43
+ // return <div>
44
+ // <InspectorControls>
45
+ // <wp.blockEditor.__experimentalLinkControl
46
+ // onChange={(e) => {
47
+ // console.log(e)
48
+ // // setLink({})
49
+ // }}
50
+ // />
51
+ // </InspectorControls>
52
+ // </div>
53
+ // }
54
+ // })
55
+ }
@@ -1,2 +1,6 @@
1
1
  import { ComponentType, ReactNode } from "react";
2
2
  export declare function defineBlock<TName extends keyof BlockProps>(name: TName, component: (props: BlockProps[TName]) => ReactNode): ComponentType<BlockProps[TName]>;
3
+ export declare namespace defineBlock {
4
+ var meta: (name: string, meta: any) => void;
5
+ }
6
+ //# sourceMappingURL=defineBlock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defineBlock.d.ts","sourceRoot":"","sources":["../../../../src/app/lib/blocks/defineBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAIhD,wBAAgB,WAAW,CAAC,KAAK,SAAS,MAAM,UAAU,EACxD,IAAI,EAAE,KAAK,EACX,SAAS,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC,KAAK,SAAS,GACjD,aAAa,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAElC;yBALe,WAAW;qBAOD,MAAM,QAAQ,GAAG"}
@@ -1,3 +1,12 @@
1
+ import { blockMetaDescriptors } from "./editor/installGutenbergHooks";
2
+ import { resolveAcfBlockName } from "./editor/block-templates";
1
3
  export function defineBlock(name, component) {
2
4
  return component;
3
5
  }
6
+ defineBlock.meta = (name, meta) => {
7
+ if (env.admin) {
8
+ if (wp.blocks) {
9
+ blockMetaDescriptors.set(resolveAcfBlockName(name, false), meta);
10
+ }
11
+ }
12
+ };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=EditingContext.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditingContext.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/EditingContext.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,31 @@
1
+ export {};
2
+ // type BlockAttributes = Record<string, unknown>
3
+ // type EditableBlock = ContentBlock & {
4
+ // name: string
5
+ // slug: BlockTypeName | (string & {})
6
+ // attributes: BlockAttributes
7
+ // clientId: string
8
+ // rootClientId: string
9
+ // isRootBlock: boolean
10
+ // getParent: () => EditableBlock | null
11
+ // canMove: boolean
12
+ // canRemove: boolean
13
+ // isSelected: boolean
14
+ // isSelectionEnabled: boolean
15
+ // tags?: DefinedBlockTags
16
+ // flags?: DefinedBlockFlags
17
+ // }
18
+ // type EditingContext = {
19
+ // block: BlockEditingContext
20
+ // }
21
+ // type BlockEditingContext = {
22
+ // clientId: string
23
+ // attributes: BlockAttributes
24
+ // insertBlock: (block: BlockInstance) => void
25
+ // setAttributes: (attrs: BlockAttributes) => void
26
+ // block: ContentBlock & BlockInstance
27
+ // }
28
+ // const EditingContext = createContext<EditingContext>(undefined!)
29
+ // export function useEditingContext() {
30
+ // return
31
+ // }
@@ -5,3 +5,4 @@ type Props = PropsWithChildren<{
5
5
  }>;
6
6
  export declare function EditorHighlights(props: Props): import("react/jsx-runtime").JSX.Element;
7
7
  export {};
8
+ //# sourceMappingURL=EditorHighlights.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditorHighlights.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/EditorHighlights.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAwC,MAAM,OAAO,CAAA;AAE/E,KAAK,KAAK,GAAG,iBAAiB,CAAC;IAC7B,OAAO,EAAE,OAAO,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAC,CAAA;AAEF,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,KAAK,2CA2D5C"}
@@ -1,7 +1,7 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { useEffect, useRef, useState } from "react";
1
+ import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
3
  export function EditorHighlights(props) {
4
- const ref = useRef(null);
4
+ const [element, setElement] = useState(null);
5
5
  const [controller, setController] = useState(null);
6
6
  // wp.data.select('core/editor').isBlockSelected
7
7
  // const isSelected = wp.data.useSelect(
@@ -9,12 +9,12 @@ export function EditorHighlights(props) {
9
9
  // [props.clientId]
10
10
  // )
11
11
  useEffect(() => {
12
- if (!props.enabled)
12
+ if (!props.enabled || !element)
13
13
  return;
14
- const controller = new HighlightController(ref.current);
14
+ const controller = new HighlightController(element);
15
15
  setController(controller);
16
16
  return () => controller.teardown();
17
- }, [props.enabled]);
17
+ }, [props.enabled, element]);
18
18
  useEffect(() => {
19
19
  if (controller) {
20
20
  controller.isSelected = false;
@@ -22,7 +22,38 @@ export function EditorHighlights(props) {
22
22
  controller.update();
23
23
  }
24
24
  }, [controller, false]);
25
- return (_jsx("div", { ref: ref, style: { display: "contents" }, onPointerEnter: () => controller?.enable(), onPointerLeave: () => controller?.disable(), children: props.children }));
25
+ useEffect(() => {
26
+ const element = document.getElementById(`block-${props.clientId}`);
27
+ if (element) {
28
+ setElement(element);
29
+ }
30
+ else {
31
+ setElement(null);
32
+ }
33
+ }, [props.clientId]);
34
+ useEffect(() => {
35
+ if (controller && element) {
36
+ const onPointerEnter = () => controller.enable();
37
+ const onPointerLeave = () => controller.disable();
38
+ element.addEventListener("pointerenter", onPointerEnter);
39
+ element.addEventListener("pointerleave", onPointerLeave);
40
+ return () => {
41
+ element.removeEventListener("pointerenter", onPointerEnter);
42
+ element.removeEventListener("pointerleave", onPointerLeave);
43
+ };
44
+ }
45
+ }, [element, controller]);
46
+ return _jsx(_Fragment, { children: props.children });
47
+ // return (
48
+ // <div
49
+ // ref={ref}
50
+ // style={{ display: "contents" }}
51
+ // // onPointerEnter={() => controller?.enable()}
52
+ // // onPointerLeave={() => controller?.disable()}
53
+ // >
54
+ // {props.children}
55
+ // </div>
56
+ // )
26
57
  }
27
58
  class HighlightController {
28
59
  root;
@@ -40,7 +71,7 @@ class HighlightController {
40
71
  let editables = Array.from(this.root.querySelectorAll("[contenteditable=true], .editable-slot"));
41
72
  let childBlocks = Array.from(this.root.querySelectorAll(".wp-block"));
42
73
  const childIsSelected = this.root.querySelectorAll(".editor-highlighter-root-selected").length > 0;
43
- this.block = childBlocks[0];
74
+ this.block = this.root;
44
75
  childBlocks = childBlocks.slice(1);
45
76
  editables = childIsSelected
46
77
  ? []
@@ -96,7 +127,10 @@ class HighlightController {
96
127
  el.style.position = "absolute";
97
128
  el.style.pointerEvents = "none";
98
129
  el.style.zIndex = "20";
99
- el.className = "editor-highlight";
130
+ el.classList.add("editor-highlight");
131
+ if (target.getAttribute("data-editor-higlight-class")) {
132
+ el.classList.add(target.getAttribute("data-editor-higlight-class"));
133
+ }
100
134
  this.block.appendChild(el);
101
135
  return el;
102
136
  }
@@ -1,5 +1,2 @@
1
- export declare const BlockContext: import("react").Context<{
2
- name: string;
3
- props: any;
4
- } | undefined>;
5
1
  export declare function EditableBlock({ payload }: any): import("react/jsx-runtime").JSX.Element | null;
2
+ //# sourceMappingURL=EditorSupport.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditorSupport.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/EditorSupport.tsx"],"names":[],"mappings":"AAUA,wBAAgB,aAAa,CAAC,EAAE,OAAO,EAAE,EAAE,GAAG,kDAkC7C"}
@@ -1,18 +1,32 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { createContext, Suspense, useContext } from "react";
2
+ import { Suspense, useMemo } from "react";
3
3
  import { blockManifestReader } from "../../internal/read-block-manifest.js";
4
4
  import { APIProvider } from "../../../utils/APIProvider.js";
5
+ import { useBlockMutation } from "../BlockPropMutator.js";
6
+ import { useBlockContext } from "../inline-editing.js";
5
7
  import { ErrorBoundaryEditor } from "./ErrorBoundaryEditor.js";
6
- export const BlockContext = createContext(undefined);
8
+ // export const BlockContext = createContext<{ name: string; props: any } | undefined>(undefined)
7
9
  export function EditableBlock({ payload }) {
8
- const block = useContext(BlockContext);
9
- if (!block)
10
+ if (!env.admin)
11
+ throw new Error("`EditableBlock` can only be used in the admin environment");
12
+ const info = useBlockContext();
13
+ const mutation = useBlockMutation();
14
+ const block = info?.editorBlock;
15
+ const props = useMemo(() => {
16
+ let props = payload ?? {};
17
+ if (!block)
18
+ return props;
19
+ props.blockStyle = info?.editorBlock?.attributes?.className?.replace("is-style-", "");
20
+ block.props = props;
21
+ if (mutation.mutate) {
22
+ mutation.mutate(block);
23
+ }
24
+ return block.props;
25
+ }, [block, payload, mutation.mutate]);
26
+ if (!info)
10
27
  return null;
11
- const getBlock = () => {
12
- return blockManifestReader.value[block.name];
13
- };
14
- const BlockComponent = getBlock();
28
+ const BlockComponent = blockManifestReader.value[info.editorBlock?.name ?? ""];
15
29
  if (!BlockComponent)
16
30
  return _jsx("div", { children: "Unable to load block component" });
17
- return (_jsx(ErrorBoundaryEditor, { children: _jsx(APIProvider, { children: _jsx(Suspense, { children: _jsx(BlockComponent, { ...payload }) }) }) }));
31
+ return (_jsx(ErrorBoundaryEditor, { children: _jsx(APIProvider, { children: _jsx(Suspense, { children: _jsx(BlockComponent, { ...props }) }) }) }));
18
32
  }
@@ -13,3 +13,4 @@ export declare class ErrorBoundaryEditor extends Component<Props, State> {
13
13
  render(): string | number | boolean | Iterable<React.ReactNode> | import("react/jsx-runtime").JSX.Element | null | undefined;
14
14
  }
15
15
  export {};
16
+ //# sourceMappingURL=ErrorBoundaryEditor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorBoundaryEditor.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/ErrorBoundaryEditor.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAE9D,UAAU,KAAK;IACb,QAAQ,EAAE,SAAS,CAAA;CACpB;AAED,UAAU,KAAK;IACb,QAAQ,EAAE,OAAO,CAAA;IACjB,KAAK,CAAC,EAAE,KAAK,CAAA;CACd;AAED,qBAAa,mBAAoB,SAAQ,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC;IACvD,KAAK,EAAE,KAAK,CAElB;WAEa,wBAAwB,CAAC,GAAG,EAAE,KAAK,GAAG,KAAK;IAKlD,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS;IAIpD,MAAM;CAqBd"}
@@ -1,3 +1,10 @@
1
1
  export type BlockTemplate = [name: ChildBlockTypeName, props: any, children?: BlockTemplate][];
2
- export declare function resolveAcfBlockName(name: string): string;
2
+ export declare function resolveAcfBlockName(name: string, check?: boolean): string;
3
3
  export declare function transformBlockTemplate(template: BlockTemplate): BlockTemplate;
4
+ export declare function applyTemplateBlocks(currentBlocks: any[], config: {
5
+ defaultBlocks?: BlockTemplate;
6
+ headerTemplate?: BlockTemplate;
7
+ footerTemplate?: BlockTemplate;
8
+ }): any[];
9
+ export declare function transformTemplateToBlocks(template: BlockTemplate, locked?: boolean, isFromTemplate?: boolean): any;
10
+ //# sourceMappingURL=block-templates.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"block-templates.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/block-templates.tsx"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG,CAAC,IAAI,EAAE,kBAAkB,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,aAAa,CAAC,EAAE,CAAA;AAE9F,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,UAAO,UAO7D;AAED,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,aAAa,GAAG,aAAa,CAI7E;AAED,wBAAgB,mBAAmB,CACjC,aAAa,EAAE,GAAG,EAAE,EACpB,MAAM,EAAE;IACN,aAAa,CAAC,EAAE,aAAa,CAAA;IAC7B,cAAc,CAAC,EAAE,aAAa,CAAA;IAC9B,cAAc,CAAC,EAAE,aAAa,CAAA;CAC/B,SA2CF;AAED,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,aAAa,EAAE,MAAM,UAAO,EAAE,cAAc,UAAO,GAAG,GAAG,CAyB5G"}
@@ -1,9 +1,78 @@
1
- export function resolveAcfBlockName(name) {
1
+ export function resolveAcfBlockName(name, check = true) {
2
2
  const acfName = "acf/" + name.replace("/", "-").replace("_", "");
3
- return wp.blocks.getBlockType(acfName) ? acfName : name;
3
+ if (check) {
4
+ return wp.blocks.getBlockType(acfName) ? acfName : name;
5
+ }
6
+ else {
7
+ return acfName;
8
+ }
4
9
  }
5
10
  export function transformBlockTemplate(template) {
6
11
  return template.map(([name, props, children]) => {
7
12
  return [resolveAcfBlockName(name), props, children ? transformBlockTemplate(children) : undefined];
8
13
  });
9
14
  }
15
+ export function applyTemplateBlocks(currentBlocks, config) {
16
+ const templateBlocks = currentBlocks.filter((block) => block.attributes.isFromTemplate);
17
+ let header = config.headerTemplate ? syncBlocks(transformTemplateToBlocks(config.headerTemplate)) : [];
18
+ let footer = config.footerTemplate ? syncBlocks(transformTemplateToBlocks(config.footerTemplate)) : [];
19
+ let blocks = currentBlocks.filter((block) => !header.includes(block) && !footer.includes(block));
20
+ blocks.forEach((block) => {
21
+ delete block.attributes.lock;
22
+ delete block.isFromTemplate;
23
+ });
24
+ // const blocksToDelete = currentBlocks.filter((block: any) => {
25
+ // return !header.includes(block) && !footer.includes(block) && !blocks.includes(block)
26
+ // })
27
+ // blocksToDelete.forEach((block: any) => {
28
+ // delete block.attributes.lock
29
+ // delete block.isFromTemplate
30
+ // })
31
+ // blocks = [...blocks, ...blocksToDelete]
32
+ // console.log("blocks", blocks)
33
+ // console.log("blocksToDelete", blocksToDelete)
34
+ if (!blocks.length && config.defaultBlocks) {
35
+ blocks = transformTemplateToBlocks(config.defaultBlocks, false, false);
36
+ }
37
+ let newBlocks = [...header, ...blocks, ...footer];
38
+ function syncBlocks(blocks) {
39
+ return blocks.map((block) => {
40
+ const matched = templateBlocks.find((templateBlock) => templateBlock.name === block.name);
41
+ templateBlocks.splice(templateBlocks.indexOf(matched), 1);
42
+ if (matched) {
43
+ matched.attributes.lock = block.attributes.lock;
44
+ return matched;
45
+ }
46
+ return block;
47
+ });
48
+ }
49
+ return newBlocks;
50
+ }
51
+ export function transformTemplateToBlocks(template, locked = true, isFromTemplate = true) {
52
+ return template.map(([name, props, children]) => {
53
+ const attributes = {
54
+ data: {},
55
+ inline: {},
56
+ isFromTemplate: isFromTemplate,
57
+ lock: undefined,
58
+ };
59
+ if (props.locked === false) {
60
+ attributes.lock = { move: false, remove: false };
61
+ }
62
+ else if (locked || props.locked === true || props.locked === "all") {
63
+ attributes.lock = { move: true, remove: true };
64
+ }
65
+ else {
66
+ attributes.lock = props.lock;
67
+ }
68
+ Object.assign(attributes, props);
69
+ return {
70
+ clientId: "block-" + Math.random().toString(36),
71
+ name: resolveAcfBlockName(name),
72
+ attributes: attributes,
73
+ innerBlocks: children ? transformTemplateToBlocks(children, false, isFromTemplate) : [],
74
+ isValid: true,
75
+ validationIssues: [],
76
+ };
77
+ });
78
+ }
@@ -5,3 +5,4 @@ export declare const blocksByTag: {
5
5
  add(block: string, tags: string[]): void;
6
6
  expand(blocks: string[]): string[];
7
7
  };
8
+ //# sourceMappingURL=blocks-by-tag.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocks-by-tag.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/blocks-by-tag.tsx"],"names":[],"mappings":"AAEA;;GAEG;AACH,eAAO,MAAM,WAAW;eACX,MAAM,QAAQ,MAAM,EAAE;mBAYlB,MAAM,EAAE;CAuBxB,CAAA"}
@@ -8,3 +8,4 @@ import { PropsWithChildren } from "react";
8
8
  */
9
9
  export declare function InspectorControls(props: PropsWithChildren<{}>): import("react/jsx-runtime").JSX.Element | null;
10
10
  export declare function BlockControls(props: PropsWithChildren<{}>): import("react/jsx-runtime").JSX.Element | null;
11
+ //# sourceMappingURL=controls.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"controls.d.ts","sourceRoot":"","sources":["../../../../../src/app/lib/blocks/editor/controls.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAA;AAEzC;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,iBAAiB,CAAC,EAAE,CAAC,kDAK7D;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,iBAAiB,CAAC,EAAE,CAAC,kDAKzD"}