@prosekit/preact 0.5.0 → 0.6.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 (94) hide show
  1. package/dist/create-component-D7yDR5ux.js +2 -1
  2. package/dist/create-component-D7yDR5ux.js.map +1 -0
  3. package/dist/{create-props-CkTwd_m_.d.ts → create-props-EGV61dJR.d.ts} +3 -2
  4. package/dist/create-props-EGV61dJR.d.ts.map +1 -0
  5. package/dist/editor-context-imq7MdJr.js +2 -1
  6. package/dist/editor-context-imq7MdJr.js.map +1 -0
  7. package/dist/prosekit-preact-autocomplete.d.ts +12 -11
  8. package/dist/prosekit-preact-autocomplete.d.ts.map +1 -0
  9. package/dist/prosekit-preact-autocomplete.js +2 -1
  10. package/dist/prosekit-preact-autocomplete.js.map +1 -0
  11. package/dist/prosekit-preact-block-handle.d.ts +9 -8
  12. package/dist/prosekit-preact-block-handle.d.ts.map +1 -0
  13. package/dist/prosekit-preact-block-handle.js +2 -1
  14. package/dist/prosekit-preact-block-handle.js.map +1 -0
  15. package/dist/prosekit-preact-drop-indicator.d.ts +5 -4
  16. package/dist/prosekit-preact-drop-indicator.d.ts.map +1 -0
  17. package/dist/prosekit-preact-drop-indicator.js +2 -1
  18. package/dist/prosekit-preact-drop-indicator.js.map +1 -0
  19. package/dist/prosekit-preact-inline-popover.d.ts +5 -4
  20. package/dist/prosekit-preact-inline-popover.d.ts.map +1 -0
  21. package/dist/prosekit-preact-inline-popover.js +2 -1
  22. package/dist/prosekit-preact-inline-popover.js.map +1 -0
  23. package/dist/prosekit-preact-popover.d.ts +9 -8
  24. package/dist/prosekit-preact-popover.d.ts.map +1 -0
  25. package/dist/prosekit-preact-popover.js +2 -1
  26. package/dist/prosekit-preact-popover.js.map +1 -0
  27. package/dist/prosekit-preact-resizable.d.ts +7 -6
  28. package/dist/prosekit-preact-resizable.d.ts.map +1 -0
  29. package/dist/prosekit-preact-resizable.js +2 -1
  30. package/dist/prosekit-preact-resizable.js.map +1 -0
  31. package/dist/prosekit-preact-table-handle.d.ts +21 -20
  32. package/dist/prosekit-preact-table-handle.d.ts.map +1 -0
  33. package/dist/prosekit-preact-table-handle.js +2 -1
  34. package/dist/prosekit-preact-table-handle.js.map +1 -0
  35. package/dist/prosekit-preact-tooltip.d.ts +9 -8
  36. package/dist/prosekit-preact-tooltip.d.ts.map +1 -0
  37. package/dist/prosekit-preact-tooltip.js +2 -1
  38. package/dist/prosekit-preact-tooltip.js.map +1 -0
  39. package/dist/prosekit-preact.d.ts +124 -34
  40. package/dist/prosekit-preact.d.ts.map +1 -0
  41. package/dist/prosekit-preact.js +137 -23
  42. package/dist/prosekit-preact.js.map +1 -0
  43. package/package.json +16 -14
  44. package/src/components/autocomplete/autocomplete-empty.gen.ts +34 -0
  45. package/src/components/autocomplete/autocomplete-item.gen.ts +34 -0
  46. package/src/components/autocomplete/autocomplete-list.gen.ts +34 -0
  47. package/src/components/autocomplete/autocomplete-popover.gen.ts +34 -0
  48. package/src/components/autocomplete/index.gen.ts +7 -0
  49. package/src/components/block-handle/block-handle-add.gen.ts +34 -0
  50. package/src/components/block-handle/block-handle-draggable.gen.ts +34 -0
  51. package/src/components/block-handle/block-handle-popover.gen.ts +34 -0
  52. package/src/components/block-handle/index.gen.ts +5 -0
  53. package/src/components/create-component.ts +135 -0
  54. package/src/components/create-props.ts +13 -0
  55. package/src/components/drop-indicator/drop-indicator.gen.ts +34 -0
  56. package/src/components/drop-indicator/index.gen.ts +1 -0
  57. package/src/components/inline-popover/index.gen.ts +1 -0
  58. package/src/components/inline-popover/inline-popover.gen.ts +34 -0
  59. package/src/components/merge-refs.ts +35 -0
  60. package/src/components/popover/index.gen.ts +5 -0
  61. package/src/components/popover/popover-content.gen.ts +34 -0
  62. package/src/components/popover/popover-root.gen.ts +34 -0
  63. package/src/components/popover/popover-trigger.gen.ts +34 -0
  64. package/src/components/prosekit.ts +37 -0
  65. package/src/components/resizable/index.gen.ts +3 -0
  66. package/src/components/resizable/resizable-handle.gen.ts +34 -0
  67. package/src/components/resizable/resizable-root.gen.ts +34 -0
  68. package/src/components/table-handle/index.gen.ts +17 -0
  69. package/src/components/table-handle/table-handle-column-root.gen.ts +34 -0
  70. package/src/components/table-handle/table-handle-column-trigger.gen.ts +34 -0
  71. package/src/components/table-handle/table-handle-drag-preview.gen.ts +34 -0
  72. package/src/components/table-handle/table-handle-drop-indicator.gen.ts +34 -0
  73. package/src/components/table-handle/table-handle-popover-content.gen.ts +34 -0
  74. package/src/components/table-handle/table-handle-popover-item.gen.ts +34 -0
  75. package/src/components/table-handle/table-handle-root.gen.ts +34 -0
  76. package/src/components/table-handle/table-handle-row-root.gen.ts +34 -0
  77. package/src/components/table-handle/table-handle-row-trigger.gen.ts +34 -0
  78. package/src/components/tooltip/index.gen.ts +5 -0
  79. package/src/components/tooltip/tooltip-content.gen.ts +34 -0
  80. package/src/components/tooltip/tooltip-root.gen.ts +34 -0
  81. package/src/components/tooltip/tooltip-trigger.gen.ts +34 -0
  82. package/src/contexts/editor-context.ts +23 -0
  83. package/src/extensions/preact-mark-view.ts +93 -0
  84. package/src/extensions/preact-node-view.ts +93 -0
  85. package/src/hooks/use-doc-change.ts +24 -0
  86. package/src/hooks/use-editor-derived-value.ts +81 -0
  87. package/src/hooks/use-editor-extension.ts +24 -0
  88. package/src/hooks/use-editor.ts +57 -0
  89. package/src/hooks/use-extension.ts +41 -0
  90. package/src/hooks/use-keymap.ts +15 -0
  91. package/src/hooks/use-priority-extension.ts +18 -0
  92. package/src/hooks/use-state-update.ts +24 -0
  93. package/src/index.ts +32 -0
  94. package/src/types.ts +16 -0
@@ -14,4 +14,5 @@ const TooltipRoot = createComponent("prosekit-tooltip-root", "TooltipRoot", Obje
14
14
  const TooltipTrigger = createComponent("prosekit-tooltip-trigger", "TooltipTrigger", Object.keys(tooltipTriggerProps), Object.keys(tooltipTriggerEvents));
15
15
 
16
16
  //#endregion
17
- export { TooltipContent, TooltipRoot, TooltipTrigger };
17
+ export { TooltipContent, TooltipRoot, TooltipTrigger };
18
+ //# sourceMappingURL=prosekit-preact-tooltip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prosekit-preact-tooltip.js","names":["TooltipContent: ForwardRefExoticComponent<\n Partial<TooltipContentProps> &\n RefAttributes<TooltipContentElement> &\n HTMLAttributes<TooltipContentElement>\n>","TooltipRoot: ForwardRefExoticComponent<\n Partial<TooltipRootProps> &\n RefAttributes<TooltipRootElement> &\n HTMLAttributes<TooltipRootElement>\n>","TooltipTrigger: ForwardRefExoticComponent<\n Partial<TooltipTriggerProps> &\n RefAttributes<TooltipTriggerElement> &\n HTMLAttributes<TooltipTriggerElement>\n>"],"sources":["../src/components/tooltip/tooltip-content.gen.ts","../src/components/tooltip/tooltip-root.gen.ts","../src/components/tooltip/tooltip-trigger.gen.ts"],"sourcesContent":["import {\n type TooltipContentElement,\n type TooltipContentProps as Props,\n type TooltipContentEvents as Events,\n tooltipContentProps,\n tooltipContentEvents,\n} from '@prosekit/web/tooltip'\nimport type {\n ForwardRefExoticComponent,\n HTMLAttributes,\n RefAttributes,\n} from 'preact/compat'\n\nimport { createComponent } from '../create-component'\nimport type { CreateProps } from '../create-props'\n\n/**\n * Props for the {@link TooltipContent} component.\n */\nexport interface TooltipContentProps extends Partial<CreateProps<Props, Events>> {}\n \nexport const TooltipContent: ForwardRefExoticComponent<\n Partial<TooltipContentProps> &\n RefAttributes<TooltipContentElement> &\n HTMLAttributes<TooltipContentElement>\n> = createComponent<\n TooltipContentProps, \n TooltipContentElement\n>(\n 'prosekit-tooltip-content',\n 'TooltipContent',\n Object.keys(tooltipContentProps),\n Object.keys(tooltipContentEvents),\n)\n","import {\n type TooltipRootElement,\n type TooltipRootProps as Props,\n type TooltipRootEvents as Events,\n tooltipRootProps,\n tooltipRootEvents,\n} from '@prosekit/web/tooltip'\nimport type {\n ForwardRefExoticComponent,\n HTMLAttributes,\n RefAttributes,\n} from 'preact/compat'\n\nimport { createComponent } from '../create-component'\nimport type { CreateProps } from '../create-props'\n\n/**\n * Props for the {@link TooltipRoot} component.\n */\nexport interface TooltipRootProps extends Partial<CreateProps<Props, Events>> {}\n \nexport const TooltipRoot: ForwardRefExoticComponent<\n Partial<TooltipRootProps> &\n RefAttributes<TooltipRootElement> &\n HTMLAttributes<TooltipRootElement>\n> = createComponent<\n TooltipRootProps, \n TooltipRootElement\n>(\n 'prosekit-tooltip-root',\n 'TooltipRoot',\n Object.keys(tooltipRootProps),\n Object.keys(tooltipRootEvents),\n)\n","import {\n type TooltipTriggerElement,\n type TooltipTriggerProps as Props,\n type TooltipTriggerEvents as Events,\n tooltipTriggerProps,\n tooltipTriggerEvents,\n} from '@prosekit/web/tooltip'\nimport type {\n ForwardRefExoticComponent,\n HTMLAttributes,\n RefAttributes,\n} from 'preact/compat'\n\nimport { createComponent } from '../create-component'\nimport type { CreateProps } from '../create-props'\n\n/**\n * Props for the {@link TooltipTrigger} component.\n */\nexport interface TooltipTriggerProps extends Partial<CreateProps<Props, Events>> {}\n \nexport const TooltipTrigger: ForwardRefExoticComponent<\n Partial<TooltipTriggerProps> &\n RefAttributes<TooltipTriggerElement> &\n HTMLAttributes<TooltipTriggerElement>\n> = createComponent<\n TooltipTriggerProps, \n TooltipTriggerElement\n>(\n 'prosekit-tooltip-trigger',\n 'TooltipTrigger',\n Object.keys(tooltipTriggerProps),\n Object.keys(tooltipTriggerEvents),\n)\n"],"mappings":";;;;;AAqBA,MAAaA,iBAIT,gBAIF,4BACA,kBACA,OAAO,KAAK,oBAAoB,EAChC,OAAO,KAAK,qBAAqB,CAClC;;;;ACZD,MAAaC,cAIT,gBAIF,yBACA,eACA,OAAO,KAAK,iBAAiB,EAC7B,OAAO,KAAK,kBAAkB,CAC/B;;;;ACZD,MAAaC,iBAIT,gBAIF,4BACA,kBACA,OAAO,KAAK,oBAAoB,EAChC,OAAO,KAAK,qBAAqB,CAClC"}
@@ -1,5 +1,7 @@
1
+ import { MarkViewContext, NodeViewContext } from "@prosemirror-adapter/preact";
1
2
  import { ComponentChildren, ComponentType } from "preact";
2
3
  import { Editor, Extension, Keymap, Priority } from "@prosekit/core";
4
+ import { CoreMarkViewUserOptions, CoreNodeViewUserOptions } from "@prosemirror-adapter/core";
3
5
  import { ProseMirrorNode } from "@prosekit/pm/model";
4
6
  import { EditorState } from "@prosekit/pm/state";
5
7
 
@@ -9,77 +11,165 @@ interface ProseKitProps {
9
11
  children?: ComponentChildren;
10
12
  }
11
13
  /**
12
- * The root component for a ProseKit editor.
13
- *
14
- * @public
15
- */
14
+ * The root component for a ProseKit editor.
15
+ *
16
+ * @public
17
+ */
16
18
  declare const ProseKit: ComponentType<ProseKitProps>;
17
19
  //#endregion
20
+ //#region src/extensions/preact-mark-view.d.ts
21
+ /**
22
+ * @public
23
+ */
24
+ interface PreactMarkViewProps extends MarkViewContext {}
25
+ /**
26
+ * @public
27
+ */
28
+ type PreactMarkViewComponent = ComponentType<PreactMarkViewProps>;
29
+ /**
30
+ * Options for {@link definePreactMarkView}.
31
+ *
32
+ * @public
33
+ */
34
+ interface PreactMarkViewOptions extends CoreMarkViewUserOptions<PreactMarkViewComponent> {
35
+ /**
36
+ * The name of the mark type.
37
+ */
38
+ name: string;
39
+ }
40
+ /**
41
+ * Defines a mark view using a Preact component.
42
+ *
43
+ * @public
44
+ */
45
+ declare function definePreactMarkView(options: PreactMarkViewOptions): Extension;
46
+ //#endregion
47
+ //#region src/extensions/preact-node-view.d.ts
48
+ /**
49
+ * @public
50
+ */
51
+ interface PreactNodeViewProps extends NodeViewContext {}
52
+ /**
53
+ * @public
54
+ */
55
+ type PreactNodeViewComponent = ComponentType<PreactNodeViewProps>;
56
+ /**
57
+ * Options for {@link definePreactNodeView}.
58
+ *
59
+ * @public
60
+ */
61
+ interface PreactNodeViewOptions extends CoreNodeViewUserOptions<PreactNodeViewComponent> {
62
+ /**
63
+ * The name of the node type.
64
+ */
65
+ name: string;
66
+ }
67
+ /**
68
+ * Defines a node view using a Preact component.
69
+ *
70
+ * @public
71
+ */
72
+ declare function definePreactNodeView(options: PreactNodeViewOptions): Extension;
73
+ //#endregion
18
74
  //#region src/hooks/use-extension.d.ts
19
75
  interface UseExtensionOptions {
20
76
  /**
21
- * The editor to add the extension to. If not provided, it will use the
22
- * editor from the nearest `ProseKit` component.
23
- */
77
+ * The editor to add the extension to. If not provided, it will use the
78
+ * editor from the nearest `ProseKit` component.
79
+ */
24
80
  editor?: Editor;
25
81
  /**
26
- * Optional priority to add the extension with.
27
- */
82
+ * Optional priority to add the extension with.
83
+ */
28
84
  priority?: Priority;
29
85
  }
30
86
  /**
31
- * Add an extension to the editor.
32
- */
33
- declare function useExtension(extension: Extension | null, options?: UseExtensionOptions): void;
87
+ * Add an extension to the editor.
88
+ */
89
+ declare function useExtension(
90
+ /**
91
+ * The extension to add to the editor. If it changes, the previous
92
+ * extension will be removed and the new one (if not null) will be added.
93
+ */
94
+ extension: Extension | null, options?: UseExtensionOptions): void;
34
95
  //#endregion
35
96
  //#region src/hooks/use-doc-change.d.ts
36
97
  /**
37
- * Calls the given handler whenever the editor document changes.
38
- *
39
- * @public
40
- */
98
+ * Calls the given handler whenever the editor document changes.
99
+ *
100
+ * @public
101
+ */
41
102
  declare function useDocChange(handler: (doc: ProseMirrorNode) => void, options?: UseExtensionOptions): void;
42
103
  //#endregion
43
104
  //#region src/hooks/use-editor.d.ts
44
105
  /**
45
- * Retrieves the editor instance from the nearest ProseKit component.
46
- *
47
- * @public
48
- */
106
+ * Retrieves the editor instance from the nearest ProseKit component.
107
+ *
108
+ * @public
109
+ */
49
110
  declare function useEditor<E extends Extension = any>(options?: {
50
111
  /**
51
- * Whether to update the component when the editor is mounted or editor state
52
- * is updated.
53
- *
54
- * @default false
55
- */
112
+ * Whether to update the component when the editor is mounted or editor state
113
+ * is updated.
114
+ *
115
+ * @default false
116
+ */
56
117
  update?: boolean;
57
118
  }): Editor<E>;
58
119
  //#endregion
120
+ //#region src/hooks/use-editor-derived-value.d.ts
121
+ interface UseEditorDerivedOptions<E extends Extension = any> {
122
+ /**
123
+ * The editor to add the extension to. If not provided, it will use the
124
+ * editor from the nearest `ProseKit` component.
125
+ */
126
+ editor?: Editor<E>;
127
+ }
128
+ /**
129
+ * A hook that runs a function to derive a value from the editor instance after
130
+ * editor state changes.
131
+ *
132
+ * This is useful when you need to render something based on the editor state,
133
+ * for example, whether the selected text is wrapped in an italic mark.
134
+ *
135
+ * @public
136
+ */
137
+ declare function useEditorDerivedValue<E extends Extension, Derived>(
138
+ /**
139
+ * A function that receives the editor instance and returns a derived value.
140
+ *
141
+ * It will be called whenever the editor's document state changes, or when it
142
+ * mounts.
143
+ *
144
+ * This function should be memoized.
145
+ */
146
+ derive: (editor: Editor<E>) => Derived, options?: UseEditorDerivedOptions<E>): Derived;
147
+ //#endregion
59
148
  //#region src/hooks/use-keymap.d.ts
60
149
  declare function useKeymap(keymap: Keymap, options?: UseExtensionOptions): void;
61
150
  //#endregion
62
151
  //#region src/hooks/use-state-update.d.ts
63
152
  /**
64
- * Calls the given handler whenever the editor state changes.
65
- *
66
- * @public
67
- */
153
+ * Calls the given handler whenever the editor state changes.
154
+ *
155
+ * @public
156
+ */
68
157
  declare function useStateUpdate(handler: (state: EditorState) => void, options?: UseExtensionOptions): void;
69
158
  //#endregion
70
159
  //#region src/types.d.ts
71
160
  /**
72
- * @internal
73
- */
161
+ * @internal
162
+ */
74
163
  type PropsWithClass<P = unknown> = P & {
75
164
  class?: string | undefined;
76
165
  className?: string | undefined;
77
166
  };
78
167
  /**
79
- * @internal
80
- */
168
+ * @internal
169
+ */
81
170
  type PropsWithChildren<P = unknown> = P & {
82
171
  children?: ComponentChildren | undefined;
83
172
  };
84
173
  //#endregion
85
- export { type PropsWithChildren, type PropsWithClass, ProseKit, type ProseKitProps, type UseExtensionOptions, useDocChange, useEditor, useExtension, useKeymap, useStateUpdate };
174
+ export { type PreactMarkViewComponent, type PreactMarkViewOptions, type PreactMarkViewProps, type PreactNodeViewComponent, type PreactNodeViewOptions, type PreactNodeViewProps, type PropsWithChildren, type PropsWithClass, ProseKit, type ProseKitProps, type UseEditorDerivedOptions, type UseExtensionOptions, definePreactMarkView, definePreactNodeView, useDocChange, useEditor, useEditorDerivedValue, useExtension, useKeymap, useStateUpdate };
175
+ //# sourceMappingURL=prosekit-preact.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prosekit-preact.d.ts","names":[],"sources":["../src/components/prosekit.ts","../src/extensions/preact-mark-view.ts","../src/extensions/preact-node-view.ts","../src/hooks/use-extension.ts","../src/hooks/use-doc-change.ts","../src/hooks/use-editor.ts","../src/hooks/use-editor-derived-value.ts","../src/hooks/use-keymap.ts","../src/hooks/use-state-update.ts","../src/types.ts"],"sourcesContent":[],"mappings":";;;;;;;;UAYiB,aAAA;UACP;aACG;;;;AAFb;;;AAEa,cAQA,QARA,EAQU,aARV,CAQwB,aARxB,CAAA;;;;;;UCWI,mBAAA,SAA4B,iBDb7C;;;;AAE8B,KCgBlB,uBAAA,GAA0B,aDhBR,CCgBsB,mBDhBtB,CAAA;AAQ9B;;;;;UCeiB,qBAAA,SAA8B,wBAAwB;;;AAZvE;EAKY,IAAA,EAAA,MAAA;;;;;;AAwCZ;AAAoC,iBAApB,oBAAA,CAAoB,OAAA,EAAU,qBAAV,CAAA,EAAkC,SAAlC;;;;;;UC7CnB,mBAAA,SAA4B,iBFb7C;;;;AAE8B,KEgBlB,uBAAA,GAA0B,aFhBR,CEgBsB,mBFhBtB,CAAA;AAQ9B;;;;;UEeiB,qBAAA,SAA8B,wBAAwB;;;ADZvE;EAKY,IAAA,EAAA,MAAA;;;;;;AAwCZ;AAAoC,iBCApB,oBAAA,CDAoB,OAAA,ECAU,qBDAV,CAAA,ECAkC,SDAlC;;;UE3DnB,mBAAA;;;;;WAKN;;AHJX;;UACU,CAAA,EGQG,QHRH;;;AASV;;AAAqC,iBGKrB,YAAA;;;;;WAKH,4BACD;;;;;;;;iBCnBI,YAAA,gBACC,oCACL;;;;;;;;iBCII,oBAAoB,wBLgBnC;;AAxBD;;;;;EAUa,MAAA,CAAA,EAAA,OAcZ;CAAA,CAAA,EKRG,MLQH,CKRU,CLQV,CAAA;;;UMvBgB,kCAAkC;;;;;WAKxC,OAAO;;ANNlB;;;;;AAUA;;;;AAAoC,iBMQpB,qBNRoB,CAAA,UMQY,SNRZ,EAAA,OAAA,CAAA;;;;ACGpC;AAKA;;;;MAAmD,EAAA,CAAA,MAAA,EKShC,MLTgC,CKSzB,CLTyB,CAAA,EAAA,GKSlB,OLTkB,EAAA,OAAA,CAAA,EKUvC,uBLVuC,CKUf,CLVe,CAAA,CAAA,EKWhD,OLXgD;;;iBMnBnC,SAAA,SAAkB,kBAAkB;;;;;;;;iBCGpC,cAAA,kBACG,gCACP;;;;;;KCXA,8BAA8B;;;;ATO1C;;;AAEa,KSDD,iBTCC,CAAA,IAAA,OAAA,CAAA,GSDgC,CTChC,GAAA;EAAiB,QAAA,CAAA,ESAjB,iBTAiB,GAAA,SAAA;AAQ9B,CAAA"}
@@ -1,23 +1,10 @@
1
1
  import { EditorContextProvider, useEditorContext } from "./editor-context-imq7MdJr.js";
2
+ import { ProsemirrorAdapterProvider, useMarkViewContext, useMarkViewFactory, useNodeViewContext, useNodeViewFactory } from "@prosemirror-adapter/preact";
2
3
  import { h } from "preact";
3
4
  import { useEffect, useMemo, useReducer } from "preact/hooks";
4
- import { EditorNotFoundError, ProseKitError, defineDocChangeHandler, defineKeymap, defineMountHandler, defineUpdateHandler, union, withPriority } from "@prosekit/core";
5
+ import { EditorNotFoundError, ProseKitError, defineDocChangeHandler, defineKeymap, defineMarkViewComponent, defineMarkViewFactory, defineMountHandler, defineNodeViewComponent, defineNodeViewFactory, defineUpdateHandler, union, withPriority } from "@prosekit/core";
6
+ import { useSyncExternalStore } from "preact/compat";
5
7
 
6
- //#region src/components/prosekit.ts
7
- /**
8
- * The root component for a ProseKit editor.
9
- *
10
- * @public
11
- */
12
- const ProseKit = (props) => {
13
- const { editor, children } = props;
14
- return h(EditorContextProvider, {
15
- value: editor,
16
- children
17
- });
18
- };
19
-
20
- //#endregion
21
8
  //#region src/hooks/use-editor-extension.ts
22
9
  /**
23
10
  * @internal
@@ -50,6 +37,94 @@ function useExtension(extension, options) {
50
37
  useEditorExtension(options?.editor || editorContext, usePriorityExtension(extension, options?.priority));
51
38
  }
52
39
 
40
+ //#endregion
41
+ //#region src/extensions/preact-mark-view.ts
42
+ function withMarkViewProps(component) {
43
+ return function MarkViewPropsWrapper() {
44
+ return h(component, useMarkViewContext());
45
+ };
46
+ }
47
+ /**
48
+ * @internal
49
+ */
50
+ const PreactMarkViewConsumer = () => {
51
+ const markViewFactory = useMarkViewFactory();
52
+ useExtension(useMemo(() => definePreactMarkViewFactory(markViewFactory), [markViewFactory]));
53
+ return null;
54
+ };
55
+ /**
56
+ * Defines a mark view using a Preact component.
57
+ *
58
+ * @public
59
+ */
60
+ function definePreactMarkView(options) {
61
+ const { name, component,...userOptions } = options;
62
+ return defineMarkViewComponent({
63
+ group: "preact",
64
+ name,
65
+ args: {
66
+ ...userOptions,
67
+ component: withMarkViewProps(component)
68
+ }
69
+ });
70
+ }
71
+ function definePreactMarkViewFactory(factory) {
72
+ return defineMarkViewFactory({
73
+ group: "preact",
74
+ factory
75
+ });
76
+ }
77
+
78
+ //#endregion
79
+ //#region src/extensions/preact-node-view.ts
80
+ function withNodeViewProps(component) {
81
+ return function NodeViewPropsWrapper() {
82
+ return h(component, useNodeViewContext());
83
+ };
84
+ }
85
+ /**
86
+ * @internal
87
+ */
88
+ const PreactNodeViewConsumer = () => {
89
+ const nodeViewFactory = useNodeViewFactory();
90
+ useExtension(useMemo(() => definePreactNodeViewFactory(nodeViewFactory), [nodeViewFactory]));
91
+ return null;
92
+ };
93
+ /**
94
+ * Defines a node view using a Preact component.
95
+ *
96
+ * @public
97
+ */
98
+ function definePreactNodeView(options) {
99
+ const { name, component,...userOptions } = options;
100
+ return defineNodeViewComponent({
101
+ group: "preact",
102
+ name,
103
+ args: {
104
+ ...userOptions,
105
+ component: withNodeViewProps(component)
106
+ }
107
+ });
108
+ }
109
+ function definePreactNodeViewFactory(factory) {
110
+ return defineNodeViewFactory({
111
+ group: "preact",
112
+ factory
113
+ });
114
+ }
115
+
116
+ //#endregion
117
+ //#region src/components/prosekit.ts
118
+ /**
119
+ * The root component for a ProseKit editor.
120
+ *
121
+ * @public
122
+ */
123
+ const ProseKit = (props) => {
124
+ const { editor, children } = props;
125
+ return h(ProsemirrorAdapterProvider, null, h(EditorContextProvider, { value: editor }, h(PreactNodeViewConsumer, null), h(PreactMarkViewConsumer, null), children));
126
+ };
127
+
53
128
  //#endregion
54
129
  //#region src/hooks/use-doc-change.ts
55
130
  /**
@@ -58,8 +133,7 @@ function useExtension(extension, options) {
58
133
  * @public
59
134
  */
60
135
  function useDocChange(handler, options) {
61
- const extension = useMemo(() => defineDocChangeHandler((view) => handler(view.state.doc)), [handler]);
62
- useExtension(extension, options);
136
+ useExtension(useMemo(() => defineDocChangeHandler((view) => handler(view.state.doc)), [handler]), options);
63
137
  }
64
138
 
65
139
  //#endregion
@@ -91,11 +165,51 @@ function useForceUpdate() {
91
165
  return dispatch;
92
166
  }
93
167
 
168
+ //#endregion
169
+ //#region src/hooks/use-editor-derived-value.ts
170
+ /**
171
+ * A hook that runs a function to derive a value from the editor instance after
172
+ * editor state changes.
173
+ *
174
+ * This is useful when you need to render something based on the editor state,
175
+ * for example, whether the selected text is wrapped in an italic mark.
176
+ *
177
+ * @public
178
+ */
179
+ function useEditorDerivedValue(derive, options) {
180
+ const editorContext = useEditorContext();
181
+ const editor = options?.editor ?? editorContext;
182
+ if (!editor) throw new EditorNotFoundError();
183
+ const [subscribe, getSnapshot] = useMemo(() => {
184
+ return createEditorStore(editor, derive);
185
+ }, [editor, derive]);
186
+ return useSyncExternalStore(subscribe, getSnapshot);
187
+ }
188
+ function createEditorStore(editor, derive) {
189
+ let dirty = true;
190
+ let derived;
191
+ const subscribe = (onChange) => {
192
+ const handleChange = () => {
193
+ dirty = true;
194
+ onChange();
195
+ };
196
+ const extension = union(defineUpdateHandler(handleChange), defineMountHandler(handleChange));
197
+ return editor.use(extension);
198
+ };
199
+ const getSnapshot = () => {
200
+ if (dirty) {
201
+ dirty = false;
202
+ derived = derive(editor);
203
+ }
204
+ return derived;
205
+ };
206
+ return [subscribe, getSnapshot];
207
+ }
208
+
94
209
  //#endregion
95
210
  //#region src/hooks/use-keymap.ts
96
211
  function useKeymap(keymap, options) {
97
- const extension = useMemo(() => defineKeymap(keymap), [keymap]);
98
- useExtension(extension, options);
212
+ useExtension(useMemo(() => defineKeymap(keymap), [keymap]), options);
99
213
  }
100
214
 
101
215
  //#endregion
@@ -106,9 +220,9 @@ function useKeymap(keymap, options) {
106
220
  * @public
107
221
  */
108
222
  function useStateUpdate(handler, options) {
109
- const extension = useMemo(() => defineUpdateHandler((view) => handler(view.state)), [handler]);
110
- useExtension(extension, options);
223
+ useExtension(useMemo(() => defineUpdateHandler((view) => handler(view.state)), [handler]), options);
111
224
  }
112
225
 
113
226
  //#endregion
114
- export { ProseKit, useDocChange, useEditor, useExtension, useKeymap, useStateUpdate };
227
+ export { ProseKit, definePreactMarkView, definePreactNodeView, useDocChange, useEditor, useEditorDerivedValue, useExtension, useKeymap, useStateUpdate };
228
+ //# sourceMappingURL=prosekit-preact.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prosekit-preact.js","names":["PreactMarkViewConsumer: FunctionComponent","PreactNodeViewConsumer: FunctionComponent","ProseKit: ComponentType<ProseKitProps>","derived: Derived"],"sources":["../src/hooks/use-editor-extension.ts","../src/hooks/use-priority-extension.ts","../src/hooks/use-extension.ts","../src/extensions/preact-mark-view.ts","../src/extensions/preact-node-view.ts","../src/components/prosekit.ts","../src/hooks/use-doc-change.ts","../src/hooks/use-editor.ts","../src/hooks/use-editor-derived-value.ts","../src/hooks/use-keymap.ts","../src/hooks/use-state-update.ts"],"sourcesContent":["import {\n EditorNotFoundError,\n type Editor,\n type Extension,\n} from '@prosekit/core'\nimport { useEffect } from 'preact/hooks'\n\n/**\n * @internal\n */\nexport function useEditorExtension(\n editor: Editor | null | undefined,\n extension: Extension | null,\n): void {\n if (!editor) {\n throw new EditorNotFoundError()\n }\n\n useEffect(() => {\n if (extension) {\n return editor.use(extension)\n }\n }, [editor, extension])\n}\n","import {\n withPriority,\n type Extension,\n type Priority,\n} from '@prosekit/core'\nimport { useMemo } from 'preact/hooks'\n\n/**\n * @internal\n */\nexport function usePriorityExtension<T extends Extension = Extension>(\n extension: T | null,\n priority?: Priority | null,\n): T | null {\n return useMemo(() => {\n return extension && priority ? withPriority(extension, priority) : extension\n }, [extension, priority])\n}\n","import type {\n Editor,\n Extension,\n Priority,\n} from '@prosekit/core'\n\nimport { useEditorContext } from '../contexts/editor-context'\n\nimport { useEditorExtension } from './use-editor-extension'\nimport { usePriorityExtension } from './use-priority-extension'\n\nexport interface UseExtensionOptions {\n /**\n * The editor to add the extension to. If not provided, it will use the\n * editor from the nearest `ProseKit` component.\n */\n editor?: Editor\n\n /**\n * Optional priority to add the extension with.\n */\n priority?: Priority\n}\n\n/**\n * Add an extension to the editor.\n */\nexport function useExtension(\n /**\n * The extension to add to the editor. If it changes, the previous\n * extension will be removed and the new one (if not null) will be added.\n */\n extension: Extension | null,\n options?: UseExtensionOptions,\n): void {\n const editorContext = useEditorContext()\n useEditorExtension(\n options?.editor || editorContext,\n usePriorityExtension(extension, options?.priority),\n )\n}\n","import {\n defineMarkViewComponent,\n defineMarkViewFactory,\n type Extension,\n} from '@prosekit/core'\nimport type { MarkViewConstructor } from '@prosekit/pm/view'\nimport type { CoreMarkViewUserOptions } from '@prosemirror-adapter/core'\nimport {\n useMarkViewContext,\n useMarkViewFactory,\n type MarkViewContext,\n type PreactMarkViewUserOptions,\n} from '@prosemirror-adapter/preact'\nimport {\n h,\n type ComponentType,\n type FunctionComponent,\n} from 'preact'\nimport { useMemo } from 'preact/hooks'\n\nimport { useExtension } from '../hooks/use-extension'\n\n/**\n * @public\n */\nexport interface PreactMarkViewProps extends MarkViewContext {}\n\n/**\n * @public\n */\nexport type PreactMarkViewComponent = ComponentType<PreactMarkViewProps>\n\n/**\n * Options for {@link definePreactMarkView}.\n *\n * @public\n */\nexport interface PreactMarkViewOptions extends CoreMarkViewUserOptions<PreactMarkViewComponent> {\n /**\n * The name of the mark type.\n */\n name: string\n}\n\nfunction withMarkViewProps(component: PreactMarkViewComponent) {\n return function MarkViewPropsWrapper() {\n const props: PreactMarkViewProps = useMarkViewContext()\n return h(component, props)\n }\n}\n\n/**\n * @internal\n */\nexport const PreactMarkViewConsumer: FunctionComponent = () => {\n const markViewFactory = useMarkViewFactory()\n const extension = useMemo(\n () => definePreactMarkViewFactory(markViewFactory),\n [markViewFactory],\n )\n useExtension(extension)\n\n return null\n}\n\n/**\n * Defines a mark view using a Preact component.\n *\n * @public\n */\nexport function definePreactMarkView(options: PreactMarkViewOptions): Extension {\n const { name, component, ...userOptions } = options\n\n const args: PreactMarkViewUserOptions = {\n ...userOptions,\n component: withMarkViewProps(component),\n }\n\n return defineMarkViewComponent<PreactMarkViewUserOptions>({\n group: 'preact',\n name,\n args,\n })\n}\n\nfunction definePreactMarkViewFactory(\n factory: (options: PreactMarkViewUserOptions) => MarkViewConstructor,\n) {\n return defineMarkViewFactory<PreactMarkViewUserOptions>({\n group: 'preact',\n factory,\n })\n}\n","import {\n defineNodeViewComponent,\n defineNodeViewFactory,\n type Extension,\n} from '@prosekit/core'\nimport type { NodeViewConstructor } from '@prosekit/pm/view'\nimport type { CoreNodeViewUserOptions } from '@prosemirror-adapter/core'\nimport {\n useNodeViewContext,\n useNodeViewFactory,\n type NodeViewContext,\n type PreactNodeViewUserOptions,\n} from '@prosemirror-adapter/preact'\nimport {\n h,\n type ComponentType,\n type FunctionComponent,\n} from 'preact'\nimport { useMemo } from 'preact/hooks'\n\nimport { useExtension } from '../hooks/use-extension'\n\n/**\n * @public\n */\nexport interface PreactNodeViewProps extends NodeViewContext {}\n\n/**\n * @public\n */\nexport type PreactNodeViewComponent = ComponentType<PreactNodeViewProps>\n\n/**\n * Options for {@link definePreactNodeView}.\n *\n * @public\n */\nexport interface PreactNodeViewOptions extends CoreNodeViewUserOptions<PreactNodeViewComponent> {\n /**\n * The name of the node type.\n */\n name: string\n}\n\nfunction withNodeViewProps(component: PreactNodeViewComponent) {\n return function NodeViewPropsWrapper() {\n const props: PreactNodeViewProps = useNodeViewContext()\n return h(component, props)\n }\n}\n\n/**\n * @internal\n */\nexport const PreactNodeViewConsumer: FunctionComponent = () => {\n const nodeViewFactory = useNodeViewFactory()\n const extension = useMemo(\n () => definePreactNodeViewFactory(nodeViewFactory),\n [nodeViewFactory],\n )\n useExtension(extension)\n\n return null\n}\n\n/**\n * Defines a node view using a Preact component.\n *\n * @public\n */\nexport function definePreactNodeView(options: PreactNodeViewOptions): Extension {\n const { name, component, ...userOptions } = options\n\n const args: PreactNodeViewUserOptions = {\n ...userOptions,\n component: withNodeViewProps(component),\n }\n\n return defineNodeViewComponent<PreactNodeViewUserOptions>({\n group: 'preact',\n name,\n args,\n })\n}\n\nfunction definePreactNodeViewFactory(\n factory: (options: PreactNodeViewUserOptions) => NodeViewConstructor,\n) {\n return defineNodeViewFactory<PreactNodeViewUserOptions>({\n group: 'preact',\n factory,\n })\n}\n","import type { Editor } from '@prosekit/core'\nimport { ProsemirrorAdapterProvider } from '@prosemirror-adapter/preact'\nimport {\n h,\n type ComponentChildren,\n type ComponentType,\n} from 'preact'\n\nimport { EditorContextProvider } from '../contexts/editor-context'\nimport { PreactMarkViewConsumer } from '../extensions/preact-mark-view'\nimport { PreactNodeViewConsumer } from '../extensions/preact-node-view'\n\nexport interface ProseKitProps {\n editor: Editor\n children?: ComponentChildren\n}\n\n/**\n * The root component for a ProseKit editor.\n *\n * @public\n */\nexport const ProseKit: ComponentType<ProseKitProps> = (props) => {\n const { editor, children } = props\n\n return h(\n ProsemirrorAdapterProvider,\n null,\n h(\n EditorContextProvider,\n { value: editor },\n h(PreactNodeViewConsumer, null),\n h(PreactMarkViewConsumer, null),\n children,\n ),\n )\n}\n","import { defineDocChangeHandler } from '@prosekit/core'\nimport type { ProseMirrorNode } from '@prosekit/pm/model'\nimport { useMemo } from 'preact/hooks'\n\nimport {\n useExtension,\n type UseExtensionOptions,\n} from './use-extension'\n\n/**\n * Calls the given handler whenever the editor document changes.\n *\n * @public\n */\nexport function useDocChange(\n handler: (doc: ProseMirrorNode) => void,\n options?: UseExtensionOptions,\n): void {\n const extension = useMemo(\n () => defineDocChangeHandler((view) => handler(view.state.doc)),\n [handler],\n )\n useExtension(extension, options)\n}\n","import {\n defineMountHandler,\n defineUpdateHandler,\n ProseKitError,\n union,\n type Editor,\n type Extension,\n} from '@prosekit/core'\nimport {\n useEffect,\n useReducer,\n} from 'preact/hooks'\n\nimport { useEditorContext } from '../contexts/editor-context'\n\n/**\n * Retrieves the editor instance from the nearest ProseKit component.\n *\n * @public\n */\nexport function useEditor<E extends Extension = any>(options?: {\n /**\n * Whether to update the component when the editor is mounted or editor state\n * is updated.\n *\n * @default false\n */\n update?: boolean\n}): Editor<E> {\n const update = options?.update ?? false\n\n const editor = useEditorContext<E>()\n if (!editor) {\n throw new ProseKitError(\n 'useEditor must be used within the ProseKit component',\n )\n }\n\n const forceUpdate = useForceUpdate()\n\n useEffect(() => {\n if (update) {\n const extension = union(\n defineMountHandler(forceUpdate),\n defineUpdateHandler(forceUpdate),\n )\n return editor.use(extension)\n }\n }, [editor, update, forceUpdate])\n\n return editor\n}\n\nfunction useForceUpdate() {\n const [, dispatch] = useReducer((x: number) => x + 1, 0)\n return dispatch\n}\n","import {\n defineMountHandler,\n defineUpdateHandler,\n EditorNotFoundError,\n union,\n type Editor,\n type Extension,\n} from '@prosekit/core'\nimport { useSyncExternalStore } from 'preact/compat'\nimport { useMemo } from 'preact/hooks'\n\nimport { useEditorContext } from '../contexts/editor-context'\n\nexport interface UseEditorDerivedOptions<E extends Extension = any> {\n /**\n * The editor to add the extension to. If not provided, it will use the\n * editor from the nearest `ProseKit` component.\n */\n editor?: Editor<E>\n}\n\n/**\n * A hook that runs a function to derive a value from the editor instance after\n * editor state changes.\n *\n * This is useful when you need to render something based on the editor state,\n * for example, whether the selected text is wrapped in an italic mark.\n *\n * @public\n */\nexport function useEditorDerivedValue<E extends Extension, Derived>(\n /**\n * A function that receives the editor instance and returns a derived value.\n *\n * It will be called whenever the editor's document state changes, or when it\n * mounts.\n *\n * This function should be memoized.\n */\n derive: (editor: Editor<E>) => Derived,\n options?: UseEditorDerivedOptions<E>,\n): Derived {\n const editorContext = useEditorContext<E>()\n const editor = options?.editor ?? editorContext\n if (!editor) {\n throw new EditorNotFoundError()\n }\n\n const [subscribe, getSnapshot] = useMemo(() => {\n return createEditorStore(editor, derive)\n }, [editor, derive])\n\n return useSyncExternalStore(subscribe, getSnapshot)\n}\n\nfunction createEditorStore<Derived, E extends Extension = any>(editor: Editor<E>, derive: (editor: Editor<E>) => Derived) {\n let dirty = true\n let derived: Derived\n\n const subscribe = (onChange: VoidFunction): VoidFunction => {\n const handleChange = () => {\n dirty = true\n onChange()\n }\n const extension = union(\n defineUpdateHandler(handleChange),\n defineMountHandler(handleChange),\n )\n return editor.use(extension)\n }\n\n const getSnapshot = () => {\n if (dirty) {\n dirty = false\n derived = derive(editor)\n }\n return derived\n }\n\n return [subscribe, getSnapshot] as const\n}\n","import {\n defineKeymap,\n type Keymap,\n} from '@prosekit/core'\nimport { useMemo } from 'preact/hooks'\n\nimport {\n useExtension,\n type UseExtensionOptions,\n} from './use-extension'\n\nexport function useKeymap(keymap: Keymap, options?: UseExtensionOptions): void {\n const extension = useMemo(() => defineKeymap(keymap), [keymap])\n useExtension(extension, options)\n}\n","import { defineUpdateHandler } from '@prosekit/core'\nimport type { EditorState } from '@prosekit/pm/state'\nimport { useMemo } from 'preact/hooks'\n\nimport {\n useExtension,\n type UseExtensionOptions,\n} from './use-extension'\n\n/**\n * Calls the given handler whenever the editor state changes.\n *\n * @public\n */\nexport function useStateUpdate(\n handler: (state: EditorState) => void,\n options?: UseExtensionOptions,\n): void {\n const extension = useMemo(\n () => defineUpdateHandler((view) => handler(view.state)),\n [handler],\n )\n useExtension(extension, options)\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@prosekit/preact",
3
3
  "type": "module",
4
- "version": "0.5.0",
4
+ "version": "0.6.0",
5
5
  "private": false,
6
6
  "description": "Preact components and utilities for ProseKit",
7
7
  "author": {
@@ -10,14 +10,14 @@
10
10
  },
11
11
  "license": "MIT",
12
12
  "funding": "https://github.com/sponsors/ocavue",
13
- "homepage": "https://github.com/ocavue/prosekit#readme",
13
+ "homepage": "https://github.com/prosekit/prosekit#readme",
14
14
  "repository": {
15
15
  "type": "git",
16
- "url": "git+https://github.com/ocavue/prosekit.git",
16
+ "url": "git+https://github.com/prosekit/prosekit.git",
17
17
  "directory": "packages/preact"
18
18
  },
19
19
  "bugs": {
20
- "url": "https://github.com/ocavue/prosekit/issues"
20
+ "url": "https://github.com/prosekit/prosekit/issues"
21
21
  },
22
22
  "keywords": [
23
23
  "ProseMirror"
@@ -64,12 +64,15 @@
64
64
  }
65
65
  },
66
66
  "files": [
67
- "dist"
67
+ "dist",
68
+ "src"
68
69
  ],
69
70
  "dependencies": {
70
- "@prosekit/core": "^0.8.3",
71
- "@prosekit/web": "^0.7.0",
72
- "@prosekit/pm": "^0.1.11"
71
+ "@prosemirror-adapter/core": "^0.4.5",
72
+ "@prosemirror-adapter/preact": "^0.4.5",
73
+ "@prosekit/web": "^0.7.4",
74
+ "@prosekit/core": "^0.8.4",
75
+ "@prosekit/pm": "^0.1.12"
73
76
  },
74
77
  "peerDependencies": {
75
78
  "preact": ">= 10.11.0"
@@ -80,10 +83,9 @@
80
83
  }
81
84
  },
82
85
  "devDependencies": {
83
- "preact": "^10.27.0",
84
- "tsdown": "^0.13.1",
85
- "typescript": "~5.8.3",
86
- "vitest": "^3.2.4",
86
+ "preact": "^10.27.2",
87
+ "tsdown": "^0.15.6",
88
+ "typescript": "~5.9.2",
87
89
  "@prosekit/config-tsdown": "0.0.0",
88
90
  "@prosekit/config-vitest": "0.0.0"
89
91
  },
@@ -95,12 +97,12 @@
95
97
  "prosekit-preact": "./src/index.ts",
96
98
  "prosekit-preact-autocomplete": "./src/components/autocomplete/index.gen.ts",
97
99
  "prosekit-preact-block-handle": "./src/components/block-handle/index.gen.ts",
100
+ "prosekit-preact-drop-indicator": "./src/components/drop-indicator/index.gen.ts",
98
101
  "prosekit-preact-inline-popover": "./src/components/inline-popover/index.gen.ts",
99
102
  "prosekit-preact-popover": "./src/components/popover/index.gen.ts",
100
103
  "prosekit-preact-resizable": "./src/components/resizable/index.gen.ts",
101
104
  "prosekit-preact-table-handle": "./src/components/table-handle/index.gen.ts",
102
- "prosekit-preact-tooltip": "./src/components/tooltip/index.gen.ts",
103
- "prosekit-preact-drop-indicator": "./src/components/drop-indicator/index.gen.ts"
105
+ "prosekit-preact-tooltip": "./src/components/tooltip/index.gen.ts"
104
106
  }
105
107
  },
106
108
  "scripts": {
@@ -0,0 +1,34 @@
1
+ import {
2
+ type AutocompleteEmptyElement,
3
+ type AutocompleteEmptyProps as Props,
4
+ type AutocompleteEmptyEvents as Events,
5
+ autocompleteEmptyProps,
6
+ autocompleteEmptyEvents,
7
+ } from '@prosekit/web/autocomplete'
8
+ import type {
9
+ ForwardRefExoticComponent,
10
+ HTMLAttributes,
11
+ RefAttributes,
12
+ } from 'preact/compat'
13
+
14
+ import { createComponent } from '../create-component'
15
+ import type { CreateProps } from '../create-props'
16
+
17
+ /**
18
+ * Props for the {@link AutocompleteEmpty} component.
19
+ */
20
+ export interface AutocompleteEmptyProps extends Partial<CreateProps<Props, Events>> {}
21
+
22
+ export const AutocompleteEmpty: ForwardRefExoticComponent<
23
+ Partial<AutocompleteEmptyProps> &
24
+ RefAttributes<AutocompleteEmptyElement> &
25
+ HTMLAttributes<AutocompleteEmptyElement>
26
+ > = createComponent<
27
+ AutocompleteEmptyProps,
28
+ AutocompleteEmptyElement
29
+ >(
30
+ 'prosekit-autocomplete-empty',
31
+ 'AutocompleteEmpty',
32
+ Object.keys(autocompleteEmptyProps),
33
+ Object.keys(autocompleteEmptyEvents),
34
+ )
@@ -0,0 +1,34 @@
1
+ import {
2
+ type AutocompleteItemElement,
3
+ type AutocompleteItemProps as Props,
4
+ type AutocompleteItemEvents as Events,
5
+ autocompleteItemProps,
6
+ autocompleteItemEvents,
7
+ } from '@prosekit/web/autocomplete'
8
+ import type {
9
+ ForwardRefExoticComponent,
10
+ HTMLAttributes,
11
+ RefAttributes,
12
+ } from 'preact/compat'
13
+
14
+ import { createComponent } from '../create-component'
15
+ import type { CreateProps } from '../create-props'
16
+
17
+ /**
18
+ * Props for the {@link AutocompleteItem} component.
19
+ */
20
+ export interface AutocompleteItemProps extends Partial<CreateProps<Props, Events>> {}
21
+
22
+ export const AutocompleteItem: ForwardRefExoticComponent<
23
+ Partial<AutocompleteItemProps> &
24
+ RefAttributes<AutocompleteItemElement> &
25
+ HTMLAttributes<AutocompleteItemElement>
26
+ > = createComponent<
27
+ AutocompleteItemProps,
28
+ AutocompleteItemElement
29
+ >(
30
+ 'prosekit-autocomplete-item',
31
+ 'AutocompleteItem',
32
+ Object.keys(autocompleteItemProps),
33
+ Object.keys(autocompleteItemEvents),
34
+ )
@@ -0,0 +1,34 @@
1
+ import {
2
+ type AutocompleteListElement,
3
+ type AutocompleteListProps as Props,
4
+ type AutocompleteListEvents as Events,
5
+ autocompleteListProps,
6
+ autocompleteListEvents,
7
+ } from '@prosekit/web/autocomplete'
8
+ import type {
9
+ ForwardRefExoticComponent,
10
+ HTMLAttributes,
11
+ RefAttributes,
12
+ } from 'preact/compat'
13
+
14
+ import { createComponent } from '../create-component'
15
+ import type { CreateProps } from '../create-props'
16
+
17
+ /**
18
+ * Props for the {@link AutocompleteList} component.
19
+ */
20
+ export interface AutocompleteListProps extends Partial<CreateProps<Props, Events>> {}
21
+
22
+ export const AutocompleteList: ForwardRefExoticComponent<
23
+ Partial<AutocompleteListProps> &
24
+ RefAttributes<AutocompleteListElement> &
25
+ HTMLAttributes<AutocompleteListElement>
26
+ > = createComponent<
27
+ AutocompleteListProps,
28
+ AutocompleteListElement
29
+ >(
30
+ 'prosekit-autocomplete-list',
31
+ 'AutocompleteList',
32
+ Object.keys(autocompleteListProps),
33
+ Object.keys(autocompleteListEvents),
34
+ )