@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,356 +0,0 @@
1
- import {getCompoundClientRect} from '../internal-utils/compound-client-rect'
2
- import {getDragSelection} from '../selectors/drag-selection'
3
- import {getSelectedBlocks} from '../selectors/selector.get-selected-blocks'
4
- import {isOverlappingSelection} from '../selectors/selector.is-overlapping-selection'
5
- import {isSelectingEntireBlocks} from '../selectors/selector.is-selecting-entire-blocks'
6
- import {effect, forward, raise} from './behavior.types.action'
7
- import {defineBehavior} from './behavior.types.behavior'
8
-
9
- export const coreDndBehaviors = [
10
- /**
11
- * Core Behavior that:
12
- * 1. Calculates and selects a "drag selection"
13
- * 2. Constructs and sets a drag ghost element
14
- * 3. Forwards the dragstart event
15
- */
16
- defineBehavior({
17
- on: 'drag.dragstart',
18
- guard: ({snapshot, dom, event}) => {
19
- const dragSelection = getDragSelection({
20
- snapshot,
21
- eventSelection: event.position.selection,
22
- })
23
- const selectingEntireBlocks = isSelectingEntireBlocks({
24
- ...snapshot,
25
- context: {
26
- ...snapshot.context,
27
- selection: dragSelection,
28
- },
29
- })
30
- const draggedDomNodes = {
31
- blockNodes: dom.getBlockNodes({
32
- ...snapshot,
33
- context: {
34
- ...snapshot.context,
35
- selection: dragSelection,
36
- },
37
- }),
38
- childNodes: dom.getChildNodes({
39
- ...snapshot,
40
- context: {
41
- ...snapshot.context,
42
- selection: dragSelection,
43
- },
44
- }),
45
- }
46
-
47
- return {
48
- dragSelection,
49
- draggedDomNodes,
50
- selectingEntireBlocks,
51
- }
52
- },
53
- actions: [
54
- (
55
- {dom, event},
56
- {dragSelection, draggedDomNodes, selectingEntireBlocks},
57
- ) => {
58
- const dragGhost = document.createElement('div')
59
-
60
- if (selectingEntireBlocks) {
61
- // Clone the DOM Nodes so they won't be visually clipped by scroll-containers etc.
62
- const clonedBlockNodes = draggedDomNodes.blockNodes.map((node) =>
63
- node.cloneNode(true),
64
- )
65
-
66
- for (const block of clonedBlockNodes) {
67
- if (block instanceof HTMLElement) {
68
- block.style.position = 'relative'
69
- }
70
- dragGhost.appendChild(block)
71
- }
72
-
73
- // A custom drag ghost element can be configured using this data attribute
74
- const customGhost = dragGhost.querySelector(
75
- '[data-pt-drag-ghost-element]',
76
- )
77
- if (customGhost) {
78
- dragGhost.replaceChildren(customGhost)
79
- }
80
-
81
- // Setting the `data-dragged` attribute so the consumer can style the element while it’s dragged
82
- dragGhost.setAttribute('data-dragged', '')
83
-
84
- dragGhost.style.position = 'absolute'
85
- dragGhost.style.left = '-99999px'
86
- dragGhost.style.boxSizing = 'border-box'
87
- document.body.appendChild(dragGhost)
88
-
89
- if (customGhost) {
90
- const customGhostRect = customGhost.getBoundingClientRect()
91
- const x = event.originEvent.clientX - customGhostRect.left
92
- const y = event.originEvent.clientY - customGhostRect.top
93
- dragGhost.style.width = `${customGhostRect.width}px`
94
- dragGhost.style.height = `${customGhostRect.height}px`
95
-
96
- return [
97
- raise({
98
- type: 'select',
99
- at: dragSelection,
100
- }),
101
- effect(() => {
102
- dom.setDragGhost({
103
- event,
104
- ghost: {
105
- element: dragGhost,
106
- x,
107
- y,
108
- },
109
- })
110
- }),
111
- forward(event),
112
- ]
113
- } else {
114
- const blocksDomRect = getCompoundClientRect(
115
- draggedDomNodes.blockNodes,
116
- )
117
- const x = event.originEvent.clientX - blocksDomRect.left
118
- const y = event.originEvent.clientY - blocksDomRect.top
119
- dragGhost.style.width = `${blocksDomRect.width}px`
120
- dragGhost.style.height = `${blocksDomRect.height}px`
121
-
122
- return [
123
- raise({
124
- type: 'select',
125
- at: dragSelection,
126
- }),
127
- effect(() => {
128
- dom.setDragGhost({
129
- event,
130
- ghost: {element: dragGhost, x, y},
131
- })
132
- }),
133
- forward(event),
134
- ]
135
- }
136
- } else {
137
- const clonedChildNodes = draggedDomNodes.childNodes.map((node) =>
138
- node.cloneNode(true),
139
- )
140
-
141
- for (const child of clonedChildNodes) {
142
- dragGhost.appendChild(child)
143
- }
144
-
145
- dragGhost.style.position = 'absolute'
146
- dragGhost.style.left = '-99999px'
147
- dragGhost.style.boxSizing = 'border-box'
148
- document.body.appendChild(dragGhost)
149
-
150
- const childrenDomRect = getCompoundClientRect(
151
- draggedDomNodes.childNodes,
152
- )
153
- const x = event.originEvent.clientX - childrenDomRect.left
154
- const y = event.originEvent.clientY - childrenDomRect.top
155
- dragGhost.style.width = `${childrenDomRect.width}px`
156
- dragGhost.style.height = `${childrenDomRect.height}px`
157
-
158
- return [
159
- raise({
160
- type: 'select',
161
- at: dragSelection,
162
- }),
163
- effect(() => {
164
- dom.setDragGhost({
165
- event,
166
- ghost: {element: dragGhost, x, y},
167
- })
168
- }),
169
- forward(event),
170
- ]
171
- }
172
- },
173
- ],
174
- }),
175
-
176
- /**
177
- * When dragging over the drag origin, we don't want to show the caret in the
178
- * text.
179
- */
180
- defineBehavior({
181
- on: 'drag.dragover',
182
- guard: ({snapshot, event}) => {
183
- const dragOrigin = event.dragOrigin
184
- const draggingOverDragOrigin = dragOrigin
185
- ? isOverlappingSelection(event.position.selection)({
186
- ...snapshot,
187
- context: {
188
- ...snapshot.context,
189
- selection: dragOrigin.selection,
190
- },
191
- })
192
- : false
193
-
194
- return draggingOverDragOrigin
195
- },
196
- actions: [],
197
- }),
198
-
199
- /**
200
- * If the drop position overlaps the drag origin, then the event should be
201
- * cancelled.
202
- */
203
- defineBehavior({
204
- on: 'drag.drop',
205
- guard: ({snapshot, event}) => {
206
- const dragOrigin = event.dragOrigin
207
- const dropPosition = event.position.selection
208
- const droppingOnDragOrigin = dragOrigin
209
- ? isOverlappingSelection(dropPosition)({
210
- ...snapshot,
211
- context: {
212
- ...snapshot.context,
213
- selection: dragOrigin.selection,
214
- },
215
- })
216
- : false
217
- return droppingOnDragOrigin
218
- },
219
- actions: [],
220
- }),
221
- /**
222
- * If we drop and have access to a drag origin, then we can deserialize
223
- * without creating a new selection.
224
- */
225
- defineBehavior({
226
- on: 'drag.drop',
227
- guard: ({event}) => event.dragOrigin !== undefined,
228
- actions: [
229
- ({event}) => [
230
- raise({
231
- type: 'deserialize',
232
- originEvent: event,
233
- }),
234
- ],
235
- ],
236
- }),
237
- /**
238
- * Otherwise, we should to create a new selection.
239
- */
240
- defineBehavior({
241
- on: 'drag.drop',
242
- actions: [
243
- ({event}) => [
244
- raise({
245
- type: 'select',
246
- at: event.position.selection,
247
- }),
248
- raise({
249
- type: 'deserialize',
250
- originEvent: event,
251
- }),
252
- ],
253
- ],
254
- }),
255
-
256
- /**
257
- * Core Behavior that uses the drag origin to mimic a move operation during
258
- * internal dragging.
259
- */
260
- defineBehavior({
261
- on: 'deserialization.success',
262
- guard: ({snapshot, event}) => {
263
- if (
264
- event.originEvent.type !== 'drag.drop' ||
265
- event.originEvent.dragOrigin === undefined
266
- ) {
267
- return false
268
- }
269
-
270
- const dragOrigin = event.originEvent.dragOrigin
271
- const dragSelection = getDragSelection({
272
- eventSelection: dragOrigin.selection,
273
- snapshot,
274
- })
275
- const dropPosition = event.originEvent.position.selection
276
- const droppingOnDragOrigin = dragOrigin
277
- ? isOverlappingSelection(dropPosition)({
278
- ...snapshot,
279
- context: {
280
- ...snapshot.context,
281
- selection: dragSelection,
282
- },
283
- })
284
- : false
285
-
286
- const draggingEntireBlocks = isSelectingEntireBlocks({
287
- ...snapshot,
288
- context: {
289
- ...snapshot.context,
290
- selection: dragSelection,
291
- },
292
- })
293
-
294
- const draggedBlocks = getSelectedBlocks({
295
- ...snapshot,
296
- context: {
297
- ...snapshot.context,
298
- selection: dragSelection,
299
- },
300
- })
301
-
302
- if (!droppingOnDragOrigin) {
303
- return {
304
- dropPosition,
305
- draggingEntireBlocks,
306
- draggedBlocks,
307
- dragOrigin,
308
- originEvent: event.originEvent,
309
- }
310
- }
311
-
312
- return false
313
- },
314
- actions: [
315
- (
316
- {event},
317
- {
318
- draggingEntireBlocks,
319
- draggedBlocks,
320
- dragOrigin,
321
- dropPosition,
322
- originEvent,
323
- },
324
- ) => [
325
- raise({
326
- type: 'select',
327
- at: dropPosition,
328
- }),
329
- ...(draggingEntireBlocks
330
- ? draggedBlocks.map((block) =>
331
- raise({
332
- type: 'delete.block',
333
- at: block.path,
334
- }),
335
- )
336
- : [
337
- raise({
338
- type: 'delete',
339
- at: dragOrigin.selection,
340
- }),
341
- ]),
342
- raise({
343
- type: 'insert.blocks',
344
- blocks: event.data,
345
- placement: draggingEntireBlocks
346
- ? originEvent.position.block === 'start'
347
- ? 'before'
348
- : originEvent.position.block === 'end'
349
- ? 'after'
350
- : 'auto'
351
- : 'auto',
352
- }),
353
- ],
354
- ],
355
- }),
356
- ]
@@ -1,266 +0,0 @@
1
- import {getFirstBlock} from '../selectors/selector.get-first-block'
2
- import {getFocusInlineObject} from '../selectors/selector.get-focus-inline-object'
3
- import {getFocusSpan} from '../selectors/selector.get-focus-span'
4
- import {getFocusTextBlock} from '../selectors/selector.get-focus-text-block'
5
- import {getLastBlock} from '../selectors/selector.get-last-block'
6
- import {getSelectedBlocks} from '../selectors/selector.get-selected-blocks'
7
- import {getSelectionEndBlock} from '../selectors/selector.get-selection-end-block'
8
- import {getSelectionStartBlock} from '../selectors/selector.get-selection-start-block'
9
- import {isAtTheEndOfBlock} from '../selectors/selector.is-at-the-end-of-block'
10
- import {isAtTheStartOfBlock} from '../selectors/selector.is-at-the-start-of-block'
11
- import {isSelectionCollapsed} from '../selectors/selector.is-selection-collapsed'
12
- import {isSelectionExpanded} from '../selectors/selector.is-selection-expanded'
13
- import {getBlockEndPoint} from '../utils/util.get-block-end-point'
14
- import {getBlockStartPoint} from '../utils/util.get-block-start-point'
15
- import {getSelectionEndPoint} from '../utils/util.get-selection-end-point'
16
- import {getSelectionStartPoint} from '../utils/util.get-selection-start-point'
17
- import {isEqualSelectionPoints} from '../utils/util.is-equal-selection-points'
18
- import {raise} from './behavior.types.action'
19
- import {defineBehavior} from './behavior.types.behavior'
20
-
21
- const breakingAtTheEndOfTextBlock = defineBehavior({
22
- on: 'insert.break',
23
- guard: ({snapshot}) => {
24
- const focusTextBlock = getFocusTextBlock(snapshot)
25
- const selectionCollapsed = isSelectionCollapsed(snapshot)
26
-
27
- if (!snapshot.context.selection || !focusTextBlock || !selectionCollapsed) {
28
- return false
29
- }
30
-
31
- const atTheEndOfBlock = isAtTheEndOfBlock(focusTextBlock)(snapshot)
32
-
33
- const focusListItem = focusTextBlock.node.listItem
34
- const focusLevel = focusTextBlock.node.level
35
-
36
- if (atTheEndOfBlock) {
37
- return {focusListItem, focusLevel}
38
- }
39
-
40
- return false
41
- },
42
- actions: [
43
- ({snapshot}, {focusListItem, focusLevel}) => [
44
- raise({
45
- type: 'insert.block',
46
- block: {
47
- _type: snapshot.context.schema.block.name,
48
- children: [
49
- {
50
- _type: snapshot.context.schema.span.name,
51
- text: '',
52
- marks: [],
53
- },
54
- ],
55
- markDefs: [],
56
- listItem: focusListItem,
57
- level: focusLevel,
58
- style: snapshot.context.schema.styles[0]?.name,
59
- },
60
- placement: 'after',
61
- }),
62
- ],
63
- ],
64
- })
65
-
66
- const breakingAtTheStartOfTextBlock = defineBehavior({
67
- on: 'insert.break',
68
- guard: ({snapshot}) => {
69
- const focusTextBlock = getFocusTextBlock(snapshot)
70
- const selectionCollapsed = isSelectionCollapsed(snapshot)
71
-
72
- if (!snapshot.context.selection || !focusTextBlock || !selectionCollapsed) {
73
- return false
74
- }
75
-
76
- const focusSpan = getFocusSpan(snapshot)
77
-
78
- const focusDecorators = focusSpan?.node.marks?.filter(
79
- (mark) =>
80
- snapshot.context.schema.decorators.some(
81
- (decorator) => decorator.name === mark,
82
- ) ?? [],
83
- )
84
- const focusAnnotations =
85
- focusSpan?.node.marks?.filter(
86
- (mark) =>
87
- !snapshot.context.schema.decorators.some(
88
- (decorator) => decorator.name === mark,
89
- ),
90
- ) ?? []
91
- const focusListItem = focusTextBlock.node.listItem
92
- const focusLevel = focusTextBlock.node.level
93
-
94
- const atTheStartOfBlock = isAtTheStartOfBlock(focusTextBlock)(snapshot)
95
-
96
- if (atTheStartOfBlock) {
97
- return {focusAnnotations, focusDecorators, focusListItem, focusLevel}
98
- }
99
-
100
- return false
101
- },
102
- actions: [
103
- (
104
- {snapshot},
105
- {focusAnnotations, focusDecorators, focusListItem, focusLevel},
106
- ) => [
107
- raise({
108
- type: 'insert.block',
109
- block: {
110
- _type: snapshot.context.schema.block.name,
111
- children: [
112
- {
113
- _type: snapshot.context.schema.span.name,
114
- marks: focusAnnotations.length === 0 ? focusDecorators : [],
115
- text: '',
116
- },
117
- ],
118
- listItem: focusListItem,
119
- level: focusLevel,
120
- style: snapshot.context.schema.styles[0]?.name,
121
- },
122
- placement: 'before',
123
- select: 'none',
124
- }),
125
- ],
126
- ],
127
- })
128
-
129
- const breakingEntireDocument = defineBehavior({
130
- on: 'insert.break',
131
- guard: ({snapshot}) => {
132
- if (!snapshot.context.selection) {
133
- return false
134
- }
135
-
136
- if (!isSelectionExpanded(snapshot)) {
137
- return false
138
- }
139
-
140
- const firstBlock = getFirstBlock(snapshot)
141
- const lastBlock = getLastBlock(snapshot)
142
-
143
- if (!firstBlock || !lastBlock) {
144
- return false
145
- }
146
-
147
- const firstBlockStartPoint = getBlockStartPoint({
148
- context: snapshot.context,
149
- block: firstBlock,
150
- })
151
- const selectionStartPoint = getSelectionStartPoint(
152
- snapshot.context.selection,
153
- )
154
- const lastBlockEndPoint = getBlockEndPoint({
155
- context: snapshot.context,
156
- block: lastBlock,
157
- })
158
- const selectionEndPoint = getSelectionEndPoint(snapshot.context.selection)
159
-
160
- if (
161
- isEqualSelectionPoints(firstBlockStartPoint, selectionStartPoint) &&
162
- isEqualSelectionPoints(lastBlockEndPoint, selectionEndPoint)
163
- ) {
164
- return {selection: snapshot.context.selection}
165
- }
166
-
167
- return false
168
- },
169
- actions: [
170
- (_, {selection}) => [
171
- raise({
172
- type: 'delete',
173
- at: selection,
174
- }),
175
- ],
176
- ],
177
- })
178
-
179
- const breakingEntireBlocks = defineBehavior({
180
- on: 'insert.break',
181
- guard: ({snapshot}) => {
182
- if (!snapshot.context.selection) {
183
- return false
184
- }
185
-
186
- if (!isSelectionExpanded(snapshot)) {
187
- return false
188
- }
189
-
190
- const selectedBlocks = getSelectedBlocks(snapshot)
191
- const selectionStartBlock = getSelectionStartBlock(snapshot)
192
- const selectionEndBlock = getSelectionEndBlock(snapshot)
193
-
194
- if (!selectionStartBlock || !selectionEndBlock) {
195
- return false
196
- }
197
-
198
- const startBlockStartPoint = getBlockStartPoint({
199
- context: snapshot.context,
200
- block: selectionStartBlock,
201
- })
202
- const selectionStartPoint = getSelectionStartPoint(
203
- snapshot.context.selection,
204
- )
205
- const endBlockEndPoint = getBlockEndPoint({
206
- context: snapshot.context,
207
- block: selectionEndBlock,
208
- })
209
- const selectionEndPoint = getSelectionEndPoint(snapshot.context.selection)
210
-
211
- if (
212
- isEqualSelectionPoints(selectionStartPoint, startBlockStartPoint) &&
213
- isEqualSelectionPoints(selectionEndPoint, endBlockEndPoint)
214
- ) {
215
- return {selectedBlocks}
216
- }
217
-
218
- return false
219
- },
220
- actions: [
221
- ({snapshot}, {selectedBlocks}) => [
222
- raise({
223
- type: 'insert.block',
224
- block: {
225
- _type: snapshot.context.schema.block.name,
226
- children: [
227
- {
228
- _type: snapshot.context.schema.span.name,
229
- text: '',
230
- marks: [],
231
- },
232
- ],
233
- },
234
- placement: 'before',
235
- select: 'start',
236
- }),
237
- ...selectedBlocks.map((block) =>
238
- raise({
239
- type: 'delete.block',
240
- at: block.path,
241
- }),
242
- ),
243
- ],
244
- ],
245
- })
246
-
247
- const breakingInlineObject = defineBehavior({
248
- on: 'insert.break',
249
- guard: ({snapshot}) => {
250
- const selectionCollapsed = isSelectionCollapsed(snapshot)
251
- const focusInlineObject = getFocusInlineObject(snapshot)
252
-
253
- return selectionCollapsed && focusInlineObject
254
- },
255
- actions: [
256
- () => [raise({type: 'move.forward', distance: 1}), raise({type: 'split'})],
257
- ],
258
- })
259
-
260
- export const coreInsertBreakBehaviors = {
261
- breakingAtTheEndOfTextBlock,
262
- breakingAtTheStartOfTextBlock,
263
- breakingEntireDocument,
264
- breakingEntireBlocks,
265
- breakingInlineObject,
266
- }
@@ -1,52 +0,0 @@
1
- import {getActiveAnnotationsMarks} from '../selectors/selector.get-active-annotation-marks'
2
- import {getActiveDecorators} from '../selectors/selector.get-active-decorators'
3
- import {getFocusSpan} from '../selectors/selector.get-focus-span'
4
- import {getMarkState} from '../selectors/selector.get-mark-state'
5
- import {raise} from './behavior.types.action'
6
- import {defineBehavior} from './behavior.types.behavior'
7
-
8
- export const coreInsertBehaviors = [
9
- defineBehavior({
10
- on: 'insert.text',
11
- guard: ({snapshot}) => {
12
- const focusSpan = getFocusSpan(snapshot)
13
-
14
- if (!focusSpan) {
15
- return false
16
- }
17
-
18
- const markState = getMarkState(snapshot)
19
- const activeDecorators = getActiveDecorators(snapshot)
20
- const activeAnnotations = getActiveAnnotationsMarks(snapshot)
21
-
22
- if (markState && markState.state === 'unchanged') {
23
- const markStateDecorators = (markState.marks ?? []).filter((mark) =>
24
- snapshot.context.schema.decorators
25
- .map((decorator) => decorator.name)
26
- .includes(mark),
27
- )
28
-
29
- if (
30
- markStateDecorators.length === activeDecorators.length &&
31
- markStateDecorators.every((mark) => activeDecorators.includes(mark))
32
- ) {
33
- return false
34
- }
35
- }
36
-
37
- return {activeDecorators, activeAnnotations}
38
- },
39
- actions: [
40
- ({snapshot, event}, {activeDecorators, activeAnnotations}) => [
41
- raise({
42
- type: 'insert.child',
43
- child: {
44
- _type: snapshot.context.schema.span.name,
45
- text: event.text,
46
- marks: [...activeDecorators, ...activeAnnotations],
47
- },
48
- }),
49
- ],
50
- ],
51
- }),
52
- ]