Radix UI Select as Form Input

Can i?
31 Replies
julius
juliusOP3y ago
<select name={zo.fields.language()}>
{languages.map((item) => (
<option key={item.key} value={item.key}>
{item.title}
</option>
))}
</select>
<select name={zo.fields.language()}>
{languages.map((item) => (
<option key={item.key} value={item.key}>
{item.title}
</option>
))}
</select>
but nice looking - using radix everywhere else but not sure where the select, option or input should go when converting to radix this is it now but doesn't use the actual form inputs
const SelectLanguage = (
<Select.Root>
<Select.Trigger className="h-10 bg-white text-gray-700 rounded border border-gray-200 w-64 flex justify-between items-center py-1 px-3 gap-3 cursor-pointer text-sm">
<Select.Value />
<Select.Icon asChild>
<TiArrowSortedDown className="w-4 text-gray-700" />
</Select.Icon>
</Select.Trigger>

<Select.Portal>
<Select.Content className="overflow-hidden bg-white rounded text-gray-700 mt-2">
<Select.Viewport className="p-2">
{languages.map((item) => (
<Select.Item key={item.key} value={item.key} asChild>
<Select.ItemText className="flex gap-2 h-10 w-64 py-1 px-3 justify-between space-x-3 cursor-pointer items-center text-sm">
<item.icon className="h-5 w-5" /> {item.key}
</Select.ItemText>
<Select.ItemIndicator className="SelectItemIndicator">
<HiCheckCircle className="h-5 w-5 text-primary" />
</Select.ItemIndicator>
</Select.Item>
))}
</Select.Viewport>
</Select.Content>
</Select.Portal>
</Select.Root>
);
const SelectLanguage = (
<Select.Root>
<Select.Trigger className="h-10 bg-white text-gray-700 rounded border border-gray-200 w-64 flex justify-between items-center py-1 px-3 gap-3 cursor-pointer text-sm">
<Select.Value />
<Select.Icon asChild>
<TiArrowSortedDown className="w-4 text-gray-700" />
</Select.Icon>
</Select.Trigger>

<Select.Portal>
<Select.Content className="overflow-hidden bg-white rounded text-gray-700 mt-2">
<Select.Viewport className="p-2">
{languages.map((item) => (
<Select.Item key={item.key} value={item.key} asChild>
<Select.ItemText className="flex gap-2 h-10 w-64 py-1 px-3 justify-between space-x-3 cursor-pointer items-center text-sm">
<item.icon className="h-5 w-5" /> {item.key}
</Select.ItemText>
<Select.ItemIndicator className="SelectItemIndicator">
<HiCheckCircle className="h-5 w-5 text-primary" />
</Select.ItemIndicator>
</Select.Item>
))}
</Select.Viewport>
</Select.Content>
</Select.Portal>
</Select.Root>
);
Matvey
Matvey3y ago
I believe you can set defaultValue and name on Select.Root and it will work in as a form input.
julius
juliusOP3y ago
hmm doesn't seem to select it
julius
juliusOP3y ago
julius
juliusOP3y ago
defaultValue samee same
benton
benton3y ago
nvm If you add onValueChange((m) => console.log(m)) to root does it correctly log the values?
julius
juliusOP3y ago
yes, but the value isn't added to the form data
julius
juliusOP3y ago
benton
benton3y ago
what form?
julius
juliusOP3y ago
julius
juliusOP3y ago
the lang field in the form doesn't change with the select
benton
benton3y ago
you need to manually set the form field, I don't think radix does this automatically i don't really see how it could use the onChange callback
julius
juliusOP3y ago
is it not a native select? im using react-zorm
<select name={zo.fields.language()}>
{languages.map((item) => (
<option key={item.key} value={item.key}>
{item.title}
</option>
))}
</select>
<select name={zo.fields.language()}>
{languages.map((item) => (
<option key={item.key} value={item.key}>
{item.title}
</option>
))}
</select>
this worked
benton
benton3y ago
It's not a native select It uses aria-attributes to give it the role of a dropdown but it's basically a div element, which lets you style it however you want so you have to hook up the value of the select to the form
julius
juliusOP3y ago
hmm fck i dont know if i can set the value manually in react-zorm, it kinda relies on the web api
benton
benton3y ago
yeah not sure, never used it
julius
juliusOP3y ago
alright thanks anyways
benton
benton3y ago
worst case, add a hidden select and set that to the dropdown value
julius
juliusOP3y ago
where would i put the select or just a bunch of radios?
benton
benton3y ago
Put the select in the form somewhere but hide it like a native select with the options you need and then use the radix select onChange to set the value of the hidden select box
const hiddenSelect = useRef<HTMLSelectElement()
return (
<form>
<select className='hidden'>
{/*...*/}
</select>
<Select.Root onChange={(value) => hiddenSelect.current.value=value}>
const hiddenSelect = useRef<HTMLSelectElement()
return (
<form>
<select className='hidden'>
{/*...*/}
</select>
<Select.Root onChange={(value) => hiddenSelect.current.value=value}>
something like this
julius
juliusOP3y ago
radix does render a select though
benton
benton3y ago
Hm odd It doesn't here unless I'm crazy https://www.radix-ui.com/docs/primitives/components/select
julius
juliusOP3y ago
hmm strange
julius
juliusOP3y ago
all values in there too - they're just not linked
benton
benton3y ago
hm not sure then
julius
juliusOP3y ago
very strange...
benton
benton3y ago
wait look it's a nested form or am I crazy is the form it's inside your form or one generated by radix?
julius
juliusOP3y ago
only one form in the DOM and it's mine
benton
benton3y ago
idk then
VikingKiller
VikingKiller2y ago
@julius Did you ever figure this one out?
mr_specific
mr_specific12mo ago
@TobyMcCann If it helps, I had this same problem and solved it by passing a name prop to Select.Root.
No description

Did you find this page helpful?