@blokkli/editor 1.0.0

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 (395) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +64 -0
  3. package/dist/module.cjs +5 -0
  4. package/dist/module.d.mts +129 -0
  5. package/dist/module.d.ts +129 -0
  6. package/dist/module.json +12 -0
  7. package/dist/module.mjs +5430 -0
  8. package/dist/runtime/adapter/drupal/graphql/base.graphql +906 -0
  9. package/dist/runtime/adapter/drupal/graphql/comments.graphql +56 -0
  10. package/dist/runtime/adapter/drupal/graphql/fragments.graphql +25 -0
  11. package/dist/runtime/adapter/drupal/graphql/library.graphql +66 -0
  12. package/dist/runtime/adapter/drupal/graphql/search.graphql +19 -0
  13. package/dist/runtime/adapter/drupal/graphql/transform.graphql +27 -0
  14. package/dist/runtime/adapter/drupal/graphqlMiddleware.d.ts +2 -0
  15. package/dist/runtime/adapter/drupal/graphqlMiddleware.js +643 -0
  16. package/dist/runtime/adapter/index.d.ts +352 -0
  17. package/dist/runtime/adapter/index.js +3 -0
  18. package/dist/runtime/blokkliPlugins/AddAction/index.vue +87 -0
  19. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue +95 -0
  20. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue +49 -0
  21. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue +34 -0
  22. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue +73 -0
  23. package/dist/runtime/blokkliPlugins/ItemAction/index.vue +132 -0
  24. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue +42 -0
  25. package/dist/runtime/blokkliPlugins/MenuButton/index.vue +74 -0
  26. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue +334 -0
  27. package/dist/runtime/blokkliPlugins/Sidebar/index.vue +286 -0
  28. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue +104 -0
  29. package/dist/runtime/blokkliPlugins/TourItem/index.vue +45 -0
  30. package/dist/runtime/blokkliPlugins/ViewOption/index.vue +106 -0
  31. package/dist/runtime/blokkliPlugins/index.d.ts +12 -0
  32. package/dist/runtime/blokkliPlugins/index.js +24 -0
  33. package/dist/runtime/components/Blocks/Fragment/icon.svg +1 -0
  34. package/dist/runtime/components/Blocks/Fragment/index.vue +24 -0
  35. package/dist/runtime/components/Blocks/FromLibrary/index.vue +58 -0
  36. package/dist/runtime/components/BlokkliEditable.vue +73 -0
  37. package/dist/runtime/components/BlokkliField.vue +157 -0
  38. package/dist/runtime/components/BlokkliItem.vue +79 -0
  39. package/dist/runtime/components/BlokkliProvider.vue +160 -0
  40. package/dist/runtime/components/Edit/Actions/index.vue +263 -0
  41. package/dist/runtime/components/Edit/AddListItem/index.vue +116 -0
  42. package/dist/runtime/components/Edit/AnimationCanvas/index.vue +122 -0
  43. package/dist/runtime/components/Edit/AppMenu/index.vue +60 -0
  44. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue +64 -0
  45. package/dist/runtime/components/Edit/Dialog/index.vue +163 -0
  46. package/dist/runtime/components/Edit/DragInteractions/index.vue +439 -0
  47. package/dist/runtime/components/Edit/DraggableList.vue +110 -0
  48. package/dist/runtime/components/Edit/EditIndicator.vue +82 -0
  49. package/dist/runtime/components/Edit/EditProvider.vue +213 -0
  50. package/dist/runtime/components/Edit/Features/AddList/docs.md +4 -0
  51. package/dist/runtime/components/Edit/Features/AddList/index.vue +205 -0
  52. package/dist/runtime/components/Edit/Features/Artboard/Manager/Artboard.d.ts +204 -0
  53. package/dist/runtime/components/Edit/Features/Artboard/Manager/Artboard.js +748 -0
  54. package/dist/runtime/components/Edit/Features/Artboard/Manager/Scrollbar/index.vue +176 -0
  55. package/dist/runtime/components/Edit/Features/Artboard/Manager/index.vue +317 -0
  56. package/dist/runtime/components/Edit/Features/Artboard/index.vue +45 -0
  57. package/dist/runtime/components/Edit/Features/Assistant/Overlay/ResultMarkup/index.vue +17 -0
  58. package/dist/runtime/components/Edit/Features/Assistant/Overlay/index.vue +147 -0
  59. package/dist/runtime/components/Edit/Features/Assistant/docs.md +7 -0
  60. package/dist/runtime/components/Edit/Features/Assistant/index.vue +68 -0
  61. package/dist/runtime/components/Edit/Features/BlockAddList/docs.md +15 -0
  62. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue +440 -0
  63. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/File.vue +68 -0
  64. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/Video.vue +56 -0
  65. package/dist/runtime/components/Edit/Features/Clipboard/List/index.vue +69 -0
  66. package/dist/runtime/components/Edit/Features/Clipboard/docs.md +16 -0
  67. package/dist/runtime/components/Edit/Features/Clipboard/index.vue +485 -0
  68. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue +61 -0
  69. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue +280 -0
  70. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue +51 -0
  71. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue +32 -0
  72. package/dist/runtime/components/Edit/Features/Comments/Comment/index.vue +53 -0
  73. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue +100 -0
  74. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue +133 -0
  75. package/dist/runtime/components/Edit/Features/Comments/docs.md +13 -0
  76. package/dist/runtime/components/Edit/Features/Comments/index.vue +110 -0
  77. package/dist/runtime/components/Edit/Features/Conversions/index.vue +98 -0
  78. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue +55 -0
  79. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue +93 -0
  80. package/dist/runtime/components/Edit/Features/Debug/docs.md +3 -0
  81. package/dist/runtime/components/Edit/Features/Debug/index.vue +178 -0
  82. package/dist/runtime/components/Edit/Features/Delete/index.vue +43 -0
  83. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue +420 -0
  84. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/fragment.glsl +58 -0
  85. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue +808 -0
  86. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/vertex.glsl +57 -0
  87. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue +410 -0
  88. package/dist/runtime/components/Edit/Features/Duplicate/index.vue +109 -0
  89. package/dist/runtime/components/Edit/Features/Edit/index.vue +63 -0
  90. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue +73 -0
  91. package/dist/runtime/components/Edit/Features/EditForm/index.vue +217 -0
  92. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Contenteditable/index.vue +42 -0
  93. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue +68 -0
  94. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue +81 -0
  95. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue +357 -0
  96. package/dist/runtime/components/Edit/Features/EditableField/index.vue +192 -0
  97. package/dist/runtime/components/Edit/Features/EditableMask/index.vue +64 -0
  98. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue +108 -0
  99. package/dist/runtime/components/Edit/Features/Exit/index.vue +38 -0
  100. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue +33 -0
  101. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue +43 -0
  102. package/dist/runtime/components/Edit/Features/Fragments/Dialog/Item/index.vue +68 -0
  103. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue +137 -0
  104. package/dist/runtime/components/Edit/Features/Fragments/docs.md +101 -0
  105. package/dist/runtime/components/Edit/Features/Fragments/index.vue +86 -0
  106. package/dist/runtime/components/Edit/Features/Grid/index.vue +40 -0
  107. package/dist/runtime/components/Edit/Features/Help/Shortcuts/index.vue +71 -0
  108. package/dist/runtime/components/Edit/Features/Help/index.vue +53 -0
  109. package/dist/runtime/components/Edit/Features/History/index.vue +263 -0
  110. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue +140 -0
  111. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue +92 -0
  112. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue +0 -0
  113. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/Item/index.vue +73 -0
  114. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue +184 -0
  115. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue +88 -0
  116. package/dist/runtime/components/Edit/Features/Library/docs.md +127 -0
  117. package/dist/runtime/components/Edit/Features/Library/index.vue +184 -0
  118. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue +184 -0
  119. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue +182 -0
  120. package/dist/runtime/components/Edit/Features/MediaLibrary/types.d.ts +57 -0
  121. package/dist/runtime/components/Edit/Features/MediaLibrary/types.js +0 -0
  122. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/fragment.glsl +90 -0
  123. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue +289 -0
  124. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/vertex.glsl +182 -0
  125. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue +76 -0
  126. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue +52 -0
  127. package/dist/runtime/components/Edit/Features/Options/Form/Checkboxes/index.vue +129 -0
  128. package/dist/runtime/components/Edit/Features/Options/Form/Color/index.vue +38 -0
  129. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue +25 -0
  130. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue +155 -0
  131. package/dist/runtime/components/Edit/Features/Options/Form/Number/index.vue +74 -0
  132. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue +135 -0
  133. package/dist/runtime/components/Edit/Features/Options/Form/Range/index.vue +47 -0
  134. package/dist/runtime/components/Edit/Features/Options/Form/Text/index.vue +38 -0
  135. package/dist/runtime/components/Edit/Features/Options/Form/index.vue +342 -0
  136. package/dist/runtime/components/Edit/Features/Options/index.vue +88 -0
  137. package/dist/runtime/components/Edit/Features/Ownership/index.vue +57 -0
  138. package/dist/runtime/components/Edit/Features/Preview/index.vue +45 -0
  139. package/dist/runtime/components/Edit/Features/PreviewGrant/QrCode/index.vue +30 -0
  140. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue +73 -0
  141. package/dist/runtime/components/Edit/Features/Publish/index.vue +50 -0
  142. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue +81 -0
  143. package/dist/runtime/components/Edit/Features/ResponsivePreview/index.vue +217 -0
  144. package/dist/runtime/components/Edit/Features/Revert/index.vue +68 -0
  145. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Content/index.vue +165 -0
  146. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue +211 -0
  147. package/dist/runtime/components/Edit/Features/Search/Overlay/index.vue +214 -0
  148. package/dist/runtime/components/Edit/Features/Search/index.vue +79 -0
  149. package/dist/runtime/components/Edit/Features/Selection/Overlay/fragment.glsl +99 -0
  150. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue +144 -0
  151. package/dist/runtime/components/Edit/Features/Selection/Overlay/vertex.glsl +85 -0
  152. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue +50 -0
  153. package/dist/runtime/components/Edit/Features/Selection/index.vue +295 -0
  154. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue +141 -0
  155. package/dist/runtime/components/Edit/Features/Settings/Dialog/index.vue +138 -0
  156. package/dist/runtime/components/Edit/Features/Settings/index.vue +92 -0
  157. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue +181 -0
  158. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue +149 -0
  159. package/dist/runtime/components/Edit/Features/Structure/List/index.vue +55 -0
  160. package/dist/runtime/components/Edit/Features/Structure/index.vue +83 -0
  161. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue +81 -0
  162. package/dist/runtime/components/Edit/Features/Theme/GeneratedCode/index.vue +24 -0
  163. package/dist/runtime/components/Edit/Features/Theme/index.vue +122 -0
  164. package/dist/runtime/components/Edit/Features/TouchActionBar/Bar/index.vue +26 -0
  165. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue +42 -0
  166. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue +270 -0
  167. package/dist/runtime/components/Edit/Features/Tour/Popup/index.vue +36 -0
  168. package/dist/runtime/components/Edit/Features/Tour/docs.md +0 -0
  169. package/dist/runtime/components/Edit/Features/Tour/index.vue +46 -0
  170. package/dist/runtime/components/Edit/Features/Transform/docs.md +67 -0
  171. package/dist/runtime/components/Edit/Features/Transform/index.vue +177 -0
  172. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue +50 -0
  173. package/dist/runtime/components/Edit/Features/Translations/index.vue +193 -0
  174. package/dist/runtime/components/Edit/Features/Validations/Overlay/Item.vue +50 -0
  175. package/dist/runtime/components/Edit/Features/Validations/Overlay/index.vue +51 -0
  176. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue +50 -0
  177. package/dist/runtime/components/Edit/Features/Validations/index.vue +70 -0
  178. package/dist/runtime/components/Edit/Features/index.vue +67 -0
  179. package/dist/runtime/components/Edit/FormOverlay/Header/index.vue +39 -0
  180. package/dist/runtime/components/Edit/FormOverlay/index.vue +52 -0
  181. package/dist/runtime/components/Edit/Highlight/index.vue +94 -0
  182. package/dist/runtime/components/Edit/Icon/index.vue +21 -0
  183. package/dist/runtime/components/Edit/ItemIcon/index.vue +27 -0
  184. package/dist/runtime/components/Edit/Loading/index.vue +19 -0
  185. package/dist/runtime/components/Edit/Messages/Item/index.vue +107 -0
  186. package/dist/runtime/components/Edit/Messages/index.vue +37 -0
  187. package/dist/runtime/components/Edit/PreviewProvider.vue +223 -0
  188. package/dist/runtime/components/Edit/RelativeTime/index.vue +37 -0
  189. package/dist/runtime/components/Edit/Resizable/index.vue +90 -0
  190. package/dist/runtime/components/Edit/ScaleToFit/index.vue +57 -0
  191. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue +90 -0
  192. package/dist/runtime/components/Edit/Sortli/index.vue +92 -0
  193. package/dist/runtime/components/Edit/SystemRequirements/index.vue +91 -0
  194. package/dist/runtime/components/Edit/Toolbar/index.vue +106 -0
  195. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue +75 -0
  196. package/dist/runtime/components/Edit/index.d.ts +14 -0
  197. package/dist/runtime/components/Edit/index.js +28 -0
  198. package/dist/runtime/composables/defineBlokkli.d.ts +6 -0
  199. package/dist/runtime/composables/defineBlokkli.js +108 -0
  200. package/dist/runtime/composables/defineBlokkliFeature.d.ts +28 -0
  201. package/dist/runtime/composables/defineBlokkliFeature.js +62 -0
  202. package/dist/runtime/composables/defineBlokkliFragment.d.ts +3 -0
  203. package/dist/runtime/composables/defineBlokkliFragment.js +54 -0
  204. package/dist/runtime/composables/useBlokkli.d.ts +8 -0
  205. package/dist/runtime/composables/useBlokkli.js +5 -0
  206. package/dist/runtime/constants/index.d.ts +4 -0
  207. package/dist/runtime/constants/index.js +2 -0
  208. package/dist/runtime/css/output.css +1 -0
  209. package/dist/runtime/helpers/Artboard/index.d.ts +16 -0
  210. package/dist/runtime/helpers/Artboard/index.js +20 -0
  211. package/dist/runtime/helpers/DragStyle/index.d.ts +12 -0
  212. package/dist/runtime/helpers/DragStyle/index.js +86 -0
  213. package/dist/runtime/helpers/animationProvider.d.ts +25 -0
  214. package/dist/runtime/helpers/animationProvider.js +116 -0
  215. package/dist/runtime/helpers/broadcastProvider.d.ts +7 -0
  216. package/dist/runtime/helpers/broadcastProvider.js +26 -0
  217. package/dist/runtime/helpers/commandsProvider.d.ts +9 -0
  218. package/dist/runtime/helpers/commandsProvider.js +16 -0
  219. package/dist/runtime/helpers/composables/defineCommands.d.ts +2 -0
  220. package/dist/runtime/helpers/composables/defineCommands.js +10 -0
  221. package/dist/runtime/helpers/composables/defineDropAreas.d.ts +2 -0
  222. package/dist/runtime/helpers/composables/defineDropAreas.js +10 -0
  223. package/dist/runtime/helpers/composables/defineShortcut.d.ts +2 -0
  224. package/dist/runtime/helpers/composables/defineShortcut.js +19 -0
  225. package/dist/runtime/helpers/composables/defineTourItem.d.ts +2 -0
  226. package/dist/runtime/helpers/composables/defineTourItem.js +10 -0
  227. package/dist/runtime/helpers/composables/onBlokkliEvent.d.ts +2 -0
  228. package/dist/runtime/helpers/composables/onBlokkliEvent.js +10 -0
  229. package/dist/runtime/helpers/composables/useAnimationFrame.d.ts +1 -0
  230. package/dist/runtime/helpers/composables/useAnimationFrame.js +14 -0
  231. package/dist/runtime/helpers/composables/useDebugLogger.d.ts +2 -0
  232. package/dist/runtime/helpers/composables/useDebugLogger.js +5 -0
  233. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.d.ts +5 -0
  234. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.js +26 -0
  235. package/dist/runtime/helpers/debugProvider.d.ts +23 -0
  236. package/dist/runtime/helpers/debugProvider.js +65 -0
  237. package/dist/runtime/helpers/dom/index.d.ts +5 -0
  238. package/dist/runtime/helpers/dom/index.js +37 -0
  239. package/dist/runtime/helpers/domProvider.d.ts +46 -0
  240. package/dist/runtime/helpers/domProvider.js +446 -0
  241. package/dist/runtime/helpers/dropAreaProvider.d.ts +9 -0
  242. package/dist/runtime/helpers/dropAreaProvider.js +22 -0
  243. package/dist/runtime/helpers/easing.d.ts +3 -0
  244. package/dist/runtime/helpers/easing.js +16 -0
  245. package/dist/runtime/helpers/eventBus.d.ts +3 -0
  246. package/dist/runtime/helpers/eventBus.js +5 -0
  247. package/dist/runtime/helpers/featuresProvider.d.ts +23 -0
  248. package/dist/runtime/helpers/featuresProvider.js +16 -0
  249. package/dist/runtime/helpers/frameEventBus.d.ts +9 -0
  250. package/dist/runtime/helpers/frameEventBus.js +2 -0
  251. package/dist/runtime/helpers/index.d.ts +87 -0
  252. package/dist/runtime/helpers/index.js +467 -0
  253. package/dist/runtime/helpers/keyboardProvider.d.ts +17 -0
  254. package/dist/runtime/helpers/keyboardProvider.js +79 -0
  255. package/dist/runtime/helpers/options.d.ts +2 -0
  256. package/dist/runtime/helpers/options.js +21 -0
  257. package/dist/runtime/helpers/runtimeHelpers/index.d.ts +10 -0
  258. package/dist/runtime/helpers/runtimeHelpers/index.js +35 -0
  259. package/dist/runtime/helpers/selectionProvider.d.ts +62 -0
  260. package/dist/runtime/helpers/selectionProvider.js +149 -0
  261. package/dist/runtime/helpers/stateProvider.d.ts +35 -0
  262. package/dist/runtime/helpers/stateProvider.js +226 -0
  263. package/dist/runtime/helpers/storageProvider.d.ts +15 -0
  264. package/dist/runtime/helpers/storageProvider.js +61 -0
  265. package/dist/runtime/helpers/symbols.d.ts +16 -0
  266. package/dist/runtime/helpers/symbols.js +18 -0
  267. package/dist/runtime/helpers/textProvider.d.ts +4 -0
  268. package/dist/runtime/helpers/textProvider.js +20 -0
  269. package/dist/runtime/helpers/themeProvider.d.ts +27 -0
  270. package/dist/runtime/helpers/themeProvider.js +124 -0
  271. package/dist/runtime/helpers/tourProvider.d.ts +11 -0
  272. package/dist/runtime/helpers/tourProvider.js +19 -0
  273. package/dist/runtime/helpers/transform.d.ts +2 -0
  274. package/dist/runtime/helpers/transform.js +17 -0
  275. package/dist/runtime/helpers/typesProvider.d.ts +36 -0
  276. package/dist/runtime/helpers/typesProvider.js +138 -0
  277. package/dist/runtime/helpers/uiProvider.d.ts +36 -0
  278. package/dist/runtime/helpers/uiProvider.js +278 -0
  279. package/dist/runtime/helpers/webgl/index.d.ts +32 -0
  280. package/dist/runtime/helpers/webgl/index.js +132 -0
  281. package/dist/runtime/icons/alert.svg +6 -0
  282. package/dist/runtime/icons/area.svg +5 -0
  283. package/dist/runtime/icons/arrow-down.svg +1 -0
  284. package/dist/runtime/icons/arrow-left.svg +1 -0
  285. package/dist/runtime/icons/arrow-right.svg +1 -0
  286. package/dist/runtime/icons/arrow-up.svg +1 -0
  287. package/dist/runtime/icons/artboard-disabled.svg +9 -0
  288. package/dist/runtime/icons/artboard-enabled.svg +29 -0
  289. package/dist/runtime/icons/artboard.svg +1 -0
  290. package/dist/runtime/icons/bug.svg +1 -0
  291. package/dist/runtime/icons/button-pointer.svg +1 -0
  292. package/dist/runtime/icons/caret.svg +12 -0
  293. package/dist/runtime/icons/cellphone.svg +1 -0
  294. package/dist/runtime/icons/chat-question.svg +1 -0
  295. package/dist/runtime/icons/check.svg +1 -0
  296. package/dist/runtime/icons/checkbox.svg +5 -0
  297. package/dist/runtime/icons/checks.svg +1 -0
  298. package/dist/runtime/icons/chevron-left.svg +1 -0
  299. package/dist/runtime/icons/chevron-right.svg +1 -0
  300. package/dist/runtime/icons/clipboard.svg +5 -0
  301. package/dist/runtime/icons/close.svg +5 -0
  302. package/dist/runtime/icons/cog.svg +5 -0
  303. package/dist/runtime/icons/command.svg +1 -0
  304. package/dist/runtime/icons/comment.svg +5 -0
  305. package/dist/runtime/icons/comment_add.svg +5 -0
  306. package/dist/runtime/icons/convert.svg +1 -0
  307. package/dist/runtime/icons/cursor-move.svg +1 -0
  308. package/dist/runtime/icons/dead.svg +1 -0
  309. package/dist/runtime/icons/delete.svg +8 -0
  310. package/dist/runtime/icons/detach.svg +7 -0
  311. package/dist/runtime/icons/drag.svg +1 -0
  312. package/dist/runtime/icons/duplicate.svg +12 -0
  313. package/dist/runtime/icons/edit.svg +8 -0
  314. package/dist/runtime/icons/exit.svg +6 -0
  315. package/dist/runtime/icons/expand.svg +1 -0
  316. package/dist/runtime/icons/file.svg +1 -0
  317. package/dist/runtime/icons/form.svg +1 -0
  318. package/dist/runtime/icons/fragment.svg +1 -0
  319. package/dist/runtime/icons/grid.svg +13 -0
  320. package/dist/runtime/icons/group.svg +5 -0
  321. package/dist/runtime/icons/help.svg +1 -0
  322. package/dist/runtime/icons/history.svg +1 -0
  323. package/dist/runtime/icons/image.svg +1 -0
  324. package/dist/runtime/icons/import.svg +5 -0
  325. package/dist/runtime/icons/laptop.svg +1 -0
  326. package/dist/runtime/icons/list-view-grid.svg +1 -0
  327. package/dist/runtime/icons/list-view-horizontal.svg +1 -0
  328. package/dist/runtime/icons/loader.svg +1 -0
  329. package/dist/runtime/icons/logo.svg +5 -0
  330. package/dist/runtime/icons/magnifier.svg +5 -0
  331. package/dist/runtime/icons/menu.svg +1 -0
  332. package/dist/runtime/icons/minus.svg +1 -0
  333. package/dist/runtime/icons/monitor.svg +1 -0
  334. package/dist/runtime/icons/multi-select.svg +1 -0
  335. package/dist/runtime/icons/multimedia.svg +1 -0
  336. package/dist/runtime/icons/opacity.svg +5 -0
  337. package/dist/runtime/icons/open_in_new.svg +3 -0
  338. package/dist/runtime/icons/palette.svg +1 -0
  339. package/dist/runtime/icons/plus-box.svg +1 -0
  340. package/dist/runtime/icons/plus.svg +1 -0
  341. package/dist/runtime/icons/preview.svg +5 -0
  342. package/dist/runtime/icons/publish.svg +12 -0
  343. package/dist/runtime/icons/puzzle.svg +1 -0
  344. package/dist/runtime/icons/qrcode.svg +5 -0
  345. package/dist/runtime/icons/question.svg +5 -0
  346. package/dist/runtime/icons/redo.svg +12 -0
  347. package/dist/runtime/icons/resize.svg +1 -0
  348. package/dist/runtime/icons/reusable.svg +5 -0
  349. package/dist/runtime/icons/revert.svg +5 -0
  350. package/dist/runtime/icons/robot.svg +1 -0
  351. package/dist/runtime/icons/rotate-phone.svg +1 -0
  352. package/dist/runtime/icons/sad.svg +1 -0
  353. package/dist/runtime/icons/save.svg +1 -0
  354. package/dist/runtime/icons/script.svg +1 -0
  355. package/dist/runtime/icons/scrolltotop.svg +6 -0
  356. package/dist/runtime/icons/search.svg +1 -0
  357. package/dist/runtime/icons/selection.svg +5 -0
  358. package/dist/runtime/icons/spinner.svg +15 -0
  359. package/dist/runtime/icons/star.svg +1 -0
  360. package/dist/runtime/icons/swap-horizontal.svg +1 -0
  361. package/dist/runtime/icons/tablet.svg +1 -0
  362. package/dist/runtime/icons/textbox.svg +1 -0
  363. package/dist/runtime/icons/texturebox.svg +5 -0
  364. package/dist/runtime/icons/tiktok.svg +1 -0
  365. package/dist/runtime/icons/title.svg +1 -0
  366. package/dist/runtime/icons/tools.svg +1 -0
  367. package/dist/runtime/icons/translate.svg +5 -0
  368. package/dist/runtime/icons/tree.svg +5 -0
  369. package/dist/runtime/icons/tutor.svg +1 -0
  370. package/dist/runtime/icons/ui-list-horizontal.svg +19 -0
  371. package/dist/runtime/icons/ui-list-sidebar.svg +21 -0
  372. package/dist/runtime/icons/ui-list-vertical.svg +9 -0
  373. package/dist/runtime/icons/undo.svg +12 -0
  374. package/dist/runtime/icons/unstar.svg +1 -0
  375. package/dist/runtime/icons/upload.svg +1 -0
  376. package/dist/runtime/icons/user.svg +1 -0
  377. package/dist/runtime/icons/video-outline.svg +1 -0
  378. package/dist/runtime/icons/vimeo.svg +3 -0
  379. package/dist/runtime/icons/window-maximize.svg +1 -0
  380. package/dist/runtime/icons/window-minimize.svg +1 -0
  381. package/dist/runtime/icons/youtube.svg +3 -0
  382. package/dist/runtime/plugins/blokkliEditable.d.ts +2 -0
  383. package/dist/runtime/plugins/blokkliEditable.js +31 -0
  384. package/dist/runtime/public/Inter.var.woff2 +0 -0
  385. package/dist/runtime/types/blokkOptions.d.ts +83 -0
  386. package/dist/runtime/types/blokkOptions.js +0 -0
  387. package/dist/runtime/types/generatedModuleTypes.d.ts +41 -0
  388. package/dist/runtime/types/generatedModuleTypes.js +0 -0
  389. package/dist/runtime/types/index.d.ts +1052 -0
  390. package/dist/runtime/types/index.js +1 -0
  391. package/dist/runtime/types/theme.d.ts +33 -0
  392. package/dist/runtime/types/theme.js +0 -0
  393. package/dist/types.d.mts +1 -0
  394. package/dist/types.d.ts +1 -0
  395. package/package.json +103 -0
@@ -0,0 +1,357 @@
1
+ <template>
2
+ <div
3
+ v-if="loaded"
4
+ ref="root"
5
+ :style="style"
6
+ class="bk-editable-field bk-control"
7
+ >
8
+ <form ref="form" class="bk-editable-field-input" @submit.prevent="close">
9
+ <div class="bk bk-editable-field-buttons">
10
+ <h3>
11
+ <ItemIcon :bundle="itemBundle" />
12
+ <span>{{ title }}</span>
13
+ </h3>
14
+ <button @click.prevent="cancel">
15
+ <Icon name="close" />
16
+ <span>{{ $t('cancel', 'Cancel') }}</span>
17
+ </button>
18
+ <button :disabled="!hasChanged" type="submit" @click.prevent="save">
19
+ <Icon name="save" />
20
+ <span>{{ $t('save', 'Save') }}</span>
21
+ </button>
22
+ </div>
23
+
24
+ <div ref="input">
25
+ <InputContenteditable
26
+ v-if="config.type === 'markup'"
27
+ v-model="modelValue"
28
+ :type="config.type"
29
+ @close="save"
30
+ />
31
+
32
+ <InputFrame
33
+ v-else-if="config.type === 'frame'"
34
+ v-model="modelValue"
35
+ :type="config.type"
36
+ :field-name="fieldName"
37
+ :host="host"
38
+ :initial-height="scrollHeight"
39
+ @close="save"
40
+ />
41
+
42
+ <InputPlaintext
43
+ v-else
44
+ v-model="modelValue"
45
+ :element="element"
46
+ :required="required"
47
+ :maxlength="maxlength"
48
+ @close="cancel"
49
+ @save="save"
50
+ />
51
+ </div>
52
+
53
+ <div v-if="!isMarkup" class="bk bk-editable-field-info">
54
+ <div v-if="errorText" class="bk-editable-field-info-error">
55
+ {{ errorText }}
56
+ </div>
57
+ <div class="bk-editable-field-info-count">
58
+ <span>{{ count }}</span>
59
+ <span v-if="maxlength >= 1">&nbsp;/&nbsp;{{ maxlength }}</span>
60
+ </div>
61
+ </div>
62
+ </form>
63
+ </div>
64
+ </template>
65
+
66
+ <script lang="ts" setup>
67
+ import type {
68
+ DraggableExistingBlock,
69
+ EntityContext,
70
+ EditableFieldConfig,
71
+ } from '#blokkli/types'
72
+ import { Icon, ItemIcon } from '#blokkli/components'
73
+ import {
74
+ computed,
75
+ ref,
76
+ watch,
77
+ onMounted,
78
+ onBeforeUnmount,
79
+ useBlokkli,
80
+ nextTick,
81
+ } from '#imports'
82
+ import { falsy, findIdealRectPosition } from '#blokkli/helpers'
83
+ import InputPlaintext from './Plaintext/index.vue'
84
+ import InputContenteditable from './Contenteditable/index.vue'
85
+ import InputFrame from './Frame/index.vue'
86
+ import onBlokkliEvent from '#blokkli/helpers/composables/onBlokkliEvent'
87
+
88
+ const { eventBus, ui, selection, state, adapter, $t, types } = useBlokkli()
89
+
90
+ const props = defineProps<{
91
+ fieldName: string
92
+ host: DraggableExistingBlock | EntityContext
93
+ element: HTMLElement
94
+ config: EditableFieldConfig
95
+ isComponent?: boolean
96
+ value?: string
97
+ }>()
98
+
99
+ const emit = defineEmits(['close'])
100
+
101
+ const shouldSave = ref(true)
102
+
103
+ const cancel = () => {
104
+ shouldSave.value = false
105
+ close()
106
+ emit('close')
107
+ }
108
+
109
+ const save = () => {
110
+ shouldSave.value = true
111
+ close()
112
+ emit('close')
113
+ }
114
+
115
+ // Save the editable when clicking away from the text area.
116
+ onBlokkliEvent('window:clickAway', save)
117
+
118
+ const getElement = (): HTMLElement => props.element
119
+
120
+ type Alignment = 'left' | 'center' | 'right'
121
+
122
+ const alignment = computed<Alignment>(() => {
123
+ if (props.element) {
124
+ const style = window.getComputedStyle(props.element)
125
+ if (
126
+ style.textAlign === 'left' ||
127
+ style.textAlign === 'center' ||
128
+ style.textAlign === 'right'
129
+ ) {
130
+ return style.textAlign
131
+ } else if (style.textAlign === 'start') {
132
+ return 'left'
133
+ } else if (style.textAlign === 'end') {
134
+ return 'right'
135
+ }
136
+ }
137
+ return 'center'
138
+ })
139
+
140
+ const scrollHeight = ref(0)
141
+ const loaded = ref(false)
142
+ const originalText = ref(props.value || '')
143
+ const modelValue = ref('')
144
+ const width = ref(320)
145
+ const inputStyle = ref<Record<string, any>>({})
146
+ const form = ref<HTMLFormElement | null>(null)
147
+ const root = ref<HTMLDivElement | null>(null)
148
+ const input = ref<HTMLDivElement | null>(null)
149
+
150
+ const x = ref(0)
151
+ const y = ref(0)
152
+
153
+ const style = computed(() => {
154
+ if (ui.isMobile.value) {
155
+ return {}
156
+ } else {
157
+ return {
158
+ width: width.value + 'px',
159
+ top: y.value + 'px',
160
+ left: x.value + 'px',
161
+ }
162
+ }
163
+ })
164
+
165
+ const hasChanged = computed(() => modelValue.value !== originalText.value)
166
+ const itemBundle = computed(() => {
167
+ if ('itemBundle' in props.host) {
168
+ return props.host.itemBundle
169
+ }
170
+ return undefined
171
+ })
172
+ const maxlength = computed(() => props.config.maxLength)
173
+ const required = computed(() => !!props.config.required)
174
+ const title = computed(() => {
175
+ if (itemBundle.value) {
176
+ return [
177
+ types.getBlockBundleDefinition(itemBundle.value)?.label,
178
+ props.config.label,
179
+ ]
180
+ .filter(falsy)
181
+ .join(' » ')
182
+ }
183
+
184
+ return props.config.label
185
+ })
186
+ const isMarkup = computed(
187
+ () =>
188
+ props.config.type === 'table' ||
189
+ props.config.type === 'markup' ||
190
+ props.config.type === 'frame',
191
+ )
192
+
193
+ const count = computed(() => modelValue.value.length)
194
+
195
+ const errorText = computed(() => {
196
+ if (required.value && !modelValue.value) {
197
+ return $t('fieldIsRequired', 'This field is required')
198
+ }
199
+
200
+ return undefined
201
+ })
202
+
203
+ const close = async () => {
204
+ // Weird iOS bug: Close method is called twice, so we have to check if we
205
+ // are actually still editing.
206
+ if (!selection.editableActive.value) {
207
+ return
208
+ }
209
+ if (shouldSave.value && errorText.value) {
210
+ return
211
+ }
212
+
213
+ const el = getElement()
214
+
215
+ if (shouldSave.value && modelValue.value !== originalText.value) {
216
+ if ('itemBundle' in props.host) {
217
+ await state.mutateWithLoadingState(() =>
218
+ adapter.updateFieldValue!({
219
+ uuid: props.host.uuid,
220
+ fieldName: props.fieldName,
221
+ fieldValue: modelValue.value,
222
+ }),
223
+ )
224
+ } else if (adapter.updateEntityFieldValue) {
225
+ await state.mutateWithLoadingState(() =>
226
+ adapter.updateEntityFieldValue!({
227
+ fieldName: props.fieldName,
228
+ fieldValue: modelValue.value,
229
+ }),
230
+ )
231
+ }
232
+ }
233
+ if (!shouldSave.value && el && !props.isComponent) {
234
+ if (isMarkup.value) {
235
+ el.innerHTML = originalText.value
236
+ } else {
237
+ el.textContent = originalText.value
238
+ }
239
+ }
240
+ if (el) {
241
+ el.dataset.blokkliEditableActive = undefined
242
+ }
243
+ }
244
+
245
+ watch(modelValue, (newText) => {
246
+ if (props.element && selection.editableActive.value && !props.isComponent) {
247
+ const el = getElement()
248
+ if (props.config.type === 'plain') {
249
+ el.textContent = newText
250
+ } else {
251
+ el.innerHTML = newText
252
+ }
253
+ }
254
+
255
+ if (props.isComponent) {
256
+ eventBus.emit('editable:update', {
257
+ name: props.fieldName,
258
+ entityUuid: props.host.uuid,
259
+ value: newText,
260
+ })
261
+ }
262
+ })
263
+
264
+ const focusInput = (el?: HTMLElement | Document | null) => {
265
+ if (!el) {
266
+ return
267
+ }
268
+
269
+ const textarea = el.querySelector('textarea')
270
+ if (textarea) {
271
+ textarea.focus()
272
+ return
273
+ }
274
+
275
+ const editable = el.querySelector('[contenteditable]')
276
+ if (editable instanceof HTMLElement) {
277
+ editable.focus()
278
+ return
279
+ }
280
+
281
+ const iframe = el.querySelector('iframe')
282
+
283
+ if (iframe?.contentDocument) {
284
+ focusInput(iframe.contentDocument)
285
+ }
286
+ }
287
+
288
+ const onAnimationFrame = () => {
289
+ if (ui.isMobile.value) {
290
+ return
291
+ }
292
+ const elementRect = props.element.getBoundingClientRect()
293
+
294
+ const height = form.value?.scrollHeight || 100
295
+ const newWidth = Math.min(Math.max(elementRect.width, 360), 1000)
296
+
297
+ const ideal = findIdealRectPosition(
298
+ ui.viewportBlockingRects.value,
299
+ {
300
+ x:
301
+ alignment.value === 'left'
302
+ ? elementRect.x
303
+ : elementRect.x + (Math.max(elementRect.width, 360) - newWidth) / 2,
304
+ y: elementRect.y - height - 20,
305
+ height,
306
+ width: newWidth,
307
+ },
308
+ ui.visibleViewportPadded.value,
309
+ )
310
+
311
+ x.value = ideal.x
312
+ y.value = ideal.y + height
313
+ width.value = newWidth
314
+ }
315
+
316
+ onAnimationFrame()
317
+
318
+ onBlokkliEvent('animationFrame', onAnimationFrame)
319
+
320
+ onMounted(() => {
321
+ const el = getElement()
322
+
323
+ if (props.isComponent) {
324
+ modelValue.value = props.value || ''
325
+ } else {
326
+ if (isMarkup.value) {
327
+ modelValue.value = el.innerHTML
328
+ } else {
329
+ modelValue.value = el.textContent || ''
330
+ }
331
+ }
332
+
333
+ originalText.value = modelValue.value
334
+
335
+ selection.editableActive.value = true
336
+ el.dataset.blokkliEditableActive = 'true'
337
+
338
+ const computedStyle = window.getComputedStyle(el)
339
+ inputStyle.value = {
340
+ textAlign: computedStyle.textAlign,
341
+ }
342
+
343
+ nextTick(() => {
344
+ scrollHeight.value = el.scrollHeight
345
+ loaded.value = true
346
+ nextTick(() => {
347
+ focusInput(form.value)
348
+ })
349
+ })
350
+ })
351
+
352
+ onBeforeUnmount(async () => {
353
+ const el = getElement()
354
+ await close()
355
+ el.dataset.blokkliEditableActive = undefined
356
+ })
357
+ </script>
@@ -0,0 +1,192 @@
1
+ <template>
2
+ <Teleport to="body">
3
+ <Transition :name="hasTransition ? 'bk-editable' : undefined">
4
+ <Overlay v-if="editable" v-bind="editable" :key="key" @close="close" />
5
+ </Transition>
6
+ </Teleport>
7
+ </template>
8
+
9
+ <script lang="ts" setup>
10
+ import {
11
+ computed,
12
+ ref,
13
+ useBlokkli,
14
+ watch,
15
+ defineBlokkliFeature,
16
+ } from '#imports'
17
+ import Overlay from './Overlay/index.vue'
18
+ import type {
19
+ DraggableExistingBlock,
20
+ EditableFieldConfig,
21
+ EntityContext,
22
+ } from '#blokkli/types'
23
+ import onBlokkliEvent from '#blokkli/helpers/composables/onBlokkliEvent'
24
+ import defineCommands from '#blokkli/helpers/composables/defineCommands'
25
+ import { falsy } from '#blokkli/helpers'
26
+
27
+ defineBlokkliFeature({
28
+ id: 'editable-field',
29
+ icon: 'textbox',
30
+ label: 'Editable Field',
31
+ requiredAdapterMethods: ['updateFieldValue', 'getEditableFieldConfig'],
32
+ description: 'Implements a form overlay to edit a single field of a block.',
33
+ })
34
+
35
+ type Editable = {
36
+ fieldName: string
37
+ host: DraggableExistingBlock | EntityContext
38
+ element: HTMLElement
39
+ config: EditableFieldConfig
40
+ isComponent?: boolean
41
+ value?: string
42
+ }
43
+
44
+ const { selection, adapter, types, $t, dom, runtimeConfig } = useBlokkli()
45
+ const editable = ref<Editable | null>(null)
46
+ const hasTransition = ref(false)
47
+
48
+ const key = computed(() => {
49
+ if (!editable.value) {
50
+ return ''
51
+ }
52
+ return editable.value.host.uuid + editable.value.fieldName
53
+ })
54
+
55
+ const getHost = (
56
+ uuid?: string,
57
+ ): DraggableExistingBlock | EntityContext | undefined => {
58
+ if (uuid) {
59
+ const block = dom.findBlock(uuid)
60
+ if (block) {
61
+ return block
62
+ }
63
+ }
64
+
65
+ return dom.findClosestEntityContext(dom.getActiveProviderElement())
66
+ }
67
+
68
+ const buildEditable = (
69
+ fieldName: string,
70
+ uuid?: string,
71
+ ): Editable | undefined => {
72
+ const host = getHost(uuid)
73
+ if (!host) {
74
+ return
75
+ }
76
+ const hostEntityType =
77
+ 'type' in host ? host.type : runtimeConfig.itemEntityType
78
+ const hostEntityBundle = 'bundle' in host ? host.bundle : host.itemBundle
79
+
80
+ const config = types.editableFieldConfig.forName(
81
+ hostEntityType,
82
+ hostEntityBundle,
83
+ fieldName,
84
+ )
85
+
86
+ if (!config) {
87
+ throw new Error(
88
+ `Failed to load editable field config for field "${fieldName}" on entity type "${hostEntityType}" of bundle "${hostEntityBundle}"`,
89
+ )
90
+ }
91
+
92
+ // Adapter doesn't support editable frames, return.
93
+ if (config.type === 'frame' && !adapter.buildEditableFrameUrl) {
94
+ return
95
+ }
96
+
97
+ const hostElement =
98
+ 'itemBundle' in host ? host.element() : dom.getActiveProviderElement()
99
+ const element = hostElement.querySelector(
100
+ `[data-blokkli-editable-field="${fieldName}"]`,
101
+ )
102
+
103
+ if (!(element instanceof HTMLElement)) {
104
+ return
105
+ }
106
+
107
+ return {
108
+ fieldName,
109
+ host,
110
+ element,
111
+ isComponent: element.dataset.blokkliEditableComponent === 'true',
112
+ value: element.dataset.blokkliEditableValue || '',
113
+ config,
114
+ }
115
+ }
116
+
117
+ onBlokkliEvent('editable:focus', (e) => {
118
+ hasTransition.value = !editable.value
119
+ editable.value = buildEditable(e.fieldName, e.uuid) || null
120
+ if (editable.value) {
121
+ selection.editableActive.value = true
122
+ }
123
+ })
124
+
125
+ defineCommands(() => {
126
+ // Find editable fields in the current selection.
127
+ const editables: Editable[] = selection.blocks.value.flatMap((v) => {
128
+ return [...v.element().querySelectorAll('[data-blokkli-editable-field]')]
129
+ .map((el) => {
130
+ if (!(el instanceof HTMLElement)) {
131
+ return
132
+ }
133
+
134
+ // Find closest block.
135
+ const block = el.closest('[data-uuid]')
136
+ if (!(block instanceof HTMLElement)) {
137
+ return
138
+ }
139
+
140
+ // Skip editable fields of nested blocks because this would lead to a
141
+ // ton of commands with the same name, e.g. when the selected block
142
+ // has 20 nested blocks with editable fields. This would be pretty
143
+ // useless.
144
+ if (block.dataset.uuid !== v.uuid) {
145
+ return
146
+ }
147
+
148
+ const name = el.dataset.blokkliEditableField
149
+ if (!name) {
150
+ return
151
+ }
152
+
153
+ return buildEditable(name, block.dataset.uuid)
154
+ })
155
+ .filter(falsy)
156
+ })
157
+
158
+ return editables.map((v) => {
159
+ return {
160
+ id: 'feature:editable:edit:' + v.fieldName,
161
+ group: 'selection',
162
+ label: $t('editableCommandEdit', 'Edit field "@name"').replace(
163
+ '@name',
164
+ v.config.label,
165
+ ),
166
+ icon: 'textbox',
167
+ disabled: false,
168
+ callback: () => {
169
+ editable.value = v
170
+ },
171
+ }
172
+ })
173
+ })
174
+
175
+ watch(selection.editableActive, (isActive) => {
176
+ if (!isActive) {
177
+ hasTransition.value = true
178
+ editable.value = null
179
+ }
180
+ })
181
+
182
+ watch(editable, (v) => {
183
+ if (!v && selection.editableActive.value) {
184
+ selection.editableActive.value = false
185
+ }
186
+ })
187
+
188
+ const close = () => {
189
+ editable.value = null
190
+ selection.editableActive.value = false
191
+ }
192
+ </script>
@@ -0,0 +1,64 @@
1
+ <template>
2
+ <PluginViewOption
3
+ id="mask"
4
+ v-model="isActive"
5
+ :label="$t('maskToggle', 'Toggle non-editable areas')"
6
+ :title-on="$t('maskShow', 'Show non-editable areas')"
7
+ :title-off="$t('maskHide', 'Hide non-editable areas')"
8
+ :tour-text="
9
+ $t(
10
+ 'maskTourText',
11
+ 'Toggle between showing or hiding non-editable parts of the page.',
12
+ )
13
+ "
14
+ icon="texturebox"
15
+ key-code="M"
16
+ />
17
+ </template>
18
+
19
+ <script lang="ts" setup>
20
+ import {
21
+ useBlokkli,
22
+ defineBlokkliFeature,
23
+ ref,
24
+ watch,
25
+ onMounted,
26
+ onBeforeUnmount,
27
+ } from '#imports'
28
+ import { PluginViewOption } from '#blokkli/plugins'
29
+
30
+ const HIDE_CLASS = 'bk-hide-non-editable'
31
+
32
+ defineBlokkliFeature({
33
+ id: 'editable-mask',
34
+ icon: 'texturebox',
35
+ label: 'Editable Mask',
36
+ description: 'Provides a view option to hide non-editable parts of the page.',
37
+ viewports: ['desktop'],
38
+ })
39
+
40
+ const { $t } = useBlokkli()
41
+
42
+ const isActive = ref(false)
43
+
44
+ const setRootClass = () => {
45
+ document.documentElement.classList.remove(HIDE_CLASS)
46
+ if (isActive.value) {
47
+ document.documentElement.classList.add(HIDE_CLASS)
48
+ }
49
+ }
50
+
51
+ watch(isActive, setRootClass)
52
+
53
+ onMounted(setRootClass)
54
+
55
+ onBeforeUnmount(() => {
56
+ document.documentElement.classList.remove(HIDE_CLASS)
57
+ })
58
+ </script>
59
+
60
+ <script lang="ts">
61
+ export default {
62
+ name: 'EditableMask',
63
+ }
64
+ </script>
@@ -0,0 +1,108 @@
1
+ <template>
2
+ <Teleport to="#bk-toolbar-title">
3
+ <button
4
+ ref="buttonEl"
5
+ class="bk-toolbar-button"
6
+ @click="eventBus.emit('editEntity')"
7
+ >
8
+ <div class="bk-toolbar-title">
9
+ <div>
10
+ <span
11
+ class="bk-status-indicator"
12
+ :class="{
13
+ 'bk-is-success': entity.status && !mutations.length,
14
+ 'bk-is-warning': entity.status && mutations.length,
15
+ }"
16
+ />
17
+ <strong>{{ entity.label }}</strong>
18
+ <span>&nbsp;{{ entity.bundleLabel }}</span>
19
+ </div>
20
+ </div>
21
+ <div class="bk-tooltip">
22
+ <span v-if="entity.status && !mutations.length">{{
23
+ statusPublished
24
+ }}</span>
25
+ <span v-else-if="entity.status && mutations.length">{{
26
+ statusPending
27
+ }}</span>
28
+ <span v-else>{{ statusUnpublished }}</span>
29
+ </div>
30
+ </button>
31
+ </Teleport>
32
+ </template>
33
+
34
+ <script lang="ts" setup>
35
+ import defineCommands from '#blokkli/helpers/composables/defineCommands'
36
+ import { useBlokkli, defineBlokkliFeature, ref, computed } from '#imports'
37
+ import defineTourItem from '#blokkli/helpers/composables/defineTourItem'
38
+
39
+ defineBlokkliFeature({
40
+ id: 'entity-title',
41
+ icon: 'title',
42
+ label: 'Entity Title',
43
+ description: 'Renders the title and status of the page entity.',
44
+ })
45
+
46
+ const { state, eventBus, $t } = useBlokkli()
47
+ const { entity, mutations } = state
48
+ const buttonEl = ref<HTMLButtonElement | null>(null)
49
+
50
+ const statusPublished = computed(() =>
51
+ $t('pageIsPublished', 'Page is published'),
52
+ )
53
+
54
+ const statusPending = computed(() =>
55
+ $t(
56
+ 'pageIsPublishedWithPendingChanges',
57
+ 'Page is published (changes pending)',
58
+ ),
59
+ )
60
+
61
+ const statusUnpublished = computed(() =>
62
+ $t('pageIsNotPublished', 'Page is not published'),
63
+ )
64
+
65
+ defineCommands(() => {
66
+ return {
67
+ id: 'feature:entity-title:edit-entity',
68
+ group: 'misc',
69
+ label: $t('editFormEntityEdit', 'Edit @label').replace(
70
+ '@label',
71
+ entity.value.label || 'Page',
72
+ ),
73
+ callback: () => eventBus.emit('editEntity'),
74
+ icon: 'edit',
75
+ }
76
+ })
77
+
78
+ const tourText = computed(() => {
79
+ const intro = $t(
80
+ 'entityTitleTourText',
81
+ '<p>Shows the title and status of the current page.</p><p>Click on the title to open the page edit form.</p>',
82
+ )
83
+
84
+ return `
85
+ ${intro}
86
+ <ul>
87
+ <li><div class="bk-status-indicator"></div>${statusUnpublished.value}</li>
88
+ <li><div class="bk-status-indicator bk-is-warning"></div>${statusPending.value}</li>
89
+ <li><div class="bk-status-indicator bk-is-success"></div>${statusPublished.value}</li>
90
+ </ul>
91
+ `
92
+ })
93
+
94
+ defineTourItem(() => {
95
+ return {
96
+ id: 'entity-title',
97
+ title: $t('entityTitleTourTitle', 'Page'),
98
+ text: tourText.value,
99
+ element: buttonEl.value,
100
+ }
101
+ })
102
+ </script>
103
+
104
+ <script lang="ts">
105
+ export default {
106
+ name: 'EntityTitle',
107
+ }
108
+ </script>