@prosekit/react 0.5.3 → 0.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/create-component-CBvs05W1.js +2 -1
- package/dist/create-component-CBvs05W1.js.map +1 -0
- package/dist/{create-props-CkTwd_m_.d.ts → create-props-EGV61dJR.d.ts} +3 -2
- package/dist/create-props-EGV61dJR.d.ts.map +1 -0
- package/dist/editor-context-Cci4uqN_.js +2 -1
- package/dist/editor-context-Cci4uqN_.js.map +1 -0
- package/dist/prosekit-react-autocomplete.d.ts +11 -10
- package/dist/prosekit-react-autocomplete.d.ts.map +1 -0
- package/dist/prosekit-react-autocomplete.js +2 -1
- package/dist/prosekit-react-autocomplete.js.map +1 -0
- package/dist/prosekit-react-block-handle.d.ts +9 -8
- package/dist/prosekit-react-block-handle.d.ts.map +1 -0
- package/dist/prosekit-react-block-handle.js +2 -1
- package/dist/prosekit-react-block-handle.js.map +1 -0
- package/dist/prosekit-react-drop-indicator.d.ts +14 -0
- package/dist/prosekit-react-drop-indicator.d.ts.map +1 -0
- package/dist/prosekit-react-drop-indicator.js +10 -0
- package/dist/prosekit-react-drop-indicator.js.map +1 -0
- package/dist/prosekit-react-inline-popover.d.ts +5 -4
- package/dist/prosekit-react-inline-popover.d.ts.map +1 -0
- package/dist/prosekit-react-inline-popover.js +2 -1
- package/dist/prosekit-react-inline-popover.js.map +1 -0
- package/dist/prosekit-react-popover.d.ts +9 -8
- package/dist/prosekit-react-popover.d.ts.map +1 -0
- package/dist/prosekit-react-popover.js +2 -1
- package/dist/prosekit-react-popover.js.map +1 -0
- package/dist/prosekit-react-resizable.d.ts +7 -6
- package/dist/prosekit-react-resizable.d.ts.map +1 -0
- package/dist/prosekit-react-resizable.js +2 -1
- package/dist/prosekit-react-resizable.js.map +1 -0
- package/dist/prosekit-react-table-handle.d.ts +21 -20
- package/dist/prosekit-react-table-handle.d.ts.map +1 -0
- package/dist/prosekit-react-table-handle.js +2 -1
- package/dist/prosekit-react-table-handle.js.map +1 -0
- package/dist/prosekit-react-tooltip.d.ts +9 -8
- package/dist/prosekit-react-tooltip.d.ts.map +1 -0
- package/dist/prosekit-react-tooltip.js +2 -1
- package/dist/prosekit-react-tooltip.js.map +1 -0
- package/dist/prosekit-react.d.ts +96 -81
- package/dist/prosekit-react.d.ts.map +1 -0
- package/dist/prosekit-react.js +2 -1
- package/dist/prosekit-react.js.map +1 -0
- package/package.json +25 -17
- package/src/components/autocomplete/autocomplete-empty.gen.ts +34 -0
- package/src/components/autocomplete/autocomplete-item.gen.ts +34 -0
- package/src/components/autocomplete/autocomplete-list.gen.ts +34 -0
- package/src/components/autocomplete/autocomplete-popover.gen.ts +34 -0
- package/src/components/autocomplete/index.gen.ts +7 -0
- package/src/components/block-handle/block-handle-add.gen.ts +34 -0
- package/src/components/block-handle/block-handle-draggable.gen.ts +34 -0
- package/src/components/block-handle/block-handle-popover.gen.ts +34 -0
- package/src/components/block-handle/index.gen.ts +5 -0
- package/src/components/create-component.ts +133 -0
- package/src/components/create-props.ts +13 -0
- package/src/components/drop-indicator/drop-indicator.gen.ts +34 -0
- package/src/components/drop-indicator/index.gen.ts +1 -0
- package/src/components/inline-popover/index.gen.ts +1 -0
- package/src/components/inline-popover/inline-popover.gen.ts +34 -0
- package/src/components/merge-refs.ts +35 -0
- package/src/components/popover/index.gen.ts +5 -0
- package/src/components/popover/popover-content.gen.ts +34 -0
- package/src/components/popover/popover-root.gen.ts +34 -0
- package/src/components/popover/popover-trigger.gen.ts +34 -0
- package/src/components/prosekit.ts +37 -0
- package/src/components/resizable/index.gen.ts +3 -0
- package/src/components/resizable/resizable-handle.gen.ts +34 -0
- package/src/components/resizable/resizable-root.gen.ts +34 -0
- package/src/components/table-handle/index.gen.ts +17 -0
- package/src/components/table-handle/table-handle-column-root.gen.ts +34 -0
- package/src/components/table-handle/table-handle-column-trigger.gen.ts +34 -0
- package/src/components/table-handle/table-handle-drag-preview.gen.ts +34 -0
- package/src/components/table-handle/table-handle-drop-indicator.gen.ts +34 -0
- package/src/components/table-handle/table-handle-popover-content.gen.ts +34 -0
- package/src/components/table-handle/table-handle-popover-item.gen.ts +34 -0
- package/src/components/table-handle/table-handle-root.gen.ts +34 -0
- package/src/components/table-handle/table-handle-row-root.gen.ts +34 -0
- package/src/components/table-handle/table-handle-row-trigger.gen.ts +34 -0
- package/src/components/tooltip/index.gen.ts +5 -0
- package/src/components/tooltip/tooltip-content.gen.ts +34 -0
- package/src/components/tooltip/tooltip-root.gen.ts +34 -0
- package/src/components/tooltip/tooltip-trigger.gen.ts +34 -0
- package/src/contexts/editor-context.ts +23 -0
- package/src/extensions/react-mark-view.ts +93 -0
- package/src/extensions/react-node-view.ts +93 -0
- package/src/hooks/use-doc-change.ts +24 -0
- package/src/hooks/use-editor-derived-value.ts +83 -0
- package/src/hooks/use-editor-extension.ts +24 -0
- package/src/hooks/use-editor.ts +62 -0
- package/src/hooks/use-extension.ts +41 -0
- package/src/hooks/use-keymap.ts +15 -0
- package/src/hooks/use-priority-extension.ts +18 -0
- package/src/hooks/use-state-update.ts +24 -0
- package/src/index.ts +29 -0
- package/src/types.ts +6 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TableHandlePopoverContentElement,
|
|
3
|
+
type TableHandlePopoverContentProps as Props,
|
|
4
|
+
type TableHandlePopoverContentEvents as Events,
|
|
5
|
+
tableHandlePopoverContentProps,
|
|
6
|
+
tableHandlePopoverContentEvents,
|
|
7
|
+
} from '@prosekit/web/table-handle'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TableHandlePopoverContent} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TableHandlePopoverContentProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TableHandlePopoverContent: ForwardRefExoticComponent<
|
|
23
|
+
TableHandlePopoverContentProps &
|
|
24
|
+
RefAttributes<TableHandlePopoverContentElement> &
|
|
25
|
+
HTMLAttributes<TableHandlePopoverContentElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TableHandlePopoverContentProps,
|
|
28
|
+
TableHandlePopoverContentElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-table-handle-popover-content',
|
|
31
|
+
'TableHandlePopoverContent',
|
|
32
|
+
Object.keys(tableHandlePopoverContentProps),
|
|
33
|
+
Object.keys(tableHandlePopoverContentEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TableHandlePopoverItemElement,
|
|
3
|
+
type TableHandlePopoverItemProps as Props,
|
|
4
|
+
type TableHandlePopoverItemEvents as Events,
|
|
5
|
+
tableHandlePopoverItemProps,
|
|
6
|
+
tableHandlePopoverItemEvents,
|
|
7
|
+
} from '@prosekit/web/table-handle'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TableHandlePopoverItem} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TableHandlePopoverItemProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TableHandlePopoverItem: ForwardRefExoticComponent<
|
|
23
|
+
TableHandlePopoverItemProps &
|
|
24
|
+
RefAttributes<TableHandlePopoverItemElement> &
|
|
25
|
+
HTMLAttributes<TableHandlePopoverItemElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TableHandlePopoverItemProps,
|
|
28
|
+
TableHandlePopoverItemElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-table-handle-popover-item',
|
|
31
|
+
'TableHandlePopoverItem',
|
|
32
|
+
Object.keys(tableHandlePopoverItemProps),
|
|
33
|
+
Object.keys(tableHandlePopoverItemEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TableHandleRootElement,
|
|
3
|
+
type TableHandleRootProps as Props,
|
|
4
|
+
type TableHandleRootEvents as Events,
|
|
5
|
+
tableHandleRootProps,
|
|
6
|
+
tableHandleRootEvents,
|
|
7
|
+
} from '@prosekit/web/table-handle'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TableHandleRoot} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TableHandleRootProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TableHandleRoot: ForwardRefExoticComponent<
|
|
23
|
+
TableHandleRootProps &
|
|
24
|
+
RefAttributes<TableHandleRootElement> &
|
|
25
|
+
HTMLAttributes<TableHandleRootElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TableHandleRootProps,
|
|
28
|
+
TableHandleRootElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-table-handle-root',
|
|
31
|
+
'TableHandleRoot',
|
|
32
|
+
Object.keys(tableHandleRootProps),
|
|
33
|
+
Object.keys(tableHandleRootEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TableHandleRowRootElement,
|
|
3
|
+
type TableHandleRowRootProps as Props,
|
|
4
|
+
type TableHandleRowRootEvents as Events,
|
|
5
|
+
tableHandleRowRootProps,
|
|
6
|
+
tableHandleRowRootEvents,
|
|
7
|
+
} from '@prosekit/web/table-handle'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TableHandleRowRoot} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TableHandleRowRootProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TableHandleRowRoot: ForwardRefExoticComponent<
|
|
23
|
+
TableHandleRowRootProps &
|
|
24
|
+
RefAttributes<TableHandleRowRootElement> &
|
|
25
|
+
HTMLAttributes<TableHandleRowRootElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TableHandleRowRootProps,
|
|
28
|
+
TableHandleRowRootElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-table-handle-row-root',
|
|
31
|
+
'TableHandleRowRoot',
|
|
32
|
+
Object.keys(tableHandleRowRootProps),
|
|
33
|
+
Object.keys(tableHandleRowRootEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TableHandleRowTriggerElement,
|
|
3
|
+
type TableHandleRowTriggerProps as Props,
|
|
4
|
+
type TableHandleRowTriggerEvents as Events,
|
|
5
|
+
tableHandleRowTriggerProps,
|
|
6
|
+
tableHandleRowTriggerEvents,
|
|
7
|
+
} from '@prosekit/web/table-handle'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TableHandleRowTrigger} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TableHandleRowTriggerProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TableHandleRowTrigger: ForwardRefExoticComponent<
|
|
23
|
+
TableHandleRowTriggerProps &
|
|
24
|
+
RefAttributes<TableHandleRowTriggerElement> &
|
|
25
|
+
HTMLAttributes<TableHandleRowTriggerElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TableHandleRowTriggerProps,
|
|
28
|
+
TableHandleRowTriggerElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-table-handle-row-trigger',
|
|
31
|
+
'TableHandleRowTrigger',
|
|
32
|
+
Object.keys(tableHandleRowTriggerProps),
|
|
33
|
+
Object.keys(tableHandleRowTriggerEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TooltipContentElement,
|
|
3
|
+
type TooltipContentProps as Props,
|
|
4
|
+
type TooltipContentEvents as Events,
|
|
5
|
+
tooltipContentProps,
|
|
6
|
+
tooltipContentEvents,
|
|
7
|
+
} from '@prosekit/web/tooltip'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TooltipContent} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TooltipContentProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TooltipContent: ForwardRefExoticComponent<
|
|
23
|
+
TooltipContentProps &
|
|
24
|
+
RefAttributes<TooltipContentElement> &
|
|
25
|
+
HTMLAttributes<TooltipContentElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TooltipContentProps,
|
|
28
|
+
TooltipContentElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-tooltip-content',
|
|
31
|
+
'TooltipContent',
|
|
32
|
+
Object.keys(tooltipContentProps),
|
|
33
|
+
Object.keys(tooltipContentEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TooltipRootElement,
|
|
3
|
+
type TooltipRootProps as Props,
|
|
4
|
+
type TooltipRootEvents as Events,
|
|
5
|
+
tooltipRootProps,
|
|
6
|
+
tooltipRootEvents,
|
|
7
|
+
} from '@prosekit/web/tooltip'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TooltipRoot} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TooltipRootProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TooltipRoot: ForwardRefExoticComponent<
|
|
23
|
+
TooltipRootProps &
|
|
24
|
+
RefAttributes<TooltipRootElement> &
|
|
25
|
+
HTMLAttributes<TooltipRootElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TooltipRootProps,
|
|
28
|
+
TooltipRootElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-tooltip-root',
|
|
31
|
+
'TooltipRoot',
|
|
32
|
+
Object.keys(tooltipRootProps),
|
|
33
|
+
Object.keys(tooltipRootEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type TooltipTriggerElement,
|
|
3
|
+
type TooltipTriggerProps as Props,
|
|
4
|
+
type TooltipTriggerEvents as Events,
|
|
5
|
+
tooltipTriggerProps,
|
|
6
|
+
tooltipTriggerEvents,
|
|
7
|
+
} from '@prosekit/web/tooltip'
|
|
8
|
+
import type {
|
|
9
|
+
ForwardRefExoticComponent,
|
|
10
|
+
HTMLAttributes,
|
|
11
|
+
RefAttributes,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { createComponent } from '../create-component'
|
|
15
|
+
import type { CreateProps } from '../create-props'
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Props for the {@link TooltipTrigger} component.
|
|
19
|
+
*/
|
|
20
|
+
export interface TooltipTriggerProps extends Partial<CreateProps<Props, Events>> {}
|
|
21
|
+
|
|
22
|
+
export const TooltipTrigger: ForwardRefExoticComponent<
|
|
23
|
+
TooltipTriggerProps &
|
|
24
|
+
RefAttributes<TooltipTriggerElement> &
|
|
25
|
+
HTMLAttributes<TooltipTriggerElement>
|
|
26
|
+
> = createComponent<
|
|
27
|
+
TooltipTriggerProps,
|
|
28
|
+
TooltipTriggerElement
|
|
29
|
+
>(
|
|
30
|
+
'prosekit-tooltip-trigger',
|
|
31
|
+
'TooltipTrigger',
|
|
32
|
+
Object.keys(tooltipTriggerProps),
|
|
33
|
+
Object.keys(tooltipTriggerEvents),
|
|
34
|
+
)
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
Editor,
|
|
3
|
+
Extension,
|
|
4
|
+
} from '@prosekit/core'
|
|
5
|
+
import {
|
|
6
|
+
createContext,
|
|
7
|
+
useContext,
|
|
8
|
+
type Provider,
|
|
9
|
+
} from 'react'
|
|
10
|
+
|
|
11
|
+
const editorContext = createContext<Editor | null>(null)
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* @internal
|
|
15
|
+
*/
|
|
16
|
+
export function useEditorContext<E extends Extension>(): Editor<E> | null {
|
|
17
|
+
return useContext(editorContext)
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @internal
|
|
22
|
+
*/
|
|
23
|
+
export const EditorContextProvider: Provider<Editor | null> = editorContext.Provider
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import {
|
|
2
|
+
defineMarkViewComponent,
|
|
3
|
+
defineMarkViewFactory,
|
|
4
|
+
type Extension,
|
|
5
|
+
} from '@prosekit/core'
|
|
6
|
+
import type { MarkViewConstructor } from '@prosekit/pm/view'
|
|
7
|
+
import type { CoreMarkViewUserOptions } from '@prosemirror-adapter/core'
|
|
8
|
+
import {
|
|
9
|
+
useMarkViewContext,
|
|
10
|
+
useMarkViewFactory,
|
|
11
|
+
type MarkViewContext,
|
|
12
|
+
type ReactMarkViewUserOptions,
|
|
13
|
+
} from '@prosemirror-adapter/react'
|
|
14
|
+
import {
|
|
15
|
+
createElement,
|
|
16
|
+
useMemo,
|
|
17
|
+
type ComponentType,
|
|
18
|
+
type FC,
|
|
19
|
+
} from 'react'
|
|
20
|
+
|
|
21
|
+
import { useExtension } from '../hooks/use-extension'
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* @public
|
|
25
|
+
*/
|
|
26
|
+
export interface ReactMarkViewProps extends MarkViewContext {}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* @public
|
|
30
|
+
*/
|
|
31
|
+
export type ReactMarkViewComponent = ComponentType<ReactMarkViewProps>
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Options for {@link defineReactMarkView}.
|
|
35
|
+
*
|
|
36
|
+
* @public
|
|
37
|
+
*/
|
|
38
|
+
export interface ReactMarkViewOptions extends CoreMarkViewUserOptions<ReactMarkViewComponent> {
|
|
39
|
+
/**
|
|
40
|
+
* The name of the mark type.
|
|
41
|
+
*/
|
|
42
|
+
name: string
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function withMarkViewProps(component: ReactMarkViewComponent) {
|
|
46
|
+
return function MarkViewPropsWrapper() {
|
|
47
|
+
const props: ReactMarkViewProps = useMarkViewContext()
|
|
48
|
+
return createElement(component, props)
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* @internal
|
|
54
|
+
*/
|
|
55
|
+
export const ReactMarkViewConsumer: FC = () => {
|
|
56
|
+
const markViewFactory = useMarkViewFactory()
|
|
57
|
+
const extension = useMemo(
|
|
58
|
+
() => defineReactMarkViewFactory(markViewFactory),
|
|
59
|
+
[markViewFactory],
|
|
60
|
+
)
|
|
61
|
+
useExtension(extension)
|
|
62
|
+
|
|
63
|
+
return null
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Defines a mark view using a React component.
|
|
68
|
+
*
|
|
69
|
+
* @public
|
|
70
|
+
*/
|
|
71
|
+
export function defineReactMarkView(options: ReactMarkViewOptions): Extension {
|
|
72
|
+
const { name, component, ...userOptions } = options
|
|
73
|
+
|
|
74
|
+
const args: ReactMarkViewUserOptions = {
|
|
75
|
+
...userOptions,
|
|
76
|
+
component: withMarkViewProps(component),
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return defineMarkViewComponent<ReactMarkViewUserOptions>({
|
|
80
|
+
group: 'react',
|
|
81
|
+
name,
|
|
82
|
+
args,
|
|
83
|
+
})
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
function defineReactMarkViewFactory(
|
|
87
|
+
factory: (options: ReactMarkViewUserOptions) => MarkViewConstructor,
|
|
88
|
+
) {
|
|
89
|
+
return defineMarkViewFactory<ReactMarkViewUserOptions>({
|
|
90
|
+
group: 'react',
|
|
91
|
+
factory,
|
|
92
|
+
})
|
|
93
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import {
|
|
2
|
+
defineNodeViewComponent,
|
|
3
|
+
defineNodeViewFactory,
|
|
4
|
+
type Extension,
|
|
5
|
+
} from '@prosekit/core'
|
|
6
|
+
import type { NodeViewConstructor } from '@prosekit/pm/view'
|
|
7
|
+
import type { CoreNodeViewUserOptions } from '@prosemirror-adapter/core'
|
|
8
|
+
import {
|
|
9
|
+
useNodeViewContext,
|
|
10
|
+
useNodeViewFactory,
|
|
11
|
+
type NodeViewContext,
|
|
12
|
+
type ReactNodeViewUserOptions,
|
|
13
|
+
} from '@prosemirror-adapter/react'
|
|
14
|
+
import {
|
|
15
|
+
createElement,
|
|
16
|
+
useMemo,
|
|
17
|
+
type ComponentType,
|
|
18
|
+
type FC,
|
|
19
|
+
} from 'react'
|
|
20
|
+
|
|
21
|
+
import { useExtension } from '../hooks/use-extension'
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* @public
|
|
25
|
+
*/
|
|
26
|
+
export interface ReactNodeViewProps extends NodeViewContext {}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* @public
|
|
30
|
+
*/
|
|
31
|
+
export type ReactNodeViewComponent = ComponentType<ReactNodeViewProps>
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Options for {@link defineReactNodeView}.
|
|
35
|
+
*
|
|
36
|
+
* @public
|
|
37
|
+
*/
|
|
38
|
+
export interface ReactNodeViewOptions extends CoreNodeViewUserOptions<ReactNodeViewComponent> {
|
|
39
|
+
/**
|
|
40
|
+
* The name of the node type.
|
|
41
|
+
*/
|
|
42
|
+
name: string
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function withNodeViewProps(component: ReactNodeViewComponent) {
|
|
46
|
+
return function NodeViewPropsWrapper() {
|
|
47
|
+
const props: ReactNodeViewProps = useNodeViewContext()
|
|
48
|
+
return createElement(component, props)
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* @internal
|
|
54
|
+
*/
|
|
55
|
+
export const ReactNodeViewConsumer: FC = () => {
|
|
56
|
+
const nodeViewFactory = useNodeViewFactory()
|
|
57
|
+
const extension = useMemo(
|
|
58
|
+
() => defineReactNodeViewFactory(nodeViewFactory),
|
|
59
|
+
[nodeViewFactory],
|
|
60
|
+
)
|
|
61
|
+
useExtension(extension)
|
|
62
|
+
|
|
63
|
+
return null
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Defines a node view using a React component.
|
|
68
|
+
*
|
|
69
|
+
* @public
|
|
70
|
+
*/
|
|
71
|
+
export function defineReactNodeView(options: ReactNodeViewOptions): Extension {
|
|
72
|
+
const { name, component, ...userOptions } = options
|
|
73
|
+
|
|
74
|
+
const args: ReactNodeViewUserOptions = {
|
|
75
|
+
...userOptions,
|
|
76
|
+
component: withNodeViewProps(component),
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return defineNodeViewComponent<ReactNodeViewUserOptions>({
|
|
80
|
+
group: 'react',
|
|
81
|
+
name,
|
|
82
|
+
args,
|
|
83
|
+
})
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
function defineReactNodeViewFactory(
|
|
87
|
+
factory: (options: ReactNodeViewUserOptions) => NodeViewConstructor,
|
|
88
|
+
) {
|
|
89
|
+
return defineNodeViewFactory<ReactNodeViewUserOptions>({
|
|
90
|
+
group: 'react',
|
|
91
|
+
factory,
|
|
92
|
+
})
|
|
93
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { defineDocChangeHandler } from '@prosekit/core'
|
|
2
|
+
import type { ProseMirrorNode } from '@prosekit/pm/model'
|
|
3
|
+
import { useMemo } from 'react'
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
useExtension,
|
|
7
|
+
type UseExtensionOptions,
|
|
8
|
+
} from './use-extension'
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Calls the given handler whenever the editor document changes.
|
|
12
|
+
*
|
|
13
|
+
* @public
|
|
14
|
+
*/
|
|
15
|
+
export function useDocChange(
|
|
16
|
+
handler: (doc: ProseMirrorNode) => void,
|
|
17
|
+
options?: UseExtensionOptions,
|
|
18
|
+
): void {
|
|
19
|
+
const extension = useMemo(
|
|
20
|
+
() => defineDocChangeHandler((view) => handler(view.state.doc)),
|
|
21
|
+
[handler],
|
|
22
|
+
)
|
|
23
|
+
useExtension(extension, options)
|
|
24
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import {
|
|
2
|
+
defineMountHandler,
|
|
3
|
+
defineUpdateHandler,
|
|
4
|
+
EditorNotFoundError,
|
|
5
|
+
union,
|
|
6
|
+
type Editor,
|
|
7
|
+
type Extension,
|
|
8
|
+
} from '@prosekit/core'
|
|
9
|
+
import {
|
|
10
|
+
useMemo,
|
|
11
|
+
useSyncExternalStore,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { useEditorContext } from '../contexts/editor-context'
|
|
15
|
+
|
|
16
|
+
export interface UseEditorDerivedOptions<E extends Extension = any> {
|
|
17
|
+
/**
|
|
18
|
+
* The editor to add the extension to. If not provided, it will use the
|
|
19
|
+
* editor from the nearest `ProseKit` component.
|
|
20
|
+
*/
|
|
21
|
+
editor?: Editor<E>
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* A hook that runs a function to derive a value from the editor instance after
|
|
26
|
+
* editor state changes.
|
|
27
|
+
*
|
|
28
|
+
* This is useful when you need to render something based on the editor state,
|
|
29
|
+
* for example, whether the selected text is wrapped in an italic mark.
|
|
30
|
+
*
|
|
31
|
+
* @public
|
|
32
|
+
*/
|
|
33
|
+
export function useEditorDerivedValue<E extends Extension, Derived>(
|
|
34
|
+
/**
|
|
35
|
+
* A function that receives the editor instance and returns a derived value.
|
|
36
|
+
*
|
|
37
|
+
* It will be called whenever the editor's document state changes, or when it
|
|
38
|
+
* mounts.
|
|
39
|
+
*
|
|
40
|
+
* This function should be memoized.
|
|
41
|
+
*/
|
|
42
|
+
derive: (editor: Editor<E>) => Derived,
|
|
43
|
+
options?: UseEditorDerivedOptions<E>,
|
|
44
|
+
): Derived {
|
|
45
|
+
const editorContext = useEditorContext<E>()
|
|
46
|
+
const editor = options?.editor ?? editorContext
|
|
47
|
+
if (!editor) {
|
|
48
|
+
throw new EditorNotFoundError()
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const [subscribe, getSnapshot] = useMemo(() => {
|
|
52
|
+
return createEditorStore(editor, derive)
|
|
53
|
+
}, [editor, derive])
|
|
54
|
+
|
|
55
|
+
return useSyncExternalStore(subscribe, getSnapshot)
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function createEditorStore<Derived, E extends Extension = any>(editor: Editor<E>, derive: (editor: Editor<E>) => Derived) {
|
|
59
|
+
let dirty = true
|
|
60
|
+
let derived: Derived
|
|
61
|
+
|
|
62
|
+
const subscribe = (onChange: VoidFunction): VoidFunction => {
|
|
63
|
+
const handleChange = () => {
|
|
64
|
+
dirty = true
|
|
65
|
+
onChange()
|
|
66
|
+
}
|
|
67
|
+
const extension = union(
|
|
68
|
+
defineUpdateHandler(handleChange),
|
|
69
|
+
defineMountHandler(handleChange),
|
|
70
|
+
)
|
|
71
|
+
return editor.use(extension)
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
const getSnapshot = () => {
|
|
75
|
+
if (dirty) {
|
|
76
|
+
dirty = false
|
|
77
|
+
derived = derive(editor)
|
|
78
|
+
}
|
|
79
|
+
return derived
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return [subscribe, getSnapshot] as const
|
|
83
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import {
|
|
2
|
+
EditorNotFoundError,
|
|
3
|
+
type Editor,
|
|
4
|
+
type Extension,
|
|
5
|
+
} from '@prosekit/core'
|
|
6
|
+
import { useEffect } from 'react'
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @internal
|
|
10
|
+
*/
|
|
11
|
+
export function useEditorExtension(
|
|
12
|
+
editor: Editor | null | undefined,
|
|
13
|
+
extension: Extension | null,
|
|
14
|
+
): void {
|
|
15
|
+
if (!editor) {
|
|
16
|
+
throw new EditorNotFoundError()
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (extension) {
|
|
21
|
+
return editor.use(extension)
|
|
22
|
+
}
|
|
23
|
+
}, [editor, extension])
|
|
24
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import {
|
|
2
|
+
defineMountHandler,
|
|
3
|
+
defineUpdateHandler,
|
|
4
|
+
ProseKitError,
|
|
5
|
+
union,
|
|
6
|
+
type Editor,
|
|
7
|
+
type Extension,
|
|
8
|
+
} from '@prosekit/core'
|
|
9
|
+
import {
|
|
10
|
+
useEffect,
|
|
11
|
+
useReducer,
|
|
12
|
+
} from 'react'
|
|
13
|
+
|
|
14
|
+
import { useEditorContext } from '../contexts/editor-context'
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Retrieves the editor instance from the nearest ProseKit component.
|
|
18
|
+
*
|
|
19
|
+
* @public
|
|
20
|
+
*/
|
|
21
|
+
export function useEditor<E extends Extension = any>(options?: {
|
|
22
|
+
/**
|
|
23
|
+
* Whether to update the component when the editor is mounted or editor state
|
|
24
|
+
* is updated.
|
|
25
|
+
*
|
|
26
|
+
* Note this this option doesn't work with [React
|
|
27
|
+
* compiler](https://react.dev/learn/react-compiler) because the returned
|
|
28
|
+
* editor will be the same instance after state updates. If you're using React
|
|
29
|
+
* compiler, you should use {@link useEditorDerivedValue} instead.
|
|
30
|
+
*
|
|
31
|
+
* @default false
|
|
32
|
+
*/
|
|
33
|
+
update?: boolean
|
|
34
|
+
}): Editor<E> {
|
|
35
|
+
const update = options?.update ?? false
|
|
36
|
+
|
|
37
|
+
const editor = useEditorContext<E>()
|
|
38
|
+
if (!editor) {
|
|
39
|
+
throw new ProseKitError(
|
|
40
|
+
'useEditor must be used within the ProseKit component',
|
|
41
|
+
)
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const forceUpdate = useForceUpdate()
|
|
45
|
+
|
|
46
|
+
useEffect(() => {
|
|
47
|
+
if (update) {
|
|
48
|
+
const extension = union(
|
|
49
|
+
defineMountHandler(forceUpdate),
|
|
50
|
+
defineUpdateHandler(forceUpdate),
|
|
51
|
+
)
|
|
52
|
+
return editor.use(extension)
|
|
53
|
+
}
|
|
54
|
+
}, [editor, update, forceUpdate])
|
|
55
|
+
|
|
56
|
+
return editor
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
function useForceUpdate() {
|
|
60
|
+
const [, dispatch] = useReducer((x: number) => x + 1, 0)
|
|
61
|
+
return dispatch
|
|
62
|
+
}
|