The Vision Plugin
Quickly test your GROQ queries using this studio plugin
Vision is a plugin that lets you quickly test your GROQ queries right from the Studio. It shows up as a tool in the navigation bar when installed, and is part of the default Studio setup when running in development mode.
New projects should have the plugin installed already. For new projects, or if it is not part of your studio configuration, you can install it by adding @sanity/vision
as a dependency of your project (adding it to package.json
and reinstalling dependencies).
With the plugin installed, you should add it to your Sanity configuration (sanity.config.js
/ sanity.config.ts
):
import {defineConfig} from 'sanity'
import {deskTool} from 'sanity/desk'
import {visionTool} from '@sanity/vision'
export default defineConfig({
// ...
plugins: [deskTool(), visionTool()],
})
Should you want to only include the plugin in development mode, you can import and use the isDev
boolean and conditionally add the plugin:
import {defineConfig, isDev} from 'sanity'
import {deskTool} from 'sanity/desk'
import {visionTool} from '@sanity/vision'
export default defineConfig({
// ...
plugins: isDev
? [deskTool(), visionTool()]
: [deskTool()],
})
The plugin can be configured by passing it an object of options.
// sanity.config.js / sanity.config.ts
import {defineConfig} from 'sanity'
import {deskTool} from 'sanity/desk'
import {visionTool} from '@sanity/vision'
export default defineConfig({
// ...
plugins: [
deskTool(),
visionTool({
defaultApiVersion: 'v2021-03-25',
defaultDataset: 'development',
}),
],
})
Currently supported properties are:
defaultApiVersion
- The default API version for queries, unless the user specifically selects a different version. Allowed values arev1
,vX
,v2021-03-25
, orv2021-10-21
.defaultDataset
- The default dataset to use unless a specific one has been chosen in the user interface.
Additionally, these base properties are available should you want to customize what the item appears as in the navigation bar:
name
- Name used to identify the tool in URLs. Defaults tovision
.title
- Title that appears in the navigation bar. Defaults toVision
.icon
- React icon that appears in navigation bar. Defaults to an eye icon (EyeOpenIcon
from@sanity/icons
)
The Vision plugin allows you to quickly test a GROQ query against any of the datasets in your Content Lake. At the top of the tool, you'll find dropdowns to select your dataset, API version and perspective.
Each time you run a query (we'll see how in a moment), you'll see a fourth field at the top containing a URL for your query. This URL contains the API call to the Content Lake that's querying for your data.
If your dataset is public, that URL can be run in a browser, cURL, or an app like Postman or Insomnia, and it will return the same JSON as you see in Vision. If your dataset is private, the request must be authenticated in order to return data. The decision on dataset visibility is up to you, and can be changed if necessary.
On the left side of the Vision plugin are two panes: query and params. In the query pane, you can enter any valid GROQ query.
Query parameters works the same way as with Sanity client libraries. Given an object {minSeats: 2}
in the Params field, you may use the keys in the object as parameters in the query: *[_type == "bike" && seats >= $minSeats] {name, seats}
. Note that every param key is prefixed with $
in the query, but does not have a prefix in the parameters object.
Gotcha
You can only use Vision to test queries and listeners. You cannot use it for mutations.
To learn more about how to write queries, read How Queries Work - GROQ.