/* * Copyright (C) 2026 Fluxer Contributors * * This file is part of Fluxer. * * Fluxer is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Fluxer is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Fluxer. If not, see . */ /** @jsxRuntime automatic */ /** @jsxImportSource hono/jsx */ export type RadioGroupOrientation = 'vertical' | 'horizontal'; export interface RadioOption { value: string; label: string; disabled?: boolean; } export interface RadioGroupProps { name: string; label?: string; value: string; options: Array; orientation?: RadioGroupOrientation; disabled?: boolean; helperText?: string; error?: string; onChangeScript?: string; } const orientationClasses: Record = { vertical: 'flex-col gap-3', horizontal: 'flex-row gap-6', }; export function RadioGroup({ name, label, value, options, orientation = 'vertical', disabled = false, helperText, error, onChangeScript, }: RadioGroupProps) { const groupId = `${name}-group`; return (
{label && {label}}
{options.map((option) => { const optionId = `${name}-${option.value}`; const isOptionDisabled = disabled || option.disabled; return (
); }