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 PartnerFormFieldsProps = {
    data: {
        name: string;
        logo: string;
        sort_order: number;
        status: boolean;
    };
    errors: Partial<Record<'name' | 'logo' | 'sort_order' | 'status', string>>;
    setData: (key: string, value: unknown) => void;
    logoInputId?: string;
};

export function PartnerFormFields({
    data,
    errors,
    setData,
    logoInputId = 'partner-logo',
}: PartnerFormFieldsProps) {
    return (
        <>
            <FormGroup
                label="Name"
                helpText="Partner or sponsor name shown as alt text for the logo."
                error={errors.name}
                inputProps={{
                    value: data.name,
                    onChange: (event) => setData('name', event.target.value),
                    required: true,
                }}
            />

            <FileUploadInput
                label="Logo (150×35 px recommended)"
                inputId={logoInputId}
                uploadUrl="/admin/api/partner/upload_logo"
                accept="image/jpeg,image/png,image/jpg,image/webp,image/svg+xml"
                previewUrl={data.logo ? `/storage/${data.logo}` : ''}
                previewType="image"
                error={errors.logo}
                onSuccess={(filename) => setData('logo', 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="partner-status"
                label="Published"
                checked={data.status}
                onChange={(event) => setData('status', event.target.checked)}
            />
        </>
    );
}
