Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
sanity-plugin-hotspot-array
Advanced tools
A configurable Custom Input for Arrays that will add and update items by clicking on an Image
This is a Sanity Studio v3 plugin. For the v2 version, please refer to the v2-branch.
A configurable Custom Input for Arrays that will add and update items by clicking on an Image
npm install --save sanity-plugin-hotspot-array
or
yarn add sanity-plugin-hotspot-array
Add it as a plugin in sanity.config.ts (or .js):
import { imageHotspotArrayPlugin } from "sanity-plugin-hotspot-array";
export default defineConfig({
// ...
plugins: [
imageHotspotArrayPlugin(),
]
})
Now you will have imageHotspot
available as an options on array
fields:
import {defineType, defineField} from 'sanity'
export const productSchema = defineType({
name: `product`,
title: `Product`,
type: `document`,
fields: [
defineField({
name: `hotspots`,
type: `array`,
of: [
// see `Spot object` setup below
],
options: {
// plugin adds support for this option
imageHotspot: {
// see `Image and description path` setup below
imagePath: `featureImage`,
descriptionPath: `details`,
// see `Custom tooltip` setup below
tooltip: undefined,
}
},
}),
// ...all your other fields
// ...of which one should be featureImage in this example
],
})
There is no need to provide an explicit input component, as that is handled by the plugin.
The plugin makes a number of assumptions to add and update data in the array. Including:
array
field is an array of objects, with a single object typex
and y
The custom input has the current values of all fields in the document, and so can "pick" the image out of the document by its path.
For example, if you want to add hotspots to an image, and that image is uploaded to the field featuredImage
, your fields options
would look like:
options: {
imageHotspot: {
imagePath: `featureImage`
}
}
To pick the image out of the hotspot-array parent object, use
options: {
imageHotspot: {
pathRoot: 'parent'
}
}
The custom input can also pre-fill a string or text field with a description of the position of the spot to make them easier to identify. Add a path relative to the spot object for this field.
options: {
imageHotspot: {
descriptionPath: `details`
}
}
Here's an example object schema complete with initial values, validation, fieldsets and a styled preview.
defineField({
name: 'spot',
type: 'object',
fieldsets: [{name: 'position', options: {columns: 2}}],
fields: [
{name: 'details', type: 'text', rows: 2},
{
name: 'x',
type: 'number',
readOnly: true,
fieldset: 'position',
initialValue: 50,
validation: (Rule) => Rule.required().min(0).max(100),
},
{
name: 'y',
type: 'number',
readOnly: true,
fieldset: 'position',
initialValue: 50,
validation: (Rule) => Rule.required().min(0).max(100),
},
],
preview: {
select: {
title: 'details',
x: 'x',
y: 'y',
},
prepare({title, x, y}) {
return {
title,
subtitle: x && y ? `${x}% x ${y}%` : `No position set`,
}
},
},
})
You can customise the Tooltip to display any Component, which will receive value
(the hotspot value with x and y),
schemaType
(schemaType of the hotspot value), and renderPreview
(callback for rendering Studio preview).
import { Box } from "@sanity/ui";
import { HotspotTooltipProps } from "sanity-plugin-hotspot-array";
export function HotspotPreview({
value,
schemaType,
renderPreview,
}: HotspotTooltipProps) {
return (
<Box padding={2} style={{ minWidth: 200 }}>
{renderPreview({
value,
schemaType,
layout: "default",
})}
</Box>
);
}
Then back in your schema definition
options: {
imageHotspot: {
tooltip: HotspotPreview
}
}
In this example our value
object has a reference
field to the product
schema type, and will show a document preview.
import {useSchema }from 'sanity'
import {Box} from '@sanity/ui'
export function ProductPreview({value, renderPreview}) {
const productSchemaType = useSchema().get('product')
return (
<Box padding={2} style={{minWidth: 200}}>
{value?.product?._ref ? (
renderPreview({
value,
schemaType: productSchemaType,
layout: "default"
})
) : (
`No reference selected`
)}
</Box>
)
}
Then back in your schema definition
options: {
imageHotspot: {
tooltip: ProductPreview
}
}
MIT-licensed. See LICENSE.
This plugin uses @sanity/plugin-kit with default configuration for build & watch scripts.
See Testing a plugin in Sanity Studio on how to run this plugin with hotreload in the studio.
Run "CI & Release" workflow. Make sure to select the main branch and check "Release new version".
Semantic release will only release on configured branches, so it is safe to run release on any branch.
FAQs
A configurable Custom Input for Arrays that will add and update items by clicking on an Image
We found that sanity-plugin-hotspot-array demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 65 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.