function useLiveQuery<TContext>(queryFn): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
function useLiveQuery<TContext>(queryFn): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
Defined in: useLiveQuery.ts:98
Create a live query using a query function
TContext extends Context
(q) => QueryBuilder<TContext>
Query function that defines what data to fetch
Accessor that returns data with Suspense support, with state and status information as properties
// Basic query with object syntax
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todosCollection })
.where(({ todos }) => eq(todos.completed, false))
.select(({ todos }) => ({ id: todos.id, text: todos.text }))
)
// Basic query with object syntax
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todosCollection })
.where(({ todos }) => eq(todos.completed, false))
.select(({ todos }) => ({ id: todos.id, text: todos.text }))
)
// With dependencies that trigger re-execution
const todosQuery = useLiveQuery(
(q) => q.from({ todos: todosCollection })
.where(({ todos }) => gt(todos.priority, minPriority())),
)
// With dependencies that trigger re-execution
const todosQuery = useLiveQuery(
(q) => q.from({ todos: todosCollection })
.where(({ todos }) => gt(todos.priority, minPriority())),
)
// Join pattern
const personIssues = useLiveQuery((q) =>
q.from({ issues: issueCollection })
.join({ persons: personCollection }, ({ issues, persons }) =>
eq(issues.userId, persons.id)
)
.select(({ issues, persons }) => ({
id: issues.id,
title: issues.title,
userName: persons.name
}))
)
// Join pattern
const personIssues = useLiveQuery((q) =>
q.from({ issues: issueCollection })
.join({ persons: personCollection }, ({ issues, persons }) =>
eq(issues.userId, persons.id)
)
.select(({ issues, persons }) => ({
id: issues.id,
title: issues.title,
userName: persons.name
}))
)
// Handle loading and error states
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Switch>
<Match when={todosQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={todosQuery.isError}>
<div>Error: {todosQuery.status}</div>
</Match>
<Match when={todosQuery.isReady}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Match>
</Switch>
)
// Handle loading and error states
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Switch>
<Match when={todosQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={todosQuery.isError}>
<div>Error: {todosQuery.status}</div>
</Match>
<Match when={todosQuery.isReady}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Match>
</Switch>
)
// Use Suspense boundaries
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Suspense fallback={<div>Loading...</div>}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Suspense>
)
// Use Suspense boundaries
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Suspense fallback={<div>Loading...</div>}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Suspense>
)
function useLiveQuery<TContext>(queryFn): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
function useLiveQuery<TContext>(queryFn): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
Defined in: useLiveQuery.ts:117
Create a live query using a query function
TContext extends Context
(q) => QueryBuilder<TContext> | null | undefined
Query function that defines what data to fetch
Accessor that returns data with Suspense support, with state and status information as properties
// Basic query with object syntax
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todosCollection })
.where(({ todos }) => eq(todos.completed, false))
.select(({ todos }) => ({ id: todos.id, text: todos.text }))
)
// Basic query with object syntax
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todosCollection })
.where(({ todos }) => eq(todos.completed, false))
.select(({ todos }) => ({ id: todos.id, text: todos.text }))
)
// With dependencies that trigger re-execution
const todosQuery = useLiveQuery(
(q) => q.from({ todos: todosCollection })
.where(({ todos }) => gt(todos.priority, minPriority())),
)
// With dependencies that trigger re-execution
const todosQuery = useLiveQuery(
(q) => q.from({ todos: todosCollection })
.where(({ todos }) => gt(todos.priority, minPriority())),
)
// Join pattern
const personIssues = useLiveQuery((q) =>
q.from({ issues: issueCollection })
.join({ persons: personCollection }, ({ issues, persons }) =>
eq(issues.userId, persons.id)
)
.select(({ issues, persons }) => ({
id: issues.id,
title: issues.title,
userName: persons.name
}))
)
// Join pattern
const personIssues = useLiveQuery((q) =>
q.from({ issues: issueCollection })
.join({ persons: personCollection }, ({ issues, persons }) =>
eq(issues.userId, persons.id)
)
.select(({ issues, persons }) => ({
id: issues.id,
title: issues.title,
userName: persons.name
}))
)
// Handle loading and error states
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Switch>
<Match when={todosQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={todosQuery.isError}>
<div>Error: {todosQuery.status}</div>
</Match>
<Match when={todosQuery.isReady}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Match>
</Switch>
)
// Handle loading and error states
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Switch>
<Match when={todosQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={todosQuery.isError}>
<div>Error: {todosQuery.status}</div>
</Match>
<Match when={todosQuery.isReady}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Match>
</Switch>
)
// Use Suspense boundaries
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Suspense fallback={<div>Loading...</div>}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Suspense>
)
// Use Suspense boundaries
const todosQuery = useLiveQuery((q) =>
q.from({ todos: todoCollection })
)
return (
<Suspense fallback={<div>Loading...</div>}>
<For each={todosQuery()}>
{(todo) => <li key={todo.id}>{todo.text}</li>}
</For>
</Suspense>
)
function useLiveQuery<TContext>(config): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
function useLiveQuery<TContext>(config): Accessor<{ [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] }[]> & object;
Defined in: useLiveQuery.ts:178
Create a live query using configuration object
TContext extends Context
Accessor<LiveQueryCollectionConfig<TContext, { [K in string | number | symbol]: (TContext["result"] extends object ? any[any] : TContext["hasJoins"] extends true ? TContext["schema"] : TContext["schema"][TContext["fromSourceName"]])[K] } & object>>
Configuration object with query and options
Accessor that returns data with Suspense support, with state and status information as properties
// Basic config object usage
const todosQuery = useLiveQuery(() => ({
query: (q) => q.from({ todos: todosCollection }),
gcTime: 60000
}))
// Basic config object usage
const todosQuery = useLiveQuery(() => ({
query: (q) => q.from({ todos: todosCollection }),
gcTime: 60000
}))
// With query builder and options
const queryBuilder = new Query()
.from({ persons: collection })
.where(({ persons }) => gt(persons.age, 30))
.select(({ persons }) => ({ id: persons.id, name: persons.name }))
const personsQuery = useLiveQuery(() => ({ query: queryBuilder }))
// With query builder and options
const queryBuilder = new Query()
.from({ persons: collection })
.where(({ persons }) => gt(persons.age, 30))
.select(({ persons }) => ({ id: persons.id, name: persons.name }))
const personsQuery = useLiveQuery(() => ({ query: queryBuilder }))
// Handle all states uniformly
const itemsQuery = useLiveQuery(() => ({
query: (q) => q.from({ items: itemCollection })
}))
return (
<Switch fallback={<div>{itemsQuery().length} items loaded</div>}>
<Match when={itemsQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={itemsQuery.isError}>
<div>Something went wrong</div>
</Match>
<Match when={!itemsQuery.isReady}>
<div>Preparing...</div>
</Match>
</Switch>
)
// Handle all states uniformly
const itemsQuery = useLiveQuery(() => ({
query: (q) => q.from({ items: itemCollection })
}))
return (
<Switch fallback={<div>{itemsQuery().length} items loaded</div>}>
<Match when={itemsQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={itemsQuery.isError}>
<div>Something went wrong</div>
</Match>
<Match when={!itemsQuery.isReady}>
<div>Preparing...</div>
</Match>
</Switch>
)
function useLiveQuery<TResult, TKey, TUtils>(liveQueryCollection): Accessor<TResult[]> & object;
function useLiveQuery<TResult, TKey, TUtils>(liveQueryCollection): Accessor<TResult[]> & object;
Defined in: useLiveQuery.ts:232
Subscribe to an existing live query collection
TResult extends object
TKey extends string | number
TUtils extends Record<string, any>
Accessor<Collection<TResult, TKey, TUtils, StandardSchemaV1<unknown, unknown>, TResult>>
Pre-created live query collection to subscribe to
Accessor that returns data with Suspense support, with state and status information as properties
// Using pre-created live query collection
const myLiveQuery = createLiveQueryCollection((q) =>
q.from({ todos: todosCollection }).where(({ todos }) => eq(todos.active, true))
)
const todosQuery = useLiveQuery(() => myLiveQuery)
// Using pre-created live query collection
const myLiveQuery = createLiveQueryCollection((q) =>
q.from({ todos: todosCollection }).where(({ todos }) => eq(todos.active, true))
)
const todosQuery = useLiveQuery(() => myLiveQuery)
// Access collection methods directly
const existingQuery = useLiveQuery(() => existingCollection)
// Use collection for mutations
const handleToggle = (id) => {
existingQuery.collection.update(id, draft => { draft.completed = !draft.completed })
}
// Access collection methods directly
const existingQuery = useLiveQuery(() => existingCollection)
// Use collection for mutations
const handleToggle = (id) => {
existingQuery.collection.update(id, draft => { draft.completed = !draft.completed })
}
// Handle states consistently
const sharedQuery = useLiveQuery(() => sharedCollection)
return (
<Switch fallback={<div><For each={sharedQuery()}>{(item) => <Item key={item.id} {...item} />}</For></div>}>
<Match when={sharedQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={sharedQuery.isError}>
<div>Error loading data</div>
</Match>
</Switch>
)
// Handle states consistently
const sharedQuery = useLiveQuery(() => sharedCollection)
return (
<Switch fallback={<div><For each={sharedQuery()}>{(item) => <Item key={item.id} {...item} />}</For></div>}>
<Match when={sharedQuery.isLoading}>
<div>Loading...</div>
</Match>
<Match when={sharedQuery.isError}>
<div>Error loading data</div>
</Match>
</Switch>
)
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.
