@prosekit/svelte 0.0.0-next-20240715033214 → 0.0.0-next-20240715055445

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.
@@ -3,7 +3,7 @@ import { useNodeViewContext } from '@prosemirror-adapter/svelte'
3
3
  import type { SvelteNodeViewProps } from '../../node-view/types'
4
4
  import type { SvelteComponent } from 'svelte'
5
5
 
6
- export let component: SvelteComponent<SvelteNodeViewProps>
6
+ export let component: SvelteComponent<SvelteNodeViewProps> | undefined
7
7
 
8
8
  const nodeViewProps: SvelteNodeViewProps = {
9
9
  contentRef: useNodeViewContext('contentRef'),
@@ -17,4 +17,6 @@ const nodeViewProps: SvelteNodeViewProps = {
17
17
  }
18
18
  </script>
19
19
 
20
- <svelte:component this={component} {...nodeViewProps} />
20
+ {#if component}
21
+ <svelte:component this={component} {...nodeViewProps} />
22
+ {/if}
@@ -3,7 +3,7 @@ import type { SvelteNodeViewProps } from '../../node-view/types';
3
3
  import type { SvelteComponent } from 'svelte';
4
4
  declare const __propDef: {
5
5
  props: {
6
- component: SvelteComponent<SvelteNodeViewProps>;
6
+ component: SvelteComponent<SvelteNodeViewProps> | undefined;
7
7
  };
8
8
  events: {
9
9
  [evt: string]: CustomEvent<any>;
@@ -1 +1 @@
1
- {"version":3,"file":"node-view-wrapper.svelte.d.ts","sourceRoot":"","sources":["../../../../../src/components/node-view-wrapper/node-view-wrapper.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAED,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAChE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AAyB7C,QAAA,MAAM,SAAS;;mBADuC,eAAe,CAAC,mBAAmB,CAAC;;;;;;CACnC,CAAC;AACxD,MAAM,MAAM,oBAAoB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAC1D,MAAM,MAAM,qBAAqB,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAC5D,MAAM,MAAM,oBAAoB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAE1D,MAAM,CAAC,OAAO,OAAO,eAAgB,SAAQ,oBAAoB,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,oBAAoB,CAAC;CACnI"}
1
+ {"version":3,"file":"node-view-wrapper.svelte.d.ts","sourceRoot":"","sources":["../../../../../src/components/node-view-wrapper/node-view-wrapper.svelte"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAE5C;AAED,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAChE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AA2B7C,QAAA,MAAM,SAAS;;mBADuC,eAAe,CAAC,mBAAmB,CAAC,GAAG,SAAS;;;;;;CAC/C,CAAC;AACxD,MAAM,MAAM,oBAAoB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAC1D,MAAM,MAAM,qBAAqB,GAAG,OAAO,SAAS,CAAC,MAAM,CAAC;AAC5D,MAAM,MAAM,oBAAoB,GAAG,OAAO,SAAS,CAAC,KAAK,CAAC;AAE1D,MAAM,CAAC,OAAO,OAAO,eAAgB,SAAQ,oBAAoB,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,oBAAoB,CAAC;CACnI"}
@@ -1 +1 @@
1
- {"version":3,"file":"define-svelte-node-view.d.ts","sourceRoot":"","sources":["../../../../src/node-view/define-svelte-node-view.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAMxE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAEpD;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,qBAAqB,GAC7B,SAAS,CAoBX"}
1
+ {"version":3,"file":"define-svelte-node-view.d.ts","sourceRoot":"","sources":["../../../../src/node-view/define-svelte-node-view.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAUxE,OAAO,KAAK,EAA2B,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAE7E;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,qBAAqB,GAC7B,SAAS,CAaX"}
@@ -9,14 +9,7 @@ export function defineSvelteNodeView(options) {
9
9
  const { name, component, ...userOptions } = options;
10
10
  const args = {
11
11
  ...userOptions,
12
- component: class NodeViewPropsWrapper extends NodeViewWrapper {
13
- constructor(options) {
14
- super({
15
- ...options,
16
- props: { ...options.props, component },
17
- });
18
- }
19
- },
12
+ component: wrapComponent(component),
20
13
  };
21
14
  return defineNodeViewComponent({
22
15
  group: 'svelte',
@@ -24,3 +17,15 @@ export function defineSvelteNodeView(options) {
24
17
  args,
25
18
  });
26
19
  }
20
+ function wrapComponent(component) {
21
+ // `NodeViewWrapper` is an object during SSR
22
+ if (!NodeViewWrapper || typeof NodeViewWrapper !== 'function') {
23
+ return component;
24
+ }
25
+ class NodeViewPropsWrapper extends NodeViewWrapper {
26
+ constructor(options) {
27
+ super({ ...options, props: { ...options.props, component } });
28
+ }
29
+ }
30
+ return NodeViewPropsWrapper;
31
+ }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@prosekit/svelte",
3
3
  "type": "module",
4
- "version": "0.0.0-next-20240715033214",
4
+ "version": "0.0.0-next-20240715055445",
5
5
  "private": false,
6
6
  "author": {
7
7
  "name": "ocavue",
@@ -72,9 +72,9 @@
72
72
  ],
73
73
  "dependencies": {
74
74
  "@prosemirror-adapter/svelte": "^0.2.6",
75
- "@prosekit/core": "^0.0.0-next-20240715033214",
76
- "@prosekit/web": "^0.0.0-next-20240715033214",
77
- "@prosekit/pm": "^0.0.0-next-20240715033214"
75
+ "@prosekit/core": "^0.0.0-next-20240715055445",
76
+ "@prosekit/pm": "^0.0.0-next-20240715055445",
77
+ "@prosekit/web": "^0.0.0-next-20240715055445"
78
78
  },
79
79
  "peerDependencies": {
80
80
  "svelte": ">= 3.0.0"