import { FormGroup } from '@admin/components/ui/forms/form-group';
import { FormNumberInput } from '@admin/components/ui/forms/form-number-input';
import { FormSwitch } from '@admin/components/ui/forms/form-switch';

type ServiceFaqFormFieldsProps = {
    data: {
        question: string;
        answer: string;
        sort_order: number;
        is_expanded: boolean;
        status: boolean;
    };
    errors: Partial<Record<'question' | 'answer' | 'sort_order' | 'is_expanded' | 'status', string>>;
    setData: (key: string, value: unknown) => void;
};

export function ServiceFaqFormFields({ data, errors, setData }: ServiceFaqFormFieldsProps) {
    return (
        <>
            <FormGroup
                label="Question"
                error={errors.question}
                inputProps={{
                    value: data.question,
                    onChange: (event) => setData('question', event.target.value),
                    required: true,
                }}
            />

            <FormGroup
                as="textarea"
                label="Answer"
                error={errors.answer}
                inputProps={{
                    value: data.answer,
                    rows: 5,
                    onChange: (event) => setData('answer', event.target.value),
                    required: true,
                }}
            />

            <FormNumberInput
                label="Display order"
                helpText="Lower numbers appear first in the accordion."
                min={0}
                value={data.sort_order}
                error={errors.sort_order}
                required
                onChange={(value) => setData('sort_order', value)}
            />

            <FormSwitch
                id="service-faq-expanded"
                label="Expanded by default"
                checked={data.is_expanded}
                onChange={(event) => setData('is_expanded', event.target.checked)}
            />

            <FormSwitch
                id="service-faq-status"
                label="Published"
                checked={data.status}
                onChange={(event) => setData('status', event.target.checked)}
            />
        </>
    );
}
