FormTanstackArray() — ui Function Reference
Architecture documentation for the FormTanstackArray() function in form-tanstack-array.tsx from the ui codebase.
Entity Profile
Dependency Diagram
graph TD 2ddac4dd_3e39_6e59_82f5_bb9f1b2d3b24["FormTanstackArray()"] dfc27144_c7c7_d972_b982_e7453fb39ce2["form-tanstack-array.tsx"] 2ddac4dd_3e39_6e59_82f5_bb9f1b2d3b24 -->|defined in| dfc27144_c7c7_d972_b982_e7453fb39ce2 style 2ddac4dd_3e39_6e59_82f5_bb9f1b2d3b24 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
apps/v4/registry/new-york-v4/examples/form-tanstack-array.tsx lines 46–179
export default function FormTanstackArray() {
const form = useForm({
defaultValues: {
emails: [{ address: "" }],
},
validators: {
onBlur: formSchema,
},
onSubmit: async ({ value }) => {
toast("You submitted the following values:", {
description: (
<pre className="bg-code text-code-foreground mt-2 w-[320px] overflow-x-auto rounded-md p-4">
<code>{JSON.stringify(value, null, 2)}</code>
</pre>
),
position: "bottom-right",
classNames: {
content: "flex flex-col gap-2",
},
style: {
"--border-radius": "calc(var(--radius) + 4px)",
} as React.CSSProperties,
})
},
})
return (
<Card className="w-full sm:max-w-md">
<CardHeader className="border-b">
<CardTitle>Contact Emails</CardTitle>
<CardDescription>Manage your contact email addresses.</CardDescription>
</CardHeader>
<CardContent>
<form
id="form-tanstack-array"
onSubmit={(e) => {
e.preventDefault()
form.handleSubmit()
}}
>
<form.Field name="emails" mode="array">
{(field) => {
const isInvalid =
field.state.meta.isTouched && !field.state.meta.isValid
return (
<FieldSet className="gap-4">
<FieldLegend variant="label">Email Addresses</FieldLegend>
<FieldDescription>
Add up to 5 email addresses where we can contact you.
</FieldDescription>
<FieldGroup className="gap-4">
{field.state.value.map((_, index) => (
<form.Field
key={index}
name={`emails[${index}].address`}
children={(subField) => {
const isSubFieldInvalid =
subField.state.meta.isTouched &&
!subField.state.meta.isValid
return (
<Field
orientation="horizontal"
data-invalid={isSubFieldInvalid}
>
<FieldContent>
<InputGroup>
<InputGroupInput
id={`form-tanstack-array-email-${index}`}
name={subField.name}
value={subField.state.value}
onBlur={subField.handleBlur}
onChange={(e) =>
subField.handleChange(e.target.value)
}
aria-invalid={isSubFieldInvalid}
placeholder="name@example.com"
type="email"
autoComplete="email"
/>
{field.state.value.length > 1 && (
<InputGroupAddon align="inline-end">
Domain
Subdomains
Source
Frequently Asked Questions
What does FormTanstackArray() do?
FormTanstackArray() is a function in the ui codebase, defined in apps/v4/registry/new-york-v4/examples/form-tanstack-array.tsx.
Where is FormTanstackArray() defined?
FormTanstackArray() is defined in apps/v4/registry/new-york-v4/examples/form-tanstack-array.tsx at line 46.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free