@prosekit/core 0.8.6 → 0.9.0

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 (57) hide show
  1. package/dist/{editor-M9OimMiI.d.ts → editor-4lgGc3CY.d.ts} +20 -60
  2. package/dist/editor-4lgGc3CY.d.ts.map +1 -0
  3. package/dist/{editor-D2iEkgO8.js → editor-DGNUXn-u.js} +99 -116
  4. package/dist/editor-DGNUXn-u.js.map +1 -0
  5. package/dist/prosekit-core-test.d.ts +1 -1
  6. package/dist/prosekit-core-test.js +1 -1
  7. package/dist/prosekit-core.d.ts +89 -180
  8. package/dist/prosekit-core.d.ts.map +1 -1
  9. package/dist/prosekit-core.js +322 -381
  10. package/dist/prosekit-core.js.map +1 -1
  11. package/package.json +7 -8
  12. package/src/commands/select-all.ts +3 -8
  13. package/src/commands/select-block.spec.ts +83 -0
  14. package/src/commands/select-block.ts +59 -0
  15. package/src/commands/wrap.ts +1 -6
  16. package/src/editor/action.ts +1 -11
  17. package/src/editor/editor.ts +20 -32
  18. package/src/extensions/command.ts +4 -0
  19. package/src/extensions/default-state.spec.ts +0 -4
  20. package/src/extensions/default-state.ts +4 -24
  21. package/src/extensions/events/dom-event.ts +1 -4
  22. package/src/extensions/events/editor-event.ts +1 -1
  23. package/src/extensions/history.ts +1 -1
  24. package/src/extensions/keymap-base.spec.ts +98 -0
  25. package/src/extensions/keymap-base.ts +37 -13
  26. package/src/extensions/keymap.spec.ts +74 -1
  27. package/src/extensions/keymap.ts +19 -31
  28. package/src/extensions/mark-spec.ts +32 -29
  29. package/src/extensions/node-spec.ts +28 -19
  30. package/src/extensions/plugin.ts +1 -2
  31. package/src/facets/command.ts +8 -2
  32. package/src/facets/state.spec.ts +6 -6
  33. package/src/facets/state.ts +1 -2
  34. package/src/index.ts +3 -23
  35. package/src/types/extension-command.ts +0 -7
  36. package/src/types/extension.ts +0 -16
  37. package/src/utils/array-grouping.spec.ts +1 -11
  38. package/src/utils/array-grouping.ts +1 -14
  39. package/src/utils/array.ts +0 -4
  40. package/src/utils/combine-event-handlers.ts +4 -6
  41. package/src/utils/editor-content.ts +3 -3
  42. package/src/utils/env.ts +2 -0
  43. package/src/utils/output-spec.ts +11 -0
  44. package/src/utils/parse.ts +9 -9
  45. package/dist/editor-D2iEkgO8.js.map +0 -1
  46. package/dist/editor-M9OimMiI.d.ts.map +0 -1
  47. package/src/extensions/doc.ts +0 -31
  48. package/src/extensions/paragraph.ts +0 -61
  49. package/src/extensions/text.ts +0 -34
  50. package/src/types/base-node-view-options.ts +0 -33
  51. package/src/types/object-entries.ts +0 -13
  52. package/src/utils/collect-children.ts +0 -21
  53. package/src/utils/collect-nodes.ts +0 -37
  54. package/src/utils/deep-equals.spec.ts +0 -26
  55. package/src/utils/deep-equals.ts +0 -29
  56. package/src/utils/get-id.spec.ts +0 -14
  57. package/src/utils/get-id.ts +0 -13
@@ -1,21 +0,0 @@
1
- import type {
2
- Fragment,
3
- ProseMirrorNode,
4
- } from '@prosekit/pm/model'
5
-
6
- /**
7
- * Collects all children of a node or a fragment, and returns them as an array.
8
- *
9
- * @deprecated Use `node.children` or `fragment.content` instead.
10
- *
11
- * @hidden
12
- */
13
- export function collectChildren(
14
- parent: ProseMirrorNode | Fragment,
15
- ): ProseMirrorNode[] {
16
- const children: ProseMirrorNode[] = []
17
- for (let i = 0; i < parent.childCount; i++) {
18
- children.push(parent.child(i))
19
- }
20
- return children
21
- }
@@ -1,37 +0,0 @@
1
- import {
2
- ProseMirrorFragment,
3
- ProseMirrorNode,
4
- } from '@prosekit/pm/model'
5
-
6
- import { ProseKitError } from '../error'
7
-
8
- /**
9
- * @hidden
10
- *
11
- * @deprecated
12
- */
13
- export type NodeContent = ProseMirrorNode | ProseMirrorFragment | NodeContent[]
14
-
15
- /**
16
- * Collects all nodes from a given content.
17
- *
18
- * @deprecated Use `collectChildren` instead.
19
- *
20
- * @hidden
21
- */
22
- export function collectNodes(content: NodeContent): ProseMirrorNode[] {
23
- if (Array.isArray(content)) {
24
- return content.flatMap(collectNodes)
25
- }
26
- if (content instanceof ProseMirrorNode) {
27
- return [content]
28
- }
29
- if (content instanceof ProseMirrorFragment) {
30
- const nodes: ProseMirrorNode[] = []
31
- for (let i = 0; i < content.childCount; i++) {
32
- nodes.push(content.child(i))
33
- }
34
- return nodes
35
- }
36
- throw new ProseKitError(`Invalid node content: ${typeof content}`)
37
- }
@@ -1,26 +0,0 @@
1
- import OrderedMap from 'orderedmap'
2
- import {
3
- expect,
4
- test,
5
- } from 'vitest'
6
-
7
- import { deepEquals } from './deep-equals'
8
-
9
- test('arrays with equal values are equal', () => {
10
- expect(deepEquals([1, 2], [1, 2])).toBe(true)
11
- expect(deepEquals([1, 2], [2, 1])).toBe(false)
12
- })
13
-
14
- test('nested objects', () => {
15
- const a = { a: 1, b: { c: 3 } }
16
- const b = { a: 1, b: { c: 3 } }
17
- const c = { a: 1, b: { c: 4 } }
18
- expect(deepEquals(a, b)).toBe(true)
19
- expect(deepEquals(a, c)).toBe(false)
20
- })
21
-
22
- test('ordered maps', () => {
23
- const map1 = OrderedMap.from({ a: 1, b: 2 })
24
- const map2 = OrderedMap.from({ a: 1, b: 2 })
25
- expect(deepEquals(map1, map2)).toBe(true)
26
- })
@@ -1,29 +0,0 @@
1
- import OrderedMap from 'orderedmap'
2
-
3
- export function deepEquals<T>(a: T, b: T): boolean {
4
- if (a === b) {
5
- return true
6
- }
7
-
8
- if (!a || !b) {
9
- return false
10
- }
11
-
12
- if (Array.isArray(a) && Array.isArray(b)) {
13
- return a.length === b.length && a.every((x, i) => deepEquals(x, b[i]))
14
- }
15
-
16
- if (a instanceof OrderedMap && b instanceof OrderedMap) {
17
- return a.size === b.size && deepEquals(a.toObject(), b.toObject())
18
- }
19
-
20
- if (typeof a === 'object' && typeof b === 'object') {
21
- const aKeys = Object.keys(a)
22
- const bKeys = Object.keys(b)
23
- return (
24
- aKeys.length === bKeys.length
25
- && aKeys.every((key) => deepEquals(a[key as keyof T], b[key as keyof T]))
26
- )
27
- }
28
- return false
29
- }
@@ -1,14 +0,0 @@
1
- import {
2
- expect,
3
- test,
4
- } from 'vitest'
5
-
6
- import { getId } from './get-id'
7
-
8
- test('generates sequential ids', () => {
9
- const first = getId()
10
- const second = getId()
11
- const firstNum = Number(first.split(':')[1])
12
- const secondNum = Number(second.split(':')[1])
13
- expect(secondNum).toBe((firstNum + 1) % Number.MAX_SAFE_INTEGER)
14
- })
@@ -1,13 +0,0 @@
1
- let id = 0
2
-
3
- /**
4
- * Returns a unique id in the current process that can be used in various places.
5
- *
6
- * @internal
7
- *
8
- * @deprecated Import `getId` from `@ocavue/utils` package instead. Remove it in a future version.
9
- */
10
- export function getId(): string {
11
- id = (id + 1) % Number.MAX_SAFE_INTEGER
12
- return `id:${id}`
13
- }