@blokkli/editor 1.4.0-alpha.1 → 2.0.0-alpha.2

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 (439) hide show
  1. package/dist/module.d.mts +12 -194
  2. package/dist/module.json +4 -4
  3. package/dist/module.mjs +1847 -1306
  4. package/dist/modules/drupal/adapter/index.d.mts +6 -0
  5. package/dist/modules/drupal/adapter/index.mjs +762 -0
  6. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliEditState.graphql +44 -0
  7. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliMutatedField.graphql +11 -0
  8. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliMutationItem.graphql +9 -0
  9. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliMutationResult.graphql +7 -0
  10. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliViolation.graphql +7 -0
  11. package/dist/modules/drupal/graphql/base/query.pbConfig.graphql +96 -0
  12. package/dist/modules/drupal/graphql/base/query.pbEditState.graphql +15 -0
  13. package/dist/modules/drupal/graphql/features/conversions.graphql +44 -0
  14. package/dist/modules/drupal/graphql/features/import-existing.graphql +34 -0
  15. package/dist/{runtime/adapter/drupal/graphql → modules/drupal/graphql/features}/library.graphql +17 -0
  16. package/dist/modules/drupal/graphql/features/media-library.graphql +28 -0
  17. package/dist/modules/drupal/graphql/features/preview-grant.graphql +13 -0
  18. package/dist/modules/drupal/graphql/features/publish.graphql +15 -0
  19. package/dist/modules/drupal/graphql/features/publishNew.graphql +59 -0
  20. package/dist/modules/drupal/graphql/mutations/add.graphql +25 -0
  21. package/dist/modules/drupal/graphql/mutations/add_clipboard_text.graphql +25 -0
  22. package/dist/modules/drupal/graphql/mutations/add_entity_reference.graphql +31 -0
  23. package/dist/modules/drupal/graphql/mutations/add_entity_reference_multiple.graphql +25 -0
  24. package/dist/modules/drupal/graphql/mutations/add_file.graphql +27 -0
  25. package/dist/modules/drupal/graphql/mutations/add_image.graphql +27 -0
  26. package/dist/modules/drupal/graphql/mutations/add_video_remote.graphql +25 -0
  27. package/dist/modules/drupal/graphql/mutations/bulk_update_behavior_settings.graphql +15 -0
  28. package/dist/modules/drupal/graphql/mutations/duplicate.graphql +33 -0
  29. package/dist/modules/drupal/graphql/mutations/move.graphql +25 -0
  30. package/dist/modules/drupal/graphql/mutations/move_multiple.graphql +25 -0
  31. package/dist/modules/drupal/graphql/mutations/redo.graphql +14 -0
  32. package/dist/modules/drupal/graphql/mutations/remove.graphql +15 -0
  33. package/dist/modules/drupal/graphql/mutations/remove_multiple.graphql +15 -0
  34. package/dist/modules/drupal/graphql/mutations/replace_host_entity_media.graphql +20 -0
  35. package/dist/modules/drupal/graphql/mutations/replace_media.graphql +22 -0
  36. package/dist/modules/drupal/graphql/mutations/revertAllChanges.graphql +14 -0
  37. package/dist/modules/drupal/graphql/mutations/setHistoryIndex.graphql +15 -0
  38. package/dist/modules/drupal/graphql/mutations/setMutationStatus.graphql +16 -0
  39. package/dist/modules/drupal/graphql/mutations/takeOwnership.graphql +14 -0
  40. package/dist/modules/drupal/graphql/mutations/undo.graphql +14 -0
  41. package/dist/modules/drupal/graphql/mutations/update_behavior_setting.graphql +23 -0
  42. package/dist/modules/drupal/graphql/mutations/update_field_value.graphql +22 -0
  43. package/dist/modules/drupal/graphql/mutations/update_host_entity_field_value.graphql +20 -0
  44. package/dist/modules/drupal/index.d.mts +10 -0
  45. package/dist/modules/drupal/index.mjs +170 -0
  46. package/dist/runtime/adapter/index.d.ts +30 -4
  47. package/dist/runtime/blokkliPlugins/AddAction/index.vue +39 -54
  48. package/dist/runtime/blokkliPlugins/AddAction/index.vue.d.ts +26 -0
  49. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue +38 -64
  50. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue.d.ts +12 -0
  51. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue +19 -30
  52. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue.d.ts +37 -0
  53. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue +15 -23
  54. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue.d.ts +21 -0
  55. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue +28 -45
  56. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue.d.ts +41 -0
  57. package/dist/runtime/blokkliPlugins/ItemAction/index.vue +39 -85
  58. package/dist/runtime/blokkliPlugins/ItemAction/index.vue.d.ts +83 -0
  59. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue +22 -26
  60. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue.d.ts +17 -0
  61. package/dist/runtime/blokkliPlugins/MenuButton/index.vue +30 -38
  62. package/dist/runtime/blokkliPlugins/MenuButton/index.vue.d.ts +32 -0
  63. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue +146 -211
  64. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue.d.ts +91 -0
  65. package/dist/runtime/blokkliPlugins/Sidebar/index.vue +95 -139
  66. package/dist/runtime/blokkliPlugins/Sidebar/index.vue.d.ts +85 -0
  67. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue +38 -57
  68. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue.d.ts +48 -0
  69. package/dist/runtime/blokkliPlugins/TourItem/index.vue +20 -29
  70. package/dist/runtime/blokkliPlugins/TourItem/index.vue.d.ts +20 -0
  71. package/dist/runtime/blokkliPlugins/ViewOption/index.vue +45 -59
  72. package/dist/runtime/blokkliPlugins/ViewOption/index.vue.d.ts +39 -0
  73. package/dist/runtime/components/Blocks/Fragment/index.vue +13 -20
  74. package/dist/runtime/components/Blocks/Fragment/index.vue.d.ts +6 -0
  75. package/dist/runtime/components/Blocks/FromLibrary/index.vue +19 -29
  76. package/dist/runtime/components/Blocks/FromLibrary/index.vue.d.ts +6 -0
  77. package/dist/runtime/components/BlokkliEditable.vue +30 -49
  78. package/dist/runtime/components/BlokkliEditable.vue.d.ts +20 -0
  79. package/dist/runtime/components/BlokkliField.vue +101 -159
  80. package/dist/runtime/components/BlokkliField.vue.d.ts +49 -0
  81. package/dist/runtime/components/BlokkliItem.vue +43 -66
  82. package/dist/runtime/components/BlokkliItem.vue.d.ts +26 -0
  83. package/dist/runtime/components/BlokkliProvider.vue +51 -87
  84. package/dist/runtime/components/BlokkliProvider.vue.d.ts +34 -0
  85. package/dist/runtime/components/Edit/Actions/index.vue +116 -164
  86. package/dist/runtime/components/Edit/Actions/index.vue.d.ts +2 -0
  87. package/dist/runtime/components/Edit/AddListItem/index.vue +45 -66
  88. package/dist/runtime/components/Edit/AddListItem/index.vue.d.ts +28 -0
  89. package/dist/runtime/components/Edit/AnimationCanvas/index.vue +52 -88
  90. package/dist/runtime/components/Edit/AnimationCanvas/index.vue.d.ts +2 -0
  91. package/dist/runtime/components/Edit/AppMenu/index.vue +12 -15
  92. package/dist/runtime/components/Edit/AppMenu/index.vue.d.ts +2 -0
  93. package/dist/runtime/components/Edit/BlockProxy/index.vue +48 -82
  94. package/dist/runtime/components/Edit/BlockProxy/index.vue.d.ts +10 -0
  95. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue +17 -21
  96. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue.d.ts +23 -0
  97. package/dist/runtime/components/Edit/Dialog/index.vue +67 -103
  98. package/dist/runtime/components/Edit/Dialog/index.vue.d.ts +44 -0
  99. package/dist/runtime/components/Edit/DragInteractions/index.vue +219 -333
  100. package/dist/runtime/components/Edit/DragInteractions/index.vue.d.ts +2 -0
  101. package/dist/runtime/components/Edit/DraggableList.vue +82 -125
  102. package/dist/runtime/components/Edit/DraggableList.vue.d.ts +27 -0
  103. package/dist/runtime/components/Edit/EditIndicator.vue +34 -46
  104. package/dist/runtime/components/Edit/EditIndicator.vue.d.ts +11 -0
  105. package/dist/runtime/components/Edit/EditProvider.vue +146 -142
  106. package/dist/runtime/components/Edit/EditProvider.vue.d.ts +26 -0
  107. package/dist/runtime/components/Edit/Features/AddList/index.vue +90 -117
  108. package/dist/runtime/components/Edit/Features/AddList/index.vue.d.ts +2 -0
  109. package/dist/runtime/components/Edit/Features/Artboard/Overview/index.vue +43 -63
  110. package/dist/runtime/components/Edit/Features/Artboard/Overview/index.vue.d.ts +6 -0
  111. package/dist/runtime/components/Edit/Features/Artboard/Scrollbar/index.vue +18 -23
  112. package/dist/runtime/components/Edit/Features/Artboard/Scrollbar/index.vue.d.ts +7 -0
  113. package/dist/runtime/components/Edit/Features/Artboard/index.vue +174 -223
  114. package/dist/runtime/components/Edit/Features/Artboard/index.vue.d.ts +2 -0
  115. package/dist/runtime/components/Edit/Features/Assistant/Overlay/ResultMarkup/index.vue +7 -7
  116. package/dist/runtime/components/Edit/Features/Assistant/Overlay/ResultMarkup/index.vue.d.ts +6 -0
  117. package/dist/runtime/components/Edit/Features/Assistant/Overlay/index.vue +41 -54
  118. package/dist/runtime/components/Edit/Features/Assistant/Overlay/index.vue.d.ts +8 -0
  119. package/dist/runtime/components/Edit/Features/Assistant/index.vue +31 -40
  120. package/dist/runtime/components/Edit/Features/Assistant/index.vue.d.ts +2 -0
  121. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue +225 -326
  122. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue.d.ts +2 -0
  123. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/File.vue +36 -44
  124. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/File.vue.d.ts +3 -0
  125. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/Video.vue +33 -35
  126. package/dist/runtime/components/Edit/Features/Clipboard/List/Item/Video.vue.d.ts +3 -0
  127. package/dist/runtime/components/Edit/Features/Clipboard/List/index.vue +13 -21
  128. package/dist/runtime/components/Edit/Features/Clipboard/List/index.vue.d.ts +10 -0
  129. package/dist/runtime/components/Edit/Features/Clipboard/index.vue +227 -298
  130. package/dist/runtime/components/Edit/Features/Clipboard/index.vue.d.ts +2 -0
  131. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue +24 -34
  132. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue.d.ts +22 -0
  133. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue +146 -195
  134. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue.d.ts +6 -0
  135. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue +21 -26
  136. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue.d.ts +2 -0
  137. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue +11 -14
  138. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue.d.ts +8 -0
  139. package/dist/runtime/components/Edit/Features/Comments/Comment/index.vue +21 -29
  140. package/dist/runtime/components/Edit/Features/Comments/Comment/index.vue.d.ts +23 -0
  141. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue +31 -43
  142. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue.d.ts +19 -0
  143. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue +70 -100
  144. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue.d.ts +18 -0
  145. package/dist/runtime/components/Edit/Features/Comments/index.vue +37 -48
  146. package/dist/runtime/components/Edit/Features/Comments/index.vue.d.ts +2 -0
  147. package/dist/runtime/components/Edit/Features/Conversions/index.vue +40 -56
  148. package/dist/runtime/components/Edit/Features/Conversions/index.vue.d.ts +2 -0
  149. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue +37 -50
  150. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue.d.ts +2 -0
  151. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue +35 -44
  152. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue.d.ts +2 -0
  153. package/dist/runtime/components/Edit/Features/Debug/index.vue +43 -57
  154. package/dist/runtime/components/Edit/Features/Debug/index.vue.d.ts +2 -0
  155. package/dist/runtime/components/Edit/Features/Delete/index.vue +31 -52
  156. package/dist/runtime/components/Edit/Features/Delete/index.vue.d.ts +2 -0
  157. package/dist/runtime/components/Edit/Features/Diff/DiffView/index.vue +75 -114
  158. package/dist/runtime/components/Edit/Features/Diff/DiffView/index.vue.d.ts +2 -0
  159. package/dist/runtime/components/Edit/Features/Diff/index.vue +17 -19
  160. package/dist/runtime/components/Edit/Features/Diff/index.vue.d.ts +2 -0
  161. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue +193 -337
  162. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue.d.ts +27 -0
  163. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/fragment.glsl +1 -1
  164. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue +391 -644
  165. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue.d.ts +156 -0
  166. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue +197 -323
  167. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue.d.ts +2 -0
  168. package/dist/runtime/components/Edit/Features/Duplicate/index.vue +49 -71
  169. package/dist/runtime/components/Edit/Features/Duplicate/index.vue.d.ts +2 -0
  170. package/dist/runtime/components/Edit/Features/Edit/index.vue +41 -71
  171. package/dist/runtime/components/Edit/Features/Edit/index.vue.d.ts +2 -0
  172. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue +35 -51
  173. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue.d.ts +11 -0
  174. package/dist/runtime/components/Edit/Features/EditForm/index.vue +104 -140
  175. package/dist/runtime/components/Edit/Features/EditForm/index.vue.d.ts +2 -0
  176. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Contenteditable/index.vue +18 -25
  177. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Contenteditable/index.vue.d.ts +12 -0
  178. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue +34 -50
  179. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue.d.ts +16 -0
  180. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue +40 -51
  181. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue.d.ts +16 -0
  182. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue +147 -209
  183. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue.d.ts +15 -0
  184. package/dist/runtime/components/Edit/Features/EditableField/index.vue +90 -143
  185. package/dist/runtime/components/Edit/Features/EditableField/index.vue.d.ts +2 -0
  186. package/dist/runtime/components/Edit/Features/EditableMask/index.vue +28 -36
  187. package/dist/runtime/components/Edit/Features/EditableMask/index.vue.d.ts +2 -0
  188. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue +49 -58
  189. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue.d.ts +2 -0
  190. package/dist/runtime/components/Edit/Features/Exit/index.vue +16 -20
  191. package/dist/runtime/components/Edit/Features/Exit/index.vue.d.ts +2 -0
  192. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue +4 -15
  193. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue.d.ts +2 -0
  194. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue +19 -21
  195. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue.d.ts +2 -0
  196. package/dist/runtime/components/Edit/Features/Fragments/Dialog/Item/index.vue +28 -35
  197. package/dist/runtime/components/Edit/Features/Fragments/Dialog/Item/index.vue.d.ts +8 -0
  198. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue +51 -74
  199. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue.d.ts +12 -0
  200. package/dist/runtime/components/Edit/Features/Fragments/index.vue +41 -51
  201. package/dist/runtime/components/Edit/Features/Fragments/index.vue.d.ts +2 -0
  202. package/dist/runtime/components/Edit/Features/Grid/index.vue +17 -20
  203. package/dist/runtime/components/Edit/Features/Grid/index.vue.d.ts +2 -0
  204. package/dist/runtime/components/Edit/Features/Help/Shortcuts/index.vue +24 -35
  205. package/dist/runtime/components/Edit/Features/Help/Shortcuts/index.vue.d.ts +2 -0
  206. package/dist/runtime/components/Edit/Features/Help/index.vue +19 -23
  207. package/dist/runtime/components/Edit/Features/Help/index.vue.d.ts +2 -0
  208. package/dist/runtime/components/Edit/Features/History/List/index.vue +49 -70
  209. package/dist/runtime/components/Edit/Features/History/List/index.vue.d.ts +5 -0
  210. package/dist/runtime/components/Edit/Features/History/index.vue +54 -69
  211. package/dist/runtime/components/Edit/Features/History/index.vue.d.ts +2 -0
  212. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue +48 -66
  213. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue.d.ts +14 -0
  214. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue +38 -54
  215. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue.d.ts +2 -0
  216. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue +90 -128
  217. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue.d.ts +13 -0
  218. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/Item/index.vue +29 -38
  219. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/Item/index.vue.d.ts +9 -0
  220. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue +68 -93
  221. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue.d.ts +12 -0
  222. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue +39 -49
  223. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue.d.ts +12 -0
  224. package/dist/runtime/components/Edit/Features/Library/index.vue +85 -117
  225. package/dist/runtime/components/Edit/Features/Library/index.vue.d.ts +2 -0
  226. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/Item.vue +13 -19
  227. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/Item.vue.d.ts +19 -0
  228. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue +76 -112
  229. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue.d.ts +6 -0
  230. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue +107 -140
  231. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue.d.ts +2 -0
  232. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue +128 -188
  233. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue.d.ts +12 -0
  234. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue +42 -57
  235. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue.d.ts +2 -0
  236. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue +27 -34
  237. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue.d.ts +14 -0
  238. package/dist/runtime/components/Edit/Features/Options/Form/Checkboxes/index.vue +55 -75
  239. package/dist/runtime/components/Edit/Features/Options/Form/Checkboxes/index.vue.d.ts +24 -0
  240. package/dist/runtime/components/Edit/Features/Options/Form/Color/index.vue +18 -21
  241. package/dist/runtime/components/Edit/Features/Options/Form/Color/index.vue.d.ts +12 -0
  242. package/dist/runtime/components/Edit/Features/Options/Form/DateTimeLocal/index.vue +36 -0
  243. package/dist/runtime/components/Edit/Features/Options/Form/DateTimeLocal/index.vue.d.ts +20 -0
  244. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue +7 -9
  245. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue.d.ts +29 -0
  246. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue +87 -93
  247. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue.d.ts +14 -0
  248. package/dist/runtime/components/Edit/Features/Options/Form/Number/index.vue +31 -45
  249. package/dist/runtime/components/Edit/Features/Options/Form/Number/index.vue.d.ts +21 -0
  250. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue +55 -79
  251. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue.d.ts +30 -0
  252. package/dist/runtime/components/Edit/Features/Options/Form/Range/index.vue +23 -33
  253. package/dist/runtime/components/Edit/Features/Options/Form/Range/index.vue.d.ts +18 -0
  254. package/dist/runtime/components/Edit/Features/Options/Form/Text/index.vue +17 -26
  255. package/dist/runtime/components/Edit/Features/Options/Form/Text/index.vue.d.ts +17 -0
  256. package/dist/runtime/components/Edit/Features/Options/Form/index.vue +178 -272
  257. package/dist/runtime/components/Edit/Features/Options/Form/index.vue.d.ts +9 -0
  258. package/dist/runtime/components/Edit/Features/Options/index.vue +38 -69
  259. package/dist/runtime/components/Edit/Features/Options/index.vue.d.ts +2 -0
  260. package/dist/runtime/components/Edit/Features/Ownership/index.vue +27 -34
  261. package/dist/runtime/components/Edit/Features/Ownership/index.vue.d.ts +2 -0
  262. package/dist/runtime/components/Edit/Features/Preview/index.vue +22 -27
  263. package/dist/runtime/components/Edit/Features/Preview/index.vue.d.ts +2 -0
  264. package/dist/runtime/components/Edit/Features/PreviewGrant/QrCode/index.vue +12 -16
  265. package/dist/runtime/components/Edit/Features/PreviewGrant/QrCode/index.vue.d.ts +5 -0
  266. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue +31 -36
  267. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue.d.ts +2 -0
  268. package/dist/runtime/components/Edit/Features/ProxyView/index.vue +18 -20
  269. package/dist/runtime/components/Edit/Features/ProxyView/index.vue.d.ts +2 -0
  270. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue +118 -0
  271. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue.d.ts +18 -0
  272. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue +251 -0
  273. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue.d.ts +19 -0
  274. package/dist/runtime/components/Edit/Features/Publish/Dialog/types.d.ts +7 -0
  275. package/dist/runtime/components/Edit/Features/Publish/index.vue +70 -74
  276. package/dist/runtime/components/Edit/Features/Publish/index.vue.d.ts +2 -0
  277. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue +48 -54
  278. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue.d.ts +27 -0
  279. package/dist/runtime/components/Edit/Features/ResponsivePreview/index.vue +77 -103
  280. package/dist/runtime/components/Edit/Features/ResponsivePreview/index.vue.d.ts +2 -0
  281. package/dist/runtime/components/Edit/Features/Revert/index.vue +27 -32
  282. package/dist/runtime/components/Edit/Features/Revert/index.vue.d.ts +2 -0
  283. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Content/index.vue +67 -88
  284. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Content/index.vue.d.ts +17 -0
  285. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue +89 -139
  286. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue.d.ts +18 -0
  287. package/dist/runtime/components/Edit/Features/Search/Overlay/index.vue +79 -108
  288. package/dist/runtime/components/Edit/Features/Search/Overlay/index.vue.d.ts +12 -0
  289. package/dist/runtime/components/Edit/Features/Search/index.vue +30 -37
  290. package/dist/runtime/components/Edit/Features/Search/index.vue.d.ts +2 -0
  291. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue +67 -103
  292. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue.d.ts +9 -0
  293. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue +28 -36
  294. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue.d.ts +5 -0
  295. package/dist/runtime/components/Edit/Features/Selection/index.vue +131 -217
  296. package/dist/runtime/components/Edit/Features/Selection/index.vue.d.ts +2 -0
  297. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue +50 -81
  298. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue.d.ts +9 -0
  299. package/dist/runtime/components/Edit/Features/Settings/Dialog/index.vue +73 -117
  300. package/dist/runtime/components/Edit/Features/Settings/Dialog/index.vue.d.ts +6 -0
  301. package/dist/runtime/components/Edit/Features/Settings/index.vue +41 -53
  302. package/dist/runtime/components/Edit/Features/Settings/index.vue.d.ts +2 -0
  303. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue +65 -101
  304. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue.d.ts +15 -0
  305. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue +71 -99
  306. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue.d.ts +12 -0
  307. package/dist/runtime/components/Edit/Features/Structure/List/index.vue +17 -26
  308. package/dist/runtime/components/Edit/Features/Structure/List/index.vue.d.ts +12 -0
  309. package/dist/runtime/components/Edit/Features/Structure/index.vue +31 -40
  310. package/dist/runtime/components/Edit/Features/Structure/index.vue.d.ts +2 -0
  311. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue +32 -53
  312. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue.d.ts +7 -0
  313. package/dist/runtime/components/Edit/Features/Theme/GeneratedCode/index.vue +7 -10
  314. package/dist/runtime/components/Edit/Features/Theme/GeneratedCode/index.vue.d.ts +2 -0
  315. package/dist/runtime/components/Edit/Features/Theme/index.vue +49 -63
  316. package/dist/runtime/components/Edit/Features/Theme/index.vue.d.ts +2 -0
  317. package/dist/runtime/components/Edit/Features/TouchActionBar/Bar/index.vue +9 -10
  318. package/dist/runtime/components/Edit/Features/TouchActionBar/Bar/index.vue.d.ts +12 -0
  319. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue +16 -19
  320. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue.d.ts +2 -0
  321. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue +119 -174
  322. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue.d.ts +6 -0
  323. package/dist/runtime/components/Edit/Features/Tour/Popup/index.vue +10 -12
  324. package/dist/runtime/components/Edit/Features/Tour/Popup/index.vue.d.ts +8 -0
  325. package/dist/runtime/components/Edit/Features/Tour/index.vue +21 -25
  326. package/dist/runtime/components/Edit/Features/Tour/index.vue.d.ts +2 -0
  327. package/dist/runtime/components/Edit/Features/Transform/index.vue +80 -120
  328. package/dist/runtime/components/Edit/Features/Transform/index.vue.d.ts +2 -0
  329. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue +21 -29
  330. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue.d.ts +6 -0
  331. package/dist/runtime/components/Edit/Features/Translations/index.vue +96 -139
  332. package/dist/runtime/components/Edit/Features/Translations/index.vue.d.ts +2 -0
  333. package/dist/runtime/components/Edit/Features/Validations/Overlay/Item.vue +21 -35
  334. package/dist/runtime/components/Edit/Features/Validations/Overlay/Item.vue.d.ts +6 -0
  335. package/dist/runtime/components/Edit/Features/Validations/Overlay/index.vue +30 -39
  336. package/dist/runtime/components/Edit/Features/Validations/Overlay/index.vue.d.ts +6 -0
  337. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue +20 -28
  338. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue.d.ts +9 -0
  339. package/dist/runtime/components/Edit/Features/Validations/index.vue +27 -33
  340. package/dist/runtime/components/Edit/Features/Validations/index.vue.d.ts +2 -0
  341. package/dist/runtime/components/Edit/Features/index.vue +33 -52
  342. package/dist/runtime/components/Edit/Features/index.vue.d.ts +6 -0
  343. package/dist/runtime/components/Edit/Form/Group/index.vue +23 -0
  344. package/dist/runtime/components/Edit/Form/Group/index.vue.d.ts +20 -0
  345. package/dist/runtime/components/Edit/Form/Item/index.vue +5 -0
  346. package/dist/runtime/components/Edit/Form/Item/index.vue.d.ts +14 -0
  347. package/dist/runtime/components/Edit/Form/Textarea/index.vue +27 -0
  348. package/dist/runtime/components/Edit/Form/Textarea/index.vue.d.ts +16 -0
  349. package/dist/runtime/components/Edit/Form/Toggle/index.vue +21 -0
  350. package/dist/runtime/components/Edit/Form/Toggle/index.vue.d.ts +14 -0
  351. package/dist/runtime/components/Edit/FormOverlay/Header/index.vue +11 -22
  352. package/dist/runtime/components/Edit/FormOverlay/Header/index.vue.d.ts +18 -0
  353. package/dist/runtime/components/Edit/FormOverlay/index.vue +15 -21
  354. package/dist/runtime/components/Edit/FormOverlay/index.vue.d.ts +25 -0
  355. package/dist/runtime/components/Edit/Highlight/index.vue +31 -70
  356. package/dist/runtime/components/Edit/Highlight/index.vue.d.ts +20 -0
  357. package/dist/runtime/components/Edit/Icon/index.vue +11 -14
  358. package/dist/runtime/components/Edit/Icon/index.vue.d.ts +7 -0
  359. package/dist/runtime/components/Edit/InfoBox/index.vue +5 -6
  360. package/dist/runtime/components/Edit/InfoBox/index.vue.d.ts +5 -0
  361. package/dist/runtime/components/Edit/ItemIcon/index.vue +13 -13
  362. package/dist/runtime/components/Edit/ItemIcon/index.vue.d.ts +6 -0
  363. package/dist/runtime/components/Edit/Loading/index.vue +8 -9
  364. package/dist/runtime/components/Edit/Loading/index.vue.d.ts +6 -0
  365. package/dist/runtime/components/Edit/Messages/Item/index.vue +30 -41
  366. package/dist/runtime/components/Edit/Messages/Item/index.vue.d.ts +11 -0
  367. package/dist/runtime/components/Edit/Messages/index.vue +13 -17
  368. package/dist/runtime/components/Edit/Messages/index.vue.d.ts +2 -0
  369. package/dist/runtime/components/Edit/Pagination/index.vue +6 -8
  370. package/dist/runtime/components/Edit/Pagination/index.vue.d.ts +12 -0
  371. package/dist/runtime/components/Edit/PreviewProvider.vue +124 -177
  372. package/dist/runtime/components/Edit/PreviewProvider.vue.d.ts +24 -0
  373. package/dist/runtime/components/Edit/RelativeTime/index.vue +19 -25
  374. package/dist/runtime/components/Edit/RelativeTime/index.vue.d.ts +15 -0
  375. package/dist/runtime/components/Edit/Resizable/index.vue +45 -55
  376. package/dist/runtime/components/Edit/Resizable/index.vue.d.ts +13 -0
  377. package/dist/runtime/components/Edit/ScaleToFit/index.vue +44 -62
  378. package/dist/runtime/components/Edit/ScaleToFit/index.vue.d.ts +15 -0
  379. package/dist/runtime/components/Edit/ScrollBoundary/index.vue +11 -27
  380. package/dist/runtime/components/Edit/ScrollBoundary/index.vue.d.ts +23 -0
  381. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue +47 -59
  382. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue.d.ts +20 -0
  383. package/dist/runtime/components/Edit/Sortli/index.vue +45 -59
  384. package/dist/runtime/components/Edit/Sortli/index.vue.d.ts +14 -0
  385. package/dist/runtime/components/Edit/SystemRequirements/index.vue +29 -43
  386. package/dist/runtime/components/Edit/SystemRequirements/index.vue.d.ts +2 -0
  387. package/dist/runtime/components/Edit/Toolbar/index.vue +26 -41
  388. package/dist/runtime/components/Edit/Toolbar/index.vue.d.ts +6 -0
  389. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue +29 -51
  390. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue.d.ts +20 -0
  391. package/dist/runtime/components/Edit/index.d.ts +5 -1
  392. package/dist/runtime/components/Edit/index.js +9 -1
  393. package/dist/runtime/composables/defineBlokkli.d.ts +2 -2
  394. package/dist/runtime/composables/defineBlokkli.js +29 -11
  395. package/dist/runtime/composables/defineBlokkliFragment.d.ts +1 -1
  396. package/dist/runtime/composables/defineBlokkliFragment.js +16 -24
  397. package/dist/runtime/css/output.css +1 -1
  398. package/dist/runtime/helpers/definitionProvider.d.ts +18 -0
  399. package/dist/runtime/helpers/definitionProvider.js +96 -0
  400. package/dist/runtime/helpers/domProvider.d.ts +2 -1
  401. package/dist/runtime/helpers/domProvider.js +6 -3
  402. package/dist/runtime/helpers/editComponents/index.d.ts +2 -0
  403. package/dist/runtime/helpers/editComponents/index.js +10 -0
  404. package/dist/runtime/helpers/featuresProvider.d.ts +2 -1
  405. package/dist/runtime/helpers/featuresProvider.js +19 -10
  406. package/dist/runtime/helpers/frameEventBus.d.ts +1 -1
  407. package/dist/runtime/helpers/imports/index.d.ts +1 -0
  408. package/dist/runtime/helpers/imports/index.js +44 -0
  409. package/dist/runtime/helpers/index.js +5 -8
  410. package/dist/runtime/helpers/runtimeHelpers/index.d.ts +5 -0
  411. package/dist/runtime/helpers/runtimeHelpers/index.js +17 -4
  412. package/dist/runtime/helpers/stateProvider.d.ts +1 -1
  413. package/dist/runtime/helpers/textProvider.d.ts +1 -1
  414. package/dist/runtime/helpers/themeProvider.js +4 -1
  415. package/dist/runtime/helpers/transform.d.ts +1 -1
  416. package/dist/runtime/helpers/typesProvider.d.ts +2 -2
  417. package/dist/runtime/helpers/uiProvider.js +4 -5
  418. package/dist/runtime/helpers/webgl/index.js +1 -1
  419. package/dist/runtime/icons/arrow-right-thin.svg +3 -0
  420. package/dist/runtime/public/_blokkli-assets/check.svg +6 -0
  421. package/dist/runtime/public/_blokkli-assets/loader.svg +1 -0
  422. package/dist/runtime/types/blokkOptions.d.ts +11 -2
  423. package/dist/runtime/types/index.d.ts +34 -14
  424. package/dist/shared/editor.gz_ac6uT.d.mts +431 -0
  425. package/dist/types.d.mts +1 -1
  426. package/package.json +30 -25
  427. package/dist/module.cjs +0 -5
  428. package/dist/module.d.ts +0 -198
  429. package/dist/runtime/adapter/drupal/graphql/base.graphql +0 -944
  430. package/dist/runtime/adapter/drupal/graphqlMiddleware.d.ts +0 -2
  431. package/dist/runtime/adapter/drupal/graphqlMiddleware.js +0 -680
  432. package/dist/runtime/types/generatedModuleTypes.d.ts +0 -49
  433. package/dist/types.d.ts +0 -1
  434. /package/dist/{runtime/adapter/drupal/graphql → modules/drupal/graphql/features}/comments.graphql +0 -0
  435. /package/dist/{runtime/adapter/drupal/graphql → modules/drupal/graphql/features}/fragments.graphql +0 -0
  436. /package/dist/{runtime/adapter/drupal/graphql → modules/drupal/graphql/features}/search.graphql +0 -0
  437. /package/dist/{runtime/adapter/drupal/graphql → modules/drupal/graphql/features}/transform.graphql +0 -0
  438. /package/dist/runtime/{types/generatedModuleTypes.js → components/Edit/Features/Publish/Dialog/types.js} +0 -0
  439. /package/dist/runtime/public/{Inter.var.woff2 → _blokkli-assets/Inter.var.woff2} +0 -0
@@ -0,0 +1,251 @@
1
+ <template>
2
+ <DialogModal
3
+ :title="$t('publishDialogTitle', 'Publish changes')"
4
+ :width="1200"
5
+ :submit-label
6
+ :is-loading="isLoading"
7
+ :can-submit="!!selectedToPublishItems.length"
8
+ class="bk-is-publish-dialog"
9
+ @submit="onSubmit"
10
+ @cancel="$emit('close')"
11
+ >
12
+ <div class="bk bk-form bk-dialog-publish-form">
13
+ <FormGroup title="Einstellungen" horizontal>
14
+ <FormItem v-if="publishOptions?.hasRevisionLogMessage">
15
+ <FormTextarea
16
+ v-model="revisionMessage"
17
+ label="Protokollnachricht der Revision"
18
+ description="Beschreiben Sie kurz die vorgenommenen Änderungen"
19
+ :disabled="isLoading"
20
+ />
21
+ </FormItem>
22
+ <FormItem>
23
+ <FormToggle
24
+ v-model="shouldPublish"
25
+ :label="toggleLabel"
26
+ :disabled="isLoading"
27
+ />
28
+ </FormItem>
29
+ </FormGroup>
30
+
31
+ <FormGroup title="Inhalte" horizontal>
32
+ <FormItem>
33
+ <template v-if="successItems.length">
34
+ <h2 class="bk-heading-2">Erfolgreich veröffentlicht</h2>
35
+
36
+ <table class="bk-table bk-publish-dialog-table">
37
+ <thead>
38
+ <tr>
39
+ <th>Name</th>
40
+ <th colspan="2">Status</th>
41
+ </tr>
42
+ </thead>
43
+
44
+ <tbody>
45
+ <Item
46
+ v-for="item in successItems"
47
+ :key="'success' + item.id"
48
+ v-bind="item"
49
+ v-model="states"
50
+ :is-current="item.id === currentId"
51
+ :should-publish
52
+ :is-mutating
53
+ :mutation-status="mutationStatusItems[item.id]"
54
+ />
55
+ </tbody>
56
+ </table>
57
+ </template>
58
+
59
+ <table class="bk-table bk-publish-dialog-table">
60
+ <thead>
61
+ <tr>
62
+ <th>Name</th>
63
+ <th colspan="2">Status</th>
64
+ </tr>
65
+ </thead>
66
+
67
+ <tbody>
68
+ <Item
69
+ v-for="item in toPublishItems"
70
+ :key="'to_publish_' + item.id"
71
+ v-bind="item"
72
+ v-model="states"
73
+ :is-current="item.id === currentId"
74
+ :should-publish
75
+ :is-mutating
76
+ :mutation-status="mutationStatusItems[item.id]"
77
+ />
78
+ </tbody>
79
+ </table>
80
+ </FormItem>
81
+ </FormGroup>
82
+ </div>
83
+ </DialogModal>
84
+ </template>
85
+
86
+ <script setup>
87
+ import { ref, computed, useBlokkli, useAsyncData } from "#imports";
88
+ import {
89
+ DialogModal,
90
+ FormToggle,
91
+ FormTextarea,
92
+ FormItem,
93
+ FormGroup
94
+ } from "#blokkli/components";
95
+ import { falsy } from "#blokkli/helpers";
96
+ import Item from "./Item.vue";
97
+ const { adapter, $t, state, context } = useBlokkli();
98
+ const isMutating = ref(false);
99
+ const mutationStatusItems = ref({});
100
+ const publishedIds = ref([]);
101
+ const shouldPublish = defineModel("shouldPublish", { type: Boolean, ...{
102
+ default: () => false
103
+ } });
104
+ const states = defineModel("states", { type: Array, ...{
105
+ default: () => []
106
+ } });
107
+ const revisionMessage = defineModel("revisionMessage", { type: String, ...{
108
+ default: () => false
109
+ } });
110
+ const emit = defineEmits(["close", "submit"]);
111
+ const { data: publishOptions, status } = await useAsyncData(() => {
112
+ return adapter.getPublishOptions();
113
+ });
114
+ const { data: editStates } = await useAsyncData(
115
+ () => {
116
+ if (adapter.getEditStates) {
117
+ return adapter.getEditStates();
118
+ }
119
+ return Promise.resolve({
120
+ items: [],
121
+ perPage: 16,
122
+ total: 0
123
+ });
124
+ },
125
+ {
126
+ default: () => {
127
+ return {
128
+ items: [],
129
+ perPage: 16,
130
+ total: 0
131
+ };
132
+ }
133
+ }
134
+ );
135
+ const currentId = computed(
136
+ () => `${context.value.entityType}:${context.value.entityUuid}`
137
+ );
138
+ const stateItems = computed(() => {
139
+ const hostEntityType = context.value.entityType;
140
+ const hostEntityUuid = context.value.entityUuid;
141
+ return [
142
+ {
143
+ id: currentId.value,
144
+ hostEntityType,
145
+ hostEntityUuid,
146
+ currentUserIsOwner: !!state.owner.value?.currentUserIsOwner,
147
+ entity: state.entity.value
148
+ },
149
+ ...editStates.value.items.map((v) => {
150
+ return {
151
+ ...v,
152
+ id: `${v.hostEntityType}:${v.hostEntityUuid}`
153
+ };
154
+ }).filter((v) => v.id !== currentId.value)
155
+ ];
156
+ });
157
+ const successItems = computed(
158
+ () => stateItems.value.filter((v) => publishedIds.value.includes(v.id))
159
+ );
160
+ const toPublishItems = computed(
161
+ () => stateItems.value.filter((v) => !publishedIds.value.includes(v.id))
162
+ );
163
+ const selectedToPublishItems = computed(
164
+ () => toPublishItems.value.filter(
165
+ (v) => currentId.value === v.id || states.value.includes(v.id)
166
+ )
167
+ );
168
+ const isLoading = computed(() => status.value === "pending" || isMutating.value);
169
+ const submitLabelPublish = computed(() => {
170
+ if (shouldPublish.value) {
171
+ const count = 1 + states.value.length;
172
+ return "@count Inhalte publizieren".replace("@count", count.toString());
173
+ }
174
+ return null;
175
+ });
176
+ const submitLabelSave = computed(() => {
177
+ const count = selectedToPublishItems.value.length;
178
+ if (!count) {
179
+ if (shouldPublish.value) {
180
+ return "Inhalte publizieren";
181
+ }
182
+ return "Inhalte speichern";
183
+ }
184
+ if (!shouldPublish.value) {
185
+ return "@count Inhalte speichern".replace("@count", count.toString());
186
+ }
187
+ return null;
188
+ });
189
+ const submitLabel = computed(() => {
190
+ return [submitLabelPublish.value, submitLabelSave.value].filter(falsy).join(", ");
191
+ });
192
+ const toggleLabel = computed(() => {
193
+ if (states.value.length) {
194
+ return "Inhalte publizieren";
195
+ }
196
+ return "Inhalt publizieren";
197
+ });
198
+ async function onSubmit() {
199
+ isMutating.value = true;
200
+ const items = stateItems.value;
201
+ let hasAnyError = false;
202
+ for (const item of items) {
203
+ const isSelected = states.value.includes(item.id) || item.hostEntityType === context.value.entityType && item.hostEntityUuid === context.value.entityUuid;
204
+ if (!isSelected) {
205
+ continue;
206
+ }
207
+ if (publishedIds.value.includes(item.id)) {
208
+ continue;
209
+ }
210
+ try {
211
+ const result = await adapter.publish({
212
+ hostEntityType: item.hostEntityType,
213
+ hostEntityUuid: item.hostEntityUuid,
214
+ closeAfterPublish: true,
215
+ revisionLogMessage: revisionMessage.value,
216
+ publishIfUnpublished: shouldPublish.value
217
+ });
218
+ let violations = [];
219
+ if (!result.success && result.state) {
220
+ const mapped = adapter.mapState(result.state);
221
+ if (mapped.mutatedState?.violations) {
222
+ violations = mapped.mutatedState.violations;
223
+ }
224
+ }
225
+ mutationStatusItems.value[item.id] = {
226
+ id: item.id,
227
+ success: result.success,
228
+ errors: result.errors,
229
+ violations
230
+ };
231
+ if (result.success) {
232
+ publishedIds.value.push(item.id);
233
+ }
234
+ hasAnyError ||= !result.success;
235
+ } catch {
236
+ mutationStatusItems.value[item.id] = {
237
+ id: item.id,
238
+ success: false,
239
+ errors: [
240
+ $t("unexpectedMutationError", "An unexpected error happened.")
241
+ ]
242
+ };
243
+ }
244
+ }
245
+ isMutating.value = false;
246
+ if (hasAnyError) {
247
+ return;
248
+ }
249
+ emit("submit");
250
+ }
251
+ </script>
@@ -0,0 +1,19 @@
1
+ type __VLS_PublicProps = {
2
+ 'shouldPublish'?: boolean;
3
+ 'states'?: string[];
4
+ 'revisionMessage'?: string;
5
+ };
6
+ declare const _default: import("vue").DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
7
+ close: () => void;
8
+ submit: () => void;
9
+ "update:shouldPublish": (value: boolean) => void;
10
+ "update:states": (value: string[]) => void;
11
+ "update:revisionMessage": (value: string) => void;
12
+ }, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
13
+ onClose?: (() => any) | undefined;
14
+ onSubmit?: (() => any) | undefined;
15
+ "onUpdate:shouldPublish"?: ((value: boolean) => any) | undefined;
16
+ "onUpdate:states"?: ((value: string[]) => any) | undefined;
17
+ "onUpdate:revisionMessage"?: ((value: string) => any) | undefined;
18
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
19
+ export default _default;
@@ -0,0 +1,7 @@
1
+ import type { Validation } from '#blokkli/types';
2
+ export type MutationStatus = {
3
+ id: string;
4
+ success: boolean;
5
+ errors?: string[];
6
+ violations?: Validation[];
7
+ };
@@ -7,96 +7,92 @@
7
7
  type="success"
8
8
  :weight="0"
9
9
  :icon="icon"
10
- @click="onClick"
10
+ @click="onMenuClick"
11
11
  />
12
+ <Teleport to="body">
13
+ <transition appear name="bk-slide-up">
14
+ <PublishDialog
15
+ v-if="showDialog"
16
+ v-model:states="additionalEditStates"
17
+ v-model:revision-message="revisionMessage"
18
+ v-model:should-publish="shouldPublish"
19
+ @close="showDialog = false"
20
+ @submit="onSubmit"
21
+ />
22
+ </transition>
23
+ </Teleport>
12
24
  </template>
13
25
 
14
- <script lang="ts" setup>
15
- import { useBlokkli, defineBlokkliFeature, computed, useRoute } from '#imports'
16
- import { PluginMenuButton } from '#blokkli/plugins'
17
- import type { BlokkliIcon } from '#blokkli-build/icons'
18
-
26
+ <script setup>
27
+ import {
28
+ useBlokkli,
29
+ defineBlokkliFeature,
30
+ computed,
31
+ useRoute,
32
+ ref
33
+ } from "#imports";
34
+ import { PluginMenuButton } from "#blokkli/plugins";
35
+ import PublishDialog from "./Dialog/index.vue";
19
36
  const { adapter, settings } = defineBlokkliFeature({
20
- id: 'publish',
21
- icon: 'publish',
22
- label: 'Publish',
23
- requiredAdapterMethods: ['publish'],
24
- description:
25
- 'Provides a menu button to publish the changes of the current entity.',
37
+ id: "publish",
38
+ icon: "publish",
39
+ label: "Publish",
40
+ requiredAdapterMethods: ["publish"],
41
+ description: "Provides a menu button to publish the changes of the current entity.",
26
42
  settings: {
27
43
  closeAfterPublish: {
28
- type: 'checkbox',
29
- label: 'Close editor after publishing',
30
- description:
31
- 'Immediately closes the editor after successfully publishing or saving.',
44
+ type: "checkbox",
45
+ label: "Close editor after publishing",
46
+ description: "Immediately closes the editor after successfully publishing or saving.",
32
47
  default: true,
33
- group: 'behavior',
34
- },
35
- },
36
- })
37
-
38
- const route = useRoute()
39
- const { state, $t, eventBus, broadcast, context } = useBlokkli()
40
- const { mutations, canEdit, mutateWithLoadingState } = state
41
-
42
- const isPublished = computed<boolean>(() => !!state.entity.value.status)
43
-
48
+ group: "behavior"
49
+ }
50
+ }
51
+ });
52
+ const route = useRoute();
53
+ const { state, $t, broadcast, context } = useBlokkli();
54
+ const { mutations, canEdit } = state;
55
+ const hasPublishOptions = !!adapter.getPublishOptions;
56
+ const isPublished = computed(() => !!state.entity.value.status);
57
+ const showDialog = ref(false);
58
+ const additionalEditStates = ref([]);
59
+ const shouldPublish = ref(!!state.entity.value.status);
60
+ const revisionMessage = ref("");
44
61
  const publishLabel = computed(() => {
45
- // Entity is published. Clicking the button will make the changes go "live".
62
+ const suffix = hasPublishOptions ? "..." : "";
46
63
  if (isPublished.value) {
47
- return settings.value.closeAfterPublish
48
- ? $t('publishAndCloseLabel', 'Publish & Close')
49
- : $t('publishLabel', 'Publish')
64
+ return (settings.value.closeAfterPublish ? $t("publishAndCloseLabel", "Publish & Close") : $t("publishLabel", "Publish")) + suffix;
50
65
  }
51
-
52
- return settings.value.closeAfterPublish
53
- ? $t('publishAndCloseLabelUnpublished', 'Save & Close')
54
- : $t('publishLabelUnpublished', 'Save')
55
- })
56
-
57
- const publishDescription = computed(() =>
58
- isPublished.value
59
- ? $t('publishDescription', 'Publish all changes.')
60
- : $t(
61
- 'publishDescriptionUnpublished',
62
- 'Save all changes while keeping page unpublished',
63
- ),
64
- )
65
-
66
- const icon = computed<BlokkliIcon>(() =>
67
- isPublished.value ? 'publish' : 'save',
68
- )
69
-
70
- const onClick = async () => {
71
- const success = await mutateWithLoadingState(
72
- () =>
73
- adapter.publish({
74
- closeAfterPublish: settings.value.closeAfterPublish,
75
- }),
76
- $t('publishError', 'Changes could not be published.'),
77
- $t('publishSuccess', 'Changes published successfully.'),
66
+ return (settings.value.closeAfterPublish ? $t("publishAndCloseLabelUnpublished", "Save & Close") : $t("publishLabelUnpublished", "Save")) + suffix;
67
+ });
68
+ const publishDescription = computed(
69
+ () => isPublished.value ? $t("publishDescription", "Publish all changes.") : $t(
70
+ "publishDescriptionUnpublished",
71
+ "Save all changes while keeping page unpublished"
78
72
  )
79
-
80
- if (!success) {
81
- const validations = state.violations.value
82
- if (validations.length) {
83
- eventBus.emit('publish:failed')
84
- // Open the validations sidebar when there are validation errors.
85
- eventBus.emit('sidebar:open', 'violations')
86
- }
87
- return
73
+ );
74
+ const icon = computed(
75
+ () => isPublished.value ? "publish" : "save"
76
+ );
77
+ const onMenuClick = async () => {
78
+ if (hasPublishOptions) {
79
+ showDialog.value = true;
80
+ return;
88
81
  }
89
-
90
- broadcast.emit('published', { uuid: context.value.entityUuid })
91
-
82
+ await publishCurrent();
83
+ };
84
+ async function publishCurrent() {
85
+ }
86
+ function onSubmit() {
87
+ broadcast.emit("published", { uuid: context.value.entityUuid });
92
88
  if (settings.value.closeAfterPublish) {
93
- window.location.href = route.path
89
+ window.location.href = route.path;
94
90
  }
95
91
  }
96
92
  </script>
97
93
 
98
- <script lang="ts">
94
+ <script>
99
95
  export default {
100
- name: 'Publish',
101
- }
96
+ name: "Publish"
97
+ };
102
98
  </script>
@@ -0,0 +1,2 @@
1
+ declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
2
+ export default _default;
@@ -6,13 +6,18 @@
6
6
  <div v-if="detached" class="bk-preview-controls">
7
7
  <slot />
8
8
  </div>
9
- <div class="bk-preview-iframe">
9
+ <div
10
+ class="bk-preview-iframe"
11
+ :style="{
12
+ pointerEvents: isResizing ? 'none' : 'auto'
13
+ }"
14
+ >
10
15
  <iframe ref="iframe" :src="src" @load="isLoading = false" />
11
16
  </div>
12
17
  </div>
13
18
  </template>
14
19
 
15
- <script lang="ts" setup>
20
+ <script setup>
16
21
  import {
17
22
  ref,
18
23
  computed,
@@ -20,62 +25,51 @@ import {
20
25
  onMounted,
21
26
  onBeforeUnmount,
22
27
  useRoute,
23
- watch,
24
- } from '#imports'
25
- import { Icon } from '#blokkli/components'
26
- import { frameEventBus } from './../../../../../helpers/frameEventBus'
27
- import onBlokkliEvent from '#blokkli/helpers/composables/onBlokkliEvent'
28
-
29
- defineProps<{
30
- detached?: boolean
31
- }>()
32
-
33
- const route = useRoute()
34
-
35
- const { selection, broadcast } = useBlokkli()
36
-
28
+ watch
29
+ } from "#imports";
30
+ import { Icon } from "#blokkli/components";
31
+ import { frameEventBus } from "./../../../../../helpers/frameEventBus";
32
+ import onBlokkliEvent from "#blokkli/helpers/composables/onBlokkliEvent";
33
+ defineProps({
34
+ detached: { type: Boolean, required: false },
35
+ isResizing: { type: Boolean, required: false }
36
+ });
37
+ const route = useRoute();
38
+ const { selection, broadcast } = useBlokkli();
37
39
  watch(selection.uuids, (selectedUuids) => {
38
- frameEventBus.emit('selectItems', selectedUuids)
39
- })
40
-
41
- const isLoading = ref(true)
42
- const iframe = ref<HTMLIFrameElement | null>(null)
43
-
44
- const src = computed(() =>
45
- route.fullPath.replace('blokkliEditing', 'blokkliPreview'),
46
- )
47
-
48
- onBlokkliEvent('updateMutatedFields', (e) =>
49
- frameEventBus.emit('mutatedFields', e.fields),
50
- )
51
- onBlokkliEvent('select', (uuids) => {
52
- const uuid = Array.isArray(uuids) ? uuids[0] : uuids
53
- frameEventBus.emit('focus', uuid)
54
- })
55
- onBlokkliEvent('option:update', (e) => frameEventBus.emit('updateOption', e))
56
-
57
- /**
58
- * Emit the event to the iframe.
59
- */
60
- const onFrameEventBusEvent = (name: any, data: any) =>
61
- iframe.value?.contentWindow?.postMessage({
62
- name: 'blokkli__' + name,
63
- data: JSON.parse(JSON.stringify(data)),
64
- })
65
-
40
+ frameEventBus.emit("selectItems", selectedUuids);
41
+ });
42
+ const isLoading = ref(true);
43
+ const iframe = ref(null);
44
+ const src = computed(
45
+ () => route.fullPath.replace("blokkliEditing", "blokkliPreview")
46
+ );
47
+ onBlokkliEvent(
48
+ "updateMutatedFields",
49
+ (e) => frameEventBus.emit("mutatedFields", e.fields)
50
+ );
51
+ onBlokkliEvent("select", (uuids) => {
52
+ const uuid = Array.isArray(uuids) ? uuids[0] : uuids;
53
+ if (uuid) {
54
+ frameEventBus.emit("focus", uuid);
55
+ }
56
+ });
57
+ onBlokkliEvent("option:update", (e) => frameEventBus.emit("updateOption", e));
58
+ const onFrameEventBusEvent = (name, data) => iframe.value?.contentWindow?.postMessage({
59
+ name: "blokkli__" + name,
60
+ data: JSON.parse(JSON.stringify(data))
61
+ });
66
62
  const onPreviewFocused = () => {
67
63
  if (iframe.value) {
68
- iframe.value.focus()
64
+ iframe.value.focus();
69
65
  }
70
- }
71
-
66
+ };
72
67
  onMounted(() => {
73
- frameEventBus.on('*', onFrameEventBusEvent)
74
- broadcast.on('previewFocused', onPreviewFocused)
75
- })
76
-
68
+ frameEventBus.on("*", onFrameEventBusEvent);
69
+ broadcast.on("previewFocused", onPreviewFocused);
70
+ });
77
71
  onBeforeUnmount(() => {
78
- frameEventBus.off('*', onFrameEventBusEvent)
79
- broadcast.off('previewFocused', onPreviewFocused)
80
- })
72
+ frameEventBus.off("*", onFrameEventBusEvent);
73
+ broadcast.off("previewFocused", onPreviewFocused);
74
+ });
81
75
  </script>
@@ -0,0 +1,27 @@
1
+ import { Icon } from '#blokkli/components';
2
+ type __VLS_Props = {
3
+ detached?: boolean;
4
+ isResizing?: boolean;
5
+ };
6
+ declare const isLoading: import("vue").Ref<boolean, boolean>;
7
+ declare const iframe: import("vue").Ref<HTMLIFrameElement | null, HTMLIFrameElement | null>;
8
+ declare const src: import("vue").ComputedRef<string>;
9
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
10
+ declare var __VLS_5: {};
11
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
12
+ default?: (props: typeof __VLS_5) => any;
13
+ }>;
14
+ declare const __VLS_self: import("vue").DefineComponent<__VLS_Props, {
15
+ Icon: typeof Icon;
16
+ isLoading: typeof isLoading;
17
+ iframe: typeof iframe;
18
+ src: typeof src;
19
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
20
+ declare const __VLS_component: 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>;
21
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
22
+ export default _default;
23
+ type __VLS_WithSlots<T, S> = T & {
24
+ new (): {
25
+ $slots: S;
26
+ };
27
+ };