Configuration
Configure the GroqBuilder
In your project, create a file called groqd-client.ts
:
import { createClient } from "@sanity/client";
import { createGroqBuilderWithZod, makeSafeQueryRunner } from 'groq-builder';
// Import the Sanity Schema types from this generated file:
import { AllSanitySchemaTypes, internalGroqTypeReferenceTo } from "./sanity.types.ts";
const sanityClient = createClient({
/* ✨ your sanity config goes here */
});
// 👇 Create a type-safe query runner
export const runQuery = makeSafeQueryRunner((query) => sanityClient.fetch(query));
// 👇 Create a type-safe query builder
type SchemaConfig = {
schemaTypes: AllSanitySchemaTypes
referenceSymbol: typeof internalGroqTypeReferenceTo;
};
export const q = createGroqBuilderWithZod<SchemaConfig>({});
Generating the types from your Sanity Schema
The above example imports the Sanity Schema types from a generated sanity.types.ts
file.
To generate this file from your Sanity Schema, you'll need to use Sanity's TypeGen tool: https://www.sanity.io/docs/sanity-typegen
The workflow looks like this:
- From your Sanity project, you use the
sanity
CLI to generate thesanity.types.ts
file - You then copy that file from the Sanity project into your project
Do I have to use a strongly-typed schema?
A strongly-typed schema enhances type-checking, enables auto-complete, and makes runtime validation optional.
If you don't want to, or can't, provide a schema, you can use any
instead. You'll still get strongly-typed results!
We highly recommend using the validationRequired: true
option for this scenario, which forces runtime type checks.
export const q = createGroqBuilderWithZod<any>({ validationRequired: true });