@cnvx/nodal 0.2.1 → 0.2.3

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.
@@ -1,19 +1,32 @@
1
+ <script lang="ts" module>
2
+ export type PassthroughDiagramControllerProps = ({
3
+ eagerLoad?: boolean;
4
+ rootMargin?: string;
5
+ figureAttributes?: HTMLAttributes<HTMLElement>;
6
+ } & (
7
+ | {
8
+ scaleToFit?: boolean;
9
+ width?: never;
10
+ height?: never;
11
+ }
12
+ | {
13
+ scaleToFit?: never;
14
+ width: number;
15
+ height: number;
16
+ }
17
+ )) &
18
+ Omit<HTMLAttributes<HTMLDivElement>, "width" | "height">;
19
+ </script>
20
+
1
21
  <script lang="ts">
2
22
  import { SvelteMap } from "svelte/reactivity";
3
23
  import Diagram, {
4
24
  type DiagramNodeDef,
5
25
  type DiagramEdgeDef,
6
26
  } from "./Diagram.svelte";
7
- import {
8
- createRawSnippet,
9
- flushSync,
10
- onMount,
11
- setContext,
12
- type Snippet,
13
- } from "svelte";
27
+ import { onMount, setContext, type Snippet } from "svelte";
14
28
  import type { HTMLAttributes } from "svelte/elements";
15
29
  import PrerenderDiagram from "./PrerenderDiagram.svelte";
16
- import { browser } from "./diagram-lib.js";
17
30
 
18
31
  let {
19
32
  children,
@@ -24,31 +37,14 @@
24
37
  rootMargin = "100px", // start a bit before it enters the viewport
25
38
  figureAttributes = { inert: true, "aria-hidden": true },
26
39
  ...rest
27
- }: ({
28
- children: Snippet;
29
- eagerLoad?: boolean;
30
- rootMargin?: string;
31
- figureAttributes?: HTMLAttributes<HTMLElement>;
32
- } & (
33
- | {
34
- scaleToFit?: boolean;
35
- width?: never;
36
- height?: never;
37
- }
38
- | {
39
- scaleToFit?: never;
40
- width: number;
41
- height: number;
42
- }
43
- )) &
44
- Omit<HTMLAttributes<HTMLDivElement>, "width" | "height"> = $props();
40
+ }: PassthroughDiagramControllerProps & { children: Snippet } = $props();
45
41
 
46
42
  const nodes = new SvelteMap<string, DiagramNodeDef>();
47
43
  const layers = new SvelteMap<number, Record<string, DiagramNodeDef>>();
48
44
  setContext("layerNodeMap", () => layers);
49
45
  const edges = new SvelteMap<string, DiagramEdgeDef>();
50
46
 
51
- let containerEl: HTMLDivElement | undefined;
47
+ let containerEl: HTMLDivElement | undefined = $state();
52
48
 
53
49
  // If we're SSR (not browser), or eagerLoad is false, render immediately.
54
50
  // Otherwise wait until after load + idle + intersection.
@@ -1,7 +1,4 @@
1
- import { type Snippet } from "svelte";
2
- import type { HTMLAttributes } from "svelte/elements";
3
- type $$ComponentProps = ({
4
- children: Snippet;
1
+ export type PassthroughDiagramControllerProps = ({
5
2
  eagerLoad?: boolean;
6
3
  rootMargin?: string;
7
4
  figureAttributes?: HTMLAttributes<HTMLElement>;
@@ -14,6 +11,11 @@ type $$ComponentProps = ({
14
11
  width: number;
15
12
  height: number;
16
13
  })) & Omit<HTMLAttributes<HTMLDivElement>, "width" | "height">;
14
+ import { type Snippet } from "svelte";
15
+ import type { HTMLAttributes } from "svelte/elements";
16
+ type $$ComponentProps = PassthroughDiagramControllerProps & {
17
+ children: Snippet;
18
+ };
17
19
  declare const DiagramController: import("svelte").Component<$$ComponentProps, {}, "">;
18
20
  type DiagramController = ReturnType<typeof DiagramController>;
19
21
  export default DiagramController;
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  export { default as Diagram } from './Diagram.svelte';
2
- export { default as DiagramController } from './DiagramController.svelte';
2
+ export { default as DiagramController, type PassthroughDiagramControllerProps } from './DiagramController.svelte';
3
3
  export { default as DiagramNode } from './DiagramNode.svelte';
4
4
  export { default as PrerenderDiagram } from './PrerenderDiagram.svelte';
5
5
  export * from './diagram-lib.js';
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@cnvx/nodal",
3
3
  "private": false,
4
4
  "license": "MIT",
5
- "version": "0.2.1",
5
+ "version": "0.2.3",
6
6
  "scripts": {
7
7
  "dev": "vite dev",
8
8
  "dev-lib": "svelte-package -w",