@portabletext/editor 3.3.3 → 3.3.4

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 (306) hide show
  1. package/package.json +11 -12
  2. package/src/behaviors/_exports/index.ts +0 -1
  3. package/src/behaviors/behavior.abstract.annotation.ts +0 -77
  4. package/src/behaviors/behavior.abstract.decorator.ts +0 -39
  5. package/src/behaviors/behavior.abstract.delete.ts +0 -273
  6. package/src/behaviors/behavior.abstract.deserialize.ts +0 -232
  7. package/src/behaviors/behavior.abstract.insert.ts +0 -525
  8. package/src/behaviors/behavior.abstract.keyboard.ts +0 -189
  9. package/src/behaviors/behavior.abstract.list-item.ts +0 -70
  10. package/src/behaviors/behavior.abstract.move.ts +0 -79
  11. package/src/behaviors/behavior.abstract.select.ts +0 -118
  12. package/src/behaviors/behavior.abstract.serialize.ts +0 -96
  13. package/src/behaviors/behavior.abstract.split.ts +0 -170
  14. package/src/behaviors/behavior.abstract.style.ts +0 -55
  15. package/src/behaviors/behavior.abstract.ts +0 -139
  16. package/src/behaviors/behavior.config.ts +0 -7
  17. package/src/behaviors/behavior.core.annotations.ts +0 -62
  18. package/src/behaviors/behavior.core.block-element.ts +0 -116
  19. package/src/behaviors/behavior.core.block-objects.ts +0 -285
  20. package/src/behaviors/behavior.core.decorators.ts +0 -44
  21. package/src/behaviors/behavior.core.dnd.ts +0 -356
  22. package/src/behaviors/behavior.core.insert-break.ts +0 -266
  23. package/src/behaviors/behavior.core.insert.ts +0 -52
  24. package/src/behaviors/behavior.core.lists.ts +0 -691
  25. package/src/behaviors/behavior.core.ts +0 -44
  26. package/src/behaviors/behavior.perform-event.ts +0 -354
  27. package/src/behaviors/behavior.types.action.ts +0 -102
  28. package/src/behaviors/behavior.types.behavior.ts +0 -83
  29. package/src/behaviors/behavior.types.event.ts +0 -667
  30. package/src/behaviors/behavior.types.guard.ts +0 -11
  31. package/src/behaviors/index.ts +0 -17
  32. package/src/converters/converter.json.ts +0 -53
  33. package/src/converters/converter.portable-text.deserialize.test.ts +0 -680
  34. package/src/converters/converter.portable-text.ts +0 -75
  35. package/src/converters/converter.text-html.deserialize.test.ts +0 -406
  36. package/src/converters/converter.text-html.serialize.test.ts +0 -246
  37. package/src/converters/converter.text-html.ts +0 -87
  38. package/src/converters/converter.text-markdown.ts +0 -67
  39. package/src/converters/converter.text-plain.test.ts +0 -245
  40. package/src/converters/converter.text-plain.ts +0 -126
  41. package/src/converters/converter.types.ts +0 -72
  42. package/src/converters/converters.core.ts +0 -18
  43. package/src/editor/Editable.tsx +0 -1012
  44. package/src/editor/PortableTextEditor.tsx +0 -791
  45. package/src/editor/components/drop-indicator.tsx +0 -17
  46. package/src/editor/components/render-block-object.tsx +0 -121
  47. package/src/editor/components/render-default-object.tsx +0 -21
  48. package/src/editor/components/render-element.tsx +0 -88
  49. package/src/editor/components/render-inline-object.tsx +0 -129
  50. package/src/editor/components/render-leaf.tsx +0 -64
  51. package/src/editor/components/render-span.tsx +0 -303
  52. package/src/editor/components/render-text-block.tsx +0 -265
  53. package/src/editor/components/render-text.tsx +0 -18
  54. package/src/editor/components/use-core-block-element-behaviors.ts +0 -39
  55. package/src/editor/create-editor.ts +0 -323
  56. package/src/editor/create-slate-editor.tsx +0 -64
  57. package/src/editor/editor-actor-context.ts +0 -4
  58. package/src/editor/editor-context.tsx +0 -7
  59. package/src/editor/editor-dom.ts +0 -220
  60. package/src/editor/editor-machine.ts +0 -751
  61. package/src/editor/editor-provider.tsx +0 -111
  62. package/src/editor/editor-schema.ts +0 -6
  63. package/src/editor/editor-selector.ts +0 -89
  64. package/src/editor/editor-snapshot.ts +0 -68
  65. package/src/editor/event-to-change.tsx +0 -49
  66. package/src/editor/hooks/usePortableTextEditor.ts +0 -25
  67. package/src/editor/hooks/usePortableTextEditorSelection.tsx +0 -28
  68. package/src/editor/mutation-machine.ts +0 -322
  69. package/src/editor/plugins/create-with-event-listeners.ts +0 -271
  70. package/src/editor/plugins/createWithEditableAPI.ts +0 -529
  71. package/src/editor/plugins/createWithHotKeys.ts +0 -68
  72. package/src/editor/plugins/createWithObjectKeys.ts +0 -289
  73. package/src/editor/plugins/createWithPatches.ts +0 -272
  74. package/src/editor/plugins/createWithPortableTextMarkModel.ts +0 -559
  75. package/src/editor/plugins/createWithSchemaTypes.ts +0 -121
  76. package/src/editor/plugins/slate-plugin.update-selection.ts +0 -51
  77. package/src/editor/plugins/slate-plugin.update-value.ts +0 -46
  78. package/src/editor/plugins/with-plugins.ts +0 -69
  79. package/src/editor/range-decorations-machine.ts +0 -421
  80. package/src/editor/relay-actor-context.ts +0 -4
  81. package/src/editor/relay-machine.ts +0 -152
  82. package/src/editor/sync-machine.ts +0 -961
  83. package/src/editor/use-editor.ts +0 -27
  84. package/src/editor/validate-selection-machine.test.ts +0 -47
  85. package/src/editor/validate-selection-machine.ts +0 -149
  86. package/src/editor/weakMaps.ts +0 -15
  87. package/src/editor/with-normalizing-node.ts +0 -14
  88. package/src/editor/with-performing-behavior-operation.ts +0 -21
  89. package/src/editor/withChanges.ts +0 -13
  90. package/src/editor/without-normalizing-conditional.ts +0 -13
  91. package/src/editor/withoutPatching.ts +0 -14
  92. package/src/editor.ts +0 -59
  93. package/src/history/behavior.operation.history.redo.ts +0 -67
  94. package/src/history/behavior.operation.history.undo.ts +0 -71
  95. package/src/history/event.history.undo.test.tsx +0 -672
  96. package/src/history/history.preserving-keys.test.tsx +0 -112
  97. package/src/history/remote-patches.ts +0 -20
  98. package/src/history/slate-plugin.history.ts +0 -142
  99. package/src/history/slate-plugin.redoing.ts +0 -21
  100. package/src/history/slate-plugin.undoing.ts +0 -21
  101. package/src/history/slate-plugin.without-history.ts +0 -23
  102. package/src/history/transform-operation.ts +0 -245
  103. package/src/history/undo-redo-collaboration.test.tsx +0 -541
  104. package/src/history/undo-redo.feature +0 -125
  105. package/src/history/undo-redo.test.tsx +0 -195
  106. package/src/history/undo-step.ts +0 -148
  107. package/src/index.ts +0 -107
  108. package/src/internal-utils/__tests__/ranges.test.ts +0 -23
  109. package/src/internal-utils/__tests__/values.test.ts +0 -110
  110. package/src/internal-utils/apply-operation-to-portable-text.test.ts +0 -1861
  111. package/src/internal-utils/apply-operation-to-portable-text.ts +0 -615
  112. package/src/internal-utils/applyPatch.ts +0 -644
  113. package/src/internal-utils/block-keys.ts +0 -9
  114. package/src/internal-utils/build-index-maps.test.ts +0 -464
  115. package/src/internal-utils/build-index-maps.ts +0 -131
  116. package/src/internal-utils/collapse-selection.ts +0 -36
  117. package/src/internal-utils/compound-client-rect.ts +0 -28
  118. package/src/internal-utils/create-placeholder-block.ts +0 -21
  119. package/src/internal-utils/create-test-snapshot.ts +0 -28
  120. package/src/internal-utils/debug.ts +0 -12
  121. package/src/internal-utils/editor-selection.test.ts +0 -44
  122. package/src/internal-utils/editor-selection.ts +0 -56
  123. package/src/internal-utils/event-position.ts +0 -318
  124. package/src/internal-utils/global-scope.ts +0 -27
  125. package/src/internal-utils/globally-scoped-context.ts +0 -39
  126. package/src/internal-utils/is-hotkey.test.ts +0 -114
  127. package/src/internal-utils/is-hotkey.ts +0 -209
  128. package/src/internal-utils/mime-type.ts +0 -1
  129. package/src/internal-utils/move-range-by-operation.ts +0 -19
  130. package/src/internal-utils/operation-to-patches.test.ts +0 -522
  131. package/src/internal-utils/operation-to-patches.ts +0 -571
  132. package/src/internal-utils/portable-text-node.ts +0 -209
  133. package/src/internal-utils/schema.ts +0 -8
  134. package/src/internal-utils/selection-block-keys.ts +0 -20
  135. package/src/internal-utils/selection-focus-text.ts +0 -40
  136. package/src/internal-utils/selection-text.test.ts +0 -32
  137. package/src/internal-utils/selection-text.ts +0 -21
  138. package/src/internal-utils/selection.ts +0 -77
  139. package/src/internal-utils/sibling-utils.ts +0 -55
  140. package/src/internal-utils/slate-utils.test.tsx +0 -121
  141. package/src/internal-utils/slate-utils.ts +0 -417
  142. package/src/internal-utils/split-string.ts +0 -12
  143. package/src/internal-utils/stop-actor.ts +0 -43
  144. package/src/internal-utils/string-overlap.test.ts +0 -14
  145. package/src/internal-utils/string-overlap.ts +0 -28
  146. package/src/internal-utils/string-utils.ts +0 -7
  147. package/src/internal-utils/text-block-key.test.ts +0 -41
  148. package/src/internal-utils/text-block-key.ts +0 -26
  149. package/src/internal-utils/text-marks.test.ts +0 -41
  150. package/src/internal-utils/text-marks.ts +0 -22
  151. package/src/internal-utils/text-selection.test.ts +0 -211
  152. package/src/internal-utils/text-selection.ts +0 -121
  153. package/src/internal-utils/to-slate-range.test.ts +0 -278
  154. package/src/internal-utils/to-slate-range.ts +0 -171
  155. package/src/internal-utils/validateValue.ts +0 -443
  156. package/src/internal-utils/value-annotations.ts +0 -33
  157. package/src/internal-utils/values.test.ts +0 -282
  158. package/src/internal-utils/values.ts +0 -266
  159. package/src/keyboard-shortcuts/default-keyboard-shortcuts.ts +0 -146
  160. package/src/operations/behavior.operation.annotation.add.ts +0 -99
  161. package/src/operations/behavior.operation.annotation.remove.ts +0 -150
  162. package/src/operations/behavior.operation.block.set.ts +0 -104
  163. package/src/operations/behavior.operation.block.unset.ts +0 -54
  164. package/src/operations/behavior.operation.child.set.ts +0 -107
  165. package/src/operations/behavior.operation.child.unset.ts +0 -116
  166. package/src/operations/behavior.operation.decorator.add.ts +0 -131
  167. package/src/operations/behavior.operation.delete.ts +0 -294
  168. package/src/operations/behavior.operation.insert.block.ts +0 -495
  169. package/src/operations/behavior.operation.insert.child.ts +0 -129
  170. package/src/operations/behavior.operation.insert.text.ts +0 -8
  171. package/src/operations/behavior.operation.move.backward.ts +0 -12
  172. package/src/operations/behavior.operation.move.block.ts +0 -44
  173. package/src/operations/behavior.operation.move.forward.ts +0 -11
  174. package/src/operations/behavior.operation.select.ts +0 -27
  175. package/src/operations/behavior.operations.ts +0 -221
  176. package/src/plugins/_exports/index.ts +0 -1
  177. package/src/plugins/index.ts +0 -3
  178. package/src/plugins/plugin.behavior.tsx +0 -24
  179. package/src/plugins/plugin.editor-ref.tsx +0 -17
  180. package/src/plugins/plugin.event-listener.tsx +0 -68
  181. package/src/plugins/plugin.internal.auto-close-brackets.test.tsx +0 -71
  182. package/src/plugins/plugin.internal.auto-close-brackets.ts +0 -62
  183. package/src/plugins/plugin.internal.change-ref.tsx +0 -19
  184. package/src/plugins/plugin.internal.portable-text-editor-ref.tsx +0 -16
  185. package/src/plugins/plugin.internal.slate-editor-ref.tsx +0 -15
  186. package/src/priority/priority.core.ts +0 -3
  187. package/src/priority/priority.sort.test.ts +0 -319
  188. package/src/priority/priority.sort.ts +0 -123
  189. package/src/priority/priority.types.ts +0 -24
  190. package/src/selectors/_exports/index.ts +0 -1
  191. package/src/selectors/drag-selection.test.ts +0 -578
  192. package/src/selectors/drag-selection.ts +0 -118
  193. package/src/selectors/index.ts +0 -54
  194. package/src/selectors/selector.get-active-annotation-marks.ts +0 -12
  195. package/src/selectors/selector.get-active-annotations.ts +0 -36
  196. package/src/selectors/selector.get-active-decorators.ts +0 -29
  197. package/src/selectors/selector.get-active-list-item.ts +0 -38
  198. package/src/selectors/selector.get-active-style.ts +0 -38
  199. package/src/selectors/selector.get-anchor-block.ts +0 -22
  200. package/src/selectors/selector.get-anchor-child.ts +0 -36
  201. package/src/selectors/selector.get-anchor-span.ts +0 -17
  202. package/src/selectors/selector.get-anchor-text-block.ts +0 -18
  203. package/src/selectors/selector.get-block-offsets.ts +0 -34
  204. package/src/selectors/selector.get-caret-word-selection.test.ts +0 -284
  205. package/src/selectors/selector.get-caret-word-selection.ts +0 -134
  206. package/src/selectors/selector.get-first-block.ts +0 -14
  207. package/src/selectors/selector.get-focus-block-object.ts +0 -18
  208. package/src/selectors/selector.get-focus-block.ts +0 -23
  209. package/src/selectors/selector.get-focus-child.ts +0 -36
  210. package/src/selectors/selector.get-focus-inline-object.ts +0 -17
  211. package/src/selectors/selector.get-focus-list-block.ts +0 -18
  212. package/src/selectors/selector.get-focus-span.ts +0 -18
  213. package/src/selectors/selector.get-focus-text-block.ts +0 -18
  214. package/src/selectors/selector.get-last-block.ts +0 -16
  215. package/src/selectors/selector.get-mark-state.test.ts +0 -325
  216. package/src/selectors/selector.get-mark-state.ts +0 -263
  217. package/src/selectors/selector.get-next-block.ts +0 -29
  218. package/src/selectors/selector.get-next-inline-object.ts +0 -53
  219. package/src/selectors/selector.get-next-inline-objects.ts +0 -50
  220. package/src/selectors/selector.get-next-span.ts +0 -56
  221. package/src/selectors/selector.get-previous-block.ts +0 -29
  222. package/src/selectors/selector.get-previous-inline-object.ts +0 -50
  223. package/src/selectors/selector.get-previous-inline-objects.ts +0 -47
  224. package/src/selectors/selector.get-previous-span.ts +0 -53
  225. package/src/selectors/selector.get-selected-blocks.ts +0 -61
  226. package/src/selectors/selector.get-selected-spans.test.ts +0 -347
  227. package/src/selectors/selector.get-selected-spans.ts +0 -155
  228. package/src/selectors/selector.get-selected-text-blocks.ts +0 -73
  229. package/src/selectors/selector.get-selected-value.test.ts +0 -834
  230. package/src/selectors/selector.get-selected-value.ts +0 -66
  231. package/src/selectors/selector.get-selection-end-block.ts +0 -33
  232. package/src/selectors/selector.get-selection-end-child.ts +0 -33
  233. package/src/selectors/selector.get-selection-end-point.ts +0 -17
  234. package/src/selectors/selector.get-selection-start-block.ts +0 -33
  235. package/src/selectors/selector.get-selection-start-child.ts +0 -33
  236. package/src/selectors/selector.get-selection-start-point.ts +0 -17
  237. package/src/selectors/selector.get-selection-text.test.ts +0 -421
  238. package/src/selectors/selector.get-selection-text.ts +0 -27
  239. package/src/selectors/selector.get-selection.ts +0 -9
  240. package/src/selectors/selector.get-text-after.ts +0 -46
  241. package/src/selectors/selector.get-text-before.ts +0 -46
  242. package/src/selectors/selector.get-value.ts +0 -11
  243. package/src/selectors/selector.is-active-annotation.test.ts +0 -320
  244. package/src/selectors/selector.is-active-annotation.ts +0 -52
  245. package/src/selectors/selector.is-active-decorator.test.ts +0 -136
  246. package/src/selectors/selector.is-active-decorator.ts +0 -24
  247. package/src/selectors/selector.is-active-list-item.ts +0 -13
  248. package/src/selectors/selector.is-active-style.ts +0 -13
  249. package/src/selectors/selector.is-at-the-end-of-block.ts +0 -30
  250. package/src/selectors/selector.is-at-the-start-of-block.ts +0 -30
  251. package/src/selectors/selector.is-overlapping-selection.test.ts +0 -304
  252. package/src/selectors/selector.is-overlapping-selection.ts +0 -181
  253. package/src/selectors/selector.is-point-after-selection.ts +0 -97
  254. package/src/selectors/selector.is-point-before-selection.ts +0 -97
  255. package/src/selectors/selector.is-selecting-entire-blocks.ts +0 -43
  256. package/src/selectors/selector.is-selection-collapsed.ts +0 -17
  257. package/src/selectors/selector.is-selection-expanded.test.ts +0 -63
  258. package/src/selectors/selector.is-selection-expanded.ts +0 -9
  259. package/src/test/_exports/index.ts +0 -1
  260. package/src/test/gherkin-parameter-types.ts +0 -112
  261. package/src/test/index.ts +0 -1
  262. package/src/test/vitest/_exports/index.ts +0 -1
  263. package/src/test/vitest/index.ts +0 -3
  264. package/src/test/vitest/step-context.ts +0 -13
  265. package/src/test/vitest/step-definitions.tsx +0 -960
  266. package/src/test/vitest/test-editor.tsx +0 -198
  267. package/src/type-utils.ts +0 -29
  268. package/src/types/block-offset.ts +0 -9
  269. package/src/types/block-with-optional-key.ts +0 -25
  270. package/src/types/editor.ts +0 -509
  271. package/src/types/options.ts +0 -13
  272. package/src/types/paths.ts +0 -35
  273. package/src/types/slate-editor.ts +0 -50
  274. package/src/types/slate.ts +0 -27
  275. package/src/utils/_exports/index.ts +0 -1
  276. package/src/utils/asserters.ts +0 -9
  277. package/src/utils/index.ts +0 -24
  278. package/src/utils/key-generator.ts +0 -33
  279. package/src/utils/parse-blocks.test.ts +0 -836
  280. package/src/utils/parse-blocks.ts +0 -504
  281. package/src/utils/util.at-the-beginning-of-block.ts +0 -32
  282. package/src/utils/util.block-offset-to-block-selection-point.ts +0 -28
  283. package/src/utils/util.block-offset-to-selection-point.ts +0 -33
  284. package/src/utils/util.block-offset.test.ts +0 -375
  285. package/src/utils/util.block-offset.ts +0 -136
  286. package/src/utils/util.block-offsets-to-selection.ts +0 -38
  287. package/src/utils/util.child-selection-point-to-block-offset.ts +0 -51
  288. package/src/utils/util.get-block-end-point.ts +0 -35
  289. package/src/utils/util.get-block-start-point.ts +0 -31
  290. package/src/utils/util.get-selection-end-point.ts +0 -20
  291. package/src/utils/util.get-selection-start-point.ts +0 -20
  292. package/src/utils/util.get-text-block-text.ts +0 -8
  293. package/src/utils/util.is-empty-text-block.ts +0 -21
  294. package/src/utils/util.is-equal-selection-points.ts +0 -13
  295. package/src/utils/util.is-equal-selections.ts +0 -20
  296. package/src/utils/util.is-keyed-segment.ts +0 -8
  297. package/src/utils/util.is-selection-collapsed.ts +0 -16
  298. package/src/utils/util.is-selection-expanded.ts +0 -13
  299. package/src/utils/util.merge-text-blocks.ts +0 -40
  300. package/src/utils/util.reverse-selection.ts +0 -26
  301. package/src/utils/util.selection-point-to-block-offset.ts +0 -30
  302. package/src/utils/util.selection-point.ts +0 -22
  303. package/src/utils/util.slice-blocks.ts +0 -221
  304. package/src/utils/util.slice-text-block.test.ts +0 -190
  305. package/src/utils/util.slice-text-block.ts +0 -89
  306. package/src/utils/util.split-text-block.ts +0 -54
@@ -1,8 +0,0 @@
1
- import type {PortableTextTextBlock} from '@sanity/types'
2
-
3
- /**
4
- * @public
5
- */
6
- export function getTextBlockText(block: PortableTextTextBlock) {
7
- return block.children.map((child) => child.text ?? '').join('')
8
- }
@@ -1,21 +0,0 @@
1
- import {isSpan, isTextBlock} from '@portabletext/schema'
2
- import type {PortableTextBlock} from '@sanity/types'
3
- import type {EditorContext} from '../editor/editor-snapshot'
4
- import {getTextBlockText} from './util.get-text-block-text'
5
-
6
- /**
7
- * @public
8
- */
9
- export function isEmptyTextBlock(
10
- context: Pick<EditorContext, 'schema'>,
11
- block: PortableTextBlock | unknown,
12
- ) {
13
- if (!isTextBlock(context, block)) {
14
- return false
15
- }
16
-
17
- const onlyText = block.children.every((child) => isSpan(context, child))
18
- const blockText = getTextBlockText(block)
19
-
20
- return onlyText && blockText === ''
21
- }
@@ -1,13 +0,0 @@
1
- import type {EditorSelectionPoint} from '../types/editor'
2
-
3
- /**
4
- * @public
5
- */
6
- export function isEqualSelectionPoints(
7
- a: EditorSelectionPoint,
8
- b: EditorSelectionPoint,
9
- ) {
10
- return (
11
- a.offset === b.offset && JSON.stringify(a.path) === JSON.stringify(b.path)
12
- )
13
- }
@@ -1,20 +0,0 @@
1
- import type {EditorSelection} from '../types/editor'
2
- import {isEqualSelectionPoints} from './util.is-equal-selection-points'
3
-
4
- /**
5
- * @public
6
- */
7
- export function isEqualSelections(a: EditorSelection, b: EditorSelection) {
8
- if (!a && !b) {
9
- return true
10
- }
11
-
12
- if (!a || !b) {
13
- return false
14
- }
15
-
16
- return (
17
- isEqualSelectionPoints(a.anchor, b.anchor) &&
18
- isEqualSelectionPoints(a.focus, b.focus)
19
- )
20
- }
@@ -1,8 +0,0 @@
1
- import type {KeyedSegment} from '@sanity/types'
2
-
3
- /**
4
- * @public
5
- */
6
- export function isKeyedSegment(segment: unknown): segment is KeyedSegment {
7
- return typeof segment === 'object' && segment !== null && '_key' in segment
8
- }
@@ -1,16 +0,0 @@
1
- import type {EditorSelection} from '../types/editor'
2
-
3
- /**
4
- * @public
5
- */
6
- export function isSelectionCollapsed(selection: EditorSelection) {
7
- if (!selection) {
8
- return false
9
- }
10
-
11
- return (
12
- JSON.stringify(selection.anchor.path) ===
13
- JSON.stringify(selection.focus.path) &&
14
- selection.anchor.offset === selection.focus.offset
15
- )
16
- }
@@ -1,13 +0,0 @@
1
- import type {EditorSelection} from '../types/editor'
2
- import {isSelectionCollapsed} from './util.is-selection-collapsed'
3
-
4
- /**
5
- * @public
6
- */
7
- export function isSelectionExpanded(selection: EditorSelection) {
8
- if (!selection) {
9
- return false
10
- }
11
-
12
- return !isSelectionCollapsed(selection)
13
- }
@@ -1,40 +0,0 @@
1
- import {isTextBlock} from '@portabletext/schema'
2
- import type {PortableTextTextBlock} from '@sanity/types'
3
- import type {EditorContext} from '../editor/editor-snapshot'
4
- import {parseBlock} from './parse-blocks'
5
-
6
- /**
7
- * @beta
8
- */
9
- export function mergeTextBlocks({
10
- context,
11
- targetBlock,
12
- incomingBlock,
13
- }: {
14
- context: Pick<EditorContext, 'keyGenerator' | 'schema'>
15
- targetBlock: PortableTextTextBlock
16
- incomingBlock: PortableTextTextBlock
17
- }) {
18
- const parsedIncomingBlock = parseBlock({
19
- context,
20
- block: incomingBlock,
21
- options: {
22
- normalize: false,
23
- removeUnusedMarkDefs: true,
24
- validateFields: false,
25
- },
26
- })
27
-
28
- if (!parsedIncomingBlock || !isTextBlock(context, parsedIncomingBlock)) {
29
- return targetBlock
30
- }
31
-
32
- return {
33
- ...targetBlock,
34
- children: [...targetBlock.children, ...parsedIncomingBlock.children],
35
- markDefs: [
36
- ...(targetBlock.markDefs ?? []),
37
- ...(parsedIncomingBlock.markDefs ?? []),
38
- ],
39
- }
40
- }
@@ -1,26 +0,0 @@
1
- import type {EditorSelection} from '../types/editor'
2
-
3
- /**
4
- * @public
5
- */
6
- export function reverseSelection<
7
- TEditorSelection extends NonNullable<EditorSelection> | null,
8
- >(selection: TEditorSelection): TEditorSelection {
9
- if (!selection) {
10
- return selection
11
- }
12
-
13
- if (selection.backward) {
14
- return {
15
- anchor: selection.focus,
16
- focus: selection.anchor,
17
- backward: false,
18
- } as TEditorSelection
19
- }
20
-
21
- return {
22
- anchor: selection.focus,
23
- focus: selection.anchor,
24
- backward: true,
25
- } as TEditorSelection
26
- }
@@ -1,30 +0,0 @@
1
- import type {EditorContext} from '../editor/editor-snapshot'
2
- import type {BlockOffset} from '../types/block-offset'
3
- import type {EditorSelectionPoint} from '../types/editor'
4
- import {childSelectionPointToBlockOffset} from './util.child-selection-point-to-block-offset'
5
- import {getBlockKeyFromSelectionPoint} from './util.selection-point'
6
-
7
- /**
8
- * @public
9
- */
10
- export function selectionPointToBlockOffset({
11
- context,
12
- selectionPoint,
13
- }: {
14
- context: Pick<EditorContext, 'schema' | 'value'>
15
- selectionPoint: EditorSelectionPoint
16
- }): BlockOffset | undefined {
17
- const blockKey = getBlockKeyFromSelectionPoint(selectionPoint)
18
-
19
- if (selectionPoint.path.length === 1 && blockKey !== undefined) {
20
- return {
21
- path: [{_key: blockKey}],
22
- offset: selectionPoint.offset,
23
- }
24
- }
25
-
26
- return childSelectionPointToBlockOffset({
27
- context,
28
- selectionPoint,
29
- })
30
- }
@@ -1,22 +0,0 @@
1
- import type {EditorSelectionPoint} from '../types/editor'
2
- import {isKeyedSegment} from './util.is-keyed-segment'
3
-
4
- export function getBlockKeyFromSelectionPoint(point: EditorSelectionPoint) {
5
- const blockPathSegment = point.path.at(0)
6
-
7
- if (isKeyedSegment(blockPathSegment)) {
8
- return blockPathSegment._key
9
- }
10
-
11
- return undefined
12
- }
13
-
14
- export function getChildKeyFromSelectionPoint(point: EditorSelectionPoint) {
15
- const childPathSegment = point.path.at(2)
16
-
17
- if (isKeyedSegment(childPathSegment)) {
18
- return childPathSegment._key
19
- }
20
-
21
- return undefined
22
- }
@@ -1,221 +0,0 @@
1
- import {isSpan, isTextBlock} from '@portabletext/schema'
2
- import type {PortableTextBlock} from '@sanity/types'
3
- import type {EditorContext} from '../editor/editor-snapshot'
4
- import {defaultKeyGenerator} from './key-generator'
5
- import {parseBlock} from './parse-blocks'
6
- import {getSelectionEndPoint} from './util.get-selection-end-point'
7
- import {getSelectionStartPoint} from './util.get-selection-start-point'
8
- import {
9
- getBlockKeyFromSelectionPoint,
10
- getChildKeyFromSelectionPoint,
11
- } from './util.selection-point'
12
-
13
- /**
14
- * @public
15
- */
16
- export function sliceBlocks({
17
- context,
18
- blocks,
19
- }: {
20
- context: Pick<EditorContext, 'schema' | 'selection'> & {
21
- keyGenerator?: () => string
22
- }
23
- blocks: Array<PortableTextBlock>
24
- }): Array<PortableTextBlock> {
25
- const slice: Array<PortableTextBlock> = []
26
-
27
- if (!context.selection) {
28
- return slice
29
- }
30
-
31
- let startBlock: PortableTextBlock | undefined
32
- const middleBlocks: PortableTextBlock[] = []
33
- let endBlock: PortableTextBlock | undefined
34
-
35
- const startPoint = getSelectionStartPoint(context.selection)
36
- const endPoint = getSelectionEndPoint(context.selection)
37
- const startBlockKey = getBlockKeyFromSelectionPoint(startPoint)
38
- const startChildKey = getChildKeyFromSelectionPoint(startPoint)
39
- const endBlockKey = getBlockKeyFromSelectionPoint(endPoint)
40
- const endChildKey = getChildKeyFromSelectionPoint(endPoint)
41
-
42
- if (!startBlockKey || !endBlockKey) {
43
- return slice
44
- }
45
-
46
- for (const block of blocks) {
47
- if (!isTextBlock(context, block)) {
48
- if (block._key === startBlockKey && block._key === endBlockKey) {
49
- startBlock = block
50
- break
51
- }
52
- }
53
-
54
- if (block._key === startBlockKey) {
55
- if (!isTextBlock(context, block)) {
56
- startBlock = block
57
- continue
58
- }
59
-
60
- if (startChildKey) {
61
- for (const child of block.children) {
62
- if (child._key === startChildKey) {
63
- if (isSpan(context, child)) {
64
- const text =
65
- child._key === endChildKey
66
- ? child.text.slice(startPoint.offset, endPoint.offset)
67
- : child.text.slice(startPoint.offset)
68
-
69
- startBlock = {
70
- ...block,
71
- children: [
72
- {
73
- ...child,
74
- text,
75
- },
76
- ],
77
- }
78
- } else {
79
- startBlock = {
80
- ...block,
81
- children: [child],
82
- }
83
- }
84
-
85
- if (block._key === endBlockKey && startChildKey === endChildKey) {
86
- break
87
- }
88
- continue
89
- }
90
-
91
- if (startBlock && isTextBlock(context, startBlock)) {
92
- if (
93
- endChildKey &&
94
- child._key === endChildKey &&
95
- isSpan(context, child)
96
- ) {
97
- startBlock.children.push({
98
- ...child,
99
- text: child.text.slice(0, endPoint.offset),
100
- })
101
- } else {
102
- startBlock.children.push(child)
103
- }
104
-
105
- if (
106
- block._key === endBlockKey &&
107
- endChildKey &&
108
- child._key === endChildKey
109
- ) {
110
- break
111
- }
112
- }
113
- }
114
-
115
- if (startBlockKey === endBlockKey) {
116
- break
117
- }
118
-
119
- continue
120
- }
121
-
122
- startBlock = block
123
-
124
- if (startBlockKey === endBlockKey) {
125
- break
126
- }
127
- }
128
-
129
- if (block._key === endBlockKey) {
130
- if (!isTextBlock(context, block)) {
131
- endBlock = block
132
- break
133
- }
134
-
135
- if (endChildKey) {
136
- endBlock = {
137
- ...block,
138
- children: [],
139
- }
140
-
141
- for (const child of block.children) {
142
- if (endBlock && isTextBlock(context, endBlock)) {
143
- if (child._key === endChildKey && isSpan(context, child)) {
144
- endBlock.children.push({
145
- ...child,
146
- text: child.text.slice(0, endPoint.offset),
147
- })
148
-
149
- break
150
- }
151
-
152
- endBlock.children.push(child)
153
-
154
- if (endChildKey && child._key === endChildKey) {
155
- break
156
- }
157
- }
158
- }
159
-
160
- break
161
- }
162
-
163
- endBlock = block
164
-
165
- break
166
- }
167
-
168
- if (startBlock) {
169
- middleBlocks.push(
170
- parseBlock({
171
- context: {
172
- schema: context.schema,
173
- keyGenerator: context.keyGenerator ?? defaultKeyGenerator,
174
- },
175
- block,
176
- options: {
177
- normalize: false,
178
- removeUnusedMarkDefs: true,
179
- validateFields: false,
180
- },
181
- }) ?? block,
182
- )
183
- }
184
- }
185
-
186
- const parsedStartBlock = startBlock
187
- ? parseBlock({
188
- context: {
189
- schema: context.schema,
190
- keyGenerator: context.keyGenerator ?? defaultKeyGenerator,
191
- },
192
- block: startBlock,
193
- options: {
194
- normalize: false,
195
- removeUnusedMarkDefs: true,
196
- validateFields: false,
197
- },
198
- })
199
- : undefined
200
-
201
- const parsedEndBlock = endBlock
202
- ? parseBlock({
203
- context: {
204
- schema: context.schema,
205
- keyGenerator: context.keyGenerator ?? defaultKeyGenerator,
206
- },
207
- block: endBlock,
208
- options: {
209
- normalize: false,
210
- removeUnusedMarkDefs: true,
211
- validateFields: false,
212
- },
213
- })
214
- : undefined
215
-
216
- return [
217
- ...(parsedStartBlock ? [parsedStartBlock] : []),
218
- ...middleBlocks,
219
- ...(parsedEndBlock ? [parsedEndBlock] : []),
220
- ]
221
- }
@@ -1,190 +0,0 @@
1
- import {compileSchema, defineSchema} from '@portabletext/schema'
2
- import {createTestKeyGenerator} from '@portabletext/test'
3
- import type {
4
- PortableTextObject,
5
- PortableTextSpan,
6
- PortableTextTextBlock,
7
- } from '@sanity/types'
8
- import {describe, expect, test} from 'vitest'
9
- import {sliceTextBlock} from './util.slice-text-block'
10
-
11
- const keyGenerator = createTestKeyGenerator()
12
-
13
- const schema = compileSchema(
14
- defineSchema({
15
- inlineObjects: [{name: 'stock-ticker'}],
16
- }),
17
- )
18
-
19
- function createSpan(span: Partial<PortableTextSpan>) {
20
- return {
21
- _type: 'span',
22
- _key: span._key ?? keyGenerator(),
23
- text: span.text ?? '',
24
- marks: span.marks ?? [],
25
- }
26
- }
27
-
28
- function createInlineObject(inlineObject: Partial<PortableTextObject>) {
29
- return {
30
- _type: 'stock-ticker',
31
- _key: inlineObject._key ?? keyGenerator(),
32
- ...inlineObject,
33
- }
34
- }
35
-
36
- function createBlock(
37
- block: Partial<PortableTextTextBlock>,
38
- ): PortableTextTextBlock {
39
- return {
40
- _type: 'block',
41
- _key: block._key ?? keyGenerator(),
42
- children: block.children ?? [createSpan({})],
43
- markDefs: block.markDefs ?? [],
44
- style: block.style ?? 'normal',
45
- ...block,
46
- }
47
- }
48
-
49
- describe(sliceTextBlock.name, () => {
50
- test('empty block', () => {
51
- const span = createSpan({})
52
- const block = createBlock({
53
- children: [span],
54
- })
55
-
56
- expect(
57
- sliceTextBlock({
58
- context: {
59
- schema,
60
- selection: {
61
- anchor: {
62
- path: [{_key: block._key}, 'children', {_key: span._key}],
63
- offset: 0,
64
- },
65
- focus: {
66
- path: [{_key: block._key}, 'children', {_key: span._key}],
67
- offset: 0,
68
- },
69
- },
70
- },
71
- block,
72
- }),
73
- ).toEqual(block)
74
- })
75
-
76
- test('middle', () => {
77
- const span = createSpan({
78
- text: 'foo bar baz',
79
- })
80
- const block = createBlock({
81
- children: [span],
82
- })
83
-
84
- expect(
85
- sliceTextBlock({
86
- context: {
87
- schema,
88
- selection: {
89
- anchor: {
90
- path: [{_key: block._key}, 'children', {_key: span._key}],
91
- offset: 4,
92
- },
93
- focus: {
94
- path: [{_key: block._key}, 'children', {_key: span._key}],
95
- offset: 7,
96
- },
97
- },
98
- },
99
- block,
100
- }),
101
- ).toEqual({
102
- ...block,
103
- children: [
104
- {
105
- ...span,
106
- text: 'bar',
107
- },
108
- ],
109
- })
110
- })
111
-
112
- describe('multiple children', () => {
113
- const fooSpan = createSpan({
114
- text: 'foo',
115
- marks: ['strong'],
116
- })
117
- const barSpan = createSpan({
118
- text: 'bar',
119
- marks: ['em'],
120
- })
121
- const bazSpan = createSpan({
122
- text: 'baz',
123
- marks: ['underline'],
124
- })
125
- const stockTicker = createInlineObject({
126
- symbol: 'AAPL',
127
- })
128
- const block = createBlock({
129
- children: [fooSpan, barSpan, stockTicker, bazSpan],
130
- })
131
-
132
- test('mid-span', () => {
133
- expect(
134
- sliceTextBlock({
135
- context: {
136
- schema,
137
- selection: {
138
- anchor: {
139
- path: [{_key: block._key}, 'children', {_key: barSpan._key}],
140
- offset: 1,
141
- },
142
- focus: {
143
- path: [{_key: block._key}, 'children', {_key: bazSpan._key}],
144
- offset: 1,
145
- },
146
- },
147
- },
148
- block,
149
- }),
150
- ).toEqual({
151
- ...block,
152
- children: [
153
- {
154
- ...barSpan,
155
- text: 'ar',
156
- },
157
- stockTicker,
158
- {
159
- ...bazSpan,
160
- text: 'b',
161
- },
162
- ],
163
- })
164
- })
165
-
166
- test('from end of span to end of block', () => {
167
- expect(
168
- sliceTextBlock({
169
- context: {
170
- schema,
171
- selection: {
172
- anchor: {
173
- path: [{_key: block._key}, 'children', {_key: fooSpan._key}],
174
- offset: 3,
175
- },
176
- focus: {
177
- path: [{_key: block._key}, 'children', {_key: bazSpan._key}],
178
- offset: 3,
179
- },
180
- },
181
- },
182
- block,
183
- }),
184
- ).toEqual({
185
- ...block,
186
- children: [{...fooSpan, text: ''}, barSpan, stockTicker, bazSpan],
187
- })
188
- })
189
- })
190
- })