<.link href={~p"<%= schema.route_prefix %>/register"}>Register
| <.link href={~p"<%= schema.route_prefix %>/log_in"}>Log in
"""
end
def mount(%{"token" => token}, _session, socket) do
form = to_form(%{"token" => token}, as: "<%= schema.singular %>")
{:ok, assign(socket, form: form), temporary_assigns: [form: nil]}
end
# Do not log in the <%= schema.singular %> after confirmation to avoid a
# leaked token giving the <%= schema.singular %> access to the account.
def handle_event("confirm_account", %{"<%= schema.singular %>" => %{"token" => token}}, socket) do
case <%= inspect context.alias %>.confirm_<%= schema.singular %>(token) do
{:ok, _} ->
{:noreply,
socket
|> put_flash(:info, "<%= inspect schema.alias %> confirmed successfully.")
|> redirect(to: ~p"/")}
:error ->
# If there is a current <%= schema.singular %> and the account was already confirmed,
# then odds are that the confirmation link was already visited, either
# by some automation or by the <%= schema.singular %> themselves, so we redirect without
# a warning message.
case socket.assigns do
%{current_<%= schema.singular %>: %{confirmed_at: confirmed_at}} when not is_nil(confirmed_at) ->
{:noreply, redirect(socket, to: ~p"/")}
%{} ->
{:noreply,
socket
|> put_flash(:error, "<%= inspect schema.alias %> confirmation link is invalid or it has expired.")
|> redirect(to: ~p"/")}
end
end
end
end