-
Notifications
You must be signed in to change notification settings - Fork 1
/
sanity.config.ts
63 lines (60 loc) · 2.12 KB
/
sanity.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/**
* This config is used to set up Sanity Studio that's mounted on the `/pages/studio/[[...index]].tsx` route
*/
// Using `@sanity/presentation` instead of `sanity/presentation` until `sanity` ships with: https://github.com/sanity-io/visual-editing/releases/tag/presentation-v1.0.5
import { presentationTool } from '@sanity/presentation'
import { visionTool } from '@sanity/vision'
import {
apiVersion,
dataset,
DRAFT_MODE_ROUTE,
projectId,
} from 'lib/sanity.api'
import { locate } from 'plugins/locate'
import { previewDocumentNode } from 'plugins/previewPane'
import { settingsPlugin, settingsStructure } from 'plugins/settings'
import { defineConfig } from 'sanity'
import { deskTool } from 'sanity/desk'
import { unsplashImageAsset } from 'sanity-plugin-asset-source-unsplash'
import authorType from 'schemas/author'
import postType from 'schemas/post'
import settingsType from 'schemas/settings'
const title =
process.env.NEXT_PUBLIC_SANITY_PROJECT_TITLE || 'Next.js Blog with Sanity.io'
export default defineConfig({
basePath: '/studio',
projectId,
dataset,
title,
schema: {
// If you want more content types, you can add them to this array
types: [authorType, postType, settingsType],
},
plugins: [
deskTool({
structure: settingsStructure(settingsType),
// `defaultDocumentNode` is responsible for adding a “Preview” tab to the document pane
defaultDocumentNode: previewDocumentNode(),
}),
presentationTool({
locate,
previewUrl: {
origin:
typeof location === 'undefined'
? 'http://localhost:3000'
: location.origin,
preview: '/',
draftMode: {
enable: DRAFT_MODE_ROUTE,
},
},
}),
// Configures the global "new document" button, and document actions, to suit the Settings document singleton
settingsPlugin({ type: settingsType.name }),
// Add an image asset source for Unsplash
unsplashImageAsset(),
// Vision lets you query your content with GROQ in the studio
// https://www.sanity.io/docs/the-vision-plugin
visionTool({ defaultApiVersion: apiVersion }),
],
})