# copied and adapted from https://github.com/surface-ui/surface/blob/master/lib/surface/components/form/email_input.ex
defmodule SupabaseSurface.Components.Form.EmailInput do
@moduledoc """
An input field that let the user enter one or multiple **e-mails**.
Provides a wrapper for Phoenix.HTML.Form's `email_input/3` function.
All options passed via `opts` will be sent to `email_input/3`, `value` and
`class` can be set directly and will override anything in `opts`.
## Examples
```
<EmailInput form="user" field="email" opts={{ autofocus: "autofocus" }}>
```
"""
use Surface.Components.Form.Input
import Phoenix.HTML.Form, only: [email_input: 3]
import Surface.Components.Utils, only: [events_to_opts: 1]
import Surface.Components.Form.Utils
alias Surface.Components.Form.{Label, Field}
prop label, :string, required: true
def render(assigns) do
default_class = get_default_class()
default_class = if is_nil(default_class), do: [], else: default_class
class = default_class ++ ["sbui-input", "sbui-input--medium", "form-input"]
helper_opts = props_to_opts(assigns)
attr_opts = props_to_attr_opts(assigns, [:value, class: class])
event_opts = events_to_opts(assigns)
~F"""
<Field name={@name} class="sbui-formlayout sbui-formlayout--medium sbui-formlayout--responsive">
<div class="sbui-space-row sbui-space-x-2 sbui-formlayout__label-container-horizontal">
<Label :if={@label} class="sbui-formlayout__label">{@label}</Label>
</div>
<div class="sbui-formlayout__content-container-horizontal">
<InputContext assigns={assigns} :let={form: form, field: field}>
<div class="sbui-input-container">
{email_input(form, field, helper_opts ++ attr_opts ++ @opts ++ event_opts)}
</div>
</InputContext>
</div>
</Field>
"""
end
end