Tina Docs
Introduction
Core Concepts
Querying Content
Editing
Customizing Tina
Going To Production
Media
Drafts
Guides
Further Reference

Radio Group Field


This is an advanced-use feature, and likely not something you'll need to configure. What you probably want is the content types reference!

The radio-group field represents a group of radio inputs. It can rendered in a "horizontal" or "vertical" direction.

TinaCMS Radio Group Field using a "radio" variant in a "horizontal" direction

TinaCMS Radio Group Field using a "radio" variant in a "vertical" direction

Options

OptionDescription
componentThe name of the plugin component. Always 'radio-group'.
nameThe path to some value in the data being edited.
optionsAn array of strings or Options to select from.
directionAn optional string indicating whether to render the radios in a "horizontal" or "vertical" orientation. This will default to "horizontal" if no value is passed. (Optional)
variantAn optional string indicating whether the "radio" or "button" variant should be used. This will default to "radio" if no value is passed. (Optional)
labelA human readable label for the field. Defaults to the name. (Optional)
descriptionDescription that expands on the purpose of the field or prompts a specific action. (Optional)
interface RadioGroupField {
name: string
component: string
label?: string
options: (Option | string)[]
direction?: 'horizontal' | 'vertical'
}
type Option = {
value: string
label: string
}
These interfaces only show the keys unique to the radio group field. Visit the Field Config docs for a complete list of options.

Example: Select an Rating

Below is an example of how a radio group field could be used to choose a rating of a customer review.

const ReviewForm = {
fields: [
{
type: 'string',
name: 'rating',
label: 'Rating',
description: 'Choose a rating for this review',
options: [
{ label: '★', value: 'one_star' },
{ label: '★★', value: 'two_star' },
{ label: '★★★', value: 'three_star' },
{ label: '★★★★', value: 'four_star' },
{ label: '★★★★★', value: 'five_star' },
],
ui: {
component: 'radio-group',
direction: 'vertical',
},
},
// ...
],
}