@portabletext/editor 3.3.3 → 3.3.5

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 (309) hide show
  1. package/lib/_chunks-dts/index.d.ts +21 -1667
  2. package/lib/index.js +511 -9010
  3. package/lib/index.js.map +1 -1
  4. package/package.json +14 -15
  5. package/src/behaviors/_exports/index.ts +0 -1
  6. package/src/behaviors/behavior.abstract.annotation.ts +0 -77
  7. package/src/behaviors/behavior.abstract.decorator.ts +0 -39
  8. package/src/behaviors/behavior.abstract.delete.ts +0 -273
  9. package/src/behaviors/behavior.abstract.deserialize.ts +0 -232
  10. package/src/behaviors/behavior.abstract.insert.ts +0 -525
  11. package/src/behaviors/behavior.abstract.keyboard.ts +0 -189
  12. package/src/behaviors/behavior.abstract.list-item.ts +0 -70
  13. package/src/behaviors/behavior.abstract.move.ts +0 -79
  14. package/src/behaviors/behavior.abstract.select.ts +0 -118
  15. package/src/behaviors/behavior.abstract.serialize.ts +0 -96
  16. package/src/behaviors/behavior.abstract.split.ts +0 -170
  17. package/src/behaviors/behavior.abstract.style.ts +0 -55
  18. package/src/behaviors/behavior.abstract.ts +0 -139
  19. package/src/behaviors/behavior.config.ts +0 -7
  20. package/src/behaviors/behavior.core.annotations.ts +0 -62
  21. package/src/behaviors/behavior.core.block-element.ts +0 -116
  22. package/src/behaviors/behavior.core.block-objects.ts +0 -285
  23. package/src/behaviors/behavior.core.decorators.ts +0 -44
  24. package/src/behaviors/behavior.core.dnd.ts +0 -356
  25. package/src/behaviors/behavior.core.insert-break.ts +0 -266
  26. package/src/behaviors/behavior.core.insert.ts +0 -52
  27. package/src/behaviors/behavior.core.lists.ts +0 -691
  28. package/src/behaviors/behavior.core.ts +0 -44
  29. package/src/behaviors/behavior.perform-event.ts +0 -354
  30. package/src/behaviors/behavior.types.action.ts +0 -102
  31. package/src/behaviors/behavior.types.behavior.ts +0 -83
  32. package/src/behaviors/behavior.types.event.ts +0 -667
  33. package/src/behaviors/behavior.types.guard.ts +0 -11
  34. package/src/behaviors/index.ts +0 -17
  35. package/src/converters/converter.json.ts +0 -53
  36. package/src/converters/converter.portable-text.deserialize.test.ts +0 -680
  37. package/src/converters/converter.portable-text.ts +0 -75
  38. package/src/converters/converter.text-html.deserialize.test.ts +0 -406
  39. package/src/converters/converter.text-html.serialize.test.ts +0 -246
  40. package/src/converters/converter.text-html.ts +0 -87
  41. package/src/converters/converter.text-markdown.ts +0 -67
  42. package/src/converters/converter.text-plain.test.ts +0 -245
  43. package/src/converters/converter.text-plain.ts +0 -126
  44. package/src/converters/converter.types.ts +0 -72
  45. package/src/converters/converters.core.ts +0 -18
  46. package/src/editor/Editable.tsx +0 -1012
  47. package/src/editor/PortableTextEditor.tsx +0 -791
  48. package/src/editor/components/drop-indicator.tsx +0 -17
  49. package/src/editor/components/render-block-object.tsx +0 -121
  50. package/src/editor/components/render-default-object.tsx +0 -21
  51. package/src/editor/components/render-element.tsx +0 -88
  52. package/src/editor/components/render-inline-object.tsx +0 -129
  53. package/src/editor/components/render-leaf.tsx +0 -64
  54. package/src/editor/components/render-span.tsx +0 -303
  55. package/src/editor/components/render-text-block.tsx +0 -265
  56. package/src/editor/components/render-text.tsx +0 -18
  57. package/src/editor/components/use-core-block-element-behaviors.ts +0 -39
  58. package/src/editor/create-editor.ts +0 -323
  59. package/src/editor/create-slate-editor.tsx +0 -64
  60. package/src/editor/editor-actor-context.ts +0 -4
  61. package/src/editor/editor-context.tsx +0 -7
  62. package/src/editor/editor-dom.ts +0 -220
  63. package/src/editor/editor-machine.ts +0 -751
  64. package/src/editor/editor-provider.tsx +0 -111
  65. package/src/editor/editor-schema.ts +0 -6
  66. package/src/editor/editor-selector.ts +0 -89
  67. package/src/editor/editor-snapshot.ts +0 -68
  68. package/src/editor/event-to-change.tsx +0 -49
  69. package/src/editor/hooks/usePortableTextEditor.ts +0 -25
  70. package/src/editor/hooks/usePortableTextEditorSelection.tsx +0 -28
  71. package/src/editor/mutation-machine.ts +0 -322
  72. package/src/editor/plugins/create-with-event-listeners.ts +0 -271
  73. package/src/editor/plugins/createWithEditableAPI.ts +0 -529
  74. package/src/editor/plugins/createWithHotKeys.ts +0 -68
  75. package/src/editor/plugins/createWithObjectKeys.ts +0 -289
  76. package/src/editor/plugins/createWithPatches.ts +0 -272
  77. package/src/editor/plugins/createWithPortableTextMarkModel.ts +0 -559
  78. package/src/editor/plugins/createWithSchemaTypes.ts +0 -121
  79. package/src/editor/plugins/slate-plugin.update-selection.ts +0 -51
  80. package/src/editor/plugins/slate-plugin.update-value.ts +0 -46
  81. package/src/editor/plugins/with-plugins.ts +0 -69
  82. package/src/editor/range-decorations-machine.ts +0 -421
  83. package/src/editor/relay-actor-context.ts +0 -4
  84. package/src/editor/relay-machine.ts +0 -152
  85. package/src/editor/sync-machine.ts +0 -961
  86. package/src/editor/use-editor.ts +0 -27
  87. package/src/editor/validate-selection-machine.test.ts +0 -47
  88. package/src/editor/validate-selection-machine.ts +0 -149
  89. package/src/editor/weakMaps.ts +0 -15
  90. package/src/editor/with-normalizing-node.ts +0 -14
  91. package/src/editor/with-performing-behavior-operation.ts +0 -21
  92. package/src/editor/withChanges.ts +0 -13
  93. package/src/editor/without-normalizing-conditional.ts +0 -13
  94. package/src/editor/withoutPatching.ts +0 -14
  95. package/src/editor.ts +0 -59
  96. package/src/history/behavior.operation.history.redo.ts +0 -67
  97. package/src/history/behavior.operation.history.undo.ts +0 -71
  98. package/src/history/event.history.undo.test.tsx +0 -672
  99. package/src/history/history.preserving-keys.test.tsx +0 -112
  100. package/src/history/remote-patches.ts +0 -20
  101. package/src/history/slate-plugin.history.ts +0 -142
  102. package/src/history/slate-plugin.redoing.ts +0 -21
  103. package/src/history/slate-plugin.undoing.ts +0 -21
  104. package/src/history/slate-plugin.without-history.ts +0 -23
  105. package/src/history/transform-operation.ts +0 -245
  106. package/src/history/undo-redo-collaboration.test.tsx +0 -541
  107. package/src/history/undo-redo.feature +0 -125
  108. package/src/history/undo-redo.test.tsx +0 -195
  109. package/src/history/undo-step.ts +0 -148
  110. package/src/index.ts +0 -107
  111. package/src/internal-utils/__tests__/ranges.test.ts +0 -23
  112. package/src/internal-utils/__tests__/values.test.ts +0 -110
  113. package/src/internal-utils/apply-operation-to-portable-text.test.ts +0 -1861
  114. package/src/internal-utils/apply-operation-to-portable-text.ts +0 -615
  115. package/src/internal-utils/applyPatch.ts +0 -644
  116. package/src/internal-utils/block-keys.ts +0 -9
  117. package/src/internal-utils/build-index-maps.test.ts +0 -464
  118. package/src/internal-utils/build-index-maps.ts +0 -131
  119. package/src/internal-utils/collapse-selection.ts +0 -36
  120. package/src/internal-utils/compound-client-rect.ts +0 -28
  121. package/src/internal-utils/create-placeholder-block.ts +0 -21
  122. package/src/internal-utils/create-test-snapshot.ts +0 -28
  123. package/src/internal-utils/debug.ts +0 -12
  124. package/src/internal-utils/editor-selection.test.ts +0 -44
  125. package/src/internal-utils/editor-selection.ts +0 -56
  126. package/src/internal-utils/event-position.ts +0 -318
  127. package/src/internal-utils/global-scope.ts +0 -27
  128. package/src/internal-utils/globally-scoped-context.ts +0 -39
  129. package/src/internal-utils/is-hotkey.test.ts +0 -114
  130. package/src/internal-utils/is-hotkey.ts +0 -209
  131. package/src/internal-utils/mime-type.ts +0 -1
  132. package/src/internal-utils/move-range-by-operation.ts +0 -19
  133. package/src/internal-utils/operation-to-patches.test.ts +0 -522
  134. package/src/internal-utils/operation-to-patches.ts +0 -571
  135. package/src/internal-utils/portable-text-node.ts +0 -209
  136. package/src/internal-utils/schema.ts +0 -8
  137. package/src/internal-utils/selection-block-keys.ts +0 -20
  138. package/src/internal-utils/selection-focus-text.ts +0 -40
  139. package/src/internal-utils/selection-text.test.ts +0 -32
  140. package/src/internal-utils/selection-text.ts +0 -21
  141. package/src/internal-utils/selection.ts +0 -77
  142. package/src/internal-utils/sibling-utils.ts +0 -55
  143. package/src/internal-utils/slate-utils.test.tsx +0 -121
  144. package/src/internal-utils/slate-utils.ts +0 -417
  145. package/src/internal-utils/split-string.ts +0 -12
  146. package/src/internal-utils/stop-actor.ts +0 -43
  147. package/src/internal-utils/string-overlap.test.ts +0 -14
  148. package/src/internal-utils/string-overlap.ts +0 -28
  149. package/src/internal-utils/string-utils.ts +0 -7
  150. package/src/internal-utils/text-block-key.test.ts +0 -41
  151. package/src/internal-utils/text-block-key.ts +0 -26
  152. package/src/internal-utils/text-marks.test.ts +0 -41
  153. package/src/internal-utils/text-marks.ts +0 -22
  154. package/src/internal-utils/text-selection.test.ts +0 -211
  155. package/src/internal-utils/text-selection.ts +0 -121
  156. package/src/internal-utils/to-slate-range.test.ts +0 -278
  157. package/src/internal-utils/to-slate-range.ts +0 -171
  158. package/src/internal-utils/validateValue.ts +0 -443
  159. package/src/internal-utils/value-annotations.ts +0 -33
  160. package/src/internal-utils/values.test.ts +0 -282
  161. package/src/internal-utils/values.ts +0 -266
  162. package/src/keyboard-shortcuts/default-keyboard-shortcuts.ts +0 -146
  163. package/src/operations/behavior.operation.annotation.add.ts +0 -99
  164. package/src/operations/behavior.operation.annotation.remove.ts +0 -150
  165. package/src/operations/behavior.operation.block.set.ts +0 -104
  166. package/src/operations/behavior.operation.block.unset.ts +0 -54
  167. package/src/operations/behavior.operation.child.set.ts +0 -107
  168. package/src/operations/behavior.operation.child.unset.ts +0 -116
  169. package/src/operations/behavior.operation.decorator.add.ts +0 -131
  170. package/src/operations/behavior.operation.delete.ts +0 -294
  171. package/src/operations/behavior.operation.insert.block.ts +0 -495
  172. package/src/operations/behavior.operation.insert.child.ts +0 -129
  173. package/src/operations/behavior.operation.insert.text.ts +0 -8
  174. package/src/operations/behavior.operation.move.backward.ts +0 -12
  175. package/src/operations/behavior.operation.move.block.ts +0 -44
  176. package/src/operations/behavior.operation.move.forward.ts +0 -11
  177. package/src/operations/behavior.operation.select.ts +0 -27
  178. package/src/operations/behavior.operations.ts +0 -221
  179. package/src/plugins/_exports/index.ts +0 -1
  180. package/src/plugins/index.ts +0 -3
  181. package/src/plugins/plugin.behavior.tsx +0 -24
  182. package/src/plugins/plugin.editor-ref.tsx +0 -17
  183. package/src/plugins/plugin.event-listener.tsx +0 -68
  184. package/src/plugins/plugin.internal.auto-close-brackets.test.tsx +0 -71
  185. package/src/plugins/plugin.internal.auto-close-brackets.ts +0 -62
  186. package/src/plugins/plugin.internal.change-ref.tsx +0 -19
  187. package/src/plugins/plugin.internal.portable-text-editor-ref.tsx +0 -16
  188. package/src/plugins/plugin.internal.slate-editor-ref.tsx +0 -15
  189. package/src/priority/priority.core.ts +0 -3
  190. package/src/priority/priority.sort.test.ts +0 -319
  191. package/src/priority/priority.sort.ts +0 -123
  192. package/src/priority/priority.types.ts +0 -24
  193. package/src/selectors/_exports/index.ts +0 -1
  194. package/src/selectors/drag-selection.test.ts +0 -578
  195. package/src/selectors/drag-selection.ts +0 -118
  196. package/src/selectors/index.ts +0 -54
  197. package/src/selectors/selector.get-active-annotation-marks.ts +0 -12
  198. package/src/selectors/selector.get-active-annotations.ts +0 -36
  199. package/src/selectors/selector.get-active-decorators.ts +0 -29
  200. package/src/selectors/selector.get-active-list-item.ts +0 -38
  201. package/src/selectors/selector.get-active-style.ts +0 -38
  202. package/src/selectors/selector.get-anchor-block.ts +0 -22
  203. package/src/selectors/selector.get-anchor-child.ts +0 -36
  204. package/src/selectors/selector.get-anchor-span.ts +0 -17
  205. package/src/selectors/selector.get-anchor-text-block.ts +0 -18
  206. package/src/selectors/selector.get-block-offsets.ts +0 -34
  207. package/src/selectors/selector.get-caret-word-selection.test.ts +0 -284
  208. package/src/selectors/selector.get-caret-word-selection.ts +0 -134
  209. package/src/selectors/selector.get-first-block.ts +0 -14
  210. package/src/selectors/selector.get-focus-block-object.ts +0 -18
  211. package/src/selectors/selector.get-focus-block.ts +0 -23
  212. package/src/selectors/selector.get-focus-child.ts +0 -36
  213. package/src/selectors/selector.get-focus-inline-object.ts +0 -17
  214. package/src/selectors/selector.get-focus-list-block.ts +0 -18
  215. package/src/selectors/selector.get-focus-span.ts +0 -18
  216. package/src/selectors/selector.get-focus-text-block.ts +0 -18
  217. package/src/selectors/selector.get-last-block.ts +0 -16
  218. package/src/selectors/selector.get-mark-state.test.ts +0 -325
  219. package/src/selectors/selector.get-mark-state.ts +0 -263
  220. package/src/selectors/selector.get-next-block.ts +0 -29
  221. package/src/selectors/selector.get-next-inline-object.ts +0 -53
  222. package/src/selectors/selector.get-next-inline-objects.ts +0 -50
  223. package/src/selectors/selector.get-next-span.ts +0 -56
  224. package/src/selectors/selector.get-previous-block.ts +0 -29
  225. package/src/selectors/selector.get-previous-inline-object.ts +0 -50
  226. package/src/selectors/selector.get-previous-inline-objects.ts +0 -47
  227. package/src/selectors/selector.get-previous-span.ts +0 -53
  228. package/src/selectors/selector.get-selected-blocks.ts +0 -61
  229. package/src/selectors/selector.get-selected-spans.test.ts +0 -347
  230. package/src/selectors/selector.get-selected-spans.ts +0 -155
  231. package/src/selectors/selector.get-selected-text-blocks.ts +0 -73
  232. package/src/selectors/selector.get-selected-value.test.ts +0 -834
  233. package/src/selectors/selector.get-selected-value.ts +0 -66
  234. package/src/selectors/selector.get-selection-end-block.ts +0 -33
  235. package/src/selectors/selector.get-selection-end-child.ts +0 -33
  236. package/src/selectors/selector.get-selection-end-point.ts +0 -17
  237. package/src/selectors/selector.get-selection-start-block.ts +0 -33
  238. package/src/selectors/selector.get-selection-start-child.ts +0 -33
  239. package/src/selectors/selector.get-selection-start-point.ts +0 -17
  240. package/src/selectors/selector.get-selection-text.test.ts +0 -421
  241. package/src/selectors/selector.get-selection-text.ts +0 -27
  242. package/src/selectors/selector.get-selection.ts +0 -9
  243. package/src/selectors/selector.get-text-after.ts +0 -46
  244. package/src/selectors/selector.get-text-before.ts +0 -46
  245. package/src/selectors/selector.get-value.ts +0 -11
  246. package/src/selectors/selector.is-active-annotation.test.ts +0 -320
  247. package/src/selectors/selector.is-active-annotation.ts +0 -52
  248. package/src/selectors/selector.is-active-decorator.test.ts +0 -136
  249. package/src/selectors/selector.is-active-decorator.ts +0 -24
  250. package/src/selectors/selector.is-active-list-item.ts +0 -13
  251. package/src/selectors/selector.is-active-style.ts +0 -13
  252. package/src/selectors/selector.is-at-the-end-of-block.ts +0 -30
  253. package/src/selectors/selector.is-at-the-start-of-block.ts +0 -30
  254. package/src/selectors/selector.is-overlapping-selection.test.ts +0 -304
  255. package/src/selectors/selector.is-overlapping-selection.ts +0 -181
  256. package/src/selectors/selector.is-point-after-selection.ts +0 -97
  257. package/src/selectors/selector.is-point-before-selection.ts +0 -97
  258. package/src/selectors/selector.is-selecting-entire-blocks.ts +0 -43
  259. package/src/selectors/selector.is-selection-collapsed.ts +0 -17
  260. package/src/selectors/selector.is-selection-expanded.test.ts +0 -63
  261. package/src/selectors/selector.is-selection-expanded.ts +0 -9
  262. package/src/test/_exports/index.ts +0 -1
  263. package/src/test/gherkin-parameter-types.ts +0 -112
  264. package/src/test/index.ts +0 -1
  265. package/src/test/vitest/_exports/index.ts +0 -1
  266. package/src/test/vitest/index.ts +0 -3
  267. package/src/test/vitest/step-context.ts +0 -13
  268. package/src/test/vitest/step-definitions.tsx +0 -960
  269. package/src/test/vitest/test-editor.tsx +0 -198
  270. package/src/type-utils.ts +0 -29
  271. package/src/types/block-offset.ts +0 -9
  272. package/src/types/block-with-optional-key.ts +0 -25
  273. package/src/types/editor.ts +0 -509
  274. package/src/types/options.ts +0 -13
  275. package/src/types/paths.ts +0 -35
  276. package/src/types/slate-editor.ts +0 -50
  277. package/src/types/slate.ts +0 -27
  278. package/src/utils/_exports/index.ts +0 -1
  279. package/src/utils/asserters.ts +0 -9
  280. package/src/utils/index.ts +0 -24
  281. package/src/utils/key-generator.ts +0 -33
  282. package/src/utils/parse-blocks.test.ts +0 -836
  283. package/src/utils/parse-blocks.ts +0 -504
  284. package/src/utils/util.at-the-beginning-of-block.ts +0 -32
  285. package/src/utils/util.block-offset-to-block-selection-point.ts +0 -28
  286. package/src/utils/util.block-offset-to-selection-point.ts +0 -33
  287. package/src/utils/util.block-offset.test.ts +0 -375
  288. package/src/utils/util.block-offset.ts +0 -136
  289. package/src/utils/util.block-offsets-to-selection.ts +0 -38
  290. package/src/utils/util.child-selection-point-to-block-offset.ts +0 -51
  291. package/src/utils/util.get-block-end-point.ts +0 -35
  292. package/src/utils/util.get-block-start-point.ts +0 -31
  293. package/src/utils/util.get-selection-end-point.ts +0 -20
  294. package/src/utils/util.get-selection-start-point.ts +0 -20
  295. package/src/utils/util.get-text-block-text.ts +0 -8
  296. package/src/utils/util.is-empty-text-block.ts +0 -21
  297. package/src/utils/util.is-equal-selection-points.ts +0 -13
  298. package/src/utils/util.is-equal-selections.ts +0 -20
  299. package/src/utils/util.is-keyed-segment.ts +0 -8
  300. package/src/utils/util.is-selection-collapsed.ts +0 -16
  301. package/src/utils/util.is-selection-expanded.ts +0 -13
  302. package/src/utils/util.merge-text-blocks.ts +0 -40
  303. package/src/utils/util.reverse-selection.ts +0 -26
  304. package/src/utils/util.selection-point-to-block-offset.ts +0 -30
  305. package/src/utils/util.selection-point.ts +0 -22
  306. package/src/utils/util.slice-blocks.ts +0 -221
  307. package/src/utils/util.slice-text-block.test.ts +0 -190
  308. package/src/utils/util.slice-text-block.ts +0 -89
  309. package/src/utils/util.split-text-block.ts +0 -54
@@ -1,323 +0,0 @@
1
- import {
2
- compileSchemaDefinitionToPortableTextMemberSchemaTypes,
3
- createPortableTextMemberSchemaTypes,
4
- portableTextMemberSchemaTypesToSchema,
5
- } from '@portabletext/sanity-bridge'
6
- import {compileSchema} from '@portabletext/schema'
7
- import {createActor} from 'xstate'
8
- import {createCoreConverters} from '../converters/converters.core'
9
- import type {Editor, EditorConfig} from '../editor'
10
- import {debugWithName} from '../internal-utils/debug'
11
- import {compileType} from '../internal-utils/schema'
12
- import {corePriority} from '../priority/priority.core'
13
- import {createEditorPriority} from '../priority/priority.types'
14
- import type {EditableAPI} from '../types/editor'
15
- import type {PortableTextSlateEditor} from '../types/slate-editor'
16
- import {defaultKeyGenerator} from '../utils/key-generator'
17
- import {createSlateEditor, type SlateEditor} from './create-slate-editor'
18
- import {createEditorDom} from './editor-dom'
19
- import type {EditorActor} from './editor-machine'
20
- import {editorMachine, rerouteExternalBehaviorEvent} from './editor-machine'
21
- import {getEditorSnapshot} from './editor-selector'
22
- import {mutationMachine, type MutationActor} from './mutation-machine'
23
- import {createEditableAPI} from './plugins/createWithEditableAPI'
24
- import {relayMachine, type RelayActor} from './relay-machine'
25
- import {syncMachine, type SyncActor} from './sync-machine'
26
-
27
- const debug = debugWithName('setup')
28
-
29
- export type InternalEditor = Editor & {
30
- _internal: {
31
- editable: EditableAPI
32
- editorActor: EditorActor
33
- slateEditor: SlateEditor
34
- }
35
- }
36
-
37
- export function createInternalEditor(config: EditorConfig): {
38
- actors: {
39
- editorActor: EditorActor
40
- mutationActor: MutationActor
41
- relayActor: RelayActor
42
- syncActor: SyncActor
43
- }
44
- editor: InternalEditor
45
- subscriptions: Array<() => () => void>
46
- } {
47
- debug('Creating new Editor instance')
48
-
49
- const subscriptions: Array<() => () => void> = []
50
- const editorActor = createActor(editorMachine, {
51
- input: editorConfigToMachineInput(config),
52
- })
53
- const relayActor = createActor(relayMachine)
54
- const slateEditor = createSlateEditor({
55
- editorActor,
56
- relayActor,
57
- subscriptions,
58
- })
59
- const editable = createEditableAPI(slateEditor.instance, editorActor)
60
- const {mutationActor, syncActor} = createActors({
61
- editorActor,
62
- relayActor,
63
- slateEditor: slateEditor.instance,
64
- subscriptions,
65
- })
66
-
67
- const editor = {
68
- dom: createEditorDom(
69
- (event) => editorActor.send(event),
70
- slateEditor.instance,
71
- ),
72
- getSnapshot: () =>
73
- getEditorSnapshot({
74
- editorActorSnapshot: editorActor.getSnapshot(),
75
- slateEditorInstance: slateEditor.instance,
76
- }),
77
- registerBehavior: (behaviorConfig) => {
78
- const priority = createEditorPriority({
79
- name: 'custom',
80
- reference: {
81
- priority: corePriority,
82
- importance: 'higher',
83
- },
84
- })
85
- const behaviorConfigWithPriority = {
86
- ...behaviorConfig,
87
- priority,
88
- }
89
-
90
- editorActor.send({
91
- type: 'add behavior',
92
- behaviorConfig: behaviorConfigWithPriority,
93
- })
94
-
95
- return () => {
96
- editorActor.send({
97
- type: 'remove behavior',
98
- behaviorConfig: behaviorConfigWithPriority,
99
- })
100
- }
101
- },
102
- send: (event) => {
103
- switch (event.type) {
104
- case 'update value':
105
- syncActor.send(event)
106
- break
107
-
108
- case 'update readOnly':
109
- case 'patches':
110
- editorActor.send(event)
111
- break
112
-
113
- default:
114
- editorActor.send(
115
- rerouteExternalBehaviorEvent({
116
- event,
117
- slateEditor: slateEditor.instance,
118
- }),
119
- )
120
- }
121
- },
122
- on: (event, listener) => {
123
- const subscription = relayActor.on(event, (event) => {
124
- switch (event.type) {
125
- case 'blurred':
126
- case 'done loading':
127
- case 'editable':
128
- case 'focused':
129
- case 'invalid value':
130
- case 'loading':
131
- case 'mutation':
132
- case 'patch':
133
- case 'read only':
134
- case 'ready':
135
- case 'selection':
136
- case 'value changed':
137
- listener(event)
138
- break
139
- }
140
- })
141
-
142
- return subscription
143
- },
144
- _internal: {
145
- editable,
146
- editorActor,
147
- slateEditor,
148
- },
149
- } satisfies InternalEditor
150
-
151
- return {
152
- actors: {
153
- editorActor,
154
- mutationActor,
155
- relayActor,
156
- syncActor,
157
- },
158
- editor,
159
- subscriptions,
160
- }
161
- }
162
-
163
- function editorConfigToMachineInput(config: EditorConfig) {
164
- const {legacySchema, schema} = compileSchemasFromEditorConfig(config)
165
-
166
- return {
167
- converters: createCoreConverters(legacySchema),
168
- getLegacySchema: () => legacySchema,
169
- keyGenerator: config.keyGenerator ?? defaultKeyGenerator,
170
- readOnly: config.readOnly,
171
- schema,
172
- initialValue: config.initialValue,
173
- } as const
174
- }
175
-
176
- function compileSchemasFromEditorConfig(config: EditorConfig) {
177
- const legacySchema = config.schemaDefinition
178
- ? compileSchemaDefinitionToPortableTextMemberSchemaTypes(
179
- config.schemaDefinition,
180
- )
181
- : createPortableTextMemberSchemaTypes(
182
- config.schema.hasOwnProperty('jsonType')
183
- ? config.schema
184
- : compileType(config.schema),
185
- )
186
- const schema = config.schemaDefinition
187
- ? compileSchema(config.schemaDefinition)
188
- : portableTextMemberSchemaTypesToSchema(legacySchema)
189
-
190
- return {
191
- legacySchema,
192
- schema,
193
- }
194
- }
195
-
196
- function createActors(config: {
197
- editorActor: EditorActor
198
- relayActor: RelayActor
199
- slateEditor: PortableTextSlateEditor
200
- subscriptions: Array<() => () => void>
201
- }): {
202
- mutationActor: MutationActor
203
- syncActor: SyncActor
204
- } {
205
- debug('Creating new Actors')
206
-
207
- const mutationActor = createActor(mutationMachine, {
208
- input: {
209
- readOnly: config.editorActor
210
- .getSnapshot()
211
- .matches({'edit mode': 'read only'}),
212
- schema: config.editorActor.getSnapshot().context.schema,
213
- slateEditor: config.slateEditor,
214
- },
215
- })
216
-
217
- const syncActor = createActor(syncMachine, {
218
- input: {
219
- initialValue: config.editorActor.getSnapshot().context.initialValue,
220
- keyGenerator: config.editorActor.getSnapshot().context.keyGenerator,
221
- readOnly: config.editorActor
222
- .getSnapshot()
223
- .matches({'edit mode': 'read only'}),
224
- schema: config.editorActor.getSnapshot().context.schema,
225
- slateEditor: config.slateEditor,
226
- },
227
- })
228
-
229
- config.subscriptions.push(() => {
230
- const subscription = mutationActor.on('*', (event) => {
231
- if (event.type === 'has pending mutations') {
232
- syncActor.send({type: 'has pending mutations'})
233
- }
234
- if (event.type === 'mutation') {
235
- syncActor.send({type: 'mutation'})
236
- config.editorActor.send({
237
- type: 'mutation',
238
- patches: event.patches,
239
- value: event.snapshot,
240
- })
241
- }
242
- if (event.type === 'patch') {
243
- config.relayActor.send(event)
244
- }
245
- })
246
-
247
- return () => {
248
- // Flushing pending patches and mutations before unmounting
249
- mutationActor.send({type: 'emit changes'})
250
-
251
- subscription.unsubscribe()
252
- }
253
- })
254
-
255
- config.subscriptions.push(() => {
256
- const subscription = syncActor.on('*', (event) => {
257
- switch (event.type) {
258
- case 'invalid value':
259
- config.relayActor.send(event)
260
- break
261
- case 'value changed':
262
- config.relayActor.send(event)
263
- break
264
- case 'patch':
265
- config.editorActor.send({
266
- ...event,
267
- type: 'internal.patch',
268
- value: config.slateEditor.value,
269
- })
270
- break
271
-
272
- default:
273
- config.editorActor.send(event)
274
- }
275
- })
276
-
277
- return () => {
278
- subscription.unsubscribe()
279
- }
280
- })
281
-
282
- config.subscriptions.push(() => {
283
- const subscription = config.editorActor.subscribe((snapshot) => {
284
- if (snapshot.matches({'edit mode': 'read only'})) {
285
- mutationActor.send({type: 'update readOnly', readOnly: true})
286
- syncActor.send({type: 'update readOnly', readOnly: true})
287
- } else {
288
- mutationActor.send({type: 'update readOnly', readOnly: false})
289
- syncActor.send({type: 'update readOnly', readOnly: false})
290
- }
291
- })
292
-
293
- return () => {
294
- subscription.unsubscribe()
295
- }
296
- })
297
-
298
- config.subscriptions.push(() => {
299
- const subscription = config.editorActor.on('*', (event) => {
300
- switch (event.type) {
301
- case 'editable':
302
- case 'mutation':
303
- case 'ready':
304
- case 'read only':
305
- case 'selection':
306
- config.relayActor.send(event)
307
- break
308
- case 'internal.patch':
309
- mutationActor.send({...event, type: 'patch'})
310
- break
311
- }
312
- })
313
-
314
- return () => {
315
- subscription.unsubscribe()
316
- }
317
- })
318
-
319
- return {
320
- mutationActor,
321
- syncActor,
322
- }
323
- }
@@ -1,64 +0,0 @@
1
- import {createEditor, type Descendant} from 'slate'
2
- import {withReact} from 'slate-react'
3
- import {buildIndexMaps} from '../internal-utils/build-index-maps'
4
- import {createPlaceholderBlock} from '../internal-utils/create-placeholder-block'
5
- import {debugWithName} from '../internal-utils/debug'
6
- import type {PortableTextSlateEditor} from '../types/slate-editor'
7
- import type {EditorActor} from './editor-machine'
8
- import {withPlugins} from './plugins/with-plugins'
9
- import type {RelayActor} from './relay-machine'
10
- import {KEY_TO_SLATE_ELEMENT} from './weakMaps'
11
-
12
- const debug = debugWithName('setup')
13
-
14
- type SlateEditorConfig = {
15
- editorActor: EditorActor
16
- relayActor: RelayActor
17
- subscriptions: Array<() => () => void>
18
- }
19
-
20
- export type SlateEditor = {
21
- instance: PortableTextSlateEditor
22
- initialValue: Array<Descendant>
23
- }
24
-
25
- export function createSlateEditor(config: SlateEditorConfig): SlateEditor {
26
- debug('Creating new Slate editor instance')
27
-
28
- const placeholderBlock = createPlaceholderBlock(
29
- config.editorActor.getSnapshot().context,
30
- )
31
-
32
- const editor = createEditor()
33
- editor.decoratedRanges = []
34
- editor.decoratorState = {}
35
- editor.value = [placeholderBlock]
36
- editor.blockIndexMap = new Map<string, number>()
37
- editor.listIndexMap = new Map<string, number>()
38
-
39
- const instance = withPlugins(withReact(editor), {
40
- editorActor: config.editorActor,
41
- relayActor: config.relayActor,
42
- subscriptions: config.subscriptions,
43
- })
44
-
45
- KEY_TO_SLATE_ELEMENT.set(instance, {})
46
-
47
- buildIndexMaps(
48
- {
49
- schema: config.editorActor.getSnapshot().context.schema,
50
- value: instance.value,
51
- },
52
- {
53
- blockIndexMap: instance.blockIndexMap,
54
- listIndexMap: instance.listIndexMap,
55
- },
56
- )
57
-
58
- const slateEditor: SlateEditor = {
59
- instance,
60
- initialValue: [placeholderBlock],
61
- }
62
-
63
- return slateEditor
64
- }
@@ -1,4 +0,0 @@
1
- import {createContext} from 'react'
2
- import type {EditorActor} from './editor-machine'
3
-
4
- export const EditorActorContext = createContext<EditorActor>({} as EditorActor)
@@ -1,7 +0,0 @@
1
- import type {Editor} from '../editor'
2
- import {createGloballyScopedContext} from '../internal-utils/globally-scoped-context'
3
-
4
- export const EditorContext = createGloballyScopedContext<Editor | null>(
5
- '@portabletext/editor/context/editor',
6
- null,
7
- )
@@ -1,220 +0,0 @@
1
- import {Editor} from 'slate'
2
- import {DOMEditor} from 'slate-dom'
3
- import type {BehaviorEvent} from '../behaviors/behavior.types.event'
4
- import {toSlateRange} from '../internal-utils/to-slate-range'
5
- import {getSelectionEndBlock, getSelectionStartBlock} from '../selectors'
6
- import type {PickFromUnion} from '../type-utils'
7
- import type {PortableTextSlateEditor} from '../types/slate-editor'
8
- import type {EditorSnapshot} from './editor-snapshot'
9
-
10
- export type EditorDom = {
11
- getBlockNodes: (snapshot: EditorSnapshot) => Array<Node>
12
- getChildNodes: (snapshot: EditorSnapshot) => Array<Node>
13
- getEditorElement: () => Element | undefined
14
- getSelectionRect: (snapshot: EditorSnapshot) => DOMRect | null
15
- getStartBlockElement: (snapshot: EditorSnapshot) => Element | null
16
- getEndBlockElement: (snapshot: EditorSnapshot) => Element | null
17
- /**
18
- * Let the Editor set the drag ghost. This is to be sure that it will get
19
- * properly removed again when the drag ends.
20
- */
21
- setDragGhost: ({
22
- event,
23
- ghost,
24
- }: {
25
- event: PickFromUnion<BehaviorEvent, 'type', 'drag.dragstart'>
26
- ghost: {
27
- element: HTMLElement
28
- x: number
29
- y: number
30
- }
31
- }) => void
32
- }
33
-
34
- export function createEditorDom(
35
- sendBack: (event: {type: 'set drag ghost'; ghost: HTMLElement}) => void,
36
- slateEditor: PortableTextSlateEditor,
37
- ): EditorDom {
38
- return {
39
- getBlockNodes: (snapshot) => getBlockNodes(slateEditor, snapshot),
40
- getChildNodes: (snapshot) => getChildNodes(slateEditor, snapshot),
41
- getEditorElement: () => getEditorElement(slateEditor),
42
- getSelectionRect: (snapshot) => getSelectionRect(snapshot),
43
- getStartBlockElement: (snapshot) =>
44
- getStartBlockElement(slateEditor, snapshot),
45
- getEndBlockElement: (snapshot) => getEndBlockElement(slateEditor, snapshot),
46
- setDragGhost: ({event, ghost}) => setDragGhost({sendBack, event, ghost}),
47
- }
48
- }
49
-
50
- function getBlockNodes(
51
- slateEditor: PortableTextSlateEditor,
52
- snapshot: EditorSnapshot,
53
- ) {
54
- if (!snapshot.context.selection) {
55
- return []
56
- }
57
-
58
- const range = toSlateRange(snapshot)
59
-
60
- if (!range) {
61
- return []
62
- }
63
-
64
- try {
65
- const blockEntries = Array.from(
66
- Editor.nodes(slateEditor, {
67
- at: range,
68
- mode: 'highest',
69
- match: (n) => !Editor.isEditor(n),
70
- }),
71
- )
72
-
73
- return blockEntries.map(([blockNode]) =>
74
- DOMEditor.toDOMNode(slateEditor, blockNode),
75
- )
76
- } catch {
77
- return []
78
- }
79
- }
80
-
81
- function getChildNodes(
82
- slateEditor: PortableTextSlateEditor,
83
- snapshot: EditorSnapshot,
84
- ) {
85
- if (!snapshot.context.selection) {
86
- return []
87
- }
88
-
89
- const range = toSlateRange(snapshot)
90
-
91
- if (!range) {
92
- return []
93
- }
94
-
95
- try {
96
- const childEntries = Array.from(
97
- Editor.nodes(slateEditor, {
98
- at: range,
99
- mode: 'lowest',
100
- match: (n) => !Editor.isEditor(n),
101
- }),
102
- )
103
-
104
- return childEntries.map(([childNode]) =>
105
- DOMEditor.toDOMNode(slateEditor, childNode),
106
- )
107
- } catch {
108
- return []
109
- }
110
- }
111
-
112
- function getEditorElement(slateEditor: PortableTextSlateEditor) {
113
- try {
114
- return DOMEditor.toDOMNode(slateEditor, slateEditor)
115
- } catch {
116
- return undefined
117
- }
118
- }
119
-
120
- function getSelectionRect(snapshot: EditorSnapshot) {
121
- if (!snapshot.context.selection) {
122
- return null
123
- }
124
-
125
- try {
126
- const selection = window.getSelection()
127
-
128
- if (!selection) {
129
- return null
130
- }
131
-
132
- const range = selection.getRangeAt(0)
133
- return range.getBoundingClientRect()
134
- } catch {
135
- return null
136
- }
137
- }
138
-
139
- function getStartBlockElement(
140
- slateEditor: PortableTextSlateEditor,
141
- snapshot: EditorSnapshot,
142
- ) {
143
- const startBlock = getSelectionStartBlock(snapshot)
144
-
145
- if (!startBlock) {
146
- return null
147
- }
148
-
149
- const startBlockNode = getBlockNodes(slateEditor, {
150
- ...snapshot,
151
- context: {
152
- ...snapshot.context,
153
- selection: {
154
- anchor: {
155
- path: startBlock.path,
156
- offset: 0,
157
- },
158
- focus: {
159
- path: startBlock.path,
160
- offset: 0,
161
- },
162
- },
163
- },
164
- })?.at(0)
165
-
166
- return startBlockNode && startBlockNode instanceof Element
167
- ? startBlockNode
168
- : null
169
- }
170
-
171
- function getEndBlockElement(
172
- slateEditor: PortableTextSlateEditor,
173
- snapshot: EditorSnapshot,
174
- ) {
175
- const endBlock = getSelectionEndBlock(snapshot)
176
-
177
- if (!endBlock) {
178
- return null
179
- }
180
-
181
- const endBlockNode = getBlockNodes(slateEditor, {
182
- ...snapshot,
183
- context: {
184
- ...snapshot.context,
185
- selection: {
186
- anchor: {
187
- path: endBlock.path,
188
- offset: 0,
189
- },
190
- focus: {
191
- path: endBlock.path,
192
- offset: 0,
193
- },
194
- },
195
- },
196
- })?.at(0)
197
-
198
- return endBlockNode && endBlockNode instanceof Element ? endBlockNode : null
199
- }
200
-
201
- function setDragGhost({
202
- sendBack,
203
- event,
204
- ghost,
205
- }: {
206
- sendBack: (event: {type: 'set drag ghost'; ghost: HTMLElement}) => void
207
- event: PickFromUnion<BehaviorEvent, 'type', 'drag.dragstart'>
208
- ghost: {
209
- element: HTMLElement
210
- x: number
211
- y: number
212
- }
213
- }) {
214
- event.originEvent.dataTransfer.setDragImage(ghost.element, ghost.x, ghost.y)
215
-
216
- sendBack({
217
- type: 'set drag ghost',
218
- ghost: ghost.element,
219
- })
220
- }