Skip to content

Conversation

jonasherr
Copy link

Description

Adds a new Next.js 15 starter example showcasing Sanity CMS integration with GraphQL fragment colocation pattern. This example demonstrates modern best practices for type-safe GraphQL queries with server-side rendering.

Key Features:

  • GraphQL Fragment Colocation: Fragments defined close to components for better maintainability
  • Type Safety: gql.tada for compile-time GraphQL type checking and IntelliSense
  • ISR with On-Demand Revalidation: Webhook-triggered cache invalidation using revalidateTag() for navigation/footer and revalidatePath() for content
  • Server-Side Only GraphQL: No client-side GraphQL bundle using URQL with React Server Components
  • Comprehensive Sanity Schemas: Posts, Pages, Navigation, Footer with full content management
  • Modern Stack: Next.js 15 App Router, React 19, Tailwind CSS v4, Biome formatter/linter

Documentation Included:

  • CLAUDE.md - Agent/developer guidelines with commands, patterns, and best practices
  • WEBHOOK_SETUP.md - Step-by-step webhook configuration for on-demand revalidation
  • Complete setup instructions in README

Guide:
A comprehensive guide has been written for this example (currently in draft):
https://vercel.com/guides/building-nextjs-apps-with-graphql-fragment-colocation-and-sanity-cms?__vercel_draft=1

Demo URL

https://cms-graphql-fragments.vercel.app/

Type of Change

  • New Example
  • Example updates (Bug fixes, new features, etc.)
  • Other (changes to the codebase, but not to examples)

Copy link

vercel bot commented Oct 1, 2025

The latest updates on your projects. Learn more about Vercel for GitHub.

Project Deployment Preview Comments Updated (UTC)
alt-tag-generator Building Building Preview Comment Oct 7, 2025 3:22pm
app-dir-css-in-js Ready Ready Preview Comment Oct 7, 2025 3:22pm
app-dir-i18n Ready Ready Preview Comment Oct 7, 2025 3:22pm
app-dir-share-state Ready Ready Preview Comment Oct 7, 2025 3:22pm
blob-starter Ready Ready Preview Comment Oct 7, 2025 3:22pm
build-output-api-routes Building Building Preview Comment Oct 7, 2025 3:22pm
cron Ready Ready Preview Comment Oct 7, 2025 3:22pm
edge-ab-testing-google-optimize Error Error Oct 7, 2025 3:22pm
edge-ab-testing-statsig Ready Ready Preview Comment Oct 7, 2025 3:22pm
edge-api-routes-hello-world Building Building Preview Comment Oct 7, 2025 3:22pm
edge-api-routes-json-response Error Error Oct 7, 2025 3:22pm
edge-functions-ab-testing-simple Ready Ready Preview Comment Oct 7, 2025 3:22pm
edge-functions-add-header Ready Ready Preview Comment Oct 7, 2025 3:22pm
edge-functions-api-rate-limit Error Error Oct 7, 2025 3:22pm
edge-functions-api-rate-limit-and-tokens Error Error Oct 7, 2025 3:22pm
edge-functions-authed-proxy Error Error Oct 7, 2025 3:22pm
edge-functions-basic-auth-password Ready Ready Preview Comment Oct 7, 2025 3:22pm
edge-functions-bot-protection-botd Error Error Oct 7, 2025 3:22pm
edge-functions-bot-protection-datadome Error Error Oct 7, 2025 3:22pm
edge-functions-cookies Error Error Oct 7, 2025 3:22pm
edge-functions-cors Error Error Oct 7, 2025 3:22pm
edge-functions-crypto Error Error Oct 7, 2025 3:22pm
edge-functions-feature-flag-configcat Error Error Oct 7, 2025 3:22pm
edge-functions-feature-flag-posthog Error Error Oct 7, 2025 3:22pm
edge-functions-feature-flag-split Error Error Oct 7, 2025 3:22pm
edge-functions-geolocation Error Error Oct 7, 2025 3:22pm
edge-functions-hostname-rewrites Error Error Oct 7, 2025 3:22pm
edge-functions-i18n Error Error Oct 7, 2025 3:22pm
edge-functions-image-response Error Error Oct 7, 2025 3:22pm
edge-functions-ip-blocking Error Error Oct 7, 2025 3:22pm
edge-functions-ip-blocking-datadome Error Error Oct 7, 2025 3:22pm
edge-functions-json-response Error Error Oct 7, 2025 3:22pm
edge-functions-jwt-authentication Error Error Oct 7, 2025 3:22pm
edge-functions-news Error Error Oct 7, 2025 3:22pm
edge-functions-power-parity-pricing Error Error Oct 7, 2025 3:22pm
edge-functions-power-parity-pricing-strategies Error Error Oct 7, 2025 3:22pm
edge-functions-query-params-filter Error Error Oct 7, 2025 3:22pm
edge-functions-redirects-upstash Error Error Oct 7, 2025 3:22pm
edge-functions-streams Error Error Oct 7, 2025 3:22pm
edge-geolocation-country-block Error Error Oct 7, 2025 3:22pm
edge-maintenance-page Error Error Oct 7, 2025 3:22pm
edge-middleware-modify-request-header Error Error Oct 7, 2025 3:22pm
edge-rewrites-upstash Error Error Oct 7, 2025 3:22pm
edge-user-agent-based-rendering Error Error Oct 7, 2025 3:22pm
example-feature-flag-apple-store Error Error Oct 7, 2025 3:22pm
example-reduce-image-bandwidth-usage Error Error Oct 7, 2025 3:22pm
examples Ready Ready Preview Comment Oct 7, 2025 3:22pm
examples-q42o Building Building Preview Comment Oct 7, 2025 3:22pm
experimentation-statsig Ready Ready Preview Comment Oct 7, 2025 3:22pm
express-ai-sdk-demo Ready Ready Preview Comment Oct 7, 2025 3:22pm
express-vercel Ready Ready Preview Comment Oct 7, 2025 3:22pm
feature-flag-hypertune Error Error Oct 7, 2025 3:22pm
feature-flag-launchdarkly Error Error Oct 7, 2025 3:22pm
feature-flag-optimizely Error Error Oct 7, 2025 3:22pm
flags-sdk-growthbook Ready Ready Preview Comment Oct 7, 2025 3:22pm
flags-sdk-launchdarkly Ready Ready Preview Comment Oct 7, 2025 3:22pm
flags-sdk-openfeature Ready Ready Preview Comment Oct 7, 2025 3:22pm
flags-sdk-posthog Ready Ready Preview Comment Oct 7, 2025 3:22pm
flags-sdk-reflag Ready Ready Preview Comment Oct 7, 2025 3:22pm
geolocation-script Building Building Preview Comment Oct 7, 2025 3:22pm
hono Ready Ready Preview Comment Oct 7, 2025 3:22pm
hono-ai-sdk Ready Ready Preview Comment Oct 7, 2025 3:22pm
i18n Error Error Oct 7, 2025 3:22pm
kv-redis-starter Ready Ready Preview Comment Oct 7, 2025 3:22pm
laurens-test Ready Ready Preview Comment Oct 7, 2025 3:22pm
mint-nft Error Error Oct 7, 2025 3:22pm
next-edge-api-route-hello-world Error Error Oct 7, 2025 3:22pm
nitro Ready Ready Preview Comment Oct 7, 2025 3:22pm
nitro-route-rules Building Building Preview Comment Oct 7, 2025 3:22pm
nodejs-api Error Error Oct 7, 2025 3:22pm
nx-monorepo Ready Ready Preview Comment Oct 7, 2025 3:22pm
postgres-drizzle Ready Ready Preview Comment Oct 7, 2025 3:22pm
postgres-pgvector Ready Ready Preview Comment Oct 7, 2025 3:22pm
postgres-starter Ready Ready Preview Comment Oct 7, 2025 3:22pm
redwood Error Error Oct 7, 2025 3:22pm
saas-microservices-api-dashboard Ready Ready Preview Comment Oct 7, 2025 3:22pm
saas-microservices-api-users Ready Ready Preview Comment Oct 7, 2025 3:22pm
saas-microservices-dashboard Ready Ready Preview Comment Oct 7, 2025 3:22pm
solutions-cms-contentstack-commerce Building Building Preview Comment Oct 7, 2025 3:22pm
solutions-combining-data-fetching-strategies Error Error Oct 7, 2025 3:22pm
solutions-image-fallback Error Error Oct 7, 2025 3:22pm
solutions-image-offset Error Error Oct 7, 2025 3:22pm
solutions-loading-web-fonts Error Error Oct 7, 2025 3:22pm
solutions-microfrontends Ready Ready Preview Comment Oct 7, 2025 3:22pm
solutions-microfrontends-docs Ready Ready Preview Comment Oct 7, 2025 3:22pm
solutions-monorepo Error Error Oct 7, 2025 3:22pm
solutions-on-demand-isr Error Error Oct 7, 2025 3:22pm
solutions-pagination-with-ssg Error Error Oct 7, 2025 3:22pm
solutions-parallel-routes-navbar Error Error Oct 7, 2025 3:22pm
solutions-reuse-responses Error Error Oct 7, 2025 3:22pm
solutions-script-component-ad Error Error Oct 7, 2025 3:22pm
solutions-script-component-strategies Error Error Oct 7, 2025 3:22pm
solutions-subdomains-auth Error Error Oct 7, 2025 3:22pm
solutions-testing Building Building Preview Comment Oct 7, 2025 3:22pm
toolbar-feature-flags-sveltekit Ready Ready Preview Comment Oct 7, 2025 3:22pm
toolbar-launchdarkly Error Error Oct 7, 2025 3:22pm
toolbar-optimizely Error Error Oct 7, 2025 3:22pm
toolbar-split Error Error Oct 7, 2025 3:22pm
toolbar-statsig Error Error Oct 7, 2025 3:22pm
turborepo-hono-web Ready Ready Preview Comment Oct 7, 2025 3:22pm
vue Ready Ready Preview Comment Oct 7, 2025 3:22pm
wasm-rust-hello-world Error Error Oct 7, 2025 3:22pm
9 Skipped Deployments
Project Deployment Preview Comments Updated (UTC)
build-output-api-draft-mode Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-edge-functions Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-edge-middleware Ignored Ignored Preview Oct 7, 2025 3:22pm
build-output-api-image-optimization Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-isr Ignored Ignored Preview Oct 7, 2025 3:22pm
build-output-api-overrides Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-prerender-functions Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-serverless-functions Ignored Ignored Oct 7, 2025 3:22pm
build-output-api-static-files Ignored Ignored Oct 7, 2025 3:22pm

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant