docs/docs/00100-intro/00200-quickstarts/00170-tanstack.md
import { InstallCardLink } from "@site/src/components/InstallCardLink"; import { StepByStep, Step, StepText, StepCode } from "@site/src/components/Steps";
Get a SpacetimeDB app with TanStack Start running in under 5 minutes.
This will start the local SpacetimeDB server, publish your module, generate TypeScript bindings, and start the development server.
</StepText>
<StepCode>
spacetime dev --template tanstack-ts
</StepCode>
The template includes a TanStack Start app with TanStack Query integration with SpacetimeDB.
</StepText>
Edit `spacetimedb/src/index.ts` to add tables and reducers. Edit `src/routes/index.tsx` to build your UI.
</StepText>
<StepCode>
my-spacetime-app/
├── spacetimedb/ # Your SpacetimeDB module
│ └── src/
│ └── index.ts # Server-side logic
├── src/ # TanStack Start frontend
│ ├── router.tsx # QueryClient + SpacetimeDB setup
│ ├── routes/
│ │ ├── __root.tsx # Root layout
│ │ └── index.tsx # Main app component
│ └── module_bindings/ # Auto-generated types
└── package.json
</StepCode>
Tables store your data. Reducers are functions that modify data — they're the only way to write to the database.
</StepText>
<StepCode>
import { schema, table, t } from 'spacetimedb/server';
const spacetimedb = schema({
person: table(
{ public: true },
{
name: t.string(),
}
),
});
export default spacetimedb;
export const add = spacetimedb.reducer(
{ name: t.string() },
(ctx, { name }) => {
ctx.db.person.insert({ name });
}
);
export const sayHello = spacetimedb.reducer(ctx => {
for (const person of ctx.db.person.iter()) {
console.info(`Hello, ${person.name}!`);
}
console.info('Hello, World!');
});
</StepCode>
spacetime call add Alice
"Alice"
spacetime call say_hello
spacetime logs 2025-01-13T12:00:00.000000Z INFO: Hello, Alice! 2025-01-13T12:00:00.000000Z INFO: Hello, World!
</StepCode>
</Step>
<Step title="Query and update data">
<StepText>
Use `useSpacetimeDBQuery()` to subscribe to tables with TanStack Query — it returns `[data, loading, query]`. SpacetimeDB React hooks also work with TanStack Start.
</StepText>
<StepCode>
```typescript
import { useSpacetimeDBQuery, useReducer } from 'spacetimedb/tanstack';
import { tables, reducers } from '../module_bindings';
function App() {
const [people, loading] = useSpacetimeDBQuery(tables.person);
const addPerson = useReducer(reducers.add);
if (loading) return <p>Loading...</p>;
return (
<ul>
{people.map((person, i) => (
<li key={i}>{person.name}</li>
))}
</ul>
);
}
</StepCode>