@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,299 @@
1
+ <template>
2
+ <Scrollbar :artboard="artboard" orientation="y" />
3
+ <PluginToolbarButton
4
+ id="artboard_reset_zoom"
5
+ :title="$t('artboardResetZoom', 'Reset zoom')"
6
+ :shortcut-group="$t('artboard', 'Artboard')"
7
+ :tour-text="
8
+ $t(
9
+ 'artboardToolbarButtonTourText',
10
+ 'Shows the current zoom factor. Click on it to reset the zoom back to 100%.'
11
+ )
12
+ "
13
+ icon="magnifier"
14
+ meta
15
+ key-code="0"
16
+ region="view-options"
17
+ weight="100"
18
+ @click="resetZoom"
19
+ >
20
+ <div class="bk-feature-canvas-button">
21
+ <span>{{ zoomLevel }}</span>
22
+ </div>
23
+ </PluginToolbarButton>
24
+
25
+ <PluginViewOption
26
+ id="artboardOverview"
27
+ v-slot="{ isActive }"
28
+ :label="$t('artboardOverviewToggle', 'Toggle overview')"
29
+ :title-on="$t('artboardOverviewShow', 'Show overview')"
30
+ :title-off="$t('artboardOverviewHide', 'Hide overview')"
31
+ :tour-text="
32
+ $t(
33
+ 'artboardOverviewTourText',
34
+ `Displays a top level overview of your content.`
35
+ )
36
+ "
37
+ icon="eye"
38
+ key-code="O"
39
+ weight="90"
40
+ >
41
+ <Teleport v-if="isActive && dom.isReady.value" to="body">
42
+ <Overview :artboard="artboard" />
43
+ </Teleport>
44
+ </PluginViewOption>
45
+ </template>
46
+
47
+ <script setup>
48
+ import {
49
+ watch,
50
+ computed,
51
+ useBlokkli,
52
+ onMounted,
53
+ onBeforeUnmount
54
+ } from "#imports";
55
+ import {
56
+ asValidNumber,
57
+ isInsideRect,
58
+ subtractRectFromViewport
59
+ } from "#blokkli/helpers";
60
+ import { PluginToolbarButton, PluginViewOption } from "#blokkli/plugins";
61
+ import Overview from "./Overview/index.vue";
62
+ import Scrollbar from "./Scrollbar/index.vue";
63
+ import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
64
+ import {
65
+ createArtboard,
66
+ touch,
67
+ wheel,
68
+ mouse,
69
+ dom as domPlugin
70
+ } from "artboard-deluxe";
71
+ import { addElementClasses } from "#blokkli/helpers/addElementClasses";
72
+ const props = defineProps({
73
+ persist: { type: Boolean, required: true },
74
+ momentum: { type: Boolean, required: true },
75
+ scrollSpeed: { type: Number, required: true }
76
+ });
77
+ addElementClasses(document.documentElement, "bk-is-artboard");
78
+ const { context, storage, ui, animation, $t, dom, selection } = useBlokkli();
79
+ const artboardElement = ui.artboardElement();
80
+ const zoomLevel = computed(() => Math.round(ui.artboardScale.value * 100) + "%");
81
+ const PADDING = 50;
82
+ const options = computed(() => {
83
+ return {
84
+ maxScale: ui.isMobile.value ? 1 : 3,
85
+ direction: ui.isMobile.value ? "vertical" : "both",
86
+ minScale: 0.1,
87
+ overscrollBounds: {
88
+ top: ui.visibleViewport.value.y + PADDING,
89
+ left: ui.visibleViewport.value.x + PADDING,
90
+ right: ui.viewport.value.width - ui.visibleViewport.value.width - ui.visibleViewport.value.x + PADDING,
91
+ bottom: PADDING
92
+ },
93
+ getBlockingRects: () => {
94
+ const toolbarRects = subtractRectFromViewport(
95
+ ui.viewport.value,
96
+ ui.visibleViewport.value
97
+ );
98
+ return [...toolbarRects, ...ui.viewportBlockingRects.value];
99
+ }
100
+ };
101
+ });
102
+ watch(options, function(newOptions) {
103
+ artboard.setOptions(newOptions);
104
+ });
105
+ const storageKey = computed(
106
+ () => "artboard:" + context.value.entityUuid + (ui.isMobile.value ? "mobile" : "desktop")
107
+ );
108
+ const savedState = storage.use(storageKey, null);
109
+ const saveState = () => {
110
+ if (!props.persist) {
111
+ return;
112
+ }
113
+ savedState.value = {
114
+ offset: artboard.getOffset(),
115
+ scale: artboard.getScale()
116
+ };
117
+ };
118
+ let pluginWheel = null;
119
+ const wheelOptions = computed(() => {
120
+ return {
121
+ useMomentumZoom: props.momentum,
122
+ useMomentumScroll: props.momentum,
123
+ interceptWheel: true,
124
+ scrollSpeed: props.scrollSpeed,
125
+ wheelZoomFactor: props.scrollSpeed
126
+ };
127
+ });
128
+ watch(wheelOptions, function(newOptions) {
129
+ if (pluginWheel) {
130
+ pluginWheel.options.setAll(newOptions);
131
+ }
132
+ });
133
+ watch(selection.uuids, function() {
134
+ if (artboard.getMomentum()) {
135
+ artboard.cancelAnimation();
136
+ }
137
+ });
138
+ function getArtboard() {
139
+ pluginWheel = wheel(wheelOptions.value);
140
+ return createArtboard(
141
+ ui.rootElement(),
142
+ [
143
+ mouse(),
144
+ touch(),
145
+ pluginWheel,
146
+ domPlugin({
147
+ element: artboardElement,
148
+ precision: 1,
149
+ restoreStyles: true
150
+ })
151
+ ],
152
+ {
153
+ initTransform: savedState.value && props.persist ? {
154
+ x: asValidNumber(savedState.value.offset.x, 0),
155
+ y: asValidNumber(savedState.value.offset.y, 0),
156
+ scale: asValidNumber(savedState.value?.scale, 1)
157
+ } : void 0,
158
+ ...options.value
159
+ }
160
+ );
161
+ }
162
+ const artboard = getArtboard();
163
+ watch(options, function(newOptions) {
164
+ artboard.setOptions(newOptions);
165
+ });
166
+ const AUTOSCROLL_EDGE_ZONE = 130;
167
+ const AUTOSCROLL_SPEED = 12;
168
+ let autoScrollSpeed = 1;
169
+ function edgeStep(distance) {
170
+ const ratio = distance / AUTOSCROLL_EDGE_ZONE;
171
+ return Math.pow(ratio, 3) * AUTOSCROLL_SPEED;
172
+ }
173
+ let hasLeftAddList = false;
174
+ onBlokkliEvent("dragging:end", () => {
175
+ hasLeftAddList = false;
176
+ });
177
+ onBlokkliEvent("animationFrame:before", ({ time, mouseY, mouseX }) => {
178
+ if (selection.isDragging.value) {
179
+ if (ui.addListOrientation.value === "horizontal") {
180
+ if (!hasLeftAddList) {
181
+ if (isInsideRect(mouseX, mouseY, ui.visibleViewportPadded.value)) {
182
+ hasLeftAddList = true;
183
+ } else {
184
+ return;
185
+ }
186
+ }
187
+ }
188
+ const viewportHeight = ui.viewport.value.height;
189
+ const currentOffset = artboard.getOffset();
190
+ const y = Math.min(Math.max(mouseY, 0), viewportHeight);
191
+ let dy = 0;
192
+ if (y < AUTOSCROLL_EDGE_ZONE) {
193
+ const dist = AUTOSCROLL_EDGE_ZONE - y;
194
+ dy = edgeStep(dist);
195
+ } else if (y > viewportHeight - AUTOSCROLL_EDGE_ZONE) {
196
+ const dist = y - (viewportHeight - AUTOSCROLL_EDGE_ZONE);
197
+ dy = -edgeStep(dist);
198
+ } else {
199
+ autoScrollSpeed = 1;
200
+ }
201
+ if (dy !== 0) {
202
+ artboard.setOffset(null, currentOffset.y + dy * autoScrollSpeed);
203
+ autoScrollSpeed = Math.min(autoScrollSpeed * 1.01, 2.25);
204
+ }
205
+ } else {
206
+ autoScrollSpeed = 1;
207
+ }
208
+ artboard.loop(time);
209
+ const artboardSize = artboard.getArtboardSize();
210
+ if (artboardSize) {
211
+ ui.artboardSize.value.height = artboardSize.height;
212
+ ui.artboardSize.value.width = artboardSize.width;
213
+ }
214
+ const offset = artboard.getOffset();
215
+ ui.artboardOffset.value.x = asValidNumber(Math.ceil(offset.x), 0);
216
+ ui.artboardOffset.value.y = asValidNumber(Math.ceil(offset.y), 0);
217
+ ui.artboardScale.value = asValidNumber(artboard.getScale(), 1);
218
+ animation.requestDraw();
219
+ });
220
+ onMounted(() => {
221
+ window.addEventListener("beforeunload", saveState);
222
+ });
223
+ onBeforeUnmount(() => {
224
+ saveState();
225
+ artboard.destroy();
226
+ window.removeEventListener("beforeunload", saveState);
227
+ });
228
+ const resetZoom = () => {
229
+ artboard.resetZoom({
230
+ duration: 500
231
+ });
232
+ animation.requestDraw();
233
+ };
234
+ onBlokkliEvent("keyPressed", (e) => {
235
+ if (ui.hasDialogOpen.value) {
236
+ return;
237
+ }
238
+ if (e.code === "Home") {
239
+ e.originalEvent.preventDefault();
240
+ artboard.scrollToTop();
241
+ animation.requestDraw();
242
+ } else if (e.code === "End") {
243
+ e.originalEvent.preventDefault();
244
+ artboard.scrollToEnd();
245
+ animation.requestDraw();
246
+ } else if (e.code === "PageUp") {
247
+ e.originalEvent.preventDefault();
248
+ artboard.scrollPageUp();
249
+ animation.requestDraw();
250
+ } else if (e.code === "PageDown") {
251
+ e.originalEvent.preventDefault();
252
+ artboard.scrollPageDown();
253
+ animation.requestDraw();
254
+ } else if (e.code === "ArrowUp") {
255
+ e.originalEvent.preventDefault();
256
+ artboard.scrollUp();
257
+ animation.requestDraw();
258
+ } else if (e.code === "ArrowDown") {
259
+ e.originalEvent.preventDefault();
260
+ artboard.scrollDown();
261
+ animation.requestDraw();
262
+ } else if (e.code === "0" && e.meta) {
263
+ e.originalEvent.preventDefault();
264
+ resetZoom();
265
+ } else if (e.code === "1" && e.meta) {
266
+ e.originalEvent.preventDefault();
267
+ artboard.scaleToFit();
268
+ animation.requestDraw();
269
+ }
270
+ });
271
+ onBlokkliEvent("scrollIntoView", (e) => {
272
+ if ("uuid" in e) {
273
+ const rect = dom.getBlockRect(e.uuid);
274
+ if (!rect) {
275
+ return;
276
+ }
277
+ if (dom.isBlockVisible(e.uuid)) {
278
+ return;
279
+ }
280
+ artboard.scrollIntoView(rect, {
281
+ scale: "none",
282
+ axis: "y",
283
+ behavior: e.immediate ? "instant" : "auto"
284
+ });
285
+ } else {
286
+ if (artboardElement.contains(e.element)) {
287
+ artboard.scrollElementIntoView(e.element, {
288
+ scale: "none",
289
+ axis: "y",
290
+ behavior: e.immediate ? "instant" : "auto"
291
+ });
292
+ } else {
293
+ artboard.scrollToTop({
294
+ duration: 0
295
+ });
296
+ }
297
+ }
298
+ });
299
+ </script>
@@ -0,0 +1,7 @@
1
+ type __VLS_Props = {
2
+ persist: boolean;
3
+ momentum: boolean;
4
+ scrollSpeed: number;
5
+ };
6
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
7
+ export default _default;
@@ -1,72 +1,16 @@
1
1
  <template>
2
- <PluginToolbarButton
3
- id="artboard_reset_zoom"
4
- :title="$t('artboardResetZoom', 'Reset zoom')"
5
- :shortcut-group="$t('artboard', 'Artboard')"
6
- :tour-text="
7
- $t(
8
- 'artboardToolbarButtonTourText',
9
- 'Shows the current zoom factor. Click on it to reset the zoom back to 100%.'
10
- )
11
- "
12
- icon="magnifier"
13
- meta
14
- key-code="0"
15
- region="view-options"
16
- weight="100"
17
- @click="resetZoom"
18
- >
19
- <div class="bk-feature-canvas-button">
20
- <span>{{ zoomLevel }}</span>
21
- </div>
22
- </PluginToolbarButton>
23
-
24
- <PluginViewOption
25
- id="artboardOverview"
26
- v-slot="{ isActive }"
27
- :label="$t('artboardOverviewToggle', 'Toggle overview')"
28
- :title-on="$t('artboardOverviewShow', 'Show overview')"
29
- :title-off="$t('artboardOverviewHide', 'Hide overview')"
30
- :tour-text="
31
- $t(
32
- 'artboardOverviewTourText',
33
- `Displays a top level overview of your content.`
34
- )
35
- "
36
- icon="eye"
37
- key-code="O"
38
- weight="90"
39
- >
40
- <Teleport v-if="isActive" to="body">
41
- <Overview :artboard="artboard" />
42
- </Teleport>
43
- </PluginViewOption>
44
-
45
- <Scrollbar :artboard="artboard" orientation="y" />
2
+ <Renderer
3
+ v-if="renderArtboard"
4
+ :persist="settings.persist"
5
+ :momentum="settings.momentum"
6
+ :scroll-speed="settings.scrollSpeed"
7
+ />
46
8
  </template>
47
9
 
48
10
  <script setup>
49
- import {
50
- watch,
51
- computed,
52
- useBlokkli,
53
- onMounted,
54
- onBeforeUnmount,
55
- defineBlokkliFeature
56
- } from "#imports";
57
- import { PluginToolbarButton, PluginViewOption } from "#blokkli/plugins";
58
- import { asValidNumber } from "#blokkli/helpers";
59
- import Overview from "./Overview/index.vue";
60
- import Scrollbar from "./Scrollbar/index.vue";
61
- import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
11
+ import { computed, useBlokkli, defineBlokkliFeature } from "#imports";
62
12
  import defineShortcut from "#blokkli/helpers/composables/defineShortcut";
63
- import {
64
- createArtboard,
65
- touch,
66
- wheel,
67
- mouse,
68
- dom as domPlugin
69
- } from "artboard-deluxe";
13
+ import Renderer from "./Renderer.vue";
70
14
  const { settings } = defineBlokkliFeature({
71
15
  id: "artboard",
72
16
  label: "Artboard",
@@ -102,145 +46,8 @@ const { settings } = defineBlokkliFeature({
102
46
  },
103
47
  screenshot: "feature-artboard.jpg"
104
48
  });
105
- const { context, storage, ui, animation, $t, dom, selection } = useBlokkli();
106
- const zoomLevel = computed(() => Math.round(ui.artboardScale.value * 100) + "%");
107
- const PADDING = 50;
108
- const options = computed(() => {
109
- return {
110
- maxScale: ui.isMobile.value ? 1 : 3,
111
- direction: ui.isMobile.value ? "vertical" : "both",
112
- minScale: 0.1,
113
- overscrollBounds: {
114
- top: ui.visibleViewport.value.y + PADDING,
115
- left: ui.visibleViewport.value.x + PADDING,
116
- right: ui.viewport.value.width - ui.visibleViewport.value.width - ui.visibleViewport.value.x + PADDING,
117
- bottom: PADDING
118
- }
119
- };
120
- });
121
- watch(options, function(newOptions) {
122
- artboard.setOptions(newOptions);
123
- });
124
- const storageKey = computed(() => "artboard:" + context.value.entityUuid);
125
- const savedState = storage.use(storageKey, null);
126
- const saveState = () => {
127
- if (!settings.value.persist) {
128
- return;
129
- }
130
- savedState.value = {
131
- offset: artboard.getOffset(),
132
- scale: artboard.getScale()
133
- };
134
- };
135
- let pluginWheel = null;
136
- const wheelOptions = computed(() => {
137
- return {
138
- useMomentumZoom: settings.value.momentum,
139
- useMomentumScroll: settings.value.momentum,
140
- interceptWheel: true,
141
- scrollSpeed: settings.value.scrollSpeed,
142
- wheelZoomFactor: settings.value.scrollSpeed
143
- };
144
- });
145
- watch(wheelOptions, function(newOptions) {
146
- if (pluginWheel) {
147
- pluginWheel.options.setAll(newOptions);
148
- }
149
- });
150
- watch(selection.uuids, function() {
151
- if (artboard.getMomentum()) {
152
- artboard.cancelAnimation();
153
- }
154
- });
155
- function getArtboard() {
156
- pluginWheel = wheel(wheelOptions.value);
157
- return createArtboard(
158
- ui.rootElement(),
159
- [
160
- mouse(),
161
- touch(),
162
- pluginWheel,
163
- domPlugin({
164
- element: ui.artboardElement(),
165
- precision: 1,
166
- restoreStyles: true
167
- })
168
- ],
169
- {
170
- initTransform: savedState.value && settings.value.persist ? {
171
- x: asValidNumber(savedState.value.offset.x, 0),
172
- y: asValidNumber(savedState.value.offset.y, 0),
173
- scale: asValidNumber(savedState.value?.scale, 1)
174
- } : void 0,
175
- ...options.value
176
- }
177
- );
178
- }
179
- const artboard = getArtboard();
180
- watch(options, function(newOptions) {
181
- artboard.setOptions(newOptions);
182
- });
183
- onBlokkliEvent("animationFrame:before", (time) => {
184
- artboard.loop(time);
185
- const artboardSize = artboard.getArtboardSize();
186
- if (artboardSize) {
187
- ui.artboardSize.value.height = artboardSize.height;
188
- ui.artboardSize.value.width = artboardSize.width;
189
- }
190
- const offset = artboard.getOffset();
191
- ui.artboardOffset.value.x = asValidNumber(Math.ceil(offset.x), 0);
192
- ui.artboardOffset.value.y = asValidNumber(Math.ceil(offset.y), 0);
193
- ui.artboardScale.value = asValidNumber(artboard.getScale(), 1);
194
- animation.requestDraw();
195
- });
196
- onMounted(() => {
197
- window.addEventListener("beforeunload", saveState);
198
- });
199
- onBeforeUnmount(() => {
200
- saveState();
201
- artboard.destroy();
202
- window.removeEventListener("beforeunload", saveState);
203
- });
204
- const resetZoom = () => {
205
- artboard.resetZoom({
206
- duration: 500
207
- });
208
- animation.requestDraw();
209
- };
210
- onBlokkliEvent("keyPressed", (e) => {
211
- if (e.code === "Home") {
212
- e.originalEvent.preventDefault();
213
- artboard.scrollToTop();
214
- animation.requestDraw();
215
- } else if (e.code === "End") {
216
- e.originalEvent.preventDefault();
217
- artboard.scrollToEnd();
218
- animation.requestDraw();
219
- } else if (e.code === "PageUp") {
220
- e.originalEvent.preventDefault();
221
- artboard.scrollPageUp();
222
- animation.requestDraw();
223
- } else if (e.code === "PageDown") {
224
- e.originalEvent.preventDefault();
225
- artboard.scrollPageDown();
226
- animation.requestDraw();
227
- } else if (e.code === "ArrowUp") {
228
- e.originalEvent.preventDefault();
229
- artboard.scrollUp();
230
- animation.requestDraw();
231
- } else if (e.code === "ArrowDown") {
232
- e.originalEvent.preventDefault();
233
- artboard.scrollDown();
234
- animation.requestDraw();
235
- } else if (e.code === "0" && e.meta) {
236
- e.originalEvent.preventDefault();
237
- resetZoom();
238
- } else if (e.code === "1" && e.meta) {
239
- e.originalEvent.preventDefault();
240
- artboard.scaleToFit();
241
- animation.requestDraw();
242
- }
243
- });
49
+ const { ui, $t } = useBlokkli();
50
+ const renderArtboard = computed(() => !ui.isAnalyzing.value);
244
51
  defineShortcut(
245
52
  [
246
53
  {
@@ -276,20 +83,6 @@ defineShortcut(
276
83
  return { ...v, group: $t("artboard", "Artboard") };
277
84
  })
278
85
  );
279
- onBlokkliEvent("scrollIntoView", (e) => {
280
- const rect = dom.getBlockRect(e.uuid);
281
- if (!rect) {
282
- return;
283
- }
284
- if (dom.isBlockVisible(e.uuid)) {
285
- return;
286
- }
287
- artboard.scrollIntoView(rect, {
288
- scale: "none",
289
- axis: "y",
290
- behavior: e.immediate ? "instant" : "auto"
291
- });
292
- });
293
86
  </script>
294
87
 
295
88
  <script>
@@ -1,8 +1,8 @@
1
1
  <template>
2
2
  <Teleport to="body">
3
- <transition name="bk-slide-in" :duration="200">
3
+ <BlokkliTransition name="slide-in">
4
4
  <Overlay v-if="placedAction" @close="onClose" @submit="onSubmit" />
5
- </transition>
5
+ </BlokkliTransition>
6
6
  </Teleport>
7
7
 
8
8
  <PluginAddAction
@@ -20,6 +20,7 @@
20
20
  <script setup>
21
21
  import { useBlokkli, defineBlokkliFeature, ref } from "#imports";
22
22
  import { PluginAddAction } from "#blokkli/plugins";
23
+ import { BlokkliTransition } from "#blokkli/components";
23
24
  import Overlay from "./Overlay/index.vue";
24
25
  const { adapter } = defineBlokkliFeature({
25
26
  id: "assistant",
@@ -30,7 +31,8 @@ const { adapter } = defineBlokkliFeature({
30
31
  "assistantGetResults",
31
32
  "assistantAddBlockFromResult"
32
33
  ],
33
- screenshot: "feature-assistant.jpg"
34
+ screenshot: "feature-assistant.jpg",
35
+ dependencies: ["add-list"]
34
36
  });
35
37
  const { state, $t } = useBlokkli();
36
38
  const placedAction = ref(null);