Radio Group
Radio groups are a collection of radio options. Use this when only one entry is allowed in the form field.
Basic usage
<RadioGroup
v-model="receiveNewsletter"
label="Would you like to receive our newsletter?"
name="newsletter"
>
<RadioNew
id="yes"
label="Yes"
value="yes"
/>
<RadioNew
id="no"
label="No"
value="no"
/>
</RadioGroup>
Variants
The RadioGroup
component comes with four variants. You can set them via the variant property. The default value is radio
.
Radio
<RadioGroup variant="radio" label="Shirt size">
<RadioNew
id="small"
label="Small"
value="sm"
/>
<RadioNew
id="medium"
label="Medium"
value="md"
/>
<RadioNew
id="large"
label="Large"
value="lg"
/>
</RadioGroup>
You can also customize the RadioNew
component by leveraging the default slot of the RadioGroup
component. This allows you to compose the RadioNew
component with other components.
<RadioGroup variant="radio" label="Priority">
<Card>
<template #top-left>
<RadioNew id="low" label="Low. This option designates tasks or items with a lower level of urgency or criticality, providing a more relaxed timeline for completion." value="low" />
</template>
</Card>
<Card>
<template #top-left>
<RadioNew id="high" label="High. This choice signifies a commitment to addressing tasks or items with heightened urgency or critical importance promptly." value="high" />
</template>
</Card>
</RadioGroup>
Button
<RadioGroup variant="button" label="Preferred operating system">
<RadioNew
id="linux"
label="Linux"
value="linux"
/>
<RadioNew
id="macos"
label="MacOS"
value="macos"
/>
<RadioNew
id="windows"
label="Windows"
value="windows"
/>
</RadioGroup>
Chip
<RadioGroup variant="chip" label="Availability">
<RadioNew
id="monday"
label="Monday"
value="monday"
/>
<RadioNew
id="tuesday"
label="Tuesday"
value="tuesday"
/>
<RadioNew
id="wednesday"
label="Wednesday"
value="wednesday"
/>
<RadioNew
id="thursday"
label="Thursday"
value="thursday"
/>
<RadioNew
id="friday"
label="Friday"
value="friday"
/>
</RadioGroup>
Tile
<RadioGroup variant="tile" label="Delivery method">
<RadioNew
id="standard"
label="Standard"
value="standard"
>
<p>5 - 10 business days</p>
<p>$10.00</p>
</RadioNew>
<RadioNew
id="express"
label="Express"
value="express"
>
<p>3 - 5 business days</p>
<p>$25.00</p>
</RadioNew>
</RadioGroup>
Hint text and error states
You can provide hint text for a RadioGroup
by using its hint-text
prop.
<RadioGroup
v-model="hintText"
label="Should I buy Ice Cream?"
name="icecream-hint"
hint-text="You know you want to."
>
<RadioNew id="yes" label="Yes" value="yes" />
<RadioNew id="no" label="No" value="no" />
</RadioGroup>
If you provide error-text
, the RadioGroup
will display an error state, which overrides the hint text.
<RadioGroup
v-model="errorText"
label="Vanilla or Chocolate?"
name="icecream-error"
:error-text="!errorText ? 'You have to select one.' : undefined"
hint-text="You know you want to."
>
<RadioNew id="Vanilla" label="Vanilla" value="Vanilla" />
<RadioNew id="Chocolate" label="Chocolate" value="Chocolate" />
</RadioGroup>
<div>
<Button @click="errorText = undefined">Reset</Button>
</div>
You can also leverage the <Field>
component to add individual hint-text and/or error states to each radio element.
<script setup>
import Field from '../../../src/components/Field/Field.vue';
import RadioGroup from '../../../src/components/RadioGroup/RadioGroup.vue';
import RadioNew from '../../../src/components/RadioNew/RadioNew.vue';
</script>
<template>
<RadioGroup label="Vanilla or Chocolate?" name="icecream-individual-hint">
<Field>
<template #hint>
<span class="tw-ml-8">Delicious classic flavor</span>
</template>
<RadioNew id="Vanilla" label="Vanilla" value="Vanilla" />
</Field>
<Field>
<template #hint>
<span class="tw-ml-8">Rich and indulgent</span>
</template>
<RadioNew id="Chocolate" label="Chocolate" value="Chocolate" />
</Field>
</RadioGroup>
</template>
Disabled
You can indicate that a specific Radio
option is disabled by setting its disabled
prop.
<RadioGroup
variant="radio"
v-model="disabledRadios"
name="radio-variant"
class="tw-mb-3"
>
<RadioNew
v-for="option in ['one', 'two',]"
:id="option"
:label="option"
:value="option"
disabled
/>
</RadioGroup>
API
See the documentation below for a complete reference to all the props and classes available to the components mentioned here.