@blocknote/core 0.16.0 → 0.17.1

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 (248) hide show
  1. package/dist/blocknote.js +3292 -2755
  2. package/dist/blocknote.js.map +1 -1
  3. package/dist/blocknote.umd.cjs +6 -6
  4. package/dist/blocknote.umd.cjs.map +1 -1
  5. package/dist/webpack-stats.json +1 -1
  6. package/package.json +5 -2
  7. package/src/api/blockManipulation/commands/insertBlocks/__snapshots__/insertBlocks.test.ts.snap +3087 -0
  8. package/src/api/blockManipulation/commands/insertBlocks/insertBlocks.test.ts +132 -0
  9. package/src/api/blockManipulation/commands/insertBlocks/insertBlocks.ts +71 -0
  10. package/src/api/blockManipulation/commands/mergeBlocks/__snapshots__/mergeBlocks.test.ts.snap +2276 -0
  11. package/src/api/blockManipulation/commands/mergeBlocks/mergeBlocks.test.ts +131 -0
  12. package/src/api/blockManipulation/commands/mergeBlocks/mergeBlocks.ts +103 -0
  13. package/src/api/blockManipulation/commands/moveBlock/__snapshots__/moveBlock.test.ts.snap +3767 -0
  14. package/src/api/blockManipulation/commands/moveBlock/moveBlock.test.ts +192 -0
  15. package/src/api/blockManipulation/commands/moveBlock/moveBlock.ts +178 -0
  16. package/src/api/blockManipulation/commands/removeBlocks/__snapshots__/removeBlocks.test.ts.snap +1136 -0
  17. package/src/api/blockManipulation/commands/removeBlocks/removeBlocks.test.ts +34 -0
  18. package/src/api/blockManipulation/commands/removeBlocks/removeBlocks.ts +100 -0
  19. package/src/api/blockManipulation/commands/replaceBlocks/__snapshots__/replaceBlocks.test.ts.snap +4931 -0
  20. package/src/api/blockManipulation/commands/replaceBlocks/replaceBlocks.test.ts +222 -0
  21. package/src/api/blockManipulation/commands/replaceBlocks/replaceBlocks.ts +70 -0
  22. package/src/api/blockManipulation/commands/splitBlock/__snapshots__/splitBlock.test.ts.snap +2924 -0
  23. package/src/api/blockManipulation/commands/splitBlock/splitBlock.test.ts +136 -0
  24. package/src/api/blockManipulation/commands/splitBlock/splitBlock.ts +48 -0
  25. package/src/api/blockManipulation/commands/updateBlock/__snapshots__/updateBlock.test.ts.snap +8376 -0
  26. package/src/api/blockManipulation/commands/updateBlock/updateBlock.test.ts +300 -0
  27. package/src/api/blockManipulation/commands/updateBlock/updateBlock.ts +199 -0
  28. package/src/api/blockManipulation/insertContentAt.ts +96 -0
  29. package/src/api/blockManipulation/selections/textCursorPosition/__snapshots__/textCursorPosition.test.ts.snap +316 -0
  30. package/src/api/blockManipulation/selections/textCursorPosition/textCursorPosition.test.ts +53 -0
  31. package/src/api/blockManipulation/selections/textCursorPosition/textCursorPosition.ts +130 -0
  32. package/src/api/blockManipulation/setupTestEnv.ts +179 -0
  33. package/src/api/clipboard/__snapshots__/tableAllCells.html +1 -1
  34. package/src/api/clipboard/clipboard.test.ts +5 -6
  35. package/src/api/clipboard/fromClipboard/fileDropExtension.ts +8 -4
  36. package/src/api/clipboard/fromClipboard/handleFileInsertion.ts +11 -6
  37. package/src/api/clipboard/fromClipboard/pasteExtension.ts +8 -4
  38. package/src/api/clipboard/toClipboard/copyExtension.ts +113 -61
  39. package/src/api/exporters/html/__snapshots__/complex/misc/external.html +1 -1
  40. package/src/api/exporters/html/__snapshots__/lists/basic/external.html +1 -1
  41. package/src/api/exporters/html/__snapshots__/lists/nested/external.html +1 -1
  42. package/src/api/exporters/html/externalHTMLExporter.ts +42 -94
  43. package/src/api/exporters/html/htmlConversion.test.ts +19 -13
  44. package/src/api/exporters/html/internalHTMLSerializer.ts +21 -72
  45. package/src/api/exporters/html/util/serializeBlocksExternalHTML.ts +263 -0
  46. package/src/api/exporters/html/util/serializeBlocksInternalHTML.ts +158 -0
  47. package/src/api/exporters/markdown/markdownExporter.test.ts +10 -10
  48. package/src/api/exporters/markdown/markdownExporter.ts +11 -7
  49. package/src/api/exporters/markdown/util/addSpacesToCheckboxesRehypePlugin.ts +2 -2
  50. package/src/api/getBlockInfoFromPos.ts +172 -90
  51. package/src/api/nodeConversions/blockToNode.ts +257 -0
  52. package/src/api/nodeConversions/fragmentToBlocks.ts +60 -0
  53. package/src/api/nodeConversions/nodeConversions.test.ts +9 -8
  54. package/src/api/nodeConversions/{nodeConversions.ts → nodeToBlock.ts} +20 -262
  55. package/src/api/parsers/html/parseHTML.test.ts +2 -2
  56. package/src/api/parsers/html/parseHTML.ts +8 -4
  57. package/src/api/parsers/html/util/nestedLists.test.ts +2 -2
  58. package/src/api/parsers/markdown/parseMarkdown.test.ts +2 -2
  59. package/src/api/parsers/markdown/parseMarkdown.ts +8 -4
  60. package/src/api/testUtil/cases/customBlocks.ts +11 -11
  61. package/src/api/testUtil/cases/customInlineContent.ts +6 -6
  62. package/src/api/testUtil/cases/customStyles.ts +6 -6
  63. package/src/api/testUtil/cases/defaultSchema.ts +4 -4
  64. package/src/api/testUtil/index.ts +6 -6
  65. package/src/api/testUtil/partialBlockTestUtil.ts +5 -5
  66. package/src/blocks/AudioBlockContent/AudioBlockContent.ts +5 -5
  67. package/src/blocks/FileBlockContent/FileBlockContent.ts +4 -4
  68. package/src/blocks/FileBlockContent/fileBlockHelpers.ts +2 -2
  69. package/src/blocks/HeadingBlockContent/HeadingBlockContent.ts +61 -39
  70. package/src/blocks/ImageBlockContent/ImageBlockContent.ts +5 -5
  71. package/src/blocks/ListItemBlockContent/BulletListItemBlockContent/BulletListItemBlockContent.ts +30 -18
  72. package/src/blocks/ListItemBlockContent/CheckListItemBlockContent/CheckListItemBlockContent.ts +67 -33
  73. package/src/blocks/ListItemBlockContent/ListItemKeyboardShortcuts.ts +23 -19
  74. package/src/blocks/ListItemBlockContent/NumberedListItemBlockContent/NumberedListIndexingPlugin.ts +22 -24
  75. package/src/blocks/ListItemBlockContent/NumberedListItemBlockContent/NumberedListItemBlockContent.ts +31 -19
  76. package/src/blocks/ParagraphBlockContent/ParagraphBlockContent.ts +16 -11
  77. package/src/blocks/TableBlockContent/TableBlockContent.ts +4 -4
  78. package/src/blocks/VideoBlockContent/VideoBlockContent.ts +5 -5
  79. package/src/blocks/defaultBlockHelpers.ts +4 -4
  80. package/src/blocks/defaultBlockTypeGuards.ts +5 -5
  81. package/src/blocks/defaultBlocks.ts +13 -13
  82. package/src/blocks/defaultProps.ts +1 -1
  83. package/src/editor/BlockNoteEditor.test.ts +14 -7
  84. package/src/editor/BlockNoteEditor.ts +82 -149
  85. package/src/editor/BlockNoteExtensions.ts +15 -11
  86. package/src/editor/BlockNoteSchema.ts +7 -7
  87. package/src/editor/BlockNoteTipTapEditor.ts +5 -3
  88. package/src/editor/cursorPositionTypes.ts +7 -2
  89. package/src/editor/selectionTypes.ts +6 -2
  90. package/src/extensions/BackgroundColor/BackgroundColorExtension.ts +1 -1
  91. package/src/extensions/BackgroundColor/BackgroundColorMark.ts +1 -1
  92. package/src/extensions/FilePanel/FilePanelPlugin.ts +4 -4
  93. package/src/extensions/FormattingToolbar/FormattingToolbarPlugin.ts +8 -4
  94. package/src/extensions/KeyboardShortcuts/KeyboardShortcutsExtension.ts +334 -0
  95. package/src/extensions/LinkToolbar/LinkToolbarPlugin.ts +9 -4
  96. package/src/extensions/{NonEditableBlocks/NonEditableBlockPlugin.ts → NodeSelectionKeyboard/NodeSelectionKeyboardPlugin.ts} +2 -2
  97. package/src/extensions/Placeholder/PlaceholderPlugin.ts +1 -1
  98. package/src/extensions/SideMenu/SideMenuPlugin.ts +72 -401
  99. package/src/extensions/SideMenu/dragging.ts +251 -0
  100. package/src/extensions/SuggestionMenu/DefaultSuggestionItem.ts +1 -1
  101. package/src/extensions/SuggestionMenu/SuggestionPlugin.ts +8 -4
  102. package/src/extensions/SuggestionMenu/getDefaultEmojiPickerItems.ts +8 -4
  103. package/src/extensions/SuggestionMenu/getDefaultSlashMenuItems.ts +19 -15
  104. package/src/extensions/TableHandles/TableHandlesPlugin.ts +11 -7
  105. package/src/extensions/TextColor/TextColorExtension.ts +1 -1
  106. package/src/extensions/TextColor/TextColorMark.ts +1 -1
  107. package/src/i18n/dictionary.ts +1 -1
  108. package/src/i18n/locales/ar.ts +1 -1
  109. package/src/i18n/locales/fr.ts +1 -1
  110. package/src/i18n/locales/hr.ts +308 -0
  111. package/src/i18n/locales/index.ts +15 -14
  112. package/src/i18n/locales/is.ts +1 -1
  113. package/src/i18n/locales/ja.ts +1 -1
  114. package/src/i18n/locales/ko.ts +1 -1
  115. package/src/i18n/locales/nl.ts +1 -1
  116. package/src/i18n/locales/pl.ts +1 -1
  117. package/src/i18n/locales/pt.ts +1 -1
  118. package/src/i18n/locales/ru.ts +1 -1
  119. package/src/i18n/locales/vi.ts +1 -1
  120. package/src/i18n/locales/zh.ts +1 -1
  121. package/src/index.ts +45 -44
  122. package/src/pm-nodes/BlockContainer.ts +3 -647
  123. package/src/pm-nodes/BlockGroup.ts +2 -2
  124. package/src/pm-nodes/index.ts +3 -3
  125. package/src/schema/blocks/createSpec.ts +8 -7
  126. package/src/schema/blocks/internal.ts +9 -9
  127. package/src/schema/blocks/types.ts +4 -4
  128. package/src/schema/index.ts +10 -10
  129. package/src/schema/inlineContent/createSpec.ts +9 -10
  130. package/src/schema/inlineContent/internal.ts +3 -3
  131. package/src/schema/inlineContent/types.ts +2 -2
  132. package/src/schema/styles/createSpec.ts +4 -3
  133. package/src/schema/styles/internal.ts +1 -1
  134. package/types/src/api/blockManipulation/commands/insertBlocks/insertBlocks.d.ts +4 -0
  135. package/types/src/api/blockManipulation/commands/mergeBlocks/mergeBlocks.d.ts +7 -0
  136. package/types/src/api/blockManipulation/commands/mergeBlocks/mergeBlocks.test.d.ts +1 -0
  137. package/types/src/api/blockManipulation/commands/moveBlock/moveBlock.d.ts +5 -0
  138. package/types/src/api/blockManipulation/commands/moveBlock/moveBlock.test.d.ts +1 -0
  139. package/types/src/api/blockManipulation/commands/removeBlocks/removeBlocks.d.ts +7 -0
  140. package/types/src/api/blockManipulation/commands/removeBlocks/removeBlocks.test.d.ts +1 -0
  141. package/types/src/api/blockManipulation/commands/replaceBlocks/replaceBlocks.d.ts +7 -0
  142. package/types/src/api/blockManipulation/commands/replaceBlocks/replaceBlocks.test.d.ts +1 -0
  143. package/types/src/api/blockManipulation/commands/splitBlock/splitBlock.d.ts +5 -0
  144. package/types/src/api/blockManipulation/commands/splitBlock/splitBlock.test.d.ts +1 -0
  145. package/types/src/api/blockManipulation/commands/updateBlock/updateBlock.d.ts +11 -0
  146. package/types/src/api/blockManipulation/commands/updateBlock/updateBlock.test.d.ts +1 -0
  147. package/types/src/api/blockManipulation/insertContentAt.d.ts +6 -0
  148. package/types/src/api/blockManipulation/selections/textCursorPosition/textCursorPosition.d.ts +5 -0
  149. package/types/src/api/blockManipulation/selections/textCursorPosition/textCursorPosition.test.d.ts +1 -0
  150. package/types/src/api/blockManipulation/setupTestEnv.d.ts +492 -0
  151. package/types/src/api/clipboard/fromClipboard/fileDropExtension.d.ts +3 -3
  152. package/types/src/api/clipboard/fromClipboard/handleFileInsertion.d.ts +1 -1
  153. package/types/src/api/clipboard/fromClipboard/pasteExtension.d.ts +2 -2
  154. package/types/src/api/clipboard/toClipboard/copyExtension.d.ts +5 -5
  155. package/types/src/api/exporters/html/externalHTMLExporter.d.ts +7 -9
  156. package/types/src/api/exporters/html/internalHTMLSerializer.d.ts +6 -10
  157. package/types/src/api/exporters/html/util/serializeBlocksExternalHTML.d.ts +10 -0
  158. package/types/src/api/exporters/html/util/serializeBlocksInternalHTML.d.ts +11 -0
  159. package/types/src/api/exporters/markdown/markdownExporter.d.ts +3 -3
  160. package/types/src/api/getBlockInfoFromPos.d.ts +63 -20
  161. package/types/src/api/nodeConversions/blockToNode.d.ts +15 -0
  162. package/types/src/api/nodeConversions/fragmentToBlocks.d.ts +7 -0
  163. package/types/src/api/nodeConversions/nodeToBlock.d.ts +16 -0
  164. package/types/src/api/parsers/html/parseHTML.d.ts +2 -2
  165. package/types/src/api/parsers/markdown/parseMarkdown.d.ts +2 -2
  166. package/types/src/api/testUtil/cases/customBlocks.d.ts +39 -39
  167. package/types/src/api/testUtil/cases/customInlineContent.d.ts +35 -35
  168. package/types/src/api/testUtil/cases/customStyles.d.ts +35 -35
  169. package/types/src/api/testUtil/cases/defaultSchema.d.ts +2 -2
  170. package/types/src/api/testUtil/index.d.ts +6 -6
  171. package/types/src/api/testUtil/partialBlockTestUtil.d.ts +4 -4
  172. package/types/src/blocks/AudioBlockContent/AudioBlockContent.d.ts +4 -4
  173. package/types/src/blocks/FileBlockContent/FileBlockContent.d.ts +4 -4
  174. package/types/src/blocks/FileBlockContent/fileBlockHelpers.d.ts +2 -2
  175. package/types/src/blocks/HeadingBlockContent/HeadingBlockContent.d.ts +2 -2
  176. package/types/src/blocks/ImageBlockContent/ImageBlockContent.d.ts +4 -4
  177. package/types/src/blocks/ListItemBlockContent/BulletListItemBlockContent/BulletListItemBlockContent.d.ts +2 -2
  178. package/types/src/blocks/ListItemBlockContent/CheckListItemBlockContent/CheckListItemBlockContent.d.ts +2 -2
  179. package/types/src/blocks/ListItemBlockContent/ListItemKeyboardShortcuts.d.ts +2 -2
  180. package/types/src/blocks/ListItemBlockContent/NumberedListItemBlockContent/NumberedListItemBlockContent.d.ts +2 -2
  181. package/types/src/blocks/ParagraphBlockContent/ParagraphBlockContent.d.ts +2 -2
  182. package/types/src/blocks/TableBlockContent/TableBlockContent.d.ts +2 -2
  183. package/types/src/blocks/VideoBlockContent/VideoBlockContent.d.ts +4 -4
  184. package/types/src/blocks/defaultBlockHelpers.d.ts +3 -3
  185. package/types/src/blocks/defaultBlockTypeGuards.d.ts +4 -4
  186. package/types/src/blocks/defaultBlocks.d.ts +38 -38
  187. package/types/src/blocks/defaultProps.d.ts +1 -1
  188. package/types/src/editor/BlockNoteEditor.d.ts +28 -16
  189. package/types/src/editor/BlockNoteExtensions.d.ts +3 -3
  190. package/types/src/editor/BlockNoteSchema.d.ts +4 -4
  191. package/types/src/editor/BlockNoteTipTapEditor.d.ts +2 -2
  192. package/types/src/editor/cursorPositionTypes.d.ts +3 -2
  193. package/types/src/editor/selectionTypes.d.ts +2 -2
  194. package/types/src/extensions/BackgroundColor/BackgroundColorMark.d.ts +1 -1
  195. package/types/src/extensions/FilePanel/FilePanelPlugin.d.ts +4 -4
  196. package/types/src/extensions/FormattingToolbar/FormattingToolbarPlugin.d.ts +4 -4
  197. package/types/src/extensions/KeyboardShortcuts/KeyboardShortcutsExtension.d.ts +5 -0
  198. package/types/src/extensions/LinkToolbar/LinkToolbarPlugin.d.ts +4 -4
  199. package/types/src/extensions/NodeSelectionKeyboard/NodeSelectionKeyboardPlugin.d.ts +2 -0
  200. package/types/src/extensions/Placeholder/PlaceholderPlugin.d.ts +1 -1
  201. package/types/src/extensions/SideMenu/SideMenuPlugin.d.ts +12 -28
  202. package/types/src/extensions/SideMenu/dragging.d.ts +17 -0
  203. package/types/src/extensions/SuggestionMenu/DefaultSuggestionItem.d.ts +1 -1
  204. package/types/src/extensions/SuggestionMenu/SuggestionPlugin.d.ts +4 -4
  205. package/types/src/extensions/SuggestionMenu/getDefaultEmojiPickerItems.d.ts +3 -3
  206. package/types/src/extensions/SuggestionMenu/getDefaultSlashMenuItems.d.ts +4 -4
  207. package/types/src/extensions/TableHandles/TableHandlesPlugin.d.ts +4 -4
  208. package/types/src/extensions/TextColor/TextColorMark.d.ts +1 -1
  209. package/types/src/i18n/dictionary.d.ts +1 -1
  210. package/types/src/i18n/locales/ar.d.ts +1 -1
  211. package/types/src/i18n/locales/fr.d.ts +1 -1
  212. package/types/src/i18n/locales/hr.d.ts +239 -0
  213. package/types/src/i18n/locales/index.d.ts +15 -14
  214. package/types/src/i18n/locales/is.d.ts +1 -1
  215. package/types/src/i18n/locales/ja.d.ts +1 -1
  216. package/types/src/i18n/locales/ko.d.ts +1 -1
  217. package/types/src/i18n/locales/nl.d.ts +1 -1
  218. package/types/src/i18n/locales/pl.d.ts +1 -1
  219. package/types/src/i18n/locales/pt.d.ts +1 -1
  220. package/types/src/i18n/locales/ru.d.ts +1 -1
  221. package/types/src/i18n/locales/vi.d.ts +1 -1
  222. package/types/src/i18n/locales/zh.d.ts +1 -1
  223. package/types/src/index.d.ts +45 -44
  224. package/types/src/pm-nodes/BlockContainer.d.ts +2 -16
  225. package/types/src/pm-nodes/BlockGroup.d.ts +1 -1
  226. package/types/src/pm-nodes/index.d.ts +3 -3
  227. package/types/src/schema/blocks/createSpec.d.ts +5 -5
  228. package/types/src/schema/blocks/internal.d.ts +5 -5
  229. package/types/src/schema/blocks/types.d.ts +4 -4
  230. package/types/src/schema/index.d.ts +10 -10
  231. package/types/src/schema/inlineContent/createSpec.d.ts +3 -3
  232. package/types/src/schema/inlineContent/internal.d.ts +2 -2
  233. package/types/src/schema/inlineContent/types.d.ts +2 -2
  234. package/types/src/schema/styles/createSpec.d.ts +1 -1
  235. package/types/src/schema/styles/internal.d.ts +1 -1
  236. package/src/api/blockManipulation/__snapshots__/blockManipulation.test.ts.snap +0 -714
  237. package/src/api/blockManipulation/blockManipulation.test.ts +0 -292
  238. package/src/api/blockManipulation/blockManipulation.ts +0 -350
  239. package/src/api/exporters/html/util/sharedHTMLConversion.ts +0 -130
  240. package/src/api/exporters/html/util/simplifyBlocksRehypePlugin.ts +0 -218
  241. package/src/api/getCurrentBlockContentType.ts +0 -14
  242. package/types/src/api/blockManipulation/blockManipulation.d.ts +0 -14
  243. package/types/src/api/exporters/html/util/sharedHTMLConversion.d.ts +0 -9
  244. package/types/src/api/exporters/html/util/simplifyBlocksRehypePlugin.d.ts +0 -16
  245. package/types/src/api/getCurrentBlockContentType.d.ts +0 -2
  246. package/types/src/api/nodeConversions/nodeConversions.d.ts +0 -24
  247. package/types/src/extensions/NonEditableBlocks/NonEditableBlockPlugin.d.ts +0 -2
  248. /package/types/src/api/blockManipulation/{blockManipulation.test.d.ts → commands/insertBlocks/insertBlocks.test.d.ts} +0 -0
@@ -0,0 +1,222 @@
1
+ import { describe, expect, it } from "vitest";
2
+
3
+ import { setupTestEnv } from "../../setupTestEnv.js";
4
+ import { replaceBlocks } from "./replaceBlocks.js";
5
+
6
+ const getEditor = setupTestEnv();
7
+
8
+ describe("Test replaceBlocks", () => {
9
+ it("Remove single block", () => {
10
+ replaceBlocks(getEditor(), ["paragraph-0"], []);
11
+
12
+ expect(getEditor().document).toMatchSnapshot();
13
+ });
14
+
15
+ it("Remove multiple consecutive blocks", () => {
16
+ replaceBlocks(
17
+ getEditor(),
18
+ ["paragraph-0", "paragraph-1", "paragraph-with-children"],
19
+ []
20
+ );
21
+
22
+ expect(getEditor().document).toMatchSnapshot();
23
+ });
24
+
25
+ it("Remove multiple non-consecutive blocks", () => {
26
+ replaceBlocks(
27
+ getEditor(),
28
+ ["paragraph-0", "table-0", "heading-with-everything"],
29
+ []
30
+ );
31
+
32
+ expect(getEditor().document).toMatchSnapshot();
33
+ });
34
+
35
+ it("Replace single block with single basic", () => {
36
+ replaceBlocks(getEditor(), ["paragraph-0"], [{ type: "paragraph" }]);
37
+
38
+ expect(getEditor().document).toMatchSnapshot();
39
+ });
40
+
41
+ it("Replace multiple consecutive blocks with single basic", () => {
42
+ replaceBlocks(
43
+ getEditor(),
44
+ ["paragraph-0", "paragraph-1", "paragraph-with-children"],
45
+ [{ type: "paragraph" }]
46
+ );
47
+
48
+ expect(getEditor().document).toMatchSnapshot();
49
+ });
50
+
51
+ it("Replace multiple non-consecutive blocks with single basic", () => {
52
+ replaceBlocks(
53
+ getEditor(),
54
+ ["paragraph-0", "table-0", "heading-with-everything"],
55
+ [{ type: "paragraph" }]
56
+ );
57
+
58
+ expect(getEditor().document).toMatchSnapshot();
59
+ });
60
+
61
+ it("Replace single block with multiple", () => {
62
+ replaceBlocks(
63
+ getEditor(),
64
+ ["paragraph-0"],
65
+ [
66
+ { type: "paragraph", content: "Inserted paragraph 1" },
67
+ { type: "paragraph", content: "Inserted paragraph 2" },
68
+ { type: "paragraph", content: "Inserted paragraph 3" },
69
+ ]
70
+ );
71
+
72
+ expect(getEditor().document).toMatchSnapshot();
73
+ });
74
+
75
+ it("Replace multiple consecutive blocks with multiple", () => {
76
+ replaceBlocks(
77
+ getEditor(),
78
+ ["paragraph-0", "paragraph-1", "paragraph-with-children"],
79
+ [
80
+ { type: "paragraph", content: "Inserted paragraph 1" },
81
+ { type: "paragraph", content: "Inserted paragraph 2" },
82
+ { type: "paragraph", content: "Inserted paragraph 3" },
83
+ ]
84
+ );
85
+
86
+ expect(getEditor().document).toMatchSnapshot();
87
+ });
88
+
89
+ it("Replace multiple non-consecutive blocks with multiple", () => {
90
+ replaceBlocks(
91
+ getEditor(),
92
+ ["paragraph-0", "table-0", "heading-with-everything"],
93
+ [
94
+ { type: "paragraph", content: "Inserted paragraph 1" },
95
+ { type: "paragraph", content: "Inserted paragraph 2" },
96
+ { type: "paragraph", content: "Inserted paragraph 3" },
97
+ ]
98
+ );
99
+
100
+ expect(getEditor().document).toMatchSnapshot();
101
+ });
102
+
103
+ it("Replace single block with single complex", () => {
104
+ replaceBlocks(
105
+ getEditor(),
106
+ ["paragraph-0"],
107
+ [
108
+ {
109
+ id: "inserted-heading-with-everything",
110
+ type: "heading",
111
+ props: {
112
+ backgroundColor: "red",
113
+ level: 2,
114
+ textAlignment: "center",
115
+ textColor: "red",
116
+ },
117
+ content: [
118
+ { type: "text", text: "Heading", styles: { bold: true } },
119
+ { type: "text", text: " with styled ", styles: {} },
120
+ { type: "text", text: "content", styles: { italic: true } },
121
+ ],
122
+ children: [
123
+ {
124
+ id: "inserted-nested-paragraph-2",
125
+ type: "paragraph",
126
+ content: "Nested Paragraph 2",
127
+ children: [
128
+ {
129
+ id: "inserted-double-nested-paragraph-2",
130
+ type: "paragraph",
131
+ content: "Double Nested Paragraph 2",
132
+ },
133
+ ],
134
+ },
135
+ ],
136
+ },
137
+ ]
138
+ );
139
+
140
+ expect(getEditor().document).toMatchSnapshot();
141
+ });
142
+
143
+ it("Replace multiple consecutive blocks with single complex", () => {
144
+ replaceBlocks(
145
+ getEditor(),
146
+ ["paragraph-0", "paragraph-1", "paragraph-with-children"],
147
+ [
148
+ {
149
+ id: "inserted-heading-with-everything",
150
+ type: "heading",
151
+ props: {
152
+ backgroundColor: "red",
153
+ level: 2,
154
+ textAlignment: "center",
155
+ textColor: "red",
156
+ },
157
+ content: [
158
+ { type: "text", text: "Heading", styles: { bold: true } },
159
+ { type: "text", text: " with styled ", styles: {} },
160
+ { type: "text", text: "content", styles: { italic: true } },
161
+ ],
162
+ children: [
163
+ {
164
+ id: "inserted-nested-paragraph-2",
165
+ type: "paragraph",
166
+ content: "Nested Paragraph 2",
167
+ children: [
168
+ {
169
+ id: "inserted-double-nested-paragraph-2",
170
+ type: "paragraph",
171
+ content: "Double Nested Paragraph 2",
172
+ },
173
+ ],
174
+ },
175
+ ],
176
+ },
177
+ ]
178
+ );
179
+
180
+ expect(getEditor().document).toMatchSnapshot();
181
+ });
182
+
183
+ it("Replace multiple non-consecutive blocks with single complex", () => {
184
+ replaceBlocks(
185
+ getEditor(),
186
+ ["paragraph-0", "table-0", "heading-with-everything"],
187
+ [
188
+ {
189
+ id: "inserted-heading-with-everything",
190
+ type: "heading",
191
+ props: {
192
+ backgroundColor: "red",
193
+ level: 2,
194
+ textAlignment: "center",
195
+ textColor: "red",
196
+ },
197
+ content: [
198
+ { type: "text", text: "Heading", styles: { bold: true } },
199
+ { type: "text", text: " with styled ", styles: {} },
200
+ { type: "text", text: "content", styles: { italic: true } },
201
+ ],
202
+ children: [
203
+ {
204
+ id: "inserted-nested-paragraph-2",
205
+ type: "paragraph",
206
+ content: "Nested Paragraph 2",
207
+ children: [
208
+ {
209
+ id: "inserted-double-nested-paragraph-2",
210
+ type: "paragraph",
211
+ content: "Double Nested Paragraph 2",
212
+ },
213
+ ],
214
+ },
215
+ ],
216
+ },
217
+ ]
218
+ );
219
+
220
+ expect(getEditor().document).toMatchSnapshot();
221
+ });
222
+ });
@@ -0,0 +1,70 @@
1
+ import { Node } from "prosemirror-model";
2
+
3
+ import { Block, PartialBlock } from "../../../../blocks/defaultBlocks.js";
4
+ import type { BlockNoteEditor } from "../../../../editor/BlockNoteEditor";
5
+ import {
6
+ BlockIdentifier,
7
+ BlockSchema,
8
+ InlineContentSchema,
9
+ StyleSchema,
10
+ } from "../../../../schema/index.js";
11
+ import { blockToNode } from "../../../nodeConversions/blockToNode.js";
12
+ import { nodeToBlock } from "../../../nodeConversions/nodeToBlock.js";
13
+ import { removeBlocksWithCallback } from "../removeBlocks/removeBlocks.js";
14
+
15
+ export function replaceBlocks<
16
+ BSchema extends BlockSchema,
17
+ I extends InlineContentSchema,
18
+ S extends StyleSchema
19
+ >(
20
+ editor: BlockNoteEditor<BSchema, I, S>,
21
+ blocksToRemove: BlockIdentifier[],
22
+ blocksToInsert: PartialBlock<BSchema, I, S>[]
23
+ ): {
24
+ insertedBlocks: Block<BSchema, I, S>[];
25
+ removedBlocks: Block<BSchema, I, S>[];
26
+ } {
27
+ const nodesToInsert: Node[] = [];
28
+ for (const block of blocksToInsert) {
29
+ nodesToInsert.push(
30
+ blockToNode(block, editor.pmSchema, editor.schema.styleSchema)
31
+ );
32
+ }
33
+
34
+ const idOfFirstBlock =
35
+ typeof blocksToRemove[0] === "string"
36
+ ? blocksToRemove[0]
37
+ : blocksToRemove[0].id;
38
+ const removedBlocks = removeBlocksWithCallback(
39
+ editor,
40
+ blocksToRemove,
41
+ (node, pos, tr, removedSize) => {
42
+ if (node.attrs.id === idOfFirstBlock) {
43
+ const oldDocSize = tr.doc.nodeSize;
44
+ tr.insert(pos, nodesToInsert);
45
+ const newDocSize = tr.doc.nodeSize;
46
+
47
+ return removedSize + oldDocSize - newDocSize;
48
+ }
49
+
50
+ return removedSize;
51
+ }
52
+ );
53
+
54
+ // Now that the `PartialBlock`s have been converted to nodes, we can
55
+ // re-convert them into full `Block`s.
56
+ const insertedBlocks: Block<BSchema, I, S>[] = [];
57
+ for (const node of nodesToInsert) {
58
+ insertedBlocks.push(
59
+ nodeToBlock(
60
+ node,
61
+ editor.schema.blockSchema,
62
+ editor.schema.inlineContentSchema,
63
+ editor.schema.styleSchema,
64
+ editor.blockCache
65
+ )
66
+ );
67
+ }
68
+
69
+ return { insertedBlocks, removedBlocks };
70
+ }