Renders an input with label and error messages.
A Phoenix.HTML.FormField
may be passed as argument,
which is used to retrieve the input name, id, and values.
Otherwise all attributes may be passed explicitly.
This function accepts all HTML input types, considering that:
type="select"
to render a <select>
tag type="checkbox"
is used exclusively to render boolean values Phoenix.Component.live_file_input/1
See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input for more information. Unsupported types, such as hidden and radio, are best written directly in your templates.
<.input field={@form[:email]} type="email" />
<.input name="my-input" errors={["oh no!"]} />
<.simple_form :let={f} for={%{}} as={:story} class="w-full"> <.input field={f[:field]} id="input-basic-inputs-text" label="Text input" type="text"/> <.input field={f[:field]} id="input-basic-inputs-textarea" label="Textarea input" type="textarea"/> <.input field={f[:field]} id="input-basic-inputs-number" label="Number input" type="number"/> <.input field={f[:field]} id="input-basic-inputs-date" label="Date input" type="date"/> <.input field={f[:field]} id="input-basic-inputs-color" label="Color input" type="color"/> <.input field={f[:field]} id="input-basic-inputs-range" label="Range input" type="range"/> <.input field={f[:field]} id="input-basic-inputs-checkbox" label="Checkbox input" type="checkbox"/> </.simple_form>
<.simple_form :let={f} for={%{}} as={:story} class="w-full"> <.input field={f[:field]} id="input-single-select" label="Select input" type="select" options={["Option 1", "Option 2", "Option 3"]}/> </.simple_form>