@blokkli/editor 2.0.0-alpha.2 → 2.0.0-alpha.21

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 (428) hide show
  1. package/dist/module.d.mts +1 -1
  2. package/dist/module.json +5 -5
  3. package/dist/module.mjs +5549 -1269
  4. package/dist/modules/drupal/graphql/base/fragment.ParagraphsBlokkliConfigInput.graphql +31 -0
  5. package/dist/modules/drupal/graphql/base/fragment.blokkliProps.graphql +9 -0
  6. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliEditState.graphql +5 -0
  7. package/dist/modules/drupal/graphql/base/fragment.paragraphsFieldItem.graphql +9 -0
  8. package/dist/modules/drupal/graphql/base/query.pbConfig.graphql +1 -10
  9. package/dist/modules/drupal/graphql/base/query.pbEntityConfig.graphql +5 -0
  10. package/dist/modules/drupal/graphql/features/comments.graphql +11 -8
  11. package/dist/modules/drupal/graphql/features/publishNew.graphql +1 -4
  12. package/dist/modules/drupal/graphql/features/scheduler.graphql +31 -0
  13. package/dist/modules/drupal/graphql/features/transform.graphql +9 -1
  14. package/dist/modules/drupal/graphql/features/transform_host.graphql +38 -0
  15. package/dist/modules/drupal/graphql/mutations/set_paragraph_schedule.graphql +15 -0
  16. package/dist/modules/drupal/graphql/mutations/update_host_options.graphql +15 -0
  17. package/dist/modules/drupal/index.d.mts +1 -1
  18. package/dist/modules/drupal/index.mjs +79 -9
  19. package/dist/modules/drupal/runtime/adapter/index.d.ts +3 -0
  20. package/dist/modules/drupal/{adapter/index.mjs → runtime/adapter/index.js} +166 -20
  21. package/dist/runtime/adapter/index.d.ts +111 -1
  22. package/dist/runtime/blokkliPlugins/AddAction/index.vue +27 -3
  23. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue +65 -0
  24. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue.d.ts +26 -0
  25. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue +6 -0
  26. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue +3 -2
  27. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue.d.ts +2 -19
  28. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue.d.ts +2 -7
  29. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue +3 -3
  30. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue.d.ts +2 -19
  31. package/dist/runtime/blokkliPlugins/ItemAction/index.vue +23 -15
  32. package/dist/runtime/blokkliPlugins/ItemAction/index.vue.d.ts +21 -44
  33. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue +49 -11
  34. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue.d.ts +29 -15
  35. package/dist/runtime/blokkliPlugins/MenuButton/index.vue.d.ts +3 -3
  36. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue +6 -7
  37. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue.d.ts +2 -51
  38. package/dist/runtime/blokkliPlugins/Sidebar/index.vue +2 -9
  39. package/dist/runtime/blokkliPlugins/Sidebar/index.vue.d.ts +15 -9
  40. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue.d.ts +1 -1
  41. package/dist/runtime/blokkliPlugins/TourItem/index.vue +10 -5
  42. package/dist/runtime/blokkliPlugins/TourItem/index.vue.d.ts +2 -4
  43. package/dist/runtime/blokkliPlugins/ViewOption/index.vue +6 -3
  44. package/dist/runtime/blokkliPlugins/ViewOption/index.vue.d.ts +4 -3
  45. package/dist/runtime/blokkliPlugins/index.d.ts +8 -7
  46. package/dist/runtime/blokkliPlugins/index.js +15 -13
  47. package/dist/runtime/components/Blocks/Fragment/icon.svg +1 -1
  48. package/dist/runtime/components/Blocks/FromLibrary/index.vue +4 -2
  49. package/dist/runtime/components/BlokkliEditable.vue +34 -16
  50. package/dist/runtime/components/BlokkliEditable.vue.d.ts +2 -1
  51. package/dist/runtime/components/BlokkliField.vue +31 -27
  52. package/dist/runtime/components/BlokkliField.vue.d.ts +61 -17
  53. package/dist/runtime/components/BlokkliItem.vue +2 -2
  54. package/dist/runtime/components/BlokkliItem.vue.d.ts +4 -2
  55. package/dist/runtime/components/BlokkliProvider.vue +60 -45
  56. package/dist/runtime/components/BlokkliProvider.vue.d.ts +45 -7
  57. package/dist/runtime/components/Edit/Actions/index.vue +69 -78
  58. package/dist/runtime/components/Edit/AddListItem/index.vue +2 -5
  59. package/dist/runtime/components/Edit/AddListItem/index.vue.d.ts +1 -1
  60. package/dist/runtime/components/Edit/AddListItemIcon/index.vue +19 -0
  61. package/dist/runtime/components/Edit/AddListItemIcon/index.vue.d.ts +15 -0
  62. package/dist/runtime/components/Edit/AnimationCanvas/index.vue +436 -25
  63. package/dist/runtime/components/Edit/AppMenu/index.vue +5 -5
  64. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue +83 -0
  65. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue.d.ts +32 -0
  66. package/dist/runtime/components/Edit/Banner/index.vue +51 -0
  67. package/dist/runtime/components/Edit/Banner/index.vue.d.ts +18 -0
  68. package/dist/runtime/components/Edit/BlockProxy/index.vue +3 -1
  69. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue.d.ts +2 -13
  70. package/dist/runtime/components/Edit/Dialog/index.vue +14 -5
  71. package/dist/runtime/components/Edit/Dialog/index.vue.d.ts +4 -2
  72. package/dist/runtime/components/Edit/DiffViewer/State.vue +276 -0
  73. package/dist/runtime/components/Edit/DiffViewer/State.vue.d.ts +16 -0
  74. package/dist/runtime/components/Edit/DraggableList.vue +20 -50
  75. package/dist/runtime/components/Edit/DraggableList.vue.d.ts +7 -7
  76. package/dist/runtime/components/Edit/EditIndicator.vue +118 -44
  77. package/dist/runtime/components/Edit/EditIndicator.vue.d.ts +3 -0
  78. package/dist/runtime/components/Edit/EditProvider.vue +192 -80
  79. package/dist/runtime/components/Edit/EditProvider.vue.d.ts +3 -0
  80. package/dist/runtime/components/Edit/Features/AddList/index.vue +24 -36
  81. package/dist/runtime/components/Edit/Features/Analyze/Overlay/fragment.glsl +58 -0
  82. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue +170 -0
  83. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue.d.ts +9 -0
  84. package/dist/runtime/components/Edit/Features/Analyze/Overlay/vertex.glsl +72 -0
  85. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue +159 -0
  86. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue.d.ts +7 -0
  87. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue +100 -0
  88. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue.d.ts +6 -0
  89. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue +56 -0
  90. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue.d.ts +3 -0
  91. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue +87 -0
  92. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue.d.ts +7 -0
  93. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue +105 -0
  94. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue.d.ts +8 -0
  95. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue +18 -0
  96. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue.d.ts +8 -0
  97. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue +92 -0
  98. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue.d.ts +17 -0
  99. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue +77 -0
  100. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue.d.ts +6 -0
  101. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.d.ts +12 -0
  102. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.js +75 -0
  103. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.d.ts +4 -0
  104. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.js +5 -0
  105. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.d.ts +32 -0
  106. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.js +45 -0
  107. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.d.ts +5 -0
  108. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.js +95 -0
  109. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.d.ts +3 -0
  110. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.js +13 -0
  111. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.d.ts +2 -0
  112. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.js +2 -0
  113. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.d.ts +2 -0
  114. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.js +165 -0
  115. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.d.ts +44 -0
  116. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.js +0 -0
  117. package/dist/runtime/components/Edit/Features/Analyze/helper.d.ts +5 -0
  118. package/dist/runtime/components/Edit/Features/Analyze/helper.js +28 -0
  119. package/dist/runtime/components/Edit/Features/Analyze/index.vue +44 -0
  120. package/dist/runtime/components/Edit/Features/Anchors/Renderer.vue +53 -0
  121. package/dist/runtime/components/Edit/Features/Anchors/index.vue +32 -0
  122. package/dist/runtime/components/Edit/Features/Artboard/Overview/index.vue +25 -13
  123. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue +299 -0
  124. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue.d.ts +7 -0
  125. package/dist/runtime/components/Edit/Features/Artboard/index.vue +10 -217
  126. package/dist/runtime/components/Edit/Features/Assistant/index.vue +5 -3
  127. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue +33 -57
  128. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue +154 -0
  129. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue.d.ts +27 -0
  130. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue +222 -0
  131. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue.d.ts +11 -0
  132. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue +96 -0
  133. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue.d.ts +2 -0
  134. package/dist/runtime/components/Edit/Features/Clipboard/index.vue +177 -46
  135. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue +51 -0
  136. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue.d.ts +17 -0
  137. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue +48 -117
  138. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue +5 -2
  139. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue +35 -20
  140. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue.d.ts +5 -3
  141. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue +29 -0
  142. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue.d.ts +13 -0
  143. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue +22 -16
  144. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue.d.ts +1 -0
  145. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue +15 -6
  146. package/dist/runtime/components/Edit/Features/Comments/index.vue +21 -9
  147. package/dist/runtime/components/Edit/Features/Conversions/index.vue +16 -21
  148. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue +26 -35
  149. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue +240 -0
  150. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue.d.ts +6 -0
  151. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue +14 -0
  152. package/dist/runtime/components/Edit/Features/Debug/index.vue +7 -162
  153. package/dist/runtime/components/Edit/Features/Delete/index.vue +1 -1
  154. package/dist/runtime/components/Edit/Features/Diff/DiffView/index.vue +13 -190
  155. package/dist/runtime/components/Edit/Features/Diff/index.vue +2 -2
  156. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue +18 -10
  157. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/fragment.glsl +8 -2
  158. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue +111 -121
  159. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue.d.ts +3 -132
  160. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/vertex.glsl +2 -1
  161. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue +87 -61
  162. package/dist/runtime/components/Edit/Features/Duplicate/index.vue +6 -8
  163. package/dist/runtime/components/Edit/Features/Edit/index.vue +16 -22
  164. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue +3 -3
  165. package/dist/runtime/components/Edit/Features/EditForm/index.vue +10 -9
  166. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue +69 -4
  167. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue.d.ts +2 -2
  168. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue +13 -9
  169. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue +45 -87
  170. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue.d.ts +2 -2
  171. package/dist/runtime/components/Edit/Features/EditableField/index.vue +45 -43
  172. package/dist/runtime/components/Edit/Features/EditableMask/index.vue +3 -20
  173. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue +33 -1
  174. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue +11 -9
  175. package/dist/runtime/components/Edit/Features/Fragments/index.vue +8 -6
  176. package/dist/runtime/components/Edit/Features/History/index.vue +39 -13
  177. package/dist/runtime/components/Edit/Features/Hover/Overlay/fragment.glsl +139 -0
  178. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue +261 -0
  179. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue.d.ts +6 -0
  180. package/dist/runtime/components/Edit/Features/Hover/Overlay/vertex.glsl +117 -0
  181. package/dist/runtime/components/Edit/Features/Hover/index.vue +25 -0
  182. package/dist/runtime/components/Edit/Features/Hover/index.vue.d.ts +2 -0
  183. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue +6 -2
  184. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue +3 -2
  185. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue +5 -7
  186. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue +19 -27
  187. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue +32 -28
  188. package/dist/runtime/components/Edit/Features/Library/index.vue +40 -32
  189. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue +11 -11
  190. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue +15 -12
  191. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/fragment.glsl +1 -1
  192. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue +44 -32
  193. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/vertex.glsl +1 -1
  194. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue +10 -18
  195. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue +3 -2
  196. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue.d.ts +2 -0
  197. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue.d.ts +2 -11
  198. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue +14 -3
  199. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue.d.ts +0 -1
  200. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue +37 -19
  201. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue.d.ts +8 -2
  202. package/dist/runtime/components/Edit/Features/Options/Form/index.vue +88 -42
  203. package/dist/runtime/components/Edit/Features/Options/Form/index.vue.d.ts +5 -5
  204. package/dist/runtime/components/Edit/Features/Options/index.vue +35 -11
  205. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue +35 -0
  206. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue.d.ts +6 -0
  207. package/dist/runtime/components/Edit/Features/Ownership/index.vue +7 -25
  208. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue +3 -3
  209. package/dist/runtime/components/Edit/Features/ProxyView/index.vue +5 -1
  210. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue +41 -14
  211. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue.d.ts +2 -0
  212. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue +47 -0
  213. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue.d.ts +19 -0
  214. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue +83 -0
  215. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue.d.ts +9 -0
  216. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue +439 -123
  217. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue.d.ts +3 -14
  218. package/dist/runtime/components/Edit/Features/Publish/index.vue +57 -24
  219. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue.d.ts +2 -13
  220. package/dist/runtime/components/Edit/Features/Revert/index.vue +3 -3
  221. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue +15 -15
  222. package/dist/runtime/components/Edit/Features/Search/index.vue +7 -3
  223. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Overlay/index.vue +85 -0
  224. package/dist/runtime/components/Edit/Features/{CommandPalette/Palette/Group → Selection/AddButtons/Overlay}/index.vue.d.ts +8 -13
  225. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/fragment.glsl +106 -0
  226. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue +440 -0
  227. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue.d.ts +32 -0
  228. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/vertex.glsl +102 -0
  229. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue +387 -0
  230. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue.d.ts +6 -0
  231. package/dist/runtime/components/Edit/Features/Selection/Overlay/fragment.glsl +15 -10
  232. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue +105 -25
  233. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue.d.ts +5 -3
  234. package/dist/runtime/components/Edit/Features/Selection/Overlay/vertex.glsl +12 -3
  235. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue +2 -2
  236. package/dist/runtime/components/Edit/Features/Selection/index.vue +135 -25
  237. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue +12 -17
  238. package/dist/runtime/components/Edit/Features/Settings/index.vue +11 -25
  239. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue +2 -2
  240. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue +13 -6
  241. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue +5 -1
  242. package/dist/runtime/components/Edit/Features/Theme/index.vue +2 -1
  243. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue +3 -2
  244. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue +3 -0
  245. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue +198 -0
  246. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue.d.ts +13 -0
  247. package/dist/runtime/components/Edit/Features/Transform/index.vue +156 -70
  248. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue +17 -11
  249. package/dist/runtime/components/Edit/Features/Translations/index.vue +20 -23
  250. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue +5 -5
  251. package/dist/runtime/components/Edit/Features/index.vue +17 -7
  252. package/dist/runtime/components/Edit/Form/Datepicker/index.vue +198 -0
  253. package/dist/runtime/components/Edit/Form/Datepicker/index.vue.d.ts +15 -0
  254. package/dist/runtime/components/Edit/Form/Group/index.vue.d.ts +2 -4
  255. package/dist/runtime/components/Edit/Form/Item/index.vue.d.ts +2 -4
  256. package/dist/runtime/components/Edit/Form/Radio/index.vue +33 -0
  257. package/dist/runtime/components/Edit/Form/Radio/index.vue.d.ts +20 -0
  258. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue +37 -0
  259. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue.d.ts +22 -0
  260. package/dist/runtime/components/Edit/Form/Select/index.vue +29 -0
  261. package/dist/runtime/components/Edit/Form/Select/index.vue.d.ts +20 -0
  262. package/dist/runtime/components/Edit/Form/Text/index.vue +34 -0
  263. package/dist/runtime/components/Edit/Form/Text/index.vue.d.ts +20 -0
  264. package/dist/runtime/components/Edit/Form/Textarea/index.vue +13 -6
  265. package/dist/runtime/components/Edit/Form/Textarea/index.vue.d.ts +4 -0
  266. package/dist/runtime/components/Edit/Form/Toggle/index.vue +4 -3
  267. package/dist/runtime/components/Edit/Form/Toggle/index.vue.d.ts +12 -2
  268. package/dist/runtime/components/Edit/FormOverlay/index.vue +1 -1
  269. package/dist/runtime/components/Edit/FormOverlay/index.vue.d.ts +3 -2
  270. package/dist/runtime/components/Edit/Indicators/index.vue +123 -0
  271. package/dist/runtime/components/Edit/Indicators/index.vue.d.ts +2 -0
  272. package/dist/runtime/components/Edit/InfoBox/index.vue +6 -2
  273. package/dist/runtime/components/Edit/InfoBox/index.vue.d.ts +12 -2
  274. package/dist/runtime/components/Edit/ItemIcon/index.vue +2 -1
  275. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue +66 -0
  276. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue.d.ts +7 -0
  277. package/dist/runtime/components/Edit/Konami/Game/blokkli.png +0 -0
  278. package/dist/runtime/components/Edit/Konami/Game/charmap.d.ts +2 -0
  279. package/dist/runtime/components/Edit/Konami/Game/charmap.js +168 -0
  280. package/dist/runtime/components/Edit/Konami/Game/index.vue +752 -0
  281. package/dist/runtime/components/Edit/Konami/Game/index.vue.d.ts +6 -0
  282. package/dist/runtime/components/Edit/Konami/Game/textRendering.d.ts +8 -0
  283. package/dist/runtime/components/Edit/Konami/Game/textRendering.js +138 -0
  284. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.d.ts +9 -0
  285. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.js +130 -0
  286. package/dist/runtime/components/Edit/Konami/index.vue +44 -0
  287. package/dist/runtime/components/Edit/Konami/index.vue.d.ts +2 -0
  288. package/dist/runtime/components/Edit/Loading/index.vue +6 -2
  289. package/dist/runtime/components/Edit/Loading/index.vue.d.ts +2 -0
  290. package/dist/runtime/components/Edit/Messages/index.vue +8 -3
  291. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue +17 -0
  292. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue.d.ts +11 -0
  293. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue +37 -0
  294. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue.d.ts +11 -0
  295. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue +43 -0
  296. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue.d.ts +11 -0
  297. package/dist/runtime/components/Edit/PluginConfigForm/index.vue +57 -0
  298. package/dist/runtime/components/Edit/PluginConfigForm/index.vue.d.ts +16 -0
  299. package/dist/runtime/components/Edit/PreviewProvider.vue +3 -4
  300. package/dist/runtime/components/Edit/RelativeTime/index.vue +3 -2
  301. package/dist/runtime/components/Edit/RelativeTime/index.vue.d.ts +2 -2
  302. package/dist/runtime/components/Edit/Resizable/index.vue.d.ts +1 -1
  303. package/dist/runtime/components/Edit/ScaleToFit/index.vue.d.ts +1 -1
  304. package/dist/runtime/components/Edit/ScheduleDate/index.vue +131 -0
  305. package/dist/runtime/components/Edit/ScheduleDate/index.vue.d.ts +23 -0
  306. package/dist/runtime/components/Edit/ScrollBoundary/index.vue.d.ts +2 -7
  307. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue +11 -3
  308. package/dist/runtime/components/Edit/Sortli/index.vue.d.ts +1 -1
  309. package/dist/runtime/components/Edit/SystemRequirements/index.vue +3 -3
  310. package/dist/runtime/components/Edit/Toolbar/index.vue +3 -2
  311. package/dist/runtime/components/Edit/Transition/Height.vue +95 -0
  312. package/dist/runtime/components/Edit/Transition/Height.vue.d.ts +36 -0
  313. package/dist/runtime/components/Edit/Transition/index.vue +41 -0
  314. package/dist/runtime/components/Edit/Transition/index.vue.d.ts +19 -0
  315. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue.d.ts +2 -7
  316. package/dist/runtime/components/Edit/index.d.ts +28 -15
  317. package/dist/runtime/components/Edit/index.js +54 -28
  318. package/dist/runtime/composables/defineBlokkli.js +16 -3
  319. package/dist/runtime/composables/defineBlokkliFeature.d.ts +4 -7
  320. package/dist/runtime/composables/defineBlokkliFragment.js +8 -1
  321. package/dist/runtime/composables/defineBlokkliProvider.d.ts +11 -0
  322. package/dist/runtime/composables/defineBlokkliProvider.js +46 -0
  323. package/dist/runtime/composables/useBlokkliHelper.d.ts +19 -0
  324. package/dist/runtime/composables/useBlokkliHelper.js +95 -0
  325. package/dist/runtime/constants/index.d.ts +3 -0
  326. package/dist/runtime/constants/index.js +3 -0
  327. package/dist/runtime/css/output.css +1 -1
  328. package/dist/runtime/helpers/addElementClasses.d.ts +2 -0
  329. package/dist/runtime/helpers/addElementClasses.js +24 -0
  330. package/dist/runtime/helpers/animationProvider.d.ts +38 -2
  331. package/dist/runtime/helpers/animationProvider.js +188 -47
  332. package/dist/runtime/helpers/bundles/index.d.ts +1 -0
  333. package/dist/runtime/helpers/bundles/index.js +4 -0
  334. package/dist/runtime/helpers/composables/defineRenderer.d.ts +8 -0
  335. package/dist/runtime/helpers/composables/defineRenderer.js +8 -0
  336. package/dist/runtime/helpers/composables/useBlockRegistration.d.ts +5 -0
  337. package/dist/runtime/helpers/composables/useBlockRegistration.js +23 -0
  338. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.d.ts +1 -1
  339. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.js +3 -2
  340. package/dist/runtime/helpers/composables/useStateBasedCache.d.ts +4 -0
  341. package/dist/runtime/helpers/composables/useStateBasedCache.js +13 -0
  342. package/dist/runtime/helpers/composables/useStickyToolbar.d.ts +23 -0
  343. package/dist/runtime/helpers/composables/useStickyToolbar.js +233 -0
  344. package/dist/runtime/helpers/definitionProvider.d.ts +3 -2
  345. package/dist/runtime/helpers/definitionProvider.js +17 -0
  346. package/dist/runtime/helpers/dom/index.d.ts +60 -0
  347. package/dist/runtime/helpers/dom/index.js +48 -0
  348. package/dist/runtime/helpers/domProvider.d.ts +58 -17
  349. package/dist/runtime/helpers/domProvider.js +320 -245
  350. package/dist/runtime/helpers/dropTargets/index.d.ts +6 -0
  351. package/dist/runtime/helpers/dropTargets/index.js +49 -0
  352. package/dist/runtime/helpers/eventBus.d.ts +1 -1
  353. package/dist/runtime/helpers/eventBus.js +2 -2
  354. package/dist/runtime/helpers/index.d.ts +10 -14
  355. package/dist/runtime/helpers/index.js +58 -121
  356. package/dist/runtime/helpers/indicatorsProvider.d.ts +10 -0
  357. package/dist/runtime/helpers/indicatorsProvider.js +23 -0
  358. package/dist/runtime/helpers/keyboardProvider.d.ts +2 -0
  359. package/dist/runtime/helpers/keyboardProvider.js +17 -1
  360. package/dist/runtime/helpers/pluginProvider.d.ts +10 -0
  361. package/dist/runtime/helpers/pluginProvider.js +33 -0
  362. package/dist/runtime/helpers/providers/blocks.d.ts +10 -0
  363. package/dist/runtime/helpers/providers/blocks.js +91 -0
  364. package/dist/runtime/helpers/providers/directive.d.ts +25 -0
  365. package/dist/runtime/helpers/providers/directive.js +208 -0
  366. package/dist/runtime/helpers/providers/element.d.ts +6 -0
  367. package/dist/runtime/helpers/providers/element.js +35 -0
  368. package/dist/runtime/helpers/providers/fields.d.ts +8 -0
  369. package/dist/runtime/helpers/providers/fields.js +47 -0
  370. package/dist/runtime/helpers/renderCycle.d.ts +1 -0
  371. package/dist/runtime/helpers/renderCycle.js +10 -0
  372. package/dist/runtime/helpers/runtimeHelpers/index.js +15 -12
  373. package/dist/runtime/helpers/selectionProvider.d.ts +27 -11
  374. package/dist/runtime/helpers/selectionProvider.js +79 -74
  375. package/dist/runtime/helpers/stateProvider.d.ts +12 -2
  376. package/dist/runtime/helpers/stateProvider.js +164 -20
  377. package/dist/runtime/helpers/storageProvider.d.ts +5 -3
  378. package/dist/runtime/helpers/storageProvider.js +61 -4
  379. package/dist/runtime/helpers/symbols.d.ts +2 -0
  380. package/dist/runtime/helpers/symbols.js +2 -0
  381. package/dist/runtime/helpers/textProvider.js +6 -0
  382. package/dist/runtime/helpers/themeProvider.d.ts +4 -1
  383. package/dist/runtime/helpers/themeProvider.js +28 -15
  384. package/dist/runtime/helpers/transform.js +1 -3
  385. package/dist/runtime/helpers/typesProvider.js +10 -26
  386. package/dist/runtime/helpers/uiProvider.d.ts +18 -3
  387. package/dist/runtime/helpers/uiProvider.js +114 -61
  388. package/dist/runtime/helpers/useTransitionedValue.d.ts +18 -0
  389. package/dist/runtime/helpers/useTransitionedValue.js +57 -0
  390. package/dist/runtime/helpers/webgl/index.d.ts +11 -2
  391. package/dist/runtime/helpers/webgl/index.js +162 -7
  392. package/dist/runtime/icons/anchor.svg +1 -0
  393. package/dist/runtime/icons/arrow-left.svg +1 -1
  394. package/dist/runtime/icons/arrow-right.svg +1 -1
  395. package/dist/runtime/icons/arrow-top-right.svg +1 -0
  396. package/dist/runtime/icons/calendar-clock.svg +1 -0
  397. package/dist/runtime/icons/calendar.svg +1 -0
  398. package/dist/runtime/icons/chart.svg +1 -0
  399. package/dist/runtime/icons/clock.svg +1 -0
  400. package/dist/runtime/icons/comment_add.svg +1 -5
  401. package/dist/runtime/icons/copy.svg +1 -0
  402. package/dist/runtime/icons/cursor-move.svg +1 -1
  403. package/dist/runtime/icons/delete.svg +1 -8
  404. package/dist/runtime/icons/diff.svg +1 -1
  405. package/dist/runtime/icons/duplicate.svg +1 -12
  406. package/dist/runtime/icons/edit.svg +1 -8
  407. package/dist/runtime/icons/eye-off.svg +1 -0
  408. package/dist/runtime/icons/eye.svg +1 -1
  409. package/dist/runtime/icons/info.svg +1 -1
  410. package/dist/runtime/icons/link.svg +1 -0
  411. package/dist/runtime/icons/reusable.svg +1 -5
  412. package/dist/runtime/icons/speedometer.svg +1 -0
  413. package/dist/runtime/plugins/blokkliDirectives.js +109 -0
  414. package/dist/runtime/types/blokkOptions.d.ts +8 -0
  415. package/dist/runtime/types/index.d.ts +278 -42
  416. package/dist/runtime/types/theme.d.ts +2 -1
  417. package/dist/shared/{editor.gz_ac6uT.d.mts → editor.CKsrTpc1.d.mts} +1 -1
  418. package/package.json +55 -38
  419. package/dist/modules/drupal/adapter/index.d.mts +0 -6
  420. package/dist/runtime/components/Edit/DragInteractions/index.vue +0 -364
  421. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue +0 -51
  422. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue +0 -22
  423. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue +0 -41
  424. package/dist/runtime/plugins/blokkliEditable.js +0 -31
  425. /package/dist/runtime/components/Edit/{DragInteractions → Features/Analyze}/index.vue.d.ts +0 -0
  426. /package/dist/runtime/components/Edit/Features/{FieldAreas/Overlay/index.vue.d.ts → Anchors/Renderer.vue.d.ts} +0 -0
  427. /package/dist/runtime/components/Edit/Features/{FieldAreas → Anchors}/index.vue.d.ts +0 -0
  428. /package/dist/runtime/plugins/{blokkliEditable.d.ts → blokkliDirectives.d.ts} +0 -0
@@ -0,0 +1,198 @@
1
+ <template>
2
+ <div class="bk bk-transform-overlay" @keydown.stop @keyup.stop>
3
+ <div ref="el" class="bk-transform-overlay-dialog" @wheel="onWheel">
4
+ <div class="bk-transform-overlay-dialog-inner">
5
+ <div class="bk-transform-overlay-dialog-inner-content">
6
+ <header>
7
+ <p>{{ title }}</p>
8
+ <button @click.prevent="$emit('cancel')">
9
+ <Icon name="close" />
10
+ </button>
11
+ </header>
12
+ <main>
13
+ <div class="bk-transform-overlay-dialog-grid">
14
+ <div class="bk-transform-overlay-dialog-top">
15
+ <p v-if="lead" class="bk-lead">{{ lead }}</p>
16
+ <ConfigForm ref="configForm" v-model="value" :config />
17
+ </div>
18
+ <DiffViewerState
19
+ v-if="stateAfter"
20
+ :state-before
21
+ :state-after
22
+ show-select
23
+ :selected="selection.uuids.value"
24
+ :include-uuids="uuids"
25
+ scheme="orange"
26
+ @toggle="onToggleSelected"
27
+ />
28
+ </div>
29
+ <Loading v-if="isLocked" white />
30
+ </main>
31
+ <footer>
32
+ <button
33
+ v-if="supportsPreview"
34
+ class="bk-button"
35
+ :disabled="disabled || !hasChanged && !hasSeedInput"
36
+ :class="{
37
+ 'bk-is-loading': isPreviewing
38
+ }"
39
+ @click.prevent="onClickPreview"
40
+ >
41
+ {{ $t("transformDialogButtonPreview", "Preview") }}
42
+ </button>
43
+ <button
44
+ class="bk-button bk-is-orange"
45
+ :disabled
46
+ @click.prevent="onClickSubmit"
47
+ >
48
+ {{ $t("transformDialogButtonApply", "Apply") }}
49
+ </button>
50
+ </footer>
51
+ </div>
52
+ </div>
53
+ </div>
54
+ </div>
55
+ </template>
56
+
57
+ <script setup>
58
+ import {
59
+ useBlokkli,
60
+ ref,
61
+ watch,
62
+ computed,
63
+ useTemplateRef,
64
+ onMounted,
65
+ onBeforeUnmount
66
+ } from "#imports";
67
+ import { ConfigForm, DiffViewerState, Icon, Loading } from "#blokkli/components";
68
+ const props = defineProps({
69
+ plugin: { type: Object, required: true },
70
+ uuids: { type: Array, required: false }
71
+ });
72
+ const { adapter, state, ui, selection, $t, eventBus } = useBlokkli();
73
+ function onToggleSelected(uuid) {
74
+ let newSelection = [...selection.uuids.value];
75
+ if (newSelection.includes(uuid)) {
76
+ newSelection = newSelection.filter((v) => v !== uuid);
77
+ } else {
78
+ newSelection.push(uuid);
79
+ }
80
+ eventBus.emit("select:force", newSelection);
81
+ }
82
+ const configForm = useTemplateRef("configForm");
83
+ function clone(v) {
84
+ return JSON.parse(JSON.stringify(v));
85
+ }
86
+ function mapValues(values) {
87
+ return Object.entries(values).map(([name, value2]) => {
88
+ return {
89
+ name,
90
+ value: value2
91
+ };
92
+ });
93
+ }
94
+ const hasSeedInput = computed(
95
+ () => !!props.plugin.configInputs?.find((v) => v.type === "seed")
96
+ );
97
+ const isLocked = ref(false);
98
+ const hasChanged = ref(false);
99
+ const isPreviewing = ref(false);
100
+ const title = computed(() => props.plugin.label);
101
+ const lead = computed(() => props.plugin.description);
102
+ const config = computed(() => props.plugin.configInputs ?? []);
103
+ const isHostPlugin = computed(() => !("bundles" in props.plugin));
104
+ const supportsPreview = computed(() => {
105
+ if (!props.plugin.preview) {
106
+ return false;
107
+ }
108
+ if (isHostPlugin.value) {
109
+ return !!adapter.previewHostTransformPlugin;
110
+ }
111
+ return !!adapter.previewTransformPlugin;
112
+ });
113
+ const stateBefore = clone(state.getMappedState());
114
+ const stateAfter = ref(null);
115
+ const emit = defineEmits(["cancel", "submit"]);
116
+ const value = ref(
117
+ (props.plugin.configInputs ?? []).reduce(
118
+ (acc, plugin) => {
119
+ acc[plugin.name] = "";
120
+ return acc;
121
+ },
122
+ {}
123
+ )
124
+ );
125
+ const requiredItems = computed(
126
+ () => config.value.filter((v) => v.required).map((v) => v.name)
127
+ );
128
+ const canSubmit = computed(() => {
129
+ return requiredItems.value.every((name) => !!value.value[name]);
130
+ });
131
+ const disabled = computed(() => isLocked.value || !canSubmit.value);
132
+ watch(
133
+ value,
134
+ () => {
135
+ hasChanged.value = true;
136
+ },
137
+ {
138
+ deep: true
139
+ }
140
+ );
141
+ function onWheel(e) {
142
+ if (e.metaKey || e.ctrlKey) {
143
+ return;
144
+ }
145
+ e.stopPropagation();
146
+ }
147
+ async function onClickPreview() {
148
+ if (isLocked.value) {
149
+ return;
150
+ }
151
+ if (configForm.value) {
152
+ configForm.value.updateSeed();
153
+ }
154
+ isLocked.value = true;
155
+ isPreviewing.value = true;
156
+ ui.setTransform(title.value);
157
+ if (supportsPreview.value && adapter.previewTransformPlugin && "bundles" in props.plugin && props.uuids) {
158
+ const config2 = mapValues(value.value);
159
+ try {
160
+ const result = await adapter.previewTransformPlugin({
161
+ pluginId: props.plugin.id,
162
+ uuids: props.uuids,
163
+ config: config2
164
+ });
165
+ stateAfter.value = clone(adapter.mapState(result.state));
166
+ state.setOverrideState(stateAfter.value);
167
+ } catch {
168
+ }
169
+ }
170
+ isLocked.value = false;
171
+ isPreviewing.value = false;
172
+ ui.setTransform();
173
+ hasChanged.value = false;
174
+ }
175
+ function onClickSubmit() {
176
+ if (isLocked.value) {
177
+ return;
178
+ }
179
+ isLocked.value = true;
180
+ emit("submit", mapValues(value.value));
181
+ }
182
+ onMounted(async () => {
183
+ ui.hasTransformOverlayOpen.value = true;
184
+ selection.lockSelection("transform-dialog");
185
+ if (hasSeedInput.value && supportsPreview.value) {
186
+ const hasOnlySeedInputs = props.plugin.configInputs?.every(
187
+ (v) => v.type === "seed"
188
+ );
189
+ if (hasOnlySeedInputs === true) {
190
+ await onClickPreview();
191
+ }
192
+ }
193
+ });
194
+ onBeforeUnmount(() => {
195
+ ui.hasTransformOverlayOpen.value = false;
196
+ selection.unlockSelection("transform-dialog");
197
+ });
198
+ </script>
@@ -0,0 +1,13 @@
1
+ import type { HostTransformPlugin, PluginConfigInputItem, TransformPlugin } from '#blokkli/types';
2
+ type __VLS_Props = {
3
+ plugin: HostTransformPlugin | TransformPlugin;
4
+ uuids?: string[];
5
+ };
6
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
7
+ cancel: () => any;
8
+ submit: (values: PluginConfigInputItem[]) => any;
9
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
10
+ onCancel?: (() => any) | undefined;
11
+ onSubmit?: ((values: PluginConfigInputItem[]) => any) | undefined;
12
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
13
+ export default _default;
@@ -1,34 +1,52 @@
1
1
  <template>
2
2
  <PluginItemDropdown
3
3
  id="transform"
4
- :title="$t('transformTo', 'Other actions')"
5
- :enabled="!!(itemBundleIds.length && possibleTransforms.length)"
6
- >
7
- <button
8
- v-for="transform in possibleTransforms"
9
- :key="transform.id"
10
- @click.prevent="onTransform(transform, selection.uuids.value)"
11
- >
12
- <div>
13
- <div>{{ transform.label }}</div>
14
- </div>
15
- </button>
16
- </PluginItemDropdown>
4
+ :title="$t('transformTo', 'Actions')"
5
+ :enabled="!!possibleTransforms.length"
6
+ :items="possibleTransforms"
7
+ icon="script"
8
+ weight="100"
9
+ @select="onSelectBlockTransformPlugin($event, selection.uuids.value)"
10
+ />
11
+
12
+ <PluginItemDropdown
13
+ v-if="hostPlugins.length"
14
+ id="transform-host"
15
+ :title="$t('transformTo', 'Actions')"
16
+ :enabled="selection.hasHostSelected.value"
17
+ :items="hostPlugins"
18
+ icon="script"
19
+ weight="100"
20
+ @select="onSelectHostTransformPlugin($event)"
21
+ />
22
+
23
+ <Teleport to="body">
24
+ <BlokkliTransition name="transform-overlay">
25
+ <TransformDialog
26
+ v-if="openPluginDefinition"
27
+ :plugin="openPluginDefinition"
28
+ :uuids="selectedUuids"
29
+ @cancel="cancelTransform"
30
+ @submit="onSubmitDialog"
31
+ />
32
+ </BlokkliTransition>
33
+ </Teleport>
17
34
  </template>
18
35
 
19
36
  <script setup>
20
37
  import {
21
38
  computed,
22
39
  watch,
40
+ ref,
23
41
  useBlokkli,
24
42
  defineBlokkliFeature,
25
43
  useLazyAsyncData
26
44
  } from "#imports";
27
45
  import { PluginItemDropdown } from "#blokkli/plugins";
28
- import { onlyUnique } from "#blokkli/helpers";
46
+ import { BlokkliTransition } from "#blokkli/components";
29
47
  import { filterTransforms } from "#blokkli/helpers/transform";
30
48
  import defineCommands from "#blokkli/helpers/composables/defineCommands";
31
- import defineDropAreas from "#blokkli/helpers/composables/defineDropAreas";
49
+ import TransformDialog from "./Dialog/index.vue";
32
50
  const { adapter } = defineBlokkliFeature({
33
51
  id: "transform",
34
52
  icon: "script",
@@ -37,7 +55,9 @@ const { adapter } = defineBlokkliFeature({
37
55
  description: "Provides integration for block transform plugins.",
38
56
  screenshot: "feature-transform.jpg"
39
57
  });
40
- const { types, selection, state, $t, dom, ui } = useBlokkli();
58
+ const { types, selection, state, $t, ui } = useBlokkli();
59
+ const openPlugin = ref(null);
60
+ const selectedUuids = ref([]);
41
61
  const {
42
62
  data: plugins,
43
63
  execute,
@@ -46,19 +66,131 @@ const {
46
66
  () => {
47
67
  return adapter.getTransformPlugins();
48
68
  },
49
- { immediate: false, default: () => [] }
69
+ {
70
+ immediate: false,
71
+ default: () => [],
72
+ transform: function(plugins2) {
73
+ return plugins2.map((plugin) => {
74
+ return {
75
+ ...plugin,
76
+ label: getPluginLabel(plugin)
77
+ };
78
+ });
79
+ }
80
+ }
50
81
  );
82
+ const {
83
+ data: hostPlugins,
84
+ status: statusHostPlugins,
85
+ execute: executeHostPlugins
86
+ } = await useLazyAsyncData(
87
+ () => {
88
+ if (adapter.getHostTransformPlugins) {
89
+ return adapter.getHostTransformPlugins();
90
+ }
91
+ return Promise.resolve([]);
92
+ },
93
+ {
94
+ immediate: !openPlugin.value,
95
+ default: () => [],
96
+ transform: function(plugins2) {
97
+ return plugins2.map((plugin) => {
98
+ return {
99
+ ...plugin,
100
+ label: getPluginLabel(plugin)
101
+ };
102
+ });
103
+ }
104
+ }
105
+ );
106
+ const openPluginDefinition = computed(() => {
107
+ if (openPlugin.value) {
108
+ if (openPlugin.value.type === "block") {
109
+ return plugins.value.find((v) => v.id === openPlugin.value?.id) ?? null;
110
+ } else if (openPlugin.value.type === "host") {
111
+ return hostPlugins.value.find((v) => v.id === openPlugin.value?.id) ?? null;
112
+ }
113
+ }
114
+ return null;
115
+ });
116
+ function getPluginLabel(plugin) {
117
+ if (plugin.configInputs?.length) {
118
+ return plugin.label + "...";
119
+ }
120
+ return plugin.label;
121
+ }
122
+ function cancelTransform() {
123
+ openPlugin.value = null;
124
+ selectedUuids.value = [];
125
+ state.clearOverrideState();
126
+ }
51
127
  watch(selection.uuids, async () => {
52
128
  if (status.value === "idle") {
53
129
  execute();
54
130
  }
55
131
  });
56
- async function onTransform(plugin, uuids) {
132
+ watch(selection.hasHostSelected, () => {
133
+ if (statusHostPlugins.value === "idle") {
134
+ executeHostPlugins();
135
+ }
136
+ });
137
+ function onSelectBlockTransformPlugin(plugin, uuids) {
138
+ if (plugin.configInputs?.length) {
139
+ openPlugin.value = {
140
+ type: "block",
141
+ id: plugin.id
142
+ };
143
+ selectedUuids.value = [...selection.uuids.value];
144
+ return;
145
+ }
146
+ onTransformBlock(plugin, uuids, []);
147
+ }
148
+ function onSelectHostTransformPlugin(plugin) {
149
+ if (plugin.configInputs?.length) {
150
+ openPlugin.value = {
151
+ type: "host",
152
+ id: plugin.id
153
+ };
154
+ return;
155
+ }
156
+ onTransformHost(plugin, []);
157
+ }
158
+ async function onTransformBlock(plugin, uuids, values) {
57
159
  ui.setTransform(plugin.label);
160
+ openPlugin.value = null;
58
161
  await state.mutateWithLoadingState(
59
162
  () => adapter.applyTransformPlugin({
60
163
  uuids,
61
- pluginId: plugin.id
164
+ pluginId: plugin.id,
165
+ config: values
166
+ }),
167
+ $t(
168
+ "failedToTransform",
169
+ 'The action "@name" could not be executed.'
170
+ ).replace("@name", plugin.label)
171
+ );
172
+ ui.setTransform();
173
+ }
174
+ function onSubmitDialog(values) {
175
+ if (!openPluginDefinition.value) {
176
+ return;
177
+ }
178
+ if ("bundles" in openPluginDefinition.value) {
179
+ onTransformBlock(openPluginDefinition.value, selection.uuids.value, values);
180
+ } else {
181
+ onTransformHost(openPluginDefinition.value, values);
182
+ }
183
+ }
184
+ async function onTransformHost(plugin, values) {
185
+ if (!adapter.applyHostTransformPlugin) {
186
+ return;
187
+ }
188
+ ui.setTransform(plugin.label);
189
+ openPlugin.value = null;
190
+ await state.mutateWithLoadingState(
191
+ () => adapter.applyHostTransformPlugin({
192
+ pluginId: plugin.id,
193
+ config: values
62
194
  }),
63
195
  $t(
64
196
  "failedToTransform",
@@ -67,71 +199,25 @@ async function onTransform(plugin, uuids) {
67
199
  );
68
200
  ui.setTransform();
69
201
  }
70
- const itemBundleIds = computed(
71
- () => selection.blocks.value.map((v) => v.itemBundle).filter(onlyUnique)
72
- );
73
202
  const possibleTransforms = computed(
74
203
  () => filterTransforms(
75
204
  plugins.value || [],
76
205
  selection.uuids.value,
77
- itemBundleIds.value,
206
+ selection.bundles.value,
78
207
  types.allowedTypesInList.value
79
208
  )
80
209
  );
81
210
  defineCommands(
82
211
  () => possibleTransforms.value.map((transform) => ({
83
212
  id: "transform:" + transform.id,
84
- label: transform.label,
213
+ label: getPluginLabel(transform),
85
214
  group: "selection",
86
215
  icon: "script",
87
- callback: () => onTransform(transform, selection.uuids.value)
216
+ callback: () => {
217
+ onSelectBlockTransformPlugin(transform, selection.uuids.value);
218
+ }
88
219
  }))
89
220
  );
90
- const getPossibleDropTransforms = (plugins2, allBlocks, dragItems) => {
91
- const notDraggedBlocks = allBlocks.filter(
92
- (block) => !dragItems.find((dragItem) => dragItem.uuid === block.uuid)
93
- );
94
- const validPlugins = plugins2.filter((plugin) => {
95
- const draggedBundles = dragItems.map((item) => item.itemBundle);
96
- return draggedBundles.every((bundle) => plugin.bundles.includes(bundle)) && dragItems.length + 1 >= plugin.min && (plugin.max === -1 || dragItems.length + 1 <= plugin.max);
97
- });
98
- const possibleTransforms2 = [];
99
- validPlugins.forEach((plugin) => {
100
- notDraggedBlocks.forEach((block) => {
101
- if (plugin.targetBundles.includes(block.itemBundle)) {
102
- possibleTransforms2.push({
103
- plugin,
104
- block
105
- });
106
- }
107
- });
108
- });
109
- return possibleTransforms2;
110
- };
111
- defineDropAreas((dragItems) => {
112
- const existing = dragItems.filter(
113
- (v) => v.itemType === "existing"
114
- );
115
- if (!existing.length) {
116
- return;
117
- }
118
- const uuids = existing.map((v) => v.uuid);
119
- return getPossibleDropTransforms(
120
- plugins.value,
121
- dom.getAllBlocks(),
122
- existing
123
- ).map((v) => {
124
- return {
125
- id: `transform:${v.plugin.id}:${v.block.uuid}`,
126
- label: v.plugin.label,
127
- element: v.block.element(),
128
- onDrop: () => {
129
- const transformUuids = [v.block.uuid, ...uuids];
130
- return onTransform(v.plugin, transformUuids);
131
- }
132
- };
133
- });
134
- });
135
221
  </script>
136
222
 
137
223
  <script>
@@ -1,21 +1,21 @@
1
1
  <template>
2
- <div class="bk bk-translations-banner">
3
- <Icon name="translate" />
4
- <p v-html="text" />
5
- <button class="bk-translations-banner-close" @click="onClick">
6
- {{ $t("translationsBannerButton", "Edit source language instead") }}
7
- <Icon name="close" />
8
- </button>
9
- </div>
2
+ <Banner
3
+ id="translate"
4
+ icon="translate"
5
+ :text
6
+ :button="$t('translationsBannerButton', 'Edit source language instead')"
7
+ scheme="yellow"
8
+ @click="onClick"
9
+ />
10
10
  </template>
11
11
 
12
12
  <script setup>
13
- import { computed, useBlokkli } from "#imports";
14
- import { Icon } from "#blokkli/components";
13
+ import { computed, useBlokkli, onMounted, onBeforeUnmount } from "#imports";
14
+ import { Banner } from "#blokkli/components";
15
15
  const props = defineProps({
16
16
  activeLanguage: { type: Object, required: true }
17
17
  });
18
- const { $t, adapter, state } = useBlokkli();
18
+ const { $t, adapter, state, ui } = useBlokkli();
19
19
  const onClick = () => {
20
20
  const sourceLanguage = state.translation.value.sourceLanguage;
21
21
  if (!sourceLanguage) {
@@ -39,4 +39,10 @@ const text = computed(() => {
39
39
  "You are currently editing the <strong>@language</strong> translation. Some features like adding, moving or deleting blocks are not available."
40
40
  ).replace("@language", props.activeLanguage.name);
41
41
  });
42
+ onMounted(() => {
43
+ ui.setSelectionColor("translating", "mono");
44
+ });
45
+ onBeforeUnmount(() => {
46
+ ui.removeSelectionColor("translating");
47
+ });
42
48
  </script>
@@ -48,11 +48,8 @@
48
48
  </PluginTourItem>
49
49
  </Teleport>
50
50
 
51
- <Teleport to="#bk-banner-container">
52
- <Banner
53
- v-if="state.editMode.value === 'translating'"
54
- :active-language="activeLanguage"
55
- />
51
+ <Teleport to="#bk-banner-list">
52
+ <Banner v-if="isTranslating" :active-language />
56
53
  </Teleport>
57
54
 
58
55
  <PluginMenuButton
@@ -61,14 +58,14 @@
61
58
  :description="
62
59
  $t('translationsBatchTranslateMenuDescription', 'Translate all blocks')
63
60
  "
64
- :disabled="editMode !== 'translating'"
61
+ :disabled="!isTranslating"
65
62
  :weight="60"
66
63
  icon="translate"
67
64
  @click="eventBus.emit('batchTranslate')"
68
65
  />
69
66
 
70
67
  <PluginItemAction
71
- v-if="editMode === 'translating'"
68
+ v-if="isTranslating"
72
69
  id="translate"
73
70
  :disabled="!canTranslateBlock"
74
71
  :title="$t('translationsItemAction', 'Translate')"
@@ -102,7 +99,7 @@ const { adapter } = defineBlokkliFeature({
102
99
  description: "Adds support for block translations."
103
100
  });
104
101
  const { eventBus, state, context, $t, ui, selection, types, definitions } = useBlokkli();
105
- const { translation, editMode } = state;
102
+ const isTranslating = computed(() => state.editMode.value === "translating");
106
103
  const isOpen = ref(false);
107
104
  const isDropdown = computed(() => {
108
105
  if (ui.isMobile.value) {
@@ -113,7 +110,7 @@ const isDropdown = computed(() => {
113
110
  });
114
111
  const activeLangcode = computed(() => context.value.language);
115
112
  const activeLanguage = computed(() => {
116
- return translation.value.availableLanguages?.find(
113
+ return state.translation.value.availableLanguages?.find(
117
114
  (v) => v.id === activeLangcode.value
118
115
  ) || {
119
116
  id: activeLangcode.value,
@@ -121,14 +118,14 @@ const activeLanguage = computed(() => {
121
118
  };
122
119
  });
123
120
  const items = computed(() => {
124
- return (translation.value.availableLanguages || []).map((language) => {
121
+ return (state.translation.value.availableLanguages || []).map((language) => {
125
122
  if (language && language.id) {
126
123
  return {
127
124
  id: language.id,
128
125
  code: language.id.toUpperCase(),
129
126
  label: language.name,
130
127
  checked: context.value.language === language.id,
131
- translation: (translation.value.translations || []).find(
128
+ translation: (state.translation.value.translations || []).find(
132
129
  (v) => v.id === language.id
133
130
  )
134
131
  };
@@ -137,22 +134,22 @@ const items = computed(() => {
137
134
  }).filter(falsy);
138
135
  });
139
136
  const canTranslateBlock = computed(() => {
140
- if (selection.blocks.value.length !== 1) {
137
+ const block = selection.item.value;
138
+ if (!block) {
141
139
  return false;
142
140
  }
143
- const block = selection.blocks.value[0];
144
- if (block.libraryItemUuid) {
141
+ if (block.library?.libraryItemUuid) {
145
142
  return false;
146
143
  }
147
144
  const definition = definitions.getBlockDefinition(
148
- block.itemBundle,
149
- block.hostFieldListType,
145
+ block.bundle,
146
+ block.fieldListType,
150
147
  block.parentBlockBundle
151
148
  );
152
149
  if (definition?.editor?.disableEdit) {
153
150
  return false;
154
151
  }
155
- const type = types.getBlockBundleDefinition(block.itemBundle);
152
+ const type = types.getBlockBundleDefinition(block.bundle);
156
153
  if (!type) {
157
154
  return false;
158
155
  }
@@ -175,17 +172,17 @@ function onTranslate(items2) {
175
172
  if (item) {
176
173
  eventBus.emit("item:edit", {
177
174
  uuid: item.uuid,
178
- bundle: item.itemBundle
175
+ bundle: item.bundle
179
176
  });
180
177
  }
181
178
  }
182
179
  onBlokkliEvent("item:doubleClick", function(block) {
183
- if (editMode.value === "translating" && canTranslateBlock.value) {
180
+ if (isTranslating.value && canTranslateBlock.value) {
184
181
  onTranslate([block]);
185
182
  }
186
183
  });
187
184
  onBlokkliEvent("entity:translated", (langcode) => {
188
- const targetTranslation = translation.value.translations?.find(
185
+ const targetTranslation = state.translation.value.translations?.find(
189
186
  (v) => v.id === langcode
190
187
  );
191
188
  if (targetTranslation) {
@@ -193,12 +190,12 @@ onBlokkliEvent("entity:translated", (langcode) => {
193
190
  }
194
191
  });
195
192
  onMounted(() => {
196
- const translationExists = !!translation.value.translations?.find(
193
+ const translationExists = !!state.translation.value.translations?.find(
197
194
  (v) => v.id === context.value.language
198
195
  );
199
196
  if (!translationExists) {
200
- const sourceTranslation = translation.value.translations?.find(
201
- (v) => v.id === translation.value.sourceLanguage
197
+ const sourceTranslation = state.translation.value.translations?.find(
198
+ (v) => v.id === state.translation.value.sourceLanguage
202
199
  );
203
200
  if (sourceTranslation) {
204
201
  return adapter.changeLanguage(sourceTranslation);