diff --git a/README.md b/README.md
index 7f807aa1..3b825c82 100644
--- a/README.md
+++ b/README.md
@@ -30,6 +30,15 @@ cd apps/server
pnpm prisma migrate dev # this will also generate the Prisma client
```
+You can run the next example app with:
+
+```sh
+# Notes:
+# - You need to build the packages first and every time you make changes to the packages
+cd apps/next-example
+pnpm dev
+```
+
## Upgrading Dependencies
```sh
diff --git a/apps/events/package.json b/apps/events/package.json
index 5271f0c9..995a2873 100644
--- a/apps/events/package.json
+++ b/apps/events/package.json
@@ -9,8 +9,8 @@
},
"dependencies": {
"@automerge/automerge": "^2.2.9",
- "@automerge/automerge-repo": "^2.0.0-beta.2",
- "@automerge/automerge-repo-react-hooks": "^2.0.0-beta.2",
+ "@automerge/automerge-repo": "=2.0.0-beta.5",
+ "@automerge/automerge-repo-react-hooks": "=2.0.0-beta.5",
"@graphprotocol/grc-20": "^0.11.5",
"@graphprotocol/hypergraph": "workspace:*",
"@graphprotocol/hypergraph-react": "workspace:*",
@@ -51,8 +51,6 @@
"@vitejs/plugin-react": "^4.4.1",
"globals": "^16.1.0",
"tailwindcss": "^4.1.5",
- "vite-plugin-node-polyfills": "^0.23.0",
- "vite-plugin-top-level-await": "^1.5.0",
- "vite-plugin-wasm": "^3.4.1"
+ "vite-plugin-node-polyfills": "^0.23.0"
}
}
diff --git a/apps/events/vite.config.ts b/apps/events/vite.config.ts
index 11e147f3..4f09502c 100644
--- a/apps/events/vite.config.ts
+++ b/apps/events/vite.config.ts
@@ -4,14 +4,10 @@ import { TanStackRouterVite } from '@tanstack/router-plugin/vite';
import react from '@vitejs/plugin-react';
import { defineConfig } from 'vite';
import { nodePolyfills } from 'vite-plugin-node-polyfills';
-import topLevelAwait from 'vite-plugin-top-level-await';
-import wasm from 'vite-plugin-wasm';
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
- wasm(),
- topLevelAwait(),
TanStackRouterVite(),
react(),
nodePolyfills({
diff --git a/apps/next-example/.gitignore b/apps/next-example/.gitignore
new file mode 100644
index 00000000..5ef6a520
--- /dev/null
+++ b/apps/next-example/.gitignore
@@ -0,0 +1,41 @@
+# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
+
+# dependencies
+/node_modules
+/.pnp
+.pnp.*
+.yarn/*
+!.yarn/patches
+!.yarn/plugins
+!.yarn/releases
+!.yarn/versions
+
+# testing
+/coverage
+
+# next.js
+/.next/
+/out/
+
+# production
+/build
+
+# misc
+.DS_Store
+*.pem
+
+# debug
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+.pnpm-debug.log*
+
+# env files (can opt-in for committing if needed)
+.env*
+
+# vercel
+.vercel
+
+# typescript
+*.tsbuildinfo
+next-env.d.ts
diff --git a/apps/next-example/next.config.ts b/apps/next-example/next.config.ts
new file mode 100644
index 00000000..69aaf395
--- /dev/null
+++ b/apps/next-example/next.config.ts
@@ -0,0 +1,13 @@
+import type { NextConfig } from 'next';
+
+const nextConfig: NextConfig = {
+ // turbopack: {
+ // root: path.join(__dirname, '../..'),
+ // resolveAlias: {
+ // '@graphprotocol/hypergraph': path.resolve(__dirname, '../../packages/hypergraph'),
+ // '@graphprotocol/hypergraph-react': path.resolve(__dirname, '../../packages/hypergraph-react'),
+ // },
+ // },
+};
+
+export default nextConfig;
diff --git a/apps/next-example/package.json b/apps/next-example/package.json
new file mode 100644
index 00000000..f8dab2b2
--- /dev/null
+++ b/apps/next-example/package.json
@@ -0,0 +1,27 @@
+{
+ "name": "next-example",
+ "version": "0.1.0",
+ "private": true,
+ "scripts": {
+ "dev": "next dev --turbopack",
+ "build": "next build",
+ "start": "next start",
+ "lint": "next lint"
+ },
+ "type": "module",
+ "dependencies": {
+ "@graphprotocol/grc-20": "^0.11.5",
+ "@graphprotocol/hypergraph": "workspace:*",
+ "@graphprotocol/hypergraph-react": "workspace:*",
+ "@privy-io/react-auth": "^2.13.0",
+ "next": "15.3.2",
+ "react": "^19.0.0",
+ "react-dom": "^19.0.0"
+ },
+ "devDependencies": {
+ "@types/node": "^22",
+ "@types/react": "^19",
+ "@types/react-dom": "^19",
+ "typescript": "^5"
+ }
+}
diff --git a/apps/next-example/src/app/favicon.ico b/apps/next-example/src/app/favicon.ico
new file mode 100644
index 00000000..718d6fea
Binary files /dev/null and b/apps/next-example/src/app/favicon.ico differ
diff --git a/apps/next-example/src/app/globals.css b/apps/next-example/src/app/globals.css
new file mode 100644
index 00000000..e3734be1
--- /dev/null
+++ b/apps/next-example/src/app/globals.css
@@ -0,0 +1,42 @@
+:root {
+ --background: #ffffff;
+ --foreground: #171717;
+}
+
+@media (prefers-color-scheme: dark) {
+ :root {
+ --background: #0a0a0a;
+ --foreground: #ededed;
+ }
+}
+
+html,
+body {
+ max-width: 100vw;
+ overflow-x: hidden;
+}
+
+body {
+ color: var(--foreground);
+ background: var(--background);
+ font-family: Arial, Helvetica, sans-serif;
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+}
+
+* {
+ box-sizing: border-box;
+ padding: 0;
+ margin: 0;
+}
+
+a {
+ color: inherit;
+ text-decoration: none;
+}
+
+@media (prefers-color-scheme: dark) {
+ html {
+ color-scheme: dark;
+ }
+}
diff --git a/apps/next-example/src/app/layout.tsx b/apps/next-example/src/app/layout.tsx
new file mode 100644
index 00000000..f94a1c4d
--- /dev/null
+++ b/apps/next-example/src/app/layout.tsx
@@ -0,0 +1,33 @@
+import Providers from '@/components/providers';
+import type { Metadata } from 'next';
+import { Geist, Geist_Mono } from 'next/font/google';
+import './globals.css';
+
+const geistSans = Geist({
+ variable: '--font-geist-sans',
+ subsets: ['latin'],
+});
+
+const geistMono = Geist_Mono({
+ variable: '--font-geist-mono',
+ subsets: ['latin'],
+});
+
+export const metadata: Metadata = {
+ title: 'Create Next App',
+ description: 'Generated by create next app',
+};
+
+export default function RootLayout({
+ children,
+}: Readonly<{
+ children: React.ReactNode;
+}>) {
+ return (
+
+
+ {children}
+
+
+ );
+}
diff --git a/apps/next-example/src/app/page.module.css b/apps/next-example/src/app/page.module.css
new file mode 100644
index 00000000..97d555e3
--- /dev/null
+++ b/apps/next-example/src/app/page.module.css
@@ -0,0 +1,35 @@
+.page {
+ --gray-rgb: 0, 0, 0;
+ --gray-alpha-200: rgba(var(--gray-rgb), 0.08);
+ --gray-alpha-100: rgba(var(--gray-rgb), 0.05);
+
+ --button-primary-hover: #383838;
+ --button-secondary-hover: #f2f2f2;
+
+ display: grid;
+ grid-template-rows: 20px 1fr 20px;
+ align-items: center;
+ justify-items: center;
+ min-height: 100svh;
+ padding: 80px;
+ gap: 64px;
+ font-family: var(--font-geist-sans);
+}
+
+@media (prefers-color-scheme: dark) {
+ .page {
+ --gray-rgb: 255, 255, 255;
+ --gray-alpha-200: rgba(var(--gray-rgb), 0.145);
+ --gray-alpha-100: rgba(var(--gray-rgb), 0.06);
+
+ --button-primary-hover: #ccc;
+ --button-secondary-hover: #1a1a1a;
+ }
+}
+
+.main {
+ display: flex;
+ flex-direction: column;
+ gap: 32px;
+ grid-row-start: 2;
+}
diff --git a/apps/next-example/src/app/page.tsx b/apps/next-example/src/app/page.tsx
new file mode 100644
index 00000000..16c47279
--- /dev/null
+++ b/apps/next-example/src/app/page.tsx
@@ -0,0 +1,11 @@
+import { Test } from '../components/test';
+import styles from './page.module.css';
+export default function Home() {
+ return (
+
+
+
+
+
+ );
+}
diff --git a/apps/next-example/src/components/providers.tsx b/apps/next-example/src/components/providers.tsx
new file mode 100644
index 00000000..206a01ce
--- /dev/null
+++ b/apps/next-example/src/components/providers.tsx
@@ -0,0 +1,30 @@
+'use client';
+
+import { HypergraphAppProvider } from '@graphprotocol/hypergraph-react';
+import { PrivyProvider } from '@privy-io/react-auth';
+
+// recommended by https://docs.privy.io/basics/troubleshooting/react-frameworks#next-js
+export default function Providers({ children }: { children: React.ReactNode }) {
+ const storage = typeof window !== 'undefined' ? window.localStorage : (undefined as unknown as Storage);
+
+ return (
+
+ {children}
+
+ );
+}
diff --git a/apps/next-example/src/components/test.tsx b/apps/next-example/src/components/test.tsx
new file mode 100644
index 00000000..50999ff3
--- /dev/null
+++ b/apps/next-example/src/components/test.tsx
@@ -0,0 +1,5 @@
+'use client';
+
+export const Test = () => {
+ return Hello World
;
+};
diff --git a/apps/next-example/tsconfig.json b/apps/next-example/tsconfig.json
new file mode 100644
index 00000000..3a7fdeba
--- /dev/null
+++ b/apps/next-example/tsconfig.json
@@ -0,0 +1,29 @@
+{
+ "compilerOptions": {
+ "target": "ES2017",
+ "lib": ["dom", "dom.iterable", "esnext"],
+ "allowJs": true,
+ "skipLibCheck": true,
+ "strict": true,
+ "noEmit": true,
+ "esModuleInterop": true,
+ "module": "esnext",
+ "moduleResolution": "bundler",
+ "resolveJsonModule": true,
+ "isolatedModules": true,
+ "jsx": "preserve",
+ "incremental": true,
+ "plugins": [
+ {
+ "name": "next"
+ }
+ ],
+ "paths": {
+ "@/*": ["./src/*"],
+ // "@graphprotocol/hypergraph": ["../../packages/hypergraph/src"],
+ // "@graphprotocol/hypergraph-react": ["../../packages/hypergraph-react/src"]
+ }
+ },
+ "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"],
+ "exclude": ["node_modules"]
+}
diff --git a/packages/hypergraph-react/package.json b/packages/hypergraph-react/package.json
index 2bcfcbac..352436a8 100644
--- a/packages/hypergraph-react/package.json
+++ b/packages/hypergraph-react/package.json
@@ -39,8 +39,8 @@
},
"dependencies": {
"@automerge/automerge": "^2.2.9",
- "@automerge/automerge-repo": "^2.0.0-beta.2",
- "@automerge/automerge-repo-react-hooks": "^2.0.0-beta.2",
+ "@automerge/automerge-repo": "=2.0.0-beta.5",
+ "@automerge/automerge-repo-react-hooks": "=2.0.0-beta.5",
"@graphprotocol/grc-20": "^0.11.5",
"@noble/hashes": "^1.8.0",
"@tanstack/react-query": "^5.75.5",
diff --git a/packages/hypergraph-react/src/HypergraphAppContext.tsx b/packages/hypergraph-react/src/HypergraphAppContext.tsx
index 3158172d..96d75f1d 100644
--- a/packages/hypergraph-react/src/HypergraphAppContext.tsx
+++ b/packages/hypergraph-react/src/HypergraphAppContext.tsx
@@ -1,9 +1,12 @@
'use client';
-import * as automerge from '@automerge/automerge';
-import { uuid } from '@automerge/automerge';
import type { DocHandle } from '@automerge/automerge-repo';
import { RepoContext } from '@automerge/automerge-repo-react-hooks';
+import { Repo } from '@automerge/automerge-repo/slim';
+// @ts-expect-error not properly typed and exported in the automerge package
+import { automergeWasmBase64 } from '@automerge/automerge/automerge.wasm.base64.js';
+import * as automerge from '@automerge/automerge/slim';
+import { uuid } from '@automerge/automerge/slim';
import { type GeoSmartAccount, Graph } from '@graphprotocol/grc-20';
import {
Identity,
@@ -1383,6 +1386,20 @@ export function HypergraphAppProvider({
[createSpaceInboxForContext],
);
+ useEffect(() => {
+ const setupRepo = async () => {
+ await automerge.next.initializeBase64Wasm(automergeWasmBase64);
+ const newRepo = new Repo({});
+ store.send({ type: 'setRepo', repo: newRepo });
+ };
+ setupRepo();
+ }, []);
+
+ // need to wait until Automerge is initialized before we can continue to any component that might need it
+ if (repo === null) {
+ return null;
+ }
+
return (
(id);
+ const result = repo.findWithProgress(id);
current = ref.current = {
space,
repo,
id,
- handle,
+ handle: result.handle,
mapping,
};
}
diff --git a/packages/hypergraph-react/test/HypergraphAppContext.test.tsx b/packages/hypergraph-react/test/HypergraphAppContext.test.tsx
index 7e0ae54c..8d30ad72 100644
--- a/packages/hypergraph-react/test/HypergraphAppContext.test.tsx
+++ b/packages/hypergraph-react/test/HypergraphAppContext.test.tsx
@@ -30,7 +30,13 @@ describe('HypergraphAppContext', () => {
);
const { result: authenticatedResult } = renderHook(() => useHypergraphAuth(), { wrapper });
- expect(authenticatedResult.current.authenticated).toEqual(false);
- expect(authenticatedResult.current.identity).toBeNull();
+ // hook won't work until the Provider loaded automerge and then renders the children
+ expect(authenticatedResult.current).toEqual(null);
+ // after automerge is loaded, the hook will be rendered and the authenticated state will be set
+ // TODO: use something more reliable than setTimeout
+ setTimeout(() => {
+ expect(authenticatedResult.current.authenticated).toEqual(false);
+ expect(authenticatedResult.current.identity).toBeNull();
+ }, 50);
});
});
diff --git a/packages/hypergraph-react/test/HypergraphSpaceContext.test.tsx b/packages/hypergraph-react/test/HypergraphSpaceContext.test.tsx
index d24275dc..bd0e2685 100644
--- a/packages/hypergraph-react/test/HypergraphSpaceContext.test.tsx
+++ b/packages/hypergraph-react/test/HypergraphSpaceContext.test.tsx
@@ -45,7 +45,8 @@ describe('HypergraphSpaceContext', () => {
beforeEach(() => {
repo = new Repo({});
- const automergeDocHandle = repo.find(Utils.idToAutomergeId(spaceId) as AnyDocumentId);
+ const result = repo.findWithProgress(Utils.idToAutomergeId(spaceId) as AnyDocumentId);
+ const automergeDocHandle = result.handle;
// set it to ready to interact with the document
automergeDocHandle.doneLoading();
diff --git a/packages/hypergraph/package.json b/packages/hypergraph/package.json
index 114e0477..bcff3498 100644
--- a/packages/hypergraph/package.json
+++ b/packages/hypergraph/package.json
@@ -27,7 +27,7 @@
},
"dependencies": {
"@automerge/automerge": "^2.2.9",
- "@automerge/automerge-repo": "^2.0.0-beta.2",
+ "@automerge/automerge-repo": "=2.0.0-beta.5",
"@effect/experimental": "^0.44.20",
"@noble/ciphers": "^1.3.0",
"@noble/curves": "^1.9.0",
diff --git a/packages/hypergraph/src/inboxes/create-inbox.ts b/packages/hypergraph/src/inboxes/create-inbox.ts
index 74673d79..e74e21eb 100644
--- a/packages/hypergraph/src/inboxes/create-inbox.ts
+++ b/packages/hypergraph/src/inboxes/create-inbox.ts
@@ -1,10 +1,11 @@
-import { type Inboxes, Messages, SpaceEvents } from '@graphprotocol/hypergraph';
import { secp256k1 } from '@noble/curves/secp256k1';
import { randomBytes } from '@noble/hashes/utils';
import { cryptoBoxKeyPair } from '@serenity-kit/noble-sodium';
import { Effect } from 'effect';
-import { bytesToHex, hexToBytes, stringToUint8Array } from '../utils/index.js';
-import { canonicalize } from '../utils/index.js';
+import type * as Inboxes from '../inboxes/types.js';
+import * as Messages from '../messages/index.js';
+import * as SpaceEvents from '../space-events/index.js';
+import { bytesToHex, canonicalize, hexToBytes, stringToUint8Array } from '../utils/index.js';
type CreateAccountInboxParams = {
accountId: string;
diff --git a/packages/hypergraph/src/inboxes/get-list-inboxes.ts b/packages/hypergraph/src/inboxes/get-list-inboxes.ts
index 1dfdf263..33458e27 100644
--- a/packages/hypergraph/src/inboxes/get-list-inboxes.ts
+++ b/packages/hypergraph/src/inboxes/get-list-inboxes.ts
@@ -1,5 +1,5 @@
-import { Messages } from '@graphprotocol/hypergraph';
import { Schema } from 'effect';
+import * as Messages from '../messages/index.js';
export const listPublicSpaceInboxes = async ({
spaceId,
diff --git a/packages/hypergraph/src/inboxes/message-validation.ts b/packages/hypergraph/src/inboxes/message-validation.ts
index 82a5475d..0ad70760 100644
--- a/packages/hypergraph/src/inboxes/message-validation.ts
+++ b/packages/hypergraph/src/inboxes/message-validation.ts
@@ -1,4 +1,5 @@
-import { Identity, type Messages } from '@graphprotocol/hypergraph';
+import * as Identity from '../identity/index.js';
+import type * as Messages from '../messages/index.js';
import type { AccountInboxStorageEntry, SpaceInboxStorageEntry } from '../store.js';
import { recoverAccountInboxMessageSigner, recoverSpaceInboxMessageSigner } from './recover-inbox-message-signer.js';
diff --git a/packages/hypergraph/src/inboxes/prepare-message.ts b/packages/hypergraph/src/inboxes/prepare-message.ts
index ae3ca049..24852ec6 100644
--- a/packages/hypergraph/src/inboxes/prepare-message.ts
+++ b/packages/hypergraph/src/inboxes/prepare-message.ts
@@ -1,5 +1,5 @@
-import type { Messages } from '@graphprotocol/hypergraph';
import { secp256k1 } from '@noble/curves/secp256k1';
+import type * as Messages from '../messages/index.js';
import type { SignatureWithRecovery } from '../types.js';
import { canonicalize, hexToBytes, stringToUint8Array } from '../utils/index.js';
import { encryptInboxMessage } from './message-encryption.js';
diff --git a/packages/hypergraph/src/inboxes/recover-inbox-message-signer.ts b/packages/hypergraph/src/inboxes/recover-inbox-message-signer.ts
index 42ecb334..08b1bff4 100644
--- a/packages/hypergraph/src/inboxes/recover-inbox-message-signer.ts
+++ b/packages/hypergraph/src/inboxes/recover-inbox-message-signer.ts
@@ -1,6 +1,7 @@
-import { type Messages, Utils } from '@graphprotocol/hypergraph';
import { secp256k1 } from '@noble/curves/secp256k1';
import { sha256 } from '@noble/hashes/sha256';
+import type * as Messages from '../messages/index.js';
+import * as Utils from '../utils/index.js';
export const recoverSpaceInboxMessageSigner = (
message: Messages.RequestCreateSpaceInboxMessage,
diff --git a/packages/hypergraph/src/store.ts b/packages/hypergraph/src/store.ts
index 1faa514c..92ab480d 100644
--- a/packages/hypergraph/src/store.ts
+++ b/packages/hypergraph/src/store.ts
@@ -1,5 +1,4 @@
-import type { AnyDocumentId, DocHandle } from '@automerge/automerge-repo';
-import { Repo } from '@automerge/automerge-repo';
+import type { AnyDocumentId, DocHandle, Repo } from '@automerge/automerge-repo';
import { type Store, createStore } from '@xstate/store';
import type { Address } from 'viem';
import { mergeMessages } from './inboxes/merge-messages.js';
@@ -55,7 +54,7 @@ interface StoreContext {
spaces: SpaceStorageEntry[];
updatesInFlight: string[];
invitations: Invitation[];
- repo: Repo;
+ repo: Repo | null;
identities: {
[accountId: string]: {
encryptionPublicKey: string;
@@ -76,7 +75,7 @@ const initialStoreContext: StoreContext = {
spaces: [],
updatesInFlight: [],
invitations: [],
- repo: new Repo({}),
+ repo: null,
identities: {},
authenticated: false,
accountId: null,
@@ -145,6 +144,10 @@ type StoreEvent =
}
| {
type: 'resetAuth';
+ }
+ | {
+ type: 'setRepo';
+ repo: Repo;
};
type GenericEventObject = { type: string };
@@ -174,12 +177,15 @@ export const store: Store = create
};
},
setSpaceFromList: (context, event: { spaceId: string }) => {
+ if (!context.repo) {
+ return context;
+ }
const existingSpace = context.spaces.find((s) => s.id === event.spaceId);
const lastUpdateClock = context.lastUpdateClock[event.spaceId] ?? -1;
- const automergeDocHandle = context.repo.find(idToAutomergeId(event.spaceId) as AnyDocumentId);
+ const result = context.repo.findWithProgress(idToAutomergeId(event.spaceId) as AnyDocumentId);
// set it to ready to interact with the document
- automergeDocHandle.doneLoading();
+ result.handle.doneLoading();
if (existingSpace) {
return {
@@ -191,7 +197,7 @@ export const store: Store = create
events: existingSpace.events ?? [],
state: existingSpace.state,
keys: existingSpace.keys ?? [],
- automergeDocHandle,
+ automergeDocHandle: result.handle,
inboxes: existingSpace.inboxes ?? [],
};
return newSpace;
@@ -216,7 +222,7 @@ export const store: Store = create
inboxes: [],
updates: [],
lastUpdateClock: -1,
- automergeDocHandle,
+ automergeDocHandle: result.handle,
},
],
};
@@ -409,17 +415,17 @@ export const store: Store = create
},
) => {
const existingSpace = context.spaces.find((s) => s.id === event.spaceId);
- if (!existingSpace) {
- const automergeDocHandle = context.repo.find(idToAutomergeId(event.spaceId) as AnyDocumentId);
+ if (!existingSpace && context.repo) {
+ const result = context.repo.findWithProgress(idToAutomergeId(event.spaceId) as AnyDocumentId);
// set it to ready to interact with the document
- automergeDocHandle.doneLoading();
+ result.handle.doneLoading();
const newSpace: SpaceStorageEntry = {
id: event.spaceId,
events: event.events,
state: event.spaceState,
keys: event.keys,
- automergeDocHandle,
+ automergeDocHandle: result.handle,
inboxes: event.inboxes ?? [],
};
return {
@@ -487,5 +493,11 @@ export const store: Store = create
keys: null,
};
},
+ setRepo: (context, event: { repo: Repo }) => {
+ return {
+ ...context,
+ repo: event.repo,
+ };
+ },
},
});
diff --git a/packages/hypergraph/test/entity/entity.test.ts b/packages/hypergraph/test/entity/entity.test.ts
index 72b2d34f..8921a9af 100644
--- a/packages/hypergraph/test/entity/entity.test.ts
+++ b/packages/hypergraph/test/entity/entity.test.ts
@@ -33,7 +33,8 @@ describe('Entity', () => {
beforeEach(() => {
repo = new Repo({}); // reset to new Repo instance to clear created entities in tests
- handle = repo.find(automergeDocId as AnyDocumentId);
+ const result = repo.findWithProgress(automergeDocId as AnyDocumentId);
+ handle = result.handle;
// set it to ready to interact with the document
handle.doneLoading();
});
diff --git a/packages/hypergraph/test/entity/findMany.test.ts b/packages/hypergraph/test/entity/findMany.test.ts
index fc15a38f..b08b91d6 100644
--- a/packages/hypergraph/test/entity/findMany.test.ts
+++ b/packages/hypergraph/test/entity/findMany.test.ts
@@ -28,7 +28,8 @@ describe('findMany with filters', () => {
beforeEach(() => {
repo = new Repo({}); // reset to new Repo instance to clear created entities in tests
- handle = repo.find(automergeDocId as AnyDocumentId);
+ const result = repo.findWithProgress(automergeDocId as AnyDocumentId);
+ handle = result.handle;
// set it to ready to interact with the document
handle.doneLoading();
});
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 0c06a150..f0a40b90 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -42,11 +42,11 @@ importers:
specifier: ^2.2.9
version: 2.2.9
'@automerge/automerge-repo':
- specifier: ^2.0.0-beta.2
- version: 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)
+ specifier: '=2.0.0-beta.5'
+ version: 2.0.0-beta.5
'@automerge/automerge-repo-react-hooks':
- specifier: ^2.0.0-beta.2
- version: 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(react-dom@19.1.0(react@19.1.0))(react@19.1.0)(typescript@5.8.3)
+ specifier: '=2.0.0-beta.5'
+ version: 2.0.0-beta.5(react-dom@19.1.0(react@19.1.0))(react@19.1.0)
'@graphprotocol/grc-20':
specifier: ^0.11.5
version: 0.11.5(bufferutil@4.0.9)(graphql@16.11.0)(ox@0.6.7(typescript@5.8.3)(zod@3.24.2))(typescript@5.8.3)(utf-8-validate@5.0.10)(zod@3.24.2)
@@ -165,12 +165,43 @@ importers:
vite-plugin-node-polyfills:
specifier: ^0.23.0
version: 0.23.0(rollup@4.39.0)(vite@6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0))
- vite-plugin-top-level-await:
- specifier: ^1.5.0
- version: 1.5.0(rollup@4.39.0)(vite@6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0))
- vite-plugin-wasm:
- specifier: ^3.4.1
- version: 3.4.1(vite@6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0))
+
+ apps/next-example:
+ dependencies:
+ '@graphprotocol/grc-20':
+ specifier: ^0.11.5
+ version: 0.11.5(bufferutil@4.0.9)(graphql@16.11.0)(ox@0.6.7(typescript@5.8.3)(zod@3.24.2))(typescript@5.8.3)(utf-8-validate@5.0.10)(zod@3.24.2)
+ '@graphprotocol/hypergraph':
+ specifier: workspace:*
+ version: link:../../packages/hypergraph/publish
+ '@graphprotocol/hypergraph-react':
+ specifier: workspace:*
+ version: link:../../packages/hypergraph-react/publish
+ '@privy-io/react-auth':
+ specifier: ^2.13.0
+ version: 2.13.0(@solana/web3.js@1.95.3(bufferutil@4.0.9)(encoding@0.1.13)(utf-8-validate@5.0.10))(@types/react@19.1.3)(bs58@6.0.0)(bufferutil@4.0.9)(permissionless@0.2.44(ox@0.6.7(typescript@5.8.3)(zod@3.24.2))(viem@2.29.0(bufferutil@4.0.9)(typescript@5.8.3)(utf-8-validate@5.0.10)(zod@3.24.2)))(react-dom@19.1.0(react@19.1.0))(react@19.1.0)(typescript@5.8.3)(use-sync-external-store@1.5.0(react@19.1.0))(utf-8-validate@5.0.10)(zod@3.24.2)
+ next:
+ specifier: 15.3.2
+ version: 15.3.2(@babel/core@7.27.1)(react-dom@19.1.0(react@19.1.0))(react@19.1.0)
+ react:
+ specifier: ^19.0.0
+ version: 19.1.0
+ react-dom:
+ specifier: ^19.0.0
+ version: 19.1.0(react@19.1.0)
+ devDependencies:
+ '@types/node':
+ specifier: ^22
+ version: 22.15.15
+ '@types/react':
+ specifier: ^19
+ version: 19.1.3
+ '@types/react-dom':
+ specifier: ^19
+ version: 19.1.3(@types/react@19.1.3)
+ typescript:
+ specifier: ^5
+ version: 5.8.3
apps/server:
dependencies:
@@ -222,7 +253,7 @@ importers:
version: 6.7.0(typescript@5.8.3)
tsup:
specifier: ^8.4.0
- version: 8.4.0(@swc/core@1.11.24)(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0)
+ version: 8.4.0(@swc/core@1.11.24(@swc/helpers@0.5.17))(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0)
typescript:
specifier: ^5.8.3
version: 5.8.3
@@ -352,7 +383,7 @@ importers:
version: 4.4.1(vite@6.3.4(@types/node@22.15.3)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0))
tsup:
specifier: ^8.4.0
- version: 8.4.0(@swc/core@1.11.24)(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0)
+ version: 8.4.0(@swc/core@1.11.24(@swc/helpers@0.5.17))(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0)
tsx:
specifier: ^4.19.4
version: 4.19.4
@@ -367,8 +398,8 @@ importers:
specifier: ^2.2.9
version: 2.2.9
'@automerge/automerge-repo':
- specifier: ^2.0.0-beta.2
- version: 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)
+ specifier: '=2.0.0-beta.5'
+ version: 2.0.0-beta.5
'@effect/experimental':
specifier: ^0.44.20
version: 0.44.20(@effect/platform@0.77.1(effect@3.14.20))(effect@3.14.20)
@@ -417,11 +448,11 @@ importers:
specifier: ^2.2.9
version: 2.2.9
'@automerge/automerge-repo':
- specifier: ^2.0.0-beta.2
- version: 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)
+ specifier: '=2.0.0-beta.5'
+ version: 2.0.0-beta.5
'@automerge/automerge-repo-react-hooks':
- specifier: ^2.0.0-beta.2
- version: 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(react-dom@19.1.0(react@19.1.0))(react@19.1.0)(typescript@5.8.3)
+ specifier: '=2.0.0-beta.5'
+ version: 2.0.0-beta.5(react-dom@19.1.0(react@19.1.0))(react@19.1.0)
'@graphprotocol/grc-20':
specifier: ^0.11.5
version: 0.11.5(bufferutil@4.0.9)(graphql@16.11.0)(ox@0.6.7(typescript@5.8.3)(zod@3.24.2))(typescript@5.8.3)(utf-8-validate@5.0.10)(zod@3.24.2)
@@ -497,21 +528,18 @@ packages:
'@asamuzakjp/css-color@2.8.2':
resolution: {integrity: sha512-RtWv9jFN2/bLExuZgFFZ0I3pWWeezAHGgrmjqGGWclATl1aDe3yhCUaI0Ilkp6OCk9zX7+FjvDasEX8Q9Rxc5w==}
- '@automerge/automerge-repo-react-hooks@2.0.0-collectionsync-alpha.1':
- resolution: {integrity: sha512-7aqn2VwnBJ+ok696Pimod2kxn3d02QrOhAYTCZIKF2DgKtp8lv6mQE1N2zSLuITjS8qud/SlcHckjLaDSA39/w==}
+ '@automerge/automerge-repo-react-hooks@2.0.0-beta.5':
+ resolution: {integrity: sha512-J/CXtcvJRfoP1Z2wm8oi4/XbKhixaG3P4oT2LBzwBoOnccnkJ8DiyysFcK5ieUbib8YhQx/mRMWFcewCIvQ6Yg==}
peerDependencies:
- react: '>16.8.0'
- react-dom: '>16.8.0'
+ react: ^18.0.0
+ react-dom: ^18.0.0
- '@automerge/automerge-repo@2.0.0-collectionsync-alpha.1':
- resolution: {integrity: sha512-IRjwNOHOCL/E+qqKAqyLro/K/MrTCTsBGyXwlvgN19lHV0v2mMngXJUHF3iSGS2DY7nTeP4dSzGR/8+uFXDLSQ==}
+ '@automerge/automerge-repo@2.0.0-beta.5':
+ resolution: {integrity: sha512-oV0ImkuONzWXyfFhI32wxd9L+Nhndf4579WfWlUkC+m+xpI3NXFCH2UFNPaJXErbD+PqpX1H7Ah8Qi5dfKXRsw==}
'@automerge/automerge@2.2.9':
resolution: {integrity: sha512-6HM52Ops79hAQBWMg/t0MNfGOdEiXyenQjO9F1hKZq0RWDsMLpPa1SzRy/C4/4UyX67sTHuA5CwBpH34SpfZlA==}
- '@automerge/automerge@3.0.0-collectionsync-alpha.1':
- resolution: {integrity: sha512-FO7QCjMz0pdoNxotVaH84X2sJKZdSYrjo6VHuVwFkQB0N/PQ0EHWi7N6knd9/JC+tIAzhGS3rb4xQwXITsewcg==}
-
'@babel/cli@7.27.2':
resolution: {integrity: sha512-cfd7DnGlhH6OIyuPSSj3vcfIdnbXukhAyKY8NaZrFadC7pXyL9mOL5WgjcptiEJLi5k3j8aYvLIVCzezrWTaiA==}
engines: {node: '>=6.9.0'}
@@ -1035,10 +1063,6 @@ packages:
'@coinbase/wallet-sdk@4.3.0':
resolution: {integrity: sha512-T3+SNmiCw4HzDm4we9wCHCxlP0pqCiwKe4sOwPH3YAK2KSKjxPRydKu6UQJrdONFVLG7ujXvbd/6ZqmvJb8rkw==}
- '@cspotcode/source-map-support@0.8.1':
- resolution: {integrity: sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==}
- engines: {node: '>=12'}
-
'@csstools/color-helpers@5.0.1':
resolution: {integrity: sha512-MKtmkA0BX87PKaO1NFRTFH+UnkgnmySQOvNxJubsadusqPEC2aJ9MOQiMceZJJ6oitUl/i0L6u0M1IrmAOmgBA==}
engines: {node: '>=18'}
@@ -1165,6 +1189,9 @@ packages:
effect: ^3.13.1
vitest: ^2.0.5
+ '@emnapi/runtime@1.4.3':
+ resolution: {integrity: sha512-pBPWdu6MLKROBX05wSNKcNb++m5Er+KQ9QkB+WVM+pW2Kx9hoSrVTnu3BdkI5eBLZoKu/J6mW/B6i6bJB2ytXQ==}
+
'@emotion/babel-plugin@11.13.5':
resolution: {integrity: sha512-pxHCpT2ex+0q+HH91/zsdHkw/lXd468DIN2zvfvLtPKLLMo6gQj7oLObq8PhkrxOZb/gGCq03S3Z7PDhS8pduQ==}
@@ -1745,6 +1772,116 @@ packages:
peerDependencies:
react-hook-form: ^7.55.0
+ '@img/sharp-darwin-arm64@0.34.1':
+ resolution: {integrity: sha512-pn44xgBtgpEbZsu+lWf2KNb6OAf70X68k+yk69Ic2Xz11zHR/w24/U49XT7AeRwJ0Px+mhALhU5LPci1Aymk7A==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [arm64]
+ os: [darwin]
+
+ '@img/sharp-darwin-x64@0.34.1':
+ resolution: {integrity: sha512-VfuYgG2r8BpYiOUN+BfYeFo69nP/MIwAtSJ7/Zpxc5QF3KS22z8Pvg3FkrSFJBPNQ7mmcUcYQFBmEQp7eu1F8Q==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [x64]
+ os: [darwin]
+
+ '@img/sharp-libvips-darwin-arm64@1.1.0':
+ resolution: {integrity: sha512-HZ/JUmPwrJSoM4DIQPv/BfNh9yrOA8tlBbqbLz4JZ5uew2+o22Ik+tHQJcih7QJuSa0zo5coHTfD5J8inqj9DA==}
+ cpu: [arm64]
+ os: [darwin]
+
+ '@img/sharp-libvips-darwin-x64@1.1.0':
+ resolution: {integrity: sha512-Xzc2ToEmHN+hfvsl9wja0RlnXEgpKNmftriQp6XzY/RaSfwD9th+MSh0WQKzUreLKKINb3afirxW7A0fz2YWuQ==}
+ cpu: [x64]
+ os: [darwin]
+
+ '@img/sharp-libvips-linux-arm64@1.1.0':
+ resolution: {integrity: sha512-IVfGJa7gjChDET1dK9SekxFFdflarnUB8PwW8aGwEoF3oAsSDuNUTYS+SKDOyOJxQyDC1aPFMuRYLoDInyV9Ew==}
+ cpu: [arm64]
+ os: [linux]
+
+ '@img/sharp-libvips-linux-arm@1.1.0':
+ resolution: {integrity: sha512-s8BAd0lwUIvYCJyRdFqvsj+BJIpDBSxs6ivrOPm/R7piTs5UIwY5OjXrP2bqXC9/moGsyRa37eYWYCOGVXxVrA==}
+ cpu: [arm]
+ os: [linux]
+
+ '@img/sharp-libvips-linux-ppc64@1.1.0':
+ resolution: {integrity: sha512-tiXxFZFbhnkWE2LA8oQj7KYR+bWBkiV2nilRldT7bqoEZ4HiDOcePr9wVDAZPi/Id5fT1oY9iGnDq20cwUz8lQ==}
+ cpu: [ppc64]
+ os: [linux]
+
+ '@img/sharp-libvips-linux-s390x@1.1.0':
+ resolution: {integrity: sha512-xukSwvhguw7COyzvmjydRb3x/09+21HykyapcZchiCUkTThEQEOMtBj9UhkaBRLuBrgLFzQ2wbxdeCCJW/jgJA==}
+ cpu: [s390x]
+ os: [linux]
+
+ '@img/sharp-libvips-linux-x64@1.1.0':
+ resolution: {integrity: sha512-yRj2+reB8iMg9W5sULM3S74jVS7zqSzHG3Ol/twnAAkAhnGQnpjj6e4ayUz7V+FpKypwgs82xbRdYtchTTUB+Q==}
+ cpu: [x64]
+ os: [linux]
+
+ '@img/sharp-libvips-linuxmusl-arm64@1.1.0':
+ resolution: {integrity: sha512-jYZdG+whg0MDK+q2COKbYidaqW/WTz0cc1E+tMAusiDygrM4ypmSCjOJPmFTvHHJ8j/6cAGyeDWZOsK06tP33w==}
+ cpu: [arm64]
+ os: [linux]
+
+ '@img/sharp-libvips-linuxmusl-x64@1.1.0':
+ resolution: {integrity: sha512-wK7SBdwrAiycjXdkPnGCPLjYb9lD4l6Ze2gSdAGVZrEL05AOUJESWU2lhlC+Ffn5/G+VKuSm6zzbQSzFX/P65A==}
+ cpu: [x64]
+ os: [linux]
+
+ '@img/sharp-linux-arm64@0.34.1':
+ resolution: {integrity: sha512-kX2c+vbvaXC6vly1RDf/IWNXxrlxLNpBVWkdpRq5Ka7OOKj6nr66etKy2IENf6FtOgklkg9ZdGpEu9kwdlcwOQ==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [arm64]
+ os: [linux]
+
+ '@img/sharp-linux-arm@0.34.1':
+ resolution: {integrity: sha512-anKiszvACti2sGy9CirTlNyk7BjjZPiML1jt2ZkTdcvpLU1YH6CXwRAZCA2UmRXnhiIftXQ7+Oh62Ji25W72jA==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [arm]
+ os: [linux]
+
+ '@img/sharp-linux-s390x@0.34.1':
+ resolution: {integrity: sha512-7s0KX2tI9mZI2buRipKIw2X1ufdTeaRgwmRabt5bi9chYfhur+/C1OXg3TKg/eag1W+6CCWLVmSauV1owmRPxA==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [s390x]
+ os: [linux]
+
+ '@img/sharp-linux-x64@0.34.1':
+ resolution: {integrity: sha512-wExv7SH9nmoBW3Wr2gvQopX1k8q2g5V5Iag8Zk6AVENsjwd+3adjwxtp3Dcu2QhOXr8W9NusBU6XcQUohBZ5MA==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [x64]
+ os: [linux]
+
+ '@img/sharp-linuxmusl-arm64@0.34.1':
+ resolution: {integrity: sha512-DfvyxzHxw4WGdPiTF0SOHnm11Xv4aQexvqhRDAoD00MzHekAj9a/jADXeXYCDFH/DzYruwHbXU7uz+H+nWmSOQ==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [arm64]
+ os: [linux]
+
+ '@img/sharp-linuxmusl-x64@0.34.1':
+ resolution: {integrity: sha512-pax/kTR407vNb9qaSIiWVnQplPcGU8LRIJpDT5o8PdAx5aAA7AS3X9PS8Isw1/WfqgQorPotjrZL3Pqh6C5EBg==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [x64]
+ os: [linux]
+
+ '@img/sharp-wasm32@0.34.1':
+ resolution: {integrity: sha512-YDybQnYrLQfEpzGOQe7OKcyLUCML4YOXl428gOOzBgN6Gw0rv8dpsJ7PqTHxBnXnwXr8S1mYFSLSa727tpz0xg==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [wasm32]
+
+ '@img/sharp-win32-ia32@0.34.1':
+ resolution: {integrity: sha512-WKf/NAZITnonBf3U1LfdjoMgNO5JYRSlhovhRhMxXVdvWYveM4kM3L8m35onYIdh75cOMCo1BexgVQcCDzyoWw==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [ia32]
+ os: [win32]
+
+ '@img/sharp-win32-x64@0.34.1':
+ resolution: {integrity: sha512-hw1iIAHpNE8q3uMIRCgGOeDoz9KtFNarFLQclLxr/LK1VBkj8nby18RjFvr6aP7USRYAjTZW6yisnBWMX571Tw==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+ cpu: [x64]
+ os: [win32]
+
'@isaacs/cliui@8.0.2':
resolution: {integrity: sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==}
engines: {node: '>=12'}
@@ -1767,9 +1904,6 @@ packages:
'@jridgewell/trace-mapping@0.3.25':
resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==}
- '@jridgewell/trace-mapping@0.3.9':
- resolution: {integrity: sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==}
-
'@jsdevtools/ez-spawn@3.0.4':
resolution: {integrity: sha512-f5DRIOZf7wxogefH03RjMPMdBF7ADTWUMoOs9kaJo06EfwF+aFhMZMDZxHg/Xe12hptN9xoZjGso2fdjapBRIA==}
engines: {node: '>=10'}
@@ -1866,6 +2000,57 @@ packages:
cpu: [x64]
os: [win32]
+ '@next/env@15.3.2':
+ resolution: {integrity: sha512-xURk++7P7qR9JG1jJtLzPzf0qEvqCN0A/T3DXf8IPMKo9/6FfjxtEffRJIIew/bIL4T3C2jLLqBor8B/zVlx6g==}
+
+ '@next/swc-darwin-arm64@15.3.2':
+ resolution: {integrity: sha512-2DR6kY/OGcokbnCsjHpNeQblqCZ85/1j6njYSkzRdpLn5At7OkSdmk7WyAmB9G0k25+VgqVZ/u356OSoQZ3z0g==}
+ engines: {node: '>= 10'}
+ cpu: [arm64]
+ os: [darwin]
+
+ '@next/swc-darwin-x64@15.3.2':
+ resolution: {integrity: sha512-ro/fdqaZWL6k1S/5CLv1I0DaZfDVJkWNaUU3un8Lg6m0YENWlDulmIWzV96Iou2wEYyEsZq51mwV8+XQXqMp3w==}
+ engines: {node: '>= 10'}
+ cpu: [x64]
+ os: [darwin]
+
+ '@next/swc-linux-arm64-gnu@15.3.2':
+ resolution: {integrity: sha512-covwwtZYhlbRWK2HlYX9835qXum4xYZ3E2Mra1mdQ+0ICGoMiw1+nVAn4d9Bo7R3JqSmK1grMq/va+0cdh7bJA==}
+ engines: {node: '>= 10'}
+ cpu: [arm64]
+ os: [linux]
+
+ '@next/swc-linux-arm64-musl@15.3.2':
+ resolution: {integrity: sha512-KQkMEillvlW5Qk5mtGA/3Yz0/tzpNlSw6/3/ttsV1lNtMuOHcGii3zVeXZyi4EJmmLDKYcTcByV2wVsOhDt/zg==}
+ engines: {node: '>= 10'}
+ cpu: [arm64]
+ os: [linux]
+
+ '@next/swc-linux-x64-gnu@15.3.2':
+ resolution: {integrity: sha512-uRBo6THWei0chz+Y5j37qzx+BtoDRFIkDzZjlpCItBRXyMPIg079eIkOCl3aqr2tkxL4HFyJ4GHDes7W8HuAUg==}
+ engines: {node: '>= 10'}
+ cpu: [x64]
+ os: [linux]
+
+ '@next/swc-linux-x64-musl@15.3.2':
+ resolution: {integrity: sha512-+uxFlPuCNx/T9PdMClOqeE8USKzj8tVz37KflT3Kdbx/LOlZBRI2yxuIcmx1mPNK8DwSOMNCr4ureSet7eyC0w==}
+ engines: {node: '>= 10'}
+ cpu: [x64]
+ os: [linux]
+
+ '@next/swc-win32-arm64-msvc@15.3.2':
+ resolution: {integrity: sha512-LLTKmaI5cfD8dVzh5Vt7+OMo+AIOClEdIU/TSKbXXT2iScUTSxOGoBhfuv+FU8R9MLmrkIL1e2fBMkEEjYAtPQ==}
+ engines: {node: '>= 10'}
+ cpu: [arm64]
+ os: [win32]
+
+ '@next/swc-win32-x64-msvc@15.3.2':
+ resolution: {integrity: sha512-aW5B8wOPioJ4mBdMDXkt5f3j8pUr9W8AnlX0Df35uRWNT1Y6RIybxjnSUe+PhM+M1bwgyY8PHLmXZC6zT1o5tA==}
+ engines: {node: '>= 10'}
+ cpu: [x64]
+ os: [win32]
+
'@nicolo-ribaudo/chokidar-2@2.1.8-no-fsevents.3':
resolution: {integrity: sha512-s88O1aVtXftvp5bCPB7WnmXc5IwOZZ7YPuwNPt+GtOOXpPvad1LfbmjYv+qII7zP6RU2QGnqve27dnLycEnyEQ==}
@@ -2435,15 +2620,6 @@ packages:
rollup:
optional: true
- '@rollup/plugin-virtual@3.0.2':
- resolution: {integrity: sha512-10monEYsBp3scM4/ND4LNH5Rxvh3e/cVeL3jWTgZ2SrQ+BmUoQcopVQvnaMcOnykb1VkxUFuDAN+0FnpTFRy2A==}
- engines: {node: '>=14.0.0'}
- peerDependencies:
- rollup: ^1.20.0||^2.0.0||^3.0.0||^4.0.0
- peerDependenciesMeta:
- rollup:
- optional: true
-
'@rollup/pluginutils@5.1.2':
resolution: {integrity: sha512-/FIdS3PyZ39bjZlwqFnWqCOVnW7o963LtKMwQOD0NhQqw22gSr2YY1afu3FxRip4ZCZNsD5jq6Aaz6QV3D/Njw==}
engines: {node: '>=14.0.0'}
@@ -2736,6 +2912,9 @@ packages:
'@swc/helpers@0.5.15':
resolution: {integrity: sha512-JQ5TuMi45Owi4/BIMAJBoSQoOJu12oOk/gADqlcUL9JEdHB8vyjUSsxqeNXnmXHjYKMi2WcYtezGEEhqUI/E2g==}
+ '@swc/helpers@0.5.17':
+ resolution: {integrity: sha512-5IKx/Y13RsYd+sauPb2x+U/xZikHjolzfuDgTAl/Tdf3Q8rslRvC19NKDLgAJQ6wsqADk10ntlv08nPFw/gO/A==}
+
'@swc/types@0.1.21':
resolution: {integrity: sha512-2YEtj5HJVbKivud9N4bpPBAyZhj4S2Ipe5LkUG94alTpr7in/GU/EARgPAd3BwU+YOmFVJC2+kjqhGRi3r0ZpQ==}
@@ -3025,18 +3204,6 @@ packages:
'@types/react-dom':
optional: true
- '@tsconfig/node10@1.0.11':
- resolution: {integrity: sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==}
-
- '@tsconfig/node12@1.0.11':
- resolution: {integrity: sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==}
-
- '@tsconfig/node14@1.0.3':
- resolution: {integrity: sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==}
-
- '@tsconfig/node16@1.0.4':
- resolution: {integrity: sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==}
-
'@types/aria-query@5.0.4':
resolution: {integrity: sha512-rfT93uj5s0PRL7EzccGMs3brplhcrghnDoV26NqKhCAS1hVo+WdNsPvE/yb6ilfr5hi2MEk6d5EWJTKdxg8jVw==}
@@ -3358,10 +3525,6 @@ packages:
resolution: {integrity: sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==}
engines: {node: '>= 0.6'}
- acorn-walk@8.3.4:
- resolution: {integrity: sha512-ueEepnujpqee2o5aIYnvHU6C0A42MNdsIDeqy5BydrkuC5R1ZuUFnm27EeFJGoEHJQgn3uleRvmTXaJgfXbt4g==}
- engines: {node: '>=0.4.0'}
-
acorn@8.14.0:
resolution: {integrity: sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==}
engines: {node: '>=0.4.0'}
@@ -3427,9 +3590,6 @@ packages:
apg-js@4.4.0:
resolution: {integrity: sha512-fefmXFknJmtgtNEXfPwZKYkMFX4Fyeyz+fNF6JWp87biGOPslJbCBVU158zvKRZfHBKnJDy8CMM40oLFGkXT8Q==}
- arg@4.1.3:
- resolution: {integrity: sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==}
-
argparse@1.0.10:
resolution: {integrity: sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==}
@@ -3771,6 +3931,9 @@ packages:
resolution: {integrity: sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==}
engines: {node: '>= 10'}
+ client-only@0.0.1:
+ resolution: {integrity: sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==}
+
cliui@6.0.0:
resolution: {integrity: sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==}
@@ -3797,6 +3960,13 @@ packages:
color-name@1.1.4:
resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==}
+ color-string@1.9.1:
+ resolution: {integrity: sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==}
+
+ color@4.2.3:
+ resolution: {integrity: sha512-1rXeuUUiGGrykh+CeBdu5Ie7OJwinCgQY0bc7GCRxy5xVHy+moaqkpL/jqQq0MtQOeYcrqEz4abc5f0KtU7W4A==}
+ engines: {node: '>=12.5.0'}
+
colorette@2.0.20:
resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==}
@@ -4074,10 +4244,6 @@ packages:
devlop@1.1.0:
resolution: {integrity: sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA==}
- diff@4.0.2:
- resolution: {integrity: sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==}
- engines: {node: '>=0.3.1'}
-
diff@7.0.0:
resolution: {integrity: sha512-PJWHUb1RFevKCwaFA9RlG5tCd+FO5iRh9A8HEtkmBH2Li03iJriB6m6JIN4rGz3K3JLawI7/veA1xzRKP6ISBw==}
engines: {node: '>=0.3.1'}
@@ -4741,6 +4907,9 @@ packages:
is-arrayish@0.2.1:
resolution: {integrity: sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==}
+ is-arrayish@0.3.2:
+ resolution: {integrity: sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==}
+
is-binary-path@2.1.0:
resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==}
engines: {node: '>=8'}
@@ -5144,9 +5313,6 @@ packages:
resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==}
engines: {node: '>=6'}
- make-error@1.3.6:
- resolution: {integrity: sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==}
-
map-cache@0.2.2:
resolution: {integrity: sha512-8y/eV9QQZCiyn1SprXSrCmqJN0yNRATe+PO8ztwqrvrbdRLA3eYJF0yaR0YayLWkMbsQSKWS9N2gPcGEc4UsZg==}
engines: {node: '>=0.10.0'}
@@ -5340,6 +5506,27 @@ packages:
resolution: {integrity: sha512-8Ofs/AUQh8MaEcrlq5xOX0CQ9ypTF5dl78mjlMNfOK08fzpgTHQRQPBxcPlEtIw0yRpws+Zo/3r+5WRby7u3Gg==}
engines: {node: '>= 0.6'}
+ next@15.3.2:
+ resolution: {integrity: sha512-CA3BatMyHkxZ48sgOCLdVHjFU36N7TF1HhqAHLFOkV6buwZnvMI84Cug8xD56B9mCuKrqXnLn94417GrZ/jjCQ==}
+ engines: {node: ^18.18.0 || ^19.8.0 || >= 20.0.0}
+ hasBin: true
+ peerDependencies:
+ '@opentelemetry/api': ^1.1.0
+ '@playwright/test': ^1.41.2
+ babel-plugin-react-compiler: '*'
+ react: ^18.2.0 || 19.0.0-rc-de68d2f4-20241204 || ^19.0.0
+ react-dom: ^18.2.0 || 19.0.0-rc-de68d2f4-20241204 || ^19.0.0
+ sass: ^1.3.0
+ peerDependenciesMeta:
+ '@opentelemetry/api':
+ optional: true
+ '@playwright/test':
+ optional: true
+ babel-plugin-react-compiler:
+ optional: true
+ sass:
+ optional: true
+
no-case@3.0.4:
resolution: {integrity: sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==}
@@ -5732,6 +5919,10 @@ packages:
postcss-value-parser@4.2.0:
resolution: {integrity: sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==}
+ postcss@8.4.31:
+ resolution: {integrity: sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ==}
+ engines: {node: ^10 || ^12 || >=14}
+
postcss@8.4.38:
resolution: {integrity: sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==}
engines: {node: ^10 || ^12 || >=14}
@@ -6115,6 +6306,11 @@ packages:
engines: {node: '>=10'}
hasBin: true
+ semver@7.7.1:
+ resolution: {integrity: sha512-hlq8tAfn0m/61p4BVRcPzIGr6LKiMwo4VM6dGi6pt4qcRkmNzTcWq6eCEjEh+qXjkMDvPlOFFSGwQjoEa6gyMA==}
+ engines: {node: '>=10'}
+ hasBin: true
+
send@1.1.0:
resolution: {integrity: sha512-v67WcEouB5GxbTWL/4NeToqcZiAWEq90N888fczVArY8A79J0L4FD7vj5hm3eUMua5EpoQ59wa/oovY6TLvRUA==}
engines: {node: '>= 18'}
@@ -6163,6 +6359,10 @@ packages:
shallowequal@1.1.0:
resolution: {integrity: sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ==}
+ sharp@0.34.1:
+ resolution: {integrity: sha512-1j0w61+eVxu7DawFJtnfYcvSv6qPFvfTaqzTQ2BLknVhHTwGS8sc63ZBF4rzkWMBVKybo4S5OBtDdZahh2A1xg==}
+ engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
+
shebang-command@2.0.0:
resolution: {integrity: sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==}
engines: {node: '>=8'}
@@ -6217,6 +6417,9 @@ packages:
simple-get@4.0.1:
resolution: {integrity: sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA==}
+ simple-swizzle@0.2.2:
+ resolution: {integrity: sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==}
+
siwe@3.0.0:
resolution: {integrity: sha512-P2/ry7dHYJA6JJ5+veS//Gn2XDwNb3JMvuD6xiXX8L/PJ1SNVD4a3a8xqEbmANx+7kNQcD8YAh1B9bNKKvRy/g==}
peerDependencies:
@@ -6372,6 +6575,19 @@ packages:
react: '>= 16.8.0'
react-dom: '>= 16.8.0'
+ styled-jsx@5.1.6:
+ resolution: {integrity: sha512-qSVyDTeMotdvQYoHWLNGwRFJHC+i+ZvdBRYosOFgC+Wg1vx4frN2/RG/NA7SYqqvKNLf39P2LSRA2pu6n0XYZA==}
+ engines: {node: '>= 12.0.0'}
+ peerDependencies:
+ '@babel/core': '*'
+ babel-plugin-macros: '*'
+ react: '>= 16.8.0 || 17.x.x || ^18.0.0-0 || ^19.0.0-0'
+ peerDependenciesMeta:
+ '@babel/core':
+ optional: true
+ babel-plugin-macros:
+ optional: true
+
stylis@4.2.0:
resolution: {integrity: sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw==}
@@ -6468,9 +6684,6 @@ packages:
tiny-invariant@1.3.3:
resolution: {integrity: sha512-+FbBPE1o9QAYvviau/qC5SE3caw21q3xkvWKBtja5vgqOWIHHJ3ioaq1VPfn/Szqctz2bU/oYeKd9/z5BL+PVg==}
- tiny-typed-emitter@2.1.0:
- resolution: {integrity: sha512-qVtvMxeXbVej0cQWKqVSSAHmKZEHAvxdF8HEUBFWts8h+xEo5m/lEiPakuyZ3BnCBjOD8i24kzNOiOLLgsSxhA==}
-
tiny-warning@1.0.3:
resolution: {integrity: sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==}
@@ -6551,20 +6764,6 @@ packages:
ts-log@2.2.7:
resolution: {integrity: sha512-320x5Ggei84AxzlXp91QkIGSw5wgaLT6GeAH0KsqDmRZdVWW2OiSeVvElVoatk3f7nicwXlElXsoFkARiGE2yg==}
- ts-node@10.9.2:
- resolution: {integrity: sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==}
- hasBin: true
- peerDependencies:
- '@swc/core': '>=1.2.50'
- '@swc/wasm': '>=1.2.50'
- '@types/node': '*'
- typescript: '>=2.7'
- peerDependenciesMeta:
- '@swc/core':
- optional: true
- '@swc/wasm':
- optional: true
-
tslib@1.14.1:
resolution: {integrity: sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==}
@@ -6814,10 +7013,6 @@ packages:
util@0.12.5:
resolution: {integrity: sha512-kZf/K6hEIrWHI6XqOFUiiMa+79wE/D8Q+NCNAWclkyg3b4d2k7s0QGepNjiABc+aR3N1PAyHL7p6UcLY6LmrnA==}
- uuid@10.0.0:
- resolution: {integrity: sha512-8XkAphELsDnEGrDxUOHB3RGvXz6TeuYSGEZBOjtTtPm2lwhGBjLgOzLHB63IUWfBpNucQjND6d3AOudO+H3RWQ==}
- hasBin: true
-
uuid@11.1.0:
resolution: {integrity: sha512-0/A9rDy9P7cJ+8w1c9WD9V//9Wj15Ce2MPz8Ri6032usz+NfePxx5AcN3bN+r6ZL6jEo066/yNYB3tn4pQEx+A==}
hasBin: true
@@ -6830,9 +7025,6 @@ packages:
resolution: {integrity: sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA==}
hasBin: true
- v8-compile-cache-lib@3.0.1:
- resolution: {integrity: sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==}
-
validate-npm-package-name@5.0.1:
resolution: {integrity: sha512-OljLrQ9SQdOUqTaQxqL5dEfZWrXExyyWsozYlAWFawPVNuD83igl7uJD2RTkNMbniIYgt8l81eCJGIdQF7avLQ==}
engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0}
@@ -6901,16 +7093,6 @@ packages:
peerDependencies:
vite: ^2.0.0 || ^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0
- vite-plugin-top-level-await@1.5.0:
- resolution: {integrity: sha512-r/DtuvHrSqUVk23XpG2cl8gjt1aATMG5cjExXL1BUTcSNab6CzkcPua9BPEc9fuTP5UpwClCxUe3+dNGL0yrgQ==}
- peerDependencies:
- vite: '>=2.8'
-
- vite-plugin-wasm@3.4.1:
- resolution: {integrity: sha512-ja3nSo2UCkVeitltJGkS3pfQHAanHv/DqGatdI39ja6McgABlpsZ5hVgl6wuR8Qx5etY3T5qgDQhOWzc5RReZA==}
- peerDependencies:
- vite: ^2 || ^3 || ^4 || ^5 || ^6
-
vite@6.3.4:
resolution: {integrity: sha512-BiReIiMS2fyFqbqNT/Qqt4CVITDU9M9vE+DKcVAsB+ZV0wvTKd+3hMbkpxz1b+NmEDMegpVbisKiAZOnvO92Sw==}
engines: {node: ^18.0.0 || ^20.0.0 || >=22.0.0}
@@ -7220,10 +7402,6 @@ packages:
resolution: {integrity: sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==}
engines: {node: '>=12'}
- yn@3.1.1:
- resolution: {integrity: sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==}
- engines: {node: '>=6'}
-
yocto-queue@0.1.0:
resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==}
engines: {node: '>=10'}
@@ -7300,48 +7478,34 @@ snapshots:
'@csstools/css-tokenizer': 3.0.3
lru-cache: 11.0.2
- '@automerge/automerge-repo-react-hooks@2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(react-dom@19.1.0(react@19.1.0))(react@19.1.0)(typescript@5.8.3)':
+ '@automerge/automerge-repo-react-hooks@2.0.0-beta.5(react-dom@19.1.0(react@19.1.0))(react@19.1.0)':
dependencies:
'@automerge/automerge': 2.2.9
- '@automerge/automerge-repo': 2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)
+ '@automerge/automerge-repo': 2.0.0-beta.5
eventemitter3: 5.0.1
react: 19.1.0
react-dom: 19.1.0(react@19.1.0)
react-usestateref: 1.0.9(react@19.1.0)
transitivePeerDependencies:
- - '@swc/core'
- - '@swc/wasm'
- - '@types/node'
- supports-color
- - typescript
- '@automerge/automerge-repo@2.0.0-collectionsync-alpha.1(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)':
+ '@automerge/automerge-repo@2.0.0-beta.5':
dependencies:
- '@automerge/automerge': 3.0.0-collectionsync-alpha.1
+ '@automerge/automerge': 2.2.9
bs58check: 3.0.1
cbor-x: 1.6.0
debug: 4.4.0
eventemitter3: 5.0.1
fast-sha256: 1.3.0
- tiny-typed-emitter: 2.1.0
- ts-node: 10.9.2(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3)
uuid: 9.0.1
xstate: 5.18.1
transitivePeerDependencies:
- - '@swc/core'
- - '@swc/wasm'
- - '@types/node'
- supports-color
- - typescript
'@automerge/automerge@2.2.9':
dependencies:
uuid: 9.0.1
- '@automerge/automerge@3.0.0-collectionsync-alpha.1':
- dependencies:
- uuid: 9.0.1
-
'@babel/cli@7.27.2(@babel/core@7.27.1)':
dependencies:
'@babel/core': 7.27.1
@@ -8027,10 +8191,6 @@ snapshots:
eventemitter3: 5.0.1
preact: 10.25.4
- '@cspotcode/source-map-support@0.8.1':
- dependencies:
- '@jridgewell/trace-mapping': 0.3.9
-
'@csstools/color-helpers@5.0.1': {}
'@csstools/css-calc@2.1.1(@csstools/css-parser-algorithms@3.0.4(@csstools/css-tokenizer@3.0.3))(@csstools/css-tokenizer@3.0.3)':
@@ -8147,6 +8307,11 @@ snapshots:
effect: 3.13.1
vitest: 3.1.3(@types/debug@4.1.12)(@types/node@22.15.3)(jiti@2.4.2)(jsdom@26.1.0(bufferutil@4.0.9)(utf-8-validate@5.0.10))(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0)
+ '@emnapi/runtime@1.4.3':
+ dependencies:
+ tslib: 2.8.1
+ optional: true
+
'@emotion/babel-plugin@11.13.5':
dependencies:
'@babel/helper-module-imports': 7.27.1
@@ -9087,6 +9252,84 @@ snapshots:
'@standard-schema/utils': 0.3.0
react-hook-form: 7.56.1(react@19.1.0)
+ '@img/sharp-darwin-arm64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-darwin-arm64': 1.1.0
+ optional: true
+
+ '@img/sharp-darwin-x64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-darwin-x64': 1.1.0
+ optional: true
+
+ '@img/sharp-libvips-darwin-arm64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-darwin-x64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linux-arm64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linux-arm@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linux-ppc64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linux-s390x@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linux-x64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linuxmusl-arm64@1.1.0':
+ optional: true
+
+ '@img/sharp-libvips-linuxmusl-x64@1.1.0':
+ optional: true
+
+ '@img/sharp-linux-arm64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linux-arm64': 1.1.0
+ optional: true
+
+ '@img/sharp-linux-arm@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linux-arm': 1.1.0
+ optional: true
+
+ '@img/sharp-linux-s390x@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linux-s390x': 1.1.0
+ optional: true
+
+ '@img/sharp-linux-x64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linux-x64': 1.1.0
+ optional: true
+
+ '@img/sharp-linuxmusl-arm64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linuxmusl-arm64': 1.1.0
+ optional: true
+
+ '@img/sharp-linuxmusl-x64@0.34.1':
+ optionalDependencies:
+ '@img/sharp-libvips-linuxmusl-x64': 1.1.0
+ optional: true
+
+ '@img/sharp-wasm32@0.34.1':
+ dependencies:
+ '@emnapi/runtime': 1.4.3
+ optional: true
+
+ '@img/sharp-win32-ia32@0.34.1':
+ optional: true
+
+ '@img/sharp-win32-x64@0.34.1':
+ optional: true
+
'@isaacs/cliui@8.0.2':
dependencies:
string-width: 5.1.2
@@ -9113,11 +9356,6 @@ snapshots:
'@jridgewell/resolve-uri': 3.1.2
'@jridgewell/sourcemap-codec': 1.5.0
- '@jridgewell/trace-mapping@0.3.9':
- dependencies:
- '@jridgewell/resolve-uri': 3.1.2
- '@jridgewell/sourcemap-codec': 1.5.0
-
'@jsdevtools/ez-spawn@3.0.4':
dependencies:
call-me-maybe: 1.0.2
@@ -9257,6 +9495,32 @@ snapshots:
'@msgpackr-extract/msgpackr-extract-win32-x64@3.0.3':
optional: true
+ '@next/env@15.3.2': {}
+
+ '@next/swc-darwin-arm64@15.3.2':
+ optional: true
+
+ '@next/swc-darwin-x64@15.3.2':
+ optional: true
+
+ '@next/swc-linux-arm64-gnu@15.3.2':
+ optional: true
+
+ '@next/swc-linux-arm64-musl@15.3.2':
+ optional: true
+
+ '@next/swc-linux-x64-gnu@15.3.2':
+ optional: true
+
+ '@next/swc-linux-x64-musl@15.3.2':
+ optional: true
+
+ '@next/swc-win32-arm64-msvc@15.3.2':
+ optional: true
+
+ '@next/swc-win32-x64-msvc@15.3.2':
+ optional: true
+
'@nicolo-ribaudo/chokidar-2@2.1.8-no-fsevents.3':
optional: true
@@ -10104,10 +10368,6 @@ snapshots:
optionalDependencies:
rollup: 4.39.0
- '@rollup/plugin-virtual@3.0.2(rollup@4.39.0)':
- optionalDependencies:
- rollup: 4.39.0
-
'@rollup/pluginutils@5.1.2(rollup@4.39.0)':
dependencies:
'@types/estree': 1.0.7
@@ -10372,7 +10632,7 @@ snapshots:
'@swc/core-win32-x64-msvc@1.11.24':
optional: true
- '@swc/core@1.11.24':
+ '@swc/core@1.11.24(@swc/helpers@0.5.17)':
dependencies:
'@swc/counter': 0.1.3
'@swc/types': 0.1.21
@@ -10387,6 +10647,8 @@ snapshots:
'@swc/core-win32-arm64-msvc': 1.11.24
'@swc/core-win32-ia32-msvc': 1.11.24
'@swc/core-win32-x64-msvc': 1.11.24
+ '@swc/helpers': 0.5.17
+ optional: true
'@swc/counter@0.1.3': {}
@@ -10394,9 +10656,14 @@ snapshots:
dependencies:
tslib: 2.8.1
+ '@swc/helpers@0.5.17':
+ dependencies:
+ tslib: 2.8.1
+
'@swc/types@0.1.21':
dependencies:
'@swc/counter': 0.1.3
+ optional: true
'@tailwindcss/node@4.1.5':
dependencies:
@@ -10695,14 +10962,6 @@ snapshots:
'@types/react': 19.1.3
'@types/react-dom': 19.1.3(@types/react@19.1.3)
- '@tsconfig/node10@1.0.11': {}
-
- '@tsconfig/node12@1.0.11': {}
-
- '@tsconfig/node14@1.0.3': {}
-
- '@tsconfig/node16@1.0.4': {}
-
'@types/aria-query@5.0.4': {}
'@types/babel__core@7.20.5':
@@ -11531,10 +11790,6 @@ snapshots:
mime-types: 3.0.0
negotiator: 1.0.0
- acorn-walk@8.3.4:
- dependencies:
- acorn: 8.14.0
-
acorn@8.14.0: {}
aes-js@3.0.0: {}
@@ -11581,8 +11836,6 @@ snapshots:
apg-js@4.4.0: {}
- arg@4.1.3: {}
-
argparse@1.0.10:
dependencies:
sprintf-js: 1.0.3
@@ -12035,6 +12288,8 @@ snapshots:
cli-width@3.0.0: {}
+ client-only@0.0.1: {}
+
cliui@6.0.0:
dependencies:
string-width: 4.2.3
@@ -12059,6 +12314,18 @@ snapshots:
color-name@1.1.4: {}
+ color-string@1.9.1:
+ dependencies:
+ color-name: 1.1.4
+ simple-swizzle: 0.2.2
+ optional: true
+
+ color@4.2.3:
+ dependencies:
+ color-convert: 2.0.1
+ color-string: 1.9.1
+ optional: true
+
colorette@2.0.20: {}
comma-separated-tokens@2.0.3: {}
@@ -12305,8 +12572,6 @@ snapshots:
dependencies:
dequal: 2.0.3
- diff@4.0.2: {}
-
diff@7.0.0: {}
diffie-hellman@5.0.3:
@@ -13107,6 +13372,9 @@ snapshots:
is-arrayish@0.2.1: {}
+ is-arrayish@0.3.2:
+ optional: true
+
is-binary-path@2.1.0:
dependencies:
binary-extensions: 2.3.0
@@ -13489,8 +13757,6 @@ snapshots:
pify: 4.0.1
semver: 5.7.2
- make-error@1.3.6: {}
-
map-cache@0.2.2: {}
math-intrinsics@1.1.0: {}
@@ -13672,6 +13938,31 @@ snapshots:
negotiator@1.0.0: {}
+ next@15.3.2(@babel/core@7.27.1)(react-dom@19.1.0(react@19.1.0))(react@19.1.0):
+ dependencies:
+ '@next/env': 15.3.2
+ '@swc/counter': 0.1.3
+ '@swc/helpers': 0.5.15
+ busboy: 1.6.0
+ caniuse-lite: 1.0.30001678
+ postcss: 8.4.31
+ react: 19.1.0
+ react-dom: 19.1.0(react@19.1.0)
+ styled-jsx: 5.1.6(@babel/core@7.27.1)(react@19.1.0)
+ optionalDependencies:
+ '@next/swc-darwin-arm64': 15.3.2
+ '@next/swc-darwin-x64': 15.3.2
+ '@next/swc-linux-arm64-gnu': 15.3.2
+ '@next/swc-linux-arm64-musl': 15.3.2
+ '@next/swc-linux-x64-gnu': 15.3.2
+ '@next/swc-linux-x64-musl': 15.3.2
+ '@next/swc-win32-arm64-msvc': 15.3.2
+ '@next/swc-win32-x64-msvc': 15.3.2
+ sharp: 0.34.1
+ transitivePeerDependencies:
+ - '@babel/core'
+ - babel-plugin-macros
+
no-case@3.0.4:
dependencies:
lower-case: 2.0.2
@@ -14118,6 +14409,12 @@ snapshots:
postcss-value-parser@4.2.0: {}
+ postcss@8.4.31:
+ dependencies:
+ nanoid: 3.3.8
+ picocolors: 1.1.1
+ source-map-js: 1.2.1
+
postcss@8.4.38:
dependencies:
nanoid: 3.3.8
@@ -14495,7 +14792,7 @@ snapshots:
rpc-websockets@9.0.4:
dependencies:
- '@swc/helpers': 0.5.15
+ '@swc/helpers': 0.5.17
'@types/uuid': 8.3.4
'@types/ws': 8.18.1
buffer: 6.0.3
@@ -14548,6 +14845,9 @@ snapshots:
semver@7.6.3: {}
+ semver@7.7.1:
+ optional: true
+
send@1.1.0:
dependencies:
debug: 4.4.0
@@ -14626,6 +14926,34 @@ snapshots:
shallowequal@1.1.0: {}
+ sharp@0.34.1:
+ dependencies:
+ color: 4.2.3
+ detect-libc: 2.0.3
+ semver: 7.7.1
+ optionalDependencies:
+ '@img/sharp-darwin-arm64': 0.34.1
+ '@img/sharp-darwin-x64': 0.34.1
+ '@img/sharp-libvips-darwin-arm64': 1.1.0
+ '@img/sharp-libvips-darwin-x64': 1.1.0
+ '@img/sharp-libvips-linux-arm': 1.1.0
+ '@img/sharp-libvips-linux-arm64': 1.1.0
+ '@img/sharp-libvips-linux-ppc64': 1.1.0
+ '@img/sharp-libvips-linux-s390x': 1.1.0
+ '@img/sharp-libvips-linux-x64': 1.1.0
+ '@img/sharp-libvips-linuxmusl-arm64': 1.1.0
+ '@img/sharp-libvips-linuxmusl-x64': 1.1.0
+ '@img/sharp-linux-arm': 0.34.1
+ '@img/sharp-linux-arm64': 0.34.1
+ '@img/sharp-linux-s390x': 0.34.1
+ '@img/sharp-linux-x64': 0.34.1
+ '@img/sharp-linuxmusl-arm64': 0.34.1
+ '@img/sharp-linuxmusl-x64': 0.34.1
+ '@img/sharp-wasm32': 0.34.1
+ '@img/sharp-win32-ia32': 0.34.1
+ '@img/sharp-win32-x64': 0.34.1
+ optional: true
+
shebang-command@2.0.0:
dependencies:
shebang-regex: 3.0.0
@@ -14696,6 +15024,11 @@ snapshots:
once: 1.4.0
simple-concat: 1.0.1
+ simple-swizzle@0.2.2:
+ dependencies:
+ is-arrayish: 0.3.2
+ optional: true
+
siwe@3.0.0(ethers@6.13.5(bufferutil@4.0.9)(utf-8-validate@5.0.10)):
dependencies:
'@spruceid/siwe-parser': 3.0.0
@@ -14853,6 +15186,13 @@ snapshots:
stylis: 4.3.2
tslib: 2.6.2
+ styled-jsx@5.1.6(@babel/core@7.27.1)(react@19.1.0):
+ dependencies:
+ client-only: 0.0.1
+ react: 19.1.0
+ optionalDependencies:
+ '@babel/core': 7.27.1
+
stylis@4.2.0: {}
stylis@4.3.2: {}
@@ -14944,8 +15284,6 @@ snapshots:
tiny-invariant@1.3.3: {}
- tiny-typed-emitter@2.1.0: {}
-
tiny-warning@1.0.3: {}
tinybench@2.9.0: {}
@@ -15009,26 +15347,6 @@ snapshots:
ts-log@2.2.7: {}
- ts-node@10.9.2(@swc/core@1.11.24)(@types/node@22.15.15)(typescript@5.8.3):
- dependencies:
- '@cspotcode/source-map-support': 0.8.1
- '@tsconfig/node10': 1.0.11
- '@tsconfig/node12': 1.0.11
- '@tsconfig/node14': 1.0.3
- '@tsconfig/node16': 1.0.4
- '@types/node': 22.15.15
- acorn: 8.14.0
- acorn-walk: 8.3.4
- arg: 4.1.3
- create-require: 1.1.1
- diff: 4.0.2
- make-error: 1.3.6
- typescript: 5.8.3
- v8-compile-cache-lib: 3.0.1
- yn: 3.1.1
- optionalDependencies:
- '@swc/core': 1.11.24
-
tslib@1.14.1: {}
tslib@2.6.2: {}
@@ -15037,7 +15355,7 @@ snapshots:
tslib@2.8.1: {}
- tsup@8.4.0(@swc/core@1.11.24)(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0):
+ tsup@8.4.0(@swc/core@1.11.24(@swc/helpers@0.5.17))(jiti@2.4.2)(postcss@8.5.3)(tsx@4.19.4)(typescript@5.8.3)(yaml@2.7.0):
dependencies:
bundle-require: 5.1.0(esbuild@0.25.2)
cac: 6.7.14
@@ -15056,7 +15374,7 @@ snapshots:
tinyglobby: 0.2.13
tree-kill: 1.2.2
optionalDependencies:
- '@swc/core': 1.11.24
+ '@swc/core': 1.11.24(@swc/helpers@0.5.17)
postcss: 8.5.3
typescript: 5.8.3
transitivePeerDependencies:
@@ -15229,16 +15547,12 @@ snapshots:
is-typed-array: 1.1.13
which-typed-array: 1.1.15
- uuid@10.0.0: {}
-
uuid@11.1.0: {}
uuid@8.3.2: {}
uuid@9.0.1: {}
- v8-compile-cache-lib@3.0.1: {}
-
validate-npm-package-name@5.0.1: {}
valtio@1.11.2(@types/react@19.1.3)(react@19.1.0):
@@ -15373,20 +15687,6 @@ snapshots:
transitivePeerDependencies:
- rollup
- vite-plugin-top-level-await@1.5.0(rollup@4.39.0)(vite@6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0)):
- dependencies:
- '@rollup/plugin-virtual': 3.0.2(rollup@4.39.0)
- '@swc/core': 1.11.24
- uuid: 10.0.0
- vite: 6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0)
- transitivePeerDependencies:
- - '@swc/helpers'
- - rollup
-
- vite-plugin-wasm@3.4.1(vite@6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0)):
- dependencies:
- vite: 6.3.5(@types/node@22.15.15)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0)
-
vite@6.3.4(@types/node@22.15.3)(jiti@2.4.2)(lightningcss@1.29.2)(tsx@4.19.4)(yaml@2.7.0):
dependencies:
esbuild: 0.25.2
@@ -15679,8 +15979,6 @@ snapshots:
y18n: 5.0.8
yargs-parser: 21.1.1
- yn@3.1.1: {}
-
yocto-queue@0.1.0: {}
zod-package-json@1.0.3: