sendou.ink/app/form/fields/UserSearchFormField.tsx

38 lines
916 B
TypeScript

import { UserSearch } from "~/components/elements/UserSearch";
import type { FormFieldProps } from "../types";
import { FormFieldMessages, useTranslatedTexts } from "./FormFieldWrapper";
import styles from "./UserSearchFormField.module.css";
type UserSearchFormFieldProps = FormFieldProps<"user-search"> & {
value: number | null;
onChange: (value: number | null) => void;
};
export function UserSearchFormField({
name,
label,
bottomText,
error,
required,
value,
onChange,
onBlur,
}: UserSearchFormFieldProps) {
const { translatedLabel } = useTranslatedTexts({
label,
});
return (
<div className={styles.root}>
<UserSearch
initialUserId={value ?? undefined}
onChange={(user) => onChange(user?.id ?? null)}
onBlur={() => onBlur?.()}
label={translatedLabel}
isRequired={required}
/>
<FormFieldMessages name={name} error={error} bottomText={bottomText} />
</div>
);
}