@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
@@ -50,13 +50,12 @@ import {
50
50
  ref,
51
51
  computed,
52
52
  useBlokkli,
53
- onMounted,
54
- onBeforeUnmount,
55
53
  nextTick,
56
54
  defineBlokkliFeature
57
55
  } from "#imports";
58
56
  import { Sortli } from "#blokkli/components";
59
57
  import { PluginSidebar, PluginTourItem } from "#blokkli/plugins";
58
+ import { addElementClasses } from "#blokkli/helpers/addElementClasses";
60
59
  const { settings } = defineBlokkliFeature({
61
60
  id: "add-list",
62
61
  icon: "plus",
@@ -87,21 +86,17 @@ const { settings } = defineBlokkliFeature({
87
86
  },
88
87
  screenshot: "feature-add-list.jpg"
89
88
  });
90
- const { state, $t, eventBus, ui } = useBlokkli();
89
+ const { state, $t, eventBus, ui, element } = useBlokkli();
91
90
  const hasContextMenuOpen = computed(
92
91
  () => ui.openContextMenu.value.startsWith("add_list_item_")
93
92
  );
94
93
  const isSidebar = computed(() => ui.addListOrientation.value === "sidebar");
95
94
  const shouldRender = computed(() => state.editMode.value === "editing");
96
95
  watch(ui.addListOrientation, () => {
97
- setRootClasses();
98
96
  nextTick(() => {
99
97
  eventBus.emit("add-list:change");
100
98
  });
101
99
  });
102
- watch(shouldRender, () => {
103
- setRootClasses();
104
- });
105
100
  const CLASS_LEFT = "bk-has-add-list-left";
106
101
  const CLASS_BOTTOM = "bk-has-add-list-bottom";
107
102
  const wrapper = ref(null);
@@ -109,17 +104,15 @@ const isActive = ref(false);
109
104
  let mouseTimeout = null;
110
105
  const style = computed(() => {
111
106
  if (settings.value.orientation === "vertical" && (isActive.value || hasContextMenuOpen.value) && wrapper.value) {
112
- const labels = [
113
- ...wrapper.value.querySelectorAll(".bk-list-item-label span")
114
- ];
115
- const width = labels.reduce((acc, el) => {
116
- if (el.offsetWidth > acc) {
117
- return el.offsetWidth;
118
- }
119
- return acc;
120
- }, 0);
107
+ const widths = element.queryAll(
108
+ wrapper.value,
109
+ ".bk-list-item-label span",
110
+ "AddList vertical sidebar style",
111
+ (el) => el.offsetWidth
112
+ );
113
+ const largestWidth = Math.max(...widths);
121
114
  return {
122
- "--bk-add-list-width": width + 90
115
+ "--bk-add-list-width": largestWidth + 90
123
116
  };
124
117
  }
125
118
  return void 0;
@@ -146,18 +139,6 @@ const onWheel = (e) => {
146
139
  e.stopPropagation();
147
140
  }
148
141
  };
149
- function setRootClasses() {
150
- document.documentElement.classList.remove(CLASS_BOTTOM);
151
- document.documentElement.classList.remove(CLASS_LEFT);
152
- if (!shouldRender.value) {
153
- return;
154
- }
155
- if (ui.addListOrientation.value === "horizontal") {
156
- document.documentElement.classList.add(CLASS_BOTTOM);
157
- } else if (ui.addListOrientation.value === "vertical") {
158
- document.documentElement.classList.add(CLASS_LEFT);
159
- }
160
- }
161
142
  const sidebarTitle = computed(() => $t("addListSidebarTitle", "Add blocks"));
162
143
  const tourText = computed(
163
144
  () => $t(
@@ -165,13 +146,20 @@ const tourText = computed(
165
146
  "<p>This shows the list of available blocks that can be placed. Add a block by dragging the icon into the page.</p><p>When an existing block is selected, some blocks may be greyed out. This indicates which blocks can be placed inside or after the selected block.</p>"
166
147
  )
167
148
  );
168
- onMounted(() => {
169
- setRootClasses();
170
- });
171
- onBeforeUnmount(() => {
172
- document.documentElement.classList.remove(CLASS_BOTTOM);
173
- document.documentElement.classList.remove(CLASS_LEFT);
174
- });
149
+ addElementClasses(
150
+ document.documentElement,
151
+ CLASS_BOTTOM,
152
+ computed(
153
+ () => ui.addListOrientation.value === "horizontal" && shouldRender.value
154
+ )
155
+ );
156
+ addElementClasses(
157
+ document.documentElement,
158
+ CLASS_LEFT,
159
+ computed(
160
+ () => ui.addListOrientation.value === "vertical" && shouldRender.value
161
+ )
162
+ );
175
163
  </script>
176
164
 
177
165
  <script>
@@ -0,0 +1,58 @@
1
+ precision highp float;
2
+
3
+ varying vec4 v_quad;
4
+ varying float v_rect_type;
5
+ varying vec3 v_color;
6
+ varying vec2 v_rect_size;
7
+ varying vec2 v_rect_center;
8
+
9
+ uniform float u_dpi;
10
+
11
+ int pseudoQuadrant(vec2 p) {
12
+ return int(floor(step(0.0, p.x) + 2.0 * step(0.0, -p.y)));
13
+ }
14
+
15
+ float sdRoundBox(vec2 p, vec2 b, vec4 radii) {
16
+ int idx = pseudoQuadrant(p);
17
+ float cr;
18
+ if (idx == 0) cr = radii[0];
19
+ else if (idx == 1) cr = radii[1];
20
+ else if (idx == 2) cr = radii[3];
21
+ else cr = radii[2];
22
+ vec2 q = abs(p) - b + cr;
23
+ return min(max(q.x, q.y), 0.0) + length(max(q, 0.0)) - cr;
24
+ }
25
+
26
+ void main() {
27
+ float borderThickness = 2.0 * u_dpi;
28
+ vec2 size = v_rect_size;
29
+ vec4 radius = vec4(0.0); // No rounded corners for now
30
+
31
+ vec2 posRelativeToQuad = gl_FragCoord.xy - v_rect_center;
32
+
33
+ float mainDist = sdRoundBox(posRelativeToQuad, size / 2.0, radius);
34
+
35
+ // Calculate fill alpha (inside the rectangle)
36
+ float fillAlpha = 1.0 - smoothstep(-1.0, 0.0, mainDist);
37
+
38
+ // Calculate border alpha (edge of the rectangle)
39
+ float borderAlpha =
40
+ 1.0 - smoothstep(-1.0, 0.0, abs(mainDist) - borderThickness);
41
+
42
+ // Background (transparent)
43
+ vec4 bg = vec4(0.0, 0.0, 0.0, 0.0);
44
+
45
+ // Fill (semi-transparent)
46
+ vec4 fill = vec4(v_color, 0.3);
47
+
48
+ // Border (fully opaque)
49
+ vec4 border = vec4(v_color, 1.0);
50
+
51
+ // Mix background with fill
52
+ vec4 res_with_fill = mix(bg, fill, fillAlpha);
53
+
54
+ // Mix with border
55
+ vec4 finalColor = mix(res_with_fill, border, borderAlpha * border.a);
56
+
57
+ gl_FragColor = finalColor;
58
+ }
@@ -0,0 +1,170 @@
1
+ <template>
2
+ <div />
3
+ </template>
4
+
5
+ <script setup>
6
+ import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
7
+ import defineRenderer from "#blokkli/helpers/composables/defineRenderer";
8
+ import { useBlokkli, computed } from "#imports";
9
+ import {
10
+ setBuffersAndAttributes,
11
+ drawBufferInfo,
12
+ setUniforms
13
+ } from "twgl.js";
14
+ import vs from "./vertex.glsl?raw";
15
+ import fs from "./fragment.glsl?raw";
16
+ import { RectangleBufferCollector } from "#blokkli/helpers/webgl";
17
+ import { toShaderColor } from "#blokkli/helpers";
18
+ const props = defineProps({
19
+ results: { type: Array, required: true },
20
+ gl: { type: null, required: true }
21
+ });
22
+ const { animation, ui, theme, selection, eventBus, element } = useBlokkli();
23
+ const programInfo = animation.registerProgram("analyze", props.gl, [vs, fs]);
24
+ const statusPriority = {
25
+ violation: 3,
26
+ incomplete: 2,
27
+ pass: 1,
28
+ inapplicable: 0
29
+ };
30
+ const nodes = computed(() => {
31
+ const allNodes = props.results.filter((v) => v.status === "incomplete" || v.status === "violation").flatMap((result) => {
32
+ const nodes2 = Array.isArray(result.nodes) ? result.nodes : [result.nodes];
33
+ return nodes2.flatMap((node) => {
34
+ const targets = Array.isArray(node.targets) ? node.targets : [node.targets];
35
+ return targets.map((v) => {
36
+ if (typeof v === "string") {
37
+ return element.query(
38
+ ui.providerElement,
39
+ v,
40
+ "Find analyze node target element."
41
+ );
42
+ }
43
+ return v;
44
+ }).filter((v) => v instanceof HTMLElement).filter((v) => ui.providerElement.contains(v));
45
+ }).map((element2) => {
46
+ return {
47
+ id: result.id,
48
+ element: element2,
49
+ title: result.title,
50
+ status: result.status
51
+ };
52
+ });
53
+ });
54
+ const nodeMap = /* @__PURE__ */ new Map();
55
+ for (const node of allNodes) {
56
+ const existing = nodeMap.get(node.element);
57
+ if (!existing || statusPriority[node.status] > statusPriority[existing.status]) {
58
+ nodeMap.set(node.element, node);
59
+ }
60
+ }
61
+ return Array.from(nodeMap.values());
62
+ });
63
+ class AnalyzeRectangleBufferCollector extends RectangleBufferCollector {
64
+ prevKey = "";
65
+ rectCache = /* @__PURE__ */ new Map();
66
+ clearCache() {
67
+ this.rectCache.clear();
68
+ }
69
+ getBufferInfo(force) {
70
+ const key = nodes.value.map((node, index) => {
71
+ if (!this.rectCache.has(node.element)) {
72
+ this.rectCache.set(
73
+ node.element,
74
+ ui.getAbsoluteElementRect(node.element)
75
+ );
76
+ }
77
+ const rect = this.rectCache.get(node.element);
78
+ if (!rect) {
79
+ return `${index}_no_rect`;
80
+ }
81
+ return `${index}_${rect.x}_${rect.y}_${rect.width}_${rect.height}_${node.status}`;
82
+ }).join("_");
83
+ const hasChanged = force || this.prevKey !== key;
84
+ if (hasChanged) {
85
+ this.reset();
86
+ for (let i = 0; i < nodes.value.length; i++) {
87
+ const node = nodes.value[i];
88
+ const id = `analyze_${i}`;
89
+ if (this.added.has(id)) {
90
+ continue;
91
+ }
92
+ const rect = this.rectCache.get(node.element);
93
+ if (!rect) {
94
+ continue;
95
+ }
96
+ this.added.add(id);
97
+ const statusType = node.status === "violation" ? 3 : node.status === "incomplete" ? 1 : node.status === "inapplicable" ? 2 : 0;
98
+ this.addRectangle(
99
+ {
100
+ id,
101
+ x: rect.x,
102
+ y: rect.y,
103
+ width: rect.width,
104
+ height: rect.height,
105
+ status: node.status
106
+ },
107
+ statusType
108
+ );
109
+ }
110
+ this.prevKey = key;
111
+ }
112
+ if (hasChanged) {
113
+ this.bufferInfo = this.createBufferInfo();
114
+ }
115
+ return { info: this.bufferInfo, hasChanged };
116
+ }
117
+ }
118
+ const collector = new AnalyzeRectangleBufferCollector(props.gl);
119
+ defineRenderer("analyze-overlay", {
120
+ zIndex: 500,
121
+ enabled: () => !selection.isMultiSelecting.value && !selection.isDragging.value,
122
+ render: (ctx) => {
123
+ ctx.gl.useProgram(programInfo.program);
124
+ const { info } = collector.getBufferInfo();
125
+ if (!info) {
126
+ return;
127
+ }
128
+ setUniforms(programInfo, {
129
+ u_color_violation: toShaderColor(theme.red.value.normal),
130
+ u_color_incomplete: toShaderColor(theme.yellow.value.normal),
131
+ u_color_pass: toShaderColor(theme.lime.value.normal)
132
+ });
133
+ animation.setSharedUniforms(ctx.gl, programInfo);
134
+ setBuffersAndAttributes(ctx.gl, programInfo, info);
135
+ drawBufferInfo(ctx.gl, info, ctx.gl.TRIANGLES);
136
+ }
137
+ });
138
+ onBlokkliEvent("ui:resized", function() {
139
+ collector.clearCache();
140
+ collector.reset();
141
+ });
142
+ onBlokkliEvent("state:reloaded", function() {
143
+ collector.clearCache();
144
+ collector.reset();
145
+ });
146
+ onBlokkliEvent("mouse:up", (e) => {
147
+ const artboardX = (e.x - ui.artboardOffset.value.x) / ui.artboardScale.value;
148
+ const artboardY = (e.y - ui.artboardOffset.value.y) / ui.artboardScale.value;
149
+ for (let i = 0; i < nodes.value.length; i++) {
150
+ const node = nodes.value[i];
151
+ const rect = collector.rectCache.get(node.element);
152
+ if (!rect) {
153
+ continue;
154
+ }
155
+ if (artboardX >= rect.x && artboardX <= rect.x + rect.width && artboardY >= rect.y && artboardY <= rect.y + rect.height) {
156
+ eventBus.emit("analyze:click-node", {
157
+ id: node.id,
158
+ target: node.element
159
+ });
160
+ return;
161
+ }
162
+ }
163
+ });
164
+ </script>
165
+
166
+ <script>
167
+ export default {
168
+ name: "AnalyzeOverlay"
169
+ };
170
+ </script>
@@ -0,0 +1,9 @@
1
+ import type { AnalyzeResultMapped } from '#blokkli/analyzer/types';
2
+ declare const _default: import("vue").DefineComponent<{
3
+ results: AnalyzeResultMapped[];
4
+ gl: WebGLRenderingContext;
5
+ }, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{
6
+ results: AnalyzeResultMapped[];
7
+ gl: WebGLRenderingContext;
8
+ }> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
9
+ export default _default;
@@ -0,0 +1,72 @@
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
+ attribute float a_rect_type;
9
+
10
+ // The global scaling applied to all quads.
11
+ uniform float u_scale;
12
+ uniform float u_dpi;
13
+ // The amount of pixels to offset on the x axis.
14
+ uniform float u_offset_x;
15
+ // The amount of pixels to offset on the y axis.
16
+ uniform float u_offset_y;
17
+ uniform vec2 u_resolution;
18
+ uniform vec3 u_color_violation;
19
+ uniform vec3 u_color_incomplete;
20
+ uniform vec3 u_color_pass;
21
+
22
+ varying vec4 v_quad;
23
+ varying float v_rect_type;
24
+ varying vec3 v_color;
25
+ varying vec2 v_rect_size;
26
+ varying vec2 v_rect_center;
27
+
28
+ void main() {
29
+ // Apply global scale and offsets
30
+ vec2 offsetPosition = a_position * u_scale;
31
+ offsetPosition.x += u_offset_x;
32
+ offsetPosition.y += u_offset_y;
33
+
34
+ // Normalize position for rendering
35
+ vec2 normalizedPosition = offsetPosition / u_resolution;
36
+
37
+ // Transform to screen space (-1 to 1)
38
+ vec2 screenSpacePosition = normalizedPosition * 2.0 - vec2(1.0, 1.0);
39
+ screenSpacePosition.y = -screenSpacePosition.y;
40
+
41
+ // Output final position in clip space
42
+ gl_Position = vec4(screenSpacePosition, 0.0, 1.0) * u_dpi;
43
+
44
+ // Pass quad and type to fragment shader
45
+ vec4 transformed_quad = vec4(
46
+ (a_quad.x * u_scale + u_offset_x) * u_dpi,
47
+ (u_resolution.y - a_quad.y * u_scale - a_quad.w * u_scale - u_offset_y) *
48
+ u_dpi,
49
+ a_quad.z * u_scale * u_dpi,
50
+ a_quad.w * u_scale * u_dpi
51
+ );
52
+ v_quad = transformed_quad;
53
+ v_rect_type = a_rect_type;
54
+ v_rect_size = vec2(v_quad.z, v_quad.w);
55
+ v_rect_center = vec2(v_quad.x + v_quad.z / 2.0, v_quad.y + v_quad.w / 2.0);
56
+
57
+ // Set color based on status type
58
+ // 0 = pass, 1 = incomplete, 2 = inapplicable, 3 = violation
59
+ if (a_rect_type > 2.5) {
60
+ // violation
61
+ v_color = u_color_violation;
62
+ } else if (a_rect_type > 0.5 && a_rect_type < 1.5) {
63
+ // incomplete
64
+ v_color = u_color_incomplete;
65
+ } else if (a_rect_type < 0.5) {
66
+ // pass
67
+ v_color = u_color_pass;
68
+ } else {
69
+ // inapplicable - use a neutral gray
70
+ v_color = vec3(0.5, 0.5, 0.5);
71
+ }
72
+ }
@@ -0,0 +1,159 @@
1
+ <template>
2
+ <div class="bk bk-analyze">
3
+ <div class="bk-analyze-button">
4
+ <button
5
+ class="bk-button bk-is-primary"
6
+ :disabled="!isStale"
7
+ @click="onClick"
8
+ >
9
+ {{ $t("analyzeButtonLabel", "Analyze Page") }}
10
+ </button>
11
+
12
+ <p v-if="lastRun" class="bk-analyze-last-run">
13
+ <RelativeTime v-slot="{ formatted }" :timestamp="lastRun">
14
+ {{
15
+ $t("analyzeLastRun", "Last run: @time").replace("@time", formatted)
16
+ }}
17
+ </RelativeTime>
18
+ </p>
19
+ <p v-if="isStale && hasRunOnce" class="bk-message-info">
20
+ {{
21
+ $t(
22
+ "analyzeStaleMessage",
23
+ "The contents of the page have changed since last analyzing the page. Please run the analyzers again to get updated results."
24
+ )
25
+ }}
26
+ </p>
27
+ </div>
28
+
29
+ <div v-if="resultsFiltered.length" class="bk-analyze-wrapper">
30
+ <div class="bk-analyze-form">
31
+ <FormSelect
32
+ id="category"
33
+ v-model="selectedCategory"
34
+ :label="$t('analyzeCategory', 'Category')"
35
+ :options="categoryOptions"
36
+ />
37
+ </div>
38
+ <AnalyzeSummary :results="resultsFiltered" />
39
+ <Results :results="resultsFiltered" />
40
+ </div>
41
+ </div>
42
+ <Overlay
43
+ v-if="
44
+ resultsFiltered.length && gl && animation.webglEnabled.value && !isStale
45
+ "
46
+ :results="resultsFiltered"
47
+ :gl="gl"
48
+ />
49
+ </template>
50
+
51
+ <script setup>
52
+ import { computed, useBlokkli, useState, ref } from "#imports";
53
+ import Results from "./Results/Results.vue";
54
+ import AnalyzeSummary from "./Summary/index.vue";
55
+ import Overlay from "./Overlay/index.vue";
56
+ import { useAnalyzeHelper } from "./helper";
57
+ import { FormSelect, RelativeTime } from "#blokkli/components";
58
+ import { AnalyzerContext } from "./analyzers/helpers/Context";
59
+ import { normalizeToArray } from "./analyzers/helpers/normalizeArray";
60
+ import { falsy } from "#blokkli/helpers";
61
+ import { renderCycle } from "#blokkli/helpers/renderCycle";
62
+ const props = defineProps({
63
+ langcode: { type: String, required: true },
64
+ analyzers: { type: Array, required: true }
65
+ });
66
+ const ALL = "ALL";
67
+ const { $t, ui, state, animation } = useBlokkli();
68
+ const { getCategoryLabel } = useAnalyzeHelper();
69
+ const gl = animation.gl();
70
+ const currentPlugin = ref("readability");
71
+ const hasRunOnce = useState(() => false);
72
+ const results = useState("blokkli:analyze", () => []);
73
+ const isLoading = useState(() => false);
74
+ const lastRun = useState(() => 0);
75
+ const lastRunKey = useState(() => "");
76
+ const selectedCategory = useState(() => ALL);
77
+ const hasInitialized = useState(() => false);
78
+ const providerRootElement = ui.providerElement;
79
+ const resultsFiltered = computed(() => {
80
+ if (selectedCategory.value === ALL) {
81
+ return results.value;
82
+ }
83
+ return results.value.filter((v) => v.category === selectedCategory.value);
84
+ });
85
+ const isStale = computed(() => lastRunKey.value !== state.refreshKey.value);
86
+ function getContext() {
87
+ return new AnalyzerContext(
88
+ props.langcode,
89
+ ui.interfaceLanguage.value,
90
+ providerRootElement,
91
+ state,
92
+ $t
93
+ );
94
+ }
95
+ async function onClick() {
96
+ if (isLoading.value) {
97
+ return;
98
+ }
99
+ const requiresRawPage = props.analyzers.some(
100
+ (analyzer) => analyzer.requireRawPage
101
+ );
102
+ if (requiresRawPage) {
103
+ ui.isAnalyzing.value = true;
104
+ }
105
+ isLoading.value = true;
106
+ await renderCycle();
107
+ const context = getContext();
108
+ if (!hasInitialized.value) {
109
+ await Promise.all(
110
+ props.analyzers.map(async (analyzer) => {
111
+ if (analyzer.init) {
112
+ await analyzer.init(context);
113
+ }
114
+ })
115
+ );
116
+ }
117
+ hasInitialized.value = true;
118
+ const newResults = [];
119
+ for (let i = 0; i < props.analyzers.length; i++) {
120
+ const analyzer = props.analyzers[i];
121
+ currentPlugin.value = analyzer.id;
122
+ const result = await normalizeToArray(analyzer.run(context));
123
+ const mapped = result.filter(falsy).map((v) => {
124
+ return {
125
+ ...v,
126
+ plugin: analyzer.id
127
+ };
128
+ });
129
+ newResults.push(...mapped);
130
+ }
131
+ results.value = newResults;
132
+ isLoading.value = false;
133
+ hasRunOnce.value = true;
134
+ lastRun.value = Date.now() / 1e3;
135
+ lastRunKey.value = state.refreshKey.value;
136
+ if (requiresRawPage) {
137
+ ui.isAnalyzing.value = false;
138
+ }
139
+ }
140
+ const categoryOptions = computed(() => {
141
+ const set = results.value.reduce((acc, v) => {
142
+ acc.add(v.category);
143
+ return acc;
144
+ }, /* @__PURE__ */ new Set());
145
+ const categories = [...set.values()].map((value) => {
146
+ return {
147
+ value,
148
+ label: getCategoryLabel(value)
149
+ };
150
+ });
151
+ return [
152
+ {
153
+ value: ALL,
154
+ label: $t("all", "All")
155
+ },
156
+ ...categories
157
+ ];
158
+ });
159
+ </script>
@@ -0,0 +1,7 @@
1
+ import type { Analyzer } from './analyzers/types.js';
2
+ type __VLS_Props = {
3
+ langcode: string;
4
+ analyzers: Analyzer[];
5
+ };
6
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
7
+ export default _default;
@@ -0,0 +1,100 @@
1
+ <template>
2
+ <div>
3
+ <details
4
+ v-for="group in grouped"
5
+ :key="group.group"
6
+ :open="group.open"
7
+ class="bk-analyze-results"
8
+ >
9
+ <summary v-show="!group.open">
10
+ <div>
11
+ <span>{{ group.label }}</span>
12
+ <div>
13
+ <span class="bk-pill">{{ group.results.length }}</span>
14
+ </div>
15
+ </div>
16
+ <Icon name="caret" />
17
+ </summary>
18
+ <ul
19
+ :class="{
20
+ 'bk-is-always-open': group.open
21
+ }"
22
+ >
23
+ <li>
24
+ <ResultsItem
25
+ v-for="result in group.results"
26
+ v-bind="result"
27
+ :key="group.group + result.id"
28
+ />
29
+ </li>
30
+ </ul>
31
+ </details>
32
+ </div>
33
+ </template>
34
+
35
+ <script setup>
36
+ import { computed, useBlokkli } from "#imports";
37
+ import ResultsItem from "./ResultsItem.vue";
38
+ import { Icon } from "#blokkli/components";
39
+ const props = defineProps({
40
+ results: { type: Array, required: true }
41
+ });
42
+ const { $t } = useBlokkli();
43
+ const groupOrder = {
44
+ problems: 1,
45
+ success: 2,
46
+ inapplicable: 3
47
+ };
48
+ const statusOrder = {
49
+ violation: 1,
50
+ incomplete: 2,
51
+ pass: 3,
52
+ inapplicable: 4
53
+ };
54
+ function getGroup(status) {
55
+ if (status === "violation" || status === "incomplete") {
56
+ return "problems";
57
+ } else if (status === "pass") {
58
+ return "success";
59
+ }
60
+ return "inapplicable";
61
+ }
62
+ function getGroupLabel(group) {
63
+ if (group === "problems") {
64
+ return "Problems";
65
+ } else if (group === "success") {
66
+ return $t("analyzeStatusPass", "Pass");
67
+ }
68
+ return $t("analyzeStatusInapplicable", "Inapplicable");
69
+ }
70
+ const grouped = computed(() => {
71
+ const map = props.results.reduce(
72
+ (acc, result) => {
73
+ const group = getGroup(result.status);
74
+ if (!acc[group]) {
75
+ acc[group] = [];
76
+ }
77
+ acc[group].push(result);
78
+ return acc;
79
+ },
80
+ {}
81
+ );
82
+ return Object.entries(map).map(([key, results]) => {
83
+ const group = key;
84
+ return {
85
+ group,
86
+ label: getGroupLabel(group),
87
+ open: group === "problems",
88
+ results: results.sort((a, b) => {
89
+ const statusDiff = statusOrder[a.status] - statusOrder[b.status];
90
+ if (statusDiff !== 0) {
91
+ return statusDiff;
92
+ }
93
+ return a.title.localeCompare(b.title);
94
+ })
95
+ };
96
+ }).sort((a, b) => {
97
+ return groupOrder[a.group] - groupOrder[b.group];
98
+ });
99
+ });
100
+ </script>
@@ -0,0 +1,6 @@
1
+ import type { AnalyzeResultMapped } from '../analyzers/types.js';
2
+ type __VLS_Props = {
3
+ results: AnalyzeResultMapped[];
4
+ };
5
+ declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
6
+ export default _default;