@instantdb/react-common 0.22.112 → 0.22.113-experimental.dwwoelfel-patch-2.21374029739.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -8,7 +8,7 @@ export default abstract class InstantReactAbstractDatabase<Schema extends Instan
8
8
  core: InstantCoreDatabase<Schema, UseDates>;
9
9
  /** @deprecated use `core` instead */
10
10
  _core: InstantCoreDatabase<Schema, UseDates>;
11
- static Storage?: any;
11
+ static Store?: any;
12
12
  static NetworkListener?: any;
13
13
  static EventSourceImpl?: any;
14
14
  constructor(config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {
@@ -1 +1 @@
1
- {"version":3,"file":"InstantReactAbstractDatabase.d.ts","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"InstantReactAbstractDatabase.d.ts","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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"}
@@ -18,13 +18,13 @@ class InstantReactAbstractDatabase {
18
18
  core;
19
19
  /** @deprecated use `core` instead */
20
20
  _core;
21
- static Storage;
21
+ static Store;
22
22
  static NetworkListener;
23
23
  static EventSourceImpl;
24
24
  constructor(config, versions) {
25
25
  this.core = (0, core_1.init)(config,
26
26
  // @ts-expect-error because TS can't resolve subclass statics
27
- this.constructor.Storage,
27
+ config.Store || this.constructor.Store,
28
28
  // @ts-expect-error because TS can't resolve subclass statics
29
29
  this.constructor.NetworkListener, versions,
30
30
  // @ts-expect-error because TS can't resolve subclass statics
@@ -1 +1 @@
1
- {"version":3,"file":"InstantReactAbstractDatabase.js","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\nimport {\n // types\n Auth,\n Storage,\n txInit,\n type AuthState,\n type User,\n type ConnectionStatus,\n type TransactionChunk,\n type RoomSchemaShape,\n type InstaQLOptions,\n type InstantConfig,\n type PageInfoResponse,\n InstantCoreDatabase,\n init as core_init,\n InstaQLLifecycleState,\n InstaQLResponse,\n RoomsOf,\n InstantSchemaDef,\n IInstantDatabase,\n InstantError,\n ValidQuery,\n} from '@instantdb/core';\nimport {\n ReactNode,\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useQueryInternal } from './useQuery.ts';\nimport { InstantReactRoom, rooms } from './InstantReactRoom.ts';\n\nconst defaultAuthState = {\n isLoading: true,\n user: undefined,\n error: undefined,\n};\n\nexport default abstract class InstantReactAbstractDatabase<\n // need to pull this schema out to another generic for query params, not sure why\n Schema extends InstantSchemaDef<any, any, any>,\n UseDates extends boolean = false,\n Config extends InstantConfig<Schema, boolean> = InstantConfig<\n Schema,\n UseDates\n >,\n Rooms extends RoomSchemaShape = RoomsOf<Schema>,\n> implements IInstantDatabase<Schema>\n{\n public tx = txInit<Schema>();\n\n public auth: Auth;\n public storage: Storage;\n public core: InstantCoreDatabase<Schema, UseDates>;\n\n /** @deprecated use `core` instead */\n public _core: InstantCoreDatabase<Schema, UseDates>;\n\n static Storage?: any;\n static NetworkListener?: any;\n static EventSourceImpl?: any;\n\n constructor(\n config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {\n useDateObjects?: UseDates;\n },\n versions?: { [key: string]: string },\n ) {\n this.core = core_init<Schema, UseDates>(\n config,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.Storage,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.NetworkListener,\n versions,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.EventSourceImpl,\n );\n this._core = this.core;\n this.auth = this.core.auth;\n this.storage = this.core.storage;\n }\n\n /**\n * Returns a unique ID for a given `name`. It's stored in local storage,\n * so you will get the same ID across sessions.\n *\n * This is useful for generating IDs that could identify a local device or user.\n *\n * @example\n * const deviceId = await db.getLocalId('device');\n */\n getLocalId = (name: string): Promise<string> => {\n return this.core.getLocalId(name);\n };\n\n /**\n * A hook that returns a unique ID for a given `name`. localIds are\n * stored in local storage, so you will get the same ID across sessions.\n *\n * Initially returns `null`, and then loads the localId.\n *\n * @example\n * const deviceId = db.useLocalId('device');\n * if (!deviceId) return null; // loading\n * console.log('Device ID:', deviceId)\n */\n useLocalId = (name: string): string | null => {\n const [localId, setLocalId] = useState<string | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const f = async () => {\n const id = await this.getLocalId(name);\n if (!mounted) return;\n setLocalId(id);\n };\n f();\n return;\n }, [name]);\n\n return localId;\n };\n\n /**\n * Obtain a handle to a room, which allows you to listen to topics and presence data\n *\n * If you don't provide a `type` or `id`, Instant will default to `_defaultRoomType` and `_defaultRoomId`\n * as the room type and id, respectively.\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n */\n room<RoomType extends keyof Rooms>(\n type: RoomType = '_defaultRoomType' as RoomType,\n id: string = '_defaultRoomId',\n ) {\n return new InstantReactRoom<Schema, Rooms, RoomType>(this.core, type, id);\n }\n\n /**\n * Hooks for working with rooms\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n * const publish = db.rooms.usePublishTopic(room, 'emoji');\n * // ...\n */\n rooms = rooms;\n\n /**\n * Use this to write data! You can create, update, delete, and link objects\n *\n * @see https://instantdb.com/docs/instaml\n *\n * @example\n * // Create a new object in the `goals` namespace\n * const goalId = id();\n * db.transact(db.tx.goals[goalId].update({title: \"Get fit\"}))\n *\n * // Update the title\n * db.transact(db.tx.goals[goalId].update({title: \"Get super fit\"}))\n *\n * // Delete it\n * db.transact(db.tx.goals[goalId].delete())\n *\n * // Or create an association:\n * todoId = id();\n * db.transact([\n * db.tx.todos[todoId].update({ title: 'Go on a run' }),\n * db.tx.goals[goalId].link({todos: todoId}),\n * ])\n */\n transact = (\n chunks: TransactionChunk<any, any> | TransactionChunk<any, any>[],\n ) => {\n return this.core.transact(chunks);\n };\n\n /**\n * Use this to query your data!\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n * // listen to all goals\n * const { isLoading, error, data } = db.useQuery({ goals: {} });\n *\n * // goals where the title is \"Get Fit\"\n * const { isLoading, error, data } = db.useQuery({\n * goals: { $: { where: { title: 'Get Fit' } } },\n * });\n *\n * // all goals, _alongside_ their todos\n * const { isLoading, error, data } = db.useQuery({\n * goals: { todos: {} },\n * });\n *\n * // skip if `user` is not logged in\n * const { isLoading, error, data } = db.useQuery(\n * auth.user ? { goals: {} } : null,\n * );\n */\n useQuery = <Q extends ValidQuery<Q, Schema>>(\n query: null | Q,\n opts?: InstaQLOptions,\n ): InstaQLLifecycleState<Schema, Q, UseDates> => {\n return useQueryInternal<Q, Schema, UseDates>(this.core, query, opts).state;\n };\n\n /**\n * Listen for the logged in state. This is useful\n * for deciding when to show a login screen.\n *\n * Check out the docs for an example `Login` component too!\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * function App() {\n * const { isLoading, user, error } = db.useAuth()\n * if (isLoading) {\n * return <div>Loading...</div>\n * }\n * if (error) {\n * return <div>Uh oh! {error.message}</div>\n * }\n * if (user) {\n * return <Main user={user} />\n * }\n * return <Login />\n * }\n *\n */\n useAuth = (): AuthState => {\n return this._useAuth();\n };\n\n protected _useAuth(): AuthState {\n // We use a ref to store the result of the query.\n // This is becuase `useSyncExternalStore` uses `Object.is`\n // to compare the previous and next state.\n // If we don't use a ref, the state will always be considered different, so\n // the component will always re-render.\n const resultCacheRef = useRef<AuthState>(\n this.core._reactor._currentUserCached,\n );\n\n // Similar to `resultCacheRef`, `useSyncExternalStore` will unsubscribe\n // if `subscribe` changes, so we use `useCallback` to memoize the function.\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeAuth((auth) => {\n resultCacheRef.current = { isLoading: false, ...auth };\n cb();\n });\n\n return unsubscribe;\n }, []);\n\n const state = useSyncExternalStore<AuthState>(\n subscribe,\n () => resultCacheRef.current,\n () => defaultAuthState,\n );\n return state;\n }\n\n /**\n * Subscribe to the currently logged in user.\n * If the user is not logged in, this hook with throw an Error.\n * You will want to protect any calls of this hook with a\n * <db.SignedIn> component, or your own logic based on db.useAuth()\n *\n * @see https://instantdb.com/docs/auth\n * @throws Error indicating user not signed in\n * @example\n * function UserDisplay() {\n * const user = db.useUser()\n * return <div>Logged in as: {user.email}</div>\n * }\n *\n * <db.SignedIn>\n * <UserDisplay />\n * </db.SignedIn>\n *\n */\n useUser = (): User => {\n const { user } = this.useAuth();\n if (!user) {\n throw new InstantError(\n 'useUser must be used within an auth-protected route',\n );\n }\n return user;\n };\n\n /**\n * One time query for the logged in state. This is useful\n * for scenarios where you want to know the current auth\n * state without subscribing to changes.\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * const user = await db.getAuth();\n * console.log('logged in as', user.email)\n */\n getAuth(): Promise<User | null> {\n return this.core.getAuth();\n }\n\n /**\n * Listen for connection status changes to Instant. Use this for things like\n * showing connection state to users\n *\n * @see https://www.instantdb.com/docs/patterns#connection-status\n * @example\n * function App() {\n * const status = db.useConnectionStatus()\n * const connectionState =\n * status === 'connecting' || status === 'opened'\n * ? 'authenticating'\n * : status === 'authenticated'\n * ? 'connected'\n * : status === 'closed'\n * ? 'closed'\n * : status === 'errored'\n * ? 'errored'\n * : 'unexpected state';\n *\n * return <div>Connection state: {connectionState}</div>\n * }\n */\n useConnectionStatus = (): ConnectionStatus => {\n const statusRef = useRef<ConnectionStatus>(\n this.core._reactor.status as ConnectionStatus,\n );\n\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeConnectionStatus((newStatus) => {\n if (newStatus !== statusRef.current) {\n statusRef.current = newStatus;\n cb();\n }\n });\n\n return unsubscribe;\n }, []);\n\n const status = useSyncExternalStore<ConnectionStatus>(\n subscribe,\n () => statusRef.current,\n // For SSR, always return 'connecting' as the initial state\n () => 'connecting',\n );\n\n return status;\n };\n\n /**\n * Use this for one-off queries.\n * Returns local data if available, otherwise fetches from the server.\n * Because we want to avoid stale data, this method will throw an error\n * if the user is offline or there is no active connection to the server.\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n *\n * const resp = await db.queryOnce({ goals: {} });\n * console.log(resp.data.goals)\n */\n queryOnce = <Q extends ValidQuery<Q, Schema>>(\n query: Q,\n opts?: InstaQLOptions,\n ): Promise<{\n data: InstaQLResponse<Schema, Q, UseDates>;\n pageInfo: PageInfoResponse<Q>;\n }> => {\n return this.core.queryOnce(query, opts);\n };\n\n /**\n * Only render children if the user is signed in.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedIn>\n * <MyComponent />\n * </db.SignedIn>\n *\n */\n SignedIn: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || !auth.user) return null;\n\n return <>{children}</>;\n };\n\n /**\n * Only render children if the user is signed out.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedOut>\n * <MyComponent />\n * </db.SignedOut>\n *\n */\n SignedOut: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || auth.user) return null;\n return <>{children}</>;\n };\n}\n"]}
1
+ {"version":3,"file":"InstantReactAbstractDatabase.js","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\nimport {\n // types\n Auth,\n Storage,\n txInit,\n type AuthState,\n type User,\n type ConnectionStatus,\n type TransactionChunk,\n type RoomSchemaShape,\n type InstaQLOptions,\n type InstantConfig,\n type PageInfoResponse,\n InstantCoreDatabase,\n init as core_init,\n InstaQLLifecycleState,\n InstaQLResponse,\n RoomsOf,\n InstantSchemaDef,\n IInstantDatabase,\n InstantError,\n ValidQuery,\n} from '@instantdb/core';\nimport {\n ReactNode,\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useQueryInternal } from './useQuery.ts';\nimport { InstantReactRoom, rooms } from './InstantReactRoom.ts';\n\nconst defaultAuthState = {\n isLoading: true,\n user: undefined,\n error: undefined,\n};\n\nexport default abstract class InstantReactAbstractDatabase<\n // need to pull this schema out to another generic for query params, not sure why\n Schema extends InstantSchemaDef<any, any, any>,\n UseDates extends boolean = false,\n Config extends InstantConfig<Schema, boolean> = InstantConfig<\n Schema,\n UseDates\n >,\n Rooms extends RoomSchemaShape = RoomsOf<Schema>,\n> implements IInstantDatabase<Schema>\n{\n public tx = txInit<Schema>();\n\n public auth: Auth;\n public storage: Storage;\n public core: InstantCoreDatabase<Schema, UseDates>;\n\n /** @deprecated use `core` instead */\n public _core: InstantCoreDatabase<Schema, UseDates>;\n\n static Store?: any;\n static NetworkListener?: any;\n static EventSourceImpl?: any;\n\n constructor(\n config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {\n useDateObjects?: UseDates;\n },\n versions?: { [key: string]: string },\n ) {\n this.core = core_init<Schema, UseDates>(\n config,\n // @ts-expect-error because TS can't resolve subclass statics\n config.Store || this.constructor.Store,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.NetworkListener,\n versions,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.EventSourceImpl,\n );\n this._core = this.core;\n this.auth = this.core.auth;\n this.storage = this.core.storage;\n }\n\n /**\n * Returns a unique ID for a given `name`. It's stored in local storage,\n * so you will get the same ID across sessions.\n *\n * This is useful for generating IDs that could identify a local device or user.\n *\n * @example\n * const deviceId = await db.getLocalId('device');\n */\n getLocalId = (name: string): Promise<string> => {\n return this.core.getLocalId(name);\n };\n\n /**\n * A hook that returns a unique ID for a given `name`. localIds are\n * stored in local storage, so you will get the same ID across sessions.\n *\n * Initially returns `null`, and then loads the localId.\n *\n * @example\n * const deviceId = db.useLocalId('device');\n * if (!deviceId) return null; // loading\n * console.log('Device ID:', deviceId)\n */\n useLocalId = (name: string): string | null => {\n const [localId, setLocalId] = useState<string | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const f = async () => {\n const id = await this.getLocalId(name);\n if (!mounted) return;\n setLocalId(id);\n };\n f();\n return;\n }, [name]);\n\n return localId;\n };\n\n /**\n * Obtain a handle to a room, which allows you to listen to topics and presence data\n *\n * If you don't provide a `type` or `id`, Instant will default to `_defaultRoomType` and `_defaultRoomId`\n * as the room type and id, respectively.\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n */\n room<RoomType extends keyof Rooms>(\n type: RoomType = '_defaultRoomType' as RoomType,\n id: string = '_defaultRoomId',\n ) {\n return new InstantReactRoom<Schema, Rooms, RoomType>(this.core, type, id);\n }\n\n /**\n * Hooks for working with rooms\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n * const publish = db.rooms.usePublishTopic(room, 'emoji');\n * // ...\n */\n rooms = rooms;\n\n /**\n * Use this to write data! You can create, update, delete, and link objects\n *\n * @see https://instantdb.com/docs/instaml\n *\n * @example\n * // Create a new object in the `goals` namespace\n * const goalId = id();\n * db.transact(db.tx.goals[goalId].update({title: \"Get fit\"}))\n *\n * // Update the title\n * db.transact(db.tx.goals[goalId].update({title: \"Get super fit\"}))\n *\n * // Delete it\n * db.transact(db.tx.goals[goalId].delete())\n *\n * // Or create an association:\n * todoId = id();\n * db.transact([\n * db.tx.todos[todoId].update({ title: 'Go on a run' }),\n * db.tx.goals[goalId].link({todos: todoId}),\n * ])\n */\n transact = (\n chunks: TransactionChunk<any, any> | TransactionChunk<any, any>[],\n ) => {\n return this.core.transact(chunks);\n };\n\n /**\n * Use this to query your data!\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n * // listen to all goals\n * const { isLoading, error, data } = db.useQuery({ goals: {} });\n *\n * // goals where the title is \"Get Fit\"\n * const { isLoading, error, data } = db.useQuery({\n * goals: { $: { where: { title: 'Get Fit' } } },\n * });\n *\n * // all goals, _alongside_ their todos\n * const { isLoading, error, data } = db.useQuery({\n * goals: { todos: {} },\n * });\n *\n * // skip if `user` is not logged in\n * const { isLoading, error, data } = db.useQuery(\n * auth.user ? { goals: {} } : null,\n * );\n */\n useQuery = <Q extends ValidQuery<Q, Schema>>(\n query: null | Q,\n opts?: InstaQLOptions,\n ): InstaQLLifecycleState<Schema, Q, UseDates> => {\n return useQueryInternal<Q, Schema, UseDates>(this.core, query, opts).state;\n };\n\n /**\n * Listen for the logged in state. This is useful\n * for deciding when to show a login screen.\n *\n * Check out the docs for an example `Login` component too!\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * function App() {\n * const { isLoading, user, error } = db.useAuth()\n * if (isLoading) {\n * return <div>Loading...</div>\n * }\n * if (error) {\n * return <div>Uh oh! {error.message}</div>\n * }\n * if (user) {\n * return <Main user={user} />\n * }\n * return <Login />\n * }\n *\n */\n useAuth = (): AuthState => {\n return this._useAuth();\n };\n\n protected _useAuth(): AuthState {\n // We use a ref to store the result of the query.\n // This is becuase `useSyncExternalStore` uses `Object.is`\n // to compare the previous and next state.\n // If we don't use a ref, the state will always be considered different, so\n // the component will always re-render.\n const resultCacheRef = useRef<AuthState>(\n this.core._reactor._currentUserCached,\n );\n\n // Similar to `resultCacheRef`, `useSyncExternalStore` will unsubscribe\n // if `subscribe` changes, so we use `useCallback` to memoize the function.\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeAuth((auth) => {\n resultCacheRef.current = { isLoading: false, ...auth };\n cb();\n });\n\n return unsubscribe;\n }, []);\n\n const state = useSyncExternalStore<AuthState>(\n subscribe,\n () => resultCacheRef.current,\n () => defaultAuthState,\n );\n return state;\n }\n\n /**\n * Subscribe to the currently logged in user.\n * If the user is not logged in, this hook with throw an Error.\n * You will want to protect any calls of this hook with a\n * <db.SignedIn> component, or your own logic based on db.useAuth()\n *\n * @see https://instantdb.com/docs/auth\n * @throws Error indicating user not signed in\n * @example\n * function UserDisplay() {\n * const user = db.useUser()\n * return <div>Logged in as: {user.email}</div>\n * }\n *\n * <db.SignedIn>\n * <UserDisplay />\n * </db.SignedIn>\n *\n */\n useUser = (): User => {\n const { user } = this.useAuth();\n if (!user) {\n throw new InstantError(\n 'useUser must be used within an auth-protected route',\n );\n }\n return user;\n };\n\n /**\n * One time query for the logged in state. This is useful\n * for scenarios where you want to know the current auth\n * state without subscribing to changes.\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * const user = await db.getAuth();\n * console.log('logged in as', user.email)\n */\n getAuth(): Promise<User | null> {\n return this.core.getAuth();\n }\n\n /**\n * Listen for connection status changes to Instant. Use this for things like\n * showing connection state to users\n *\n * @see https://www.instantdb.com/docs/patterns#connection-status\n * @example\n * function App() {\n * const status = db.useConnectionStatus()\n * const connectionState =\n * status === 'connecting' || status === 'opened'\n * ? 'authenticating'\n * : status === 'authenticated'\n * ? 'connected'\n * : status === 'closed'\n * ? 'closed'\n * : status === 'errored'\n * ? 'errored'\n * : 'unexpected state';\n *\n * return <div>Connection state: {connectionState}</div>\n * }\n */\n useConnectionStatus = (): ConnectionStatus => {\n const statusRef = useRef<ConnectionStatus>(\n this.core._reactor.status as ConnectionStatus,\n );\n\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeConnectionStatus((newStatus) => {\n if (newStatus !== statusRef.current) {\n statusRef.current = newStatus;\n cb();\n }\n });\n\n return unsubscribe;\n }, []);\n\n const status = useSyncExternalStore<ConnectionStatus>(\n subscribe,\n () => statusRef.current,\n // For SSR, always return 'connecting' as the initial state\n () => 'connecting',\n );\n\n return status;\n };\n\n /**\n * Use this for one-off queries.\n * Returns local data if available, otherwise fetches from the server.\n * Because we want to avoid stale data, this method will throw an error\n * if the user is offline or there is no active connection to the server.\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n *\n * const resp = await db.queryOnce({ goals: {} });\n * console.log(resp.data.goals)\n */\n queryOnce = <Q extends ValidQuery<Q, Schema>>(\n query: Q,\n opts?: InstaQLOptions,\n ): Promise<{\n data: InstaQLResponse<Schema, Q, UseDates>;\n pageInfo: PageInfoResponse<Q>;\n }> => {\n return this.core.queryOnce(query, opts);\n };\n\n /**\n * Only render children if the user is signed in.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedIn>\n * <MyComponent />\n * </db.SignedIn>\n *\n */\n SignedIn: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || !auth.user) return null;\n\n return <>{children}</>;\n };\n\n /**\n * Only render children if the user is signed out.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedOut>\n * <MyComponent />\n * </db.SignedOut>\n *\n */\n SignedOut: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || auth.user) return null;\n return <>{children}</>;\n };\n}\n"]}
@@ -8,7 +8,7 @@ export default abstract class InstantReactAbstractDatabase<Schema extends Instan
8
8
  core: InstantCoreDatabase<Schema, UseDates>;
9
9
  /** @deprecated use `core` instead */
10
10
  _core: InstantCoreDatabase<Schema, UseDates>;
11
- static Storage?: any;
11
+ static Store?: any;
12
12
  static NetworkListener?: any;
13
13
  static EventSourceImpl?: any;
14
14
  constructor(config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {
@@ -1 +1 @@
1
- {"version":3,"file":"InstantReactAbstractDatabase.d.ts","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"InstantReactAbstractDatabase.d.ts","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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"}
@@ -16,13 +16,13 @@ export default class InstantReactAbstractDatabase {
16
16
  core;
17
17
  /** @deprecated use `core` instead */
18
18
  _core;
19
- static Storage;
19
+ static Store;
20
20
  static NetworkListener;
21
21
  static EventSourceImpl;
22
22
  constructor(config, versions) {
23
23
  this.core = core_init(config,
24
24
  // @ts-expect-error because TS can't resolve subclass statics
25
- this.constructor.Storage,
25
+ config.Store || this.constructor.Store,
26
26
  // @ts-expect-error because TS can't resolve subclass statics
27
27
  this.constructor.NetworkListener, versions,
28
28
  // @ts-expect-error because TS can't resolve subclass statics
@@ -1 +1 @@
1
- {"version":3,"file":"InstantReactAbstractDatabase.js","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\nimport {\n // types\n Auth,\n Storage,\n txInit,\n type AuthState,\n type User,\n type ConnectionStatus,\n type TransactionChunk,\n type RoomSchemaShape,\n type InstaQLOptions,\n type InstantConfig,\n type PageInfoResponse,\n InstantCoreDatabase,\n init as core_init,\n InstaQLLifecycleState,\n InstaQLResponse,\n RoomsOf,\n InstantSchemaDef,\n IInstantDatabase,\n InstantError,\n ValidQuery,\n} from '@instantdb/core';\nimport {\n ReactNode,\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useQueryInternal } from './useQuery.ts';\nimport { InstantReactRoom, rooms } from './InstantReactRoom.ts';\n\nconst defaultAuthState = {\n isLoading: true,\n user: undefined,\n error: undefined,\n};\n\nexport default abstract class InstantReactAbstractDatabase<\n // need to pull this schema out to another generic for query params, not sure why\n Schema extends InstantSchemaDef<any, any, any>,\n UseDates extends boolean = false,\n Config extends InstantConfig<Schema, boolean> = InstantConfig<\n Schema,\n UseDates\n >,\n Rooms extends RoomSchemaShape = RoomsOf<Schema>,\n> implements IInstantDatabase<Schema>\n{\n public tx = txInit<Schema>();\n\n public auth: Auth;\n public storage: Storage;\n public core: InstantCoreDatabase<Schema, UseDates>;\n\n /** @deprecated use `core` instead */\n public _core: InstantCoreDatabase<Schema, UseDates>;\n\n static Storage?: any;\n static NetworkListener?: any;\n static EventSourceImpl?: any;\n\n constructor(\n config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {\n useDateObjects?: UseDates;\n },\n versions?: { [key: string]: string },\n ) {\n this.core = core_init<Schema, UseDates>(\n config,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.Storage,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.NetworkListener,\n versions,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.EventSourceImpl,\n );\n this._core = this.core;\n this.auth = this.core.auth;\n this.storage = this.core.storage;\n }\n\n /**\n * Returns a unique ID for a given `name`. It's stored in local storage,\n * so you will get the same ID across sessions.\n *\n * This is useful for generating IDs that could identify a local device or user.\n *\n * @example\n * const deviceId = await db.getLocalId('device');\n */\n getLocalId = (name: string): Promise<string> => {\n return this.core.getLocalId(name);\n };\n\n /**\n * A hook that returns a unique ID for a given `name`. localIds are\n * stored in local storage, so you will get the same ID across sessions.\n *\n * Initially returns `null`, and then loads the localId.\n *\n * @example\n * const deviceId = db.useLocalId('device');\n * if (!deviceId) return null; // loading\n * console.log('Device ID:', deviceId)\n */\n useLocalId = (name: string): string | null => {\n const [localId, setLocalId] = useState<string | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const f = async () => {\n const id = await this.getLocalId(name);\n if (!mounted) return;\n setLocalId(id);\n };\n f();\n return;\n }, [name]);\n\n return localId;\n };\n\n /**\n * Obtain a handle to a room, which allows you to listen to topics and presence data\n *\n * If you don't provide a `type` or `id`, Instant will default to `_defaultRoomType` and `_defaultRoomId`\n * as the room type and id, respectively.\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n */\n room<RoomType extends keyof Rooms>(\n type: RoomType = '_defaultRoomType' as RoomType,\n id: string = '_defaultRoomId',\n ) {\n return new InstantReactRoom<Schema, Rooms, RoomType>(this.core, type, id);\n }\n\n /**\n * Hooks for working with rooms\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n * const publish = db.rooms.usePublishTopic(room, 'emoji');\n * // ...\n */\n rooms = rooms;\n\n /**\n * Use this to write data! You can create, update, delete, and link objects\n *\n * @see https://instantdb.com/docs/instaml\n *\n * @example\n * // Create a new object in the `goals` namespace\n * const goalId = id();\n * db.transact(db.tx.goals[goalId].update({title: \"Get fit\"}))\n *\n * // Update the title\n * db.transact(db.tx.goals[goalId].update({title: \"Get super fit\"}))\n *\n * // Delete it\n * db.transact(db.tx.goals[goalId].delete())\n *\n * // Or create an association:\n * todoId = id();\n * db.transact([\n * db.tx.todos[todoId].update({ title: 'Go on a run' }),\n * db.tx.goals[goalId].link({todos: todoId}),\n * ])\n */\n transact = (\n chunks: TransactionChunk<any, any> | TransactionChunk<any, any>[],\n ) => {\n return this.core.transact(chunks);\n };\n\n /**\n * Use this to query your data!\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n * // listen to all goals\n * const { isLoading, error, data } = db.useQuery({ goals: {} });\n *\n * // goals where the title is \"Get Fit\"\n * const { isLoading, error, data } = db.useQuery({\n * goals: { $: { where: { title: 'Get Fit' } } },\n * });\n *\n * // all goals, _alongside_ their todos\n * const { isLoading, error, data } = db.useQuery({\n * goals: { todos: {} },\n * });\n *\n * // skip if `user` is not logged in\n * const { isLoading, error, data } = db.useQuery(\n * auth.user ? { goals: {} } : null,\n * );\n */\n useQuery = <Q extends ValidQuery<Q, Schema>>(\n query: null | Q,\n opts?: InstaQLOptions,\n ): InstaQLLifecycleState<Schema, Q, UseDates> => {\n return useQueryInternal<Q, Schema, UseDates>(this.core, query, opts).state;\n };\n\n /**\n * Listen for the logged in state. This is useful\n * for deciding when to show a login screen.\n *\n * Check out the docs for an example `Login` component too!\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * function App() {\n * const { isLoading, user, error } = db.useAuth()\n * if (isLoading) {\n * return <div>Loading...</div>\n * }\n * if (error) {\n * return <div>Uh oh! {error.message}</div>\n * }\n * if (user) {\n * return <Main user={user} />\n * }\n * return <Login />\n * }\n *\n */\n useAuth = (): AuthState => {\n return this._useAuth();\n };\n\n protected _useAuth(): AuthState {\n // We use a ref to store the result of the query.\n // This is becuase `useSyncExternalStore` uses `Object.is`\n // to compare the previous and next state.\n // If we don't use a ref, the state will always be considered different, so\n // the component will always re-render.\n const resultCacheRef = useRef<AuthState>(\n this.core._reactor._currentUserCached,\n );\n\n // Similar to `resultCacheRef`, `useSyncExternalStore` will unsubscribe\n // if `subscribe` changes, so we use `useCallback` to memoize the function.\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeAuth((auth) => {\n resultCacheRef.current = { isLoading: false, ...auth };\n cb();\n });\n\n return unsubscribe;\n }, []);\n\n const state = useSyncExternalStore<AuthState>(\n subscribe,\n () => resultCacheRef.current,\n () => defaultAuthState,\n );\n return state;\n }\n\n /**\n * Subscribe to the currently logged in user.\n * If the user is not logged in, this hook with throw an Error.\n * You will want to protect any calls of this hook with a\n * <db.SignedIn> component, or your own logic based on db.useAuth()\n *\n * @see https://instantdb.com/docs/auth\n * @throws Error indicating user not signed in\n * @example\n * function UserDisplay() {\n * const user = db.useUser()\n * return <div>Logged in as: {user.email}</div>\n * }\n *\n * <db.SignedIn>\n * <UserDisplay />\n * </db.SignedIn>\n *\n */\n useUser = (): User => {\n const { user } = this.useAuth();\n if (!user) {\n throw new InstantError(\n 'useUser must be used within an auth-protected route',\n );\n }\n return user;\n };\n\n /**\n * One time query for the logged in state. This is useful\n * for scenarios where you want to know the current auth\n * state without subscribing to changes.\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * const user = await db.getAuth();\n * console.log('logged in as', user.email)\n */\n getAuth(): Promise<User | null> {\n return this.core.getAuth();\n }\n\n /**\n * Listen for connection status changes to Instant. Use this for things like\n * showing connection state to users\n *\n * @see https://www.instantdb.com/docs/patterns#connection-status\n * @example\n * function App() {\n * const status = db.useConnectionStatus()\n * const connectionState =\n * status === 'connecting' || status === 'opened'\n * ? 'authenticating'\n * : status === 'authenticated'\n * ? 'connected'\n * : status === 'closed'\n * ? 'closed'\n * : status === 'errored'\n * ? 'errored'\n * : 'unexpected state';\n *\n * return <div>Connection state: {connectionState}</div>\n * }\n */\n useConnectionStatus = (): ConnectionStatus => {\n const statusRef = useRef<ConnectionStatus>(\n this.core._reactor.status as ConnectionStatus,\n );\n\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeConnectionStatus((newStatus) => {\n if (newStatus !== statusRef.current) {\n statusRef.current = newStatus;\n cb();\n }\n });\n\n return unsubscribe;\n }, []);\n\n const status = useSyncExternalStore<ConnectionStatus>(\n subscribe,\n () => statusRef.current,\n // For SSR, always return 'connecting' as the initial state\n () => 'connecting',\n );\n\n return status;\n };\n\n /**\n * Use this for one-off queries.\n * Returns local data if available, otherwise fetches from the server.\n * Because we want to avoid stale data, this method will throw an error\n * if the user is offline or there is no active connection to the server.\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n *\n * const resp = await db.queryOnce({ goals: {} });\n * console.log(resp.data.goals)\n */\n queryOnce = <Q extends ValidQuery<Q, Schema>>(\n query: Q,\n opts?: InstaQLOptions,\n ): Promise<{\n data: InstaQLResponse<Schema, Q, UseDates>;\n pageInfo: PageInfoResponse<Q>;\n }> => {\n return this.core.queryOnce(query, opts);\n };\n\n /**\n * Only render children if the user is signed in.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedIn>\n * <MyComponent />\n * </db.SignedIn>\n *\n */\n SignedIn: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || !auth.user) return null;\n\n return <>{children}</>;\n };\n\n /**\n * Only render children if the user is signed out.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedOut>\n * <MyComponent />\n * </db.SignedOut>\n *\n */\n SignedOut: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || auth.user) return null;\n return <>{children}</>;\n };\n}\n"]}
1
+ {"version":3,"file":"InstantReactAbstractDatabase.js","sourceRoot":"","sources":["../../src/InstantReactAbstractDatabase.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\nimport {\n // types\n Auth,\n Storage,\n txInit,\n type AuthState,\n type User,\n type ConnectionStatus,\n type TransactionChunk,\n type RoomSchemaShape,\n type InstaQLOptions,\n type InstantConfig,\n type PageInfoResponse,\n InstantCoreDatabase,\n init as core_init,\n InstaQLLifecycleState,\n InstaQLResponse,\n RoomsOf,\n InstantSchemaDef,\n IInstantDatabase,\n InstantError,\n ValidQuery,\n} from '@instantdb/core';\nimport {\n ReactNode,\n useCallback,\n useEffect,\n useRef,\n useState,\n useSyncExternalStore,\n} from 'react';\nimport { useQueryInternal } from './useQuery.ts';\nimport { InstantReactRoom, rooms } from './InstantReactRoom.ts';\n\nconst defaultAuthState = {\n isLoading: true,\n user: undefined,\n error: undefined,\n};\n\nexport default abstract class InstantReactAbstractDatabase<\n // need to pull this schema out to another generic for query params, not sure why\n Schema extends InstantSchemaDef<any, any, any>,\n UseDates extends boolean = false,\n Config extends InstantConfig<Schema, boolean> = InstantConfig<\n Schema,\n UseDates\n >,\n Rooms extends RoomSchemaShape = RoomsOf<Schema>,\n> implements IInstantDatabase<Schema>\n{\n public tx = txInit<Schema>();\n\n public auth: Auth;\n public storage: Storage;\n public core: InstantCoreDatabase<Schema, UseDates>;\n\n /** @deprecated use `core` instead */\n public _core: InstantCoreDatabase<Schema, UseDates>;\n\n static Store?: any;\n static NetworkListener?: any;\n static EventSourceImpl?: any;\n\n constructor(\n config: Omit<InstantConfig<Schema, UseDates>, 'useDateObjects'> & {\n useDateObjects?: UseDates;\n },\n versions?: { [key: string]: string },\n ) {\n this.core = core_init<Schema, UseDates>(\n config,\n // @ts-expect-error because TS can't resolve subclass statics\n config.Store || this.constructor.Store,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.NetworkListener,\n versions,\n // @ts-expect-error because TS can't resolve subclass statics\n this.constructor.EventSourceImpl,\n );\n this._core = this.core;\n this.auth = this.core.auth;\n this.storage = this.core.storage;\n }\n\n /**\n * Returns a unique ID for a given `name`. It's stored in local storage,\n * so you will get the same ID across sessions.\n *\n * This is useful for generating IDs that could identify a local device or user.\n *\n * @example\n * const deviceId = await db.getLocalId('device');\n */\n getLocalId = (name: string): Promise<string> => {\n return this.core.getLocalId(name);\n };\n\n /**\n * A hook that returns a unique ID for a given `name`. localIds are\n * stored in local storage, so you will get the same ID across sessions.\n *\n * Initially returns `null`, and then loads the localId.\n *\n * @example\n * const deviceId = db.useLocalId('device');\n * if (!deviceId) return null; // loading\n * console.log('Device ID:', deviceId)\n */\n useLocalId = (name: string): string | null => {\n const [localId, setLocalId] = useState<string | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const f = async () => {\n const id = await this.getLocalId(name);\n if (!mounted) return;\n setLocalId(id);\n };\n f();\n return;\n }, [name]);\n\n return localId;\n };\n\n /**\n * Obtain a handle to a room, which allows you to listen to topics and presence data\n *\n * If you don't provide a `type` or `id`, Instant will default to `_defaultRoomType` and `_defaultRoomId`\n * as the room type and id, respectively.\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n */\n room<RoomType extends keyof Rooms>(\n type: RoomType = '_defaultRoomType' as RoomType,\n id: string = '_defaultRoomId',\n ) {\n return new InstantReactRoom<Schema, Rooms, RoomType>(this.core, type, id);\n }\n\n /**\n * Hooks for working with rooms\n *\n * @see https://instantdb.com/docs/presence-and-topics\n *\n * @example\n * const room = db.room('chat', roomId);\n * const { peers } = db.rooms.usePresence(room);\n * const publish = db.rooms.usePublishTopic(room, 'emoji');\n * // ...\n */\n rooms = rooms;\n\n /**\n * Use this to write data! You can create, update, delete, and link objects\n *\n * @see https://instantdb.com/docs/instaml\n *\n * @example\n * // Create a new object in the `goals` namespace\n * const goalId = id();\n * db.transact(db.tx.goals[goalId].update({title: \"Get fit\"}))\n *\n * // Update the title\n * db.transact(db.tx.goals[goalId].update({title: \"Get super fit\"}))\n *\n * // Delete it\n * db.transact(db.tx.goals[goalId].delete())\n *\n * // Or create an association:\n * todoId = id();\n * db.transact([\n * db.tx.todos[todoId].update({ title: 'Go on a run' }),\n * db.tx.goals[goalId].link({todos: todoId}),\n * ])\n */\n transact = (\n chunks: TransactionChunk<any, any> | TransactionChunk<any, any>[],\n ) => {\n return this.core.transact(chunks);\n };\n\n /**\n * Use this to query your data!\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n * // listen to all goals\n * const { isLoading, error, data } = db.useQuery({ goals: {} });\n *\n * // goals where the title is \"Get Fit\"\n * const { isLoading, error, data } = db.useQuery({\n * goals: { $: { where: { title: 'Get Fit' } } },\n * });\n *\n * // all goals, _alongside_ their todos\n * const { isLoading, error, data } = db.useQuery({\n * goals: { todos: {} },\n * });\n *\n * // skip if `user` is not logged in\n * const { isLoading, error, data } = db.useQuery(\n * auth.user ? { goals: {} } : null,\n * );\n */\n useQuery = <Q extends ValidQuery<Q, Schema>>(\n query: null | Q,\n opts?: InstaQLOptions,\n ): InstaQLLifecycleState<Schema, Q, UseDates> => {\n return useQueryInternal<Q, Schema, UseDates>(this.core, query, opts).state;\n };\n\n /**\n * Listen for the logged in state. This is useful\n * for deciding when to show a login screen.\n *\n * Check out the docs for an example `Login` component too!\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * function App() {\n * const { isLoading, user, error } = db.useAuth()\n * if (isLoading) {\n * return <div>Loading...</div>\n * }\n * if (error) {\n * return <div>Uh oh! {error.message}</div>\n * }\n * if (user) {\n * return <Main user={user} />\n * }\n * return <Login />\n * }\n *\n */\n useAuth = (): AuthState => {\n return this._useAuth();\n };\n\n protected _useAuth(): AuthState {\n // We use a ref to store the result of the query.\n // This is becuase `useSyncExternalStore` uses `Object.is`\n // to compare the previous and next state.\n // If we don't use a ref, the state will always be considered different, so\n // the component will always re-render.\n const resultCacheRef = useRef<AuthState>(\n this.core._reactor._currentUserCached,\n );\n\n // Similar to `resultCacheRef`, `useSyncExternalStore` will unsubscribe\n // if `subscribe` changes, so we use `useCallback` to memoize the function.\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeAuth((auth) => {\n resultCacheRef.current = { isLoading: false, ...auth };\n cb();\n });\n\n return unsubscribe;\n }, []);\n\n const state = useSyncExternalStore<AuthState>(\n subscribe,\n () => resultCacheRef.current,\n () => defaultAuthState,\n );\n return state;\n }\n\n /**\n * Subscribe to the currently logged in user.\n * If the user is not logged in, this hook with throw an Error.\n * You will want to protect any calls of this hook with a\n * <db.SignedIn> component, or your own logic based on db.useAuth()\n *\n * @see https://instantdb.com/docs/auth\n * @throws Error indicating user not signed in\n * @example\n * function UserDisplay() {\n * const user = db.useUser()\n * return <div>Logged in as: {user.email}</div>\n * }\n *\n * <db.SignedIn>\n * <UserDisplay />\n * </db.SignedIn>\n *\n */\n useUser = (): User => {\n const { user } = this.useAuth();\n if (!user) {\n throw new InstantError(\n 'useUser must be used within an auth-protected route',\n );\n }\n return user;\n };\n\n /**\n * One time query for the logged in state. This is useful\n * for scenarios where you want to know the current auth\n * state without subscribing to changes.\n *\n * @see https://instantdb.com/docs/auth\n * @example\n * const user = await db.getAuth();\n * console.log('logged in as', user.email)\n */\n getAuth(): Promise<User | null> {\n return this.core.getAuth();\n }\n\n /**\n * Listen for connection status changes to Instant. Use this for things like\n * showing connection state to users\n *\n * @see https://www.instantdb.com/docs/patterns#connection-status\n * @example\n * function App() {\n * const status = db.useConnectionStatus()\n * const connectionState =\n * status === 'connecting' || status === 'opened'\n * ? 'authenticating'\n * : status === 'authenticated'\n * ? 'connected'\n * : status === 'closed'\n * ? 'closed'\n * : status === 'errored'\n * ? 'errored'\n * : 'unexpected state';\n *\n * return <div>Connection state: {connectionState}</div>\n * }\n */\n useConnectionStatus = (): ConnectionStatus => {\n const statusRef = useRef<ConnectionStatus>(\n this.core._reactor.status as ConnectionStatus,\n );\n\n const subscribe = useCallback((cb: Function) => {\n const unsubscribe = this.core.subscribeConnectionStatus((newStatus) => {\n if (newStatus !== statusRef.current) {\n statusRef.current = newStatus;\n cb();\n }\n });\n\n return unsubscribe;\n }, []);\n\n const status = useSyncExternalStore<ConnectionStatus>(\n subscribe,\n () => statusRef.current,\n // For SSR, always return 'connecting' as the initial state\n () => 'connecting',\n );\n\n return status;\n };\n\n /**\n * Use this for one-off queries.\n * Returns local data if available, otherwise fetches from the server.\n * Because we want to avoid stale data, this method will throw an error\n * if the user is offline or there is no active connection to the server.\n *\n * @see https://instantdb.com/docs/instaql\n *\n * @example\n *\n * const resp = await db.queryOnce({ goals: {} });\n * console.log(resp.data.goals)\n */\n queryOnce = <Q extends ValidQuery<Q, Schema>>(\n query: Q,\n opts?: InstaQLOptions,\n ): Promise<{\n data: InstaQLResponse<Schema, Q, UseDates>;\n pageInfo: PageInfoResponse<Q>;\n }> => {\n return this.core.queryOnce(query, opts);\n };\n\n /**\n * Only render children if the user is signed in.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedIn>\n * <MyComponent />\n * </db.SignedIn>\n *\n */\n SignedIn: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || !auth.user) return null;\n\n return <>{children}</>;\n };\n\n /**\n * Only render children if the user is signed out.\n * @see https://instantdb.com/docs/auth\n *\n * @example\n * <db.SignedOut>\n * <MyComponent />\n * </db.SignedOut>\n *\n */\n SignedOut: React.FC<{\n children: ReactNode;\n }> = ({ children }) => {\n const auth = this.useAuth();\n if (auth.isLoading || auth.error || auth.user) return null;\n return <>{children}</>;\n };\n}\n"]}
@@ -4110,7 +4110,7 @@ function sr(t) {
4110
4110
  }, e;
4111
4111
  }, {});
4112
4112
  }
4113
- const Yr = "v0.22.112";
4113
+ const Yr = "v0.22.113-experimental.dwwoelfel-patch-2.21374029739.1";
4114
4114
  function wa(t, e) {
4115
4115
  return {
4116
4116
  info: t ? (...n) => console.info(...n, e()) : () => {
@@ -7401,7 +7401,7 @@ class It {
7401
7401
  this.core = dc(
7402
7402
  e,
7403
7403
  // @ts-expect-error because TS can't resolve subclass statics
7404
- this.constructor.Storage,
7404
+ e.Store || this.constructor.Store,
7405
7405
  // @ts-expect-error because TS can't resolve subclass statics
7406
7406
  this.constructor.NetworkListener,
7407
7407
  n,
@@ -7450,7 +7450,7 @@ class It {
7450
7450
  return this.core.getAuth();
7451
7451
  }
7452
7452
  }
7453
- p(It, "Storage"), p(It, "NetworkListener"), p(It, "EventSourceImpl");
7453
+ p(It, "Store"), p(It, "NetworkListener"), p(It, "EventSourceImpl");
7454
7454
  export {
7455
7455
  It as InstantReactAbstractDatabase
7456
7456
  };
@@ -27,10 +27,10 @@ Check the top-level render call using <`+S+">.")}return _}}function Hr(f,_){{if(
27
27
  <%s {...props} />
28
28
  React keys must be passed directly to JSX without using spread:
29
29
  let props = %s;
30
- <%s key={someKey} {...props} />`,an,we,pc,we),Yr[we+an]=!0}}return f===s?uc(L):cc(L),L}}function lc(f,_,S){return Zr(f,_,S,!0)}function fc(f,_,S){return Zr(f,_,S,!1)}var dc=fc,hc=lc;Ie.Fragment=s,Ie.jsx=dc,Ie.jsxs=hc}(),Ie}var ts={};ts.NODE_ENV==="production"?fe.exports=Xr():fe.exports=es();var We=fe.exports;function F(t){if(typeof t=="number")return(Math.abs(t*2654435761)>>>0).toString(16);if(typeof t=="boolean")return t?"1":"0";if(t===null)return"null";if(t===void 0)return"undefined";if(typeof t=="string"){let e=2166136261;for(let n=0;n<t.length;n++)e^=t.charCodeAt(n),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(t)){let e=2166136261;for(let n=0;n<t.length;n++){e^=(n+1)*2654435761;const r=F(t[n]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof t=="object"){let e=2166136261;const n=Object.keys(t).sort();for(let r=0;r<n.length;r++){const s=n[r],i=F(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=F(t[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return F(String(t))}const x={Remove:"remove",Replace:"replace",Add:"add"},ln=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),ns=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Qe=Symbol.iterator,Y={mutable:"mutable",immutable:"immutable"},pt={};function Me(t,e){return t instanceof Map?t.has(e):Object.prototype.hasOwnProperty.call(t,e)}function fn(t,e){if(e in t){let n=Reflect.getPrototypeOf(t);for(;n;){const r=Reflect.getOwnPropertyDescriptor(n,e);if(r)return r;n=Reflect.getPrototypeOf(n)}}}function yt(t){return Object.getPrototypeOf(t)===Set.prototype}function bt(t){return Object.getPrototypeOf(t)===Map.prototype}function Z(t){var e;return(e=t.copy)!==null&&e!==void 0?e:t.original}function he(t){return!!P(t)}function P(t){return typeof t!="object"?null:t==null?void 0:t[ln]}function _t(t){var e;const n=P(t);return n?(e=n.copy)!==null&&e!==void 0?e:n.original:t}function te(t,e){if(!t||typeof t!="object")return!1;let n;return Object.getPrototypeOf(t)===Object.prototype||Array.isArray(t)||t instanceof Map||t instanceof Set||!!(e!=null&&e.mark)&&((n=e.mark(t,Y))===Y.immutable||typeof n=="function")}function dn(t,e=[]){if(Object.hasOwnProperty.call(t,"key")){const n=t.parent.copy,r=P(ae(n,t.key));if(r!==null&&(r==null?void 0:r.original)!==t.original)return null;const s=t.parent.type===3,i=s?Array.from(t.parent.setMap.keys()).indexOf(t.key):t.key;if(!(s&&n.size>i||Me(n,i)))return null;e.push(i)}if(t.parent)return dn(t.parent,e);e.reverse();try{rs(t.copy,e)}catch{return null}return e}function pe(t){return Array.isArray(t)?1:t instanceof Map?2:t instanceof Set?3:0}function ae(t,e){return pe(t)===2?t.get(e):t[e]}function je(t,e,n){pe(t)===2?t.set(e,n):t[e]=n}function gt(t,e){const n=P(t);return(n?Z(n):t)[e]}function ce(t,e){return t===e?t!==0||1/t===1/e:t!==t&&e!==e}function Tt(t){if(t)for(;t.finalities.revoke.length>0;)t.finalities.revoke.pop()()}function ye(t,e){return e?t:[""].concat(t).map(n=>{const r=`${n}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function rs(t,e){for(let n=0;n<e.length-1;n+=1){const r=e[n];if(t=ae(pe(t)===3?Array.from(t):t,r),typeof t!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return t}function ss(t){const e=Object.create(Object.getPrototypeOf(t));return Reflect.ownKeys(t).forEach(n=>{let r=Reflect.getOwnPropertyDescriptor(t,n);if(r.enumerable&&r.configurable&&r.writable){e[n]=t[n];return}r.writable||(r.writable=!0,r.configurable=!0),(r.get||r.set)&&(r={configurable:!0,writable:!0,enumerable:r.enumerable,value:t[n]}),Reflect.defineProperty(e,n,r)}),e}const is=Object.prototype.propertyIsEnumerable;function hn(t,e){let n;if(Array.isArray(t))return Array.prototype.concat.call(t);if(t instanceof Set){if(!yt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t.values())}return Set.prototype.difference?Set.prototype.difference.call(t,new Set):new Set(t.values())}else if(t instanceof Map){if(!bt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t)}return new Map(t)}else if(e!=null&&e.mark&&(n=e.mark(t,Y),n!==void 0)&&n!==Y.mutable){if(n===Y.immutable)return ss(t);if(typeof n=="function"){if(e.enablePatches||e.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return n()}throw new Error(`Unsupported mark result: ${n}`)}else if(typeof t=="object"&&Object.getPrototypeOf(t)===Object.prototype){const r={};return Object.keys(t).forEach(s=>{r[s]=t[s]}),Object.getOwnPropertySymbols(t).forEach(s=>{is.call(t,s)&&(r[s]=t[s])}),r}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function q(t){t.copy||(t.copy=hn(t.original,t.options))}function Re(t){if(!te(t))return _t(t);if(Array.isArray(t))return t.map(Re);if(t instanceof Map){const n=Array.from(t.entries()).map(([r,s])=>[r,Re(s)]);if(!bt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Map(n)}if(t instanceof Set){const n=Array.from(t).map(Re);if(!yt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Set(n)}const e=Object.create(Object.getPrototypeOf(t));for(const n in t)e[n]=Re(t[n]);return e}function Be(t){return he(t)?Re(t):t}function ie(t){var e;t.assignedMap=(e=t.assignedMap)!==null&&e!==void 0?e:new Map,t.operated||(t.operated=!0,t.parent&&ie(t.parent))}function pn(){throw new Error("Cannot modify frozen object")}function me(t,e,n,r,s){{n=n??new WeakMap,r=r??[],s=s??[];const o=n.has(t)?n.get(t):t;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(t)||he(t)){r.pop(),s.pop();return}switch(pe(t)){case 2:for(const[a,c]of t)me(a,a,n,r,s),me(c,a,n,r,s);t.set=t.clear=t.delete=pn;break;case 3:for(const a of t)me(a,a,n,r,s);t.add=t.clear=t.delete=pn;break;case 1:Object.freeze(t);let o=0;for(const a of t)me(a,o,n,r,s),o+=1;break;default:Object.freeze(t),Object.keys(t).forEach(a=>{const c=t[a];me(c,a,n,r,s)})}r.pop(),s.pop()}function wt(t,e){const n=pe(t);if(n===0)Reflect.ownKeys(t).forEach(r=>{e(r,t[r],t)});else if(n===1){let r=0;for(const s of t)e(r,s,t),r+=1}else t.forEach((r,s)=>e(s,r,t))}function yn(t,e,n){if(he(t)||!te(t,n)||e.has(t)||Object.isFrozen(t))return;const r=t instanceof Set,s=r?new Map:void 0;if(e.add(t),wt(t,(i,o)=>{var a;if(he(o)){const c=P(o);q(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;je(r?s:t,i,u)}else yn(o,e,n)}),s){const i=t,o=Array.from(i);i.clear(),o.forEach(a=>{i.add(s.has(a)?s.get(a):a)})}}function os(t,e){const n=t.type===3?t.setMap:t.copy;t.finalities.revoke.length>1&&t.assignedMap.get(e)&&n&&yn(ae(n,e),t.finalities.handledSet,t.options)}function mt(t){t.type===3&&t.copy&&(t.copy.clear(),t.setMap.forEach(e=>{t.copy.add(_t(e))}))}function St(t,e,n,r){if(t.operated&&t.assignedMap&&t.assignedMap.size>0&&!t.finalized){if(n&&r){const i=dn(t);i&&e(t,i,n,r)}t.finalized=!0}}function vt(t,e,n,r){const s=P(n);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=t.type===3?t.setMap:t.copy;if(ce(ae(c,e),n)){let u=s.original;s.copy&&(u=s.copy),mt(t),St(t,r,i,o),t.options.enableAutoFreeze&&(t.options.updatedValues=(a=t.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,t.options.updatedValues.set(u,s.original)),je(c,e,u)}}),t.options.enableAutoFreeze&&s.finalities!==t.finalities&&(t.options.enableAutoFreeze=!1)),te(n,t.options)&&t.finalities.draft.push(()=>{const i=t.type===3?t.setMap:t.copy;ce(ae(i,e),n)&&os(t,e)})}function as(t,e,n,r,s){let{original:i,assignedMap:o,options:a}=t,c=t.copy;c.length<i.length&&([i,c]=[c,i],[n,r]=[r,n]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),d=ye(l,s);n.push({op:x.Replace,path:d,value:Be(c[u])}),r.push({op:x.Replace,path:d,value:Be(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),d=ye(l,s);n.push({op:x.Add,path:d,value:Be(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),d=ye(l,s);r.push({op:x.Replace,path:d,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const d=e.concat([l-1]),h=ye(d,s);r.push({op:x.Remove,path:h})}}}function cs({original:t,copy:e,assignedMap:n},r,s,i,o){n.forEach((a,c)=>{const u=ae(t,c),l=Be(ae(e,c)),d=a?Me(t,c)?x.Replace:x.Add:x.Remove;if(ce(u,l)&&d===x.Replace)return;const h=r.concat(c),y=ye(h,o);s.push(d===x.Remove?{op:d,path:y}:{op:d,path:y,value:l}),i.push(d===x.Add?{op:x.Remove,path:y}:d===x.Remove?{op:x.Add,path:y,value:u}:{op:x.Replace,path:y,value:u})})}function us({original:t,copy:e},n,r,s,i){let o=0;t.forEach(a=>{if(!e.has(a)){const c=n.concat([o]),u=ye(c,i);r.push({op:x.Remove,path:u,value:a}),s.unshift({op:x.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!t.has(a)){const c=n.concat([o]),u=ye(c,i);r.push({op:x.Add,path:u,value:a}),s.unshift({op:x.Remove,path:u,value:a})}o+=1})}function De(t,e,n,r){const{pathAsArray:s=!0}=t.options.enablePatches;switch(t.type){case 0:case 2:return cs(t,e,n,r,s);case 1:return as(t,e,n,r,s);case 3:return us(t,e,n,r,s)}}const Ge=(t,e,n=!1)=>{if(typeof t=="object"&&t!==null&&(!te(t,e)||n))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},At={get size(){return Z(P(this)).size},has(t){return Z(P(this)).has(t)},set(t,e){const n=P(this),r=Z(n);return(!r.has(t)||!ce(r.get(t),e))&&(q(n),ie(n),n.assignedMap.set(t,!0),n.copy.set(t,e),vt(n,t,e,De)),this},delete(t){if(!this.has(t))return!1;const e=P(this);return q(e),ie(e),e.original.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.copy.delete(t),!0},clear(){const t=P(this);if(this.size){q(t),ie(t),t.assignedMap=new Map;for(const[e]of t.original)t.assignedMap.set(e,!1);t.copy.clear()}},forEach(t,e){const n=P(this);Z(n).forEach((r,s)=>{t.call(e,this.get(s),s,this)})},get(t){var e,n;const r=P(this),s=Z(r).get(t),i=((n=(e=r.options).mark)===null||n===void 0?void 0:n.call(e,s,Y))===Y.mutable;if(r.options.strict&&Ge(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(t))return s;const o=pt.createDraft({original:s,parentDraft:r,key:t,finalities:r.finalities,options:r.options});return q(r),r.copy.set(t,o),o},keys(){return Z(P(this)).keys()},values(){const t=this.keys();return{[Qe]:()=>this.values(),next:()=>{const e=t.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const t=this.keys();return{[Qe]:()=>this.entries(),next:()=>{const e=t.next();if(e.done)return e;const n=this.get(e.value);return{done:!1,value:[e.value,n]}}}},[Qe](){return this.entries()}},ls=Reflect.ownKeys(At),bn=(t,e,{isValuesIterator:n})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=t.setMap.get(o);const c=P(a),u=((s=(r=t.options).mark)===null||s===void 0?void 0:s.call(r,a,Y))===Y.mutable;if(t.options.strict&&Ge(o,t.options,u),!u&&!c&&te(o,t.options)&&!t.finalized&&t.original.has(o)){const l=pt.createDraft({original:o,parentDraft:t,key:o,finalities:t.finalities,options:t.options});t.setMap.set(o,l),a=l}else c&&(a=c.proxy);return{done:!1,value:n?a:[a,a]}},He={get size(){return P(this).setMap.size},has(t){const e=P(this);if(e.setMap.has(t))return!0;q(e);const n=P(t);return!!(n&&e.setMap.has(n.original))},add(t){const e=P(this);return this.has(t)||(q(e),ie(e),e.assignedMap.set(t,!0),e.setMap.set(t,t),vt(e,t,t,De)),this},delete(t){if(!this.has(t))return!1;const e=P(this);q(e),ie(e);const n=P(t);return n&&e.setMap.has(n.original)?(e.assignedMap.set(n.original,!1),e.setMap.delete(n.original)):(!n&&e.setMap.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.setMap.delete(t))},clear(){if(!this.size)return;const t=P(this);q(t),ie(t);for(const e of t.original)t.assignedMap.set(e,!1);t.setMap.clear()},values(){const t=P(this);q(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:bn(t,e,{isValuesIterator:!0})}},entries(){const t=P(this);q(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:bn(t,e,{isValuesIterator:!1})}},keys(){return this.values()},[Qe](){return this.values()},forEach(t,e){const n=this.values();let r=n.next();for(;!r.done;)t.call(e,r.value,r.value,this),r=n.next()}};Set.prototype.difference&&Object.assign(He,{intersection(t){return Set.prototype.intersection.call(new Set(this.values()),t)},union(t){return Set.prototype.union.call(new Set(this.values()),t)},difference(t){return Set.prototype.difference.call(new Set(this.values()),t)},symmetricDifference(t){return Set.prototype.symmetricDifference.call(new Set(this.values()),t)},isSubsetOf(t){return Set.prototype.isSubsetOf.call(new Set(this.values()),t)},isSupersetOf(t){return Set.prototype.isSupersetOf.call(new Set(this.values()),t)},isDisjointFrom(t){return Set.prototype.isDisjointFrom.call(new Set(this.values()),t)}});const fs=Reflect.ownKeys(He),_n=new WeakSet,gn={get(t,e,n){var r,s;const i=(r=t.copy)===null||r===void 0?void 0:r[e];if(i&&_n.has(i))return i;if(e===ln)return t;let o;if(t.options.mark){const u=e==="size"&&(t.original instanceof Map||t.original instanceof Set)?Reflect.get(t.original,e):Reflect.get(t.original,e,n);if(o=t.options.mark(u,Y),o===Y.mutable)return t.options.strict&&Ge(u,t.options,!0),u}const a=Z(t);if(a instanceof Map&&ls.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(At,"size").get.call(t.proxy);const u=At[e];if(u)return u.bind(t.proxy)}if(a instanceof Set&&fs.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(He,"size").get.call(t.proxy);const u=He[e];if(u)return u.bind(t.proxy)}if(!Me(a,e)){const u=fn(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(t.proxy):void 0}const c=a[e];if(t.options.strict&&Ge(c,t.options),t.finalized||!te(c,t.options))return c;if(c===gt(t.original,e)){if(q(t),t.copy[e]=Et({original:t.original[e],parentDraft:t,key:t.type===1?Number(e):e,finalities:t.finalities,options:t.options}),typeof o=="function"){const u=P(t.copy[e]);return q(u),ie(u),u.copy}return t.copy[e]}return c},set(t,e,n){var r;if(t.type===3||t.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(t.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=fn(Z(t),e);if(i!=null&&i.set)return i.set.call(t.proxy,n),!0;const o=gt(Z(t),e),a=P(o);return a&&ce(a.original,n)?(t.copy[e]=n,t.assignedMap=(r=t.assignedMap)!==null&&r!==void 0?r:new Map,t.assignedMap.set(e,!1),!0):(ce(n,o)&&(n!==void 0||Me(t.original,e))||(q(t),ie(t),Me(t.original,e)&&ce(n,t.original[e])?t.assignedMap.delete(e):t.assignedMap.set(e,!0),t.copy[e]=n,vt(t,e,n,De)),!0)},has(t,e){return e in Z(t)},ownKeys(t){return Reflect.ownKeys(Z(t))},getOwnPropertyDescriptor(t,e){const n=Z(t),r=Reflect.getOwnPropertyDescriptor(n,e);return r&&{writable:!0,configurable:t.type!==1||e!=="length",enumerable:r.enumerable,value:n[e]}},getPrototypeOf(t){return Reflect.getPrototypeOf(t.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(t,e){var n;return t.type===1?gn.set.call(this,t,e,void 0,t.proxy):(gt(t.original,e)!==void 0||e in t.original?(q(t),ie(t),t.assignedMap.set(e,!1)):(t.assignedMap=(n=t.assignedMap)!==null&&n!==void 0?n:new Map,t.assignedMap.delete(e)),t.copy&&delete t.copy[e],!0)}};function Et(t){const{original:e,parentDraft:n,key:r,finalities:s,options:i}=t,o=pe(e),a={type:o,finalized:!1,parent:n,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in t)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,gn);if(s.revoke.push(u),_n.add(c),a.proxy=c,n){const l=n;l.finalities.draft.push((d,h)=>{var y,b;const g=P(c);let w=l.type===3?l.setMap:l.copy;const m=ae(w,r),T=P(m);if(T){let v=T.original;T.operated&&(v=_t(m)),mt(T),St(T,De,d,h),l.options.enableAutoFreeze&&(l.options.updatedValues=(y=l.options.updatedValues)!==null&&y!==void 0?y:new WeakMap,l.options.updatedValues.set(v,T.original)),je(w,r,v)}(b=g.callbacks)===null||b===void 0||b.forEach(v=>{v(d,h)})})}else{const l=P(c);l.finalities.draft.push((d,h)=>{mt(l),St(l,De,d,h)})}return c}pt.createDraft=Et;function ds(t,e,n,r,s){var i;const o=P(t),a=(i=o==null?void 0:o.original)!==null&&i!==void 0?i:t,c=!!e.length;if(o!=null&&o.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(n,r);const u=c?e[0]:o?o.operated?o.copy:o.original:t;return o&&Tt(o),s&&me(u,u,o==null?void 0:o.options.updatedValues),[u,n&&c?[{op:x.Replace,path:[],value:e[0]}]:n,r&&c?[{op:x.Replace,path:[],value:a}]:r]}function hs(t,e){var n;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((n=e.mark)===null||n===void 0?void 0:n.call(e,t,Y))===Y.mutable||!te(t,e)?t:Et({original:t,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=ds(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function Ot(t){const{rootDraft:e,value:n,useRawReturn:r=!1,isRoot:s=!0}=t;wt(n,(i,o,a)=>{const c=P(o);if(c&&e&&c.finalities===e.finalities){t.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(d=>a.add(i===d?u:d))}else je(a,i,u)}else typeof o=="object"&&o!==null&&(t.value=o,t.isRoot=!1,Ot(t))}),s&&(t.isContainDraft||console.warn("The return value does not contain any draft, please use 'rawReturn()' to wrap the return value to improve performance."),r&&console.warn("The return value contains drafts, please don't use 'rawReturn()' to wrap the return value."))}function Tn(t){var e;const n=P(t);if(!te(t,n==null?void 0:n.options))return t;const r=pe(t);if(n&&!n.operated)return n.original;let s;function i(){s=r===2?bt(t)?new Map(t):new(Object.getPrototypeOf(t)).constructor(t):r===3?Array.from(n.setMap.values()):hn(t,n==null?void 0:n.options)}if(n){n.finalized=!0;try{i()}finally{n.finalized=!1}}else s=t;if(wt(s,(o,a)=>{if(n&&ce(ae(n.original,o),a))return;const c=Tn(a);c!==a&&(s===t&&i(),je(s,o,c))}),r===3){const o=(e=n==null?void 0:n.original)!==null&&e!==void 0?e:s;return yt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function wn(t){if(!he(t))throw new Error(`current() is only used for Draft, parameter: ${t}`);return Tn(t)}const Je=(t=>function e(n,r,s){var i,o,a;if(typeof n=="function"&&typeof r!="function")return function(A,...R){return e(A,K=>n.call(this,K,...R),r)};const c=n,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},t),l);const d=he(c)?wn(c):c,h=Array.isArray(l.mark)?(A,R)=>{for(const K of l.mark){if(typeof K!="function")throw new Error(`Invalid mark: ${K}, 'mark' should be a function.`);const V=K(A,R);if(V)return V}}:l.mark,y=(i=l.enablePatches)!==null&&i!==void 0?i:!1,b=(o=l.strict)!==null&&o!==void 0?o:!1,w={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:h,strict:b,enablePatches:y};if(!te(d,w)&&typeof d=="object"&&d!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[m,T]=hs(d,w);if(typeof r!="function"){if(!te(d,w))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[m,T]}let v;try{v=u(m)}catch(A){throw Tt(P(m)),A}const k=A=>{const R=P(m);if(!he(A)){if(A!==void 0&&!ce(A,m)&&(R!=null&&R.operated))throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const V=A==null?void 0:A[ns];if(V){const ze=V[0];return w.strict&&typeof A=="object"&&A!==null&&Ot({rootDraft:R,value:A,useRawReturn:!0}),T([ze])}if(A!==void 0)return typeof A=="object"&&A!==null&&Ot({rootDraft:R,value:A}),T([A])}if(A===m||A===void 0)return T([]);const K=P(A);if(w===K.options){if(K.operated)throw new Error("Cannot return a modified child draft.");return T([wn(A)])}return T([A])};return v instanceof Promise?v.then(k,A=>{throw Tt(P(m)),A}):k(v)})();Object.prototype.constructor.toString();function mn(t,e){const n=Object.keys(t),r=Object.keys(e);return n.length===r.length&&Object.keys(t).every(s=>e.hasOwnProperty(s))}function Sn(t,e){return Object.keys(t).length===Object.keys(e).length&&Object.keys(t).every(n=>e.hasOwnProperty(n)&&t[n]===e[n])}function Ye(t,e){return typeof t!="object"||typeof e!="object"||t===null||e===null?t===e:mn(t,e)?Object.keys(t).every(n=>Ye(t[n],e[n])):!1}function kt(t){if(!xe(t))return t;const e={};for(const[n,r]of Object.entries(t))r!==void 0&&(e[n]=r);return e}function vn(t,e){if(!xe(t)||!xe(e))return e;const n={...t};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete n[r];continue}const s=xe(t[r])&&xe(e[r]);n[r]=s?vn(t[r],e[r]):e[r]}return n}function xe(t){return typeof t=="object"&&t!==null&&!Array.isArray(t)}function ps(t,e,n){if(!t||e.length===0)return;let r=t||{};for(let i=0;i<e.length-1;i++){const o=e[i];(!(o in r)||typeof r[o]!="object")&&(r[o]=typeof e[i+1]=="number"?[]:{}),r=r[o]}const s=e[e.length-1];Array.isArray(r)&&typeof s=="number"?r.splice(s,0,n):r[s]=n}function An(t,e,n){if(!t||e.length===0)return;let r=t||{};for(let s=0;s<e.length-1;s++){const i=e[s];(!(i in r)||typeof r[i]!="object")&&(r[i]=typeof e[s+1]=="number"?[]:{}),r=r[i]}r[e[e.length-1]]=n}function En(t,e){if(!t||e.length===0)return;const[n,...r]=e;if(n in t){if(r.length===0){Array.isArray(t)?t.splice(n,1):delete t[n];return}En(t[n],r),ys(t[n])&&delete t[n]}}function ys(t){return t&&Object.keys(t).length===0}const On=/ZULU|YEKT|YEKST|YAPT|YAKT|YAKST|XJT|WGT|WGST|WFT|WETDST|WET|WDT|WAT|WAST|WAKT|WADT|VUT|VOLT|VLAT|VLAST|VET|UZT|UZST|UYT|UYST|UTC|UT|ULAT|ULAST|UCT|TVT|TRUT|TOT|TMT|TKT|TJT|TFT|TAHT|SGT|SCT|SAST|SADT|RET|PYT|PYST|PWT|PST|PONT|PMST|PMDT|PKT|PKST|PHT|PGT|PETT|PETST|PET|PDT|OMST|OMSST|NZT|NZST|NZDT|NUT|NST|NPT|NOVT|NOVST|NFT|NDT|MYT|MVT|MUT|MUST|MST|MSK|MSD|MPT|MMT|MHT|MEZ|METDST|MET|MESZ|MEST|MDT|MAWT|MART|MAGT|MAGST|LKT|LINT|LIGT|LHST|LHDT|KST|KRAT|KRAST|KOST|KGT|KGST|KDT|JST|JAYT|IST|IRT|IRKT|IRKST|IOT|IDT|ICT|HST|HKT|GYT|GMT|GILT|GFT|GET|GEST|GAMT|GALT|FNT|FNST|FKT|FKST|FJT|FJST|FET|EST|EGT|EGST|EETDST|EET|EEST|EDT|EAT|EAST|EASST|DDUT|DAVT|CXT|CST|COT|CLT|CLST|CKT|CHUT|CHAST|CHADT|CETDST|CET|CEST|CDT|CCT|CAST|CADT|BTT|BST|BRT|BRST|BRA|BOT|BORT|BNT|BDT|BDST|AZT|AZST|AZOT|AZOST|AWST|AWSST|AST|ART|ARST|ANAT|ANAST|AMT|AMST|ALMT|ALMST|AKST|AKDT|AFT|AEST|AESST|AEDT|ADT|ACWST|ACT|ACST|ACSST|ACDT$/,bs={ZULU:0,YEKT:18e3,YEKST:21600,YAPT:36e3,YAKT:32400,YAKST:32400,XJT:21600,WGT:-10800,WGST:-7200,WFT:43200,WETDST:3600,WET:0,WDT:32400,WAT:3600,WAST:25200,WAKT:43200,WADT:28800,VUT:39600,VOLT:10800,VLAT:36e3,VLAST:36e3,VET:-14400,UZT:18e3,UZST:21600,UYT:-10800,UYST:-7200,UTC:0,UT:0,ULAT:28800,ULAST:32400,UCT:0,TVT:43200,TRUT:36e3,TOT:46800,TMT:18e3,TKT:46800,TJT:18e3,TFT:18e3,TAHT:-36e3,SGT:28800,SCT:14400,SAST:7200,SADT:37800,RET:14400,PYT:-14400,PYST:-10800,PWT:32400,PST:-28800,PONT:39600,PMST:-10800,PMDT:-7200,PKT:18e3,PKST:21600,PHT:28800,PGT:36e3,PETT:43200,PETST:43200,PET:-18e3,PDT:-25200,OMST:21600,OMSST:21600,NZT:43200,NZST:43200,NZDT:46800,NUT:-39600,NST:-12600,NPT:20700,NOVT:25200,NOVST:25200,NFT:-12600,NDT:-9e3,MYT:28800,MVT:18e3,MUT:14400,MUST:18e3,MST:-25200,MSK:10800,MSD:14400,MPT:36e3,MMT:23400,MHT:43200,MEZ:3600,METDST:7200,MET:3600,MESZ:7200,MEST:7200,MDT:-21600,MAWT:18e3,MART:-34200,MAGT:39600,MAGST:39600,LKT:19800,LINT:50400,LIGT:36e3,LHST:37800,LHDT:37800,KST:32400,KRAT:25200,KRAST:25200,KOST:39600,KGT:21600,KGST:21600,KDT:36e3,JST:32400,JAYT:32400,IST:7200,IRT:12600,IRKT:28800,IRKST:28800,IOT:21600,IDT:10800,ICT:25200,HST:-36e3,HKT:28800,GYT:-14400,GMT:0,GILT:43200,GFT:-10800,GET:14400,GEST:14400,GAMT:-32400,GALT:-21600,FNT:-7200,FNST:-3600,FKT:-10800,FKST:-10800,FJT:43200,FJST:46800,FET:10800,EST:-18e3,EGT:-3600,EGST:0,EETDST:10800,EET:7200,EEST:10800,EDT:-14400,EAT:10800,EAST:-21600,EASST:-21600,DDUT:36e3,DAVT:25200,CXT:25200,CST:-21600,COT:-18e3,CLT:-14400,CLST:-10800,CKT:-36e3,CHUT:36e3,CHAST:45900,CHADT:49500,CETDST:7200,CET:3600,CEST:7200,CDT:-18e3,CCT:28800,CAST:34200,CADT:37800,BTT:21600,BST:3600,BRT:-10800,BRST:-7200,BRA:-10800,BOT:-14400,BORT:28800,BNT:28800,BDT:21600,BDST:7200,AZT:14400,AZST:14400,AZOT:-3600,AZOST:0,AWST:28800,AWSST:32400,AST:-14400,ART:-10800,ARST:-10800,ANAT:43200,ANAST:43200,AMT:-14400,AMST:14400,ALMT:21600,ALMST:25200,AKST:-32400,AKDT:-28800,AFT:16200,AEST:36e3,AESST:39600,AEDT:39600,ADT:-10800,ACWST:31500,ACT:-18e3,ACST:34200,ACSST:37800,ACDT:37800};function _s(t){return new Date(t)}function gs(t){return new Date(t+"Z")}const Ts=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function ws(t){const e=t.match(Ts);if(!e)return null;const[n,r,s,i]=e;return r<=0||s<=0||i<=0?null:r>999?new Date(Date.UTC(r,s-1,i,0,0,0,0)):new Date(Date.UTC(i,r-1,s,0,0,0,0))}function ms(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function Ss(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function vs(t){return new Date(t)}function As(t){const e=/^(\w{3}) (\w{3}) (\d{2}) (\d{4})$/;if(!t.match(e))throw new Error(`Unable to parse \`${t}\` as a date.`);const r=new Date(t+" UTC");return new Date(Date.UTC(r.getUTCFullYear(),r.getUTCMonth(),r.getUTCDate(),0,0,0,0))}function Es(t){const e=/^(.+T.+)([+-])(\d{2})$/,n=t.match(e);if(n){const[,r,s,i]=n,o=`${r}${s}${i}:00`;return new Date(o)}return null}function Os(t){const e=/^(\d+)-(\d{1,2})-(\d{1,2})([ T])(.+)$/,n=t.match(e);if(n){const[,r,s,i,o,a]=n,c=s.padStart(2,"0"),u=i.padStart(2,"0"),l=`${r}-${c}-${u}T${a}`;return new Date(l)}return null}function ks(t){const[e,n]=t.split(", "),[r,s,i]=e.split("/").map(Number),o=n.match(/(\d{1,2}):(\d{2}):(\d{2}) (AM|PM)/);if(!o)throw new Error(`Unable to parse time from: ${t}`);let[,a,c,u,l]=o;return a=Number(a),c=Number(c),u=Number(u),l==="PM"&&a!==12?a+=12:l==="AM"&&a===12&&(a=0),new Date(Date.UTC(i,r-1,s,a,c,u))}function Ps(t){switch(t){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Cs(t){const e=t.match(On);if(!e)return null;const[n]=e,r=bs[n],s=new Date(t.replace(On,"Z"));return new Date(s.getTime()-r*1e3)}const Is=[ws,Ss,As,ks,vs,gs,Es,ms,_s,Ps,Cs,Os];function Ms(t,e){try{const n=t(e);return n instanceof Date&&!isNaN(n.getTime())?n:null}catch{return null}}function Pt(t){for(const e of Is){const n=Ms(e,t);if(n)return n}return null}function js(t){try{const e=JSON.parse(t);return typeof e=="string"?Pt(e):null}catch{return null}}function Ze(t){if(t!==void 0){if(t===null)return null;if(t instanceof Date)return t;if(typeof t=="string"){const e=Pt(t)||js(t)||Pt(t.trim());if(!e)throw new Error(`Unable to parse \`${t}\` as a date.`);return e}else if(typeof t=="number")return new Date(t);throw new Error(`Invalid date value \`${t}\`. Expected a date, number, or string, got type ${typeof t}.`)}}class be{constructor(e,n){p(this,"attrs");p(this,"linkIndex");p(this,"_blobAttrs",null);p(this,"_primaryKeys",null);p(this,"_forwardIdents",null);p(this,"_revIdents",null);this.attrs=e,this.linkIndex=n}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const n=this.attrs[e.id];n&&(this.attrs[e.id]={...n,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(It(e)){const[n,r,s]=e["forward-identity"];Q(this.blobAttrs,[r,s],e)}return this._blobAttrs}get primaryKeys(){if(this._primaryKeys)return this._primaryKeys;this._primaryKeys=new Map;for(const e of Object.values(this.attrs))if(e["primary?"]){const[n,r]=e["forward-identity"];Q(this._primaryKeys,[r],e)}return this._primaryKeys}get forwardIdents(){if(this._forwardIdents)return this._forwardIdents;this._forwardIdents=new Map;for(const e of Object.values(this.attrs)){const n=e["forward-identity"],[r,s,i]=n;Q(this._forwardIdents,[s,i],e)}return this._forwardIdents}get revIdents(){if(this._revIdents)return this._revIdents;this._revIdents=new Map;for(const e of Object.values(this.attrs)){const n=e["reverse-identity"];if(n){const[r,s,i]=n;Q(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function Rs(t){return t.cardinality==="one"}function Ct(t){return t["value-type"]==="ref"}function It(t){return t["value-type"]==="blob"}function Se(t,e){return e.reduce((n,r)=>n&&n.get(r),t)}function ne(t,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){t.delete(e[0]);return}const[n,...r]=e;t.has(n)&&ne(t.get(n),r)}function Q(t,e,n){let r=t;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],n)}function kn(t,e,n){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=t.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&n&&(u=Ze(u),o[2]=u),Ct(l)&&Q(i,[u,c,a],o),Q(r,[a,c,u],o),Q(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function Pn(t){return{triples:B(t.eav,3),cardinalityInference:t.cardinalityInference,useDateObjects:t.useDateObjects,version:1}}function Cn(t,e){return $e(t,e.triples,e.cardinalityInference,e.useDateObjects)}function In(t,e){if(t)return new be(t.attrs,t.linkIndex);if(e&&"__type"in e)return new be(e.attrs,e.linkIndex)}function Ds(t,e){return Se(t.eav,[e])!==void 0}function $e(t,e,n,r){const s=kn(t,e,r);return s.cardinalityInference=n,s.useDateObjects=r,s}function Ue(t,e){var s,i;let n;if(Array.isArray(e[0])){const[o,a]=e[0],c=t.aev.get(o);if(!c)return null;n=(s=B(c,2).find(l=>l[2]===a))==null?void 0:s[0]}else n=e[0];if(!n)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&t.aev.get(r[0])){const[o,a]=r,c=t.aev.get(o);if(!c)return null;const l=(i=B(c,2).find(g=>g[2]===a))==null?void 0:i[0];if(!l)return null;const[d,h,y,...b]=e;return[n,h,l,...b]}else{const[o,...a]=e;return[n,...a]}}function Mn(t,e,n){const r=Ue(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(t.eav,[s,i,o]),ne(t.aev,[i,s,o]),Ct(a)&&ne(t.vae,[o,i,s]))}let xs=0;function jn(t,e,n){const[r,s,i]=n;let o;const a=Se(t.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+xs++}function Rn(t,e,n){const r=Ue(t,n);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&t.useDateObjects&&(o=Ze(o));const c=Se(t.eav,[s,i,o]),u=(c==null?void 0:c[3])??jn(t,a,r),l=[s,i,o,u];Rs(a)?(Q(t.eav,[s,i],new Map([[o,l]])),Q(t.aev,[i,s],new Map([[o,l]]))):(Q(t.eav,[s,i,o],l),Q(t.aev,[i,s,o],l)),Ct(a)&&Q(t.vae,[o,i,s],l)}function $s(t,e,n){var y;const r=Ue(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!It(a))throw new Error("merge operation is not supported for links");const c=Se(t.eav,[s,i]);if(!c)return;const u=(y=c.values().next())==null?void 0:y.value;if(!u)return;const l=u[2],d=vn(l,o),h=[s,i,d,jn(t,a,u)];Q(t.eav,[s,i],new Map([[d,h]])),Q(t.aev,[i,s],new Map([[d,h]]))}function Mt(t,e,n){var u,l;const[r,s]=n,i=Ue(t,[r]);if(!i)return;const[o]=i,a=t.eav.get(o);if(a){for(const d of a.keys()){const h=e.getAttr(d);h&&h["on-delete-reverse"]==="cascade"&&B(a.get(d),1).forEach(([y,b,g])=>{var w;return Mt(t,e,[g,(w=h["reverse-identity"])==null?void 0:w[1]])}),(!s||!h||((u=h["forward-identity"])==null?void 0:u[1])===s)&&(ne(t.aev,[d,o]),ne(t.eav,[o,d]))}a.size===0&&ne(t.eav,[o])}const c=t.vae.get(o)&&B(t.vae.get(o),2);c&&c.forEach(d=>{var w,m,T;const[h,y,b]=d,g=e.getAttr(y);(!s||!g||((w=g["reverse-identity"])==null?void 0:w[1])===s)&&(ne(t.eav,[h,y,b]),ne(t.aev,[y,h,b]),ne(t.vae,[b,y,h])),g&&g["on-delete"]==="cascade"&&((m=g["reverse-identity"])==null?void 0:m[1])===s&&Mt(t,e,[h,(T=g["forward-identity"])==null?void 0:T[1]])}),((l=t.vae.get(o))==null?void 0:l.size)===0&&ne(t.vae,[o])}function Dn(t,e,n){const r=kn(e,n,t.useDateObjects);Object.keys(r).forEach(s=>{t[s]=r[s]})}function Us(t,[e]){t.addAttr(e)}function xn(t){return B(t.eav,3)}function Ls(t,e,[n]){if(!e.getAttr(n))return;const r=xn(t).filter(([s,i])=>i!==n);e.deleteAttr(n),Dn(t,e,r)}function Fs(t,e,[n]){e.getAttr(n.id)&&(e.updateAttr(n),Dn(t,e,xn(t)))}function Ns(t,e,n){const[r,...s]=n;switch(r){case"add-triple":Rn(t,e,s);break;case"deep-merge-triple":$s(t,e,s);break;case"retract-triple":Mn(t,e,s);break;case"delete-entity":Mt(t,e,s);break;case"add-attr":Us(e,s);break;case"delete-attr":Ls(t,e,s);break;case"update-attr":Fs(t,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(t,e,n=[]){if(!t||e===0)return n;if(e===1){for(const r of t.values())n.push(r);return n}for(const r of t.values())B(r,e-1,n);return n}function Xe(t,e,n){var i;const r=[];if(n!=null&&n.hasOwnProperty("$not")){for(const o of e.keys())n.$not!==o&&r.push(e.get(o));return r}if(n!=null&&n.hasOwnProperty("$isNull")){const{attrId:o,isNull:a,reverse:c}=n.$isNull;if(c)for(const u of e.keys()){const l=t.vae.get(u),d=!l||!l.get(o);(a?d:!d)&&r.push(e.get(u))}else{const u=t.aev.get(o);for(const l of e.keys()){const d=!u||((i=u.get(l))==null?void 0:i.get(null))||!u.get(l);(a?d:!d)&&r.push(e.get(l))}}return r}if(n!=null&&n.$comparator)return B(e,1).filter(n.$op);const s=n.in||n.$in||[n];for(const o of s){const a=e.get(o);a&&r.push(a)}return r}function Ks(t,e,n){let r="";return t!==void 0&&(r+="e"),e!==void 0&&(r+="a"),n!==void 0&&(r+="v"),r}function zs(t,[e,n,r]){var i,o;switch(Ks(e,n,r)){case"e":{const a=t.eav.get(e);return B(a,2)}case"ea":{const a=(i=t.eav.get(e))==null?void 0:i.get(n);return B(a,1)}case"eav":{const a=(o=t.eav.get(e))==null?void 0:o.get(n);return a?Xe(t,a,r):[]}case"ev":{const a=t.eav.get(e);if(!a)return[];const c=[];for(const u of a.values())c.push(...Xe(t,u,r));return c}case"a":{const a=t.aev.get(n);return B(a,2)}case"av":{const a=t.aev.get(n);if(!a)return[];const c=[];for(const u of a.values())c.push(...Xe(t,u,r));return c}case"v":{const a=[];for(const c of t.eav.values())for(const u of c.values())a.push(...Xe(t,u,r));return a}default:return B(t.eav,3)}}function qs(t,e,n){var s;const r={};if(!e)return r;for(const[i,o]of e.entries()){const a=(s=t.eav.get(n))==null?void 0:s.get(o.id),c=B(a,1);for(const u of c)r[i]=u[2]}return r}function U(t,e,n){var r;return(r=t.forwardIdents.get(e))==null?void 0:r.get(n)}function _e(t,e,n){var r;return(r=t.revIdents.get(e))==null?void 0:r.get(n)}function Vs(t,e){return t.blobAttrs.get(e)}function $n(t,e){var r;const n=t.primaryKeys.get(e);return n||((r=t.forwardIdents.get(e))==null?void 0:r.get("id"))}function Ws(t,e,n){const r=Ue(t,n);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return Se(t.eav,[s,i])}function Qs(t,e,n){const r=n.filter(([s,i,o,a,c])=>{if(s!=="add-triple"&&s!=="deep-merge-triple")return!0;const u=c==null?void 0:c.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const d=e.getAttr(o);if(d){const h=$n(e,d["forward-identity"][1]);l=!!Ws(t,e,[i,h==null?void 0:h.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Je({store:t,attrsStore:e},s=>{r.forEach(i=>{Ns(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof be)return"immutable"}})}function Bs(t){return typeof t=="string"&&t.startsWith("?")}function Gs(t,e,n){if(n.hasOwnProperty(t)){const r=n[t];return Ln(r,e,n)}return{...n,[t]:e}}function Un(t,e,n){return t===e?n:null}function Hs(t){switch(typeof t){case"string":return t.startsWith("?")?Gs:Un;default:return Un}}const Js=["in","$in","$not","$isNull","$comparator"];function Ys(t){for(const e of Js)if(t.hasOwnProperty(e))return!0;return!1}function Ln(t,e,n){return n?typeof t=="object"?Ys(t)?n:null:Hs(t)(t,e,n):null}function Zs(t,e,n){return t.reduce((r,s,i)=>{const o=e[i];return Ln(s,o,r)},n)}function Xs(t,e,n){return ni(t,e,n).map(r=>Zs(e,r,n)).filter(r=>r)}function ei(t,e,n){return e.or?e.or.patterns.flatMap(r=>jt(t,r,n)):e.and?e.and.patterns.reduce((r,s)=>jt(t,s,r),n):n.flatMap(r=>Xs(t,e,r))}function jt(t,e,n=[{}]){return e.reduce((r,s)=>ei(t,s,r),n)}function Rt(t,e){return Array.isArray(e)?e.map(n=>Rt(t,n)):Bs(e)?t[e]:e}function ti(t,{find:e,where:n}){return jt(t,n).map(s=>Rt(s,e))}function ni(t,e,n){return zs(t,Rt(n,e))}const ri=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function ve(t){return typeof t=="string"&&ri.test(t)}const z=[];for(let t=0;t<256;++t)z.push((t+256).toString(16).slice(1));function si(t,e=0){return(z[t[e+0]]+z[t[e+1]]+z[t[e+2]]+z[t[e+3]]+"-"+z[t[e+4]]+z[t[e+5]]+"-"+z[t[e+6]]+z[t[e+7]]+"-"+z[t[e+8]]+z[t[e+9]]+"-"+z[t[e+10]]+z[t[e+11]]+z[t[e+12]]+z[t[e+13]]+z[t[e+14]]+z[t[e+15]]).toLowerCase()}let Dt;const ii=new Uint8Array(16);function oi(){if(!Dt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");Dt=crypto.getRandomValues.bind(crypto)}return Dt(ii)}const Fn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function ai(t,e,n){var s;if(Fn.randomUUID&&!t)return Fn.randomUUID();t=t||{};const r=t.random??((s=t.rng)==null?void 0:s.call(t))??oi();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,si(r)}function Nn(t){const e=t.replace(/-/g,""),n=[];for(let r=0;r<e.length;r+=2)n.push(parseInt(e.substring(r,r+2),16));return n}function ci(t,e){for(let n=0;n<t.length;n++){if(t[n]<e[n])return-1;if(t[n]>e[n])return 1}return 0}function ui(t,e){return ci(Nn(t),Nn(e))}function N(){return ai()}function li(t,e){return t.localeCompare(e)}function fi(){let t=li;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{t=Intl.Collator("en-US").compare}catch{}return t}const di=fi();let hi=0;function Le(t){return et(`_${t}`,hi++)}function et(t,e){return`?${t}-${e}`}class Ae extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function pi(t,e){const n=$n(t,e);if(!n)throw new Ae(`Could not find id attr for ${e}`);return n}function Kn(t,e,n,r){return[yi(t,e,n,r)]}function yi(t,e,n,r){return[t(n,r),pi(e,n).id,t(n,r),t("time",r)]}function bi(t,e,n){return t.map(r=>r===e?n:r)}function zn(t,e,n,r,s){const i=U(e,n,s),o=_e(e,n,s),a=i||o;if(!a)throw new Ae(`Could not find attr for ${[n,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,d]=a["reverse-identity"],h=r+1,y=i?[t(u,r),a.id,t(d,h),Le("time")]:[t(u,h),a.id,t(d,r),Le("time")];return[i?d:u,h,y,a,!!i]}function qn(t,e){if(typeof e!="string")return function(o){return!1};const r=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/%/g,".*").replace(/_/g,"."),s=new RegExp(`^${r}$`,t?void 0:"i");return function(o){return typeof o!="string"?!1:s.test(o)}}function _i(t,e){if(typeof e!="object"||e.hasOwnProperty("$in")||e.hasOwnProperty("in"))return e;const n=t["checked-data-type"]==="date";if(e.hasOwnProperty("$gt"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])>new Date(e.$gt)}:function(s){return s[2]>e.$gt}};if(e.hasOwnProperty("$gte"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])>=new Date(e.$gte)}:function(s){return s[2]>=e.$gte}};if(e.hasOwnProperty("$lt"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])<new Date(e.$lt)}:function(s){return s[2]<e.$lt}};if(e.hasOwnProperty("$lte"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])<=new Date(e.$lte)}:function(s){return s[2]<=e.$lte}};if(e.hasOwnProperty("$like")){const r=qn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=qn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function gi(t,e,n,r,s,i){const o=U(e,n,s),a=_e(e,n,s),c=o||a;if(!c)throw new Ae(`No attr for etype = ${n} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=U(e,n,"id");if(!u)throw new Ae(`No attr for etype = ${n} label = id`);return[t(n,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Le("time")]}return o?[t(n,r),c.id,_i(c,i),Le("time")]:[i,c.id,t(n,r),Le("time")]}function Ti(t,e,n,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,h]=c,[y,b,g]=zn(t,e,l,d,u);return[y,b,[...h,g]]},[n,r,[]]);return[i,o,a]}function xt(t,e,n,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Ti(t,e,n,r,o),d=gi(t,e,c,u,a,i);return l.concat([d])}function wi(t,e){return e?[e].concat(t):t}function mi([t,e]){return t==="or"&&Array.isArray(e)}function Si([t,e]){return t==="and"&&Array.isArray(e)}function vi(t,e,n){return(r,s)=>{const i=t(r,s);return e==i?i:`${i}-${n}`}}function Vn(t,e,n,r,s,i){const o=t(r,s),a=i.map((c,u)=>{const l=vi(t,o,u);return Qn(l,n,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ai(t){const e=[];for(let n=1;n<=t.length;n++)e.push(t.slice(0,n));return e}function Wn(t,e,n,r,s){return Ai(s).map(i=>xt(t,e,n,r,i,{$isNull:!0}))}function Qn(t,e,n,r,s){return Object.entries(s).flatMap(([i,o])=>{if(mi([i,o]))return Vn(t,"or",e,n,r,o);if(Si([i,o]))return Vn(t,"and",e,n,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o!=null&&o.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o!=null&&o.hasOwnProperty("$not")){const c=xt(t,e,n,r,a,o),u=Wn(t,e,n,r,a);return[{or:{patterns:[c,...u],joinSym:t(n,r)}}]}return o!=null&&o.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:Wn(t,e,n,r,a),joinSym:t(n,r)}}]:xt(t,e,n,r,a,o)})}function Ei(t,e,n,r){const s=et;return r?Qn(s,t,e,n,r).concat(Kn(s,t,e,n)):Kn(s,t,e,n)}function Oi(t,e,n){return[t(e,n),t("time",n)]}function ki(t,e,n,r,s,i){const[o,a,c,u,l]=zn(t,e,n,r,s),d=bi(c,t(n,r),i);return[o,a,d,u,l]}function Pi(t,e,n,{etype:r,level:s,form:i},o){const a=Object.keys(i).filter(c=>c!=="$");return a.length?Object.entries(o).map(function([u,l]){return a.map(function(y){var g,w,m;const b=!!(e.cardinalityInference&&((m=(w=(g=n.linkIndex)==null?void 0:g[r])==null?void 0:w[y])!=null&&m.isSingular));try{const[T,v,k]=ki(t,n,r,s,y,u),A=Gn(e,n,{etype:T,level:v,form:i[y],join:k}),R=b?A[0]:A;return{[y]:R}}catch(T){if(T instanceof Ae)return{[y]:b?void 0:[]};throw T}}).reduce(function(y,b){return{...y,...b}},l)}):Object.values(o)}function Ci(t,e,n){return n==="string"?di(t,e):t>e?1:-1}function Fe(t,e,n,r,s){return e===r||e==null&&r==null?ui(t,n):r==null?1:e==null?-1:Ci(e,r,s)}function tt([t,e],[n,r],s){return Fe(t,e,n,r,s)}function $t(t){return t==null?t:new Date(t).getTime()}function Ii(t,e,n,r){var b;const[s,i,o,a]=t,c=n==="desc"?1:-1;if(((b=e["forward-identity"])==null?void 0:b[2])==="id")return tt(r,[s,a],null)===c;const[u,l]=r,d=e["checked-data-type"],h=d==="date"?$t(l):l,y=d==="date"?$t(o):o;return tt([u,h],[s,y],d)===c}function Mi(t,e){const n=e[1];return t.getAttr(n)}function ji(t,e,n){const r=Object.keys(n)[0];return U(t,e,r)}function Ri(t,e,n,r){if(n)return Mi(t,n);if(r)return ji(t,e,r)}function Di(t,e,n){var s,i;if(!Array.isArray(n.fields))return Vs(t,e);const r=new Map;for(const o of n.fields){const a=U(t,e,o),c=(s=a==null?void 0:a["forward-identity"])==null?void 0:s[2];c&&It(a)&&r.set(c,a)}if(!r.has("id")){const o=U(t,e,"id"),a=(i=o==null?void 0:o["forward-identity"])==null?void 0:i[2];a&&r.set(a,o)}return r}function xi(t,e,{etype:n,pageInfo:r,dq:s,form:i}){var b,g;const o=(b=i==null?void 0:i.$)==null?void 0:b.order,a=Bn(i),c=$i(i);let u=ti(t,s);const l=r==null?void 0:r["start-cursor"],d=Ri(e,n,l,o);if(d&&((g=d==null?void 0:d["forward-identity"])==null?void 0:g[2])!=="id"){const w=d["checked-data-type"]==="date",m=d.id;u=u.map(([T])=>{var k,A,R,K,V;let v=(V=(K=(R=(A=(k=t.eav.get(T))==null?void 0:k.get(m))==null?void 0:A.values())==null?void 0:R.next())==null?void 0:K.value)==null?void 0:V[2];return w&&(v=$t(v)),[T,v]})}u.sort(c==="asc"?function(m,T){return tt(m,T,d==null?void 0:d["checked-data-type"])}:function(m,T){return tt(T,m,d==null?void 0:d["checked-data-type"])});let h={};const y=Di(e,n,s);for(const w of u){const[m]=w;if(h[m]||!a&&l&&d&&Ii(l,d,c,w))continue;const T=qs(t,y,m);T&&(h[m]=T)}return h}function $i(t){var n;const e=(n=t.$)==null?void 0:n.order;return e&&e[Object.keys(e)[0]]||"asc"}function Bn(t){var s,i,o;const e=(s=t.$)==null?void 0:s.offset,n=(i=t.$)==null?void 0:i.before,r=(o=t.$)==null?void 0:o.after;return!e&&!n&&!r}function Ui(t,e,{etype:n,level:r,form:s,join:i,pageInfo:o}){var h,y,b,g,w;if(!Bn(s)&&(!o||!o["start-cursor"]))return[];const a=wi(Ei(e,n,r,(h=s.$)==null?void 0:h.where),i),c=Oi(et,n,r),u=(y=s.$)==null?void 0:y.fields,l=xi(t,e,{etype:n,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((b=s.$)==null?void 0:b.limit)||((g=s.$)==null?void 0:g.first)||((w=s.$)==null?void 0:w.last);if(d!=null){r>0&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const m=Object.entries(l);return m.length<=d?l:Object.fromEntries(m.slice(0,d))}return l}function Li(t,e,n){try{return Ui(t,e,n)}catch(r){if(r instanceof Ae)return{};throw r}}function Gn(t,e,n){const r=Li(t,e,n);return Pi(et,t,e,n,r)}function Fi(t){const e={};for(const[n,r]of Object.entries(t))e[n]={startCursor:r["start-cursor"],endCursor:r["end-cursor"],hasNextPage:r["has-next-page?"],hasPreviousPage:r["has-previous-page?"]};return e}function Hn({store:t,attrsStore:e,pageInfo:n,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r!=null&&r[u]||u==="$$ruleParams"||(c[u]=Gn(t,e,{etype:u,form:s[u],level:0,pageInfo:n==null?void 0:n[u]})),c},{})};return n&&(o.pageInfo=Fi(n)),r&&(o.aggregate=r),o}function Ni(){const e={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(e))}const Ki=Ni();function nt(t,e,n){const r={__etype:t,__ops:n};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return n;if(i==="__etype")return t;if(Ki.has(i))return(o,a)=>nt(t,e,[...n,a?[i,t,e,o,a]:[i,t,e,o]])}})}function zi(t,e){return`lookup__${t}__${JSON.stringify(e)}`}function rt(t){return t.startsWith("lookup__")}function Ut(t){const[e,n,...r]=t.split("__");return[n,JSON.parse(r.join("__"))]}function qi(t){return new Proxy({__etype:t},{get(e,n){if(n==="lookup")return(s,i)=>nt(t,Ut(zi(s,i)),[]);if(n==="__etype")return t;const r=n;return rt(r)?nt(t,Ut(r),[]):nt(t,r,[])}})}function Lt(){return new Proxy({},{get(t,e){return qi(e)}})}Lt();function Vi(t){return t.__ops}function Wi(t,e){const{attrIdMap:n,refSwapAttrIds:r}=t,s=[];for(const o of e){const a=n[o];if(a)s.push(a);else if(Array.isArray(o)&&o.length==2&&n[o[0]]){const[c,u]=o;s.push([n[c],u])}else s.push(o)}const[i]=e;if((i==="add-triple"||i==="retract-triple")&&r.has(e[2])){const o=s[1];s[1]=s[3],s[3]=o}return s}function Qi(t){if(Array.isArray(t))return t;const e=Object.entries(t);if(e.length!==1)throw new Error("lookup must be an object with a single unique attr and value.");return e[0]}function Bi(t,e,n){return n.indexOf(".")!==-1&&!U(t,e,n)}function Ft(t){const[e,n,...r]=t.split(".");if(r.length>0||n!=="id")throw new Error(`${t} is not a valid lookup attribute.`);return e}function Gi(t,e,n){if(!Bi(t,e,n))return U(t,e,n);const r=Ft(n),s=U(t,e,r)||_e(t,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${n} does not reference a valid link attribute.`);return s}function Nt(t){return typeof t=="string"&&!rt(t)?null:typeof t=="string"&&rt(t)?Ut(t):Qi(t)}function G(t,e,n){const r=Nt(n);if(r===null)return n;const[s,i]=r,o=Gi(t,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Jn(t,e,n,r){var o;const s=G(t,e,n);return Array.isArray(s)?[["add-triple",s,(o=U(t,e,"id"))==null?void 0:o.id,s]].concat(r):r}function Hi({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=U(t,e,i),u=_e(t,e,i);return a.map(l=>c?["add-triple",G(t,e,n),c.id,G(t,c["reverse-identity"][1],l)]:["add-triple",G(t,u["forward-identity"][1],l),u==null?void 0:u.id,G(t,e,n)])});return Jn(t,e,n,s)}function Ji({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=U(t,e,i),u=_e(t,e,i);return a.map(l=>c?["retract-triple",G(t,e,n),c.id,G(t,c["reverse-identity"][1],l)]:["retract-triple",G(t,u["forward-identity"][1],l),u.id,G(t,e,n)])});return Jn(t,e,n,s)}function Yi(t,e,n,r){var s;if(Array.isArray(r)){const[i,o]=r;for(const a of t||[]){const c=a==null?void 0:a.aev.get(i);if(c){for(const[u,l,d]of B(c,2))if(d===o)return!0}}}else for(const i of t||[]){const o=i==null?void 0:i.eav.get(r);if(o){for(const a of o.keys())if(((s=e.getAttr(a))==null?void 0:s["forward-identity"][1])==n)return!0}}return!1}function Yn({stores:t,attrsStore:e},[n,r,s,i]){return(i==null?void 0:i.upsert)===!1?{mode:"update"}:(i==null?void 0:i.upsert)===!0?null:Yi(t,e,n,r)?{mode:"update"}:null}function Zi(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,d])=>{const h=U(n,r,l);return h["checked-data-type"]==="date"&&t.useDateObjects&&(d=Ze(d)),["add-triple",c,h.id,d,{mode:"create"}]})}function Xi(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s),u=Yn(t,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([d,h])=>{const y=U(n,r,d);return y["checked-data-type"]==="date"&&t.useDateObjects&&(h=Ze(h)),["add-triple",c,y.id,h,...u?[u]:[]]})}function eo({attrsStore:t},[e,n]){return[["delete-entity",G(t,e,n),e]]}function to(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s),u=Yn(t,[r,c,i,o]),l=Object.entries(a).map(([h,y])=>{const b=U(n,r,h);return["deep-merge-triple",c,b.id,y,...u?[u]:[]]});return[["add-triple",c,U(n,r,"id").id,c,...u?[u]:[]]].concat(l)}function no({attrsStore:t},[e,n,r]){return[["rule-params",G(t,e,n),e,r]]}function ro(t){const[e,n,r,s,i]=t;if(!s)return t;const o={...s};return delete o.id,[e,n,r,o,...i?[i]:[]]}function so(t,e){const[n,...r]=ro(e);switch(n){case"merge":return to(t,r);case"create":return Zi(t,r);case"update":return Xi(t,r);case"link":return Hi(t,r);case"unlink":return Ji(t,r);case"delete":return eo(t,r);case"ruleParams":return no(t,r);default:throw new Error(`unsupported action ${n}`)}}function io(t){switch(t){case"string":case"date":case"boolean":case"number":return t;default:return}}function oo(t,e,n){var a,c;const r=(c=(a=t.entities[e])==null?void 0:a.attrs)==null?void 0:c[n];if(n==="id")return null;if(!r)throw new Error(`${e}.${n} does not exist in your schema`);const{unique:s,indexed:i}=r==null?void 0:r.config,o=io(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function st(t,e,n,r){const s=t?oo(t,e,n):null,i=N(),a=[N(),e,n];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function ao(t,e,n){return Object.values(t.links).find(i=>i.forward.on===e&&i.forward.label===n||i.reverse.on===e&&i.reverse.label===n)}function co(t,e,n){const r=ao(t,e,n);if(!r)throw new Error(`Couldn't find the link ${e}.${n} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[N(),s.on,s.label],"reverse-identity":[N(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Zn(t,e,n,r){const s=t?co(t,e,n):null,i=N(),o=[N(),e,n],a=[N(),n,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const uo=new Set(["create","update","merge","link","unlink"]),lo=new Set(["link","unlink"]),fo=new Set(["create","update","merge"]),ho=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Kt={"unique?":!0,"index?":!0},po={...Kt,cardinality:"one"};function yo(t){const e=[],[n,r,s,i]=t;if(!ho.has(n))return e;const o=Nt(s);if(o&&e.push({etype:r,lookupPair:o}),n==="link")for(const[a,c]of Object.entries(i)){const u=Array.isArray(c)?c:[c];for(const l of u){const d=Nt(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function bo({attrsStore:t,schema:e},n){var h,y;const r=new Set,s=[],i=[];function o(b,g){return U(t,b,g)||s.find(w=>w["forward-identity"][1]===b&&w["forward-identity"][2]===g)}function a(b,g){return _e(t,b,g)||s.find(w=>{var m,T;return((m=w["reverse-identity"])==null?void 0:m[1])===b&&((T=w["reverse-identity"])==null?void 0:T[2])===g})}function c(b){s.push(b),i.push(["add-attr",b]),r.add(b.id)}function u(b){b&&"isUnsynced"in b&&b.isUnsynced&&!r.has(b.id)&&(s.push(b),i.push(["add-attr",b]),r.add(b.id))}function l(b,g){return g.indexOf(".")!==-1&&!o(b,g)}function d(b,g){const w=o(b,g),m=a(b,g);u(w),u(m),!w&&!m&&c(Zn(e,b,g,po))}for(const b of n)for(const{etype:g,lookupPair:w,linkLabel:m}of yo(b)){const T=w[0];if(m){d(g,m);const v=o(g,m),k=a(g,m);u(v),u(k);const A=((h=v==null?void 0:v["reverse-identity"])==null?void 0:h[1])||((y=k==null?void 0:k["forward-identity"])==null?void 0:y[1])||m;if(l(A,T))d(A,Ft(T));else{const R=o(A,T);R||c(st(e,A,T,Kt)),u(R)}}else if(l(g,T))d(g,Ft(T));else{const v=o(g,T);v||c(st(e,g,T,Kt)),u(v)}}for(const b of n){const[g,w,m,T]=b;if(uo.has(g)){const v=o(w,"id");u(v),v||c(st(e,w,"id",{"unique?":!0}));for(const k of Object.keys(T)){const A=o(w,k);if(u(A),fo.has(g)&&(A||c(st(e,w,k,k==="id"?{"unique?":!0}:null))),lo.has(g)){const R=a(w,k);!A&&!R&&c(Zn(e,w,k)),u(R)}}}}if(s.length){const b={...t.attrs};for(const g of s)b[g.id]=g;return[new be(b,t.linkIndex),i]}return[t,i]}function _o(t,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Vi(c)),[s,i]=bo(t,r),o={...t,attrsStore:s},a=r.flatMap(c=>so(o,c));return[...i,...a]}function Xn(t,e){typeof requestIdleCallback>"u"?t():requestIdleCallback(t,{timeout:e})}const Ne="__meta";class go{constructor(e,n){}}class zt{constructor(e){p(this,"currentValue");p(this,"_subs",[]);p(this,"_persister");p(this,"_merge");p(this,"serialize");p(this,"parse");p(this,"_saveThrottleMs");p(this,"_idleCallbackMaxWaitMs");p(this,"_nextSave",null);p(this,"_nextGc",null);p(this,"_pendingSaveKeys",new Set);p(this,"_loadedKeys",new Set);p(this,"_loadingKeys");p(this,"_objectSize");p(this,"_log");p(this,"onKeyLoaded");p(this,"_version",0);p(this,"_meta",{isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0});p(this,"_gcOpts");this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){var e;this._meta.loadingPromise&&await this._meta.loadingPromise;try{const n=this._persister.getItem(Ne);this._meta.loadingPromise=n;const r=await n;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const s=((e=this._meta.value)==null?void 0:e.objects)??{},i=r??{},o=i.objects??{};this._meta.value={...i,objects:{...s,...o}}}catch(n){this._meta.error=n,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const n=await this.waitForMetaToLoad();if(!n)return;const r=Object.entries(n.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const n=await this._persister.getItem(e);return n&&this.parse(e,n)}catch(n){return console.error(`Unable to read from storage for key=${e}`,n),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const n=this._getFromStorage(e);this._loadingKeys[e]=n;const r=await n;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const n=[],r=e==null?void 0:e.skipGc;if(this._meta.isLoading){const d=new Promise((h,y)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(h).catch(y),10+((e==null?void 0:e.attempts)??0)*1e3)});return n.push(d),Promise.all(n).then(h=>h.reduce((y,b)=>y+b,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const d of this._pendingSaveKeys)d in this.currentValue?o.push(d):(i.push(d),delete s.objects[d]);for(const d of i){const h=this._persister.removeItem(d);n.push(h.then(()=>1)),this._loadedKeys.delete(d),this._pendingSaveKeys.delete(d)}const a=[],c=[[Ne,s]],u=s.objects??{};s.objects=u;for(const d of o)if(this._loadedKeys.has(d)){const h=this.serialize(d,this.currentValue[d]);c.push([d,h]);const y=this._objectSize(h),b=u[d]??{createdAt:Date.now(),updatedAt:Date.now(),size:y};b.updatedAt=Date.now(),b.size=y,u[d]=b,this._pendingSaveKeys.delete(d)}else a.push(d);const l=this._persister.multiSet(c);n.push(l.then(()=>1));for(const d of a){const h=this._loadKey(d).then(()=>this._enqueuePersist(e));n.push(h)}return r||this.gc(),Promise.all(n).then(d=>d.reduce((h,y)=>h+y,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Ne);const n=new Set(Object.keys(this.currentValue));for(const h of Object.keys(this._loadingKeys))n.add(h);for(const h of this._loadedKeys)n.add(h);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:n,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const h of e)n.has(h)||h in r.objects||(this._log.info("Lost track of key in meta",h),s.push(this._persister.removeItem(h)),i.removed.push(h),i.removedMissingCount++);const o=Date.now();for(const[h,y]of Object.entries(r.objects))!n.has(h)&&y.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([h,y],[b,g])=>y.updatedAt-g.updatedAt);const c=a.filter(([h])=>!n.has(h));if(a.length>this._gcOpts.maxEntries)for(const[h]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([h,y],[b,g])=>y.updatedAt-g.updatedAt);const l=u.filter(([h])=>!n.has(h));let d=u.reduce((h,[y,b])=>h+b.size,0);for(;d>0&&d>this._gcOpts.maxSize&&l.length;){const[[h,y]]=l.splice(0,1);d-=y.size,s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedSizeCount++}for(const h of Object.keys(r.objects))!e.has(h)&&!n.has(h)&&delete r.objects[h];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{Xn(()=>{this._nextGc=null,this._gc()},30*1e3)},1e3*60+Math.random()*500))}_enqueuePersist(e){return new Promise((n,r)=>{if(this._nextSave){n(0);return}this._nextSave=setTimeout(()=>{Xn(()=>{this._nextSave=null,this._writeToStorage(e).then(n).catch(r)},this._idleCallbackMaxWaitMs)},this._saveThrottleMs)})}version(){return this._version}updateInPlace(e){this._version++;const[n,r]=Je(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=n,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return n}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(n=>n!==e)}}}const To=6,wo=["kv","querySubs","syncSubs"];function mo(t){return function(n){console.error("Error in IndexedDB event",{source:t,event:n})}}async function So(t){return new Promise(e=>{const n=indexedDB.open(t);n.onerror=r=>{e(null)},n.onsuccess=r=>{const i=r.target.result;e(i)},n.onupgradeneeded=r=>{var i;(i=r.target.transaction)==null||i.abort(),e(null)}})}async function vo(t,e,n){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{var l,d,h;const a={};for(const[y,b]of Object.entries(r)){const g=typeof b=="string"?JSON.parse(b):b;if(g.lastAccessed){const m={createdAt:g.lastAccessed,updatedAt:g.lastAccessed,size:((h=(d=(l=g.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:h.length)??0};a[y]=m}const w=n.put(g,y);s.add(w)}const c={objects:a},u=n.put(c,Ne);s.add(u);for(const y of s)y.onsuccess=()=>{s.delete(y),s.size===0&&i()},y.onerror=b=>{o(b)}})}async function er(t,e,n){const r=n.put(e,t);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Ao(t,e){const n=await So(`instant_${t}_5`);if(!n)return;const r=await new Promise((l,d)=>{const b=n.transaction(["kv"],"readonly").objectStore("kv").openCursor();b.onerror=w=>{d(w)};const g=[];b.onsuccess=()=>{const w=b.result;if(w){const m=w.key,T=w.value;g.push([m,T]),w.continue()}else l(g)},b.onerror=w=>{d(w)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,d]of r)switch(l){case"querySubs":{const h=vo(l,d,o);a.push(h);break}default:{const h=er(l,d,i);a.push(h);const y={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=y;break}}const u=er(Ne,c,i);a.push(u),await Promise.all(a),await new Promise((l,d)=>{s.oncomplete=h=>l(h),s.onerror=h=>d(h),s.onabort=h=>d(h)})}const tr=new Map;class nr extends go{constructor(n,r){super(n,r);p(this,"dbName");p(this,"_storeName");p(this,"_appId");p(this,"_prefix");p(this,"_dbPromise");this.dbName=`instant_${n}_${To}`,this._storeName=r,this._appId=n,this._dbPromise=this._init()}_init(){return new Promise((n,r)=>{let s=!1;const i=indexedDB.open(this.dbName,1);i.onerror=o=>{r(o)},i.onsuccess=o=>{const c=o.target.result;if(s){const u=Ao(this._appId,c).catch(l=>{mo("Error upgrading store from version 5 to 6.")(l)});tr.set(this.dbName,u),u.then(()=>n(c)).catch(()=>n(c))}else{const u=tr.get(this.dbName);u?u.then(()=>n(c)).catch(()=>n(c)):n(c)}},i.onupgradeneeded=o=>{s=!0,this._upgradeStore(o)}})}_upgradeStore(n){const s=n.target.result;for(const i of wo)s.objectStoreNames.contains(i)||s.createObjectStore(i)}async getItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readonly").objectStore(this._storeName).get(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{c.result?s(c.result):s(null)}})}async setItem(n,r){const s=await this._dbPromise;return new Promise((i,o)=>{const u=s.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(r,n);u.onerror=l=>{o(l)},u.onsuccess=l=>{i()}})}async multiSet(n){const r=await this._dbPromise;return new Promise((s,i)=>{const o=r.transaction([this._storeName],"readwrite"),a=o.objectStore(this._storeName),c=new Set;for(const[u,l]of n){const d=a.put(l,u);c.add(d)}for(const u of c)u.onerror=l=>{o.abort(),i(l)},u.onsuccess=l=>{c.delete(u),c.size===0&&s()}})}async removeItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async getAllKeys(){const n=await this._dbPromise;return new Promise((r,s)=>{const a=n.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();a.onerror=c=>{s(c)},a.onsuccess=c=>{r(a.result.filter(u=>typeof u=="string"))}})}}class rr{static async getIsOnline(){return navigator.onLine}static listen(e){const n=()=>{e(!0)},r=()=>{e(!1)};return addEventListener("online",n),addEventListener("offline",r),()=>{removeEventListener("online",n),removeEventListener("offline",r)}}}class Ee extends Error{constructor(n,r){super(n);p(this,"hint");this.hint=r;const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,Ee),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class it extends Ee{constructor(n){var i;const r=((i=n.body)==null?void 0:i.message)||`API Error (${n.status})`;super(r,n.body.hint);p(this,"body");p(this,"status");const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,it),this.name="InstantAPIError",this.status=n.status,this.body=n.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(t,e){const n=await fetch(t,e),r=await n.json();return n.status===200?Promise.resolve(r):Promise.reject(new it({status:n.status,body:r}))}function Eo({apiURI:t,appId:e,email:n}){return re(`${t}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n})})}async function Oo({apiURI:t,appId:e,email:n,code:r,refreshToken:s}){return await re(`${t}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n,code:r,...s?{"refresh-token":s}:{}})})}async function ko({apiURI:t,appId:e,refreshToken:n}){return await re(`${t}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":n})})}async function Po({apiURI:t,appId:e}){return await re(`${t}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function sr({apiURI:t,appId:e,code:n,codeVerifier:r,refreshToken:s}){return await re(`${t}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:n,code_verifier:r,refresh_token:s})})}async function Co({apiURI:t,appId:e,nonce:n,idToken:r,clientName:s,refreshToken:i}){return await re(`${t}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:n,id_token:r,client_name:s,refresh_token:i})})}async function Io({apiURI:t,appId:e,refreshToken:n}){return await re(`${t}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:n})})}async function Mo({apiURI:t,appId:e,path:n,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:n,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await re(`${t}/storage/upload`,{method:"PUT",headers:a,body:r})}async function jo({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await re(`${t}/storage/files?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function Ro({apiURI:t,appId:e,fileName:n,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${t}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:n})});return i}async function Do(t,e){return(await fetch(t,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function xo({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await re(`${t}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let qt=!1,ir=!1,or=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(qt=!!window.localStorage.getItem("devBackend"),ir=!!window.localStorage.getItem("__instantLogging"),or=!!window.localStorage.getItem("__devtoolLocalDash"));function ar(t,e){if(!e)return t;const n={};return e.forEach(r=>{n[r]=t[r]}),n}function $o(t,e,n){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=ar(t.user??{},e==null?void 0:e.keys);r.user={...i,peerId:n}}for(const i of Object.keys(t.peers??{})){const o=(e==null?void 0:e.peers)===void 0,a=Array.isArray(e==null?void 0:e.peers)&&(e==null?void 0:e.peers.includes(i));if(o||a){const c=ar(t.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Uo(t,e){if(t.isLoading!==e.isLoading||t.error!==e.error||(t.user||e.user)&&(!t.user||!e.user||!Sn(t.user,e.user))||!mn(t.peers,e.peers))return!0;for(const r of Object.keys(t.peers))if(!Sn(t.peers[r],e.peers[r]))return!0;return!1}class cr{constructor(){p(this,"promise");p(this,"_resolve");p(this,"_reject");this.promise=new Promise((e,n)=>{this._resolve=e,this._reject=n})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function ur(t,e=[]){t.forEach(n=>{const{data:r}=n,{"datalog-result":s}=r,{"join-rows":i}=s;for(const o of i)for(const a of o)e.push(a);ur(n["child-nodes"],e)})}function lr(t){const e=[];return ur(t,e),e}function fr(t){return Object.values(t.links).reduce((e,n)=>{var r,s;return e[r=n.forward.on]??(e[r]={}),e[n.forward.on][n.forward.label]={isForward:!0,isSingular:n.forward.has==="one",link:n},e[s=n.reverse.on]??(e[s]={}),e[n.reverse.on][n.reverse.label]={isForward:!1,isSingular:n.reverse.has==="one",link:n},e},{})}const dr="v0.22.112";function Lo(t,e){return{info:t?(...n)=>console.info(...n,e()):()=>{},debug:t?(...n)=>console.debug(...n,e()):()=>{},error:t?(...n)=>console.error(...n,e()):()=>{}}}class ue{constructor(e,n,r,s={indexed:!1,unique:!1}){p(this,"valueType");p(this,"required");p(this,"isIndexed");p(this,"config");p(this,"metadata",{});this.valueType=e,this.required=n,this.isIndexed=r,this.config=s}clientRequired(){return new ue(this.valueType,!1,this.isIndexed,this.config)}optional(){return new ue(this.valueType,!1,this.isIndexed,this.config)}unique(){return new ue(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new ue(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class D extends Error{constructor(e,n){const r=n?`At path '${n}': ${e}`:e;super(r),this.name="QueryValidationError"}}const hr=["where","order","limit","last","first","offset","after","before","fields","aggregate"],Fo=t=>t.valueType||"unknown",pr=(t,e,n=!1)=>{if(n||t==null)return!0;switch(e){case"string":return typeof t=="string";case"number":return typeof t=="number"&&!isNaN(t);case"boolean":return typeof t=="boolean";case"date":return t instanceof Date||typeof t=="string"||typeof t=="number";default:return!0}},No=(t,e,n,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!pr(d,l,a))throw new D(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof d}`,o)};switch(t){case"in":case"$in":if(!Array.isArray(e))throw new D(`Operator '${t}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(t,n,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(t,n,e);break;case"$like":case"$ilike":if(c(t,"string",e),t==="$ilike"&&!i.isIndexed)throw new D(`Operator '${t}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(t,"boolean",e);break;default:throw new D(`Unknown operator '${t}' for attribute '${r}' in entity '${s}'`,o)}},Oe=(t,e,n,r,s)=>{const i=Fo(n),o=n.valueType==="json";if(typeof t=="object"&&t!==null&&!Array.isArray(t)){if(o)return;const c=t;for(const[u,l]of Object.entries(c))No(u,l,i,e,r,n,`${s}.${u}`)}else if(!pr(t,i,o))throw new D(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof t}`,s)},Ko=(t,e,n,r,s)=>{const i=t.split(".");if(i.length<2)throw new D(`Invalid dot notation path '${t}'. Must contain at least one dot.`,s);let o=n;for(let l=0;l<i.length-1;l++){const d=i[l],h=r.entities[o];if(!h)throw new D(`Entity '${o}' does not exist in schema while traversing dot notation path '${t}'.`,s);const y=h.links[d];if(!y){const b=Object.keys(h.links);throw new D(`Link '${d}' does not exist on entity '${o}' in dot notation path '${t}'. Available links: ${b.length>0?b.join(", "):"none"}`,s)}o=y.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new D(`Target entity '${o}' does not exist in schema for dot notation path '${t}'.`,s);if(a==="id"){if(typeof e=="string"&&!ve(e))throw new D(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Oe(e,t,new ue("string",!1,!0),n,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!ve(e))throw new D(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Oe(e,t,new ue("string",!1,!0),n,s);return}if(!u){const l=Object.keys(c.attrs);throw new D(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${t}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Oe(e,t,u,n,s)},yr=(t,e,n,r)=>{for(const[s,i]of Object.entries(t)){if(s==="or"||s==="and"){if(Array.isArray(i))for(const u of i)typeof u=="object"&&u!==null&&yr(u,e,n,`${r}.${s}[${u}]`);continue}if(s==="id"){Oe(i,"id",new ue("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){Ko(s,i,e,n,`${r}.${s}`);continue}const o=n.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new D(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)Oe(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!ve(i))throw new D(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new ue("string",!1,!0);Oe(i,s,u,e,`${r}.${s}`)}}},zo=(t,e,n,r,s=0)=>{for(const o of Object.keys(t))if(!hr.includes(o))throw new D(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${hr.join(", ")}. Found: ${o}`,r);const i=["offset","before","after","first","last"];for(const o of i)if(t[o]!==void 0&&s>0)throw new D(`'${o}' can only be used on top-level namespaces. It cannot be used in nested queries.`,r);if(t.where&&n){if(typeof t.where!="object"||t.where===null)throw new D(`'where' clause must be an object in entity '${e}', but received: ${typeof t.where}`,r?`${r}.where`:void 0);yr(t.where,e,n,r?`${r}.where`:"where")}},br=(t,e,n,r,s=0)=>{var i;if(!t||typeof t!="object")throw new D(`Query part for entity '${e}' must be an object, but received: ${typeof t}`,r);for(const o of Object.keys(t))if(o!=="$"){if(n&&!(o in n.entities[e].links)){const c=Object.keys(n.entities[e].links);throw new D(`Link '${o}' does not exist on entity '${e}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${r}.${o}`)}const a=t[o];if(typeof a=="object"&&a!==null){const c=(i=n==null?void 0:n.entities[e].links[o])==null?void 0:i.entityName;c&&br(a,c,n,`${r}.${o}`,s+1)}}else{const a=t[o];if(typeof a!="object"||a===null)throw new D(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof a}`,`${r}.$`);zo(a,e,n,`${r}.$`,s)}},_r=(t,e)=>{if(typeof t!="object"||t===null)throw new D(`Query must be an object, but received: ${typeof t}${t===null?" (null)":""}`);if(Array.isArray(t))throw new D(`Query must be an object, but received: ${typeof t}`);const n=t;for(const r of Object.keys(n)){if(Array.isArray(t[r]))throw new D(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new D(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new D(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}br(n[r],r,e,r,0)}}},gr=t=>typeof t!="string"?!1:rt(t)?!0:ve(t);class X extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Tr=t=>t.length>0?t.join(", "):"none",qo=(t,e)=>new X(`Entity '${t}' does not exist in schema. Available entities: ${Tr(e)}`),Vt={string:t=>typeof t=="string",number:t=>typeof t=="number"&&!isNaN(t),boolean:t=>typeof t=="boolean",date:t=>t instanceof Date||typeof t=="string"||typeof t=="number",json:()=>!0},Vo=(t,e)=>{var n;return t==null?!0:((n=Vt[e.valueType])==null?void 0:n.call(Vt,t))??!1},wr=(t,e)=>{const n=e.entities[t];if(!n)throw qo(t,Object.keys(e.entities));return n},Wt=(t,e,n)=>{const r=wr(t,n);if(typeof e!="object"||e===null)throw new X(`Arguments for data operation on entity '${t}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!Vo(i,o))throw new X(`Invalid value for attribute '${s}' in entity '${t}'. Expected ${o.valueType}, but received: ${typeof i}`)}},mr=(t,e,n)=>{const r=wr(t,n);if(typeof e!="object"||e===null)throw new X(`Arguments for link operation on entity '${t}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new X(`Link '${s}' does not exist on entity '${t}'. Available links: ${Tr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!gr(a))throw new X(`Invalid entity ID in link '${s}' for entity '${t}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!gr(i))throw new X(`Invalid UUID in link '${s}' for entity '${t}'. Expected a UUID, but received: ${i}`)}}},Wo={create:Wt,update:Wt,merge:Wt,link:mr,unlink:mr,delete:()=>{}},Qo=(t,e)=>{if(!e)return;const[n,r,s,i]=t;if(!Array.isArray(s)&&!ve(s))throw new X(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new X(`Entity name must be a string, but received: ${typeof r}`);const o=Wo[n];o&&i!==void 0&&o(r,i,e)},Bo=(t,e)=>{const n=Array.isArray(t)?t:[t];for(const r of n){if(!r||typeof r!="object")throw new X(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new X(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new X(`Transaction operation must be an array, but received: ${typeof s}`);Qo(s,e)}}};let Sr=0;class vr{constructor(e){p(this,"type","ws");p(this,"conn");p(this,"id");p(this,"onopen");p(this,"onmessage");p(this,"onclose");p(this,"onerror");this.id=`${this.type}_${Sr++}`,this.conn=new WebSocket(e),this.conn.onopen=n=>{this.onopen&&this.onopen({target:this})},this.conn.onmessage=n=>{this.onmessage&&this.onmessage({target:this,message:JSON.parse(n.data.toString())})},this.conn.onclose=n=>{this.onclose&&this.onclose({target:this})},this.conn.onerror=n=>{this.onerror&&this.onerror({target:this})}}close(){this.conn.close()}isOpen(){return this.conn.readyState===(WebSocket.OPEN??1)}isConnecting(){return this.conn.readyState===(WebSocket.CONNECTING??0)}send(e){return this.conn.send(JSON.stringify(e))}}class Go{constructor(e,n){p(this,"type","sse");p(this,"initParams",null);p(this,"sendQueue",[]);p(this,"sendPromise");p(this,"closeFired",!1);p(this,"sseInitTimeout");p(this,"ES");p(this,"conn");p(this,"url");p(this,"id");p(this,"onopen");p(this,"onmessage");p(this,"onclose");p(this,"onerror");this.id=`${this.type}_${Sr++}`,this.url=n,this.ES=e,this.conn=new e(n),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=r=>{const s=JSON.parse(r.data);if(Array.isArray(s))for(const i of s)this.handleMessage(i);else this.handleMessage(s)},this.conn.onerror=r=>{this.handleError()}}handleMessage(e){if(e.op==="sse-init"){this.initParams={machineId:e["machine-id"],sessionId:e["session-id"],sseToken:e["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:e})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(e){var n,r,s;try{(await fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(n=this.initParams)==null?void 0:n.machineId,session_id:(r=this.initParams)==null?void 0:r.sessionId,sse_token:(s=this.initParams)==null?void 0:s.sseToken,messages:e})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const e=this.sendQueue;this.sendQueue=[];const n=this.postMessages(e);this.sendPromise=n,n.then(()=>{this.sendPromise=null,this.flushQueue()})}send(e){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(e),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}function Ho(t,e){const n=t.values;if(n){const r=In(n.attrsStore,null);if(r){for(const s of n.entities||[])s.store.useDateObjects=e,s.store=Cn(r,s.store);n.attrsStore=r}}return t}function Jo(t,e){var n;if(e.values){const r=[];for(const s of(n=e.values)==null?void 0:n.entities){const i=Pn(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function Yo(t,e,n){var i,o;const r=(i=e==null?void 0:e.state)==null?void 0:i.txId,s=(o=n==null?void 0:n.state)==null?void 0:o.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?n:e||n}function Qt(t,e,n){return Hn({store:e,attrsStore:n,pageInfo:null,aggregate:null},t.query).data[t.table][0]}function Ar(t,e,n,r){var o;const s=(o=U(n,t.table,"id"))==null?void 0:o.id;if(!s)return-1;const i=Se(e.eav,[r,s,r]);return i?i[3]:-1}function Er(t,e,n){for(const{action:r,triple:s}of n)switch(r){case"added":Rn(t,e,s);break;case"removed":Mn(t,e,s);break}}function Zo(t,e,n){var s,i;const r={};for(const{action:o,triple:a}of n){const[c,u,l]=a,d=(i=(s=e.getAttr(u))==null?void 0:s["forward-identity"])==null?void 0:i[2];if(!d)continue;const h=r[c]??{};r[c]=h;const y=h[d]??{};switch(o){case"added":y.newValue=l;break;case"removed":y.oldValue===void 0&&(y.oldValue=l);break}h[d]=y}for(const[o,a]of Object.entries(r))for(const[c,{oldValue:u,newValue:l}]of Object.entries(a))u===l&&delete a[c];return r}function ot(t,e){return{[t.table]:e.map(n=>n.entity)}}function Xo(t,e){var r;if(t.orderFieldType)return t.orderFieldType;const n=t.orderField==="serverCreatedAt"?"number":(r=U(e(),t.table,t.orderField))==null?void 0:r["checked-data-type"];return t.orderFieldType=n,n}function ea(t,e,n){const r=e;if(t.orderField==="serverCreatedAt"){n.sort(t.orderDirection==="asc"?function(o,a){return Fe(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Fe(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=t.orderField;n.sort(t.orderDirection==="asc"?function(o,a){return Fe(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Fe(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var ge;(function(t){t.InitialSyncBatch="InitialSyncBatch",t.InitialSyncComplete="InitialSyncComplete",t.LoadFromStorage="LoadFromStorage",t.SyncTransaction="SyncTransaction",t.Error="Error"})(ge||(ge={}));class ta{constructor(e,n,r,s,i,o){p(this,"trySend");p(this,"subs");p(this,"callbacks",{});p(this,"config");p(this,"idToHash",{});p(this,"log");p(this,"createStore");p(this,"getAttrs");this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new zt({persister:n,merge:Yo,serialize:Jo,parse:(a,c)=>Ho(c,this.config.useDateObjects),objectSize:a=>{var c;return((c=a.values)==null?void 0:c.entities.length)||0},logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,n){const r=F(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(n),this.initSubscription(e,r,n),s=>{this.unsubscribe(r,n,s==null?void 0:s.keepSubscription)}}unsubscribe(e,n,r){const s=(this.callbacks[e]||[]).filter(i=>i!==n);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i!=null&&i.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend(N(),{op:"start-sync",q:e})}sendResync(e,n,r){this.idToHash[n.subscriptionId]=e.hash,this.trySend(n.subscriptionId,{op:"resync-table","subscription-id":n.subscriptionId,"tx-id":r,token:n.token})}sendRemove(e,n){this.trySend(N(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":n})}async initSubscription(e,n,r){var u,l,d,h;await this.subs.waitForKeyToLoad(n);const s=this.subs.currentValue[n];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),(u=s.values)!=null&&u.entities&&r&&r({type:ge.LoadFromStorage,data:ot(s,(l=s.values)==null?void 0:l.entities)});return}const i=Object.keys(e)[0],o=((h=(d=e[i])==null?void 0:d.$)==null?void 0:h.order)||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(y=>{y[n]={query:e,hash:n,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const n=this.subs.currentValue[e];n?await this.initSubscription(n.query,n.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const n=e["subscription-id"],r=e.q,s=F(r);this.idToHash[n]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",n,"query",r),i;o.state={subscriptionId:n,token:e.token}})}notifyCbs(e,n){for(const r of this.callbacks[e]||[])r(n)}onSyncLoadBatch(e){const n=e["subscription-id"],r=e["join-rows"],s=this.idToHash[n];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),d=Qt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:Ar(o,l,a.attrsStore,d.id)}),i.push(d)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:ge.InitialSyncBatch,data:ot(o,o.values.entities),batch:i})}onSyncInitFinish(e){var i;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(o=>{const a=o[r];if(!a){this.log.error("Missing sub for hash",r,e);return}const c=a.state;if(!c)return this.log.error("Sub never set init, missing result",a,e),o;c.txId=e["tx-id"],a.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:ge.InitialSyncComplete,data:ot(s,((i=s.values)==null?void 0:i.entities)||[])})}onSyncUpdateTriples(e){var o;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const a of e.txes){if(i.txId&&i.txId>=a["tx-id"])continue;i.txId=a["tx-id"];const c=[],u={};for(const w of a.changes){const m=u[w.triple[0]]??[];u[w.triple[0]]=m,m.push(w)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const h=[];e:for(const[w,m]of Object.entries(u))for(let T=0;T<d.length;T++){const v=d[T];if(Ds(v.store,w)){Er(v.store,l.attrsStore,m);const k=Qt(s,v.store,l.attrsStore),A=Zo(v.store,l.attrsStore,m)[w];k?(h.push({oldEntity:v.entity,newEntity:k,changedFields:A||{}}),v.entity=k):c.push(T),delete u[w];continue e}}const y=[];for(const[w,m]of Object.entries(u)){const T=this.createStore([]);Er(T,l.attrsStore,m);const v=Qt(s,T,l.attrsStore);if(!v){this.log.error("No entity found after applying change",{sub:s,changes:m,store:T});continue}d.push({store:T,entity:v,serverCreatedAt:Ar(s,T,l.attrsStore,v.id)}),y.push(v)}const b=[];for(const w of c.sort().reverse())b.push(d[w].entity),d.splice(w,1);const g=Xo(s,this.getAttrs);ea(s,g,d),this.notifyCbs(r,{type:ge.SyncTransaction,data:ot(s,(o=s.values)==null?void 0:o.entities),added:y,removed:b,updated:h})}this.subs.updateInPlace(a=>{a[r]=s,a[r].updatedAt=Date.now()})}clearSubscriptionData(e,n){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,n),n?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const n=F(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(n,{type:ge.Error,data:{[s]:[]},error:r})}onResyncError(e){const n=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(n,!1);r&&this.initSubscription(r.query,r.hash)}}const le={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},na=3e4,ra=3e4,sa=200,ia=1e3*60,oa={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Bt="_instant_oauth_redirect",Ke="currentUser";function aa({transportType:t,appId:e,apiURI:n,wsURI:r,EventSourceImpl:s}){if(!s)return new vr(`${r}?app_id=${e}`);switch(t){case"ws":return new vr(`${r}?app_id=${e}`);case"sse":return new Go(s,`${n}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+t)}}function ca(){return typeof window<"u"||typeof chrome<"u"}const Or={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function ua(t,e){var r;const n=typeof t=="string"?JSON.parse(t):t;if((r=n==null?void 0:n.result)!=null&&r.store){const s=In(n.result.attrsStore,n.result.store);if(s){const i=n.result.store;n.result.store=Cn(s,{...i,useDateObjects:e}),n.result.attrsStore=s}}return n}function la(t,e){const{result:n,...r}=e,s=r;if(n){const i={...n,store:Pn(n.store),attrsStore:n.attrsStore.toJSON()};s.result=i}return s}function fa(t,e){switch(t){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function da(t,e){switch(t){case"pendingMutations":return[...e.entries()];default:return e}}function ha(t,e,n){const r=e==null?void 0:e.result,s=n==null?void 0:n.result;return r&&!s&&n&&(n.result=r),n||e}function Gt(t){return[...t].sort((e,n)=>{const[r,s]=e,[i,o]=n,a=s.order||0,c=o.order||0;return a==c?r<i?-1:r>i?1:0:a-c})}class pa{constructor(e,n=nr,r=rr,s,i){p(this,"attrs");p(this,"_isOnline",!0);p(this,"_isShutdown",!1);p(this,"status",le.CONNECTING);p(this,"querySubs");p(this,"kv");p(this,"_syncTable");p(this,"queryCbs",{});p(this,"queryOnceDfds",{});p(this,"authCbs",[]);p(this,"attrsCbs",[]);p(this,"mutationErrorCbs",[]);p(this,"connectionStatusCbs",[]);p(this,"config");p(this,"mutationDeferredStore",new Map);p(this,"_reconnectTimeoutId",null);p(this,"_reconnectTimeoutMs",0);p(this,"_transport");p(this,"_transportType","ws");p(this,"_EventSource");p(this,"_wsOk",null);p(this,"_localIdPromises",{});p(this,"_errorMessage",null);p(this,"_oauthCallbackResponse",null);p(this,"_linkIndex",null);p(this,"_broadcastChannel");p(this,"_rooms",{});p(this,"_roomsPendingLeave",{});p(this,"_presence",{});p(this,"_broadcastQueue",[]);p(this,"_broadcastSubs",{});p(this,"_currentUserCached",{isLoading:!0,error:void 0,user:void 0});p(this,"_beforeUnloadCbs",[]);p(this,"_dataForQueryCache",{});p(this,"_log");p(this,"_pendingTxCleanupTimeout");p(this,"_pendingMutationCleanupThreshold");p(this,"_inFlightMutationEventIds",new Set);p(this,"_onMergeKv",(e,n,r)=>{switch(e){case"pendingMutations":{const s=(n==null?void 0:n.entries())??[],i=(r==null?void 0:r.entries())??[],o=new Map([...s,...i]);return(n?this._rewriteMutationsSorted(this.attrs,n):[]).forEach(([c,u])=>{var l;!((l=r==null?void 0:r.pendingMutations)!=null&&l.has(c))&&!u["tx-id"]&&this._sendMutation(c,u)}),o}default:return r||n}});p(this,"getPreviousResult",e=>{var r;const n=F(e);return(r=this.dataForQuery(n))==null?void 0:r.data});p(this,"notifyOne",e=>{var i;const n=this.queryCbs[e]??[],r=(i=this._dataForQueryCache[e])==null?void 0:i.data,s=this.dataForQuery(e);s!=null&&s.data&&(this._dataForQueryCache[e]=s,!Ye(s.data,r)&&n.forEach(o=>o.cb(s.data)))});p(this,"notifyOneQueryOnce",e=>{var s;const n=this.queryOnceDfds[e]??[],r=(s=this.dataForQuery(e))==null?void 0:s.data;n.forEach(i=>{this._completeQueryOnce(i.q,e,i.dfd),i.dfd.resolve(r)})});p(this,"notifyQueryError",(e,n)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:n}))});p(this,"pushTx",e=>{this.config.disableValidation||Bo(e,this.config.schema);try{const n=_o({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>{var s;return(s=r==null?void 0:r.result)==null?void 0:s.store}),useDateObjects:this.config.useDateObjects},e);return this.pushOps(n)}catch(n){return this.pushOps([],n)}});p(this,"pushOps",(e,n)=>{const r=N(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:n,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new cr;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise});p(this,"_transportOnOpen",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][open]",n.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(le.OPENED),this.getCurrentUser().then(r=>{var s;this._trySend(N(),{op:"init","app-id":this.config.appId,"refresh-token":(s=r.user)==null?void 0:s.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",n.id,r)})});p(this,"_transportOnMessage",e=>{const n=e.target,r=e.message;if(this._transport!==n){this._log.info("[socket][message]",n.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&n.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(n.id,s);else this._handleReceive(n.id,e.message)});p(this,"_transportOnError",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][error]",n.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",n.id,e)});p(this,"_scheduleReconnect",()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)});p(this,"_transportOnClose",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][close]",n.id,"skip; this is no longer the current transport");return}this._setStatus(le.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",n.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",n.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()});if(this._EventSource=i,this.config={...oa,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??ra,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??sa,this._log=Lo(e.verbose||qt||ir,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":dr},this.config.schema&&(this._linkIndex=fr(this.config.schema)),!!ca()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!ve(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{var a;try{if(((a=o.data)==null?void 0:a.type)==="auth"){const c=await this.getCurrentUser();this.updateUser(c.user)}}catch(c){this._log.error("[error] handle broadcast channel",c)}})),this._initStorage(n),this._syncTable=new ta(this._trySendAuthed.bind(this),new n(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>$e(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._oauthCallbackResponse=this._oauthLoginInit(),this.getCurrentUser().then(o=>{this.syncUserToEndpoint(o.user)}),setInterval(async()=>{const o=await this.getCurrentUser();this.syncUserToEndpoint(o.user)},ia),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",le.CLOSED),this._setStatus(le.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?fr(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new zt({persister:new e(this.config.appId,"querySubs"),merge:ha,serialize:la,parse:(n,r)=>ua(r,this.config.useDateObjects),objectSize:n=>{var r,s,i;return((i=(s=(r=n==null?void 0:n.result)==null?void 0:r.store)==null?void 0:s.triples)==null?void 0:i.length)??0},logger:this._log,preloadEntryCount:10,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}}),this.querySubs.onKeyLoaded=n=>this._onQuerySubLoaded(n),this.kv=new zt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:da,parse:fa,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=n=>{n==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(Ke),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,n,r){const s=this.mutationDeferredStore.get(n);this.mutationDeferredStore.delete(n);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:n,...r}),!!s)if(i)s.resolve({status:e,eventId:n});else if(r!=null&&r.type){const{status:o,...a}=r;s.reject(new it({body:a,status:o??0}))}else s.reject(new Ee((r==null?void 0:r.message)||"Unknown error",r==null?void 0:r.hint))}_setStatus(e,n){this.status=e,this._errorMessage=n,this.notifyConnectionStatusSubs(e)}_flushEnqueuedRoomData(e){var s,i;const n=(i=(s=this._presence[e])==null?void 0:s.result)==null?void 0:i.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],n&&this._trySetPresence(e,n),r)for(const o of r){const{topic:a,roomType:c,data:u}=o;this._tryBroadcast(e,c,a,u)}}_addQueryData(e,n,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=F(e),i=this.ensureAttrs(),o=$e(this.attrs,n.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:n.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,n){var s,i,o,a,c,u;const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(Or[n.op]||this._log.info("[receive]",e,n.op,n),n.op){case"init-ok":{this._setStatus(le.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(n.attrs),this._flushPendingMessages(),this._sessionId=n["session-id"];for(const h of Object.keys(this._rooms)){const y=(i=(s=this._presence[h])==null?void 0:s.result)==null?void 0:i.user;this._tryJoinRoom(h,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(F(n.q));break}case"add-query-ok":{const{q:h,result:y}=n,b=F(h);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[b])break;const g=(a=(o=y==null?void 0:y[0])==null?void 0:o.data)==null?void 0:a["page-info"],w=(u=(c=y==null?void 0:y[0])==null?void 0:c.data)==null?void 0:u.aggregate,m=lr(y),T=this.ensureAttrs(),v=$e(T,m,r,this.config.useDateObjects);this.querySubs.updateInPlace(k=>{if(!k[b]){this._log.info("Missing value in querySubs",{hash:b,q:h});return}k[b].result={store:v,attrsStore:T,pageInfo:g,aggregate:w,processedTxId:n["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(b),this.notifyOneQueryOnce(b),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(n);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(n);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(n);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(n);break}case"refresh-ok":{const{computations:h,attrs:y}=n,b=n["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),b);g!==this._pendingMutations()&&this.kv.updateInPlace(T=>{T.pendingMutations=g});const w=Gt(g.entries()),m=h.map(T=>{var qe,se,oe,de;const v=T["instaql-query"],k=T["instaql-result"],A=F(v),R=lr(k),K=this.ensureAttrs(),V=$e(K,R,r,this.config.useDateObjects),{store:ze,attrsStore:ut}=this._applyOptimisticUpdates(V,K,w,b),Yt=(se=(qe=k==null?void 0:k[0])==null?void 0:qe.data)==null?void 0:se["page-info"],Zt=(de=(oe=k==null?void 0:k[0])==null?void 0:oe.data)==null?void 0:de.aggregate;return{q:v,hash:A,store:ze,attrsStore:ut,pageInfo:Yt,aggregate:Zt}});m.forEach(({hash:T,q:v,store:k,attrsStore:A,pageInfo:R,aggregate:K})=>{this.querySubs.updateInPlace(V=>{if(!V[T]){this._log.error("Missing value in querySubs",{hash:T,q:v});return}V[T].result={store:k,attrsStore:A,pageInfo:R,aggregate:K,processedTxId:b}})}),this._cleanupPendingMutationsQueries(),m.forEach(({hash:T})=>{this.notifyOne(T)});break}case"transact-ok":{const{"client-event-id":h,"tx-id":y}=n;this._inFlightMutationEventIds.delete(h);const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(h);if(!g)break;this._updatePendingMutations(m=>{m.set(h,{...m.get(h),"tx-id":y,confirmed:Date.now()})});const w=[];for(const m of g["tx-steps"])if(m[0]==="add-attr"){const T=m[1];w.push(T)}if(w.length){const m=Object.values(this.ensureAttrs().attrs);this._setAttrs([...m,...w])}this._finishTransaction("synced",h),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const h=n["room-id"];this._trySetRoomConnected(h,!0),this._patchPresencePeers(h,n.edits),this._notifyPresenceSubs(h);break}case"refresh-presence":{const h=n["room-id"];this._trySetRoomConnected(h,!0),this._setPresencePeers(h,n.data),this._notifyPresenceSubs(h);break}case"server-broadcast":{const h=n["room-id"],y=n.topic;this._trySetRoomConnected(h,!0),this._notifyBroadcastSubs(h,y,n);break}case"join-room-ok":{const h=n["room-id"];if(!this._rooms[h]){this._roomsPendingLeave[h]&&(this._tryLeaveRoom(h),delete this._roomsPendingLeave[h]);break}this._trySetRoomConnected(h,!0),this._flushEnqueuedRoomData(h);break}case"leave-room-ok":{const h=n["room-id"];this._trySetRoomConnected(h,!1);break}case"join-room-error":const l=n["room-id"],d=this._rooms[l];d&&(d.error=n.error),this._notifyPresenceSubs(l);break;case"error":this._handleReceiveError(n);break;default:this._log.info("Uknown op",n.op,n);break}}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(n=>{const r=n.pendingMutations??new Map;n.pendingMutations=r,e(r)})}_handleMutationError(e,n,r){const s=this._pendingMutations().get(n);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(n),o)),this._inFlightMutationEventIds.delete(n);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,n,r)}}_handleReceiveError(e){var a,c,u,l,d,h,y;console.log("error",e);const n=e["client-event-id"];this._inFlightMutationEventIds.delete(n);const r=this._pendingMutations().get(n),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",n,e);return}if((a=e["original-event"])!=null&&a.hasOwnProperty("q")&&((c=e["original-event"])==null?void 0:c.op)==="add-query"){const b=(u=e["original-event"])==null?void 0:u.q,g=F(b);this.notifyQueryError(F(b),s),this.notifyQueryOnceError(b,g,n,s);return}if(((l=e["original-event"])==null?void 0:l.op)==="init"){if(e.type==="record-not-found"&&((d=e.hint)==null?void 0:d["record-type"])==="app-user"){this.changeCurrentUser(null);return}this._setStatus(le.ERRORED,s),this.notifyAll();return}if(((h=e["original-event"])==null?void 0:h.op)==="resync-table"){this._syncTable.onResyncError(e);return}if(((y=e["original-event"])==null?void 0:y.op)==="start-sync"){this._syncTable.onStartSyncError(e);return}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
30
+ <%s key={someKey} {...props} />`,an,we,pc,we),Yr[we+an]=!0}}return f===s?uc(L):cc(L),L}}function lc(f,_,S){return Zr(f,_,S,!0)}function fc(f,_,S){return Zr(f,_,S,!1)}var dc=fc,hc=lc;Ie.Fragment=s,Ie.jsx=dc,Ie.jsxs=hc}(),Ie}var ts={};ts.NODE_ENV==="production"?fe.exports=Xr():fe.exports=es();var We=fe.exports;function F(t){if(typeof t=="number")return(Math.abs(t*2654435761)>>>0).toString(16);if(typeof t=="boolean")return t?"1":"0";if(t===null)return"null";if(t===void 0)return"undefined";if(typeof t=="string"){let e=2166136261;for(let n=0;n<t.length;n++)e^=t.charCodeAt(n),e+=(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24),e=e>>>0;return e.toString(16)}if(Array.isArray(t)){let e=2166136261;for(let n=0;n<t.length;n++){e^=(n+1)*2654435761;const r=F(t[n]);for(let s=0;s<r.length;s++)e^=r.charCodeAt(s),e*=16777619,e=e>>>0}return e.toString(16)}if(typeof t=="object"){let e=2166136261;const n=Object.keys(t).sort();for(let r=0;r<n.length;r++){const s=n[r],i=F(s);e^=parseInt(i,16),e*=16777619,e=e>>>0;const o=F(t[s]);e^=parseInt(o,16),e*=16777619,e=e>>>0}return e.toString(16)}return F(String(t))}const x={Remove:"remove",Replace:"replace",Add:"add"},ln=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),ns=Symbol("__MUTATIVE_RAW_RETURN_SYMBOL__"),Qe=Symbol.iterator,Y={mutable:"mutable",immutable:"immutable"},pt={};function Me(t,e){return t instanceof Map?t.has(e):Object.prototype.hasOwnProperty.call(t,e)}function fn(t,e){if(e in t){let n=Reflect.getPrototypeOf(t);for(;n;){const r=Reflect.getOwnPropertyDescriptor(n,e);if(r)return r;n=Reflect.getPrototypeOf(n)}}}function yt(t){return Object.getPrototypeOf(t)===Set.prototype}function bt(t){return Object.getPrototypeOf(t)===Map.prototype}function Z(t){var e;return(e=t.copy)!==null&&e!==void 0?e:t.original}function he(t){return!!P(t)}function P(t){return typeof t!="object"?null:t==null?void 0:t[ln]}function _t(t){var e;const n=P(t);return n?(e=n.copy)!==null&&e!==void 0?e:n.original:t}function te(t,e){if(!t||typeof t!="object")return!1;let n;return Object.getPrototypeOf(t)===Object.prototype||Array.isArray(t)||t instanceof Map||t instanceof Set||!!(e!=null&&e.mark)&&((n=e.mark(t,Y))===Y.immutable||typeof n=="function")}function dn(t,e=[]){if(Object.hasOwnProperty.call(t,"key")){const n=t.parent.copy,r=P(ae(n,t.key));if(r!==null&&(r==null?void 0:r.original)!==t.original)return null;const s=t.parent.type===3,i=s?Array.from(t.parent.setMap.keys()).indexOf(t.key):t.key;if(!(s&&n.size>i||Me(n,i)))return null;e.push(i)}if(t.parent)return dn(t.parent,e);e.reverse();try{rs(t.copy,e)}catch{return null}return e}function pe(t){return Array.isArray(t)?1:t instanceof Map?2:t instanceof Set?3:0}function ae(t,e){return pe(t)===2?t.get(e):t[e]}function je(t,e,n){pe(t)===2?t.set(e,n):t[e]=n}function gt(t,e){const n=P(t);return(n?Z(n):t)[e]}function ce(t,e){return t===e?t!==0||1/t===1/e:t!==t&&e!==e}function Tt(t){if(t)for(;t.finalities.revoke.length>0;)t.finalities.revoke.pop()()}function ye(t,e){return e?t:[""].concat(t).map(n=>{const r=`${n}`;return r.indexOf("/")===-1&&r.indexOf("~")===-1?r:r.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function rs(t,e){for(let n=0;n<e.length-1;n+=1){const r=e[n];if(t=ae(pe(t)===3?Array.from(t):t,r),typeof t!="object")throw new Error(`Cannot resolve patch at '${e.join("/")}'.`)}return t}function ss(t){const e=Object.create(Object.getPrototypeOf(t));return Reflect.ownKeys(t).forEach(n=>{let r=Reflect.getOwnPropertyDescriptor(t,n);if(r.enumerable&&r.configurable&&r.writable){e[n]=t[n];return}r.writable||(r.writable=!0,r.configurable=!0),(r.get||r.set)&&(r={configurable:!0,writable:!0,enumerable:r.enumerable,value:t[n]}),Reflect.defineProperty(e,n,r)}),e}const is=Object.prototype.propertyIsEnumerable;function hn(t,e){let n;if(Array.isArray(t))return Array.prototype.concat.call(t);if(t instanceof Set){if(!yt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t.values())}return Set.prototype.difference?Set.prototype.difference.call(t,new Set):new Set(t.values())}else if(t instanceof Map){if(!bt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(t)}return new Map(t)}else if(e!=null&&e.mark&&(n=e.mark(t,Y),n!==void 0)&&n!==Y.mutable){if(n===Y.immutable)return ss(t);if(typeof n=="function"){if(e.enablePatches||e.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return n()}throw new Error(`Unsupported mark result: ${n}`)}else if(typeof t=="object"&&Object.getPrototypeOf(t)===Object.prototype){const r={};return Object.keys(t).forEach(s=>{r[s]=t[s]}),Object.getOwnPropertySymbols(t).forEach(s=>{is.call(t,s)&&(r[s]=t[s])}),r}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function q(t){t.copy||(t.copy=hn(t.original,t.options))}function Re(t){if(!te(t))return _t(t);if(Array.isArray(t))return t.map(Re);if(t instanceof Map){const n=Array.from(t.entries()).map(([r,s])=>[r,Re(s)]);if(!bt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Map(n)}if(t instanceof Set){const n=Array.from(t).map(Re);if(!yt(t)){const r=Object.getPrototypeOf(t).constructor;return new r(n)}return new Set(n)}const e=Object.create(Object.getPrototypeOf(t));for(const n in t)e[n]=Re(t[n]);return e}function Be(t){return he(t)?Re(t):t}function ie(t){var e;t.assignedMap=(e=t.assignedMap)!==null&&e!==void 0?e:new Map,t.operated||(t.operated=!0,t.parent&&ie(t.parent))}function pn(){throw new Error("Cannot modify frozen object")}function me(t,e,n,r,s){{n=n??new WeakMap,r=r??[],s=s??[];const o=n.has(t)?n.get(t):t;if(r.length>0){const a=r.indexOf(o);if(o&&typeof o=="object"&&a!==-1)throw r[0]===o?new Error("Forbids circular reference"):new Error(`Forbids circular reference: ~/${s.slice(0,a).map((c,u)=>{if(typeof c=="symbol")return`[${c.toString()}]`;const l=r[u];return typeof c=="object"&&(l instanceof Map||l instanceof Set)?Array.from(l.keys()).indexOf(c):c}).join("/")}`);r.push(o),s.push(e)}else r.push(o)}if(Object.isFrozen(t)||he(t)){r.pop(),s.pop();return}switch(pe(t)){case 2:for(const[a,c]of t)me(a,a,n,r,s),me(c,a,n,r,s);t.set=t.clear=t.delete=pn;break;case 3:for(const a of t)me(a,a,n,r,s);t.add=t.clear=t.delete=pn;break;case 1:Object.freeze(t);let o=0;for(const a of t)me(a,o,n,r,s),o+=1;break;default:Object.freeze(t),Object.keys(t).forEach(a=>{const c=t[a];me(c,a,n,r,s)})}r.pop(),s.pop()}function wt(t,e){const n=pe(t);if(n===0)Reflect.ownKeys(t).forEach(r=>{e(r,t[r],t)});else if(n===1){let r=0;for(const s of t)e(r,s,t),r+=1}else t.forEach((r,s)=>e(s,r,t))}function yn(t,e,n){if(he(t)||!te(t,n)||e.has(t)||Object.isFrozen(t))return;const r=t instanceof Set,s=r?new Map:void 0;if(e.add(t),wt(t,(i,o)=>{var a;if(he(o)){const c=P(o);q(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;je(r?s:t,i,u)}else yn(o,e,n)}),s){const i=t,o=Array.from(i);i.clear(),o.forEach(a=>{i.add(s.has(a)?s.get(a):a)})}}function os(t,e){const n=t.type===3?t.setMap:t.copy;t.finalities.revoke.length>1&&t.assignedMap.get(e)&&n&&yn(ae(n,e),t.finalities.handledSet,t.options)}function mt(t){t.type===3&&t.copy&&(t.copy.clear(),t.setMap.forEach(e=>{t.copy.add(_t(e))}))}function St(t,e,n,r){if(t.operated&&t.assignedMap&&t.assignedMap.size>0&&!t.finalized){if(n&&r){const i=dn(t);i&&e(t,i,n,r)}t.finalized=!0}}function vt(t,e,n,r){const s=P(n);s&&(s.callbacks||(s.callbacks=[]),s.callbacks.push((i,o)=>{var a;const c=t.type===3?t.setMap:t.copy;if(ce(ae(c,e),n)){let u=s.original;s.copy&&(u=s.copy),mt(t),St(t,r,i,o),t.options.enableAutoFreeze&&(t.options.updatedValues=(a=t.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,t.options.updatedValues.set(u,s.original)),je(c,e,u)}}),t.options.enableAutoFreeze&&s.finalities!==t.finalities&&(t.options.enableAutoFreeze=!1)),te(n,t.options)&&t.finalities.draft.push(()=>{const i=t.type===3?t.setMap:t.copy;ce(ae(i,e),n)&&os(t,e)})}function as(t,e,n,r,s){let{original:i,assignedMap:o,options:a}=t,c=t.copy;c.length<i.length&&([i,c]=[c,i],[n,r]=[r,n]);for(let u=0;u<i.length;u+=1)if(o.get(u.toString())&&c[u]!==i[u]){const l=e.concat([u]),d=ye(l,s);n.push({op:x.Replace,path:d,value:Be(c[u])}),r.push({op:x.Replace,path:d,value:Be(i[u])})}for(let u=i.length;u<c.length;u+=1){const l=e.concat([u]),d=ye(l,s);n.push({op:x.Add,path:d,value:Be(c[u])})}if(i.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=e.concat(["length"]),d=ye(l,s);r.push({op:x.Replace,path:d,value:i.length})}else for(let l=c.length;i.length<l;l-=1){const d=e.concat([l-1]),h=ye(d,s);r.push({op:x.Remove,path:h})}}}function cs({original:t,copy:e,assignedMap:n},r,s,i,o){n.forEach((a,c)=>{const u=ae(t,c),l=Be(ae(e,c)),d=a?Me(t,c)?x.Replace:x.Add:x.Remove;if(ce(u,l)&&d===x.Replace)return;const h=r.concat(c),y=ye(h,o);s.push(d===x.Remove?{op:d,path:y}:{op:d,path:y,value:l}),i.push(d===x.Add?{op:x.Remove,path:y}:d===x.Remove?{op:x.Add,path:y,value:u}:{op:x.Replace,path:y,value:u})})}function us({original:t,copy:e},n,r,s,i){let o=0;t.forEach(a=>{if(!e.has(a)){const c=n.concat([o]),u=ye(c,i);r.push({op:x.Remove,path:u,value:a}),s.unshift({op:x.Add,path:u,value:a})}o+=1}),o=0,e.forEach(a=>{if(!t.has(a)){const c=n.concat([o]),u=ye(c,i);r.push({op:x.Add,path:u,value:a}),s.unshift({op:x.Remove,path:u,value:a})}o+=1})}function De(t,e,n,r){const{pathAsArray:s=!0}=t.options.enablePatches;switch(t.type){case 0:case 2:return cs(t,e,n,r,s);case 1:return as(t,e,n,r,s);case 3:return us(t,e,n,r,s)}}const Ge=(t,e,n=!1)=>{if(typeof t=="object"&&t!==null&&(!te(t,e)||n))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},At={get size(){return Z(P(this)).size},has(t){return Z(P(this)).has(t)},set(t,e){const n=P(this),r=Z(n);return(!r.has(t)||!ce(r.get(t),e))&&(q(n),ie(n),n.assignedMap.set(t,!0),n.copy.set(t,e),vt(n,t,e,De)),this},delete(t){if(!this.has(t))return!1;const e=P(this);return q(e),ie(e),e.original.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.copy.delete(t),!0},clear(){const t=P(this);if(this.size){q(t),ie(t),t.assignedMap=new Map;for(const[e]of t.original)t.assignedMap.set(e,!1);t.copy.clear()}},forEach(t,e){const n=P(this);Z(n).forEach((r,s)=>{t.call(e,this.get(s),s,this)})},get(t){var e,n;const r=P(this),s=Z(r).get(t),i=((n=(e=r.options).mark)===null||n===void 0?void 0:n.call(e,s,Y))===Y.mutable;if(r.options.strict&&Ge(s,r.options,i),i||r.finalized||!te(s,r.options)||s!==r.original.get(t))return s;const o=pt.createDraft({original:s,parentDraft:r,key:t,finalities:r.finalities,options:r.options});return q(r),r.copy.set(t,o),o},keys(){return Z(P(this)).keys()},values(){const t=this.keys();return{[Qe]:()=>this.values(),next:()=>{const e=t.next();return e.done?e:{done:!1,value:this.get(e.value)}}}},entries(){const t=this.keys();return{[Qe]:()=>this.entries(),next:()=>{const e=t.next();if(e.done)return e;const n=this.get(e.value);return{done:!1,value:[e.value,n]}}}},[Qe](){return this.entries()}},ls=Reflect.ownKeys(At),bn=(t,e,{isValuesIterator:n})=>()=>{var r,s;const i=e.next();if(i.done)return i;const o=i.value;let a=t.setMap.get(o);const c=P(a),u=((s=(r=t.options).mark)===null||s===void 0?void 0:s.call(r,a,Y))===Y.mutable;if(t.options.strict&&Ge(o,t.options,u),!u&&!c&&te(o,t.options)&&!t.finalized&&t.original.has(o)){const l=pt.createDraft({original:o,parentDraft:t,key:o,finalities:t.finalities,options:t.options});t.setMap.set(o,l),a=l}else c&&(a=c.proxy);return{done:!1,value:n?a:[a,a]}},He={get size(){return P(this).setMap.size},has(t){const e=P(this);if(e.setMap.has(t))return!0;q(e);const n=P(t);return!!(n&&e.setMap.has(n.original))},add(t){const e=P(this);return this.has(t)||(q(e),ie(e),e.assignedMap.set(t,!0),e.setMap.set(t,t),vt(e,t,t,De)),this},delete(t){if(!this.has(t))return!1;const e=P(this);q(e),ie(e);const n=P(t);return n&&e.setMap.has(n.original)?(e.assignedMap.set(n.original,!1),e.setMap.delete(n.original)):(!n&&e.setMap.has(t)?e.assignedMap.set(t,!1):e.assignedMap.delete(t),e.setMap.delete(t))},clear(){if(!this.size)return;const t=P(this);q(t),ie(t);for(const e of t.original)t.assignedMap.set(e,!1);t.setMap.clear()},values(){const t=P(this);q(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:bn(t,e,{isValuesIterator:!0})}},entries(){const t=P(this);q(t);const e=t.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:bn(t,e,{isValuesIterator:!1})}},keys(){return this.values()},[Qe](){return this.values()},forEach(t,e){const n=this.values();let r=n.next();for(;!r.done;)t.call(e,r.value,r.value,this),r=n.next()}};Set.prototype.difference&&Object.assign(He,{intersection(t){return Set.prototype.intersection.call(new Set(this.values()),t)},union(t){return Set.prototype.union.call(new Set(this.values()),t)},difference(t){return Set.prototype.difference.call(new Set(this.values()),t)},symmetricDifference(t){return Set.prototype.symmetricDifference.call(new Set(this.values()),t)},isSubsetOf(t){return Set.prototype.isSubsetOf.call(new Set(this.values()),t)},isSupersetOf(t){return Set.prototype.isSupersetOf.call(new Set(this.values()),t)},isDisjointFrom(t){return Set.prototype.isDisjointFrom.call(new Set(this.values()),t)}});const fs=Reflect.ownKeys(He),_n=new WeakSet,gn={get(t,e,n){var r,s;const i=(r=t.copy)===null||r===void 0?void 0:r[e];if(i&&_n.has(i))return i;if(e===ln)return t;let o;if(t.options.mark){const u=e==="size"&&(t.original instanceof Map||t.original instanceof Set)?Reflect.get(t.original,e):Reflect.get(t.original,e,n);if(o=t.options.mark(u,Y),o===Y.mutable)return t.options.strict&&Ge(u,t.options,!0),u}const a=Z(t);if(a instanceof Map&&ls.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(At,"size").get.call(t.proxy);const u=At[e];if(u)return u.bind(t.proxy)}if(a instanceof Set&&fs.includes(e)){if(e==="size")return Object.getOwnPropertyDescriptor(He,"size").get.call(t.proxy);const u=He[e];if(u)return u.bind(t.proxy)}if(!Me(a,e)){const u=fn(a,e);return u?"value"in u?u.value:(s=u.get)===null||s===void 0?void 0:s.call(t.proxy):void 0}const c=a[e];if(t.options.strict&&Ge(c,t.options),t.finalized||!te(c,t.options))return c;if(c===gt(t.original,e)){if(q(t),t.copy[e]=Et({original:t.original[e],parentDraft:t,key:t.type===1?Number(e):e,finalities:t.finalities,options:t.options}),typeof o=="function"){const u=P(t.copy[e]);return q(u),ie(u),u.copy}return t.copy[e]}return c},set(t,e,n){var r;if(t.type===3||t.type===2)throw new Error("Map/Set draft does not support any property assignment.");let s;if(t.type===1&&e!=="length"&&!(Number.isInteger(s=Number(e))&&s>=0&&(e===0||s===0||String(s)===String(e))))throw new Error("Only supports setting array indices and the 'length' property.");const i=fn(Z(t),e);if(i!=null&&i.set)return i.set.call(t.proxy,n),!0;const o=gt(Z(t),e),a=P(o);return a&&ce(a.original,n)?(t.copy[e]=n,t.assignedMap=(r=t.assignedMap)!==null&&r!==void 0?r:new Map,t.assignedMap.set(e,!1),!0):(ce(n,o)&&(n!==void 0||Me(t.original,e))||(q(t),ie(t),Me(t.original,e)&&ce(n,t.original[e])?t.assignedMap.delete(e):t.assignedMap.set(e,!0),t.copy[e]=n,vt(t,e,n,De)),!0)},has(t,e){return e in Z(t)},ownKeys(t){return Reflect.ownKeys(Z(t))},getOwnPropertyDescriptor(t,e){const n=Z(t),r=Reflect.getOwnPropertyDescriptor(n,e);return r&&{writable:!0,configurable:t.type!==1||e!=="length",enumerable:r.enumerable,value:n[e]}},getPrototypeOf(t){return Reflect.getPrototypeOf(t.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(t,e){var n;return t.type===1?gn.set.call(this,t,e,void 0,t.proxy):(gt(t.original,e)!==void 0||e in t.original?(q(t),ie(t),t.assignedMap.set(e,!1)):(t.assignedMap=(n=t.assignedMap)!==null&&n!==void 0?n:new Map,t.assignedMap.delete(e)),t.copy&&delete t.copy[e],!0)}};function Et(t){const{original:e,parentDraft:n,key:r,finalities:s,options:i}=t,o=pe(e),a={type:o,finalized:!1,parent:n,original:e,copy:null,proxy:null,finalities:s,options:i,setMap:o===3?new Map(e.entries()):void 0};(r||"key"in t)&&(a.key=r);const{proxy:c,revoke:u}=Proxy.revocable(o===1?Object.assign([],a):a,gn);if(s.revoke.push(u),_n.add(c),a.proxy=c,n){const l=n;l.finalities.draft.push((d,h)=>{var y,b;const g=P(c);let w=l.type===3?l.setMap:l.copy;const m=ae(w,r),T=P(m);if(T){let v=T.original;T.operated&&(v=_t(m)),mt(T),St(T,De,d,h),l.options.enableAutoFreeze&&(l.options.updatedValues=(y=l.options.updatedValues)!==null&&y!==void 0?y:new WeakMap,l.options.updatedValues.set(v,T.original)),je(w,r,v)}(b=g.callbacks)===null||b===void 0||b.forEach(v=>{v(d,h)})})}else{const l=P(c);l.finalities.draft.push((d,h)=>{mt(l),St(l,De,d,h)})}return c}pt.createDraft=Et;function ds(t,e,n,r,s){var i;const o=P(t),a=(i=o==null?void 0:o.original)!==null&&i!==void 0?i:t,c=!!e.length;if(o!=null&&o.operated)for(;o.finalities.draft.length>0;)o.finalities.draft.pop()(n,r);const u=c?e[0]:o?o.operated?o.copy:o.original:t;return o&&Tt(o),s&&me(u,u,o==null?void 0:o.options.updatedValues),[u,n&&c?[{op:x.Replace,path:[],value:e[0]}]:n,r&&c?[{op:x.Replace,path:[],value:a}]:r]}function hs(t,e){var n;const r={draft:[],revoke:[],handledSet:new WeakSet};let s,i;e.enablePatches&&(s=[],i=[]);const a=((n=e.mark)===null||n===void 0?void 0:n.call(e,t,Y))===Y.mutable||!te(t,e)?t:Et({original:t,parentDraft:null,finalities:r,options:e});return[a,(c=[])=>{const[u,l,d]=ds(a,c,s,i,e.enableAutoFreeze);return e.enablePatches?[u,l,d]:u}]}function Ot(t){const{rootDraft:e,value:n,useRawReturn:r=!1,isRoot:s=!0}=t;wt(n,(i,o,a)=>{const c=P(o);if(c&&e&&c.finalities===e.finalities){t.isContainDraft=!0;const u=c.original;if(a instanceof Set){const l=Array.from(a);a.clear(),l.forEach(d=>a.add(i===d?u:d))}else je(a,i,u)}else typeof o=="object"&&o!==null&&(t.value=o,t.isRoot=!1,Ot(t))}),s&&(t.isContainDraft||console.warn("The return value does not contain any draft, please use 'rawReturn()' to wrap the return value to improve performance."),r&&console.warn("The return value contains drafts, please don't use 'rawReturn()' to wrap the return value."))}function Tn(t){var e;const n=P(t);if(!te(t,n==null?void 0:n.options))return t;const r=pe(t);if(n&&!n.operated)return n.original;let s;function i(){s=r===2?bt(t)?new Map(t):new(Object.getPrototypeOf(t)).constructor(t):r===3?Array.from(n.setMap.values()):hn(t,n==null?void 0:n.options)}if(n){n.finalized=!0;try{i()}finally{n.finalized=!1}}else s=t;if(wt(s,(o,a)=>{if(n&&ce(ae(n.original,o),a))return;const c=Tn(a);c!==a&&(s===t&&i(),je(s,o,c))}),r===3){const o=(e=n==null?void 0:n.original)!==null&&e!==void 0?e:s;return yt(o)?new Set(s):new(Object.getPrototypeOf(o)).constructor(s)}return s}function wn(t){if(!he(t))throw new Error(`current() is only used for Draft, parameter: ${t}`);return Tn(t)}const Je=(t=>function e(n,r,s){var i,o,a;if(typeof n=="function"&&typeof r!="function")return function(A,...R){return e(A,K=>n.call(this,K,...R),r)};const c=n,u=r;let l=s;if(typeof r!="function"&&(l=r),l!==void 0&&Object.prototype.toString.call(l)!=="[object Object]")throw new Error(`Invalid options: ${l}, 'options' should be an object.`);l=Object.assign(Object.assign({},t),l);const d=he(c)?wn(c):c,h=Array.isArray(l.mark)?(A,R)=>{for(const K of l.mark){if(typeof K!="function")throw new Error(`Invalid mark: ${K}, 'mark' should be a function.`);const V=K(A,R);if(V)return V}}:l.mark,y=(i=l.enablePatches)!==null&&i!==void 0?i:!1,b=(o=l.strict)!==null&&o!==void 0?o:!1,w={enableAutoFreeze:(a=l.enableAutoFreeze)!==null&&a!==void 0?a:!1,mark:h,strict:b,enablePatches:y};if(!te(d,w)&&typeof d=="object"&&d!==null)throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");const[m,T]=hs(d,w);if(typeof r!="function"){if(!te(d,w))throw new Error("Invalid base state: create() only supports plain objects, arrays, Set, Map or using mark() to mark the state as immutable.");return[m,T]}let v;try{v=u(m)}catch(A){throw Tt(P(m)),A}const k=A=>{const R=P(m);if(!he(A)){if(A!==void 0&&!ce(A,m)&&(R!=null&&R.operated))throw new Error("Either the value is returned as a new non-draft value, or only the draft is modified without returning any value.");const V=A==null?void 0:A[ns];if(V){const ze=V[0];return w.strict&&typeof A=="object"&&A!==null&&Ot({rootDraft:R,value:A,useRawReturn:!0}),T([ze])}if(A!==void 0)return typeof A=="object"&&A!==null&&Ot({rootDraft:R,value:A}),T([A])}if(A===m||A===void 0)return T([]);const K=P(A);if(w===K.options){if(K.operated)throw new Error("Cannot return a modified child draft.");return T([wn(A)])}return T([A])};return v instanceof Promise?v.then(k,A=>{throw Tt(P(m)),A}):k(v)})();Object.prototype.constructor.toString();function mn(t,e){const n=Object.keys(t),r=Object.keys(e);return n.length===r.length&&Object.keys(t).every(s=>e.hasOwnProperty(s))}function Sn(t,e){return Object.keys(t).length===Object.keys(e).length&&Object.keys(t).every(n=>e.hasOwnProperty(n)&&t[n]===e[n])}function Ye(t,e){return typeof t!="object"||typeof e!="object"||t===null||e===null?t===e:mn(t,e)?Object.keys(t).every(n=>Ye(t[n],e[n])):!1}function kt(t){if(!xe(t))return t;const e={};for(const[n,r]of Object.entries(t))r!==void 0&&(e[n]=r);return e}function vn(t,e){if(!xe(t)||!xe(e))return e;const n={...t};for(const r of Object.keys(e)){if(e[r]===void 0)continue;if(e[r]===null){delete n[r];continue}const s=xe(t[r])&&xe(e[r]);n[r]=s?vn(t[r],e[r]):e[r]}return n}function xe(t){return typeof t=="object"&&t!==null&&!Array.isArray(t)}function ps(t,e,n){if(!t||e.length===0)return;let r=t||{};for(let i=0;i<e.length-1;i++){const o=e[i];(!(o in r)||typeof r[o]!="object")&&(r[o]=typeof e[i+1]=="number"?[]:{}),r=r[o]}const s=e[e.length-1];Array.isArray(r)&&typeof s=="number"?r.splice(s,0,n):r[s]=n}function An(t,e,n){if(!t||e.length===0)return;let r=t||{};for(let s=0;s<e.length-1;s++){const i=e[s];(!(i in r)||typeof r[i]!="object")&&(r[i]=typeof e[s+1]=="number"?[]:{}),r=r[i]}r[e[e.length-1]]=n}function En(t,e){if(!t||e.length===0)return;const[n,...r]=e;if(n in t){if(r.length===0){Array.isArray(t)?t.splice(n,1):delete t[n];return}En(t[n],r),ys(t[n])&&delete t[n]}}function ys(t){return t&&Object.keys(t).length===0}const On=/ZULU|YEKT|YEKST|YAPT|YAKT|YAKST|XJT|WGT|WGST|WFT|WETDST|WET|WDT|WAT|WAST|WAKT|WADT|VUT|VOLT|VLAT|VLAST|VET|UZT|UZST|UYT|UYST|UTC|UT|ULAT|ULAST|UCT|TVT|TRUT|TOT|TMT|TKT|TJT|TFT|TAHT|SGT|SCT|SAST|SADT|RET|PYT|PYST|PWT|PST|PONT|PMST|PMDT|PKT|PKST|PHT|PGT|PETT|PETST|PET|PDT|OMST|OMSST|NZT|NZST|NZDT|NUT|NST|NPT|NOVT|NOVST|NFT|NDT|MYT|MVT|MUT|MUST|MST|MSK|MSD|MPT|MMT|MHT|MEZ|METDST|MET|MESZ|MEST|MDT|MAWT|MART|MAGT|MAGST|LKT|LINT|LIGT|LHST|LHDT|KST|KRAT|KRAST|KOST|KGT|KGST|KDT|JST|JAYT|IST|IRT|IRKT|IRKST|IOT|IDT|ICT|HST|HKT|GYT|GMT|GILT|GFT|GET|GEST|GAMT|GALT|FNT|FNST|FKT|FKST|FJT|FJST|FET|EST|EGT|EGST|EETDST|EET|EEST|EDT|EAT|EAST|EASST|DDUT|DAVT|CXT|CST|COT|CLT|CLST|CKT|CHUT|CHAST|CHADT|CETDST|CET|CEST|CDT|CCT|CAST|CADT|BTT|BST|BRT|BRST|BRA|BOT|BORT|BNT|BDT|BDST|AZT|AZST|AZOT|AZOST|AWST|AWSST|AST|ART|ARST|ANAT|ANAST|AMT|AMST|ALMT|ALMST|AKST|AKDT|AFT|AEST|AESST|AEDT|ADT|ACWST|ACT|ACST|ACSST|ACDT$/,bs={ZULU:0,YEKT:18e3,YEKST:21600,YAPT:36e3,YAKT:32400,YAKST:32400,XJT:21600,WGT:-10800,WGST:-7200,WFT:43200,WETDST:3600,WET:0,WDT:32400,WAT:3600,WAST:25200,WAKT:43200,WADT:28800,VUT:39600,VOLT:10800,VLAT:36e3,VLAST:36e3,VET:-14400,UZT:18e3,UZST:21600,UYT:-10800,UYST:-7200,UTC:0,UT:0,ULAT:28800,ULAST:32400,UCT:0,TVT:43200,TRUT:36e3,TOT:46800,TMT:18e3,TKT:46800,TJT:18e3,TFT:18e3,TAHT:-36e3,SGT:28800,SCT:14400,SAST:7200,SADT:37800,RET:14400,PYT:-14400,PYST:-10800,PWT:32400,PST:-28800,PONT:39600,PMST:-10800,PMDT:-7200,PKT:18e3,PKST:21600,PHT:28800,PGT:36e3,PETT:43200,PETST:43200,PET:-18e3,PDT:-25200,OMST:21600,OMSST:21600,NZT:43200,NZST:43200,NZDT:46800,NUT:-39600,NST:-12600,NPT:20700,NOVT:25200,NOVST:25200,NFT:-12600,NDT:-9e3,MYT:28800,MVT:18e3,MUT:14400,MUST:18e3,MST:-25200,MSK:10800,MSD:14400,MPT:36e3,MMT:23400,MHT:43200,MEZ:3600,METDST:7200,MET:3600,MESZ:7200,MEST:7200,MDT:-21600,MAWT:18e3,MART:-34200,MAGT:39600,MAGST:39600,LKT:19800,LINT:50400,LIGT:36e3,LHST:37800,LHDT:37800,KST:32400,KRAT:25200,KRAST:25200,KOST:39600,KGT:21600,KGST:21600,KDT:36e3,JST:32400,JAYT:32400,IST:7200,IRT:12600,IRKT:28800,IRKST:28800,IOT:21600,IDT:10800,ICT:25200,HST:-36e3,HKT:28800,GYT:-14400,GMT:0,GILT:43200,GFT:-10800,GET:14400,GEST:14400,GAMT:-32400,GALT:-21600,FNT:-7200,FNST:-3600,FKT:-10800,FKST:-10800,FJT:43200,FJST:46800,FET:10800,EST:-18e3,EGT:-3600,EGST:0,EETDST:10800,EET:7200,EEST:10800,EDT:-14400,EAT:10800,EAST:-21600,EASST:-21600,DDUT:36e3,DAVT:25200,CXT:25200,CST:-21600,COT:-18e3,CLT:-14400,CLST:-10800,CKT:-36e3,CHUT:36e3,CHAST:45900,CHADT:49500,CETDST:7200,CET:3600,CEST:7200,CDT:-18e3,CCT:28800,CAST:34200,CADT:37800,BTT:21600,BST:3600,BRT:-10800,BRST:-7200,BRA:-10800,BOT:-14400,BORT:28800,BNT:28800,BDT:21600,BDST:7200,AZT:14400,AZST:14400,AZOT:-3600,AZOST:0,AWST:28800,AWSST:32400,AST:-14400,ART:-10800,ARST:-10800,ANAT:43200,ANAST:43200,AMT:-14400,AMST:14400,ALMT:21600,ALMST:25200,AKST:-32400,AKDT:-28800,AFT:16200,AEST:36e3,AESST:39600,AEDT:39600,ADT:-10800,ACWST:31500,ACT:-18e3,ACST:34200,ACSST:37800,ACDT:37800};function _s(t){return new Date(t)}function gs(t){return new Date(t+"Z")}const Ts=/^(\d+)[\./-](\d+)[\./-](\d+)$/;function ws(t){const e=t.match(Ts);if(!e)return null;const[n,r,s,i]=e;return r<=0||s<=0||i<=0?null:r>999?new Date(Date.UTC(r,s-1,i,0,0,0,0)):new Date(Date.UTC(i,r-1,s,0,0,0,0))}function ms(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function Ss(t){const[e,n]=t.split(" ");return new Date(e+"T"+n+"Z")}function vs(t){return new Date(t)}function As(t){const e=/^(\w{3}) (\w{3}) (\d{2}) (\d{4})$/;if(!t.match(e))throw new Error(`Unable to parse \`${t}\` as a date.`);const r=new Date(t+" UTC");return new Date(Date.UTC(r.getUTCFullYear(),r.getUTCMonth(),r.getUTCDate(),0,0,0,0))}function Es(t){const e=/^(.+T.+)([+-])(\d{2})$/,n=t.match(e);if(n){const[,r,s,i]=n,o=`${r}${s}${i}:00`;return new Date(o)}return null}function Os(t){const e=/^(\d+)-(\d{1,2})-(\d{1,2})([ T])(.+)$/,n=t.match(e);if(n){const[,r,s,i,o,a]=n,c=s.padStart(2,"0"),u=i.padStart(2,"0"),l=`${r}-${c}-${u}T${a}`;return new Date(l)}return null}function ks(t){const[e,n]=t.split(", "),[r,s,i]=e.split("/").map(Number),o=n.match(/(\d{1,2}):(\d{2}):(\d{2}) (AM|PM)/);if(!o)throw new Error(`Unable to parse time from: ${t}`);let[,a,c,u,l]=o;return a=Number(a),c=Number(c),u=Number(u),l==="PM"&&a!==12?a+=12:l==="AM"&&a===12&&(a=0),new Date(Date.UTC(i,r-1,s,a,c,u))}function Ps(t){switch(t){case"epoch":return new Date(0);case"infinity":case"-infinity":case"today":case"tomorrow":case"yesterday":return null}}function Cs(t){const e=t.match(On);if(!e)return null;const[n]=e,r=bs[n],s=new Date(t.replace(On,"Z"));return new Date(s.getTime()-r*1e3)}const Is=[ws,Ss,As,ks,vs,gs,Es,ms,_s,Ps,Cs,Os];function Ms(t,e){try{const n=t(e);return n instanceof Date&&!isNaN(n.getTime())?n:null}catch{return null}}function Pt(t){for(const e of Is){const n=Ms(e,t);if(n)return n}return null}function js(t){try{const e=JSON.parse(t);return typeof e=="string"?Pt(e):null}catch{return null}}function Ze(t){if(t!==void 0){if(t===null)return null;if(t instanceof Date)return t;if(typeof t=="string"){const e=Pt(t)||js(t)||Pt(t.trim());if(!e)throw new Error(`Unable to parse \`${t}\` as a date.`);return e}else if(typeof t=="number")return new Date(t);throw new Error(`Invalid date value \`${t}\`. Expected a date, number, or string, got type ${typeof t}.`)}}class be{constructor(e,n){p(this,"attrs");p(this,"linkIndex");p(this,"_blobAttrs",null);p(this,"_primaryKeys",null);p(this,"_forwardIdents",null);p(this,"_revIdents",null);this.attrs=e,this.linkIndex=n}resetAttrIndexes(){this._blobAttrs=null,this._primaryKeys=null,this._forwardIdents=null,this._revIdents=null}addAttr(e){this.attrs[e.id]=e,this.resetAttrIndexes()}deleteAttr(e){delete this.attrs[e],this.resetAttrIndexes()}updateAttr(e){const n=this.attrs[e.id];n&&(this.attrs[e.id]={...n,...e},this.resetAttrIndexes())}getAttr(e){return this.attrs[e]}get blobAttrs(){if(this._blobAttrs)return this._blobAttrs;this._blobAttrs=new Map;for(const e of Object.values(this.attrs))if(It(e)){const[n,r,s]=e["forward-identity"];Q(this.blobAttrs,[r,s],e)}return this._blobAttrs}get primaryKeys(){if(this._primaryKeys)return this._primaryKeys;this._primaryKeys=new Map;for(const e of Object.values(this.attrs))if(e["primary?"]){const[n,r]=e["forward-identity"];Q(this._primaryKeys,[r],e)}return this._primaryKeys}get forwardIdents(){if(this._forwardIdents)return this._forwardIdents;this._forwardIdents=new Map;for(const e of Object.values(this.attrs)){const n=e["forward-identity"],[r,s,i]=n;Q(this._forwardIdents,[s,i],e)}return this._forwardIdents}get revIdents(){if(this._revIdents)return this._revIdents;this._revIdents=new Map;for(const e of Object.values(this.attrs)){const n=e["reverse-identity"];if(n){const[r,s,i]=n;Q(this._revIdents,[s,i],e)}}return this._revIdents}toJSON(){return{attrs:this.attrs,linkIndex:this.linkIndex}}}function Rs(t){return t.cardinality==="one"}function Ct(t){return t["value-type"]==="ref"}function It(t){return t["value-type"]==="blob"}function Se(t,e){return e.reduce((n,r)=>n&&n.get(r),t)}function ne(t,e){if(e.length===0)throw new Error("path must have at least one element");if(e.length===1){t.delete(e[0]);return}const[n,...r]=e;t.has(n)&&ne(t.get(n),r)}function Q(t,e,n){let r=t;const s=e.length-1;for(let i=0;i<s;i++){const o=e[i];let a=r.get(o);a===void 0&&(a=new Map,r.set(o,a)),r=a}s>-1&&r.set(e[s],n)}function kn(t,e,n){const r=new Map,s=new Map,i=new Map;for(const o of e){let[a,c,u]=o;const l=t.getAttr(c);if(!l){console.warn("no such attr",c,a);continue}l["checked-data-type"]==="date"&&n&&(u=Ze(u),o[2]=u),Ct(l)&&Q(i,[u,c,a],o),Q(r,[a,c,u],o),Q(s,[c,a,u],o)}return{eav:r,aev:s,vae:i}}function Pn(t){return{triples:B(t.eav,3),cardinalityInference:t.cardinalityInference,useDateObjects:t.useDateObjects,version:1}}function Cn(t,e){return $e(t,e.triples,e.cardinalityInference,e.useDateObjects)}function In(t,e){if(t)return new be(t.attrs,t.linkIndex);if(e&&"__type"in e)return new be(e.attrs,e.linkIndex)}function Ds(t,e){return Se(t.eav,[e])!==void 0}function $e(t,e,n,r){const s=kn(t,e,r);return s.cardinalityInference=n,s.useDateObjects=r,s}function Ue(t,e){var s,i;let n;if(Array.isArray(e[0])){const[o,a]=e[0],c=t.aev.get(o);if(!c)return null;n=(s=B(c,2).find(l=>l[2]===a))==null?void 0:s[0]}else n=e[0];if(!n)return null;const r=e[2];if(Array.isArray(r)&&r.length===2&&t.aev.get(r[0])){const[o,a]=r,c=t.aev.get(o);if(!c)return null;const l=(i=B(c,2).find(g=>g[2]===a))==null?void 0:i[0];if(!l)return null;const[d,h,y,...b]=e;return[n,h,l,...b]}else{const[o,...a]=e;return[n,...a]}}function Mn(t,e,n){const r=Ue(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);a&&(ne(t.eav,[s,i,o]),ne(t.aev,[i,s,o]),Ct(a)&&ne(t.vae,[o,i,s]))}let xs=0;function jn(t,e,n){const[r,s,i]=n;let o;const a=Se(t.eav,[r,s,i]);return a&&(o=a[3]),o||Date.now()*10+xs++}function Rn(t,e,n){const r=Ue(t,n);if(!r)return;let[s,i,o]=r;const a=e.getAttr(i);if(!a)return;a["checked-data-type"]==="date"&&t.useDateObjects&&(o=Ze(o));const c=Se(t.eav,[s,i,o]),u=(c==null?void 0:c[3])??jn(t,a,r),l=[s,i,o,u];Rs(a)?(Q(t.eav,[s,i],new Map([[o,l]])),Q(t.aev,[i,s],new Map([[o,l]]))):(Q(t.eav,[s,i,o],l),Q(t.aev,[i,s,o],l)),Ct(a)&&Q(t.vae,[o,i,s],l)}function $s(t,e,n){var y;const r=Ue(t,n);if(!r)return;const[s,i,o]=r,a=e.getAttr(i);if(!a)return;if(!It(a))throw new Error("merge operation is not supported for links");const c=Se(t.eav,[s,i]);if(!c)return;const u=(y=c.values().next())==null?void 0:y.value;if(!u)return;const l=u[2],d=vn(l,o),h=[s,i,d,jn(t,a,u)];Q(t.eav,[s,i],new Map([[d,h]])),Q(t.aev,[i,s],new Map([[d,h]]))}function Mt(t,e,n){var u,l;const[r,s]=n,i=Ue(t,[r]);if(!i)return;const[o]=i,a=t.eav.get(o);if(a){for(const d of a.keys()){const h=e.getAttr(d);h&&h["on-delete-reverse"]==="cascade"&&B(a.get(d),1).forEach(([y,b,g])=>{var w;return Mt(t,e,[g,(w=h["reverse-identity"])==null?void 0:w[1]])}),(!s||!h||((u=h["forward-identity"])==null?void 0:u[1])===s)&&(ne(t.aev,[d,o]),ne(t.eav,[o,d]))}a.size===0&&ne(t.eav,[o])}const c=t.vae.get(o)&&B(t.vae.get(o),2);c&&c.forEach(d=>{var w,m,T;const[h,y,b]=d,g=e.getAttr(y);(!s||!g||((w=g["reverse-identity"])==null?void 0:w[1])===s)&&(ne(t.eav,[h,y,b]),ne(t.aev,[y,h,b]),ne(t.vae,[b,y,h])),g&&g["on-delete"]==="cascade"&&((m=g["reverse-identity"])==null?void 0:m[1])===s&&Mt(t,e,[h,(T=g["forward-identity"])==null?void 0:T[1]])}),((l=t.vae.get(o))==null?void 0:l.size)===0&&ne(t.vae,[o])}function Dn(t,e,n){const r=kn(e,n,t.useDateObjects);Object.keys(r).forEach(s=>{t[s]=r[s]})}function Us(t,[e]){t.addAttr(e)}function xn(t){return B(t.eav,3)}function Ls(t,e,[n]){if(!e.getAttr(n))return;const r=xn(t).filter(([s,i])=>i!==n);e.deleteAttr(n),Dn(t,e,r)}function Fs(t,e,[n]){e.getAttr(n.id)&&(e.updateAttr(n),Dn(t,e,xn(t)))}function Ns(t,e,n){const[r,...s]=n;switch(r){case"add-triple":Rn(t,e,s);break;case"deep-merge-triple":$s(t,e,s);break;case"retract-triple":Mn(t,e,s);break;case"delete-entity":Mt(t,e,s);break;case"add-attr":Us(e,s);break;case"delete-attr":Ls(t,e,s);break;case"update-attr":Fs(t,e,s);break;case"restore-attr":break;case"rule-params":break;default:throw new Error(`unhandled transaction action: ${r}`)}}function B(t,e,n=[]){if(!t||e===0)return n;if(e===1){for(const r of t.values())n.push(r);return n}for(const r of t.values())B(r,e-1,n);return n}function Xe(t,e,n){var i;const r=[];if(n!=null&&n.hasOwnProperty("$not")){for(const o of e.keys())n.$not!==o&&r.push(e.get(o));return r}if(n!=null&&n.hasOwnProperty("$isNull")){const{attrId:o,isNull:a,reverse:c}=n.$isNull;if(c)for(const u of e.keys()){const l=t.vae.get(u),d=!l||!l.get(o);(a?d:!d)&&r.push(e.get(u))}else{const u=t.aev.get(o);for(const l of e.keys()){const d=!u||((i=u.get(l))==null?void 0:i.get(null))||!u.get(l);(a?d:!d)&&r.push(e.get(l))}}return r}if(n!=null&&n.$comparator)return B(e,1).filter(n.$op);const s=n.in||n.$in||[n];for(const o of s){const a=e.get(o);a&&r.push(a)}return r}function Ks(t,e,n){let r="";return t!==void 0&&(r+="e"),e!==void 0&&(r+="a"),n!==void 0&&(r+="v"),r}function zs(t,[e,n,r]){var i,o;switch(Ks(e,n,r)){case"e":{const a=t.eav.get(e);return B(a,2)}case"ea":{const a=(i=t.eav.get(e))==null?void 0:i.get(n);return B(a,1)}case"eav":{const a=(o=t.eav.get(e))==null?void 0:o.get(n);return a?Xe(t,a,r):[]}case"ev":{const a=t.eav.get(e);if(!a)return[];const c=[];for(const u of a.values())c.push(...Xe(t,u,r));return c}case"a":{const a=t.aev.get(n);return B(a,2)}case"av":{const a=t.aev.get(n);if(!a)return[];const c=[];for(const u of a.values())c.push(...Xe(t,u,r));return c}case"v":{const a=[];for(const c of t.eav.values())for(const u of c.values())a.push(...Xe(t,u,r));return a}default:return B(t.eav,3)}}function qs(t,e,n){var s;const r={};if(!e)return r;for(const[i,o]of e.entries()){const a=(s=t.eav.get(n))==null?void 0:s.get(o.id),c=B(a,1);for(const u of c)r[i]=u[2]}return r}function U(t,e,n){var r;return(r=t.forwardIdents.get(e))==null?void 0:r.get(n)}function _e(t,e,n){var r;return(r=t.revIdents.get(e))==null?void 0:r.get(n)}function Vs(t,e){return t.blobAttrs.get(e)}function $n(t,e){var r;const n=t.primaryKeys.get(e);return n||((r=t.forwardIdents.get(e))==null?void 0:r.get("id"))}function Ws(t,e,n){const r=Ue(t,n);if(!r)return;const[s,i,o]=r;if(e.getAttr(i))return Se(t.eav,[s,i])}function Qs(t,e,n){const r=n.filter(([s,i,o,a,c])=>{if(s!=="add-triple"&&s!=="deep-merge-triple")return!0;const u=c==null?void 0:c.mode;if(u!=="create"&&u!=="update")return!0;let l=!1;const d=e.getAttr(o);if(d){const h=$n(e,d["forward-identity"][1]);l=!!Ws(t,e,[i,h==null?void 0:h.id,i])}return!(u==="create"&&l||u==="update"&&!l)});return Je({store:t,attrsStore:e},s=>{r.forEach(i=>{Ns(s.store,s.attrsStore,i)})},{mark:s=>{if(s instanceof be)return"immutable"}})}function Bs(t){return typeof t=="string"&&t.startsWith("?")}function Gs(t,e,n){if(n.hasOwnProperty(t)){const r=n[t];return Ln(r,e,n)}return{...n,[t]:e}}function Un(t,e,n){return t===e?n:null}function Hs(t){switch(typeof t){case"string":return t.startsWith("?")?Gs:Un;default:return Un}}const Js=["in","$in","$not","$isNull","$comparator"];function Ys(t){for(const e of Js)if(t.hasOwnProperty(e))return!0;return!1}function Ln(t,e,n){return n?typeof t=="object"?Ys(t)?n:null:Hs(t)(t,e,n):null}function Zs(t,e,n){return t.reduce((r,s,i)=>{const o=e[i];return Ln(s,o,r)},n)}function Xs(t,e,n){return ni(t,e,n).map(r=>Zs(e,r,n)).filter(r=>r)}function ei(t,e,n){return e.or?e.or.patterns.flatMap(r=>jt(t,r,n)):e.and?e.and.patterns.reduce((r,s)=>jt(t,s,r),n):n.flatMap(r=>Xs(t,e,r))}function jt(t,e,n=[{}]){return e.reduce((r,s)=>ei(t,s,r),n)}function Rt(t,e){return Array.isArray(e)?e.map(n=>Rt(t,n)):Bs(e)?t[e]:e}function ti(t,{find:e,where:n}){return jt(t,n).map(s=>Rt(s,e))}function ni(t,e,n){return zs(t,Rt(n,e))}const ri=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function ve(t){return typeof t=="string"&&ri.test(t)}const z=[];for(let t=0;t<256;++t)z.push((t+256).toString(16).slice(1));function si(t,e=0){return(z[t[e+0]]+z[t[e+1]]+z[t[e+2]]+z[t[e+3]]+"-"+z[t[e+4]]+z[t[e+5]]+"-"+z[t[e+6]]+z[t[e+7]]+"-"+z[t[e+8]]+z[t[e+9]]+"-"+z[t[e+10]]+z[t[e+11]]+z[t[e+12]]+z[t[e+13]]+z[t[e+14]]+z[t[e+15]]).toLowerCase()}let Dt;const ii=new Uint8Array(16);function oi(){if(!Dt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");Dt=crypto.getRandomValues.bind(crypto)}return Dt(ii)}const Fn={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function ai(t,e,n){var s;if(Fn.randomUUID&&!t)return Fn.randomUUID();t=t||{};const r=t.random??((s=t.rng)==null?void 0:s.call(t))??oi();if(r.length<16)throw new Error("Random bytes length must be >= 16");return r[6]=r[6]&15|64,r[8]=r[8]&63|128,si(r)}function Nn(t){const e=t.replace(/-/g,""),n=[];for(let r=0;r<e.length;r+=2)n.push(parseInt(e.substring(r,r+2),16));return n}function ci(t,e){for(let n=0;n<t.length;n++){if(t[n]<e[n])return-1;if(t[n]>e[n])return 1}return 0}function ui(t,e){return ci(Nn(t),Nn(e))}function N(){return ai()}function li(t,e){return t.localeCompare(e)}function fi(){let t=li;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{t=Intl.Collator("en-US").compare}catch{}return t}const di=fi();let hi=0;function Le(t){return et(`_${t}`,hi++)}function et(t,e){return`?${t}-${e}`}class Ae extends Error{constructor(e){super(e),this.name="AttrNotFoundError"}}function pi(t,e){const n=$n(t,e);if(!n)throw new Ae(`Could not find id attr for ${e}`);return n}function Kn(t,e,n,r){return[yi(t,e,n,r)]}function yi(t,e,n,r){return[t(n,r),pi(e,n).id,t(n,r),t("time",r)]}function bi(t,e,n){return t.map(r=>r===e?n:r)}function zn(t,e,n,r,s){const i=U(e,n,s),o=_e(e,n,s),a=i||o;if(!a)throw new Ae(`Could not find attr for ${[n,s]}`);if(a["value-type"]!=="ref")throw new Error(`Attr ${a.id} is not a ref`);const[c,u]=a["forward-identity"],[l,d]=a["reverse-identity"],h=r+1,y=i?[t(u,r),a.id,t(d,h),Le("time")]:[t(u,h),a.id,t(d,r),Le("time")];return[i?d:u,h,y,a,!!i]}function qn(t,e){if(typeof e!="string")return function(o){return!1};const r=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/%/g,".*").replace(/_/g,"."),s=new RegExp(`^${r}$`,t?void 0:"i");return function(o){return typeof o!="string"?!1:s.test(o)}}function _i(t,e){if(typeof e!="object"||e.hasOwnProperty("$in")||e.hasOwnProperty("in"))return e;const n=t["checked-data-type"]==="date";if(e.hasOwnProperty("$gt"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])>new Date(e.$gt)}:function(s){return s[2]>e.$gt}};if(e.hasOwnProperty("$gte"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])>=new Date(e.$gte)}:function(s){return s[2]>=e.$gte}};if(e.hasOwnProperty("$lt"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])<new Date(e.$lt)}:function(s){return s[2]<e.$lt}};if(e.hasOwnProperty("$lte"))return{$comparator:!0,$op:n?function(s){return new Date(s[2])<=new Date(e.$lte)}:function(s){return s[2]<=e.$lte}};if(e.hasOwnProperty("$like")){const r=qn(!0,e.$like);return{$comparator:!0,$op:function(i){return r(i[2])}}}if(e.hasOwnProperty("$ilike")){const r=qn(!1,e.$ilike);return{$comparator:!0,$op:function(i){return r(i[2])}}}return e}function gi(t,e,n,r,s,i){const o=U(e,n,s),a=_e(e,n,s),c=o||a;if(!c)throw new Ae(`No attr for etype = ${n} label = ${s}`);if(i!=null&&i.hasOwnProperty("$isNull")){const u=U(e,n,"id");if(!u)throw new Ae(`No attr for etype = ${n} label = id`);return[t(n,r),u.id,{$isNull:{attrId:c.id,isNull:i.$isNull,reverse:!o}},Le("time")]}return o?[t(n,r),c.id,_i(c,i),Le("time")]:[i,c.id,t(n,r),Le("time")]}function Ti(t,e,n,r,s){const[i,o,a]=s.reduce((c,u)=>{const[l,d,h]=c,[y,b,g]=zn(t,e,l,d,u);return[y,b,[...h,g]]},[n,r,[]]);return[i,o,a]}function xt(t,e,n,r,s,i){const o=s.slice(0,s.length-1),a=s[s.length-1],[c,u,l]=Ti(t,e,n,r,o),d=gi(t,e,c,u,a,i);return l.concat([d])}function wi(t,e){return e?[e].concat(t):t}function mi([t,e]){return t==="or"&&Array.isArray(e)}function Si([t,e]){return t==="and"&&Array.isArray(e)}function vi(t,e,n){return(r,s)=>{const i=t(r,s);return e==i?i:`${i}-${n}`}}function Vn(t,e,n,r,s,i){const o=t(r,s),a=i.map((c,u)=>{const l=vi(t,o,u);return Qn(l,n,r,s,c)});return{[e]:{patterns:a,joinSym:o}}}function Ai(t){const e=[];for(let n=1;n<=t.length;n++)e.push(t.slice(0,n));return e}function Wn(t,e,n,r,s){return Ai(s).map(i=>xt(t,e,n,r,i,{$isNull:!0}))}function Qn(t,e,n,r,s){return Object.entries(s).flatMap(([i,o])=>{if(mi([i,o]))return Vn(t,"or",e,n,r,o);if(Si([i,o]))return Vn(t,"and",e,n,r,o);if(i==="$entityIdStartsWith")return[];const a=i.split(".");if(o!=null&&o.hasOwnProperty("$ne")&&(o={...o,$not:o.$ne},delete o.$ne),o!=null&&o.hasOwnProperty("$not")){const c=xt(t,e,n,r,a,o),u=Wn(t,e,n,r,a);return[{or:{patterns:[c,...u],joinSym:t(n,r)}}]}return o!=null&&o.hasOwnProperty("$isNull")&&o.$isNull===!0&&a.length>1?[{or:{patterns:Wn(t,e,n,r,a),joinSym:t(n,r)}}]:xt(t,e,n,r,a,o)})}function Ei(t,e,n,r){const s=et;return r?Qn(s,t,e,n,r).concat(Kn(s,t,e,n)):Kn(s,t,e,n)}function Oi(t,e,n){return[t(e,n),t("time",n)]}function ki(t,e,n,r,s,i){const[o,a,c,u,l]=zn(t,e,n,r,s),d=bi(c,t(n,r),i);return[o,a,d,u,l]}function Pi(t,e,n,{etype:r,level:s,form:i},o){const a=Object.keys(i).filter(c=>c!=="$");return a.length?Object.entries(o).map(function([u,l]){return a.map(function(y){var g,w,m;const b=!!(e.cardinalityInference&&((m=(w=(g=n.linkIndex)==null?void 0:g[r])==null?void 0:w[y])!=null&&m.isSingular));try{const[T,v,k]=ki(t,n,r,s,y,u),A=Gn(e,n,{etype:T,level:v,form:i[y],join:k}),R=b?A[0]:A;return{[y]:R}}catch(T){if(T instanceof Ae)return{[y]:b?void 0:[]};throw T}}).reduce(function(y,b){return{...y,...b}},l)}):Object.values(o)}function Ci(t,e,n){return n==="string"?di(t,e):t>e?1:-1}function Fe(t,e,n,r,s){return e===r||e==null&&r==null?ui(t,n):r==null?1:e==null?-1:Ci(e,r,s)}function tt([t,e],[n,r],s){return Fe(t,e,n,r,s)}function $t(t){return t==null?t:new Date(t).getTime()}function Ii(t,e,n,r){var b;const[s,i,o,a]=t,c=n==="desc"?1:-1;if(((b=e["forward-identity"])==null?void 0:b[2])==="id")return tt(r,[s,a],null)===c;const[u,l]=r,d=e["checked-data-type"],h=d==="date"?$t(l):l,y=d==="date"?$t(o):o;return tt([u,h],[s,y],d)===c}function Mi(t,e){const n=e[1];return t.getAttr(n)}function ji(t,e,n){const r=Object.keys(n)[0];return U(t,e,r)}function Ri(t,e,n,r){if(n)return Mi(t,n);if(r)return ji(t,e,r)}function Di(t,e,n){var s,i;if(!Array.isArray(n.fields))return Vs(t,e);const r=new Map;for(const o of n.fields){const a=U(t,e,o),c=(s=a==null?void 0:a["forward-identity"])==null?void 0:s[2];c&&It(a)&&r.set(c,a)}if(!r.has("id")){const o=U(t,e,"id"),a=(i=o==null?void 0:o["forward-identity"])==null?void 0:i[2];a&&r.set(a,o)}return r}function xi(t,e,{etype:n,pageInfo:r,dq:s,form:i}){var b,g;const o=(b=i==null?void 0:i.$)==null?void 0:b.order,a=Bn(i),c=$i(i);let u=ti(t,s);const l=r==null?void 0:r["start-cursor"],d=Ri(e,n,l,o);if(d&&((g=d==null?void 0:d["forward-identity"])==null?void 0:g[2])!=="id"){const w=d["checked-data-type"]==="date",m=d.id;u=u.map(([T])=>{var k,A,R,K,V;let v=(V=(K=(R=(A=(k=t.eav.get(T))==null?void 0:k.get(m))==null?void 0:A.values())==null?void 0:R.next())==null?void 0:K.value)==null?void 0:V[2];return w&&(v=$t(v)),[T,v]})}u.sort(c==="asc"?function(m,T){return tt(m,T,d==null?void 0:d["checked-data-type"])}:function(m,T){return tt(T,m,d==null?void 0:d["checked-data-type"])});let h={};const y=Di(e,n,s);for(const w of u){const[m]=w;if(h[m]||!a&&l&&d&&Ii(l,d,c,w))continue;const T=qs(t,y,m);T&&(h[m]=T)}return h}function $i(t){var n;const e=(n=t.$)==null?void 0:n.order;return e&&e[Object.keys(e)[0]]||"asc"}function Bn(t){var s,i,o;const e=(s=t.$)==null?void 0:s.offset,n=(i=t.$)==null?void 0:i.before,r=(o=t.$)==null?void 0:o.after;return!e&&!n&&!r}function Ui(t,e,{etype:n,level:r,form:s,join:i,pageInfo:o}){var h,y,b,g,w;if(!Bn(s)&&(!o||!o["start-cursor"]))return[];const a=wi(Ei(e,n,r,(h=s.$)==null?void 0:h.where),i),c=Oi(et,n,r),u=(y=s.$)==null?void 0:y.fields,l=xi(t,e,{etype:n,pageInfo:o,form:s,dq:{where:a,find:c,fields:u}}),d=((b=s.$)==null?void 0:b.limit)||((g=s.$)==null?void 0:g.first)||((w=s.$)==null?void 0:w.last);if(d!=null){r>0&&console.warn("WARNING: Limits in child queries are only run client-side. Data returned from the server will not have a limit.");const m=Object.entries(l);return m.length<=d?l:Object.fromEntries(m.slice(0,d))}return l}function Li(t,e,n){try{return Ui(t,e,n)}catch(r){if(r instanceof Ae)return{};throw r}}function Gn(t,e,n){const r=Li(t,e,n);return Pi(et,t,e,n,r)}function Fi(t){const e={};for(const[n,r]of Object.entries(t))e[n]={startCursor:r["start-cursor"],endCursor:r["end-cursor"],hasNextPage:r["has-next-page?"],hasPreviousPage:r["has-previous-page?"]};return e}function Hn({store:t,attrsStore:e,pageInfo:n,aggregate:r},s){const o={data:Object.keys(s).reduce(function(c,u){return r!=null&&r[u]||u==="$$ruleParams"||(c[u]=Gn(t,e,{etype:u,form:s[u],level:0,pageInfo:n==null?void 0:n[u]})),c},{})};return n&&(o.pageInfo=Fi(n)),r&&(o.aggregate=r),o}function Ni(){const e={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(e))}const Ki=Ni();function nt(t,e,n){const r={__etype:t,__ops:n};return new Proxy(r,{get:(s,i)=>{if(i==="__ops")return n;if(i==="__etype")return t;if(Ki.has(i))return(o,a)=>nt(t,e,[...n,a?[i,t,e,o,a]:[i,t,e,o]])}})}function zi(t,e){return`lookup__${t}__${JSON.stringify(e)}`}function rt(t){return t.startsWith("lookup__")}function Ut(t){const[e,n,...r]=t.split("__");return[n,JSON.parse(r.join("__"))]}function qi(t){return new Proxy({__etype:t},{get(e,n){if(n==="lookup")return(s,i)=>nt(t,Ut(zi(s,i)),[]);if(n==="__etype")return t;const r=n;return rt(r)?nt(t,Ut(r),[]):nt(t,r,[])}})}function Lt(){return new Proxy({},{get(t,e){return qi(e)}})}Lt();function Vi(t){return t.__ops}function Wi(t,e){const{attrIdMap:n,refSwapAttrIds:r}=t,s=[];for(const o of e){const a=n[o];if(a)s.push(a);else if(Array.isArray(o)&&o.length==2&&n[o[0]]){const[c,u]=o;s.push([n[c],u])}else s.push(o)}const[i]=e;if((i==="add-triple"||i==="retract-triple")&&r.has(e[2])){const o=s[1];s[1]=s[3],s[3]=o}return s}function Qi(t){if(Array.isArray(t))return t;const e=Object.entries(t);if(e.length!==1)throw new Error("lookup must be an object with a single unique attr and value.");return e[0]}function Bi(t,e,n){return n.indexOf(".")!==-1&&!U(t,e,n)}function Ft(t){const[e,n,...r]=t.split(".");if(r.length>0||n!=="id")throw new Error(`${t} is not a valid lookup attribute.`);return e}function Gi(t,e,n){if(!Bi(t,e,n))return U(t,e,n);const r=Ft(n),s=U(t,e,r)||_e(t,e,r);if(s&&s["value-type"]!=="ref")throw new Error(`${n} does not reference a valid link attribute.`);return s}function Nt(t){return typeof t=="string"&&!rt(t)?null:typeof t=="string"&&rt(t)?Ut(t):Qi(t)}function G(t,e,n){const r=Nt(n);if(r===null)return n;const[s,i]=r,o=Gi(t,e,s);if(!o||!o["unique?"])throw new Error(`${s} is not a unique attribute.`);return[o.id,i]}function Jn(t,e,n,r){var o;const s=G(t,e,n);return Array.isArray(s)?[["add-triple",s,(o=U(t,e,"id"))==null?void 0:o.id,s]].concat(r):r}function Hi({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=U(t,e,i),u=_e(t,e,i);return a.map(l=>c?["add-triple",G(t,e,n),c.id,G(t,c["reverse-identity"][1],l)]:["add-triple",G(t,u["forward-identity"][1],l),u==null?void 0:u.id,G(t,e,n)])});return Jn(t,e,n,s)}function Ji({attrsStore:t},[e,n,r]){const s=Object.entries(r).flatMap(([i,o])=>{const a=Array.isArray(o)?o:[o],c=U(t,e,i),u=_e(t,e,i);return a.map(l=>c?["retract-triple",G(t,e,n),c.id,G(t,c["reverse-identity"][1],l)]:["retract-triple",G(t,u["forward-identity"][1],l),u.id,G(t,e,n)])});return Jn(t,e,n,s)}function Yi(t,e,n,r){var s;if(Array.isArray(r)){const[i,o]=r;for(const a of t||[]){const c=a==null?void 0:a.aev.get(i);if(c){for(const[u,l,d]of B(c,2))if(d===o)return!0}}}else for(const i of t||[]){const o=i==null?void 0:i.eav.get(r);if(o){for(const a of o.keys())if(((s=e.getAttr(a))==null?void 0:s["forward-identity"][1])==n)return!0}}return!1}function Yn({stores:t,attrsStore:e},[n,r,s,i]){return(i==null?void 0:i.upsert)===!1?{mode:"update"}:(i==null?void 0:i.upsert)===!0?null:Yi(t,e,n,r)?{mode:"update"}:null}function Zi(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s);return[["id",c]].concat(Object.entries(a)).map(([l,d])=>{const h=U(n,r,l);return h["checked-data-type"]==="date"&&t.useDateObjects&&(d=Ze(d)),["add-triple",c,h.id,d,{mode:"create"}]})}function Xi(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s),u=Yn(t,[r,c,i,o]);return[["id",c]].concat(Object.entries(a)).map(([d,h])=>{const y=U(n,r,d);return y["checked-data-type"]==="date"&&t.useDateObjects&&(h=Ze(h)),["add-triple",c,y.id,h,...u?[u]:[]]})}function eo({attrsStore:t},[e,n]){return[["delete-entity",G(t,e,n),e]]}function to(t,e){const{attrsStore:n}=t,[r,s,i,o]=e,a=kt(i),c=G(n,r,s),u=Yn(t,[r,c,i,o]),l=Object.entries(a).map(([h,y])=>{const b=U(n,r,h);return["deep-merge-triple",c,b.id,y,...u?[u]:[]]});return[["add-triple",c,U(n,r,"id").id,c,...u?[u]:[]]].concat(l)}function no({attrsStore:t},[e,n,r]){return[["rule-params",G(t,e,n),e,r]]}function ro(t){const[e,n,r,s,i]=t;if(!s)return t;const o={...s};return delete o.id,[e,n,r,o,...i?[i]:[]]}function so(t,e){const[n,...r]=ro(e);switch(n){case"merge":return to(t,r);case"create":return Zi(t,r);case"update":return Xi(t,r);case"link":return Hi(t,r);case"unlink":return Ji(t,r);case"delete":return eo(t,r);case"ruleParams":return no(t,r);default:throw new Error(`unsupported action ${n}`)}}function io(t){switch(t){case"string":case"date":case"boolean":case"number":return t;default:return}}function oo(t,e,n){var a,c;const r=(c=(a=t.entities[e])==null?void 0:a.attrs)==null?void 0:c[n];if(n==="id")return null;if(!r)throw new Error(`${e}.${n} does not exist in your schema`);const{unique:s,indexed:i}=r==null?void 0:r.config,o=io(r==null?void 0:r.valueType);return{"index?":i,"unique?":s,"checked-data-type":o}}function st(t,e,n,r){const s=t?oo(t,e,n):null,i=N(),a=[N(),e,n];return{id:i,"forward-identity":a,"value-type":"blob",cardinality:"one","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}function ao(t,e,n){return Object.values(t.links).find(i=>i.forward.on===e&&i.forward.label===n||i.reverse.on===e&&i.reverse.label===n)}function co(t,e,n){const r=ao(t,e,n);if(!r)throw new Error(`Couldn't find the link ${e}.${n} in your schema`);const{forward:s,reverse:i}=r;return{"forward-identity":[N(),s.on,s.label],"reverse-identity":[N(),i.on,i.label],cardinality:s.has==="one"?"one":"many","unique?":i.has==="one","on-delete":s.onDelete,"on-delete-reverse":i.onDelete}}function Zn(t,e,n,r){const s=t?co(t,e,n):null,i=N(),o=[N(),e,n],a=[N(),n,e];return{id:i,"forward-identity":o,"reverse-identity":a,"value-type":"ref",cardinality:"many","unique?":!1,"index?":!1,isUnsynced:!0,...s||{},...r||{}}}const uo=new Set(["create","update","merge","link","unlink"]),lo=new Set(["link","unlink"]),fo=new Set(["create","update","merge"]),ho=new Set(["link","unlink","create","update","merge","delete","ruleParams"]),Kt={"unique?":!0,"index?":!0},po={...Kt,cardinality:"one"};function yo(t){const e=[],[n,r,s,i]=t;if(!ho.has(n))return e;const o=Nt(s);if(o&&e.push({etype:r,lookupPair:o}),n==="link")for(const[a,c]of Object.entries(i)){const u=Array.isArray(c)?c:[c];for(const l of u){const d=Nt(l);d&&e.push({etype:r,lookupPair:d,linkLabel:a})}}return e}function bo({attrsStore:t,schema:e},n){var h,y;const r=new Set,s=[],i=[];function o(b,g){return U(t,b,g)||s.find(w=>w["forward-identity"][1]===b&&w["forward-identity"][2]===g)}function a(b,g){return _e(t,b,g)||s.find(w=>{var m,T;return((m=w["reverse-identity"])==null?void 0:m[1])===b&&((T=w["reverse-identity"])==null?void 0:T[2])===g})}function c(b){s.push(b),i.push(["add-attr",b]),r.add(b.id)}function u(b){b&&"isUnsynced"in b&&b.isUnsynced&&!r.has(b.id)&&(s.push(b),i.push(["add-attr",b]),r.add(b.id))}function l(b,g){return g.indexOf(".")!==-1&&!o(b,g)}function d(b,g){const w=o(b,g),m=a(b,g);u(w),u(m),!w&&!m&&c(Zn(e,b,g,po))}for(const b of n)for(const{etype:g,lookupPair:w,linkLabel:m}of yo(b)){const T=w[0];if(m){d(g,m);const v=o(g,m),k=a(g,m);u(v),u(k);const A=((h=v==null?void 0:v["reverse-identity"])==null?void 0:h[1])||((y=k==null?void 0:k["forward-identity"])==null?void 0:y[1])||m;if(l(A,T))d(A,Ft(T));else{const R=o(A,T);R||c(st(e,A,T,Kt)),u(R)}}else if(l(g,T))d(g,Ft(T));else{const v=o(g,T);v||c(st(e,g,T,Kt)),u(v)}}for(const b of n){const[g,w,m,T]=b;if(uo.has(g)){const v=o(w,"id");u(v),v||c(st(e,w,"id",{"unique?":!0}));for(const k of Object.keys(T)){const A=o(w,k);if(u(A),fo.has(g)&&(A||c(st(e,w,k,k==="id"?{"unique?":!0}:null))),lo.has(g)){const R=a(w,k);!A&&!R&&c(Zn(e,w,k)),u(R)}}}}if(s.length){const b={...t.attrs};for(const g of s)b[g.id]=g;return[new be(b,t.linkIndex),i]}return[t,i]}function _o(t,e){const r=(Array.isArray(e)?e:[e]).flatMap(c=>Vi(c)),[s,i]=bo(t,r),o={...t,attrsStore:s},a=r.flatMap(c=>so(o,c));return[...i,...a]}function Xn(t,e){typeof requestIdleCallback>"u"?t():requestIdleCallback(t,{timeout:e})}const Ne="__meta";class go{constructor(e,n){}}class zt{constructor(e){p(this,"currentValue");p(this,"_subs",[]);p(this,"_persister");p(this,"_merge");p(this,"serialize");p(this,"parse");p(this,"_saveThrottleMs");p(this,"_idleCallbackMaxWaitMs");p(this,"_nextSave",null);p(this,"_nextGc",null);p(this,"_pendingSaveKeys",new Set);p(this,"_loadedKeys",new Set);p(this,"_loadingKeys");p(this,"_objectSize");p(this,"_log");p(this,"onKeyLoaded");p(this,"_version",0);p(this,"_meta",{isLoading:!0,onLoadCbs:[],value:null,error:null,attempts:0});p(this,"_gcOpts");this._persister=e.persister,this._merge=e.merge,this.serialize=e.serialize,this.parse=e.parse,this._objectSize=e.objectSize,this._log=e.logger,this._saveThrottleMs=e.saveThrottleMs??100,this._idleCallbackMaxWaitMs=e.idleCallbackMaxWaitMs??1e3,this._gcOpts=e.gc,this.currentValue={},this._loadedKeys=new Set,this._loadingKeys={},this._initMeta(),e.preloadEntryCount&&this._preloadEntries(e.preloadEntryCount)}async _initMeta(){var e;this._meta.loadingPromise&&await this._meta.loadingPromise;try{const n=this._persister.getItem(Ne);this._meta.loadingPromise=n;const r=await n;this._meta.isLoading=!1,this._meta.error=null,this._meta.loadingPromise=null,this._meta.attempts=0;const s=((e=this._meta.value)==null?void 0:e.objects)??{},i=r??{},o=i.objects??{};this._meta.value={...i,objects:{...s,...o}}}catch(n){this._meta.error=n,this._meta.attempts++,this._meta.loadingPromise=null}}async _getMeta(){return this._meta.value?this._meta.value:this._meta.loadingPromise?(await this._meta.loadingPromise,this._meta.value):(this._initMeta(),await this._meta.loadingPromise,this._meta.value)}async _refreshMeta(){return await this._initMeta(),this._meta.value}async _preloadEntries(e){const n=await this.waitForMetaToLoad();if(!n)return;const r=Object.entries(n.objects);r.sort(([s,i],[o,a])=>a.updatedAt-i.updatedAt);for(const[s]of r.slice(0,e))this._loadKey(s)}async _getFromStorage(e){try{const n=await this._persister.getItem(e);return n&&this.parse(e,n)}catch(n){return console.error(`Unable to read from storage for key=${e}`,n),null}}async waitForKeyToLoad(e){return this._loadedKeys.has(e)?this.currentValue[e]:(await(this._loadingKeys[e]||this._loadKey(e)),this.currentValue[e])}async waitForMetaToLoad(){return this._getMeta()}unloadKey(e){this._loadedKeys.delete(e),delete this._loadingKeys[e],delete this.currentValue[e]}async _loadKey(e){if(this._loadedKeys.has(e)||e in this._loadingKeys)return;const n=this._getFromStorage(e);this._loadingKeys[e]=n;const r=await n;if(delete this._loadingKeys[e],this._loadedKeys.add(e),r){const s=this._merge(e,r,this.currentValue[e]);s&&(this.currentValue[e]=s)}this.onKeyLoaded&&this.onKeyLoaded(e)}_writeToStorage(e){const n=[],r=e==null?void 0:e.skipGc;if(this._meta.isLoading){const d=new Promise((h,y)=>{setTimeout(()=>this._enqueuePersist(e?{...e,attempts:(e.attempts||0)+1}:{attempts:1}).then(h).catch(y),10+((e==null?void 0:e.attempts)??0)*1e3)});return n.push(d),Promise.all(n).then(h=>h.reduce((y,b)=>y+b,0))}const s=this._meta.value;if(!s)return Promise.resolve(0);const i=[],o=[];for(const d of this._pendingSaveKeys)d in this.currentValue?o.push(d):(i.push(d),delete s.objects[d]);for(const d of i){const h=this._persister.removeItem(d);n.push(h.then(()=>1)),this._loadedKeys.delete(d),this._pendingSaveKeys.delete(d)}const a=[],c=[[Ne,s]],u=s.objects??{};s.objects=u;for(const d of o)if(this._loadedKeys.has(d)){const h=this.serialize(d,this.currentValue[d]);c.push([d,h]);const y=this._objectSize(h),b=u[d]??{createdAt:Date.now(),updatedAt:Date.now(),size:y};b.updatedAt=Date.now(),b.size=y,u[d]=b,this._pendingSaveKeys.delete(d)}else a.push(d);const l=this._persister.multiSet(c);n.push(l.then(()=>1));for(const d of a){const h=this._loadKey(d).then(()=>this._enqueuePersist(e));n.push(h)}return r||this.gc(),Promise.all(n).then(d=>d.reduce((h,y)=>h+y,0))}async flush(){return this._nextSave?(clearTimeout(this._nextSave),this._nextSave=null,this._writeToStorage()):void 0}async _gc(){if(!this._gcOpts)return;const e=new Set(await this._persister.getAllKeys());e.delete(Ne);const n=new Set(Object.keys(this.currentValue));for(const h of Object.keys(this._loadingKeys))n.add(h);for(const h of this._loadedKeys)n.add(h);const r=await this._refreshMeta();if(!r){this._log.info("Could not gc because we were not able to load meta");return}const s=[],i={gcOpts:this._gcOpts,keys:e,sacredKeys:n,removed:[],metaRemoved:[],removedMissingCount:0,removedOldCount:0,removedThresholdCount:0,removedSizeCount:0};for(const h of e)n.has(h)||h in r.objects||(this._log.info("Lost track of key in meta",h),s.push(this._persister.removeItem(h)),i.removed.push(h),i.removedMissingCount++);const o=Date.now();for(const[h,y]of Object.entries(r.objects))!n.has(h)&&y.updatedAt<o-this._gcOpts.maxAgeMs&&(s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedOldCount++);const a=Object.entries(r.objects);a.sort(([h,y],[b,g])=>y.updatedAt-g.updatedAt);const c=a.filter(([h])=>!n.has(h));if(a.length>this._gcOpts.maxEntries)for(const[h]of c.slice(0,a.length-this._gcOpts.maxEntries))s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedThresholdCount++;const u=Object.entries(r.objects);u.sort(([h,y],[b,g])=>y.updatedAt-g.updatedAt);const l=u.filter(([h])=>!n.has(h));let d=u.reduce((h,[y,b])=>h+b.size,0);for(;d>0&&d>this._gcOpts.maxSize&&l.length;){const[[h,y]]=l.splice(0,1);d-=y.size,s.push(this._persister.removeItem(h)),delete r.objects[h],i.removed.push(h),i.removedSizeCount++}for(const h of Object.keys(r.objects))!e.has(h)&&!n.has(h)&&delete r.objects[h];return(i.removed.length||i.metaRemoved.length)&&s.push(this._enqueuePersist({skipGc:!0})),this._log.info("Completed GC",i),await Promise.all(s),i}gc(){this._nextGc||(this._nextGc=setTimeout(()=>{Xn(()=>{this._nextGc=null,this._gc()},30*1e3)},1e3*60+Math.random()*500))}_enqueuePersist(e){return new Promise((n,r)=>{if(this._nextSave){n(0);return}this._nextSave=setTimeout(()=>{Xn(()=>{this._nextSave=null,this._writeToStorage(e).then(n).catch(r)},this._idleCallbackMaxWaitMs)},this._saveThrottleMs)})}version(){return this._version}updateInPlace(e){this._version++;const[n,r]=Je(this.currentValue,e,{enablePatches:!0});for(const s of r){const i=s.path[0];i&&typeof i=="string"&&(this._pendingSaveKeys.add(i),this._loadedKeys.has(i)||this._loadKey(i))}this.currentValue=n,this._enqueuePersist();for(const s of this._subs)s(this.currentValue);return n}subscribe(e){return this._subs.push(e),e(this.currentValue),()=>{this._subs=this._subs.filter(n=>n!==e)}}}const To=6,wo=["kv","querySubs","syncSubs"];function mo(t){return function(n){console.error("Error in IndexedDB event",{source:t,event:n})}}async function So(t){return new Promise(e=>{const n=indexedDB.open(t);n.onerror=r=>{e(null)},n.onsuccess=r=>{const i=r.target.result;e(i)},n.onupgradeneeded=r=>{var i;(i=r.target.transaction)==null||i.abort(),e(null)}})}async function vo(t,e,n){const r=typeof e=="string"?JSON.parse(e):e;if(!r)return;const s=new Set;return new Promise((i,o)=>{var l,d,h;const a={};for(const[y,b]of Object.entries(r)){const g=typeof b=="string"?JSON.parse(b):b;if(g.lastAccessed){const m={createdAt:g.lastAccessed,updatedAt:g.lastAccessed,size:((h=(d=(l=g.result)==null?void 0:l.store)==null?void 0:d.triples)==null?void 0:h.length)??0};a[y]=m}const w=n.put(g,y);s.add(w)}const c={objects:a},u=n.put(c,Ne);s.add(u);for(const y of s)y.onsuccess=()=>{s.delete(y),s.size===0&&i()},y.onerror=b=>{o(b)}})}async function er(t,e,n){const r=n.put(e,t);return new Promise((s,i)=>{r.onsuccess=()=>s(),r.onerror=o=>i(o)})}async function Ao(t,e){const n=await So(`instant_${t}_5`);if(!n)return;const r=await new Promise((l,d)=>{const b=n.transaction(["kv"],"readonly").objectStore("kv").openCursor();b.onerror=w=>{d(w)};const g=[];b.onsuccess=()=>{const w=b.result;if(w){const m=w.key,T=w.value;g.push([m,T]),w.continue()}else l(g)},b.onerror=w=>{d(w)}}),s=e.transaction(["kv","querySubs"],"readwrite"),i=s.objectStore("kv"),o=s.objectStore("querySubs"),a=[],c={objects:{}};for(const[l,d]of r)switch(l){case"querySubs":{const h=vo(l,d,o);a.push(h);break}default:{const h=er(l,d,i);a.push(h);const y={createdAt:Date.now(),updatedAt:Date.now(),size:0};c.objects[l]=y;break}}const u=er(Ne,c,i);a.push(u),await Promise.all(a),await new Promise((l,d)=>{s.oncomplete=h=>l(h),s.onerror=h=>d(h),s.onabort=h=>d(h)})}const tr=new Map;class nr extends go{constructor(n,r){super(n,r);p(this,"dbName");p(this,"_storeName");p(this,"_appId");p(this,"_prefix");p(this,"_dbPromise");this.dbName=`instant_${n}_${To}`,this._storeName=r,this._appId=n,this._dbPromise=this._init()}_init(){return new Promise((n,r)=>{let s=!1;const i=indexedDB.open(this.dbName,1);i.onerror=o=>{r(o)},i.onsuccess=o=>{const c=o.target.result;if(s){const u=Ao(this._appId,c).catch(l=>{mo("Error upgrading store from version 5 to 6.")(l)});tr.set(this.dbName,u),u.then(()=>n(c)).catch(()=>n(c))}else{const u=tr.get(this.dbName);u?u.then(()=>n(c)).catch(()=>n(c)):n(c)}},i.onupgradeneeded=o=>{s=!0,this._upgradeStore(o)}})}_upgradeStore(n){const s=n.target.result;for(const i of wo)s.objectStoreNames.contains(i)||s.createObjectStore(i)}async getItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readonly").objectStore(this._storeName).get(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{c.result?s(c.result):s(null)}})}async setItem(n,r){const s=await this._dbPromise;return new Promise((i,o)=>{const u=s.transaction([this._storeName],"readwrite").objectStore(this._storeName).put(r,n);u.onerror=l=>{o(l)},u.onsuccess=l=>{i()}})}async multiSet(n){const r=await this._dbPromise;return new Promise((s,i)=>{const o=r.transaction([this._storeName],"readwrite"),a=o.objectStore(this._storeName),c=new Set;for(const[u,l]of n){const d=a.put(l,u);c.add(d)}for(const u of c)u.onerror=l=>{o.abort(),i(l)},u.onsuccess=l=>{c.delete(u),c.size===0&&s()}})}async removeItem(n){const r=await this._dbPromise;return new Promise((s,i)=>{const c=r.transaction([this._storeName],"readwrite").objectStore(this._storeName).delete(n);c.onerror=u=>{i(u)},c.onsuccess=u=>{s()}})}async getAllKeys(){const n=await this._dbPromise;return new Promise((r,s)=>{const a=n.transaction([this._storeName],"readonly").objectStore(this._storeName).getAllKeys();a.onerror=c=>{s(c)},a.onsuccess=c=>{r(a.result.filter(u=>typeof u=="string"))}})}}class rr{static async getIsOnline(){return navigator.onLine}static listen(e){const n=()=>{e(!0)},r=()=>{e(!1)};return addEventListener("online",n),addEventListener("offline",r),()=>{removeEventListener("online",n),removeEventListener("offline",r)}}}class Ee extends Error{constructor(n,r){super(n);p(this,"hint");this.hint=r;const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,Ee),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class it extends Ee{constructor(n){var i;const r=((i=n.body)==null?void 0:i.message)||`API Error (${n.status})`;super(r,n.body.hint);p(this,"body");p(this,"status");const s=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,s),Error.captureStackTrace&&Error.captureStackTrace(this,it),this.name="InstantAPIError",this.status=n.status,this.body=n.body}get[Symbol.toStringTag](){return"InstantAPIError"}}async function re(t,e){const n=await fetch(t,e),r=await n.json();return n.status===200?Promise.resolve(r):Promise.reject(new it({status:n.status,body:r}))}function Eo({apiURI:t,appId:e,email:n}){return re(`${t}/runtime/auth/send_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n})})}async function Oo({apiURI:t,appId:e,email:n,code:r,refreshToken:s}){return await re(`${t}/runtime/auth/verify_magic_code`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,email:n,code:r,...s?{"refresh-token":s}:{}})})}async function ko({apiURI:t,appId:e,refreshToken:n}){return await re(`${t}/runtime/auth/verify_refresh_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e,"refresh-token":n})})}async function Po({apiURI:t,appId:e}){return await re(`${t}/runtime/auth/sign_in_guest`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":e})})}async function sr({apiURI:t,appId:e,code:n,codeVerifier:r,refreshToken:s}){return await re(`${t}/runtime/oauth/token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,code:n,code_verifier:r,refresh_token:s})})}async function Co({apiURI:t,appId:e,nonce:n,idToken:r,clientName:s,refreshToken:i}){return await re(`${t}/runtime/oauth/id_token`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,nonce:n,id_token:r,client_name:s,refresh_token:i})})}async function Io({apiURI:t,appId:e,refreshToken:n}){return await re(`${t}/runtime/signout`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({app_id:e,refresh_token:n})})}async function Mo({apiURI:t,appId:e,path:n,file:r,refreshToken:s,contentType:i,contentDisposition:o}){const a={app_id:e,path:n,authorization:`Bearer ${s}`,"content-type":i||r.type};return o&&(a["content-disposition"]=o),await re(`${t}/storage/upload`,{method:"PUT",headers:a,body:r})}async function jo({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await re(`${t}/storage/files?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"DELETE",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}async function Ro({apiURI:t,appId:e,fileName:n,refreshToken:r,metadata:s={}}){const{data:i}=await re(`${t}/storage/signed-upload-url`,{method:"POST",headers:{"content-type":"application/json",authorization:`Bearer ${r}`},body:JSON.stringify({app_id:e,filename:n})});return i}async function Do(t,e){return(await fetch(t,{method:"PUT",body:e,headers:{"Content-Type":e.type}})).ok}async function xo({apiURI:t,appId:e,path:n,refreshToken:r}){const{data:s}=await re(`${t}/storage/signed-download-url?app_id=${e}&filename=${encodeURIComponent(n)}`,{method:"GET",headers:{"content-type":"application/json",authorization:`Bearer ${r}`}});return s}let qt=!1,ir=!1,or=!1;typeof window<"u"&&typeof window.localStorage<"u"&&(qt=!!window.localStorage.getItem("devBackend"),ir=!!window.localStorage.getItem("__instantLogging"),or=!!window.localStorage.getItem("__devtoolLocalDash"));function ar(t,e){if(!e)return t;const n={};return e.forEach(r=>{n[r]=t[r]}),n}function $o(t,e,n){const r={peers:{}};if(e&&"user"in e?e.user:!0){const i=ar(t.user??{},e==null?void 0:e.keys);r.user={...i,peerId:n}}for(const i of Object.keys(t.peers??{})){const o=(e==null?void 0:e.peers)===void 0,a=Array.isArray(e==null?void 0:e.peers)&&(e==null?void 0:e.peers.includes(i));if(o||a){const c=ar(t.peers[i],e==null?void 0:e.keys);r.peers[i]={...c,peerId:i}}}return r}function Uo(t,e){if(t.isLoading!==e.isLoading||t.error!==e.error||(t.user||e.user)&&(!t.user||!e.user||!Sn(t.user,e.user))||!mn(t.peers,e.peers))return!0;for(const r of Object.keys(t.peers))if(!Sn(t.peers[r],e.peers[r]))return!0;return!1}class cr{constructor(){p(this,"promise");p(this,"_resolve");p(this,"_reject");this.promise=new Promise((e,n)=>{this._resolve=e,this._reject=n})}resolve(e){this._resolve(e)}reject(e){this._reject(e)}}function ur(t,e=[]){t.forEach(n=>{const{data:r}=n,{"datalog-result":s}=r,{"join-rows":i}=s;for(const o of i)for(const a of o)e.push(a);ur(n["child-nodes"],e)})}function lr(t){const e=[];return ur(t,e),e}function fr(t){return Object.values(t.links).reduce((e,n)=>{var r,s;return e[r=n.forward.on]??(e[r]={}),e[n.forward.on][n.forward.label]={isForward:!0,isSingular:n.forward.has==="one",link:n},e[s=n.reverse.on]??(e[s]={}),e[n.reverse.on][n.reverse.label]={isForward:!1,isSingular:n.reverse.has==="one",link:n},e},{})}const dr="v0.22.113-experimental.dwwoelfel-patch-2.21374029739.1";function Lo(t,e){return{info:t?(...n)=>console.info(...n,e()):()=>{},debug:t?(...n)=>console.debug(...n,e()):()=>{},error:t?(...n)=>console.error(...n,e()):()=>{}}}class ue{constructor(e,n,r,s={indexed:!1,unique:!1}){p(this,"valueType");p(this,"required");p(this,"isIndexed");p(this,"config");p(this,"metadata",{});this.valueType=e,this.required=n,this.isIndexed=r,this.config=s}clientRequired(){return new ue(this.valueType,!1,this.isIndexed,this.config)}optional(){return new ue(this.valueType,!1,this.isIndexed,this.config)}unique(){return new ue(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new ue(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class D extends Error{constructor(e,n){const r=n?`At path '${n}': ${e}`:e;super(r),this.name="QueryValidationError"}}const hr=["where","order","limit","last","first","offset","after","before","fields","aggregate"],Fo=t=>t.valueType||"unknown",pr=(t,e,n=!1)=>{if(n||t==null)return!0;switch(e){case"string":return typeof t=="string";case"number":return typeof t=="number"&&!isNaN(t);case"boolean":return typeof t=="boolean";case"date":return t instanceof Date||typeof t=="string"||typeof t=="number";default:return!0}},No=(t,e,n,r,s,i,o)=>{const a=i.valueType==="json",c=(u,l,d)=>{if(!pr(d,l,a))throw new D(`Invalid value for operator '${u}' on attribute '${r}' in entity '${s}'. Expected ${l}, but received: ${typeof d}`,o)};switch(t){case"in":case"$in":if(!Array.isArray(e))throw new D(`Operator '${t}' for attribute '${r}' in entity '${s}' must be an array, but received: ${typeof e}`,o);for(const u of e)c(t,n,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(t,n,e);break;case"$like":case"$ilike":if(c(t,"string",e),t==="$ilike"&&!i.isIndexed)throw new D(`Operator '${t}' can only be used with indexed attributes, but '${r}' in entity '${s}' is not indexed`,o);break;case"$isNull":c(t,"boolean",e);break;default:throw new D(`Unknown operator '${t}' for attribute '${r}' in entity '${s}'`,o)}},Oe=(t,e,n,r,s)=>{const i=Fo(n),o=n.valueType==="json";if(typeof t=="object"&&t!==null&&!Array.isArray(t)){if(o)return;const c=t;for(const[u,l]of Object.entries(c))No(u,l,i,e,r,n,`${s}.${u}`)}else if(!pr(t,i,o))throw new D(`Invalid value for attribute '${e}' in entity '${r}'. Expected ${i}, but received: ${typeof t}`,s)},Ko=(t,e,n,r,s)=>{const i=t.split(".");if(i.length<2)throw new D(`Invalid dot notation path '${t}'. Must contain at least one dot.`,s);let o=n;for(let l=0;l<i.length-1;l++){const d=i[l],h=r.entities[o];if(!h)throw new D(`Entity '${o}' does not exist in schema while traversing dot notation path '${t}'.`,s);const y=h.links[d];if(!y){const b=Object.keys(h.links);throw new D(`Link '${d}' does not exist on entity '${o}' in dot notation path '${t}'. Available links: ${b.length>0?b.join(", "):"none"}`,s)}o=y.entityName}const a=i[i.length-1],c=r.entities[o];if(!c)throw new D(`Target entity '${o}' does not exist in schema for dot notation path '${t}'.`,s);if(a==="id"){if(typeof e=="string"&&!ve(e))throw new D(`Invalid value for id field in entity '${o}'. Expected a UUID, but received: ${e}`,s);Oe(e,t,new ue("string",!1,!0),n,s);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof e=="string"&&!ve(e))throw new D(`Invalid value for link '${a}' in entity '${o}'. Expected a UUID, but received: ${e}`,s);Oe(e,t,new ue("string",!1,!0),n,s);return}if(!u){const l=Object.keys(c.attrs);throw new D(`Attribute '${a}' does not exist on entity '${o}' in dot notation path '${t}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,s)}Oe(e,t,u,n,s)},yr=(t,e,n,r)=>{for(const[s,i]of Object.entries(t)){if(s==="or"||s==="and"){if(Array.isArray(i))for(const u of i)typeof u=="object"&&u!==null&&yr(u,e,n,`${r}.${s}[${u}]`);continue}if(s==="id"){Oe(i,"id",new ue("string",!1,!0),e,`${r}.id`);continue}if(s.includes(".")){Ko(s,i,e,n,`${r}.${s}`);continue}const o=n.entities[e];if(!o)continue;const a=o.attrs[s],c=o.links[s];if(!a&&!c){const u=Object.keys(o.attrs),l=Object.keys(o.links);throw new D(`Attribute or link '${s}' does not exist on entity '${e}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${r}.${s}`)}if(a)Oe(i,s,a,e,`${r}.${s}`);else if(c){if(typeof i=="string"&&!ve(i))throw new D(`Invalid value for link '${s}' in entity '${e}'. Expected a UUID, but received: ${i}`,`${r}.${s}`);const u=new ue("string",!1,!0);Oe(i,s,u,e,`${r}.${s}`)}}},zo=(t,e,n,r,s=0)=>{for(const o of Object.keys(t))if(!hr.includes(o))throw new D(`Invalid query parameter '${o}' in $ object. Valid parameters are: ${hr.join(", ")}. Found: ${o}`,r);const i=["offset","before","after","first","last"];for(const o of i)if(t[o]!==void 0&&s>0)throw new D(`'${o}' can only be used on top-level namespaces. It cannot be used in nested queries.`,r);if(t.where&&n){if(typeof t.where!="object"||t.where===null)throw new D(`'where' clause must be an object in entity '${e}', but received: ${typeof t.where}`,r?`${r}.where`:void 0);yr(t.where,e,n,r?`${r}.where`:"where")}},br=(t,e,n,r,s=0)=>{var i;if(!t||typeof t!="object")throw new D(`Query part for entity '${e}' must be an object, but received: ${typeof t}`,r);for(const o of Object.keys(t))if(o!=="$"){if(n&&!(o in n.entities[e].links)){const c=Object.keys(n.entities[e].links);throw new D(`Link '${o}' does not exist on entity '${e}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${r}.${o}`)}const a=t[o];if(typeof a=="object"&&a!==null){const c=(i=n==null?void 0:n.entities[e].links[o])==null?void 0:i.entityName;c&&br(a,c,n,`${r}.${o}`,s+1)}}else{const a=t[o];if(typeof a!="object"||a===null)throw new D(`Query parameter '$' must be an object in entity '${e}', but received: ${typeof a}`,`${r}.$`);zo(a,e,n,`${r}.$`,s)}},_r=(t,e)=>{if(typeof t!="object"||t===null)throw new D(`Query must be an object, but received: ${typeof t}${t===null?" (null)":""}`);if(Array.isArray(t))throw new D(`Query must be an object, but received: ${typeof t}`);const n=t;for(const r of Object.keys(n)){if(Array.isArray(t[r]))throw new D(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(typeof r!="string")throw new D(`Query keys must be strings, but found key of type: ${typeof r}`,r);if(r!=="$$ruleParams"){if(e&&!e.entities[r]){const s=Object.keys(e.entities);throw new D(`Entity '${r}' does not exist in schema. Available entities: ${s.length>0?s.join(", "):"none"}`,r)}br(n[r],r,e,r,0)}}},gr=t=>typeof t!="string"?!1:rt(t)?!0:ve(t);class X extends Error{constructor(e){super(e),this.name="TransactionValidationError"}}const Tr=t=>t.length>0?t.join(", "):"none",qo=(t,e)=>new X(`Entity '${t}' does not exist in schema. Available entities: ${Tr(e)}`),Vt={string:t=>typeof t=="string",number:t=>typeof t=="number"&&!isNaN(t),boolean:t=>typeof t=="boolean",date:t=>t instanceof Date||typeof t=="string"||typeof t=="number",json:()=>!0},Vo=(t,e)=>{var n;return t==null?!0:((n=Vt[e.valueType])==null?void 0:n.call(Vt,t))??!1},wr=(t,e)=>{const n=e.entities[t];if(!n)throw qo(t,Object.keys(e.entities));return n},Wt=(t,e,n)=>{const r=wr(t,n);if(typeof e!="object"||e===null)throw new X(`Arguments for data operation on entity '${t}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(s==="id")continue;const o=r.attrs[s];if(o&&!Vo(i,o))throw new X(`Invalid value for attribute '${s}' in entity '${t}'. Expected ${o.valueType}, but received: ${typeof i}`)}},mr=(t,e,n)=>{const r=wr(t,n);if(typeof e!="object"||e===null)throw new X(`Arguments for link operation on entity '${t}' must be an object, but received: ${typeof e}`);for(const[s,i]of Object.entries(e)){if(!r.links[s]){const a=Object.keys(r.links);throw new X(`Link '${s}' does not exist on entity '${t}'. Available links: ${Tr(a)}`)}if(i!=null){if(Array.isArray(i)){for(const a of i)if(!gr(a))throw new X(`Invalid entity ID in link '${s}' for entity '${t}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!gr(i))throw new X(`Invalid UUID in link '${s}' for entity '${t}'. Expected a UUID, but received: ${i}`)}}},Wo={create:Wt,update:Wt,merge:Wt,link:mr,unlink:mr,delete:()=>{}},Qo=(t,e)=>{if(!e)return;const[n,r,s,i]=t;if(!Array.isArray(s)&&!ve(s))throw new X(`Invalid id for entity '${r}'. Expected a UUID, but received: ${s}`);if(typeof r!="string")throw new X(`Entity name must be a string, but received: ${typeof r}`);const o=Wo[n];o&&i!==void 0&&o(r,i,e)},Bo=(t,e)=>{const n=Array.isArray(t)?t:[t];for(const r of n){if(!r||typeof r!="object")throw new X(`Transaction chunk must be an object, but received: ${typeof r}`);if(!Array.isArray(r.__ops))throw new X(`Transaction chunk must have __ops array, but received: ${typeof r.__ops}`);for(const s of r.__ops){if(!Array.isArray(s))throw new X(`Transaction operation must be an array, but received: ${typeof s}`);Qo(s,e)}}};let Sr=0;class vr{constructor(e){p(this,"type","ws");p(this,"conn");p(this,"id");p(this,"onopen");p(this,"onmessage");p(this,"onclose");p(this,"onerror");this.id=`${this.type}_${Sr++}`,this.conn=new WebSocket(e),this.conn.onopen=n=>{this.onopen&&this.onopen({target:this})},this.conn.onmessage=n=>{this.onmessage&&this.onmessage({target:this,message:JSON.parse(n.data.toString())})},this.conn.onclose=n=>{this.onclose&&this.onclose({target:this})},this.conn.onerror=n=>{this.onerror&&this.onerror({target:this})}}close(){this.conn.close()}isOpen(){return this.conn.readyState===(WebSocket.OPEN??1)}isConnecting(){return this.conn.readyState===(WebSocket.CONNECTING??0)}send(e){return this.conn.send(JSON.stringify(e))}}class Go{constructor(e,n){p(this,"type","sse");p(this,"initParams",null);p(this,"sendQueue",[]);p(this,"sendPromise");p(this,"closeFired",!1);p(this,"sseInitTimeout");p(this,"ES");p(this,"conn");p(this,"url");p(this,"id");p(this,"onopen");p(this,"onmessage");p(this,"onclose");p(this,"onerror");this.id=`${this.type}_${Sr++}`,this.url=n,this.ES=e,this.conn=new e(n),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=r=>{const s=JSON.parse(r.data);if(Array.isArray(s))for(const i of s)this.handleMessage(i);else this.handleMessage(s)},this.conn.onerror=r=>{this.handleError()}}handleMessage(e){if(e.op==="sse-init"){this.initParams={machineId:e["machine-id"],sessionId:e["session-id"],sseToken:e["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:e})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(e){var n,r,s;try{(await fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(n=this.initParams)==null?void 0:n.machineId,session_id:(r=this.initParams)==null?void 0:r.sessionId,sse_token:(s=this.initParams)==null?void 0:s.sseToken,messages:e})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const e=this.sendQueue;this.sendQueue=[];const n=this.postMessages(e);this.sendPromise=n,n.then(()=>{this.sendPromise=null,this.flushQueue()})}send(e){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(e),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}function Ho(t,e){const n=t.values;if(n){const r=In(n.attrsStore,null);if(r){for(const s of n.entities||[])s.store.useDateObjects=e,s.store=Cn(r,s.store);n.attrsStore=r}}return t}function Jo(t,e){var n;if(e.values){const r=[];for(const s of(n=e.values)==null?void 0:n.entities){const i=Pn(s.store);r.push({...s,store:i})}return{...e,values:{attrsStore:e.values.attrsStore.toJSON(),entities:r}}}else return e}function Yo(t,e,n){var i,o;const r=(i=e==null?void 0:e.state)==null?void 0:i.txId,s=(o=n==null?void 0:n.state)==null?void 0:o.txId;return r&&(!s||r>s)?e:s&&(!r||s>r)?n:e||n}function Qt(t,e,n){return Hn({store:e,attrsStore:n,pageInfo:null,aggregate:null},t.query).data[t.table][0]}function Ar(t,e,n,r){var o;const s=(o=U(n,t.table,"id"))==null?void 0:o.id;if(!s)return-1;const i=Se(e.eav,[r,s,r]);return i?i[3]:-1}function Er(t,e,n){for(const{action:r,triple:s}of n)switch(r){case"added":Rn(t,e,s);break;case"removed":Mn(t,e,s);break}}function Zo(t,e,n){var s,i;const r={};for(const{action:o,triple:a}of n){const[c,u,l]=a,d=(i=(s=e.getAttr(u))==null?void 0:s["forward-identity"])==null?void 0:i[2];if(!d)continue;const h=r[c]??{};r[c]=h;const y=h[d]??{};switch(o){case"added":y.newValue=l;break;case"removed":y.oldValue===void 0&&(y.oldValue=l);break}h[d]=y}for(const[o,a]of Object.entries(r))for(const[c,{oldValue:u,newValue:l}]of Object.entries(a))u===l&&delete a[c];return r}function ot(t,e){return{[t.table]:e.map(n=>n.entity)}}function Xo(t,e){var r;if(t.orderFieldType)return t.orderFieldType;const n=t.orderField==="serverCreatedAt"?"number":(r=U(e(),t.table,t.orderField))==null?void 0:r["checked-data-type"];return t.orderFieldType=n,n}function ea(t,e,n){const r=e;if(t.orderField==="serverCreatedAt"){n.sort(t.orderDirection==="asc"?function(o,a){return Fe(o.entity.id,o.serverCreatedAt,a.entity.id,a.serverCreatedAt,r)}:function(o,a){return Fe(a.entity.id,a.serverCreatedAt,o.entity.id,o.serverCreatedAt,r)});return}const s=t.orderField;n.sort(t.orderDirection==="asc"?function(o,a){return Fe(o.entity.id,o.entity[s],a.entity.id,a.entity[s],r)}:function(o,a){return Fe(a.entity.id,a.entity[s],o.entity.id,o.entity[s],r)})}var ge;(function(t){t.InitialSyncBatch="InitialSyncBatch",t.InitialSyncComplete="InitialSyncComplete",t.LoadFromStorage="LoadFromStorage",t.SyncTransaction="SyncTransaction",t.Error="Error"})(ge||(ge={}));class ta{constructor(e,n,r,s,i,o){p(this,"trySend");p(this,"subs");p(this,"callbacks",{});p(this,"config");p(this,"idToHash",{});p(this,"log");p(this,"createStore");p(this,"getAttrs");this.trySend=e,this.config=r,this.log=s,this.createStore=i,this.getAttrs=o,this.subs=new zt({persister:n,merge:Yo,serialize:Jo,parse:(a,c)=>Ho(c,this.config.useDateObjects),objectSize:a=>{var c;return((c=a.values)==null?void 0:c.entities.length)||0},logger:s,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}})}beforeUnload(){this.subs.flush()}subscribe(e,n){const r=F(e);return this.callbacks[r]=this.callbacks[r]||[],this.callbacks[r].push(n),this.initSubscription(e,r,n),s=>{this.unsubscribe(r,n,s==null?void 0:s.keepSubscription)}}unsubscribe(e,n,r){const s=(this.callbacks[e]||[]).filter(i=>i!==n);if(this.callbacks[e]=s,!s.length){delete this.callbacks[e];const i=this.subs.currentValue[e];i!=null&&i.state&&this.clearSubscriptionData(i.state.subscriptionId,!!r),r||this.subs.updateInPlace(o=>{delete o[e]})}}sendStart(e){this.trySend(N(),{op:"start-sync",q:e})}sendResync(e,n,r){this.idToHash[n.subscriptionId]=e.hash,this.trySend(n.subscriptionId,{op:"resync-table","subscription-id":n.subscriptionId,"tx-id":r,token:n.token})}sendRemove(e,n){this.trySend(N(),{op:"remove-sync","subscription-id":e.subscriptionId,"keep-subscription":n})}async initSubscription(e,n,r){var u,l,d,h;await this.subs.waitForKeyToLoad(n);const s=this.subs.currentValue[n];if(s&&s.state&&s.state.txId){this.sendResync(s,s.state,s.state.txId),(u=s.values)!=null&&u.entities&&r&&r({type:ge.LoadFromStorage,data:ot(s,(l=s.values)==null?void 0:l.entities)});return}const i=Object.keys(e)[0],o=((h=(d=e[i])==null?void 0:d.$)==null?void 0:h.order)||{serverCreatedAt:"asc"},[a,c]=Object.entries(o)[0];this.subs.updateInPlace(y=>{y[n]={query:e,hash:n,table:i,orderDirection:c,orderField:a,createdAt:Date.now(),updatedAt:Date.now()}}),this.sendStart(e)}async flushPending(){for(const e of Object.keys(this.callbacks)){await this.subs.waitForKeyToLoad(e);const n=this.subs.currentValue[e];n?await this.initSubscription(n.query,n.hash):this.log.error("Missing sub for hash in flushPending",e)}}onStartSyncOk(e){const n=e["subscription-id"],r=e.q,s=F(r);this.idToHash[n]=s,this.subs.updateInPlace(i=>{const o=i[s];if(!o)return this.log.error("Missing sub for hash",s,"subscription-id",n,"query",r),i;o.state={subscriptionId:n,token:e.token}})}notifyCbs(e,n){for(const r of this.callbacks[e]||[])r(n)}onSyncLoadBatch(e){const n=e["subscription-id"],r=e["join-rows"],s=this.idToHash[n];if(!s){this.log.error("Missing hash for subscription",e);return}const i=[],o=this.subs.currentValue[s];if(!o){this.log.error("Missing sub for hash",s,e);return}const a=o.values??{entities:[],attrsStore:this.getAttrs()};o.values=a;const c=a.entities;for(const u of r){const l=this.createStore(u),d=Qt(o,l,a.attrsStore);c.push({store:l,entity:d,serverCreatedAt:Ar(o,l,a.attrsStore,d.id)}),i.push(d)}this.subs.updateInPlace(u=>{u[s]=o,u[s].updatedAt=Date.now()}),o.values&&this.notifyCbs(s,{type:ge.InitialSyncBatch,data:ot(o,o.values.entities),batch:i})}onSyncInitFinish(e){var i;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}this.subs.updateInPlace(o=>{const a=o[r];if(!a){this.log.error("Missing sub for hash",r,e);return}const c=a.state;if(!c)return this.log.error("Sub never set init, missing result",a,e),o;c.txId=e["tx-id"],a.updatedAt=Date.now()});const s=this.subs.currentValue[r];s&&this.notifyCbs(r,{type:ge.InitialSyncComplete,data:ot(s,((i=s.values)==null?void 0:i.entities)||[])})}onSyncUpdateTriples(e){var o;const n=e["subscription-id"],r=this.idToHash[n];if(!r){this.log.error("Missing hash for subscription",e);return}const s=this.subs.currentValue[r];if(!s){this.log.error("Missing sub for hash",r,e);return}const i=s.state;if(!i){this.log.error("Missing state for sub",s,e);return}for(const a of e.txes){if(i.txId&&i.txId>=a["tx-id"])continue;i.txId=a["tx-id"];const c=[],u={};for(const w of a.changes){const m=u[w.triple[0]]??[];u[w.triple[0]]=m,m.push(w)}const l=s.values??{entities:[],attrsStore:this.getAttrs()},d=l.entities;s.values=l;const h=[];e:for(const[w,m]of Object.entries(u))for(let T=0;T<d.length;T++){const v=d[T];if(Ds(v.store,w)){Er(v.store,l.attrsStore,m);const k=Qt(s,v.store,l.attrsStore),A=Zo(v.store,l.attrsStore,m)[w];k?(h.push({oldEntity:v.entity,newEntity:k,changedFields:A||{}}),v.entity=k):c.push(T),delete u[w];continue e}}const y=[];for(const[w,m]of Object.entries(u)){const T=this.createStore([]);Er(T,l.attrsStore,m);const v=Qt(s,T,l.attrsStore);if(!v){this.log.error("No entity found after applying change",{sub:s,changes:m,store:T});continue}d.push({store:T,entity:v,serverCreatedAt:Ar(s,T,l.attrsStore,v.id)}),y.push(v)}const b=[];for(const w of c.sort().reverse())b.push(d[w].entity),d.splice(w,1);const g=Xo(s,this.getAttrs);ea(s,g,d),this.notifyCbs(r,{type:ge.SyncTransaction,data:ot(s,(o=s.values)==null?void 0:o.entities),added:y,removed:b,updated:h})}this.subs.updateInPlace(a=>{a[r]=s,a[r].updatedAt=Date.now()})}clearSubscriptionData(e,n){const r=this.idToHash[e];if(r){delete this.idToHash[e];const s=this.subs.currentValue[r];if(s.state&&this.sendRemove(s.state,n),n?this.subs.unloadKey(r):this.subs.updateInPlace(i=>{delete i[r]}),s)return s}}onStartSyncError(e){const n=F(e["original-event"].q),r={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa.",status:e.status,type:e.type,hint:e.hint},s=Object.keys(e["original-event"].q)[0];this.notifyCbs(n,{type:ge.Error,data:{[s]:[]},error:r})}onResyncError(e){const n=e["original-event"]["subscription-id"],r=this.clearSubscriptionData(n,!1);r&&this.initSubscription(r.query,r.hash)}}const le={CONNECTING:"connecting",OPENED:"opened",AUTHENTICATED:"authenticated",CLOSED:"closed",ERRORED:"errored"},na=3e4,ra=3e4,sa=200,ia=1e3*60,oa={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"},Bt="_instant_oauth_redirect",Ke="currentUser";function aa({transportType:t,appId:e,apiURI:n,wsURI:r,EventSourceImpl:s}){if(!s)return new vr(`${r}?app_id=${e}`);switch(t){case"ws":return new vr(`${r}?app_id=${e}`);case"sse":return new Go(s,`${n}/runtime/sse?app_id=${e}`);default:throw new Error("Unknown transport type "+t)}}function ca(){return typeof window<"u"||typeof chrome<"u"}const Or={"set-presence":!0,"set-presence-ok":!0,"refresh-presence":!0,"patch-presence":!0};function ua(t,e){var r;const n=typeof t=="string"?JSON.parse(t):t;if((r=n==null?void 0:n.result)!=null&&r.store){const s=In(n.result.attrsStore,n.result.store);if(s){const i=n.result.store;n.result.store=Cn(s,{...i,useDateObjects:e}),n.result.attrsStore=s}}return n}function la(t,e){const{result:n,...r}=e,s=r;if(n){const i={...n,store:Pn(n.store),attrsStore:n.attrsStore.toJSON()};s.result=i}return s}function fa(t,e){switch(t){case"pendingMutations":return new Map(typeof e=="string"?JSON.parse(e):e);default:return e}}function da(t,e){switch(t){case"pendingMutations":return[...e.entries()];default:return e}}function ha(t,e,n){const r=e==null?void 0:e.result,s=n==null?void 0:n.result;return r&&!s&&n&&(n.result=r),n||e}function Gt(t){return[...t].sort((e,n)=>{const[r,s]=e,[i,o]=n,a=s.order||0,c=o.order||0;return a==c?r<i?-1:r>i?1:0:a-c})}class pa{constructor(e,n=nr,r=rr,s,i){p(this,"attrs");p(this,"_isOnline",!0);p(this,"_isShutdown",!1);p(this,"status",le.CONNECTING);p(this,"querySubs");p(this,"kv");p(this,"_syncTable");p(this,"queryCbs",{});p(this,"queryOnceDfds",{});p(this,"authCbs",[]);p(this,"attrsCbs",[]);p(this,"mutationErrorCbs",[]);p(this,"connectionStatusCbs",[]);p(this,"config");p(this,"mutationDeferredStore",new Map);p(this,"_reconnectTimeoutId",null);p(this,"_reconnectTimeoutMs",0);p(this,"_transport");p(this,"_transportType","ws");p(this,"_EventSource");p(this,"_wsOk",null);p(this,"_localIdPromises",{});p(this,"_errorMessage",null);p(this,"_oauthCallbackResponse",null);p(this,"_linkIndex",null);p(this,"_broadcastChannel");p(this,"_rooms",{});p(this,"_roomsPendingLeave",{});p(this,"_presence",{});p(this,"_broadcastQueue",[]);p(this,"_broadcastSubs",{});p(this,"_currentUserCached",{isLoading:!0,error:void 0,user:void 0});p(this,"_beforeUnloadCbs",[]);p(this,"_dataForQueryCache",{});p(this,"_log");p(this,"_pendingTxCleanupTimeout");p(this,"_pendingMutationCleanupThreshold");p(this,"_inFlightMutationEventIds",new Set);p(this,"_onMergeKv",(e,n,r)=>{switch(e){case"pendingMutations":{const s=(n==null?void 0:n.entries())??[],i=(r==null?void 0:r.entries())??[],o=new Map([...s,...i]);return(n?this._rewriteMutationsSorted(this.attrs,n):[]).forEach(([c,u])=>{var l;!((l=r==null?void 0:r.pendingMutations)!=null&&l.has(c))&&!u["tx-id"]&&this._sendMutation(c,u)}),o}default:return r||n}});p(this,"getPreviousResult",e=>{var r;const n=F(e);return(r=this.dataForQuery(n))==null?void 0:r.data});p(this,"notifyOne",e=>{var i;const n=this.queryCbs[e]??[],r=(i=this._dataForQueryCache[e])==null?void 0:i.data,s=this.dataForQuery(e);s!=null&&s.data&&(this._dataForQueryCache[e]=s,!Ye(s.data,r)&&n.forEach(o=>o.cb(s.data)))});p(this,"notifyOneQueryOnce",e=>{var s;const n=this.queryOnceDfds[e]??[],r=(s=this.dataForQuery(e))==null?void 0:s.data;n.forEach(i=>{this._completeQueryOnce(i.q,e,i.dfd),i.dfd.resolve(r)})});p(this,"notifyQueryError",(e,n)=>{(this.queryCbs[e]||[]).forEach(s=>s.cb({error:n}))});p(this,"pushTx",e=>{this.config.disableValidation||Bo(e,this.config.schema);try{const n=_o({attrsStore:this.optimisticAttrs(),schema:this.config.schema,stores:Object.values(this.querySubs.currentValue).map(r=>{var s;return(s=r==null?void 0:r.result)==null?void 0:s.store}),useDateObjects:this.config.useDateObjects},e);return this.pushOps(n)}catch(n){return this.pushOps([],n)}});p(this,"pushOps",(e,n)=>{const r=N(),s=[...this._pendingMutations().values()],i=Math.max(0,...s.map(c=>c.order||0))+1,o={op:"transact","tx-steps":e,created:Date.now(),error:n,order:i};this._updatePendingMutations(c=>{c.set(r,o)});const a=new cr;return this.mutationDeferredStore.set(r,a),this._sendMutation(r,o),this.notifyAll(),a.promise});p(this,"_transportOnOpen",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][open]",n.id,"skip; this is no longer the current transport");return}this._log.info("[socket][open]",this._transport.id),this._setStatus(le.OPENED),this.getCurrentUser().then(r=>{var s;this._trySend(N(),{op:"init","app-id":this.config.appId,"refresh-token":(s=r.user)==null?void 0:s.refresh_token,versions:this.versions,"__admin-token":this.config.__adminToken})}).catch(r=>{this._log.error("[socket][error]",n.id,r)})});p(this,"_transportOnMessage",e=>{const n=e.target,r=e.message;if(this._transport!==n){this._log.info("[socket][message]",n.id,r,"skip; this is no longer the current transport");return}if(!this._wsOk&&n.type==="ws"&&(this._wsOk=!0),this._transportType="ws",Array.isArray(e.message))for(const s of e.message)this._handleReceive(n.id,s);else this._handleReceive(n.id,e.message)});p(this,"_transportOnError",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][error]",n.id,"skip; this is no longer the current transport");return}this._log.error("[socket][error]",n.id,e)});p(this,"_scheduleReconnect",()=>{!this._wsOk&&this._transportType!=="sse"&&(this._transportType="sse",this._reconnectTimeoutMs=0),setTimeout(()=>{if(this._reconnectTimeoutMs=Math.min(this._reconnectTimeoutMs+1e3,1e4),!this._isOnline){this._log.info("[socket][close]",this._transport.id,"we are offline, no need to start socket");return}this._startSocket()},this._reconnectTimeoutMs)});p(this,"_transportOnClose",e=>{const n=e.target;if(this._transport!==n){this._log.info("[socket][close]",n.id,"skip; this is no longer the current transport");return}this._setStatus(le.CLOSED);for(const r of Object.values(this._rooms))r.isConnected=!1;if(this._isShutdown){this._log.info("[socket][close]",n.id,"Reactor has been shut down and will not reconnect");return}this._log.info("[socket][close]",n.id,"schedule reconnect, ms =",this._reconnectTimeoutMs),this._scheduleReconnect()});if(this._EventSource=i,this.config={...oa,...e},this.queryCacheLimit=this.config.queryCacheLimit??10,this._pendingTxCleanupTimeout=this.config.pendingTxCleanupTimeout??ra,this._pendingMutationCleanupThreshold=this.config.pendingMutationCleanupThreshold??sa,this._log=Lo(e.verbose||qt||ir,()=>this._reactorStats()),this.versions={...s||{},"@instantdb/core":dr},this.config.schema&&(this._linkIndex=fr(this.config.schema)),!!ca()){if(!e.appId)throw new Error("Instant must be initialized with an appId.");if(!ve(e.appId))throw new Error(`Instant must be initialized with a valid appId. \`${e.appId}\` is not a valid uuid.`);typeof BroadcastChannel=="function"&&(this._broadcastChannel=new BroadcastChannel("@instantdb"),this._broadcastChannel.addEventListener("message",async o=>{var a;try{if(((a=o.data)==null?void 0:a.type)==="auth"){const c=await this.getCurrentUser();this.updateUser(c.user)}}catch(c){this._log.error("[error] handle broadcast channel",c)}})),this._initStorage(n),this._syncTable=new ta(this._trySendAuthed.bind(this),new n(this.config.appId,"syncSubs"),{useDateObjects:this.config.useDateObjects},this._log,o=>$e(this.ensureAttrs(),o,this.config.enableCardinalityInference,this.config.useDateObjects),()=>this.ensureAttrs()),this._oauthCallbackResponse=this._oauthLoginInit(),this.getCurrentUser().then(o=>{this.syncUserToEndpoint(o.user)}),setInterval(async()=>{const o=await this.getCurrentUser();this.syncUserToEndpoint(o.user)},ia),r.getIsOnline().then(o=>{this._isOnline=o,this._startSocket(),r.listen(a=>{a!==this._isOnline&&(this._log.info("[network] online =",a),this._isOnline=a,this._isOnline?this._startSocket():(this._log.info("Changing status from",this.status,"to",le.CLOSED),this._setStatus(le.CLOSED)))})}),typeof addEventListener<"u"&&(this._beforeUnload=this._beforeUnload.bind(this),addEventListener("beforeunload",this._beforeUnload))}}ensureAttrs(){if(!this.attrs)throw new Error("attrs have not loaded.");return this.attrs}updateSchema(e){this.config={...this.config,schema:e,cardinalityInference:!!e},this._linkIndex=e?fr(this.config.schema):null}_reactorStats(){return{inFlightMutationCount:this._inFlightMutationEventIds.size,storedMutationCount:this._pendingMutations().size,transportType:this._transportType}}_onQuerySubLoaded(e){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyOne(e))}_initStorage(e){this.querySubs=new zt({persister:new e(this.config.appId,"querySubs"),merge:ha,serialize:la,parse:(n,r)=>ua(r,this.config.useDateObjects),objectSize:n=>{var r,s,i;return((i=(s=(r=n==null?void 0:n.result)==null?void 0:r.store)==null?void 0:s.triples)==null?void 0:i.length)??0},logger:this._log,preloadEntryCount:10,gc:{maxAgeMs:1e3*60*60*24*7*52,maxEntries:1e3,maxSize:1e6}}),this.querySubs.onKeyLoaded=n=>this._onQuerySubLoaded(n),this.kv=new zt({persister:new e(this.config.appId,"kv"),merge:this._onMergeKv,serialize:da,parse:fa,objectSize:()=>0,logger:this._log,saveThrottleMs:100,idleCallbackMaxWaitMs:100,gc:null}),this.kv.onKeyLoaded=n=>{n==="pendingMutations"&&this.notifyAll()},this.kv.waitForKeyToLoad("pendingMutations"),this.kv.waitForKeyToLoad(Ke),this._beforeUnloadCbs.push(()=>{this.kv.flush(),this.querySubs.flush()})}_beforeUnload(){for(const e of this._beforeUnloadCbs)e();this._syncTable.beforeUnload()}_finishTransaction(e,n,r){const s=this.mutationDeferredStore.get(n);this.mutationDeferredStore.delete(n);const i=e!=="error"&&e!=="timeout";if(!s&&!i&&console.error("Mutation failed",{status:e,eventId:n,...r}),!!s)if(i)s.resolve({status:e,eventId:n});else if(r!=null&&r.type){const{status:o,...a}=r;s.reject(new it({body:a,status:o??0}))}else s.reject(new Ee((r==null?void 0:r.message)||"Unknown error",r==null?void 0:r.hint))}_setStatus(e,n){this.status=e,this._errorMessage=n,this.notifyConnectionStatusSubs(e)}_flushEnqueuedRoomData(e){var s,i;const n=(i=(s=this._presence[e])==null?void 0:s.result)==null?void 0:i.user,r=this._broadcastQueue[e];if(this._broadcastQueue[e]=[],n&&this._trySetPresence(e,n),r)for(const o of r){const{topic:a,roomType:c,data:u}=o;this._tryBroadcast(e,c,a,u)}}_addQueryData(e,n,r){if(!this.attrs)throw new Error("Attrs in reactor have not been set");const s=F(e),i=this.ensureAttrs(),o=$e(this.attrs,n.triples,r,this.config.useDateObjects);this.querySubs.updateInPlace(a=>{a[s]={result:{store:o,attrsStore:i,pageInfo:n.pageInfo,processedTxId:void 0,isExternal:!0},q:e}}),this._cleanupPendingMutationsQueries(),this.notifyOne(s),this.notifyOneQueryOnce(s),this._cleanupPendingMutationsTimeout()}_handleReceive(e,n){var s,i,o,a,c,u;const r=!!this.config.schema&&("cardinalityInference"in this.config?!!this.config.cardinalityInference:!0);switch(Or[n.op]||this._log.info("[receive]",e,n.op,n),n.op){case"init-ok":{this._setStatus(le.AUTHENTICATED),this._reconnectTimeoutMs=0,this._setAttrs(n.attrs),this._flushPendingMessages(),this._sessionId=n["session-id"];for(const h of Object.keys(this._rooms)){const y=(i=(s=this._presence[h])==null?void 0:s.result)==null?void 0:i.user;this._tryJoinRoom(h,y)}break}case"add-query-exists":{this.notifyOneQueryOnce(F(n.q));break}case"add-query-ok":{const{q:h,result:y}=n,b=F(h);if(!this._hasQueryListeners()&&!this.querySubs.currentValue[b])break;const g=(a=(o=y==null?void 0:y[0])==null?void 0:o.data)==null?void 0:a["page-info"],w=(u=(c=y==null?void 0:y[0])==null?void 0:c.data)==null?void 0:u.aggregate,m=lr(y),T=this.ensureAttrs(),v=$e(T,m,r,this.config.useDateObjects);this.querySubs.updateInPlace(k=>{if(!k[b]){this._log.info("Missing value in querySubs",{hash:b,q:h});return}k[b].result={store:v,attrsStore:T,pageInfo:g,aggregate:w,processedTxId:n["processed-tx-id"]}}),this._cleanupPendingMutationsQueries(),this.notifyOne(b),this.notifyOneQueryOnce(b),this._cleanupPendingMutationsTimeout();break}case"start-sync-ok":{this._syncTable.onStartSyncOk(n);break}case"sync-load-batch":{this._syncTable.onSyncLoadBatch(n);break}case"sync-init-finish":{this._syncTable.onSyncInitFinish(n);break}case"sync-update-triples":{this._syncTable.onSyncUpdateTriples(n);break}case"refresh-ok":{const{computations:h,attrs:y}=n,b=n["processed-tx-id"];y&&this._setAttrs(y),this._cleanupPendingMutationsTimeout();const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations(),b);g!==this._pendingMutations()&&this.kv.updateInPlace(T=>{T.pendingMutations=g});const w=Gt(g.entries()),m=h.map(T=>{var qe,se,oe,de;const v=T["instaql-query"],k=T["instaql-result"],A=F(v),R=lr(k),K=this.ensureAttrs(),V=$e(K,R,r,this.config.useDateObjects),{store:ze,attrsStore:ut}=this._applyOptimisticUpdates(V,K,w,b),Yt=(se=(qe=k==null?void 0:k[0])==null?void 0:qe.data)==null?void 0:se["page-info"],Zt=(de=(oe=k==null?void 0:k[0])==null?void 0:oe.data)==null?void 0:de.aggregate;return{q:v,hash:A,store:ze,attrsStore:ut,pageInfo:Yt,aggregate:Zt}});m.forEach(({hash:T,q:v,store:k,attrsStore:A,pageInfo:R,aggregate:K})=>{this.querySubs.updateInPlace(V=>{if(!V[T]){this._log.error("Missing value in querySubs",{hash:T,q:v});return}V[T].result={store:k,attrsStore:A,pageInfo:R,aggregate:K,processedTxId:b}})}),this._cleanupPendingMutationsQueries(),m.forEach(({hash:T})=>{this.notifyOne(T)});break}case"transact-ok":{const{"client-event-id":h,"tx-id":y}=n;this._inFlightMutationEventIds.delete(h);const g=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations()).get(h);if(!g)break;this._updatePendingMutations(m=>{m.set(h,{...m.get(h),"tx-id":y,confirmed:Date.now()})});const w=[];for(const m of g["tx-steps"])if(m[0]==="add-attr"){const T=m[1];w.push(T)}if(w.length){const m=Object.values(this.ensureAttrs().attrs);this._setAttrs([...m,...w])}this._finishTransaction("synced",h),this._cleanupPendingMutationsTimeout();break}case"patch-presence":{const h=n["room-id"];this._trySetRoomConnected(h,!0),this._patchPresencePeers(h,n.edits),this._notifyPresenceSubs(h);break}case"refresh-presence":{const h=n["room-id"];this._trySetRoomConnected(h,!0),this._setPresencePeers(h,n.data),this._notifyPresenceSubs(h);break}case"server-broadcast":{const h=n["room-id"],y=n.topic;this._trySetRoomConnected(h,!0),this._notifyBroadcastSubs(h,y,n);break}case"join-room-ok":{const h=n["room-id"];if(!this._rooms[h]){this._roomsPendingLeave[h]&&(this._tryLeaveRoom(h),delete this._roomsPendingLeave[h]);break}this._trySetRoomConnected(h,!0),this._flushEnqueuedRoomData(h);break}case"leave-room-ok":{const h=n["room-id"];this._trySetRoomConnected(h,!1);break}case"join-room-error":const l=n["room-id"],d=this._rooms[l];d&&(d.error=n.error),this._notifyPresenceSubs(l);break;case"error":this._handleReceiveError(n);break;default:this._log.info("Uknown op",n.op,n);break}}_pendingMutations(){return this.kv.currentValue.pendingMutations??new Map}_updatePendingMutations(e){this.kv.updateInPlace(n=>{const r=n.pendingMutations??new Map;n.pendingMutations=r,e(r)})}_handleMutationError(e,n,r){const s=this._pendingMutations().get(n);if(s&&(e!=="timeout"||!s["tx-id"])){this._updatePendingMutations(o=>(o.delete(n),o)),this._inFlightMutationEventIds.delete(n);const i={message:r.message,hint:r.hint};this.notifyAll(),this.notifyAttrsSubs(),this.notifyMutationErrorSubs(i),this._finishTransaction(e,n,r)}}_handleReceiveError(e){var a,c,u,l,d,h,y;console.log("error",e);const n=e["client-event-id"];this._inFlightMutationEventIds.delete(n);const r=this._pendingMutations().get(n),s={message:e.message||"Uh-oh, something went wrong. Ping Joe & Stopa."};if(e.hint&&(s.hint=e.hint),r){this._handleMutationError("error",n,e);return}if((a=e["original-event"])!=null&&a.hasOwnProperty("q")&&((c=e["original-event"])==null?void 0:c.op)==="add-query"){const b=(u=e["original-event"])==null?void 0:u.q,g=F(b);this.notifyQueryError(F(b),s),this.notifyQueryOnceError(b,g,n,s);return}if(((l=e["original-event"])==null?void 0:l.op)==="init"){if(e.type==="record-not-found"&&((d=e.hint)==null?void 0:d["record-type"])==="app-user"){this.changeCurrentUser(null);return}this._setStatus(le.ERRORED,s),this.notifyAll();return}if(((h=e["original-event"])==null?void 0:h.op)==="resync-table"){this._syncTable.onResyncError(e);return}if(((y=e["original-event"])==null?void 0:y.op)==="start-sync"){this._syncTable.onStartSyncError(e);return}const o={...e};delete o.message,delete o.hint,console.error(e.message,o),e.hint&&console.error(`This error comes with some debugging information. Here it is:
31
31
  `,e.hint)}notifyQueryOnceError(e,n,r,s){var o;const i=(o=this.queryOnceDfds[n])==null?void 0:o.find(a=>a.eventId===r);i&&(i.dfd.reject(s),this._completeQueryOnce(e,n,i.dfd))}_setAttrs(e){this.attrs=new be(e.reduce((n,r)=>(n[r.id]=r,n),{}),this._linkIndex),this.notifyAttrsSubs()}_startQuerySub(e,n){const r=N();return this.querySubs.updateInPlace(s=>{s[n]=s[n]||{q:e,result:null,eventId:r},s[n].lastAccessed=Date.now()}),this._trySendAuthed(r,{op:"add-query",q:e}),r}subscribeTable(e,n){return this._syncTable.subscribe(e,n)}subscribeQuery(e,n,r){this.config.disableValidation||_r(e,this.config.schema),r&&"ruleParams"in r&&(e={$$ruleParams:r.ruleParams,...e});const s=F(e),i=this.getPreviousResult(e);return i&&n(i),this.queryCbs[s]=this.queryCbs[s]??[],this.queryCbs[s].push({q:e,cb:n}),this._startQuerySub(e,s),()=>{this._unsubQuery(e,s,n)}}queryOnce(e,n){this.config.disableValidation||_r(e,this.config.schema),n&&"ruleParams"in n&&(e={$$ruleParams:n.ruleParams,...e});const r=new cr;if(!this._isOnline)return r.reject(new Error("We can't run `queryOnce`, because the device is offline.")),r.promise;if(!this.querySubs)return r.reject(new Error("We can't run `queryOnce` on the backend. Use adminAPI.query instead: https://www.instantdb.com/docs/backend#query")),r.promise;const s=F(e),i=this._startQuerySub(e,s);return this.queryOnceDfds[s]=this.queryOnceDfds[s]??[],this.queryOnceDfds[s].push({q:e,dfd:r,eventId:i}),setTimeout(()=>r.reject(new Error("Query timed out")),na),r.promise}_completeQueryOnce(e,n,r){this.queryOnceDfds[n]&&(this.queryOnceDfds[n]=this.queryOnceDfds[n].filter(s=>s.dfd!==r),this._cleanupQuery(e,n))}_unsubQuery(e,n,r){this.queryCbs[n]&&(this.queryCbs[n]=this.queryCbs[n].filter(s=>s.cb!==r),this._cleanupQuery(e,n))}_hasQueryListeners(e){var n,r;return!!((n=this.queryCbs[e])!=null&&n.length||(r=this.queryOnceDfds[e])!=null&&r.length)}_cleanupQuery(e,n){this._hasQueryListeners(n)||(delete this.queryCbs[n],delete this.queryOnceDfds[n],delete this._dataForQueryCache[n],this.querySubs.unloadKey(n),this._trySendAuthed(N(),{op:"remove-query",q:e}))}_rewriteMutations(e,n,r){if(!e)return n;if(!n)return new Map;const s=l=>{const[d,h,y]=l["forward-identity"];return U(e,h,y)},i=l=>{const[d,h,y]=l["forward-identity"];return _e(e,h,y)},o={attrIdMap:{},refSwapAttrIds:new Set};let a=!1;const c=(l,d)=>{const h=[];for(const y of l){const[b]=y;if(b==="add-attr"){const[w,m]=y,T=s(m);if(T&&m.id!==T.id){o.attrIdMap[m.id]=T.id,a=!0;continue}if(m["value-type"]==="ref"){const v=i(m);if(v){o.attrIdMap[m.id]=v.id,o.refSwapAttrIds.add(m.id),a=!0;continue}}}if(r&&d&&r>=d&&b==="add-attr"||b==="update-attr"||b==="delete-attr"){a=!0;continue}const g=a?Wi(o,y):y;h.push(g)}return a?h:l},u=new Map;for(const[l,d]of n.entries())u.set(l,{...d,"tx-steps":c(d["tx-steps"],d["tx-id"])});return a?u:n}_rewriteMutationsSorted(e,n){return Gt(this._rewriteMutations(e,n).entries())}optimisticAttrs(){var i,o;const e=[...this._pendingMutations().values()].flatMap(a=>a["tx-steps"]),n=new Set(e.filter(([a,c])=>a==="delete-attr").map(([a,c])=>c)),r=[];for(const[a,c]of e)if(a==="add-attr")r.push(c);else if(a==="update-attr"&&c.id&&((i=this.attrs)!=null&&i.getAttr(c.id))){const u={...this.attrs.getAttr(c.id),...c};r.push(u)}if(!n.size&&!r.length)return this.attrs||new be({},this._linkIndex);const s={...((o=this.attrs)==null?void 0:o.attrs)||{}};for(const a of r)s[a.id]=a;for(const a of n)delete s[a];return new be(s,this._linkIndex)}dataForQuery(e,n=!0){const r=this._errorMessage;if(r)return{error:r};if(!this.querySubs||!this.kv.currentValue.pendingMutations)return;const s=this.querySubs.version(),i=this.querySubs.currentValue,o=this.kv.version(),a=this._pendingMutations(),{q:c,result:u}=i[e]||{};if(!u)return;const l=this._dataForQueryCache[e];if(l&&s===l.querySubVersion&&o===l.pendingMutationsVersion)return l;let d=u.store,h=u.attrsStore;const{pageInfo:y,aggregate:b,processedTxId:g}=u,w=this._rewriteMutationsSorted(h,a);if(n){const T=this._applyOptimisticUpdates(d,h,w,g);d=T.store,h=T.attrsStore}return{data:Hn({store:d,attrsStore:h,pageInfo:y,aggregate:b},c),querySubVersion:s,pendingMutationsVersion:o}}_applyOptimisticUpdates(e,n,r,s){for(const[i,o]of r)if(!o["tx-id"]||s&&o["tx-id"]>s){const a=Qs(e,n,o["tx-steps"]);e=a.store,n=a.attrsStore}return{store:e,attrsStore:n}}notifyAll(){Object.keys(this.queryCbs).forEach(e=>{this.querySubs.waitForKeyToLoad(e).then(()=>this.notifyOne(e)).catch(()=>this.notifyOne(e))})}loadedNotifyAll(){this.kv.waitForKeyToLoad("pendingMutations").then(()=>this.notifyAll()).catch(()=>this.notifyAll())}shutdown(){var e;this._log.info("[shutdown]",this.config.appId),this._isShutdown=!0,(e=this._transport)==null||e.close()}_sendMutation(e,n){if(n.error){this._handleMutationError("error",e,{message:n.error.message});return}if(this.status!==le.AUTHENTICATED){this._finishTransaction("enqueued",e);return}const r=Math.max(6e3,Math.min(this._inFlightMutationEventIds.size+1,this._pendingMutations().size+1)*6e3);this._isOnline?(this._trySend(e,n),setTimeout(()=>{this._isOnline&&this._handleMutationError("timeout",e,{message:"transaction timed out"})},r)):this._finishTransaction("enqueued",e)}_flushPendingMessages(){Object.keys(this.queryCbs).map(i=>this.querySubs.currentValue[i]).filter(i=>i).forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})}),Object.values(this.queryOnceDfds).flat().forEach(({eventId:i,q:o})=>{this._trySendAuthed(i,{op:"add-query",q:o})});const r=this._rewriteMutations(this.ensureAttrs(),this._pendingMutations());r!==this._pendingMutations()&&this.kv.updateInPlace(i=>{i.pendingMutations=r}),Gt(r.entries()).forEach(([i,o])=>{o["tx-id"]||this._sendMutation(i,o)}),this._syncTable.flushPending()}_cleanupPendingMutationsQueries(){let e=Number.MAX_SAFE_INTEGER;for(const{result:n}of Object.values(this.querySubs.currentValue))n!=null&&n.processedTxId&&(e=Math.min(e,n==null?void 0:n.processedTxId));this._updatePendingMutations(n=>{for(const[r,s]of Array.from(n.entries()))s["tx-id"]&&s["tx-id"]<=e&&n.delete(r)})}_cleanupPendingMutationsTimeout(){if(this._pendingMutations().size<this._pendingMutationCleanupThreshold)return;const e=Date.now();this._updatePendingMutations(n=>{for(const[r,s]of Array.from(n.entries()))s.confirmed&&s.confirmed+this._pendingTxCleanupTimeout<e&&n.delete(r)})}_trySendAuthed(...e){this.status===le.AUTHENTICATED&&this._trySend(...e)}_trySend(e,n,r){if(this._transport.isOpen()){switch(Or[n.op]||this._log.info("[send]",this._transport.id,n.op,n),n.op){case"transact":{this._inFlightMutationEventIds.add(e);break}case"init":this._inFlightMutationEventIds.clear()}this._transport.send({"client-event-id":e,...n})}}_startSocket(){if(this._wsOk=null,this._isShutdown){this._log.info("[socket][start]",this.config.appId,"Reactor has been shut down and will not start a new socket");return}if(this._transport&&this._transport.isConnecting()){this._log.info("[socket][start]",this._transport.id,"maintained as current transport, we were still in a connecting state");return}const e=this._transport;this._transport=aa({transportType:this._transportType,appId:this.config.appId,apiURI:this.config.apiURI,wsURI:this.config.websocketURI,EventSourceImpl:this._EventSource}),this._transport.onopen=this._transportOnOpen,this._transport.onmessage=this._transportOnMessage,this._transport.onclose=this._transportOnClose,this._transport.onerror=this._transportOnError,this._log.info("[socket][start]",this._transport.id),e!=null&&e.isOpen()&&(this._log.info("[socket][start]",this._transport.id,"close previous transport id = ",e.id),e.close())}async getLocalId(e){const n=`localToken_${e}`;if(this.kv.currentValue[n])return this.kv.currentValue[n];const r=await this.kv.waitForKeyToLoad(n);if(r)return r;const s=N();return this.kv.updateInPlace(i=>{i[n]||(i[n]=s)}),await this.kv.waitForKeyToLoad(n)}_replaceUrlAfterOAuth(){if(typeof URL>"u")return;const e=new URL(window.location.href);if(e.searchParams.get(Bt)){const n=e.toString();e.searchParams.delete(Bt),e.searchParams.delete("code"),e.searchParams.delete("error");const r=e.pathname+(e.searchParams.size?"?"+e.searchParams:"")+e.hash;if(history.replaceState(history.state,"",r),typeof navigation=="object"&&typeof navigation.addEventListener=="function"&&typeof navigation.removeEventListener=="function"){let s=!1;const i=o=>{var a;s||(s=!0,navigation.removeEventListener("navigate",i),!o.userInitiated&&o.navigationType==="replace"&&((a=o.destination)==null?void 0:a.url)===n&&history.replaceState(history.state,"",r))};navigation.addEventListener("navigate",i)}}}async _oauthLoginInit(){var s,i,o,a;if(typeof window>"u"||typeof window.location>"u"||typeof URLSearchParams>"u")return null;const e=new URLSearchParams(window.location.search);if(!e.get(Bt))return null;const n=e.get("error");if(n)return this._replaceUrlAfterOAuth(),{error:{message:n}};const r=e.get("code");if(!r)return null;this._replaceUrlAfterOAuth();try{const c=await this._getCurrentUser(),u=(c==null?void 0:c.type)==="guest",{user:l}=await sr({apiURI:this.config.apiURI,appId:this.config.appId,code:r,refreshToken:u?c.refresh_token:void 0});return this.setCurrentUser(l),null}catch(c){return((s=c==null?void 0:c.body)==null?void 0:s.type)==="record-not-found"&&((o=(i=c==null?void 0:c.body)==null?void 0:i.hint)==null?void 0:o["record-type"])==="app-oauth-code"&&await this._hasCurrentUser()?null:{error:{message:((a=c==null?void 0:c.body)==null?void 0:a.message)||"Error logging in."}}}}async _waitForOAuthCallbackResponse(){return await this._oauthCallbackResponse}__subscribeMutationErrors(e){return this.mutationErrorCbs.push(e),()=>{this.mutationErrorCbs=this.mutationErrorCbs.filter(n=>n!==e)}}subscribeAuth(e){this.authCbs.push(e);const n=this._currentUserCached;n.isLoading||e(this._currentUserCached);let r=!1;return this.getCurrentUser().then(s=>{r||Ye(s,n)||e(s)}),()=>{r=!0,this.authCbs=this.authCbs.filter(s=>s!==e)}}async getAuth(){const{user:e,error:n}=await this.getCurrentUser();if(n)throw new Ee("Could not get current user: "+n.message);return e}subscribeConnectionStatus(e){return this.connectionStatusCbs.push(e),()=>{this.connectionStatusCbs=this.connectionStatusCbs.filter(n=>n!==e)}}subscribeAttrs(e){return this.attrsCbs.push(e),this.attrs&&e(this.attrs.attrs),()=>{this.attrsCbs=this.attrsCbs.filter(n=>n!==e)}}notifyAuthSubs(e){this.authCbs.forEach(n=>n(e))}notifyMutationErrorSubs(e){this.mutationErrorCbs.forEach(n=>n(e))}notifyAttrsSubs(){if(!this.attrs)return;const e=this.optimisticAttrs();this.attrsCbs.forEach(n=>n(e.attrs))}notifyConnectionStatusSubs(e){this.connectionStatusCbs.forEach(n=>n(e))}async setCurrentUser(e){this.kv.updateInPlace(n=>{n[Ke]=e}),await this.kv.waitForKeyToLoad(Ke)}getCurrentUserCached(){return this._currentUserCached}async _getCurrentUser(){const e=await this.kv.waitForKeyToLoad(Ke);return typeof e=="string"?JSON.parse(e):e}async getCurrentUser(){const e=await this._waitForOAuthCallbackResponse();if(e!=null&&e.error){const n={error:e.error,user:void 0};return this._currentUserCached={isLoading:!1,...n},n}try{const r={user:await this._getCurrentUser(),error:void 0};return this._currentUserCached={isLoading:!1,...r},r}catch(n){return{user:void 0,isLoading:!1,error:{message:(n==null?void 0:n.message)||"Error loading user"}}}}async _hasCurrentUser(){const e=await this.kv.waitForKeyToLoad(Ke);return typeof e=="string"?JSON.parse(e)!=null:e!=null}async changeCurrentUser(e){var r;const{user:n}=await this.getCurrentUser();if(!Ye(n,e)){await this.setCurrentUser(e),this.updateUser(e);try{(r=this._broadcastChannel)==null||r.postMessage({type:"auth"})}catch(s){console.error("Error posting message to broadcast channel",s)}}}async syncUserToEndpoint(e){if(this.config.firstPartyPath)try{fetch(this.config.firstPartyPath+"/",{method:"POST",body:JSON.stringify({type:"sync-user",appId:this.config.appId,user:e}),headers:{"Content-Type":"application/json"}})}catch(n){this._log.error("Error syncing user with external endpoint",n)}}updateUser(e){this.syncUserToEndpoint(e);const n={error:void 0,user:e};this._currentUserCached={isLoading:!1,...n},this._dataForQueryCache={},this.querySubs.updateInPlace(r=>{Object.keys(r).forEach(s=>{delete r[s].result})}),this._reconnectTimeoutMs=0,this._transport.close(),this._oauthCallbackResponse=null,this.notifyAuthSubs(n)}sendMagicCode({email:e}){return Eo({apiURI:this.config.apiURI,appId:this.config.appId,email:e})}async signInWithMagicCode({email:e,code:n}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await Oo({apiURI:this.config.apiURI,appId:this.config.appId,email:e,code:n,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}async signInWithCustomToken(e){const n=await ko({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:e});return await this.changeCurrentUser(n.user),n}async signInAsGuest(){const e=await Po({apiURI:this.config.apiURI,appId:this.config.appId});return await this.changeCurrentUser(e.user),e}potentiallyInvalidateToken(e,n){var i;const r=(i=e==null?void 0:e.user)==null?void 0:i.refresh_token;if(!r)return;if(n.invalidateToken===!1){this._log.info("[auth-invalidate] skipped invalidateToken");return}Io({apiURI:this.config.apiURI,appId:this.config.appId,refreshToken:r}).then(()=>{this._log.info("[auth-invalidate] completed invalidateToken")}).catch(o=>{})}async signOut(e){const n=await this.getCurrentUser();this.potentiallyInvalidateToken(n,e),await this.changeCurrentUser(null)}createAuthorizationURL({clientName:e,redirectURL:n}){const{apiURI:r,appId:s}=this.config;return`${r}/runtime/oauth/start?app_id=${s}&client_name=${e}&redirect_uri=${n}`}async exchangeCodeForToken({code:e,codeVerifier:n}){var o;const r=await this.getCurrentUser(),s=((o=r==null?void 0:r.user)==null?void 0:o.type)==="guest",i=await sr({apiURI:this.config.apiURI,appId:this.config.appId,code:e,codeVerifier:n,refreshToken:s?r.user.refresh_token:void 0});return await this.changeCurrentUser(i.user),i}issuerURI(){const{apiURI:e,appId:n}=this.config;return`${e}/runtime/${n}`}async signInWithIdToken({idToken:e,clientName:n,nonce:r}){var a;const s=await this.getCurrentUser(),i=(a=s==null?void 0:s.user)==null?void 0:a.refresh_token,o=await Co({apiURI:this.config.apiURI,appId:this.config.appId,idToken:e,clientName:n,nonce:r,refreshToken:i});return await this.changeCurrentUser(o.user),o}joinRoom(e,n){let r=!1;this._rooms[e]||(r=!0,this._rooms[e]={isConnected:!1,error:void 0}),this._presence[e]=this._presence[e]||{};const s=this._presence[e].result;return n&&!s&&(this._presence[e].result=this._presence[e].result||{},this._presence[e].result.user=n,this._notifyPresenceSubs(e)),r&&this._tryJoinRoom(e,n),()=>{this._cleanupRoom(e)}}_cleanupRoom(e){var n,r,s;if(!((r=(n=this._presence[e])==null?void 0:n.handlers)!=null&&r.length)&&!Object.keys(this._broadcastSubs[e]??{}).length){const i=(s=this._rooms[e])==null?void 0:s.isConnected;delete this._rooms[e],delete this._presence[e],delete this._broadcastSubs[e],i?this._tryLeaveRoom(e):this._roomsPendingLeave[e]=!0}}getPresence(e,n,r={}){const s=this._rooms[n],i=this._presence[n];return!s||!i||!i.result?null:{...$o(i.result,r,this._sessionId),isLoading:!s.isConnected,error:s.error}}publishPresence(e,n,r){const s=this._rooms[n],i=this._presence[n];if(!s||!i)return;i.result=i.result||{};const o={...i.result.user,...r};i.result.user=o,s.isConnected&&(this._trySetPresence(n,o),this._notifyPresenceSubs(n))}_trySetPresence(e,n){this._trySendAuthed(N(),{op:"set-presence","room-id":e,data:n})}_tryJoinRoom(e,n){this._trySendAuthed(N(),{op:"join-room","room-id":e,data:n}),delete this._roomsPendingLeave[e]}_tryLeaveRoom(e){this._trySendAuthed(N(),{op:"leave-room","room-id":e})}_trySetRoomConnected(e,n){const r=this._rooms[e];r&&(r.isConnected=n)}subscribePresence(e,n,r,s){const i=this.joinRoom(n,r.initialPresence||r.initialData),o={...r,roomId:n,cb:s,prev:null};return this._presence[n]=this._presence[n]||{},this._presence[n].handlers=this._presence[n].handlers||[],this._presence[n].handlers.push(o),this._notifyPresenceSub(n,o),()=>{var a,c;this._presence[n].handlers=((c=(a=this._presence[n])==null?void 0:a.handlers)==null?void 0:c.filter(u=>u!==o))??[],i()}}_notifyPresenceSubs(e){var n,r;(r=(n=this._presence[e])==null?void 0:n.handlers)==null||r.forEach(s=>{this._notifyPresenceSub(e,s)})}_notifyPresenceSub(e,n){const r=this.getPresence("",e,n);r&&(n.prev&&!Uo(r,n.prev)||(n.prev=r,n.cb(r)))}_patchPresencePeers(e,n){var o,a,c;const r=((a=(o=this._presence[e])==null?void 0:o.result)==null?void 0:a.peers)||{};let s=Object.fromEntries(Object.entries(r).map(([u,l])=>[u,{data:l}]));(c=this._presence[e])==null||c.result;const i=Je(s,u=>{for(let[l,d,h]of n)switch(d){case"+":ps(u,l,h);break;case"r":An(u,l,h);break;case"-":En(u,l);break}delete u[this._sessionId]});this._setPresencePeers(e,i)}_setPresencePeers(e,n){const r={...n};delete r[this._sessionId];const s=Object.fromEntries(Object.entries(r).map(([i,o])=>[i,o.data]));this._presence=Je(this._presence,i=>{An(i,[e,"result","peers"],s)})}publishTopic({roomType:e,roomId:n,topic:r,data:s}){const i=this._rooms[n];if(i){if(!i.isConnected){this._broadcastQueue[n]=this._broadcastQueue[n]??[],this._broadcastQueue[n].push({topic:r,roomType:e,data:s});return}this._tryBroadcast(n,e,r,s)}}_tryBroadcast(e,n,r,s){this._trySendAuthed(N(),{op:"client-broadcast","room-id":e,roomType:n,topic:r,data:s})}subscribeTopic(e,n,r){const s=this.joinRoom(e);return this._broadcastSubs[e]=this._broadcastSubs[e]||{},this._broadcastSubs[e][n]=this._broadcastSubs[e][n]||[],this._broadcastSubs[e][n].push(r),this._presence[e]=this._presence[e]||{},()=>{this._broadcastSubs[e][n]=this._broadcastSubs[e][n].filter(i=>i!==r),this._broadcastSubs[e][n].length||delete this._broadcastSubs[e][n],s()}}_notifyBroadcastSubs(e,n,r){var s,i,o;(o=(i=(s=this._broadcastSubs)==null?void 0:s[e])==null?void 0:i[n])==null||o.forEach(a=>{var l,d,h,y,b,g;const c=(l=r.data)==null?void 0:l.data,u=r.data["peer-id"]===this._sessionId?(h=(d=this._presence[e])==null?void 0:d.result)==null?void 0:h.user:(g=(b=(y=this._presence[e])==null?void 0:y.result)==null?void 0:b.peers)==null?void 0:g[r.data["peer-id"]];return a(c,u)})}async uploadFile(e,n,r){var o;const s=await this.getCurrentUser(),i=(o=s==null?void 0:s.user)==null?void 0:o.refresh_token;return Mo({...r,apiURI:this.config.apiURI,appId:this.config.appId,path:e,file:n,refreshToken:i})}async deleteFile(e){var i;const n=await this.getCurrentUser(),r=(i=n==null?void 0:n.user)==null?void 0:i.refresh_token;return await jo({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}async upload(e,n){var c;const r=await this.getCurrentUser(),s=(c=r==null?void 0:r.user)==null?void 0:c.refresh_token,i=e||n.name,o=await Ro({apiURI:this.config.apiURI,appId:this.config.appId,fileName:i,refreshToken:s});return await Do(o,n)}async getDownloadUrl(e){var i;const n=await this.getCurrentUser(),r=(i=n==null?void 0:n.user)==null?void 0:i.refresh_token;return await xo({apiURI:this.config.apiURI,appId:this.config.appId,path:e,refreshToken:r})}}let at;function ya(t,e){at==null||at.dispose();const n=ma(e),r=ga(e,a),s=_a(ba(t));function i(l){var d;l.source===s.element.contentWindow&&((d=l.data)==null?void 0:d.type)==="close"&&n.isVisible()&&a()}function o(l){const d=l.shiftKey&&l.ctrlKey&&l.key==="0",h=l.key==="Escape"||l.key==="Esc";(d||h&&n.isVisible())&&a()}function a(){n.isVisible()?n.element.style.display="none":(n.element.style.display="block",n.element.contains(s.element)||n.element.appendChild(s.element))}function c(){n.element.remove(),r.element.remove(),removeEventListener("keydown",o),removeEventListener("message",i)}function u(){document.body.appendChild(n.element),document.body.appendChild(r.element),addEventListener("keydown",o),addEventListener("message",i),at={dispose:c}}return u()}function ba(t){return`${qt||or?"http://localhost:3000":"https://instantdb.com"}/_devtool?appId=${t}`}function _a(t){const e=document.createElement("iframe");return e.src=t,e.className="instant-devtool-iframe",Object.assign(e.style,{width:"100%",height:"100%",backgroundColor:"white",border:"none"}),{element:e}}function ga(t,e){const n=`
32
32
  <svg width="32" height="32" viewBox="0 0 512 512" fill="none" xmlns="http://www.w3.org/2000/svg">
33
33
  <rect width="512" height="512" fill="black"/>
34
34
  <rect x="97.0973" y="91.3297" width="140" height="330" fill="white"/>
35
35
  </svg>
36
- `,r=document.createElement("button");return r.innerHTML=n,r.className="instant-devtool-toggler",Object.assign(r.style,{position:"fixed",...Ta(t.position),height:"32px",width:"32px",display:"flex",alignItems:"center",justifyContent:"center",zIndex:"9010",padding:"0",margin:"0",border:"none",cursor:"pointer"}),r.addEventListener("click",e),{element:r}}function Ta(t){switch(t){case"bottom-left":return{bottom:"24px",left:"24px"};case"bottom-right":return{bottom:"24px",right:"24px"};case"top-right":return{top:"24px",right:"24px"};case"top-left":return{top:"24px",left:"24px"}}}function wa(t){switch(t){case"bottom-left":return{bottom:"24px",right:"24px",left:"60px",top:"72px"};case"bottom-right":return{bottom:"24px",left:"24px",right:"60px",top:"72px"};case"top-right":return{top:"24px",left:"24px",right:"60px",bottom:"72px"};case"top-left":return{top:"24px",right:"24px",left:"60px",bottom:"72px"}}}function ma(t){const e=document.createElement("div");Object.assign(e.style,{position:"fixed",...wa(t.position),display:"block",borderRadius:"4px",border:"1px #ccc solid",boxShadow:"0px 0px 8px #00000044",backgroundColor:"#eee",zIndex:"999990"}),e.style.display="none",e.className="instant-devtool-container";function n(){return e.style.display!=="none"}return{element:e,isVisible:n}}const Sa={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"};function va(){return globalThis.__instantDbSchemaHashStore=globalThis.__instantDbSchemaHashStore??new WeakMap,globalThis.__instantDbSchemaHashStore}function Aa(){return globalThis.__instantDbStore=globalThis.__instantDbStore??{},globalThis.__instantDbStore}function Ht(t){const e=t.__adminToken;return t.appId+"_"+(t.websocketURI||"default_ws_uri")+"_"+(t.apiURI||"default_api_uri")+"_"+(e||"client_only")+"_"+t.useDateObjects}const Jt=Aa(),kr=va();class Ea{constructor(e){p(this,"db");p(this,"sendMagicCode",e=>this.db.sendMagicCode(e));p(this,"signInWithMagicCode",e=>this.db.signInWithMagicCode(e));p(this,"signInWithToken",e=>this.db.signInWithCustomToken(e));p(this,"signInAsGuest",()=>this.db.signInAsGuest());p(this,"createAuthorizationURL",e=>this.db.createAuthorizationURL(e));p(this,"signInWithIdToken",e=>this.db.signInWithIdToken(e));p(this,"exchangeOAuthCode",e=>this.db.exchangeCodeForToken(e));p(this,"issuerURI",()=>this.db.issuerURI());p(this,"signOut",(e={invalidateToken:!0})=>this.db.signOut(e));this.db=e}}class Oa{constructor(e){p(this,"db");p(this,"uploadFile",(e,n,r={})=>this.db.uploadFile(e,n,r));p(this,"delete",e=>this.db.deleteFile(e));p(this,"upload",(e,n)=>this.db.upload(e,n));p(this,"put",this.upload);p(this,"getDownloadUrl",e=>this.db.getDownloadUrl(e));this.db=e}}function ka(t){return JSON.parse(JSON.stringify(t))}class Pa{constructor(e){p(this,"_reactor");p(this,"auth");p(this,"storage");p(this,"tx",Lt());this._reactor=e,this.auth=new Ea(this._reactor),this.storage=new Oa(this._reactor)}transact(e){return this._reactor.pushTx(e)}getLocalId(e){return this._reactor.getLocalId(e)}subscribeQuery(e,n,r){return this._reactor.subscribeQuery(e,n,r)}subscribeAuth(e){return this._reactor.subscribeAuth(e)}getAuth(){return this._reactor.getAuth()}subscribeConnectionStatus(e){return this._reactor.subscribeConnectionStatus(e)}joinRoom(e="_defaultRoomType",n="_defaultRoomId",r){return{leaveRoom:this._reactor.joinRoom(n,r==null?void 0:r.initialPresence),subscribeTopic:(i,o)=>this._reactor.subscribeTopic(n,i,o),subscribePresence:(i,o)=>this._reactor.subscribePresence(e,n,i,o),publishTopic:(i,o)=>this._reactor.publishTopic({roomType:e,roomId:n,topic:i,data:o}),publishPresence:i=>this._reactor.publishPresence(e,n,i),getPresence:i=>this._reactor.getPresence(e,n,i)}}shutdown(){delete Jt[Ht(this._reactor.config)],this._reactor.shutdown()}queryOnce(e,n){return this._reactor.queryOnce(e,n)}_syncTableExperimental(e,n){return this._reactor.subscribeTable(e,n)}}function Pr(t){if(!t)return"0";const e=kr.get(t);if(e)return e;const n=F(t);return kr.set(t,n),n}function Ca(t,e){return Pr(t._reactor.config.schema)!==Pr(e)}function Ia(t,e,n,r,s){var u;const i={...t,appId:(u=t.appId)==null?void 0:u.trim(),useDateObjects:t.useDateObjects??!1},o=Jt[Ht(i)];if(o)return Ca(o,i.schema)&&o._reactor.updateSchema(i.schema),o;const a=new pa({...Sa,...i,cardinalityInference:!!i.schema},e||nr,n||rr,{...r||{},"@instantdb/core":dr},s),c=new Pa(a);return Jt[Ht(i)]=c,Ma(i.appId,i.devtool),c}function Ma(t,e){if(typeof window>"u"||typeof window.location>"u"||typeof document>"u"||typeof e=="boolean"&&!e)return;const n={position:"bottom-right",allowedHosts:["localhost"],...typeof e=="object"?e:{}};n.allowedHosts.includes(window.location.hostname)&&ya(t,n)}const ja={isLoading:!0,data:void 0,pageInfo:void 0,error:void 0};function Cr(t){return{isLoading:!t,data:void 0,pageInfo:void 0,error:void 0,...t||{}}}function Ra(t,e,n){e&&n&&"ruleParams"in n&&(e={$$ruleParams:n.ruleParams,...e});const r=e?ka(e):null,s=F(r),i=O.useRef(Cr(t._reactor.getPreviousResult(r))),o=O.useCallback(c=>(i.current=Cr(t._reactor.getPreviousResult(r)),c(),r?t.subscribeQuery(r,l=>{i.current={isLoading:!l,data:void 0,pageInfo:void 0,error:void 0,...l},c()}):()=>{}),[s]);return{state:O.useSyncExternalStore(o,()=>i.current,()=>ja),query:r}}function Da(){const t=O.useRef(null);O.useEffect(()=>{n()},[]);function e(r,s){n(),t.current=setTimeout(s,r)}function n(){t.current&&clearTimeout(t.current)}return{set:e,clear:n}}const xa=1e3;function $a(t,e,n){const r=O.useRef(n);r.current=n,O.useEffect(()=>t.core._reactor.subscribeTopic(t.id,e,(i,o)=>{r.current(i,o)}),[t.id,e])}function Ua(t,e){return O.useEffect(()=>t.core._reactor.joinRoom(t.id),[t.id]),O.useCallback(r=>{t.core._reactor.publishTopic({roomType:t.type,roomId:t.id,topic:e,data:r})},[t.id,e])}function La(t,e={}){var o,a;const[n,r]=O.useState(()=>t.core._reactor.getPresence(t.type,t.id,e)??{peers:{},isLoading:!0});O.useEffect(()=>t.core._reactor.subscribePresence(t.type,t.id,e,u=>{r(u)}),[t.id,e.user,(o=e.peers)==null?void 0:o.join(),(a=e.keys)==null?void 0:a.join()]);const s=O.useCallback(c=>{t.core._reactor.publishPresence(t.type,t.id,c)},[t.type,t.id]);return O.useMemo(()=>({...n,publishPresence:s}),[n,s])}function Fa(t,e,n){O.useEffect(()=>t.core._reactor.joinRoom(t.id,e),[t.id]),O.useEffect(()=>t.core._reactor.publishPresence(t.type,t.id,e),[t.type,t.id,n??JSON.stringify(e)])}function Na(t,e,n={}){const r=Da(),s=Te.usePresence(t,{keys:[e]}),i=O.useMemo(()=>{const l=t._core._reactor.getPresence(t.type,t.id);return n!=null&&n.writeOnly?[]:Object.values((l==null?void 0:l.peers)??{}).filter(d=>d[e]===!0)},[n==null?void 0:n.writeOnly,s]),o=O.useCallback(l=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:l}),l&&((n==null?void 0:n.timeout)===null||(n==null?void 0:n.timeout)===0||r.set((n==null?void 0:n.timeout)??xa,()=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:null})}))},[t.type,t.id,e,n==null?void 0:n.timeout,r]),a=O.useCallback(l=>{const h=!((n==null?void 0:n.stopOnEnter)&&l.key==="Enter");o(h)},[n.stopOnEnter,o]),c=O.useCallback(()=>{o(!1)},[o]),u=O.useMemo(()=>({onKeyDown:a,onBlur:c}),[a,c]);return{active:i,setActive:o,inputProps:u}}const Te={useTopicEffect:$a,usePublishTopic:Ua,usePresence:La,useSyncPresence:Fa,useTypingIndicator:Na};class Ka{constructor(e,n,r){p(this,"core");p(this,"_core");p(this,"type");p(this,"id");p(this,"useTopicEffect",(e,n)=>{Te.useTopicEffect(this,e,n)});p(this,"usePublishTopic",e=>Te.usePublishTopic(this,e));p(this,"usePresence",(e={})=>Te.usePresence(this,e));p(this,"useSyncPresence",(e,n)=>Te.useSyncPresence(this,e,n));p(this,"useTypingIndicator",(e,n={})=>Te.useTypingIndicator(this,e,n));this.core=e,this._core=this.core,this.type=n,this.id=r}}const za={isLoading:!0,user:void 0,error:void 0};class ct{constructor(e,n){p(this,"tx",Lt());p(this,"auth");p(this,"storage");p(this,"core");p(this,"_core");p(this,"getLocalId",e=>this.core.getLocalId(e));p(this,"useLocalId",e=>{const[n,r]=O.useState(null);return O.useEffect(()=>{(async()=>{const i=await this.getLocalId(e);r(i)})()},[e]),n});p(this,"rooms",Te);p(this,"transact",e=>this.core.transact(e));p(this,"useQuery",(e,n)=>Ra(this.core,e,n).state);p(this,"useAuth",()=>this._useAuth());p(this,"useUser",()=>{const{user:e}=this.useAuth();if(!e)throw new Ee("useUser must be used within an auth-protected route");return e});p(this,"useConnectionStatus",()=>{const e=O.useRef(this.core._reactor.status),n=O.useCallback(s=>this.core.subscribeConnectionStatus(o=>{o!==e.current&&(e.current=o,s())}),[]);return O.useSyncExternalStore(n,()=>e.current,()=>"connecting")});p(this,"queryOnce",(e,n)=>this.core.queryOnce(e,n));p(this,"SignedIn",({children:e})=>{const n=this.useAuth();return n.isLoading||n.error||!n.user?null:We.jsx(We.Fragment,{children:e})});p(this,"SignedOut",({children:e})=>{const n=this.useAuth();return n.isLoading||n.error||n.user?null:We.jsx(We.Fragment,{children:e})});this.core=Ia(e,this.constructor.Storage,this.constructor.NetworkListener,n,this.constructor.EventSourceImpl),this._core=this.core,this.auth=this.core.auth,this.storage=this.core.storage}room(e="_defaultRoomType",n="_defaultRoomId"){return new Ka(this.core,e,n)}_useAuth(){const e=O.useRef(this.core._reactor._currentUserCached),n=O.useCallback(s=>this.core.subscribeAuth(o=>{e.current={isLoading:!1,...o},s()}),[]);return O.useSyncExternalStore(n,()=>e.current,()=>za)}getAuth(){return this.core.getAuth()}}p(ct,"Storage"),p(ct,"NetworkListener"),p(ct,"EventSourceImpl"),J.InstantReactAbstractDatabase=ct,Object.defineProperty(J,Symbol.toStringTag,{value:"Module"})});
36
+ `,r=document.createElement("button");return r.innerHTML=n,r.className="instant-devtool-toggler",Object.assign(r.style,{position:"fixed",...Ta(t.position),height:"32px",width:"32px",display:"flex",alignItems:"center",justifyContent:"center",zIndex:"9010",padding:"0",margin:"0",border:"none",cursor:"pointer"}),r.addEventListener("click",e),{element:r}}function Ta(t){switch(t){case"bottom-left":return{bottom:"24px",left:"24px"};case"bottom-right":return{bottom:"24px",right:"24px"};case"top-right":return{top:"24px",right:"24px"};case"top-left":return{top:"24px",left:"24px"}}}function wa(t){switch(t){case"bottom-left":return{bottom:"24px",right:"24px",left:"60px",top:"72px"};case"bottom-right":return{bottom:"24px",left:"24px",right:"60px",top:"72px"};case"top-right":return{top:"24px",left:"24px",right:"60px",bottom:"72px"};case"top-left":return{top:"24px",right:"24px",left:"60px",bottom:"72px"}}}function ma(t){const e=document.createElement("div");Object.assign(e.style,{position:"fixed",...wa(t.position),display:"block",borderRadius:"4px",border:"1px #ccc solid",boxShadow:"0px 0px 8px #00000044",backgroundColor:"#eee",zIndex:"999990"}),e.style.display="none",e.className="instant-devtool-container";function n(){return e.style.display!=="none"}return{element:e,isVisible:n}}const Sa={apiURI:"https://api.instantdb.com",websocketURI:"wss://api.instantdb.com/runtime/session"};function va(){return globalThis.__instantDbSchemaHashStore=globalThis.__instantDbSchemaHashStore??new WeakMap,globalThis.__instantDbSchemaHashStore}function Aa(){return globalThis.__instantDbStore=globalThis.__instantDbStore??{},globalThis.__instantDbStore}function Ht(t){const e=t.__adminToken;return t.appId+"_"+(t.websocketURI||"default_ws_uri")+"_"+(t.apiURI||"default_api_uri")+"_"+(e||"client_only")+"_"+t.useDateObjects}const Jt=Aa(),kr=va();class Ea{constructor(e){p(this,"db");p(this,"sendMagicCode",e=>this.db.sendMagicCode(e));p(this,"signInWithMagicCode",e=>this.db.signInWithMagicCode(e));p(this,"signInWithToken",e=>this.db.signInWithCustomToken(e));p(this,"signInAsGuest",()=>this.db.signInAsGuest());p(this,"createAuthorizationURL",e=>this.db.createAuthorizationURL(e));p(this,"signInWithIdToken",e=>this.db.signInWithIdToken(e));p(this,"exchangeOAuthCode",e=>this.db.exchangeCodeForToken(e));p(this,"issuerURI",()=>this.db.issuerURI());p(this,"signOut",(e={invalidateToken:!0})=>this.db.signOut(e));this.db=e}}class Oa{constructor(e){p(this,"db");p(this,"uploadFile",(e,n,r={})=>this.db.uploadFile(e,n,r));p(this,"delete",e=>this.db.deleteFile(e));p(this,"upload",(e,n)=>this.db.upload(e,n));p(this,"put",this.upload);p(this,"getDownloadUrl",e=>this.db.getDownloadUrl(e));this.db=e}}function ka(t){return JSON.parse(JSON.stringify(t))}class Pa{constructor(e){p(this,"_reactor");p(this,"auth");p(this,"storage");p(this,"tx",Lt());this._reactor=e,this.auth=new Ea(this._reactor),this.storage=new Oa(this._reactor)}transact(e){return this._reactor.pushTx(e)}getLocalId(e){return this._reactor.getLocalId(e)}subscribeQuery(e,n,r){return this._reactor.subscribeQuery(e,n,r)}subscribeAuth(e){return this._reactor.subscribeAuth(e)}getAuth(){return this._reactor.getAuth()}subscribeConnectionStatus(e){return this._reactor.subscribeConnectionStatus(e)}joinRoom(e="_defaultRoomType",n="_defaultRoomId",r){return{leaveRoom:this._reactor.joinRoom(n,r==null?void 0:r.initialPresence),subscribeTopic:(i,o)=>this._reactor.subscribeTopic(n,i,o),subscribePresence:(i,o)=>this._reactor.subscribePresence(e,n,i,o),publishTopic:(i,o)=>this._reactor.publishTopic({roomType:e,roomId:n,topic:i,data:o}),publishPresence:i=>this._reactor.publishPresence(e,n,i),getPresence:i=>this._reactor.getPresence(e,n,i)}}shutdown(){delete Jt[Ht(this._reactor.config)],this._reactor.shutdown()}queryOnce(e,n){return this._reactor.queryOnce(e,n)}_syncTableExperimental(e,n){return this._reactor.subscribeTable(e,n)}}function Pr(t){if(!t)return"0";const e=kr.get(t);if(e)return e;const n=F(t);return kr.set(t,n),n}function Ca(t,e){return Pr(t._reactor.config.schema)!==Pr(e)}function Ia(t,e,n,r,s){var u;const i={...t,appId:(u=t.appId)==null?void 0:u.trim(),useDateObjects:t.useDateObjects??!1},o=Jt[Ht(i)];if(o)return Ca(o,i.schema)&&o._reactor.updateSchema(i.schema),o;const a=new pa({...Sa,...i,cardinalityInference:!!i.schema},e||nr,n||rr,{...r||{},"@instantdb/core":dr},s),c=new Pa(a);return Jt[Ht(i)]=c,Ma(i.appId,i.devtool),c}function Ma(t,e){if(typeof window>"u"||typeof window.location>"u"||typeof document>"u"||typeof e=="boolean"&&!e)return;const n={position:"bottom-right",allowedHosts:["localhost"],...typeof e=="object"?e:{}};n.allowedHosts.includes(window.location.hostname)&&ya(t,n)}const ja={isLoading:!0,data:void 0,pageInfo:void 0,error:void 0};function Cr(t){return{isLoading:!t,data:void 0,pageInfo:void 0,error:void 0,...t||{}}}function Ra(t,e,n){e&&n&&"ruleParams"in n&&(e={$$ruleParams:n.ruleParams,...e});const r=e?ka(e):null,s=F(r),i=O.useRef(Cr(t._reactor.getPreviousResult(r))),o=O.useCallback(c=>(i.current=Cr(t._reactor.getPreviousResult(r)),c(),r?t.subscribeQuery(r,l=>{i.current={isLoading:!l,data:void 0,pageInfo:void 0,error:void 0,...l},c()}):()=>{}),[s]);return{state:O.useSyncExternalStore(o,()=>i.current,()=>ja),query:r}}function Da(){const t=O.useRef(null);O.useEffect(()=>{n()},[]);function e(r,s){n(),t.current=setTimeout(s,r)}function n(){t.current&&clearTimeout(t.current)}return{set:e,clear:n}}const xa=1e3;function $a(t,e,n){const r=O.useRef(n);r.current=n,O.useEffect(()=>t.core._reactor.subscribeTopic(t.id,e,(i,o)=>{r.current(i,o)}),[t.id,e])}function Ua(t,e){return O.useEffect(()=>t.core._reactor.joinRoom(t.id),[t.id]),O.useCallback(r=>{t.core._reactor.publishTopic({roomType:t.type,roomId:t.id,topic:e,data:r})},[t.id,e])}function La(t,e={}){var o,a;const[n,r]=O.useState(()=>t.core._reactor.getPresence(t.type,t.id,e)??{peers:{},isLoading:!0});O.useEffect(()=>t.core._reactor.subscribePresence(t.type,t.id,e,u=>{r(u)}),[t.id,e.user,(o=e.peers)==null?void 0:o.join(),(a=e.keys)==null?void 0:a.join()]);const s=O.useCallback(c=>{t.core._reactor.publishPresence(t.type,t.id,c)},[t.type,t.id]);return O.useMemo(()=>({...n,publishPresence:s}),[n,s])}function Fa(t,e,n){O.useEffect(()=>t.core._reactor.joinRoom(t.id,e),[t.id]),O.useEffect(()=>t.core._reactor.publishPresence(t.type,t.id,e),[t.type,t.id,n??JSON.stringify(e)])}function Na(t,e,n={}){const r=Da(),s=Te.usePresence(t,{keys:[e]}),i=O.useMemo(()=>{const l=t._core._reactor.getPresence(t.type,t.id);return n!=null&&n.writeOnly?[]:Object.values((l==null?void 0:l.peers)??{}).filter(d=>d[e]===!0)},[n==null?void 0:n.writeOnly,s]),o=O.useCallback(l=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:l}),l&&((n==null?void 0:n.timeout)===null||(n==null?void 0:n.timeout)===0||r.set((n==null?void 0:n.timeout)??xa,()=>{t.core._reactor.publishPresence(t.type,t.id,{[e]:null})}))},[t.type,t.id,e,n==null?void 0:n.timeout,r]),a=O.useCallback(l=>{const h=!((n==null?void 0:n.stopOnEnter)&&l.key==="Enter");o(h)},[n.stopOnEnter,o]),c=O.useCallback(()=>{o(!1)},[o]),u=O.useMemo(()=>({onKeyDown:a,onBlur:c}),[a,c]);return{active:i,setActive:o,inputProps:u}}const Te={useTopicEffect:$a,usePublishTopic:Ua,usePresence:La,useSyncPresence:Fa,useTypingIndicator:Na};class Ka{constructor(e,n,r){p(this,"core");p(this,"_core");p(this,"type");p(this,"id");p(this,"useTopicEffect",(e,n)=>{Te.useTopicEffect(this,e,n)});p(this,"usePublishTopic",e=>Te.usePublishTopic(this,e));p(this,"usePresence",(e={})=>Te.usePresence(this,e));p(this,"useSyncPresence",(e,n)=>Te.useSyncPresence(this,e,n));p(this,"useTypingIndicator",(e,n={})=>Te.useTypingIndicator(this,e,n));this.core=e,this._core=this.core,this.type=n,this.id=r}}const za={isLoading:!0,user:void 0,error:void 0};class ct{constructor(e,n){p(this,"tx",Lt());p(this,"auth");p(this,"storage");p(this,"core");p(this,"_core");p(this,"getLocalId",e=>this.core.getLocalId(e));p(this,"useLocalId",e=>{const[n,r]=O.useState(null);return O.useEffect(()=>{(async()=>{const i=await this.getLocalId(e);r(i)})()},[e]),n});p(this,"rooms",Te);p(this,"transact",e=>this.core.transact(e));p(this,"useQuery",(e,n)=>Ra(this.core,e,n).state);p(this,"useAuth",()=>this._useAuth());p(this,"useUser",()=>{const{user:e}=this.useAuth();if(!e)throw new Ee("useUser must be used within an auth-protected route");return e});p(this,"useConnectionStatus",()=>{const e=O.useRef(this.core._reactor.status),n=O.useCallback(s=>this.core.subscribeConnectionStatus(o=>{o!==e.current&&(e.current=o,s())}),[]);return O.useSyncExternalStore(n,()=>e.current,()=>"connecting")});p(this,"queryOnce",(e,n)=>this.core.queryOnce(e,n));p(this,"SignedIn",({children:e})=>{const n=this.useAuth();return n.isLoading||n.error||!n.user?null:We.jsx(We.Fragment,{children:e})});p(this,"SignedOut",({children:e})=>{const n=this.useAuth();return n.isLoading||n.error||n.user?null:We.jsx(We.Fragment,{children:e})});this.core=Ia(e,e.Store||this.constructor.Store,this.constructor.NetworkListener,n,this.constructor.EventSourceImpl),this._core=this.core,this.auth=this.core.auth,this.storage=this.core.storage}room(e="_defaultRoomType",n="_defaultRoomId"){return new Ka(this.core,e,n)}_useAuth(){const e=O.useRef(this.core._reactor._currentUserCached),n=O.useCallback(s=>this.core.subscribeAuth(o=>{e.current={isLoading:!1,...o},s()}),[]);return O.useSyncExternalStore(n,()=>e.current,()=>za)}getAuth(){return this.core.getAuth()}}p(ct,"Store"),p(ct,"NetworkListener"),p(ct,"EventSourceImpl"),J.InstantReactAbstractDatabase=ct,Object.defineProperty(J,Symbol.toStringTag,{value:"Module"})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@instantdb/react-common",
3
- "version": "0.22.112",
3
+ "version": "0.22.113-experimental.dwwoelfel-patch-2.21374029739.1",
4
4
  "description": "Instant DB shared components for React and React Native",
5
5
  "homepage": "https://github.com/instantdb/instant/tree/main/client/packages/react-common",
6
6
  "repository": {
@@ -53,8 +53,8 @@
53
53
  "react": ">=16"
54
54
  },
55
55
  "dependencies": {
56
- "@instantdb/core": "0.22.112",
57
- "@instantdb/version": "0.22.112"
56
+ "@instantdb/core": "0.22.113-experimental.dwwoelfel-patch-2.21374029739.1",
57
+ "@instantdb/version": "0.22.113-experimental.dwwoelfel-patch-2.21374029739.1"
58
58
  },
59
59
  "scripts": {
60
60
  "test": "vitest",
@@ -59,7 +59,7 @@ export default abstract class InstantReactAbstractDatabase<
59
59
  /** @deprecated use `core` instead */
60
60
  public _core: InstantCoreDatabase<Schema, UseDates>;
61
61
 
62
- static Storage?: any;
62
+ static Store?: any;
63
63
  static NetworkListener?: any;
64
64
  static EventSourceImpl?: any;
65
65
 
@@ -72,7 +72,7 @@ export default abstract class InstantReactAbstractDatabase<
72
72
  this.core = core_init<Schema, UseDates>(
73
73
  config,
74
74
  // @ts-expect-error because TS can't resolve subclass statics
75
- this.constructor.Storage,
75
+ config.Store || this.constructor.Store,
76
76
  // @ts-expect-error because TS can't resolve subclass statics
77
77
  this.constructor.NetworkListener,
78
78
  versions,