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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (428) hide show
  1. package/dist/module.d.mts +1 -1
  2. package/dist/module.json +5 -5
  3. package/dist/module.mjs +5549 -1269
  4. package/dist/modules/drupal/graphql/base/fragment.ParagraphsBlokkliConfigInput.graphql +31 -0
  5. package/dist/modules/drupal/graphql/base/fragment.blokkliProps.graphql +9 -0
  6. package/dist/modules/drupal/graphql/base/fragment.paragraphsBlokkliEditState.graphql +5 -0
  7. package/dist/modules/drupal/graphql/base/fragment.paragraphsFieldItem.graphql +9 -0
  8. package/dist/modules/drupal/graphql/base/query.pbConfig.graphql +1 -10
  9. package/dist/modules/drupal/graphql/base/query.pbEntityConfig.graphql +5 -0
  10. package/dist/modules/drupal/graphql/features/comments.graphql +11 -8
  11. package/dist/modules/drupal/graphql/features/publishNew.graphql +1 -4
  12. package/dist/modules/drupal/graphql/features/scheduler.graphql +31 -0
  13. package/dist/modules/drupal/graphql/features/transform.graphql +9 -1
  14. package/dist/modules/drupal/graphql/features/transform_host.graphql +38 -0
  15. package/dist/modules/drupal/graphql/mutations/set_paragraph_schedule.graphql +15 -0
  16. package/dist/modules/drupal/graphql/mutations/update_host_options.graphql +15 -0
  17. package/dist/modules/drupal/index.d.mts +1 -1
  18. package/dist/modules/drupal/index.mjs +79 -9
  19. package/dist/modules/drupal/runtime/adapter/index.d.ts +3 -0
  20. package/dist/modules/drupal/{adapter/index.mjs → runtime/adapter/index.js} +166 -20
  21. package/dist/runtime/adapter/index.d.ts +111 -1
  22. package/dist/runtime/blokkliPlugins/AddAction/index.vue +27 -3
  23. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue +65 -0
  24. package/dist/runtime/blokkliPlugins/BlockIndicator/index.vue.d.ts +26 -0
  25. package/dist/runtime/blokkliPlugins/ContextMenu/Menu/index.vue +6 -0
  26. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue +3 -2
  27. package/dist/runtime/blokkliPlugins/ContextMenu/index.vue.d.ts +2 -19
  28. package/dist/runtime/blokkliPlugins/DebugOverlay/index.vue.d.ts +2 -7
  29. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue +3 -3
  30. package/dist/runtime/blokkliPlugins/DroppableEdit/index.vue.d.ts +2 -19
  31. package/dist/runtime/blokkliPlugins/ItemAction/index.vue +23 -15
  32. package/dist/runtime/blokkliPlugins/ItemAction/index.vue.d.ts +21 -44
  33. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue +49 -11
  34. package/dist/runtime/blokkliPlugins/ItemDropdown/index.vue.d.ts +29 -15
  35. package/dist/runtime/blokkliPlugins/MenuButton/index.vue.d.ts +3 -3
  36. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue +6 -7
  37. package/dist/runtime/blokkliPlugins/Sidebar/Detached/index.vue.d.ts +2 -51
  38. package/dist/runtime/blokkliPlugins/Sidebar/index.vue +2 -9
  39. package/dist/runtime/blokkliPlugins/Sidebar/index.vue.d.ts +15 -9
  40. package/dist/runtime/blokkliPlugins/ToolbarButton/index.vue.d.ts +1 -1
  41. package/dist/runtime/blokkliPlugins/TourItem/index.vue +10 -5
  42. package/dist/runtime/blokkliPlugins/TourItem/index.vue.d.ts +2 -4
  43. package/dist/runtime/blokkliPlugins/ViewOption/index.vue +6 -3
  44. package/dist/runtime/blokkliPlugins/ViewOption/index.vue.d.ts +4 -3
  45. package/dist/runtime/blokkliPlugins/index.d.ts +8 -7
  46. package/dist/runtime/blokkliPlugins/index.js +15 -13
  47. package/dist/runtime/components/Blocks/Fragment/icon.svg +1 -1
  48. package/dist/runtime/components/Blocks/FromLibrary/index.vue +4 -2
  49. package/dist/runtime/components/BlokkliEditable.vue +34 -16
  50. package/dist/runtime/components/BlokkliEditable.vue.d.ts +2 -1
  51. package/dist/runtime/components/BlokkliField.vue +31 -27
  52. package/dist/runtime/components/BlokkliField.vue.d.ts +61 -17
  53. package/dist/runtime/components/BlokkliItem.vue +2 -2
  54. package/dist/runtime/components/BlokkliItem.vue.d.ts +4 -2
  55. package/dist/runtime/components/BlokkliProvider.vue +60 -45
  56. package/dist/runtime/components/BlokkliProvider.vue.d.ts +45 -7
  57. package/dist/runtime/components/Edit/Actions/index.vue +69 -78
  58. package/dist/runtime/components/Edit/AddListItem/index.vue +2 -5
  59. package/dist/runtime/components/Edit/AddListItem/index.vue.d.ts +1 -1
  60. package/dist/runtime/components/Edit/AddListItemIcon/index.vue +19 -0
  61. package/dist/runtime/components/Edit/AddListItemIcon/index.vue.d.ts +15 -0
  62. package/dist/runtime/components/Edit/AnimationCanvas/index.vue +436 -25
  63. package/dist/runtime/components/Edit/AppMenu/index.vue +5 -5
  64. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue +83 -0
  65. package/dist/runtime/components/Edit/ArtboardTooltip/index.vue.d.ts +32 -0
  66. package/dist/runtime/components/Edit/Banner/index.vue +51 -0
  67. package/dist/runtime/components/Edit/Banner/index.vue.d.ts +18 -0
  68. package/dist/runtime/components/Edit/BlockProxy/index.vue +3 -1
  69. package/dist/runtime/components/Edit/BlokkliErrorBoundary.vue.d.ts +2 -13
  70. package/dist/runtime/components/Edit/Dialog/index.vue +14 -5
  71. package/dist/runtime/components/Edit/Dialog/index.vue.d.ts +4 -2
  72. package/dist/runtime/components/Edit/DiffViewer/State.vue +276 -0
  73. package/dist/runtime/components/Edit/DiffViewer/State.vue.d.ts +16 -0
  74. package/dist/runtime/components/Edit/DraggableList.vue +20 -50
  75. package/dist/runtime/components/Edit/DraggableList.vue.d.ts +7 -7
  76. package/dist/runtime/components/Edit/EditIndicator.vue +118 -44
  77. package/dist/runtime/components/Edit/EditIndicator.vue.d.ts +3 -0
  78. package/dist/runtime/components/Edit/EditProvider.vue +192 -80
  79. package/dist/runtime/components/Edit/EditProvider.vue.d.ts +3 -0
  80. package/dist/runtime/components/Edit/Features/AddList/index.vue +24 -36
  81. package/dist/runtime/components/Edit/Features/Analyze/Overlay/fragment.glsl +58 -0
  82. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue +170 -0
  83. package/dist/runtime/components/Edit/Features/Analyze/Overlay/index.vue.d.ts +9 -0
  84. package/dist/runtime/components/Edit/Features/Analyze/Overlay/vertex.glsl +72 -0
  85. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue +159 -0
  86. package/dist/runtime/components/Edit/Features/Analyze/Renderer.vue.d.ts +7 -0
  87. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue +100 -0
  88. package/dist/runtime/components/Edit/Features/Analyze/Results/Results.vue.d.ts +6 -0
  89. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue +56 -0
  90. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItem.vue.d.ts +3 -0
  91. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue +87 -0
  92. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodes.vue.d.ts +7 -0
  93. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue +105 -0
  94. package/dist/runtime/components/Edit/Features/Analyze/Results/ResultsItemNodesTarget.vue.d.ts +8 -0
  95. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue +18 -0
  96. package/dist/runtime/components/Edit/Features/Analyze/Results/Status.vue.d.ts +8 -0
  97. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue +92 -0
  98. package/dist/runtime/components/Edit/Features/Analyze/Summary/Chart.vue.d.ts +17 -0
  99. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue +77 -0
  100. package/dist/runtime/components/Edit/Features/Analyze/Summary/index.vue.d.ts +6 -0
  101. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.d.ts +12 -0
  102. package/dist/runtime/components/Edit/Features/Analyze/analyzers/axe.js +75 -0
  103. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.d.ts +4 -0
  104. package/dist/runtime/components/Edit/Features/Analyze/analyzers/defineAnalyzer.js +5 -0
  105. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.d.ts +32 -0
  106. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/Context.js +45 -0
  107. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.d.ts +5 -0
  108. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/collectTextElements.js +95 -0
  109. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.d.ts +3 -0
  110. package/dist/runtime/components/Edit/Features/Analyze/analyzers/helpers/normalizeArray.js +13 -0
  111. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.d.ts +2 -0
  112. package/dist/runtime/components/Edit/Features/Analyze/analyzers/index.js +2 -0
  113. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.d.ts +2 -0
  114. package/dist/runtime/components/Edit/Features/Analyze/analyzers/readability.js +165 -0
  115. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.d.ts +44 -0
  116. package/dist/runtime/components/Edit/Features/Analyze/analyzers/types.js +0 -0
  117. package/dist/runtime/components/Edit/Features/Analyze/helper.d.ts +5 -0
  118. package/dist/runtime/components/Edit/Features/Analyze/helper.js +28 -0
  119. package/dist/runtime/components/Edit/Features/Analyze/index.vue +44 -0
  120. package/dist/runtime/components/Edit/Features/Anchors/Renderer.vue +53 -0
  121. package/dist/runtime/components/Edit/Features/Anchors/index.vue +32 -0
  122. package/dist/runtime/components/Edit/Features/Artboard/Overview/index.vue +25 -13
  123. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue +299 -0
  124. package/dist/runtime/components/Edit/Features/Artboard/Renderer.vue.d.ts +7 -0
  125. package/dist/runtime/components/Edit/Features/Artboard/index.vue +10 -217
  126. package/dist/runtime/components/Edit/Features/Assistant/index.vue +5 -3
  127. package/dist/runtime/components/Edit/Features/BlockAddList/index.vue +33 -57
  128. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue +154 -0
  129. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/ScheduleSection.vue.d.ts +27 -0
  130. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue +222 -0
  131. package/dist/runtime/components/Edit/Features/BlockScheduler/Dialog/index.vue.d.ts +11 -0
  132. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue +96 -0
  133. package/dist/runtime/components/Edit/Features/BlockScheduler/index.vue.d.ts +2 -0
  134. package/dist/runtime/components/Edit/Features/Clipboard/index.vue +177 -46
  135. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue +51 -0
  136. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Item/index.vue.d.ts +17 -0
  137. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/index.vue +48 -117
  138. package/dist/runtime/components/Edit/Features/CommandPalette/index.vue +5 -2
  139. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue +35 -20
  140. package/dist/runtime/components/Edit/Features/Comments/AddForm/index.vue.d.ts +5 -3
  141. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue +29 -0
  142. package/dist/runtime/components/Edit/Features/Comments/CommentInput/index.vue.d.ts +13 -0
  143. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue +22 -16
  144. package/dist/runtime/components/Edit/Features/Comments/Overlay/Item/index.vue.d.ts +1 -0
  145. package/dist/runtime/components/Edit/Features/Comments/Overlay/index.vue +15 -6
  146. package/dist/runtime/components/Edit/Features/Comments/index.vue +21 -9
  147. package/dist/runtime/components/Edit/Features/Conversions/index.vue +16 -21
  148. package/dist/runtime/components/Edit/Features/Debug/Rects/index.vue +26 -35
  149. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue +240 -0
  150. package/dist/runtime/components/Edit/Features/Debug/Renderer.vue.d.ts +6 -0
  151. package/dist/runtime/components/Edit/Features/Debug/Viewport/index.vue +14 -0
  152. package/dist/runtime/components/Edit/Features/Debug/index.vue +7 -162
  153. package/dist/runtime/components/Edit/Features/Delete/index.vue +1 -1
  154. package/dist/runtime/components/Edit/Features/Diff/DiffView/index.vue +13 -190
  155. package/dist/runtime/components/Edit/Features/Diff/index.vue +2 -2
  156. package/dist/runtime/components/Edit/Features/DraggingOverlay/DragItems/index.vue +18 -10
  157. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/fragment.glsl +8 -2
  158. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue +111 -121
  159. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/index.vue.d.ts +3 -132
  160. package/dist/runtime/components/Edit/Features/DraggingOverlay/DropTargets/vertex.glsl +2 -1
  161. package/dist/runtime/components/Edit/Features/DraggingOverlay/index.vue +87 -61
  162. package/dist/runtime/components/Edit/Features/Duplicate/index.vue +6 -8
  163. package/dist/runtime/components/Edit/Features/Edit/index.vue +16 -22
  164. package/dist/runtime/components/Edit/Features/EditForm/Frame/index.vue +3 -3
  165. package/dist/runtime/components/Edit/Features/EditForm/index.vue +10 -9
  166. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue +69 -4
  167. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Frame/index.vue.d.ts +2 -2
  168. package/dist/runtime/components/Edit/Features/EditableField/Overlay/Plaintext/index.vue +13 -9
  169. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue +45 -87
  170. package/dist/runtime/components/Edit/Features/EditableField/Overlay/index.vue.d.ts +2 -2
  171. package/dist/runtime/components/Edit/Features/EditableField/index.vue +45 -43
  172. package/dist/runtime/components/Edit/Features/EditableMask/index.vue +3 -20
  173. package/dist/runtime/components/Edit/Features/EntityTitle/index.vue +33 -1
  174. package/dist/runtime/components/Edit/Features/Fragments/Dialog/index.vue +11 -9
  175. package/dist/runtime/components/Edit/Features/Fragments/index.vue +8 -6
  176. package/dist/runtime/components/Edit/Features/History/index.vue +39 -13
  177. package/dist/runtime/components/Edit/Features/Hover/Overlay/fragment.glsl +139 -0
  178. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue +261 -0
  179. package/dist/runtime/components/Edit/Features/Hover/Overlay/index.vue.d.ts +6 -0
  180. package/dist/runtime/components/Edit/Features/Hover/Overlay/vertex.glsl +117 -0
  181. package/dist/runtime/components/Edit/Features/Hover/index.vue +25 -0
  182. package/dist/runtime/components/Edit/Features/Hover/index.vue.d.ts +2 -0
  183. package/dist/runtime/components/Edit/Features/ImportExisting/Dialog/index.vue +6 -2
  184. package/dist/runtime/components/Edit/Features/ImportExisting/index.vue +3 -2
  185. package/dist/runtime/components/Edit/Features/Library/EditReusable/index.vue +5 -7
  186. package/dist/runtime/components/Edit/Features/Library/LibraryDialog/index.vue +19 -27
  187. package/dist/runtime/components/Edit/Features/Library/ReusableDialog/index.vue +32 -28
  188. package/dist/runtime/components/Edit/Features/Library/index.vue +40 -32
  189. package/dist/runtime/components/Edit/Features/MediaLibrary/Library/index.vue +11 -11
  190. package/dist/runtime/components/Edit/Features/MediaLibrary/index.vue +15 -12
  191. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/fragment.glsl +1 -1
  192. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/index.vue +44 -32
  193. package/dist/runtime/components/Edit/Features/MultiSelect/Overlay/vertex.glsl +1 -1
  194. package/dist/runtime/components/Edit/Features/MultiSelect/index.vue +10 -18
  195. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue +3 -2
  196. package/dist/runtime/components/Edit/Features/Options/Form/Checkbox/index.vue.d.ts +2 -0
  197. package/dist/runtime/components/Edit/Features/Options/Form/Group.vue.d.ts +2 -11
  198. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue +14 -3
  199. package/dist/runtime/components/Edit/Features/Options/Form/Item.vue.d.ts +0 -1
  200. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue +37 -19
  201. package/dist/runtime/components/Edit/Features/Options/Form/Radios/index.vue.d.ts +8 -2
  202. package/dist/runtime/components/Edit/Features/Options/Form/index.vue +88 -42
  203. package/dist/runtime/components/Edit/Features/Options/Form/index.vue.d.ts +5 -5
  204. package/dist/runtime/components/Edit/Features/Options/index.vue +35 -11
  205. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue +35 -0
  206. package/dist/runtime/components/Edit/Features/Ownership/Renderer.vue.d.ts +6 -0
  207. package/dist/runtime/components/Edit/Features/Ownership/index.vue +7 -25
  208. package/dist/runtime/components/Edit/Features/PreviewGrant/index.vue +3 -3
  209. package/dist/runtime/components/Edit/Features/ProxyView/index.vue +5 -1
  210. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue +41 -14
  211. package/dist/runtime/components/Edit/Features/Publish/Dialog/Item.vue.d.ts +2 -0
  212. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue +47 -0
  213. package/dist/runtime/components/Edit/Features/Publish/Dialog/PublishOption.vue.d.ts +19 -0
  214. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue +83 -0
  215. package/dist/runtime/components/Edit/Features/Publish/Dialog/Summary.vue.d.ts +9 -0
  216. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue +439 -123
  217. package/dist/runtime/components/Edit/Features/Publish/Dialog/index.vue.d.ts +3 -14
  218. package/dist/runtime/components/Edit/Features/Publish/index.vue +57 -24
  219. package/dist/runtime/components/Edit/Features/ResponsivePreview/Frame/index.vue.d.ts +2 -13
  220. package/dist/runtime/components/Edit/Features/Revert/index.vue +3 -3
  221. package/dist/runtime/components/Edit/Features/Search/Overlay/Results/Page/index.vue +15 -15
  222. package/dist/runtime/components/Edit/Features/Search/index.vue +7 -3
  223. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Overlay/index.vue +85 -0
  224. package/dist/runtime/components/Edit/Features/{CommandPalette/Palette/Group → Selection/AddButtons/Overlay}/index.vue.d.ts +8 -13
  225. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/fragment.glsl +106 -0
  226. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue +440 -0
  227. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/index.vue.d.ts +32 -0
  228. package/dist/runtime/components/Edit/Features/Selection/AddButtons/Renderer/vertex.glsl +102 -0
  229. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue +387 -0
  230. package/dist/runtime/components/Edit/Features/Selection/AddButtons/index.vue.d.ts +6 -0
  231. package/dist/runtime/components/Edit/Features/Selection/Overlay/fragment.glsl +15 -10
  232. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue +105 -25
  233. package/dist/runtime/components/Edit/Features/Selection/Overlay/index.vue.d.ts +5 -3
  234. package/dist/runtime/components/Edit/Features/Selection/Overlay/vertex.glsl +12 -3
  235. package/dist/runtime/components/Edit/Features/Selection/OverlayFallback/index.vue +2 -2
  236. package/dist/runtime/components/Edit/Features/Selection/index.vue +135 -25
  237. package/dist/runtime/components/Edit/Features/Settings/Dialog/FeatureSetting/index.vue +12 -17
  238. package/dist/runtime/components/Edit/Features/Settings/index.vue +11 -25
  239. package/dist/runtime/components/Edit/Features/Structure/List/Field/index.vue +2 -2
  240. package/dist/runtime/components/Edit/Features/Structure/List/Item/index.vue +13 -6
  241. package/dist/runtime/components/Edit/Features/Theme/Color/index.vue +5 -1
  242. package/dist/runtime/components/Edit/Features/Theme/index.vue +2 -1
  243. package/dist/runtime/components/Edit/Features/TouchActionBar/index.vue +3 -2
  244. package/dist/runtime/components/Edit/Features/Tour/Overlay/index.vue +3 -0
  245. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue +198 -0
  246. package/dist/runtime/components/Edit/Features/Transform/Dialog/index.vue.d.ts +13 -0
  247. package/dist/runtime/components/Edit/Features/Transform/index.vue +156 -70
  248. package/dist/runtime/components/Edit/Features/Translations/Banner/index.vue +17 -11
  249. package/dist/runtime/components/Edit/Features/Translations/index.vue +20 -23
  250. package/dist/runtime/components/Edit/Features/Validations/SidebarItem/index.vue +5 -5
  251. package/dist/runtime/components/Edit/Features/index.vue +17 -7
  252. package/dist/runtime/components/Edit/Form/Datepicker/index.vue +198 -0
  253. package/dist/runtime/components/Edit/Form/Datepicker/index.vue.d.ts +15 -0
  254. package/dist/runtime/components/Edit/Form/Group/index.vue.d.ts +2 -4
  255. package/dist/runtime/components/Edit/Form/Item/index.vue.d.ts +2 -4
  256. package/dist/runtime/components/Edit/Form/Radio/index.vue +33 -0
  257. package/dist/runtime/components/Edit/Form/Radio/index.vue.d.ts +20 -0
  258. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue +37 -0
  259. package/dist/runtime/components/Edit/Form/RadioTabs/index.vue.d.ts +22 -0
  260. package/dist/runtime/components/Edit/Form/Select/index.vue +29 -0
  261. package/dist/runtime/components/Edit/Form/Select/index.vue.d.ts +20 -0
  262. package/dist/runtime/components/Edit/Form/Text/index.vue +34 -0
  263. package/dist/runtime/components/Edit/Form/Text/index.vue.d.ts +20 -0
  264. package/dist/runtime/components/Edit/Form/Textarea/index.vue +13 -6
  265. package/dist/runtime/components/Edit/Form/Textarea/index.vue.d.ts +4 -0
  266. package/dist/runtime/components/Edit/Form/Toggle/index.vue +4 -3
  267. package/dist/runtime/components/Edit/Form/Toggle/index.vue.d.ts +12 -2
  268. package/dist/runtime/components/Edit/FormOverlay/index.vue +1 -1
  269. package/dist/runtime/components/Edit/FormOverlay/index.vue.d.ts +3 -2
  270. package/dist/runtime/components/Edit/Indicators/index.vue +123 -0
  271. package/dist/runtime/components/Edit/Indicators/index.vue.d.ts +2 -0
  272. package/dist/runtime/components/Edit/InfoBox/index.vue +6 -2
  273. package/dist/runtime/components/Edit/InfoBox/index.vue.d.ts +12 -2
  274. package/dist/runtime/components/Edit/ItemIcon/index.vue +2 -1
  275. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue +66 -0
  276. package/dist/runtime/components/Edit/Konami/Game/PixelGrid.vue.d.ts +7 -0
  277. package/dist/runtime/components/Edit/Konami/Game/blokkli.png +0 -0
  278. package/dist/runtime/components/Edit/Konami/Game/charmap.d.ts +2 -0
  279. package/dist/runtime/components/Edit/Konami/Game/charmap.js +168 -0
  280. package/dist/runtime/components/Edit/Konami/Game/index.vue +752 -0
  281. package/dist/runtime/components/Edit/Konami/Game/index.vue.d.ts +6 -0
  282. package/dist/runtime/components/Edit/Konami/Game/textRendering.d.ts +8 -0
  283. package/dist/runtime/components/Edit/Konami/Game/textRendering.js +138 -0
  284. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.d.ts +9 -0
  285. package/dist/runtime/components/Edit/Konami/Game/useIconRendering.js +130 -0
  286. package/dist/runtime/components/Edit/Konami/index.vue +44 -0
  287. package/dist/runtime/components/Edit/Konami/index.vue.d.ts +2 -0
  288. package/dist/runtime/components/Edit/Loading/index.vue +6 -2
  289. package/dist/runtime/components/Edit/Loading/index.vue.d.ts +2 -0
  290. package/dist/runtime/components/Edit/Messages/index.vue +8 -3
  291. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue +17 -0
  292. package/dist/runtime/components/Edit/PluginConfigForm/Checkbox/index.vue.d.ts +11 -0
  293. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue +37 -0
  294. package/dist/runtime/components/Edit/PluginConfigForm/Options/index.vue.d.ts +11 -0
  295. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue +43 -0
  296. package/dist/runtime/components/Edit/PluginConfigForm/Text/index.vue.d.ts +11 -0
  297. package/dist/runtime/components/Edit/PluginConfigForm/index.vue +57 -0
  298. package/dist/runtime/components/Edit/PluginConfigForm/index.vue.d.ts +16 -0
  299. package/dist/runtime/components/Edit/PreviewProvider.vue +3 -4
  300. package/dist/runtime/components/Edit/RelativeTime/index.vue +3 -2
  301. package/dist/runtime/components/Edit/RelativeTime/index.vue.d.ts +2 -2
  302. package/dist/runtime/components/Edit/Resizable/index.vue.d.ts +1 -1
  303. package/dist/runtime/components/Edit/ScaleToFit/index.vue.d.ts +1 -1
  304. package/dist/runtime/components/Edit/ScheduleDate/index.vue +131 -0
  305. package/dist/runtime/components/Edit/ScheduleDate/index.vue.d.ts +23 -0
  306. package/dist/runtime/components/Edit/ScrollBoundary/index.vue.d.ts +2 -7
  307. package/dist/runtime/components/Edit/ShortcutIndicator/index.vue +11 -3
  308. package/dist/runtime/components/Edit/Sortli/index.vue.d.ts +1 -1
  309. package/dist/runtime/components/Edit/SystemRequirements/index.vue +3 -3
  310. package/dist/runtime/components/Edit/Toolbar/index.vue +3 -2
  311. package/dist/runtime/components/Edit/Transition/Height.vue +95 -0
  312. package/dist/runtime/components/Edit/Transition/Height.vue.d.ts +36 -0
  313. package/dist/runtime/components/Edit/Transition/index.vue +41 -0
  314. package/dist/runtime/components/Edit/Transition/index.vue.d.ts +19 -0
  315. package/dist/runtime/components/Edit/ViewportBlockingRect/index.vue.d.ts +2 -7
  316. package/dist/runtime/components/Edit/index.d.ts +28 -15
  317. package/dist/runtime/components/Edit/index.js +54 -28
  318. package/dist/runtime/composables/defineBlokkli.js +16 -3
  319. package/dist/runtime/composables/defineBlokkliFeature.d.ts +4 -7
  320. package/dist/runtime/composables/defineBlokkliFragment.js +8 -1
  321. package/dist/runtime/composables/defineBlokkliProvider.d.ts +11 -0
  322. package/dist/runtime/composables/defineBlokkliProvider.js +46 -0
  323. package/dist/runtime/composables/useBlokkliHelper.d.ts +19 -0
  324. package/dist/runtime/composables/useBlokkliHelper.js +95 -0
  325. package/dist/runtime/constants/index.d.ts +3 -0
  326. package/dist/runtime/constants/index.js +3 -0
  327. package/dist/runtime/css/output.css +1 -1
  328. package/dist/runtime/helpers/addElementClasses.d.ts +2 -0
  329. package/dist/runtime/helpers/addElementClasses.js +24 -0
  330. package/dist/runtime/helpers/animationProvider.d.ts +38 -2
  331. package/dist/runtime/helpers/animationProvider.js +188 -47
  332. package/dist/runtime/helpers/bundles/index.d.ts +1 -0
  333. package/dist/runtime/helpers/bundles/index.js +4 -0
  334. package/dist/runtime/helpers/composables/defineRenderer.d.ts +8 -0
  335. package/dist/runtime/helpers/composables/defineRenderer.js +8 -0
  336. package/dist/runtime/helpers/composables/useBlockRegistration.d.ts +5 -0
  337. package/dist/runtime/helpers/composables/useBlockRegistration.js +23 -0
  338. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.d.ts +1 -1
  339. package/dist/runtime/helpers/composables/useDelayedIntersectionObserver.js +3 -2
  340. package/dist/runtime/helpers/composables/useStateBasedCache.d.ts +4 -0
  341. package/dist/runtime/helpers/composables/useStateBasedCache.js +13 -0
  342. package/dist/runtime/helpers/composables/useStickyToolbar.d.ts +23 -0
  343. package/dist/runtime/helpers/composables/useStickyToolbar.js +233 -0
  344. package/dist/runtime/helpers/definitionProvider.d.ts +3 -2
  345. package/dist/runtime/helpers/definitionProvider.js +17 -0
  346. package/dist/runtime/helpers/dom/index.d.ts +60 -0
  347. package/dist/runtime/helpers/dom/index.js +48 -0
  348. package/dist/runtime/helpers/domProvider.d.ts +58 -17
  349. package/dist/runtime/helpers/domProvider.js +320 -245
  350. package/dist/runtime/helpers/dropTargets/index.d.ts +6 -0
  351. package/dist/runtime/helpers/dropTargets/index.js +49 -0
  352. package/dist/runtime/helpers/eventBus.d.ts +1 -1
  353. package/dist/runtime/helpers/eventBus.js +2 -2
  354. package/dist/runtime/helpers/index.d.ts +10 -14
  355. package/dist/runtime/helpers/index.js +58 -121
  356. package/dist/runtime/helpers/indicatorsProvider.d.ts +10 -0
  357. package/dist/runtime/helpers/indicatorsProvider.js +23 -0
  358. package/dist/runtime/helpers/keyboardProvider.d.ts +2 -0
  359. package/dist/runtime/helpers/keyboardProvider.js +17 -1
  360. package/dist/runtime/helpers/pluginProvider.d.ts +10 -0
  361. package/dist/runtime/helpers/pluginProvider.js +33 -0
  362. package/dist/runtime/helpers/providers/blocks.d.ts +10 -0
  363. package/dist/runtime/helpers/providers/blocks.js +91 -0
  364. package/dist/runtime/helpers/providers/directive.d.ts +25 -0
  365. package/dist/runtime/helpers/providers/directive.js +208 -0
  366. package/dist/runtime/helpers/providers/element.d.ts +6 -0
  367. package/dist/runtime/helpers/providers/element.js +35 -0
  368. package/dist/runtime/helpers/providers/fields.d.ts +8 -0
  369. package/dist/runtime/helpers/providers/fields.js +47 -0
  370. package/dist/runtime/helpers/renderCycle.d.ts +1 -0
  371. package/dist/runtime/helpers/renderCycle.js +10 -0
  372. package/dist/runtime/helpers/runtimeHelpers/index.js +15 -12
  373. package/dist/runtime/helpers/selectionProvider.d.ts +27 -11
  374. package/dist/runtime/helpers/selectionProvider.js +79 -74
  375. package/dist/runtime/helpers/stateProvider.d.ts +12 -2
  376. package/dist/runtime/helpers/stateProvider.js +164 -20
  377. package/dist/runtime/helpers/storageProvider.d.ts +5 -3
  378. package/dist/runtime/helpers/storageProvider.js +61 -4
  379. package/dist/runtime/helpers/symbols.d.ts +2 -0
  380. package/dist/runtime/helpers/symbols.js +2 -0
  381. package/dist/runtime/helpers/textProvider.js +6 -0
  382. package/dist/runtime/helpers/themeProvider.d.ts +4 -1
  383. package/dist/runtime/helpers/themeProvider.js +28 -15
  384. package/dist/runtime/helpers/transform.js +1 -3
  385. package/dist/runtime/helpers/typesProvider.js +10 -26
  386. package/dist/runtime/helpers/uiProvider.d.ts +18 -3
  387. package/dist/runtime/helpers/uiProvider.js +114 -61
  388. package/dist/runtime/helpers/useTransitionedValue.d.ts +18 -0
  389. package/dist/runtime/helpers/useTransitionedValue.js +57 -0
  390. package/dist/runtime/helpers/webgl/index.d.ts +11 -2
  391. package/dist/runtime/helpers/webgl/index.js +162 -7
  392. package/dist/runtime/icons/anchor.svg +1 -0
  393. package/dist/runtime/icons/arrow-left.svg +1 -1
  394. package/dist/runtime/icons/arrow-right.svg +1 -1
  395. package/dist/runtime/icons/arrow-top-right.svg +1 -0
  396. package/dist/runtime/icons/calendar-clock.svg +1 -0
  397. package/dist/runtime/icons/calendar.svg +1 -0
  398. package/dist/runtime/icons/chart.svg +1 -0
  399. package/dist/runtime/icons/clock.svg +1 -0
  400. package/dist/runtime/icons/comment_add.svg +1 -5
  401. package/dist/runtime/icons/copy.svg +1 -0
  402. package/dist/runtime/icons/cursor-move.svg +1 -1
  403. package/dist/runtime/icons/delete.svg +1 -8
  404. package/dist/runtime/icons/diff.svg +1 -1
  405. package/dist/runtime/icons/duplicate.svg +1 -12
  406. package/dist/runtime/icons/edit.svg +1 -8
  407. package/dist/runtime/icons/eye-off.svg +1 -0
  408. package/dist/runtime/icons/eye.svg +1 -1
  409. package/dist/runtime/icons/info.svg +1 -1
  410. package/dist/runtime/icons/link.svg +1 -0
  411. package/dist/runtime/icons/reusable.svg +1 -5
  412. package/dist/runtime/icons/speedometer.svg +1 -0
  413. package/dist/runtime/plugins/blokkliDirectives.js +109 -0
  414. package/dist/runtime/types/blokkOptions.d.ts +8 -0
  415. package/dist/runtime/types/index.d.ts +278 -42
  416. package/dist/runtime/types/theme.d.ts +2 -1
  417. package/dist/shared/{editor.gz_ac6uT.d.mts → editor.CKsrTpc1.d.mts} +1 -1
  418. package/package.json +55 -38
  419. package/dist/modules/drupal/adapter/index.d.mts +0 -6
  420. package/dist/runtime/components/Edit/DragInteractions/index.vue +0 -364
  421. package/dist/runtime/components/Edit/Features/CommandPalette/Palette/Group/index.vue +0 -51
  422. package/dist/runtime/components/Edit/Features/FieldAreas/Overlay/index.vue +0 -22
  423. package/dist/runtime/components/Edit/Features/FieldAreas/index.vue +0 -41
  424. package/dist/runtime/plugins/blokkliEditable.js +0 -31
  425. /package/dist/runtime/components/Edit/{DragInteractions → Features/Analyze}/index.vue.d.ts +0 -0
  426. /package/dist/runtime/components/Edit/Features/{FieldAreas/Overlay/index.vue.d.ts → Anchors/Renderer.vue.d.ts} +0 -0
  427. /package/dist/runtime/components/Edit/Features/{FieldAreas → Anchors}/index.vue.d.ts +0 -0
  428. /package/dist/runtime/plugins/{blokkliEditable.d.ts → blokkliDirectives.d.ts} +0 -0
@@ -1,116 +1,329 @@
1
1
  <template>
2
2
  <DialogModal
3
3
  :title="$t('publishDialogTitle', 'Publish changes')"
4
- :width="1200"
4
+ :width="900"
5
5
  :submit-label
6
6
  :is-loading="isLoading"
7
- :can-submit="!!selectedToPublishItems.length"
7
+ :can-submit="canSubmit"
8
8
  class="bk-is-publish-dialog"
9
9
  @submit="onSubmit"
10
10
  @cancel="$emit('close')"
11
11
  >
12
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"
13
+ <FormItem>
14
+ <div class="bk-form-label">
15
+ {{ $t("publishMode", "Publish mode")
16
+ }}<span class="bk-required-indicator">*</span>
17
+ </div>
18
+ <div class="bk-publish-options">
19
+ <PublishOption
20
+ v-for="option in publishModeOptions"
21
+ :id="option.id"
22
+ :key="option.id"
23
+ v-model="publishMode"
24
+ :icon="option.icon"
25
+ :color="option.color"
26
+ :label="option.label"
27
+ :description="option.description"
28
+ :disabled="option.disabled"
20
29
  />
21
- </FormItem>
22
- <FormItem>
23
- <FormToggle
24
- v-model="shouldPublish"
25
- :label="toggleLabel"
26
- :disabled="isLoading"
30
+ </div>
31
+ </FormItem>
32
+
33
+ <FormItem v-if="publishMode === 'scheduled'">
34
+ <div>
35
+ <label class="bk-form-label">
36
+ {{ $t("publishScheduleDate", "Publication date") }}
37
+ </label>
38
+ <div class="bk-publish-schedule-date-wrapper">
39
+ <div v-if="isAlreadyScheduled" class="bk-publish-scheduled-display">
40
+ {{ formatScheduleDate(scheduleDate) }}
41
+ </div>
42
+ <ScheduleDate
43
+ v-else
44
+ v-model="scheduleDate"
45
+ :disabled="isLoading"
46
+ :error="scheduleDateError"
47
+ >
48
+ <div
49
+ class="bk-schedule-date-info"
50
+ v-text="
51
+ $t(
52
+ 'publishScheduledInfo',
53
+ 'You can still make changes until the scheduled publication date.'
54
+ )
55
+ "
56
+ />
57
+ </ScheduleDate>
58
+ <button
59
+ v-if="isAlreadyScheduled"
60
+ type="button"
61
+ class="bk-button bk-is-danger"
62
+ @click="removeScheduledDate"
63
+ >
64
+ {{ $t("publishRemoveSchedule", "Remove schedule") }}
65
+ </button>
66
+ </div>
67
+ <div v-if="isAlreadyScheduled" class="bk-form-description">
68
+ {{
69
+ $t(
70
+ "publishAlreadyScheduledDescription",
71
+ "This page is already scheduled for publishing"
72
+ )
73
+ }}
74
+ </div>
75
+ </div>
76
+ </FormItem>
77
+
78
+ <FormItem v-if="publishOptions?.hasRevisionLogMessage">
79
+ <FormTextarea
80
+ id="revision-message"
81
+ v-model="revisionMessage"
82
+ :label="$t('publishRevisionLogMessage', 'Change description')"
83
+ :description="
84
+ $t(
85
+ 'publishRevisionLogMessageDescription',
86
+ 'Briefly describe the changes made'
87
+ )
88
+ "
89
+ :disabled="isLoading || isAlreadyScheduled"
90
+ rows="2"
91
+ />
92
+ </FormItem>
93
+
94
+ <FormItem v-if="publishMode !== 'save' && scheduledBlocks.length">
95
+ <InfoBox>
96
+ <p
97
+ v-for="(text, index) in scheduledBlocks"
98
+ :key="'infobox' + index"
99
+ v-html="text"
27
100
  />
28
- </FormItem>
29
- </FormGroup>
101
+ </InfoBox>
102
+ </FormItem>
30
103
 
31
- <FormGroup title="Inhalte" horizontal>
32
- <FormItem>
33
- <template v-if="successItems.length">
34
- <h2 class="bk-heading-2">Erfolgreich veröffentlicht</h2>
104
+ <FormItem v-if="successItems.length && showTable">
105
+ <h2 class="bk-heading-2">
106
+ {{ $t("publishSuccessfullyPublished", "Successfully published") }}
107
+ </h2>
35
108
 
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>
109
+ <table class="bk-table bk-publish-dialog-table">
110
+ <thead>
111
+ <tr>
112
+ <th>{{ $t("publishName", "Name") }}</th>
113
+ <th colspan="2">{{ $t("publishStatus", "Status") }}</th>
114
+ </tr>
115
+ </thead>
43
116
 
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>
117
+ <tbody>
118
+ <Item
119
+ v-for="item in successItems"
120
+ :key="'success' + item.id"
121
+ v-bind="item"
122
+ v-model="states"
123
+ :is-current="item.id === currentId"
124
+ :should-publish
125
+ :is-mutating
126
+ :mutation-status="mutationStatusItems[item.id]"
127
+ :is-scheduled="enableScheduling"
128
+ :schedule-date
129
+ />
130
+ </tbody>
131
+ </table>
58
132
 
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>
133
+ <table class="bk-table bk-publish-dialog-table">
134
+ <thead>
135
+ <tr>
136
+ <th>{{ $t("publishName", "Name") }}</th>
137
+ <th colspan="2">{{ $t("publishStatus", "Status") }}</th>
138
+ </tr>
139
+ </thead>
66
140
 
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>
141
+ <tbody>
142
+ <Item
143
+ v-for="item in toPublishItems"
144
+ :key="'to_publish_' + item.id"
145
+ v-bind="item"
146
+ v-model="states"
147
+ :is-current="item.id === currentId"
148
+ :should-publish
149
+ :is-mutating
150
+ :mutation-status="mutationStatusItems[item.id]"
151
+ :is-scheduled="enableScheduling"
152
+ :schedule-date
153
+ />
154
+ </tbody>
155
+ </table>
156
+ </FormItem>
82
157
  </div>
158
+ <template #pre-footer>
159
+ <div>
160
+ <h3 class="bk-form-label">
161
+ {{ $t("publishSummary", "Summary") }}
162
+ </h3>
163
+ <Summary
164
+ :is-published="isCurrentlyPublished"
165
+ :mode="publishMode"
166
+ :current-state-label="currentStateLabel"
167
+ :action-label="actionLabel"
168
+ :result-state-label="resultStateLabel"
169
+ />
170
+ </div>
171
+ </template>
83
172
  </DialogModal>
84
173
  </template>
85
174
 
86
175
  <script setup>
87
- import { ref, computed, useBlokkli, useAsyncData } from "#imports";
176
+ import {
177
+ ref,
178
+ computed,
179
+ watch,
180
+ useBlokkli,
181
+ useAsyncData,
182
+ onMounted,
183
+ onUnmounted
184
+ } from "#imports";
88
185
  import {
89
186
  DialogModal,
90
- FormToggle,
91
187
  FormTextarea,
92
188
  FormItem,
93
- FormGroup
189
+ ScheduleDate,
190
+ InfoBox
94
191
  } from "#blokkli/components";
95
- import { falsy } from "#blokkli/helpers";
192
+ import { emitMessage } from "#blokkli/helpers/eventBus";
96
193
  import Item from "./Item.vue";
97
- const { adapter, $t, state, context } = useBlokkli();
194
+ import PublishOption, {} from "./PublishOption.vue";
195
+ import Summary from "./Summary.vue";
196
+ const showTable = false;
197
+ const { adapter, $t, state, context, ui } = useBlokkli();
198
+ const formatScheduleDate = (date) => {
199
+ return ui.formatDate(date, {
200
+ weekday: "long",
201
+ year: "numeric",
202
+ month: "long",
203
+ day: "numeric",
204
+ hour: "2-digit",
205
+ minute: "2-digit"
206
+ });
207
+ };
98
208
  const isMutating = ref(false);
99
209
  const mutationStatusItems = ref({});
100
210
  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
- } });
211
+ const states = ref([]);
212
+ const revisionMessage = ref("");
213
+ const currentTimestamp = ref(Date.now());
214
+ let timestampInterval = null;
215
+ onMounted(() => {
216
+ timestampInterval = setInterval(() => {
217
+ currentTimestamp.value = Date.now();
218
+ }, 3e4);
219
+ });
220
+ onUnmounted(() => {
221
+ if (timestampInterval) {
222
+ clearInterval(timestampInterval);
223
+ }
224
+ });
225
+ const publishMode = ref("immediate");
110
226
  const emit = defineEmits(["close", "submit"]);
111
- const { data: publishOptions, status } = await useAsyncData(() => {
227
+ const {
228
+ data: publishOptions,
229
+ status,
230
+ refresh
231
+ } = await useAsyncData(() => {
112
232
  return adapter.getPublishOptions();
113
233
  });
234
+ const scheduledBlocks = computed(() => {
235
+ const referenceTimestamp = publishMode.value === "scheduled" && scheduleDate.value ? new Date(scheduleDate.value).getTime() : currentTimestamp.value;
236
+ const grouped = state.getAllUuids().reduce((acc, uuid) => {
237
+ const item = state.getFieldListItem(uuid);
238
+ if (!item?.editContext?.publishOn) {
239
+ return acc;
240
+ }
241
+ const publishDate = new Date(item.editContext.publishOn).getTime();
242
+ if (publishDate <= referenceTimestamp) {
243
+ return acc;
244
+ }
245
+ const dateKey = item.editContext.publishOn;
246
+ acc[dateKey] = (acc[dateKey] || 0) + 1;
247
+ return acc;
248
+ }, {});
249
+ return Object.entries(grouped).map(([date, count]) => {
250
+ const formattedDate = formatScheduleDate(date);
251
+ const message = count === 1 ? $t(
252
+ "publishScheduledBlockSingular",
253
+ "1 block is scheduled to be published on @date"
254
+ ) : $t(
255
+ "publishScheduledBlockPlural",
256
+ "@count blocks are scheduled to be published on @date"
257
+ );
258
+ return message.replace("@count", count.toString()).replace("@date", `<strong>${formattedDate}</strong>`);
259
+ });
260
+ });
261
+ const canSchedule = computed(() => !!publishOptions.value?.canSchedule);
262
+ const publishOn = computed(
263
+ () => publishOptions.value?.publishOn ?? null
264
+ );
265
+ const isAlreadyScheduled = computed(() => !!publishOn.value);
266
+ const isCurrentlyPublished = computed(() => !!state.entity.value?.status);
267
+ const publishModeOptions = computed(() => {
268
+ const options = [
269
+ {
270
+ id: "save",
271
+ icon: "save",
272
+ color: "red",
273
+ label: $t("publishModeSaveTitle", "Save"),
274
+ description: $t(
275
+ "publishModeSaveDescription",
276
+ "Save changes without publishing"
277
+ ),
278
+ disabled: isCurrentlyPublished.value || isAlreadyScheduled.value
279
+ },
280
+ {
281
+ id: "immediate",
282
+ icon: "publish",
283
+ color: "lime",
284
+ label: $t("publishModeImmediateTitle", "Publish"),
285
+ description: $t(
286
+ "publishModeImmediateDescription",
287
+ "Publish changes immediately"
288
+ ),
289
+ disabled: isAlreadyScheduled.value
290
+ }
291
+ ];
292
+ if (canSchedule.value) {
293
+ options.push({
294
+ id: "scheduled",
295
+ icon: "calendar-clock",
296
+ color: "yellow",
297
+ label: $t("publishModeScheduledTitle", "Schedule"),
298
+ description: $t(
299
+ "publishModeScheduledDescription",
300
+ "Schedule changes for publishing"
301
+ ),
302
+ disabled: false
303
+ });
304
+ }
305
+ return options;
306
+ });
307
+ const scheduleDate = ref(publishOn.value || "");
308
+ if (publishOptions.value?.revisionLogMessage) {
309
+ revisionMessage.value = publishOptions.value.revisionLogMessage;
310
+ }
311
+ if (!isCurrentlyPublished.value) {
312
+ publishMode.value = "save";
313
+ }
314
+ if (publishOn.value) {
315
+ publishMode.value = "scheduled";
316
+ }
317
+ watch(publishMode, (newMode) => {
318
+ if (newMode === "scheduled" && !scheduleDate.value) {
319
+ const tomorrow = /* @__PURE__ */ new Date();
320
+ tomorrow.setDate(tomorrow.getDate() + 1);
321
+ tomorrow.setHours(12, 0, 0, 0);
322
+ scheduleDate.value = tomorrow.toISOString();
323
+ }
324
+ });
325
+ const enableScheduling = computed(() => publishMode.value === "scheduled");
326
+ const shouldPublish = computed(() => publishMode.value !== "save");
114
327
  const { data: editStates } = await useAsyncData(
115
328
  () => {
116
329
  if (adapter.getEditStates) {
@@ -166,39 +379,133 @@ const selectedToPublishItems = computed(
166
379
  )
167
380
  );
168
381
  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());
382
+ const scheduleDateError = computed(() => {
383
+ if (publishMode.value !== "scheduled" || !scheduleDate.value) {
384
+ return "";
385
+ }
386
+ const selectedDateTime = new Date(scheduleDate.value);
387
+ const minDateTime = new Date(currentTimestamp.value + 2 * 60 * 1e3);
388
+ if (selectedDateTime < minDateTime) {
389
+ return $t(
390
+ "publishScheduleDateTooSoon",
391
+ "The scheduled date must be at least 2 minutes in the future"
392
+ );
173
393
  }
174
- return null;
394
+ return "";
175
395
  });
176
- const submitLabelSave = computed(() => {
396
+ const canSubmit = computed(() => {
397
+ if (!selectedToPublishItems.value.length) {
398
+ return false;
399
+ }
400
+ if (publishMode.value === "scheduled" && !scheduleDate.value) {
401
+ return false;
402
+ }
403
+ if (publishMode.value === "scheduled" && isAlreadyScheduled.value) {
404
+ return false;
405
+ }
406
+ if (scheduleDateError.value) {
407
+ return false;
408
+ }
409
+ return true;
410
+ });
411
+ const submitLabel = computed(() => {
177
412
  const count = selectedToPublishItems.value.length;
178
- if (!count) {
179
- if (shouldPublish.value) {
180
- return "Inhalte publizieren";
413
+ if (publishMode.value === "scheduled") {
414
+ if (count === 0) {
415
+ return $t("publishSchedulePublication", "Schedule publication");
416
+ }
417
+ return count === 1 ? $t("publishSchedulePublication", "Schedule publication") : $t(
418
+ "publishSchedulePublications",
419
+ "Schedule @count publications"
420
+ ).replace("@count", count.toString());
421
+ }
422
+ if (publishMode.value === "save") {
423
+ if (count === 0) {
424
+ return $t("publishSaveContent", "Save content");
181
425
  }
182
- return "Inhalte speichern";
426
+ return count === 1 ? $t("publishSaveContent", "Save content") : $t("publishSaveContents", "Save @count contents").replace(
427
+ "@count",
428
+ count.toString()
429
+ );
183
430
  }
184
- if (!shouldPublish.value) {
185
- return "@count Inhalte speichern".replace("@count", count.toString());
431
+ if (count === 0) {
432
+ return $t("publishPublishContent", "Publish content");
186
433
  }
187
- return null;
434
+ return count === 1 ? $t("publishPublishContent", "Publish content") : $t("publishPublishContents", "Publish @count contents").replace(
435
+ "@count",
436
+ count.toString()
437
+ );
188
438
  });
189
- const submitLabel = computed(() => {
190
- return [submitLabelPublish.value, submitLabelSave.value].filter(falsy).join(", ");
439
+ const currentStateLabel = computed(
440
+ () => isCurrentlyPublished.value ? $t("publishCurrentlyPublished", "Page is published") : $t("publishCurrentlyUnpublished", "Page is unpublished")
441
+ );
442
+ const actionLabel = computed(() => {
443
+ if (publishMode.value === "save") {
444
+ return $t("publishModeSaveTitle", "Save");
445
+ }
446
+ if (publishMode.value === "scheduled") {
447
+ return $t("publishModeScheduledTitle", "Schedule");
448
+ }
449
+ return $t("publishModeImmediateTitle", "Publish");
191
450
  });
192
- const toggleLabel = computed(() => {
193
- if (states.value.length) {
194
- return "Inhalte publizieren";
451
+ const resultStateLabel = computed(() => {
452
+ if (publishMode.value === "save") {
453
+ return $t(
454
+ "publishResultSaveChanges",
455
+ "Changes are saved, page remains unpublished"
456
+ );
457
+ }
458
+ if (publishMode.value === "scheduled" && scheduleDate.value) {
459
+ const formattedDate = formatScheduleDate(scheduleDate.value);
460
+ if (isCurrentlyPublished.value) {
461
+ return $t(
462
+ "publishResultScheduledChanges",
463
+ "Changes will be published on @date"
464
+ ).replace("@date", formattedDate);
465
+ }
466
+ return $t(
467
+ "publishResultScheduledPage",
468
+ "Page will be published on @date"
469
+ ).replace("@date", formattedDate);
195
470
  }
196
- return "Inhalt publizieren";
471
+ if (isCurrentlyPublished.value) {
472
+ return $t(
473
+ "publishResultPublishChangesRemainPublished",
474
+ "Changes are published, page remains published"
475
+ );
476
+ }
477
+ return $t(
478
+ "publishResultPublishChangesNowPublished",
479
+ "Changes are published, page is now published"
480
+ );
197
481
  });
482
+ async function removeScheduledDate() {
483
+ if (!adapter.unscheduleEditState) {
484
+ return;
485
+ }
486
+ isMutating.value = true;
487
+ const previousScheduleDate = scheduleDate.value;
488
+ const success = await state.mutateWithLoadingState(
489
+ () => adapter.unscheduleEditState({
490
+ hostEntityType: context.value.entityType,
491
+ hostEntityUuid: context.value.entityUuid
492
+ })
493
+ );
494
+ if (success) {
495
+ await refresh();
496
+ scheduleDate.value = previousScheduleDate;
497
+ }
498
+ isMutating.value = false;
499
+ }
198
500
  async function onSubmit() {
501
+ currentTimestamp.value = Date.now();
502
+ if (scheduleDateError.value) {
503
+ return;
504
+ }
199
505
  isMutating.value = true;
200
506
  const items = stateItems.value;
201
- let hasAnyError = false;
507
+ const hasAnyError = false;
508
+ let mutationResult = false;
202
509
  for (const item of items) {
203
510
  const isSelected = states.value.includes(item.id) || item.hostEntityType === context.value.entityType && item.hostEntityUuid === context.value.entityUuid;
204
511
  if (!isSelected) {
@@ -208,30 +515,29 @@ async function onSubmit() {
208
515
  continue;
209
516
  }
210
517
  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;
518
+ if (publishMode.value === "scheduled") {
519
+ if (!adapter.scheduleEditState) {
520
+ throw new Error("scheduleEditState method not available");
223
521
  }
522
+ mutationResult = await state.mutateWithLoadingState(
523
+ () => adapter.scheduleEditState({
524
+ hostEntityType: item.hostEntityType,
525
+ hostEntityUuid: item.hostEntityUuid,
526
+ revisionLogMessage: revisionMessage.value,
527
+ date: scheduleDate.value
528
+ })
529
+ );
530
+ } else {
531
+ mutationResult = await state.mutateWithLoadingState(
532
+ () => adapter.publish({
533
+ hostEntityType: item.hostEntityType,
534
+ hostEntityUuid: item.hostEntityUuid,
535
+ closeAfterPublish: true,
536
+ revisionLogMessage: revisionMessage.value,
537
+ publishIfUnpublished: shouldPublish.value
538
+ })
539
+ );
224
540
  }
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
541
  } catch {
236
542
  mutationStatusItems.value[item.id] = {
237
543
  id: item.id,
@@ -243,9 +549,19 @@ async function onSubmit() {
243
549
  }
244
550
  }
245
551
  isMutating.value = false;
246
- if (hasAnyError) {
552
+ if (hasAnyError || !mutationResult) {
247
553
  return;
248
554
  }
249
- emit("submit");
555
+ if (publishMode.value === "scheduled") {
556
+ const formattedDate = formatScheduleDate(scheduleDate.value);
557
+ const message = $t(
558
+ "publishScheduleSuccess",
559
+ "Publication scheduled for @date"
560
+ ).replace("@date", formattedDate);
561
+ emitMessage(message, "success");
562
+ emit("close");
563
+ } else {
564
+ emit("submit");
565
+ }
250
566
  }
251
567
  </script>
@@ -1,19 +1,8 @@
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, {
1
+ declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
7
2
  close: () => void;
8
3
  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<{
4
+ }, string, import("vue").PublicProps, Readonly<{}> & Readonly<{
13
5
  onClose?: (() => any) | undefined;
14
6
  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>;
7
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
19
8
  export default _default;