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';
import { FileUploadInput } from '@admin/components/ui/forms/file-upload-input';

type TestimonialFormFieldsProps = {
    data: {
        message: string;
        name: string;
        title: string;
        photo: string;
        sort_order: number;
        status: boolean;
    };
    errors: Partial<Record<'message' | 'name' | 'title' | 'photo' | 'sort_order' | 'status', string>>;
    setData: (key: string, value: unknown) => void;
    photoInputId?: string;
};

export function TestimonialFormFields({
    data,
    errors,
    setData,
    photoInputId = 'testimonial-photo',
}: TestimonialFormFieldsProps) {
    return (
        <>
            <FormGroup
                as="textarea"
                label="Message"
                helpText="The quote or review text shown on the site."
                error={errors.message}
                inputProps={{
                    value: data.message,
                    rows: 4,
                    onChange: (event) => setData('message', event.target.value),
                    required: true,
                }}
            />

            <FormGroup
                label="Name"
                error={errors.name}
                inputProps={{
                    value: data.name,
                    onChange: (event) => setData('name', event.target.value),
                    required: true,
                }}
            />

            <FormGroup
                label="Title"
                helpText="Role or company, e.g. CEO, Acme Inc."
                error={errors.title}
                inputProps={{
                    value: data.title,
                    onChange: (event) => setData('title', event.target.value),
                    required: true,
                }}
            />

            <FileUploadInput
                label="Photo (75×75 px recommended)"
                inputId={photoInputId}
                uploadUrl="/admin/api/testimonial/upload_photo"
                accept="image/jpeg,image/png,image/jpg,image/webp"
                previewUrl={data.photo ? `/storage/${data.photo}` : ''}
                previewType="image"
                error={errors.photo}
                onSuccess={(filename) => setData('photo', filename)}
            />

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

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