postiz/libraries/react-shared-libraries/src/form/textarea.tsx

64 lines
1.7 KiB
TypeScript

'use client';
import { DetailedHTMLProps, FC, InputHTMLAttributes, useMemo } from 'react';
// @ts-ignore
import clsx from 'clsx';
import { useFormContext } from 'react-hook-form';
import interClass from '../helpers/inter.font';
import { TranslatedLabel } from '../translation/translated-label';
export const Textarea: FC<
DetailedHTMLProps<
InputHTMLAttributes<HTMLTextAreaElement>,
HTMLTextAreaElement
> & {
error?: any;
disableForm?: boolean;
label: string;
name: string;
translationKey?: string;
translationParams?: Record<string, string | number>;
}
> = (props) => {
const {
label,
className,
disableForm,
error,
translationKey,
translationParams,
...rest
} = props;
const form = useFormContext();
const err = useMemo(() => {
if (error) return error;
if (!form || !form.formState.errors[props?.name!]) return;
return form?.formState?.errors?.[props?.name!]?.message! as string;
}, [form?.formState?.errors?.[props?.name!]?.message, error]);
return (
<div
className={clsx(
'flex flex-col gap-[6px]',
props.disabled && 'opacity-50'
)}
>
<div className={`${interClass} text-[14px]`}>
<TranslatedLabel
label={label}
translationKey={translationKey}
translationParams={translationParams}
/>
</div>
<textarea
{...(disableForm ? {} : form.register(props.name))}
className={clsx(
'bg-input min-h-[150px] p-[16px] outline-none border-fifth border rounded-[4px] text-inputText placeholder-inputText',
className
)}
{...rest}
/>
<div className="text-red-400 text-[12px]">{err || <>&nbsp;</>}</div>
</div>
);
};