mirror of
https://github.com/supabase/supabase.git
synced 2026-05-10 19:00:05 -04:00
0facd341a6
## Problem We used to have a `_Shadcn_` suffix for all the shadcn form components because we also had `formik` form components. This is not needed anymore. ## Solution - Remove the suffix - Update all usages
72 lines
2.4 KiB
TypeScript
72 lines
2.4 KiB
TypeScript
import { InputVariants } from '@ui/components/shadcn/ui/input'
|
|
import { HelpCircle } from 'lucide-react'
|
|
import Link from 'next/link'
|
|
import type { Control, FieldPath, FieldValues } from 'react-hook-form'
|
|
import { cn, FormControl, FormField, Input_Shadcn_, Textarea } from 'ui'
|
|
import { Input } from 'ui-patterns/DataInputs/Input'
|
|
import { FormItemLayout } from 'ui-patterns/form/FormItemLayout/FormItemLayout'
|
|
|
|
import type { ServerOption } from './Wrappers.types'
|
|
|
|
interface InputFieldProps<TFieldValues extends FieldValues = FieldValues> {
|
|
option: ServerOption
|
|
control: Control<TFieldValues>
|
|
loading?: boolean
|
|
}
|
|
|
|
const InputField = <
|
|
TFieldValues extends FieldValues = FieldValues,
|
|
TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
|
|
>({
|
|
control,
|
|
option,
|
|
loading = false,
|
|
}: InputFieldProps<TFieldValues>) => {
|
|
return (
|
|
<FormField
|
|
control={control}
|
|
name={option.name as TName}
|
|
defaultValue={(option.defaultValue ?? '') as any}
|
|
render={({ field }) => (
|
|
<FormItemLayout
|
|
name={option.name}
|
|
layout="vertical"
|
|
label={
|
|
<div className="flex items-center space-x-2">
|
|
<p>{option.label}</p>
|
|
{option.urlHelper !== undefined && (
|
|
<Link href={option.urlHelper} target="_blank" rel="noreferrer">
|
|
<span className="sr-only">Documentation</span>
|
|
<HelpCircle
|
|
strokeWidth={2}
|
|
size={14}
|
|
className="text-foreground-light hover:text-foreground cursor-pointer transition"
|
|
/>
|
|
</Link>
|
|
)}
|
|
</div>
|
|
}
|
|
labelOptional={!option.required ? 'Optional' : undefined}
|
|
description={option.description}
|
|
>
|
|
<FormControl>
|
|
{loading ? (
|
|
<span className={cn(InputVariants({ size: 'small' }))}>
|
|
Fetching value from Vault...
|
|
</span>
|
|
) : option.isTextArea ? (
|
|
<Textarea {...field} id={option.name} rows={6} className="input-mono resize-none" />
|
|
) : option.secureEntry ? (
|
|
<Input copy reveal {...field} id={option.name} />
|
|
) : (
|
|
<Input_Shadcn_ {...field} id={option.name} />
|
|
)}
|
|
</FormControl>
|
|
</FormItemLayout>
|
|
)}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export default InputField
|