Configuration
Configure the GroqBuilder
In your project, we recommend creating a file called groqd-client.ts:
import { createClient } from "@sanity/client";
import { createGroqBuilder, makeSafeQueryRunner } from 'groqd';
// 👇 Import Sanity types, generated by your Sanity project.
import type * as SanityTypes 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: SanityTypes.AllSanitySchemaTypes
  referenceSymbol: typeof SanityTypes.internalGroqTypeReferenceTo;
};
export const q = createGroqBuilder<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 sanityCLI to generate thesanity.types.tsfile
- 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 = createGroqBuilder<any>({ validationRequired: true });