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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (428) hide show
  1. package/dist/module.d.mts +1 -1
  2. package/dist/module.json +5 -5
  3. package/dist/module.mjs +5549 -1269
  4. package/dist/modules/drupal/graphql/base/fragment.ParagraphsBlokkliConfigInput.graphql +31 -0
  5. package/dist/modules/drupal/graphql/base/fragment.blokkliProps.graphql +9 -0
  6. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliEditState.graphql +5 -0
  7. package/dist/modules/drupal/graphql/base/fragment.paragraphsFieldItem.graphql +9 -0
  8. package/dist/modules/drupal/graphql/base/query.pbConfig.graphql +1 -10
  9. package/dist/modules/drupal/graphql/base/query.pbEntityConfig.graphql +5 -0
  10. package/dist/modules/drupal/graphql/features/comments.graphql +11 -8
  11. package/dist/modules/drupal/graphql/features/publishNew.graphql +1 -4
  12. package/dist/modules/drupal/graphql/features/scheduler.graphql +31 -0
  13. package/dist/modules/drupal/graphql/features/transform.graphql +9 -1
  14. package/dist/modules/drupal/graphql/features/transform_host.graphql +38 -0
  15. package/dist/modules/drupal/graphql/mutations/set_paragraph_schedule.graphql +15 -0
  16. package/dist/modules/drupal/graphql/mutations/update_host_options.graphql +15 -0
  17. package/dist/modules/drupal/index.d.mts +1 -1
  18. package/dist/modules/drupal/index.mjs +79 -9
  19. package/dist/modules/drupal/runtime/adapter/index.d.ts +3 -0
  20. package/dist/modules/drupal/{adapter/index.mjs → runtime/adapter/index.js} +166 -20
  21. package/dist/runtime/adapter/index.d.ts +111 -1
  22. package/dist/runtime/blokkliPlugins/AddAction/index.vue +27 -3
  23. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue +65 -0
  24. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue.d.ts +26 -0
  25. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue +6 -0
  26. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue +3 -2
  27. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue.d.ts +2 -19
  28. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue.d.ts +2 -7
  29. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue +3 -3
  30. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue.d.ts +2 -19
  31. package/dist/runtime/blokkliPlugins/ItemAction/index.vue +23 -15
  32. package/dist/runtime/blokkliPlugins/ItemAction/index.vue.d.ts +21 -44
  33. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue +49 -11
  34. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue.d.ts +29 -15
  35. package/dist/runtime/blokkliPlugins/MenuButton/index.vue.d.ts +3 -3
  36. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue +6 -7
  37. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue.d.ts +2 -51
  38. package/dist/runtime/blokkliPlugins/Sidebar/index.vue +2 -9
  39. package/dist/runtime/blokkliPlugins/Sidebar/index.vue.d.ts +15 -9
  40. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue.d.ts +1 -1
  41. package/dist/runtime/blokkliPlugins/TourItem/index.vue +10 -5
  42. package/dist/runtime/blokkliPlugins/TourItem/index.vue.d.ts +2 -4
  43. package/dist/runtime/blokkliPlugins/ViewOption/index.vue +6 -3
  44. package/dist/runtime/blokkliPlugins/ViewOption/index.vue.d.ts +4 -3
  45. package/dist/runtime/blokkliPlugins/index.d.ts +8 -7
  46. package/dist/runtime/blokkliPlugins/index.js +15 -13
  47. package/dist/runtime/components/Blocks/Fragment/icon.svg +1 -1
  48. package/dist/runtime/components/Blocks/FromLibrary/index.vue +4 -2
  49. package/dist/runtime/components/BlokkliEditable.vue +34 -16
  50. package/dist/runtime/components/BlokkliEditable.vue.d.ts +2 -1
  51. package/dist/runtime/components/BlokkliField.vue +31 -27
  52. package/dist/runtime/components/BlokkliField.vue.d.ts +61 -17
  53. package/dist/runtime/components/BlokkliItem.vue +2 -2
  54. package/dist/runtime/components/BlokkliItem.vue.d.ts +4 -2
  55. package/dist/runtime/components/BlokkliProvider.vue +60 -45
  56. package/dist/runtime/components/BlokkliProvider.vue.d.ts +45 -7
  57. package/dist/runtime/components/Edit/Actions/index.vue +69 -78
  58. package/dist/runtime/components/Edit/AddListItem/index.vue +2 -5
  59. package/dist/runtime/components/Edit/AddListItem/index.vue.d.ts +1 -1
  60. package/dist/runtime/components/Edit/AddListItemIcon/index.vue +19 -0
  61. package/dist/runtime/components/Edit/AddListItemIcon/index.vue.d.ts +15 -0
  62. package/dist/runtime/components/Edit/AnimationCanvas/index.vue +436 -25
  63. package/dist/runtime/components/Edit/AppMenu/index.vue +5 -5
  64. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue +83 -0
  65. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue.d.ts +32 -0
  66. package/dist/runtime/components/Edit/Banner/index.vue +51 -0
  67. package/dist/runtime/components/Edit/Banner/index.vue.d.ts +18 -0
  68. package/dist/runtime/components/Edit/BlockProxy/index.vue +3 -1
  69. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue.d.ts +2 -13
  70. package/dist/runtime/components/Edit/Dialog/index.vue +14 -5
  71. package/dist/runtime/components/Edit/Dialog/index.vue.d.ts +4 -2
  72. package/dist/runtime/components/Edit/DiffViewer/State.vue +276 -0
  73. package/dist/runtime/components/Edit/DiffViewer/State.vue.d.ts +16 -0
  74. package/dist/runtime/components/Edit/DraggableList.vue +20 -50
  75. package/dist/runtime/components/Edit/DraggableList.vue.d.ts +7 -7
  76. package/dist/runtime/components/Edit/EditIndicator.vue +118 -44
  77. package/dist/runtime/components/Edit/EditIndicator.vue.d.ts +3 -0
  78. package/dist/runtime/components/Edit/EditProvider.vue +192 -80
  79. package/dist/runtime/components/Edit/EditProvider.vue.d.ts +3 -0
  80. package/dist/runtime/components/Edit/Features/AddList/index.vue +24 -36
  81. package/dist/runtime/components/Edit/Features/Analyze/Overlay/fragment.glsl +58 -0
  82. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue +170 -0
  83. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue.d.ts +9 -0
  84. package/dist/runtime/components/Edit/Features/Analyze/Overlay/vertex.glsl +72 -0
  85. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue +159 -0
  86. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue.d.ts +7 -0
  87. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue +100 -0
  88. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue.d.ts +6 -0
  89. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue +56 -0
  90. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue.d.ts +3 -0
  91. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue +87 -0
  92. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue.d.ts +7 -0
  93. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue +105 -0
  94. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue.d.ts +8 -0
  95. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue +18 -0
  96. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue.d.ts +8 -0
  97. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue +92 -0
  98. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue.d.ts +17 -0
  99. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue +77 -0
  100. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue.d.ts +6 -0
  101. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.d.ts +12 -0
  102. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.js +75 -0
  103. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.d.ts +4 -0
  104. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.js +5 -0
  105. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.d.ts +32 -0
  106. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.js +45 -0
  107. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.d.ts +5 -0
  108. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.js +95 -0
  109. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.d.ts +3 -0
  110. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.js +13 -0
  111. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.d.ts +2 -0
  112. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.js +2 -0
  113. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.d.ts +2 -0
  114. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.js +165 -0
  115. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.d.ts +44 -0
  116. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.js +0 -0
  117. package/dist/runtime/components/Edit/Features/Analyze/helper.d.ts +5 -0
  118. package/dist/runtime/components/Edit/Features/Analyze/helper.js +28 -0
  119. package/dist/runtime/components/Edit/Features/Analyze/index.vue +44 -0
  120. package/dist/runtime/components/Edit/Features/Anchors/Renderer.vue +53 -0
  121. package/dist/runtime/components/Edit/Features/Anchors/index.vue +32 -0
  122. package/dist/runtime/components/Edit/Features/Artboard/Overview/index.vue +25 -13
  123. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue +299 -0
  124. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue.d.ts +7 -0
  125. package/dist/runtime/components/Edit/Features/Artboard/index.vue +10 -217
  126. package/dist/runtime/components/Edit/Features/Assistant/index.vue +5 -3
  127. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue +33 -57
  128. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue +154 -0
  129. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue.d.ts +27 -0
  130. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue +222 -0
  131. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue.d.ts +11 -0
  132. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue +96 -0
  133. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue.d.ts +2 -0
  134. package/dist/runtime/components/Edit/Features/Clipboard/index.vue +177 -46
  135. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue +51 -0
  136. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue.d.ts +17 -0
  137. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue +48 -117
  138. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue +5 -2
  139. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue +35 -20
  140. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue.d.ts +5 -3
  141. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue +29 -0
  142. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue.d.ts +13 -0
  143. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue +22 -16
  144. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue.d.ts +1 -0
  145. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue +15 -6
  146. package/dist/runtime/components/Edit/Features/Comments/index.vue +21 -9
  147. package/dist/runtime/components/Edit/Features/Conversions/index.vue +16 -21
  148. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue +26 -35
  149. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue +240 -0
  150. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue.d.ts +6 -0
  151. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue +14 -0
  152. package/dist/runtime/components/Edit/Features/Debug/index.vue +7 -162
  153. package/dist/runtime/components/Edit/Features/Delete/index.vue +1 -1
  154. package/dist/runtime/components/Edit/Features/Diff/DiffView/index.vue +13 -190
  155. package/dist/runtime/components/Edit/Features/Diff/index.vue +2 -2
  156. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue +18 -10
  157. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/fragment.glsl +8 -2
  158. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue +111 -121
  159. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue.d.ts +3 -132
  160. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/vertex.glsl +2 -1
  161. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue +87 -61
  162. package/dist/runtime/components/Edit/Features/Duplicate/index.vue +6 -8
  163. package/dist/runtime/components/Edit/Features/Edit/index.vue +16 -22
  164. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue +3 -3
  165. package/dist/runtime/components/Edit/Features/EditForm/index.vue +10 -9
  166. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue +69 -4
  167. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue.d.ts +2 -2
  168. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue +13 -9
  169. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue +45 -87
  170. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue.d.ts +2 -2
  171. package/dist/runtime/components/Edit/Features/EditableField/index.vue +45 -43
  172. package/dist/runtime/components/Edit/Features/EditableMask/index.vue +3 -20
  173. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue +33 -1
  174. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue +11 -9
  175. package/dist/runtime/components/Edit/Features/Fragments/index.vue +8 -6
  176. package/dist/runtime/components/Edit/Features/History/index.vue +39 -13
  177. package/dist/runtime/components/Edit/Features/Hover/Overlay/fragment.glsl +139 -0
  178. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue +261 -0
  179. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue.d.ts +6 -0
  180. package/dist/runtime/components/Edit/Features/Hover/Overlay/vertex.glsl +117 -0
  181. package/dist/runtime/components/Edit/Features/Hover/index.vue +25 -0
  182. package/dist/runtime/components/Edit/Features/Hover/index.vue.d.ts +2 -0
  183. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue +6 -2
  184. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue +3 -2
  185. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue +5 -7
  186. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue +19 -27
  187. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue +32 -28
  188. package/dist/runtime/components/Edit/Features/Library/index.vue +40 -32
  189. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue +11 -11
  190. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue +15 -12
  191. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/fragment.glsl +1 -1
  192. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue +44 -32
  193. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/vertex.glsl +1 -1
  194. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue +10 -18
  195. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue +3 -2
  196. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue.d.ts +2 -0
  197. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue.d.ts +2 -11
  198. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue +14 -3
  199. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue.d.ts +0 -1
  200. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue +37 -19
  201. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue.d.ts +8 -2
  202. package/dist/runtime/components/Edit/Features/Options/Form/index.vue +88 -42
  203. package/dist/runtime/components/Edit/Features/Options/Form/index.vue.d.ts +5 -5
  204. package/dist/runtime/components/Edit/Features/Options/index.vue +35 -11
  205. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue +35 -0
  206. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue.d.ts +6 -0
  207. package/dist/runtime/components/Edit/Features/Ownership/index.vue +7 -25
  208. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue +3 -3
  209. package/dist/runtime/components/Edit/Features/ProxyView/index.vue +5 -1
  210. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue +41 -14
  211. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue.d.ts +2 -0
  212. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue +47 -0
  213. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue.d.ts +19 -0
  214. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue +83 -0
  215. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue.d.ts +9 -0
  216. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue +439 -123
  217. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue.d.ts +3 -14
  218. package/dist/runtime/components/Edit/Features/Publish/index.vue +57 -24
  219. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue.d.ts +2 -13
  220. package/dist/runtime/components/Edit/Features/Revert/index.vue +3 -3
  221. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue +15 -15
  222. package/dist/runtime/components/Edit/Features/Search/index.vue +7 -3
  223. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Overlay/index.vue +85 -0
  224. package/dist/runtime/components/Edit/Features/{CommandPalette/Palette/Group → Selection/AddButtons/Overlay}/index.vue.d.ts +8 -13
  225. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/fragment.glsl +106 -0
  226. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue +440 -0
  227. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue.d.ts +32 -0
  228. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/vertex.glsl +102 -0
  229. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue +387 -0
  230. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue.d.ts +6 -0
  231. package/dist/runtime/components/Edit/Features/Selection/Overlay/fragment.glsl +15 -10
  232. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue +105 -25
  233. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue.d.ts +5 -3
  234. package/dist/runtime/components/Edit/Features/Selection/Overlay/vertex.glsl +12 -3
  235. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue +2 -2
  236. package/dist/runtime/components/Edit/Features/Selection/index.vue +135 -25
  237. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue +12 -17
  238. package/dist/runtime/components/Edit/Features/Settings/index.vue +11 -25
  239. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue +2 -2
  240. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue +13 -6
  241. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue +5 -1
  242. package/dist/runtime/components/Edit/Features/Theme/index.vue +2 -1
  243. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue +3 -2
  244. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue +3 -0
  245. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue +198 -0
  246. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue.d.ts +13 -0
  247. package/dist/runtime/components/Edit/Features/Transform/index.vue +156 -70
  248. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue +17 -11
  249. package/dist/runtime/components/Edit/Features/Translations/index.vue +20 -23
  250. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue +5 -5
  251. package/dist/runtime/components/Edit/Features/index.vue +17 -7
  252. package/dist/runtime/components/Edit/Form/Datepicker/index.vue +198 -0
  253. package/dist/runtime/components/Edit/Form/Datepicker/index.vue.d.ts +15 -0
  254. package/dist/runtime/components/Edit/Form/Group/index.vue.d.ts +2 -4
  255. package/dist/runtime/components/Edit/Form/Item/index.vue.d.ts +2 -4
  256. package/dist/runtime/components/Edit/Form/Radio/index.vue +33 -0
  257. package/dist/runtime/components/Edit/Form/Radio/index.vue.d.ts +20 -0
  258. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue +37 -0
  259. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue.d.ts +22 -0
  260. package/dist/runtime/components/Edit/Form/Select/index.vue +29 -0
  261. package/dist/runtime/components/Edit/Form/Select/index.vue.d.ts +20 -0
  262. package/dist/runtime/components/Edit/Form/Text/index.vue +34 -0
  263. package/dist/runtime/components/Edit/Form/Text/index.vue.d.ts +20 -0
  264. package/dist/runtime/components/Edit/Form/Textarea/index.vue +13 -6
  265. package/dist/runtime/components/Edit/Form/Textarea/index.vue.d.ts +4 -0
  266. package/dist/runtime/components/Edit/Form/Toggle/index.vue +4 -3
  267. package/dist/runtime/components/Edit/Form/Toggle/index.vue.d.ts +12 -2
  268. package/dist/runtime/components/Edit/FormOverlay/index.vue +1 -1
  269. package/dist/runtime/components/Edit/FormOverlay/index.vue.d.ts +3 -2
  270. package/dist/runtime/components/Edit/Indicators/index.vue +123 -0
  271. package/dist/runtime/components/Edit/Indicators/index.vue.d.ts +2 -0
  272. package/dist/runtime/components/Edit/InfoBox/index.vue +6 -2
  273. package/dist/runtime/components/Edit/InfoBox/index.vue.d.ts +12 -2
  274. package/dist/runtime/components/Edit/ItemIcon/index.vue +2 -1
  275. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue +66 -0
  276. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue.d.ts +7 -0
  277. package/dist/runtime/components/Edit/Konami/Game/blokkli.png +0 -0
  278. package/dist/runtime/components/Edit/Konami/Game/charmap.d.ts +2 -0
  279. package/dist/runtime/components/Edit/Konami/Game/charmap.js +168 -0
  280. package/dist/runtime/components/Edit/Konami/Game/index.vue +752 -0
  281. package/dist/runtime/components/Edit/Konami/Game/index.vue.d.ts +6 -0
  282. package/dist/runtime/components/Edit/Konami/Game/textRendering.d.ts +8 -0
  283. package/dist/runtime/components/Edit/Konami/Game/textRendering.js +138 -0
  284. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.d.ts +9 -0
  285. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.js +130 -0
  286. package/dist/runtime/components/Edit/Konami/index.vue +44 -0
  287. package/dist/runtime/components/Edit/Konami/index.vue.d.ts +2 -0
  288. package/dist/runtime/components/Edit/Loading/index.vue +6 -2
  289. package/dist/runtime/components/Edit/Loading/index.vue.d.ts +2 -0
  290. package/dist/runtime/components/Edit/Messages/index.vue +8 -3
  291. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue +17 -0
  292. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue.d.ts +11 -0
  293. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue +37 -0
  294. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue.d.ts +11 -0
  295. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue +43 -0
  296. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue.d.ts +11 -0
  297. package/dist/runtime/components/Edit/PluginConfigForm/index.vue +57 -0
  298. package/dist/runtime/components/Edit/PluginConfigForm/index.vue.d.ts +16 -0
  299. package/dist/runtime/components/Edit/PreviewProvider.vue +3 -4
  300. package/dist/runtime/components/Edit/RelativeTime/index.vue +3 -2
  301. package/dist/runtime/components/Edit/RelativeTime/index.vue.d.ts +2 -2
  302. package/dist/runtime/components/Edit/Resizable/index.vue.d.ts +1 -1
  303. package/dist/runtime/components/Edit/ScaleToFit/index.vue.d.ts +1 -1
  304. package/dist/runtime/components/Edit/ScheduleDate/index.vue +131 -0
  305. package/dist/runtime/components/Edit/ScheduleDate/index.vue.d.ts +23 -0
  306. package/dist/runtime/components/Edit/ScrollBoundary/index.vue.d.ts +2 -7
  307. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue +11 -3
  308. package/dist/runtime/components/Edit/Sortli/index.vue.d.ts +1 -1
  309. package/dist/runtime/components/Edit/SystemRequirements/index.vue +3 -3
  310. package/dist/runtime/components/Edit/Toolbar/index.vue +3 -2
  311. package/dist/runtime/components/Edit/Transition/Height.vue +95 -0
  312. package/dist/runtime/components/Edit/Transition/Height.vue.d.ts +36 -0
  313. package/dist/runtime/components/Edit/Transition/index.vue +41 -0
  314. package/dist/runtime/components/Edit/Transition/index.vue.d.ts +19 -0
  315. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue.d.ts +2 -7
  316. package/dist/runtime/components/Edit/index.d.ts +28 -15
  317. package/dist/runtime/components/Edit/index.js +54 -28
  318. package/dist/runtime/composables/defineBlokkli.js +16 -3
  319. package/dist/runtime/composables/defineBlokkliFeature.d.ts +4 -7
  320. package/dist/runtime/composables/defineBlokkliFragment.js +8 -1
  321. package/dist/runtime/composables/defineBlokkliProvider.d.ts +11 -0
  322. package/dist/runtime/composables/defineBlokkliProvider.js +46 -0
  323. package/dist/runtime/composables/useBlokkliHelper.d.ts +19 -0
  324. package/dist/runtime/composables/useBlokkliHelper.js +95 -0
  325. package/dist/runtime/constants/index.d.ts +3 -0
  326. package/dist/runtime/constants/index.js +3 -0
  327. package/dist/runtime/css/output.css +1 -1
  328. package/dist/runtime/helpers/addElementClasses.d.ts +2 -0
  329. package/dist/runtime/helpers/addElementClasses.js +24 -0
  330. package/dist/runtime/helpers/animationProvider.d.ts +38 -2
  331. package/dist/runtime/helpers/animationProvider.js +188 -47
  332. package/dist/runtime/helpers/bundles/index.d.ts +1 -0
  333. package/dist/runtime/helpers/bundles/index.js +4 -0
  334. package/dist/runtime/helpers/composables/defineRenderer.d.ts +8 -0
  335. package/dist/runtime/helpers/composables/defineRenderer.js +8 -0
  336. package/dist/runtime/helpers/composables/useBlockRegistration.d.ts +5 -0
  337. package/dist/runtime/helpers/composables/useBlockRegistration.js +23 -0
  338. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.d.ts +1 -1
  339. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.js +3 -2
  340. package/dist/runtime/helpers/composables/useStateBasedCache.d.ts +4 -0
  341. package/dist/runtime/helpers/composables/useStateBasedCache.js +13 -0
  342. package/dist/runtime/helpers/composables/useStickyToolbar.d.ts +23 -0
  343. package/dist/runtime/helpers/composables/useStickyToolbar.js +233 -0
  344. package/dist/runtime/helpers/definitionProvider.d.ts +3 -2
  345. package/dist/runtime/helpers/definitionProvider.js +17 -0
  346. package/dist/runtime/helpers/dom/index.d.ts +60 -0
  347. package/dist/runtime/helpers/dom/index.js +48 -0
  348. package/dist/runtime/helpers/domProvider.d.ts +58 -17
  349. package/dist/runtime/helpers/domProvider.js +320 -245
  350. package/dist/runtime/helpers/dropTargets/index.d.ts +6 -0
  351. package/dist/runtime/helpers/dropTargets/index.js +49 -0
  352. package/dist/runtime/helpers/eventBus.d.ts +1 -1
  353. package/dist/runtime/helpers/eventBus.js +2 -2
  354. package/dist/runtime/helpers/index.d.ts +10 -14
  355. package/dist/runtime/helpers/index.js +58 -121
  356. package/dist/runtime/helpers/indicatorsProvider.d.ts +10 -0
  357. package/dist/runtime/helpers/indicatorsProvider.js +23 -0
  358. package/dist/runtime/helpers/keyboardProvider.d.ts +2 -0
  359. package/dist/runtime/helpers/keyboardProvider.js +17 -1
  360. package/dist/runtime/helpers/pluginProvider.d.ts +10 -0
  361. package/dist/runtime/helpers/pluginProvider.js +33 -0
  362. package/dist/runtime/helpers/providers/blocks.d.ts +10 -0
  363. package/dist/runtime/helpers/providers/blocks.js +91 -0
  364. package/dist/runtime/helpers/providers/directive.d.ts +25 -0
  365. package/dist/runtime/helpers/providers/directive.js +208 -0
  366. package/dist/runtime/helpers/providers/element.d.ts +6 -0
  367. package/dist/runtime/helpers/providers/element.js +35 -0
  368. package/dist/runtime/helpers/providers/fields.d.ts +8 -0
  369. package/dist/runtime/helpers/providers/fields.js +47 -0
  370. package/dist/runtime/helpers/renderCycle.d.ts +1 -0
  371. package/dist/runtime/helpers/renderCycle.js +10 -0
  372. package/dist/runtime/helpers/runtimeHelpers/index.js +15 -12
  373. package/dist/runtime/helpers/selectionProvider.d.ts +27 -11
  374. package/dist/runtime/helpers/selectionProvider.js +79 -74
  375. package/dist/runtime/helpers/stateProvider.d.ts +12 -2
  376. package/dist/runtime/helpers/stateProvider.js +164 -20
  377. package/dist/runtime/helpers/storageProvider.d.ts +5 -3
  378. package/dist/runtime/helpers/storageProvider.js +61 -4
  379. package/dist/runtime/helpers/symbols.d.ts +2 -0
  380. package/dist/runtime/helpers/symbols.js +2 -0
  381. package/dist/runtime/helpers/textProvider.js +6 -0
  382. package/dist/runtime/helpers/themeProvider.d.ts +4 -1
  383. package/dist/runtime/helpers/themeProvider.js +28 -15
  384. package/dist/runtime/helpers/transform.js +1 -3
  385. package/dist/runtime/helpers/typesProvider.js +10 -26
  386. package/dist/runtime/helpers/uiProvider.d.ts +18 -3
  387. package/dist/runtime/helpers/uiProvider.js +114 -61
  388. package/dist/runtime/helpers/useTransitionedValue.d.ts +18 -0
  389. package/dist/runtime/helpers/useTransitionedValue.js +57 -0
  390. package/dist/runtime/helpers/webgl/index.d.ts +11 -2
  391. package/dist/runtime/helpers/webgl/index.js +162 -7
  392. package/dist/runtime/icons/anchor.svg +1 -0
  393. package/dist/runtime/icons/arrow-left.svg +1 -1
  394. package/dist/runtime/icons/arrow-right.svg +1 -1
  395. package/dist/runtime/icons/arrow-top-right.svg +1 -0
  396. package/dist/runtime/icons/calendar-clock.svg +1 -0
  397. package/dist/runtime/icons/calendar.svg +1 -0
  398. package/dist/runtime/icons/chart.svg +1 -0
  399. package/dist/runtime/icons/clock.svg +1 -0
  400. package/dist/runtime/icons/comment_add.svg +1 -5
  401. package/dist/runtime/icons/copy.svg +1 -0
  402. package/dist/runtime/icons/cursor-move.svg +1 -1
  403. package/dist/runtime/icons/delete.svg +1 -8
  404. package/dist/runtime/icons/diff.svg +1 -1
  405. package/dist/runtime/icons/duplicate.svg +1 -12
  406. package/dist/runtime/icons/edit.svg +1 -8
  407. package/dist/runtime/icons/eye-off.svg +1 -0
  408. package/dist/runtime/icons/eye.svg +1 -1
  409. package/dist/runtime/icons/info.svg +1 -1
  410. package/dist/runtime/icons/link.svg +1 -0
  411. package/dist/runtime/icons/reusable.svg +1 -5
  412. package/dist/runtime/icons/speedometer.svg +1 -0
  413. package/dist/runtime/plugins/blokkliDirectives.js +109 -0
  414. package/dist/runtime/types/blokkOptions.d.ts +8 -0
  415. package/dist/runtime/types/index.d.ts +278 -42
  416. package/dist/runtime/types/theme.d.ts +2 -1
  417. package/dist/shared/{editor.gz_ac6uT.d.mts → editor.CKsrTpc1.d.mts} +1 -1
  418. package/package.json +55 -38
  419. package/dist/modules/drupal/adapter/index.d.mts +0 -6
  420. package/dist/runtime/components/Edit/DragInteractions/index.vue +0 -364
  421. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue +0 -51
  422. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue +0 -22
  423. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue +0 -41
  424. package/dist/runtime/plugins/blokkliEditable.js +0 -31
  425. /package/dist/runtime/components/Edit/{DragInteractions → Features/Analyze}/index.vue.d.ts +0 -0
  426. /package/dist/runtime/components/Edit/Features/{FieldAreas/Overlay/index.vue.d.ts → Anchors/Renderer.vue.d.ts} +0 -0
  427. /package/dist/runtime/components/Edit/Features/{FieldAreas → Anchors}/index.vue.d.ts +0 -0
  428. /package/dist/runtime/plugins/{blokkliEditable.d.ts → blokkliDirectives.d.ts} +0 -0
@@ -0,0 +1,440 @@
1
+ <template>
2
+ <Teleport to="#bk-canvas-overlay">
3
+ <div
4
+ class="bk bk-add-button-tooltip"
5
+ :class="{ 'bk-is-field': tooltipData?.isField }"
6
+ :style="{
7
+ position: 'fixed',
8
+ left: (tooltipData?.x ?? 0) + 'px',
9
+ top: (tooltipData?.y ?? 0) + 'px',
10
+ transform: tooltipData?.transform ?? 'translate(0, 0)',
11
+ visibility: tooltipData ? 'visible' : 'hidden'
12
+ }"
13
+ >
14
+ {{ tooltipData?.text ?? "" }}
15
+ </div>
16
+ </Teleport>
17
+ </template>
18
+
19
+ <script setup>
20
+ import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
21
+ import defineRenderer from "#blokkli/helpers/composables/defineRenderer";
22
+ import { useBlokkli, computed, ref } from "#imports";
23
+ import { setBuffersAndAttributes, drawBufferInfo, setUniforms } from "twgl.js";
24
+ import vs from "./vertex.glsl?raw";
25
+ import fs from "./fragment.glsl?raw";
26
+ import { RectangleBufferCollector } from "#blokkli/helpers/webgl";
27
+ import { toShaderColor, getFieldKey } from "#blokkli/helpers";
28
+ import {
29
+ getChildrenOrientation,
30
+ determineCanAddChildren
31
+ } from "#blokkli/helpers/dropTargets";
32
+ import { isInternalBundle } from "#blokkli/helpers/bundles";
33
+ import { itemEntityType } from "#blokkli-build/config";
34
+ const {
35
+ animation,
36
+ theme,
37
+ dom,
38
+ selection,
39
+ state,
40
+ types,
41
+ ui,
42
+ $t,
43
+ blocks,
44
+ fields
45
+ } = useBlokkli();
46
+ const emptyFieldTooltips = ref([]);
47
+ const currentUuid = ref("");
48
+ const currentBundleLabel = ref("");
49
+ const currentSingleAllowedBundleLabel = ref(null);
50
+ const tooltipData = computed(() => {
51
+ if (hoveredCircle.value < 0) {
52
+ return null;
53
+ }
54
+ const index = hoveredCircle.value;
55
+ const artboardX = circlePositions[index * 2];
56
+ const artboardY = circlePositions[index * 2 + 1];
57
+ if (artboardX === void 0 || artboardY === void 0) {
58
+ return null;
59
+ }
60
+ const scale = ui.artboardScale.value;
61
+ const offset = ui.artboardOffset.value;
62
+ const screenX = artboardX * scale + offset.x;
63
+ const screenY = artboardY * scale + offset.y;
64
+ let transform;
65
+ let position;
66
+ let text;
67
+ let isField = false;
68
+ if (index === 0 || index === 1) {
69
+ const orientation = currentOrientation.value;
70
+ if (currentSingleAllowedBundleLabel.value) {
71
+ if (index === 0) {
72
+ text = $t("addButtonBundleBefore", 'Add "@bundle" before').replace(
73
+ "@bundle",
74
+ currentSingleAllowedBundleLabel.value
75
+ );
76
+ } else {
77
+ text = $t("addButtonBundleAfter", 'Add "@bundle" after').replace(
78
+ "@bundle",
79
+ currentSingleAllowedBundleLabel.value
80
+ );
81
+ }
82
+ } else {
83
+ if (index === 0) {
84
+ text = $t("addButtonBeforeBundle", "Add before...");
85
+ } else {
86
+ text = $t("addButtonAfterBundle", "Add after...");
87
+ }
88
+ }
89
+ if (orientation === "horizontal") {
90
+ if (index === 0) {
91
+ transform = `translate(${TOOLTIP_MARGIN}px, -50%)`;
92
+ position = "right";
93
+ } else {
94
+ transform = `translate(calc(-100% - ${TOOLTIP_MARGIN}px), -50%)`;
95
+ position = "left";
96
+ }
97
+ } else {
98
+ if (index === 0) {
99
+ transform = `translate(-50%, ${TOOLTIP_MARGIN}px)`;
100
+ position = "bottom";
101
+ } else {
102
+ transform = `translate(-50%, calc(-100% - ${TOOLTIP_MARGIN}px))`;
103
+ position = "top";
104
+ }
105
+ }
106
+ } else {
107
+ transform = `translate(-50%, calc(-100% - ${TOOLTIP_MARGIN}px))`;
108
+ position = "top";
109
+ isField = true;
110
+ const fieldIndex = index - 2;
111
+ text = emptyFieldTooltips.value[fieldIndex] || "Add to field";
112
+ }
113
+ return { x: screenX, y: screenY, transform, position, text, isField };
114
+ });
115
+ const emit = defineEmits(["toggle", "toggleField"]);
116
+ const gl = animation.gl();
117
+ const programInfo = gl ? animation.registerProgram("add-buttons", gl, [vs, fs]) : null;
118
+ const MAX_CIRCLES = 10;
119
+ const BUTTON_RADIUS = 12;
120
+ const TOOLTIP_MARGIN = 20;
121
+ let bufferInfo = null;
122
+ if (gl) {
123
+ class CircleBufferCollector extends RectangleBufferCollector {
124
+ }
125
+ const collector = new CircleBufferCollector(gl);
126
+ for (let i = 0; i < MAX_CIRCLES; i++) {
127
+ collector.addRectangle(
128
+ {
129
+ id: `circle-${i}`,
130
+ x: 0,
131
+ y: 0,
132
+ width: 40,
133
+ height: 40
134
+ },
135
+ i
136
+ );
137
+ }
138
+ bufferInfo = collector.createBufferInfo();
139
+ }
140
+ const circlePositions = new Float32Array(MAX_CIRCLES * 2);
141
+ const circleVisible = new Float32Array(MAX_CIRCLES);
142
+ const hoveredCircle = ref(-1);
143
+ const color = computed(() => {
144
+ return toShaderColor(theme.accent.value[600]);
145
+ });
146
+ const colorHover = computed(() => {
147
+ return toShaderColor(theme.accent.value[500]);
148
+ });
149
+ const colorField = computed(() => {
150
+ return toShaderColor(theme.accent.value[400]);
151
+ });
152
+ const colorFieldHover = computed(() => {
153
+ return toShaderColor(theme.accent.value[300]);
154
+ });
155
+ const orientationCache = /* @__PURE__ */ new Map();
156
+ const currentOrientation = ref("horizontal");
157
+ const blockStateCache = /* @__PURE__ */ new Map();
158
+ function getOrientationForUuid(uuid) {
159
+ let cached = orientationCache.get(uuid);
160
+ if (!cached) {
161
+ const item = blocks.getBlock(uuid);
162
+ if (item) {
163
+ const field = fields.find(item.host.uuid, item.host.fieldName);
164
+ if (field) {
165
+ cached = getChildrenOrientation(field.element);
166
+ orientationCache.set(uuid, cached);
167
+ }
168
+ }
169
+ }
170
+ return cached || "horizontal";
171
+ }
172
+ function getBlockState(uuid) {
173
+ let cached = blockStateCache.get(uuid);
174
+ if (!cached) {
175
+ let canShowBeforeAfter = false;
176
+ let singleAllowedBundleLabel = null;
177
+ const block = blocks.getBlock(uuid);
178
+ if (!block) {
179
+ return {
180
+ canShowBeforeAfter: false,
181
+ emptyFieldKeys: [],
182
+ emptyFieldTooltips: [],
183
+ bundleLabel: "",
184
+ singleAllowedBundleLabel: null
185
+ };
186
+ }
187
+ if (block) {
188
+ const field = fields.find(block.host.uuid, block.host.fieldName);
189
+ if (!field) {
190
+ return {
191
+ canShowBeforeAfter: false,
192
+ emptyFieldKeys: [],
193
+ emptyFieldTooltips: [],
194
+ bundleLabel: "",
195
+ singleAllowedBundleLabel: null
196
+ };
197
+ }
198
+ if (field) {
199
+ const fieldChildren = [...field.element.children];
200
+ const currentCount = state.getFieldBlockCount(field.key);
201
+ canShowBeforeAfter = determineCanAddChildren(
202
+ field,
203
+ fieldChildren,
204
+ [],
205
+ // Not moving any blocks, adding a new one
206
+ currentCount,
207
+ 1,
208
+ // Adding 1 new block
209
+ []
210
+ // Don't know which bundle will be added
211
+ );
212
+ const allowedBundles = field.allowedBundles.filter(
213
+ (bundle) => !isInternalBundle(bundle)
214
+ );
215
+ if (allowedBundles.length === 1) {
216
+ const bundle = allowedBundles[0];
217
+ if (bundle) {
218
+ singleAllowedBundleLabel = types.getBlockBundleDefinition(bundle)?.label || bundle;
219
+ }
220
+ }
221
+ }
222
+ }
223
+ const bundleLabel = block ? types.getBlockBundleDefinition(block.bundle)?.label || block.bundle : "";
224
+ const emptyFieldKeys = [];
225
+ const emptyFieldTooltips2 = [];
226
+ if (block) {
227
+ const fieldConfigs = types.fieldConfig.forEntityTypeAndBundle(
228
+ itemEntityType,
229
+ block.bundle
230
+ );
231
+ for (const fieldConfig of fieldConfigs) {
232
+ const key = getFieldKey(uuid, fieldConfig.name);
233
+ const count = state.getFieldBlockCount(key);
234
+ if (count === 0) {
235
+ emptyFieldKeys.push(key);
236
+ const fieldLabel = fieldConfig.label || fieldConfig.name;
237
+ const fieldElement = fields.find(uuid, fieldConfig.name);
238
+ if (fieldElement) {
239
+ const allowedBundles = fieldElement.allowedBundles.filter(
240
+ (bundle) => !isInternalBundle(bundle)
241
+ );
242
+ if (allowedBundles.length === 1) {
243
+ const bundle = allowedBundles[0];
244
+ if (bundle) {
245
+ const singleBundleLabel = types.getBlockBundleDefinition(bundle)?.label || bundle;
246
+ const tooltip = $t(
247
+ "addButtonBundleInsideField",
248
+ 'Add "@bundle" inside @parentBundle \xBB @fieldLabel'
249
+ ).replace("@bundle", singleBundleLabel).replace("@parentBundle", bundleLabel).replace("@fieldLabel", fieldLabel);
250
+ emptyFieldTooltips2.push(tooltip);
251
+ } else {
252
+ emptyFieldTooltips2.push(
253
+ $t(
254
+ "addButtonInsideField",
255
+ "Add inside @parentBundle \xBB @fieldLabel..."
256
+ ).replace("@parentBundle", bundleLabel).replace("@fieldLabel", fieldLabel)
257
+ );
258
+ }
259
+ } else {
260
+ emptyFieldTooltips2.push(
261
+ $t(
262
+ "addButtonInsideField",
263
+ "Add inside @parentBundle \xBB @fieldLabel..."
264
+ ).replace("@parentBundle", bundleLabel).replace("@fieldLabel", fieldLabel)
265
+ );
266
+ }
267
+ } else {
268
+ emptyFieldTooltips2.push(
269
+ $t(
270
+ "addButtonInsideField",
271
+ "Add inside @parentBundle \xBB @fieldLabel..."
272
+ ).replace("@parentBundle", bundleLabel).replace("@fieldLabel", fieldLabel)
273
+ );
274
+ }
275
+ }
276
+ }
277
+ }
278
+ cached = {
279
+ canShowBeforeAfter,
280
+ emptyFieldKeys,
281
+ emptyFieldTooltips: emptyFieldTooltips2,
282
+ bundleLabel,
283
+ singleAllowedBundleLabel
284
+ };
285
+ blockStateCache.set(uuid, cached);
286
+ }
287
+ return cached;
288
+ }
289
+ onBlokkliEvent("state:reloaded", () => {
290
+ orientationCache.clear();
291
+ blockStateCache.clear();
292
+ });
293
+ function getCircleAtPoint(x, y) {
294
+ if (ui.artboardScale.value <= 0.4) {
295
+ return -1;
296
+ }
297
+ const effectiveScale = Math.max(ui.artboardScale.value, 0.5);
298
+ const radius = BUTTON_RADIUS / effectiveScale;
299
+ for (let i = 0; i < MAX_CIRCLES; i++) {
300
+ if (circleVisible[i] > 0) {
301
+ const cx = circlePositions[i * 2];
302
+ const cy = circlePositions[i * 2 + 1];
303
+ const dx = x - cx;
304
+ const dy = y - cy;
305
+ const distance = Math.sqrt(dx * dx + dy * dy);
306
+ if (distance <= radius) {
307
+ return i;
308
+ }
309
+ }
310
+ }
311
+ return -1;
312
+ }
313
+ if (gl && programInfo && bufferInfo) {
314
+ defineRenderer("add-buttons", {
315
+ zIndex: 1e3,
316
+ enabled: () => {
317
+ if (selection.uuids.value.length !== 1) {
318
+ return false;
319
+ }
320
+ if (ui.openTooltip.value && ui.openTooltip.value !== "add-buttons") {
321
+ return false;
322
+ }
323
+ if (ui.hasTransformOverlayOpen.value) {
324
+ return false;
325
+ }
326
+ return true;
327
+ },
328
+ cursor: () => hoveredCircle.value >= 0 ? "pointer" : null,
329
+ onClick: ({ mouseArtboard }) => {
330
+ if (selection.uuids.value.length !== 1) {
331
+ return false;
332
+ }
333
+ const clickedCircle = getCircleAtPoint(mouseArtboard.x, mouseArtboard.y);
334
+ if (clickedCircle >= 0) {
335
+ const cx = circlePositions[clickedCircle * 2];
336
+ const cy = circlePositions[clickedCircle * 2 + 1];
337
+ if (clickedCircle === 0 || clickedCircle === 1) {
338
+ const position = clickedCircle === 0 ? "before" : "after";
339
+ emit("toggle", {
340
+ position,
341
+ coordinates: { x: cx, y: cy }
342
+ });
343
+ } else {
344
+ const fieldIndex = clickedCircle - 2;
345
+ emit("toggleField", {
346
+ index: fieldIndex,
347
+ coordinates: { x: cx, y: cy }
348
+ });
349
+ }
350
+ return true;
351
+ }
352
+ return false;
353
+ },
354
+ render: (ctx) => {
355
+ if (selection.isChangingOptions.value) {
356
+ return;
357
+ }
358
+ circleVisible.fill(0);
359
+ if (ctx.selectedUuids.length !== 1) {
360
+ return;
361
+ }
362
+ const uuid = ctx.selectedUuids[0];
363
+ if (!uuid) {
364
+ return;
365
+ }
366
+ const blockState = getBlockState(uuid);
367
+ if (blockState.canShowBeforeAfter) {
368
+ const blockRect = dom.getBlockRect(uuid);
369
+ if (!blockRect || blockRect.width === 0) {
370
+ return;
371
+ }
372
+ const orientation = getOrientationForUuid(uuid);
373
+ currentOrientation.value = orientation;
374
+ const BUTTON_SHIFT = 2 / ctx.artboardScale;
375
+ if (orientation === "horizontal") {
376
+ circlePositions[0] = blockRect.x - BUTTON_SHIFT;
377
+ circlePositions[1] = blockRect.y + blockRect.height / 2;
378
+ circleVisible[0] = 1;
379
+ circlePositions[2] = blockRect.x + blockRect.width + BUTTON_SHIFT;
380
+ circlePositions[3] = blockRect.y + blockRect.height / 2;
381
+ circleVisible[1] = 1;
382
+ } else {
383
+ circlePositions[0] = blockRect.x + blockRect.width / 2;
384
+ circlePositions[1] = blockRect.y - BUTTON_SHIFT;
385
+ circleVisible[0] = 1;
386
+ circlePositions[2] = blockRect.x + blockRect.width / 2;
387
+ circlePositions[3] = blockRect.y + blockRect.height + BUTTON_SHIFT;
388
+ circleVisible[1] = 1;
389
+ }
390
+ }
391
+ currentUuid.value = uuid;
392
+ currentBundleLabel.value = blockState.bundleLabel;
393
+ currentSingleAllowedBundleLabel.value = blockState.singleAllowedBundleLabel;
394
+ if (blockState.emptyFieldKeys.length > 0) {
395
+ emptyFieldTooltips.value = blockState.emptyFieldTooltips;
396
+ for (let i = 0; i < blockState.emptyFieldKeys.length && i < 8; i++) {
397
+ const fieldKey = blockState.emptyFieldKeys[i];
398
+ if (!fieldKey) {
399
+ continue;
400
+ }
401
+ const fieldRect = dom.getFieldRect(fieldKey);
402
+ if (!fieldRect) {
403
+ continue;
404
+ }
405
+ const circleIndex = i + 2;
406
+ circlePositions[circleIndex * 2] = fieldRect.x + fieldRect.width / 2;
407
+ circlePositions[circleIndex * 2 + 1] = fieldRect.y + fieldRect.height / 2;
408
+ circleVisible[circleIndex] = 1;
409
+ }
410
+ } else {
411
+ emptyFieldTooltips.value = [];
412
+ }
413
+ hoveredCircle.value = getCircleAtPoint(
414
+ ctx.mouseArtboard.x,
415
+ ctx.mouseArtboard.y
416
+ );
417
+ gl.useProgram(programInfo.program);
418
+ setUniforms(programInfo, {
419
+ u_circle_positions: circlePositions,
420
+ u_circle_visible: circleVisible,
421
+ u_color: color.value,
422
+ u_color_hover: colorHover.value,
423
+ u_color_field: colorField.value,
424
+ u_color_field_hover: colorFieldHover.value,
425
+ u_hovered_circle: hoveredCircle.value,
426
+ u_radius: BUTTON_RADIUS
427
+ });
428
+ animation.setSharedUniforms(gl, programInfo);
429
+ setBuffersAndAttributes(gl, programInfo, bufferInfo);
430
+ drawBufferInfo(gl, bufferInfo, gl.TRIANGLES);
431
+ }
432
+ });
433
+ }
434
+ </script>
435
+
436
+ <script>
437
+ export default {
438
+ name: "AddButtonsRenderer"
439
+ };
440
+ </script>
@@ -0,0 +1,32 @@
1
+ declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
2
+ toggle: (data: {
3
+ position: "before" | "after";
4
+ coordinates: {
5
+ x: number;
6
+ y: number;
7
+ };
8
+ }) => any;
9
+ toggleField: (data: {
10
+ index: number;
11
+ coordinates: {
12
+ x: number;
13
+ y: number;
14
+ };
15
+ }) => any;
16
+ }, string, import("vue").PublicProps, Readonly<{}> & Readonly<{
17
+ onToggle?: ((data: {
18
+ position: "before" | "after";
19
+ coordinates: {
20
+ x: number;
21
+ y: number;
22
+ };
23
+ }) => any) | undefined;
24
+ onToggleField?: ((data: {
25
+ index: number;
26
+ coordinates: {
27
+ x: number;
28
+ y: number;
29
+ };
30
+ }) => any) | undefined;
31
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
32
+ export default _default;
@@ -0,0 +1,102 @@
1
+ precision highp float;
2
+
3
+ // [x, y] position.
4
+ attribute vec2 a_position;
5
+ // The [x,y,width, height] of the quad the vertex belongs to.
6
+ attribute vec4 a_quad;
7
+ attribute float a_rect_id;
8
+
9
+ // The global scaling applied to all quads.
10
+ uniform float u_scale;
11
+ uniform float u_dpi;
12
+ // The amount of pixels to offset on the x axis.
13
+ uniform float u_offset_x;
14
+ // The amount of pixels to offset on the y axis.
15
+ uniform float u_offset_y;
16
+ uniform vec2 u_resolution;
17
+
18
+ // Circle positions (10 vec2s = 20 floats)
19
+ uniform vec2 u_circle_positions[10];
20
+ // Circle visibility (10 floats)
21
+ uniform float u_circle_visible[10];
22
+ // Hovered circle index (-1 for none)
23
+ uniform float u_hovered_circle;
24
+ // Button radius in pixels
25
+ uniform float u_radius;
26
+
27
+ // The transformed quad for the fragment shader.
28
+ varying vec4 v_quad;
29
+ varying vec2 v_circle_center;
30
+ varying float v_visible;
31
+ varying float v_is_hovered;
32
+ varying float v_scale_fade;
33
+ varying float v_rect_id;
34
+
35
+ void main() {
36
+ int rectId = int(a_rect_id);
37
+
38
+ // Get circle position and visibility for this rect
39
+ vec2 circlePos = u_circle_positions[rectId];
40
+ v_visible = u_circle_visible[rectId];
41
+ v_is_hovered = float(rectId) == u_hovered_circle ? 1.0 : 0.0;
42
+ v_rect_id = a_rect_id;
43
+
44
+ // Calculate fade factor based on scale (fade from 1.0 at 0.5 to 0.0 at 0.4)
45
+ v_scale_fade = 1.0;
46
+ if (u_scale < 0.5) {
47
+ // Interpolate from 1.0 (at scale 0.5) to 0.0 (at scale 0.4)
48
+ v_scale_fade = (u_scale - 0.4) / (0.5 - 0.4);
49
+ v_scale_fade = clamp(v_scale_fade, 0.0, 1.0);
50
+ }
51
+
52
+ // Border width in pixels (must match fragment shader)
53
+ float borderWidth = 4.0;
54
+
55
+ // Circle radius in artboard space - apply inverse scaling to keep constant size
56
+ // Then multiply by fade factor
57
+ // Add border width to the radius so the border renders outside
58
+ float radius = (u_radius + borderWidth) / u_scale * v_scale_fade;
59
+
60
+ // Calculate quad bounds centered on circle position
61
+ float left = circlePos.x - radius;
62
+ float top = circlePos.y - radius;
63
+ float width = radius * 2.0;
64
+ float height = radius * 2.0;
65
+
66
+ // Determine which corner of the quad this vertex represents
67
+ // Normalize position within the dummy quad (0.0 to 1.0)
68
+ vec2 quadCorner = vec2(
69
+ (a_position.x - a_quad.x) / a_quad.z,
70
+ (a_position.y - a_quad.y) / a_quad.w
71
+ );
72
+
73
+ // Calculate actual vertex position in artboard space
74
+ vec2 vertexPos = vec2(
75
+ left + quadCorner.x * width,
76
+ top + quadCorner.y * height
77
+ );
78
+
79
+ // Apply global scale and offsets
80
+ vec2 offsetPosition = vertexPos * u_scale;
81
+ offsetPosition.x += u_offset_x;
82
+ offsetPosition.y += u_offset_y;
83
+
84
+ // Normalize position for rendering
85
+ vec2 normalizedPosition = offsetPosition / u_resolution;
86
+
87
+ // Transform to screen space (-1 to 1)
88
+ vec2 screenSpacePosition = normalizedPosition * 2.0 - vec2(1.0, 1.0);
89
+ screenSpacePosition.y = -screenSpacePosition.y;
90
+
91
+ // Output final position in clip space
92
+ gl_Position = vec4(screenSpacePosition, 0.0, 1.0) * u_dpi;
93
+
94
+ // Calculate transformed quad for fragment shader
95
+ v_quad = vec4(
96
+ (left * u_scale + u_offset_x) * u_dpi,
97
+ (u_resolution.y - top * u_scale - height * u_scale - u_offset_y) * u_dpi,
98
+ width * u_scale * u_dpi,
99
+ height * u_scale * u_dpi
100
+ );
101
+ v_circle_center = vec2(v_quad.x + v_quad.z / 2.0, v_quad.y + v_quad.w / 2.0);
102
+ }