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

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 +51 -39
  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 +153 -64
  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 +96 -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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@blokkli/editor",
3
- "version": "2.0.0-alpha.2",
3
+ "version": "2.0.0-alpha.20",
4
4
  "description": "Interactive page building experience for Nuxt",
5
5
  "repository": "blokkli/editor",
6
6
  "type": "module",
@@ -57,55 +57,72 @@
57
57
  "license": "MIT",
58
58
  "dependencies": {
59
59
  "@types/micromatch": "^4.0.9",
60
- "artboard-deluxe": "^0.1.0",
61
- "estree-walker-ts": "^1.0.1",
60
+ "artboard-deluxe": "^0.1.2",
61
+ "estree-walker-ts": "^1.1.0",
62
+ "flesch": "^2.0.1",
62
63
  "fzf": "^0.5.2",
63
64
  "get-video-id": "^4.1.7",
64
65
  "html-diff-ts": "^1.4.2",
66
+ "hyphen": "^1.10.6",
65
67
  "mitt": "^3.0.1",
66
- "qrcode.vue": "^3.4.1",
67
- "twgl.js": "^5.5.4"
68
+ "parse-latin": "^7.0.0",
69
+ "qrcode.vue": "^3.6.0",
70
+ "twgl.js": "^7.0.0"
68
71
  },
69
72
  "devDependencies": {
70
- "@ckeditor/ckeditor5-build-classic": "^43.1.0",
71
- "@ckeditor/ckeditor5-vue": "^7.0.0",
73
+ "@ckeditor/ckeditor5-build-classic": "^44.3.0",
74
+ "@ckeditor/ckeditor5-vue": "^7.3.0",
75
+ "@lunarisapp/readability": "^1.0.2",
72
76
  "@nuxt/devtools": "latest",
73
- "@nuxt/eslint-config": "^1.3.0",
74
- "@nuxt/kit": "^3.16.2",
75
- "@nuxt/module-builder": "^1.0.1",
76
- "@nuxt/schema": "^3.16.2",
77
- "@nuxt/test-utils": "^3.14.2",
78
- "@nuxtjs/tailwindcss": "^6.12.1",
79
- "@tailwindcss/forms": "^0.5.9",
80
- "@tailwindcss/typography": "^0.5.15",
77
+ "@nuxt/eslint-config": "^1.9.0",
78
+ "@nuxt/kit": "^4.1.2",
79
+ "@nuxt/module-builder": "^1.0.2",
80
+ "@nuxt/schema": "^4.1.2",
81
+ "@nuxt/test-utils": "^3.19.2",
82
+ "@nuxtjs/tailwindcss": "^6.14.0",
83
+ "@tailwindcss/forms": "^0.5.10",
84
+ "@tailwindcss/typography": "^0.5.16",
81
85
  "@thedutchcoder/postcss-rem-to-px": "^0.0.2",
82
- "@types/gettext-parser": "^4.0.4",
83
- "@types/node": "^22.5.4",
86
+ "@types/gettext-parser": "^8.0.0",
87
+ "@types/hyphen": "^1.6.7",
88
+ "@types/node": "^24.3.0",
84
89
  "@vue/test-utils": "^2.4.6",
85
- "changelogen": "^0.5.5",
86
- "cypress": "^13.14.2",
87
- "eslint": "^9.24.0",
88
- "eslint-plugin-sonarjs": "^3.0.2",
89
- "eslint-plugin-tailwindcss": "^3.18.0",
90
+ "axe-core": "^4.10.3",
91
+ "changelogen": "^0.6.2",
92
+ "cypress": "^15.0.0",
93
+ "eslint": "^9.33.0",
94
+ "eslint-plugin-sonarjs": "^3.0.4",
95
+ "eslint-plugin-tailwindcss": "^3.18.2",
90
96
  "gettext-parser": "^8.0.0",
91
- "happy-dom": "^15.7.4",
92
- "nuxt": "^3.16.2",
93
- "nuxt-graphql-middleware": "^5.0.0-alpha.18",
94
- "nuxt-svg-icon-sprite": "^2.0.0-alpha.1",
95
- "openai": "^4.59.0",
96
- "playwright-core": "^1.47.0",
97
- "postcss": "^8.4.45",
98
- "postcss-cli": "^11.0.0",
99
- "postcss-import": "^16.1.0",
100
- "postcss-mixins": "^11.0.1",
97
+ "happy-dom": "^18.0.1",
98
+ "nuxt": "^4.1.2",
99
+ "nuxt-graphql-middleware": "^5.2.1",
100
+ "nuxt-svg-icon-sprite": "^2.0.2",
101
+ "openai": "^5.13.1",
102
+ "oxc-walker": "^0.5.2",
103
+ "playwright-core": "^1.55.0",
104
+ "postcss": "^8.5.6",
105
+ "postcss-cli": "^11.0.1",
106
+ "postcss-import": "^16.1.1",
107
+ "postcss-mixins": "^12.1.2",
101
108
  "postcss-nested-import": "^1.3.0",
102
109
  "postcss-replace": "^2.0.1",
103
110
  "postcss-url": "^10.1.3",
104
- "prettier": "^3.3.3",
105
- "prettier-plugin-glsl": "^0.2.0",
106
- "tailwindcss": "^3.4.11",
107
- "vite-plugin-glsl": "^1.3.0",
108
- "vitepress": "^1.3.4",
109
- "vitest": "^2.0.5"
111
+ "prettier": "^3.6.2",
112
+ "prettier-plugin-glsl": "^0.2.2",
113
+ "tailwindcss": "^3.4.17",
114
+ "unbuild": "^3.6.1",
115
+ "vite-plugin-glsl": "^1.5.1",
116
+ "vitepress": "^1.6.4",
117
+ "vitest": "^3.2.4",
118
+ "vue-tsc": "^2.2.12"
119
+ },
120
+ "peerDependencies": {
121
+ "@lunarisapp/readability": "^1.0.2"
122
+ },
123
+ "peerDependenciesMeta": {
124
+ "@lunarisapp/readability": {
125
+ "optional": true
126
+ }
110
127
  }
111
128
  }
@@ -1,6 +0,0 @@
1
- import * as _blokkli_adapter from '#blokkli/adapter';
2
- import { ParagraphsBlokkliEditStateFragment } from '#graphql-operations';
3
-
4
- declare const _default: _blokkli_adapter.BlokkliAdapterFactory<ParagraphsBlokkliEditStateFragment>;
5
-
6
- export { _default as default };
@@ -1,364 +0,0 @@
1
- <template>
2
- <div />
3
- </template>
4
-
5
- <script setup>
6
- import {
7
- falsy,
8
- getDistance,
9
- getInteractionCoordinates,
10
- isInsideRect
11
- } from "#blokkli/helpers";
12
- import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
13
- import { watch, ref, useBlokkli, onMounted, onBeforeUnmount } from "#imports";
14
- const { dom, eventBus, selection, keyboard, ui, state } = useBlokkli();
15
- const rootEl = ui.rootElement();
16
- const rects = ref([]);
17
- function buildRects() {
18
- const visible = dom.getVisibleBlocks();
19
- rects.value = visible.map((uuid) => {
20
- const rect = dom.getBlockRect(uuid);
21
- if (!rect) {
22
- return;
23
- }
24
- return { uuid, rect };
25
- }).filter(falsy);
26
- }
27
- watch(dom.isReady, buildRects);
28
- let lastInteractedElement = null;
29
- let pointerDownElement = null;
30
- let mouseStartCoordinates = null;
31
- function getInteractedElement(e) {
32
- const { x, y } = getInteractionCoordinates(e);
33
- const elements = document.elementsFromPoint(x, y);
34
- let editableFieldName = "";
35
- let uuid = "";
36
- for (let i = 0; i < elements.length; i++) {
37
- let el = elements[i];
38
- if (!(el instanceof HTMLElement)) {
39
- continue;
40
- }
41
- if (el.dataset.blokkliEditableField) {
42
- editableFieldName = el.dataset.blokkliEditableField;
43
- }
44
- if (el instanceof HTMLTableCellElement) {
45
- const parent = el.parentElement;
46
- if (parent instanceof HTMLTableRowElement) {
47
- el = parent;
48
- }
49
- }
50
- if (!(el instanceof HTMLElement)) {
51
- continue;
52
- }
53
- if (!el.dataset.uuid) {
54
- continue;
55
- }
56
- const block = dom.findBlock(el.dataset.uuid);
57
- if (!block) {
58
- continue;
59
- }
60
- const draggableEl = dom.getDragElement(block);
61
- if (draggableEl && el !== draggableEl && !elements.includes(draggableEl)) {
62
- continue;
63
- }
64
- uuid = el.dataset.uuid;
65
- break;
66
- }
67
- if (editableFieldName || uuid) {
68
- return { editableFieldName, uuid, timestamp: Date.now(), x, y };
69
- }
70
- const visibleUuids = dom.getVisibleBlocks();
71
- for (let i = 0; i < visibleUuids.length; i++) {
72
- const rect = dom.getBlockRect(visibleUuids[i]);
73
- if (rect) {
74
- const relativeRect = ui.getViewportRelativeRect(rect);
75
- if (isInsideRect(x, y, relativeRect)) {
76
- return {
77
- uuid: visibleUuids[i],
78
- timestamp: Date.now(),
79
- x,
80
- y
81
- };
82
- }
83
- }
84
- }
85
- return null;
86
- }
87
- function onPointerMove(e) {
88
- if (keyboard.isPressingSpace.value || state.editMode.value !== "editing") {
89
- return;
90
- }
91
- e.preventDefault();
92
- e.stopPropagation();
93
- e.stopImmediatePropagation();
94
- if (e.pointerType === "touch") {
95
- return onTouchMove(e);
96
- }
97
- if (e.buttons !== 1) {
98
- return;
99
- }
100
- if (!pointerDownElement || !mouseStartCoordinates || selection.isDragging.value || keyboard.isPressingSpace.value || selection.isMultiSelecting.value) {
101
- return;
102
- }
103
- const diffX = Math.abs(mouseStartCoordinates.x - e.clientX);
104
- const diffY = Math.abs(mouseStartCoordinates.y - e.clientY);
105
- if (diffX < 6 && diffY < 6) {
106
- return;
107
- }
108
- const interacted = getInteractedElement(e);
109
- if (interacted && interacted.uuid) {
110
- if (selection.uuids.value.includes(interacted.uuid)) {
111
- eventBus.emit("dragging:start", {
112
- items: [...selection.blocks.value],
113
- coords: { x: e.clientX, y: e.clientY },
114
- mode: "mouse"
115
- });
116
- } else {
117
- const block = dom.findBlock(interacted.uuid);
118
- if (block) {
119
- eventBus.emit("dragging:start", {
120
- items: [block],
121
- coords: { x: e.clientX, y: e.clientY },
122
- mode: "mouse"
123
- });
124
- }
125
- }
126
- }
127
- }
128
- let pointerDownTimestamp = 0;
129
- let pointerUpTimestamp = 0;
130
- function onPointerDown(e) {
131
- if (!keyboard.isPressingSpace.value) {
132
- e.preventDefault();
133
- e.stopPropagation();
134
- e.stopImmediatePropagation();
135
- }
136
- keyboard.setShortcutStateFromEvent(e);
137
- rootEl.removeEventListener("pointermove", onPointerMove);
138
- if (state.isLoading.value) {
139
- return;
140
- }
141
- rootEl.addEventListener("pointermove", onPointerMove);
142
- if (e.pointerType === "touch") {
143
- return onTouchStart(e);
144
- }
145
- if (selection.isDragging.value) {
146
- return;
147
- }
148
- const coords = { x: e.clientX, y: e.clientY };
149
- if (!e.shiftKey && e.buttons !== 2) {
150
- pointerDownTimestamp = Date.now();
151
- mouseStartCoordinates = coords;
152
- const interacted = getInteractedElement(e);
153
- pointerDownElement = interacted;
154
- if (interacted) {
155
- return;
156
- }
157
- }
158
- eventBus.emit("mouse:down", { ...coords, type: "mouse", distance: 0 });
159
- }
160
- function onPointerUp(e) {
161
- rootEl.removeEventListener("pointermove", onPointerMove);
162
- e.preventDefault();
163
- e.stopPropagation();
164
- e.stopImmediatePropagation();
165
- const wasDragging = selection.isDragging.value;
166
- const wasMultiSelecting = selection.isMultiSelecting.value;
167
- pointerDownElement = null;
168
- if (state.isLoading.value) {
169
- return;
170
- }
171
- if (e.pointerType === "touch") {
172
- return onTouchEnd(e);
173
- }
174
- const coords = getInteractionCoordinates(e);
175
- const distance = mouseStartCoordinates ? getDistance(mouseStartCoordinates, coords) : 0;
176
- eventBus.emit("mouse:up", {
177
- x: e.clientX,
178
- y: e.clientY,
179
- type: "mouse",
180
- distance,
181
- duration: Date.now() - pointerDownTimestamp
182
- });
183
- if (wasDragging || wasMultiSelecting) {
184
- eventBus.emit("dragging:end");
185
- return;
186
- }
187
- if (keyboard.isPressingSpace.value) {
188
- return;
189
- }
190
- if (selection.editableActive.value) {
191
- eventBus.emit("window:clickAway");
192
- lastInteractedElement = null;
193
- return;
194
- }
195
- const clicked = getInteractedElement(e);
196
- if (clicked && pointerUpTimestamp && lastInteractedElement && (clicked.uuid === lastInteractedElement.uuid || clicked.editableFieldName === lastInteractedElement.editableFieldName)) {
197
- const deltaTime = Date.now() - pointerUpTimestamp;
198
- const deltaX = Math.abs(lastInteractedElement.x - e.clientX);
199
- const deltaY = Math.abs(lastInteractedElement.y - e.clientY);
200
- if (deltaTime < 400 && deltaX < 3 && deltaY < 3) {
201
- if (clicked.editableFieldName) {
202
- eventBus.emit("editable:focus", {
203
- fieldName: clicked.editableFieldName,
204
- uuid: clicked.uuid
205
- });
206
- return;
207
- }
208
- if (lastInteractedElement.uuid) {
209
- const block = dom.findBlock(lastInteractedElement.uuid);
210
- if (!block) {
211
- return;
212
- }
213
- eventBus.emit("item:doubleClick", block);
214
- }
215
- }
216
- }
217
- lastInteractedElement = clicked;
218
- pointerUpTimestamp = Date.now();
219
- if (clicked?.uuid) {
220
- dom.refreshBlockRect(clicked.uuid);
221
- if (keyboard.isPressingControl.value || selection.isMultiSelecting.value) {
222
- eventBus.emit("select:toggle", clicked.uuid);
223
- } else if (keyboard.isPressingShift.value) {
224
- eventBus.emit("select:shiftToggle", clicked.uuid);
225
- } else {
226
- eventBus.emit("select", clicked.uuid);
227
- }
228
- return;
229
- }
230
- eventBus.emit("window:clickAway");
231
- }
232
- let longPressTimeout = null;
233
- let touchStartInteraction = null;
234
- let touchStartCoords = null;
235
- let longPressInteraction = null;
236
- let touchStartTimestamp = 0;
237
- function onTouchStart(e) {
238
- if (e.isPrimary) {
239
- touchStartTimestamp = Date.now();
240
- }
241
- longPressInteraction = null;
242
- const coords = getInteractionCoordinates(e);
243
- touchStartCoords = coords;
244
- eventBus.emit("mouse:down", { ...coords, type: "touch", distance: 0 });
245
- if (selection.isDragging.value) {
246
- return;
247
- }
248
- clearTimeout(longPressTimeout);
249
- const interacted = getInteractedElement(e);
250
- if (!interacted?.uuid) {
251
- return;
252
- }
253
- touchStartInteraction = interacted;
254
- longPressTimeout = setTimeout(() => {
255
- if (touchStartInteraction?.uuid) {
256
- longPressInteraction = touchStartInteraction;
257
- if (selection.uuids.value.includes(touchStartInteraction.uuid) && state.editMode.value === "editing") {
258
- eventBus.emit("dragging:start", {
259
- items: [...selection.blocks.value],
260
- coords: {
261
- x: touchStartInteraction.x,
262
- y: touchStartInteraction.y
263
- },
264
- mode: "touch"
265
- });
266
- return;
267
- }
268
- eventBus.emit("select:start", {
269
- uuids: [...selection.uuids.value, touchStartInteraction.uuid],
270
- mode: "touch"
271
- });
272
- }
273
- }, 500);
274
- }
275
- function onTouchMove(e) {
276
- if (!longPressTimeout || !touchStartInteraction) {
277
- return;
278
- }
279
- const coords = getInteractionCoordinates(e);
280
- const deltaX = Math.abs(coords.x - touchStartInteraction.x);
281
- const deltaY = Math.abs(coords.y - touchStartInteraction.y);
282
- if (deltaX > 10 || deltaY > 10) {
283
- clearTimeout(longPressTimeout);
284
- longPressTimeout = null;
285
- }
286
- }
287
- function onTouchEnd(e) {
288
- const wasDragging = selection.isDragging.value;
289
- const coords = getInteractionCoordinates(e);
290
- const distance = touchStartCoords ? getDistance(touchStartCoords, coords) : 0;
291
- if (e.isPrimary) {
292
- eventBus.emit("mouse:up", {
293
- ...coords,
294
- type: "touch",
295
- distance,
296
- duration: Date.now() - touchStartTimestamp
297
- });
298
- }
299
- clearTimeout(longPressTimeout);
300
- longPressTimeout = null;
301
- if (wasDragging) {
302
- return;
303
- }
304
- if (!touchStartCoords) {
305
- return;
306
- }
307
- if (distance > 7) {
308
- return;
309
- }
310
- const interacted = getInteractedElement(e);
311
- if (interacted?.uuid) {
312
- if (longPressInteraction && longPressInteraction.uuid === interacted.uuid) {
313
- return;
314
- }
315
- if (selection.isMultiSelecting.value) {
316
- eventBus.emit("select:toggle", interacted.uuid);
317
- } else {
318
- eventBus.emit("select", interacted.uuid);
319
- }
320
- } else {
321
- eventBus.emit("window:clickAway");
322
- }
323
- longPressInteraction = null;
324
- }
325
- onBlokkliEvent("dragging:start", (e) => {
326
- mouseStartCoordinates = e.coords;
327
- });
328
- function onClick(e) {
329
- e.preventDefault();
330
- e.stopImmediatePropagation();
331
- e.stopPropagation();
332
- }
333
- onMounted(() => {
334
- const providerElement = ui.providerElement();
335
- providerElement.addEventListener("click", onClick, {
336
- capture: true
337
- });
338
- rootEl.addEventListener("click", onClick, {
339
- capture: true
340
- });
341
- rootEl.addEventListener("pointerdown", onPointerDown, {
342
- capture: true
343
- });
344
- rootEl.addEventListener("pointerup", onPointerUp, {
345
- capture: true
346
- });
347
- });
348
- onBeforeUnmount(() => {
349
- const providerElement = ui.providerElement();
350
- providerElement.removeEventListener("click", onClick, {
351
- capture: true
352
- });
353
- rootEl.removeEventListener("click", onClick, {
354
- capture: true
355
- });
356
- rootEl.removeEventListener("pointerdown", onPointerDown, {
357
- capture: true
358
- });
359
- rootEl.removeEventListener("pointermove", onPointerMove);
360
- rootEl.removeEventListener("pointerup", onPointerUp, {
361
- capture: true
362
- });
363
- });
364
- </script>
@@ -1,51 +0,0 @@
1
- <template>
2
- <div v-if="shouldRender" class="bk-command-palette-results-group">
3
- <h2>{{ label }}</h2>
4
- <div>
5
- <button
6
- v-for="item in mapped"
7
- v-show="item.visible"
8
- :key="item.id"
9
- :data-command-id="item.id"
10
- :data-command-visible="item.visible"
11
- class="bk-command"
12
- :class="{ 'bk-is-focused': focusedId === item.id }"
13
- @mouseenter="$emit('focus', item.id)"
14
- @click.prevent="$emit('select', item.id)"
15
- >
16
- <div class="bk-command-icon">
17
- <Icon v-if="item.icon" :name="item.icon" />
18
- <ItemIcon v-else :bundle="item.bundle" />
19
- </div>
20
- <Highlight :text="item.label" tag="span" :positions="item.positions" />
21
- </button>
22
- </div>
23
- </div>
24
- </template>
25
-
26
- <script setup>
27
- import { computed } from "#imports";
28
- import { Icon, ItemIcon, Highlight } from "#blokkli/components";
29
- const props = defineProps({
30
- label: { type: String, required: true },
31
- commands: { type: Array, required: true },
32
- visibleIds: { type: null, required: true },
33
- focusedId: { type: String, required: true }
34
- });
35
- defineEmits(["close", "focus", "select"]);
36
- const mapped = computed(() => {
37
- return props.commands.map((v) => {
38
- const found = props.visibleIds?.find((w) => w.id === v._id);
39
- return {
40
- ...v,
41
- visible: props.visibleIds === void 0 || !!found,
42
- positions: found?.positions
43
- };
44
- }).sort((a, b) => {
45
- const indexA = props.visibleIds?.findIndex((w) => w.id === a._id) || -1;
46
- const indexB = props.visibleIds?.findIndex((w) => w.id === b._id) || -1;
47
- return indexA - indexB;
48
- });
49
- });
50
- const shouldRender = computed(() => mapped.value.some((v) => v.visible));
51
- </script>
@@ -1,22 +0,0 @@
1
- <template>
2
- <div v-show="!selection.isDragging.value" class="bk">
3
- <div
4
- v-for="area in areas"
5
- :key="area.key"
6
- class="bk-field-area"
7
- :style="area.style"
8
- :class="{ 'bk-is-active': area.key === selection.activeFieldKey.value }"
9
- @click="eventBus.emit('setActiveFieldKey', area.key)"
10
- >
11
- <div>
12
- <span>{{ area.label }}</span>
13
- </div>
14
- </div>
15
- </div>
16
- </template>
17
-
18
- <script setup>
19
- import { ref, useBlokkli } from "#imports";
20
- const { eventBus, selection } = useBlokkli();
21
- const areas = ref([]);
22
- </script>
@@ -1,41 +0,0 @@
1
- <template>
2
- <PluginViewOption
3
- id="fieldAreas"
4
- v-slot="{ isActive }"
5
- :label="$t('fieldAreasToggle', 'Toggle block fields')"
6
- :title-on="$t('fieldAreasShow', 'Show block fields')"
7
- :title-off="$t('fieldAreasHide', 'Hide block fields')"
8
- :tour-text="
9
- $t(
10
- 'fieldAreasTourText',
11
- 'Toggle between showing or hiding the areas where blocks can be placed.'
12
- )
13
- "
14
- icon="area"
15
- key-code="I"
16
- >
17
- <Teleport v-if="isActive" to="body">
18
- <Overlay />
19
- </Teleport>
20
- </PluginViewOption>
21
- </template>
22
-
23
- <script setup>
24
- import { useBlokkli, defineBlokkliFeature } from "#imports";
25
- import Overlay from "./Overlay/index.vue";
26
- import { PluginViewOption } from "#blokkli/plugins";
27
- defineBlokkliFeature({
28
- id: "field-areas",
29
- label: "Field Areas",
30
- icon: "area",
31
- description: "Provides a view option to render the field areas with labels.",
32
- viewports: ["desktop"]
33
- });
34
- const { $t } = useBlokkli();
35
- </script>
36
-
37
- <script>
38
- export default {
39
- name: "FieldAreas"
40
- };
41
- </script>
@@ -1,31 +0,0 @@
1
- import { defineNuxtPlugin } from "#imports";
2
- export default defineNuxtPlugin((nuxtApp) => {
3
- nuxtApp.vueApp.directive("blokkli-editable", {
4
- created(el, binding) {
5
- if (import.meta.client) {
6
- if (!window.location.search.includes("blokkliEditing")) {
7
- return;
8
- }
9
- const fieldName = binding.value?.name || binding.arg;
10
- if (!fieldName) {
11
- return;
12
- }
13
- el.dataset.blokkliEditableField = fieldName;
14
- }
15
- }
16
- });
17
- nuxtApp.vueApp.directive("blokkli-droppable", {
18
- created(el, binding) {
19
- if (import.meta.client) {
20
- if (!window.location.search.includes("blokkliEditing")) {
21
- return;
22
- }
23
- const fieldName = binding.value?.name || binding.arg;
24
- if (!fieldName) {
25
- return;
26
- }
27
- el.dataset.blokkliDroppableField = fieldName;
28
- }
29
- }
30
- });
31
- });