{
  "$schema": "https://ui.shadcn.com/schema/registry-item.json",
  "name": "p-form-1",
  "description": "Input in a form",
  "registryDependencies": [
    "@coss/button",
    "@coss/field",
    "@coss/form",
    "@coss/input"
  ],
  "files": [
    {
      "path": "registry/default/particles/p-form-1.tsx",
      "content": "\"use client\";\n\nimport type { FormEvent } from \"react\";\nimport { useState } from \"react\";\nimport { Button } from \"@/registry/default/ui/button\";\nimport { Field, FieldError, FieldLabel } from \"@/registry/default/ui/field\";\nimport { Form } from \"@/registry/default/ui/form\";\nimport { Input } from \"@/registry/default/ui/input\";\n\nexport default function Particle() {\n  const [loading, setLoading] = useState(false);\n  const onSubmit = async (e: FormEvent<HTMLFormElement>) => {\n    e.preventDefault();\n    const formData = new FormData(e.currentTarget);\n    setLoading(true);\n    await new Promise((r) => setTimeout(r, 800));\n    setLoading(false);\n    alert(`Email: ${formData.get(\"email\") || \"\"}`);\n  };\n\n  return (\n    <Form className=\"max-w-64\" onSubmit={onSubmit}>\n      <Field name=\"email\">\n        <FieldLabel>Email</FieldLabel>\n        <Input placeholder=\"you@example.com\" required type=\"email\" />\n        <FieldError>Please enter a valid email.</FieldError>\n      </Field>\n      <Button loading={loading} type=\"submit\">\n        Submit\n      </Button>\n    </Form>\n  );\n}\n",
      "type": "registry:block"
    }
  ],
  "meta": {
    "className": "**:data-[slot=preview]:w-full **:data-[slot=preview]:max-w-64"
  },
  "categories": [
    "button",
    "field",
    "form",
    "input"
  ],
  "type": "registry:block"
}