@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
@@ -1,32 +1,446 @@
1
1
  <template>
2
- <Teleport to="body">
3
- <canvas id="bk-animation-canvas-webgl" ref="canvasGl" />
2
+ <Teleport to="#bk-canvas-overlay">
3
+ <canvas
4
+ id="bk-animation-canvas-webgl"
5
+ ref="canvasEl"
6
+ :style
7
+ @click.capture="onClick"
8
+ @pointerdown.capture="onPointerDown"
9
+ @pointerup.capture="onPointerUp"
10
+ />
4
11
  </Teleport>
5
12
  </template>
6
13
 
7
14
  <script setup>
15
+ import {
16
+ falsy,
17
+ getDistance,
18
+ getInteractionCoordinates,
19
+ isInsideRect
20
+ } from "#blokkli/helpers";
21
+ import {
22
+ MOUSE_BUTTON,
23
+ MOUSE_BUTTONS
24
+ } from "#blokkli/helpers/dom";
8
25
  import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
9
- import { ref, computed, useBlokkli, onMounted, watch } from "#imports";
10
- const { ui, animation, eventBus } = useBlokkli();
11
- const canvasGl = ref(null);
26
+ import {
27
+ ref,
28
+ computed,
29
+ useBlokkli,
30
+ onMounted,
31
+ watch,
32
+ useTemplateRef,
33
+ onBeforeUnmount
34
+ } from "#imports";
35
+ const {
36
+ dom,
37
+ eventBus,
38
+ selection,
39
+ keyboard,
40
+ ui,
41
+ animation,
42
+ state,
43
+ directive,
44
+ runtimeConfig,
45
+ blocks
46
+ } = useBlokkli();
47
+ const cursor = computed(
48
+ () => state.isLoading.value ? "wait" : animation.cursor.value
49
+ );
50
+ const style = computed(() => {
51
+ return {
52
+ imageRendering: "pixelated",
53
+ cursor: cursor.value
54
+ };
55
+ });
56
+ const rects = ref([]);
57
+ function buildRects() {
58
+ const visible = dom.getVisibleBlocks();
59
+ rects.value = visible.map((uuid) => {
60
+ const rect = dom.getBlockRect(uuid);
61
+ if (!rect) {
62
+ return;
63
+ }
64
+ return { uuid, rect };
65
+ }).filter(falsy);
66
+ }
67
+ watch(dom.isReady, buildRects);
68
+ let lastInteractedElement = null;
69
+ let pointerDownElement = null;
70
+ let mouseStartCoordinates = null;
71
+ let pointerDownTimestamp = 0;
72
+ let pointerUpTimestamp = 0;
73
+ function getInteractedElement(e) {
74
+ const { x, y } = getInteractionCoordinates(e);
75
+ const editableField = directive.getEditableAtPoint(x, y);
76
+ if (editableField) {
77
+ const uuid = editableField.type === runtimeConfig.itemEntityType ? editableField.uuid : void 0;
78
+ return {
79
+ editableFieldName: editableField.fieldName,
80
+ uuid,
81
+ timestamp: Date.now(),
82
+ x,
83
+ y
84
+ };
85
+ }
86
+ const visibleUuids = dom.getVisibleBlocks();
87
+ let deepestUuid = "";
88
+ let deepestLevel = -1;
89
+ for (let i = 0; i < visibleUuids.length; i++) {
90
+ const uuid = visibleUuids[i];
91
+ if (!uuid) {
92
+ continue;
93
+ }
94
+ const rect = dom.getBlockRect(uuid);
95
+ if (rect) {
96
+ const level = state.getNestingLevel(uuid);
97
+ if (level <= deepestLevel) {
98
+ continue;
99
+ }
100
+ const relativeRect = ui.getViewportRelativeRect(rect);
101
+ if (isInsideRect(x, y, relativeRect)) {
102
+ deepestUuid = uuid;
103
+ deepestLevel = level;
104
+ }
105
+ }
106
+ }
107
+ if (deepestUuid) {
108
+ return {
109
+ uuid: deepestUuid,
110
+ timestamp: Date.now(),
111
+ x,
112
+ y
113
+ };
114
+ }
115
+ return null;
116
+ }
117
+ function toDraggableExisting(v) {
118
+ const blocks2 = Array.isArray(v) ? v : [v];
119
+ return blocks2.map((block) => {
120
+ return {
121
+ itemType: "existing",
122
+ block
123
+ };
124
+ });
125
+ }
126
+ function onPointerMove(e) {
127
+ if (keyboard.isPressingSpace.value || e.buttons === MOUSE_BUTTONS.AUXILIARY) {
128
+ return;
129
+ }
130
+ e.preventDefault();
131
+ e.stopPropagation();
132
+ e.stopImmediatePropagation();
133
+ if (e.pointerType === "touch") {
134
+ return onTouchMove(e);
135
+ }
136
+ if (e.buttons !== MOUSE_BUTTONS.PRIMARY) {
137
+ return;
138
+ }
139
+ if (!mouseStartCoordinates || selection.isMultiSelecting.value || selection.isDragging.value || keyboard.isPressingSpace.value) {
140
+ return;
141
+ }
142
+ const diffX = Math.abs(mouseStartCoordinates.x - e.clientX);
143
+ const diffY = Math.abs(mouseStartCoordinates.y - e.clientY);
144
+ if (!pointerDownElement) {
145
+ const timeDelta = Date.now() - pointerDownTimestamp;
146
+ const maxMovement = Math.max(diffX, diffY);
147
+ if (maxMovement > 6 && timeDelta > 150 || maxMovement > 20) {
148
+ canvasEl.value?.removeEventListener("pointermove", onPointerMove);
149
+ eventBus.emit("multi-select:start", {
150
+ x: e.clientX,
151
+ y: e.clientY
152
+ });
153
+ }
154
+ return;
155
+ }
156
+ if (state.editMode.value !== "editing") {
157
+ return;
158
+ }
159
+ if (diffX < 6 && diffY < 6) {
160
+ return;
161
+ }
162
+ const interacted = getInteractedElement(e);
163
+ if (interacted && interacted.uuid) {
164
+ if (selection.uuids.value.includes(interacted.uuid)) {
165
+ eventBus.emit("dragging:start", {
166
+ items: toDraggableExisting(selection.items.value),
167
+ coords: { x: e.clientX, y: e.clientY },
168
+ mode: "mouse"
169
+ });
170
+ } else {
171
+ const block = blocks.getBlock(interacted.uuid);
172
+ if (block) {
173
+ eventBus.emit("dragging:start", {
174
+ items: toDraggableExisting(block),
175
+ coords: { x: e.clientX, y: e.clientY },
176
+ mode: "mouse"
177
+ });
178
+ }
179
+ }
180
+ canvasEl.value?.removeEventListener("pointermove", onPointerMove);
181
+ }
182
+ }
183
+ function onPointerDown(e) {
184
+ if (e.buttons === MOUSE_BUTTONS.AUXILIARY) {
185
+ return;
186
+ }
187
+ if (!keyboard.isPressingSpace.value) {
188
+ e.preventDefault();
189
+ e.stopPropagation();
190
+ e.stopImmediatePropagation();
191
+ }
192
+ keyboard.setShortcutStateFromEvent(e);
193
+ canvasEl.value?.removeEventListener("pointermove", onPointerMove);
194
+ if (ui.openTooltip.value) {
195
+ return;
196
+ }
197
+ if (state.isLoading.value) {
198
+ return;
199
+ }
200
+ canvasEl.value?.addEventListener("pointermove", onPointerMove);
201
+ if (e.pointerType === "touch") {
202
+ return onTouchStart(e);
203
+ }
204
+ if (selection.isDragging.value) {
205
+ return;
206
+ }
207
+ pointerDownTimestamp = Date.now();
208
+ const coords = { x: e.clientX, y: e.clientY };
209
+ mouseStartCoordinates = coords;
210
+ if (!e.shiftKey && e.buttons === MOUSE_BUTTONS.PRIMARY) {
211
+ const interacted = getInteractedElement(e);
212
+ pointerDownElement = interacted;
213
+ if (interacted) {
214
+ return;
215
+ }
216
+ }
217
+ eventBus.emit("mouse:down", { ...coords, type: "mouse", distance: 0 });
218
+ }
219
+ function isClickInArtboard(coords) {
220
+ const size = ui.artboardSize.value;
221
+ const scale = ui.artboardScale.value;
222
+ const rect = {
223
+ x: ui.artboardOffset.value.x,
224
+ y: ui.artboardOffset.value.y,
225
+ width: size.width * scale,
226
+ height: size.height * scale
227
+ };
228
+ return isInsideRect(coords.x, coords.y, rect);
229
+ }
230
+ function onPointerUp(e) {
231
+ canvasEl.value?.removeEventListener("pointermove", onPointerMove);
232
+ if (e.button === MOUSE_BUTTON.AUXILIARY) {
233
+ e.preventDefault();
234
+ return;
235
+ }
236
+ e.preventDefault();
237
+ e.stopPropagation();
238
+ e.stopImmediatePropagation();
239
+ if (ui.openTooltip.value) {
240
+ ui.openTooltip.value = "";
241
+ return;
242
+ }
243
+ const wasDragging = selection.isDragging.value;
244
+ const wasMultiSelecting = selection.isMultiSelecting.value;
245
+ pointerDownElement = null;
246
+ if (state.isLoading.value) {
247
+ return;
248
+ }
249
+ if (e.pointerType === "touch") {
250
+ return onTouchEnd(e);
251
+ }
252
+ const coords = getInteractionCoordinates(e);
253
+ const distance = mouseStartCoordinates ? getDistance(mouseStartCoordinates, coords) : 0;
254
+ eventBus.emit("mouse:up", {
255
+ x: e.clientX,
256
+ y: e.clientY,
257
+ type: "mouse",
258
+ distance,
259
+ duration: Date.now() - pointerDownTimestamp
260
+ });
261
+ if (wasDragging || wasMultiSelecting) {
262
+ eventBus.emit("dragging:end");
263
+ return;
264
+ }
265
+ if (keyboard.isPressingSpace.value) {
266
+ return;
267
+ }
268
+ if (selection.editableActive.value) {
269
+ eventBus.emit("window:clickAway");
270
+ lastInteractedElement = null;
271
+ return;
272
+ }
273
+ if (animation.handleClick(e.clientX, e.clientY)) {
274
+ return;
275
+ }
276
+ const clicked = getInteractedElement(e);
277
+ if (clicked && pointerUpTimestamp && lastInteractedElement && (clicked.uuid === lastInteractedElement.uuid || clicked.editableFieldName === lastInteractedElement.editableFieldName)) {
278
+ const deltaTime = Date.now() - pointerUpTimestamp;
279
+ const deltaX = Math.abs(lastInteractedElement.x - e.clientX);
280
+ const deltaY = Math.abs(lastInteractedElement.y - e.clientY);
281
+ if (deltaTime < 400 && deltaX < 3 && deltaY < 3) {
282
+ if (clicked.editableFieldName) {
283
+ eventBus.emit("editable:focus", {
284
+ fieldName: clicked.editableFieldName,
285
+ uuid: clicked.uuid
286
+ });
287
+ return;
288
+ }
289
+ if (lastInteractedElement.uuid) {
290
+ const block = blocks.getBlock(lastInteractedElement.uuid);
291
+ if (!block) {
292
+ return;
293
+ }
294
+ eventBus.emit("item:doubleClick", block);
295
+ }
296
+ }
297
+ }
298
+ lastInteractedElement = clicked;
299
+ pointerUpTimestamp = Date.now();
300
+ if (clicked?.uuid) {
301
+ dom.refreshBlockRect(clicked.uuid);
302
+ if (keyboard.isPressingControl.value || selection.isMultiSelecting.value) {
303
+ eventBus.emit("select:toggle", clicked.uuid);
304
+ } else if (keyboard.isPressingShift.value) {
305
+ eventBus.emit("select:shiftToggle", clicked.uuid);
306
+ } else {
307
+ eventBus.emit("select", clicked.uuid);
308
+ }
309
+ return;
310
+ }
311
+ eventBus.emit("window:clickAway");
312
+ if (isClickInArtboard(coords)) {
313
+ eventBus.emit("select:host");
314
+ } else {
315
+ eventBus.emit("select:host:unselect");
316
+ }
317
+ }
318
+ let longPressTimeout = null;
319
+ let touchStartInteraction = null;
320
+ let touchStartCoords = null;
321
+ let longPressInteraction = null;
322
+ let touchStartTimestamp = 0;
323
+ function onTouchStart(e) {
324
+ if (e.isPrimary) {
325
+ touchStartTimestamp = Date.now();
326
+ }
327
+ longPressInteraction = null;
328
+ const coords = getInteractionCoordinates(e);
329
+ touchStartCoords = coords;
330
+ eventBus.emit("mouse:down", { ...coords, type: "touch", distance: 0 });
331
+ if (ui.openTooltip.value) {
332
+ return;
333
+ }
334
+ if (selection.isDragging.value) {
335
+ return;
336
+ }
337
+ clearTimeout(longPressTimeout);
338
+ const interacted = getInteractedElement(e);
339
+ if (!interacted?.uuid) {
340
+ return;
341
+ }
342
+ touchStartInteraction = interacted;
343
+ longPressTimeout = setTimeout(() => {
344
+ if (touchStartInteraction?.uuid) {
345
+ longPressInteraction = touchStartInteraction;
346
+ if (selection.uuids.value.includes(touchStartInteraction.uuid) && state.editMode.value === "editing") {
347
+ eventBus.emit("dragging:start", {
348
+ items: toDraggableExisting(selection.items.value),
349
+ coords: {
350
+ x: touchStartInteraction.x,
351
+ y: touchStartInteraction.y
352
+ },
353
+ mode: "touch"
354
+ });
355
+ return;
356
+ }
357
+ eventBus.emit("select:start", {
358
+ uuids: [...selection.uuids.value, touchStartInteraction.uuid],
359
+ mode: "touch"
360
+ });
361
+ }
362
+ }, 500);
363
+ }
364
+ function onTouchMove(e) {
365
+ if (!longPressTimeout || !touchStartInteraction) {
366
+ return;
367
+ }
368
+ const coords = getInteractionCoordinates(e);
369
+ const deltaX = Math.abs(coords.x - touchStartInteraction.x);
370
+ const deltaY = Math.abs(coords.y - touchStartInteraction.y);
371
+ if (deltaX > 10 || deltaY > 10) {
372
+ clearTimeout(longPressTimeout);
373
+ longPressTimeout = null;
374
+ }
375
+ }
376
+ function onTouchEnd(e) {
377
+ const wasDragging = selection.isDragging.value;
378
+ const coords = getInteractionCoordinates(e);
379
+ const distance = touchStartCoords ? getDistance(touchStartCoords, coords) : 0;
380
+ if (e.isPrimary) {
381
+ eventBus.emit("mouse:up", {
382
+ ...coords,
383
+ type: "touch",
384
+ distance,
385
+ duration: Date.now() - touchStartTimestamp
386
+ });
387
+ }
388
+ clearTimeout(longPressTimeout);
389
+ longPressTimeout = null;
390
+ if (ui.openTooltip.value) {
391
+ ui.openTooltip.value = "";
392
+ return;
393
+ }
394
+ if (wasDragging) {
395
+ return;
396
+ }
397
+ if (!touchStartCoords) {
398
+ return;
399
+ }
400
+ if (distance > 7) {
401
+ return;
402
+ }
403
+ if (animation.handleClick(coords.x, coords.y)) {
404
+ return;
405
+ }
406
+ const interacted = getInteractedElement(e);
407
+ if (interacted?.uuid) {
408
+ if (longPressInteraction && longPressInteraction.uuid === interacted.uuid) {
409
+ return;
410
+ }
411
+ if (selection.isMultiSelecting.value) {
412
+ eventBus.emit("select:toggle", interacted.uuid);
413
+ } else {
414
+ eventBus.emit("select", interacted.uuid);
415
+ }
416
+ } else {
417
+ eventBus.emit("window:clickAway");
418
+ }
419
+ longPressInteraction = null;
420
+ }
421
+ onBlokkliEvent("dragging:start", (e) => {
422
+ mouseStartCoordinates = e.coords;
423
+ });
424
+ function onClick(e) {
425
+ e.preventDefault();
426
+ e.stopImmediatePropagation();
427
+ e.stopPropagation();
428
+ }
429
+ const canvasEl = useTemplateRef("canvasEl");
12
430
  const canvasAttributes = computed(() => {
13
431
  return {
14
432
  width: ui.viewport.value.width * animation.dpi.value,
15
- height: ui.viewport.value.height * animation.dpi.value,
16
- style: {
17
- width: ui.viewport.value.width + "px",
18
- height: ui.viewport.value.height + "px"
19
- }
433
+ height: ui.viewport.value.height * animation.dpi.value
20
434
  };
21
435
  });
22
436
  let gl = null;
23
437
  function initGl() {
24
- if (!canvasGl.value) {
438
+ if (!canvasEl.value) {
25
439
  return;
26
440
  }
27
441
  gl = animation.gl();
28
- canvasGl.value.width = canvasAttributes.value.width;
29
- canvasGl.value.height = canvasAttributes.value.height;
442
+ canvasEl.value.width = canvasAttributes.value.width;
443
+ canvasEl.value.height = canvasAttributes.value.height;
30
444
  if (!gl) {
31
445
  return;
32
446
  }
@@ -57,31 +471,28 @@ function setScissor(v) {
57
471
  watch(scissor, setScissor);
58
472
  let lastCanvasWidth = 0;
59
473
  let lastCanvasHeight = 0;
60
- onBlokkliEvent("animationFrame", (e) => {
61
- if (!canvasGl.value) {
474
+ onBlokkliEvent("animationFrame", () => {
475
+ if (!canvasEl.value) {
62
476
  return;
63
477
  }
64
478
  const canvasWidth = canvasAttributes.value.width;
65
479
  const canvasHeight = canvasAttributes.value.height;
66
480
  if (canvasWidth !== lastCanvasWidth || canvasHeight !== lastCanvasHeight) {
67
- canvasGl.value.width = canvasWidth;
68
- canvasGl.value.height = canvasHeight;
481
+ canvasEl.value.width = canvasWidth;
482
+ canvasEl.value.height = canvasHeight;
69
483
  if (gl) {
70
484
  gl.viewport(0, 0, canvasWidth, canvasHeight);
71
485
  }
72
486
  lastCanvasWidth = canvasWidth;
73
487
  lastCanvasHeight = canvasHeight;
74
488
  }
75
- const offset = ui.artboardOffset.value;
76
- const scale = ui.artboardScale.value;
77
- eventBus.emit("canvas:draw", {
78
- ...e,
79
- artboardOffset: offset,
80
- artboardScale: scale,
81
- time: e.time
82
- });
83
489
  });
84
490
  onMounted(() => {
85
491
  initGl();
86
492
  });
493
+ onBeforeUnmount(() => {
494
+ if (canvasEl.value) {
495
+ canvasEl.value.removeEventListener("pointermove", onPointerMove);
496
+ }
497
+ });
87
498
  </script>
@@ -7,14 +7,14 @@
7
7
  </div>
8
8
  </Teleport>
9
9
  <Teleport to="body">
10
- <transition name="bk-fade" :duration="200">
10
+ <BlokkliTransition name="fade">
11
11
  <div
12
12
  v-if="menuOpen"
13
13
  class="bk bk-menu-overlay bk-overlay"
14
14
  @click="ui.menu.close()"
15
15
  />
16
- </transition>
17
- <transition name="bk-menu" :duration="200">
16
+ </BlokkliTransition>
17
+ <BlokkliTransition name="menu">
18
18
  <div v-show="menuOpen" class="bk bk-menu-list">
19
19
  <button :class="{ 'bk-is-active': menuOpen }" @click="ui.menu.close">
20
20
  <Icon name="close" />
@@ -34,13 +34,13 @@
34
34
  </aside>
35
35
  </div>
36
36
  </div>
37
- </transition>
37
+ </BlokkliTransition>
38
38
  </Teleport>
39
39
  </template>
40
40
 
41
41
  <script setup>
42
42
  import { computed, useBlokkli } from "#imports";
43
- import { Icon } from "#blokkli/components";
43
+ import { Icon, BlokkliTransition } from "#blokkli/components";
44
44
  import { blokkliVersion } from "#blokkli-build/config";
45
45
  const { ui, eventBus } = useBlokkli();
46
46
  const menuOpen = computed(() => ui.menu.isOpen.value);
@@ -0,0 +1,83 @@
1
+ <template>
2
+ <div
3
+ ref="el"
4
+ class="bk bk-artboard-tooltip"
5
+ :class="'bk-is-' + placementY"
6
+ :style="{
7
+ '--bk-caret-x': caretX
8
+ }"
9
+ >
10
+ <div class="bk bk-artboard-tooltip-inner bk-caret-tooltip-inner">
11
+ <div class="bk-artboard-tooltip-header">
12
+ <div v-html="title" />
13
+ <button @click="$emit('close')">
14
+ <Icon :name="closeIcon" />
15
+ </button>
16
+ </div>
17
+ <slot />
18
+ </div>
19
+ </div>
20
+ </template>
21
+
22
+ <script setup>
23
+ import useStickyToolbar, {
24
+ } from "#blokkli/helpers/composables/useStickyToolbar";
25
+ import {
26
+ useTemplateRef,
27
+ useBlokkli,
28
+ onMounted,
29
+ onBeforeUnmount,
30
+ watch
31
+ } from "#imports";
32
+ import { Icon } from "#blokkli/components";
33
+ import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
34
+ const props = defineProps({
35
+ id: { type: String, required: true },
36
+ title: { type: String, required: true },
37
+ anchorEl: { type: null, required: false, default: null },
38
+ anchorCoordinates: { type: [Object, null], required: false, default: null },
39
+ placementY: { type: String, required: false, default: "auto" },
40
+ closeIcon: { type: null, required: false, default: "close" }
41
+ });
42
+ const emit = defineEmits(["close"]);
43
+ const el = useTemplateRef("el");
44
+ const { ui } = useBlokkli();
45
+ const { placementY, caretX } = useStickyToolbar(el, {
46
+ getAnchorElement() {
47
+ return props.anchorEl ?? null;
48
+ },
49
+ getAnchorCoordinates() {
50
+ return props.anchorCoordinates ?? null;
51
+ },
52
+ getPlacementY() {
53
+ return props.placementY;
54
+ },
55
+ getPlacementX() {
56
+ return "center";
57
+ },
58
+ getCaretWidth() {
59
+ return 30;
60
+ }
61
+ });
62
+ watch(ui.openTooltip, (id) => {
63
+ if (id !== props.id) {
64
+ emit("close");
65
+ }
66
+ });
67
+ onBlokkliEvent("keyPressed", (e) => {
68
+ if (ui.hasDialogOpen.value) {
69
+ return;
70
+ }
71
+ if (e.code === "Escape") {
72
+ emit("close");
73
+ }
74
+ });
75
+ onMounted(() => {
76
+ ui.openTooltip.value = props.id;
77
+ });
78
+ onBeforeUnmount(() => {
79
+ if (ui.openTooltip.value === props.id) {
80
+ ui.openTooltip.value = "";
81
+ }
82
+ });
83
+ </script>
@@ -0,0 +1,32 @@
1
+ import { type PlacementVertical } from '#blokkli/helpers/composables/useStickyToolbar';
2
+ import type { BlokkliIcon } from '#blokkli-build/icons';
3
+ import type { Coord } from '#blokkli/types';
4
+ type __VLS_Props = {
5
+ id: string;
6
+ title: string;
7
+ anchorEl?: HTMLElement | null;
8
+ anchorCoordinates?: Coord | null;
9
+ placementY?: PlacementVertical;
10
+ closeIcon?: BlokkliIcon;
11
+ };
12
+ declare var __VLS_5: {};
13
+ type __VLS_Slots = {} & {
14
+ default?: (props: typeof __VLS_5) => any;
15
+ };
16
+ declare const __VLS_component: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
17
+ close: () => any;
18
+ }, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
19
+ onClose?: (() => any) | undefined;
20
+ }>, {
21
+ anchorEl: HTMLElement | null;
22
+ anchorCoordinates: Coord | null;
23
+ placementY: PlacementVertical;
24
+ closeIcon: BlokkliIcon;
25
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
26
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
27
+ export default _default;
28
+ type __VLS_WithSlots<T, S> = T & {
29
+ new (): {
30
+ $slots: S;
31
+ };
32
+ };
@@ -0,0 +1,51 @@
1
+ <template>
2
+ <div
3
+ ref="el"
4
+ class="bk bk-banner"
5
+ :class="scheme ? 'bk-scheme-' + scheme : void 0"
6
+ >
7
+ <Icon :name="icon" />
8
+ <p v-html="text" />
9
+ <button v-if="button" class="bk-banner-close" @click="$emit('click')">
10
+ {{ button }}
11
+ <Icon name="close" />
12
+ </button>
13
+ </div>
14
+ </template>
15
+
16
+ <script setup>
17
+ import { Icon } from "#blokkli/components";
18
+ import {
19
+ onBeforeUnmount,
20
+ onMounted,
21
+ useTemplateRef,
22
+ useBlokkli
23
+ } from "#imports";
24
+ const props = defineProps({
25
+ id: { type: String, required: true },
26
+ icon: { type: null, required: true },
27
+ text: { type: String, required: true },
28
+ button: { type: String, required: false, default: void 0 },
29
+ scheme: { type: String, required: false, default: "accent" }
30
+ });
31
+ defineEmits(["click"]);
32
+ const { ui } = useBlokkli();
33
+ const el = useTemplateRef("el");
34
+ const observer = new ResizeObserver((entries) => {
35
+ const entry = entries.at(0);
36
+ if (!entry) {
37
+ return;
38
+ }
39
+ const height = Math.ceil(entry.borderBoxSize.at(0)?.blockSize ?? 0);
40
+ ui.setBannerHeight(props.id, height);
41
+ });
42
+ onMounted(() => {
43
+ if (el.value) {
44
+ observer.observe(el.value);
45
+ }
46
+ });
47
+ onBeforeUnmount(() => {
48
+ observer.disconnect();
49
+ ui.removeBanner(props.id);
50
+ });
51
+ </script>