memEx/lib/memex_web/templates/user_settings/edit.html.heex

161 lines
5.0 KiB
Plaintext
Raw Normal View History

2023-02-04 20:41:41 -05:00
<div class="mx-auto pb-8 max-w-2xl flex flex-col justify-center items-center text-center space-y-4">
2022-07-25 22:04:10 -04:00
<h1 class="pb-4 title text-primary-400 text-xl">
2022-11-17 22:30:01 -05:00
<%= gettext("settings") %>
2021-09-02 23:32:52 -04:00
</h1>
2022-02-25 21:39:22 -05:00
<hr class="hr" />
2022-05-05 20:55:59 -04:00
<.form
2022-11-16 21:11:02 -05:00
:let={f}
2022-05-05 20:55:59 -04:00
for={@email_changeset}
action={Routes.user_settings_path(@conn, :update)}
class="flex flex-col space-y-4 sm:space-y-0 sm:grid sm:grid-cols-3 sm:gap-4 justify-center items-center"
>
2022-07-25 22:04:10 -04:00
<h3 class="title text-primary-400 text-lg col-span-3">
2022-11-17 22:30:01 -05:00
<%= dgettext("actions", "change email") %>
2022-02-25 21:39:22 -05:00
</h3>
2023-02-04 11:29:06 -05:00
<div
:if={@email_changeset.action && not @email_changeset.valid?()}
class="alert alert-danger col-span-3"
>
<p>
<%= dgettext("errors", "oops, something went wrong! Please check the errors below") %>
</p>
</div>
2022-02-25 21:39:22 -05:00
2022-02-16 22:15:47 -05:00
<%= hidden_input(f, :action, name: "action", value: "update_email") %>
2022-02-25 21:39:22 -05:00
2022-11-17 22:30:01 -05:00
<%= label(f, :email, gettext("email"), class: "title text-lg text-primary-400") %>
2022-02-25 21:39:22 -05:00
<%= email_input(f, :email, required: true, class: "mx-2 my-1 input input-primary col-span-2") %>
<%= error_tag(f, :email, "col-span-3") %>
2022-11-17 22:30:01 -05:00
<%= label(f, :current_password, gettext("current password"),
2022-02-25 21:39:22 -05:00
for: "current_password_for_email",
2022-07-25 22:04:10 -04:00
class: "mx-2 my-1 title text-lg text-primary-400"
2022-02-25 21:39:22 -05:00
) %>
<%= password_input(f, :current_password,
required: true,
name: "current_password",
id: "current_password_for_email",
class: "mx-2 my-1 input input-primary col-span-2"
) %>
<%= error_tag(f, :current_password, "col-span-3") %>
2022-11-17 22:30:01 -05:00
<%= submit(dgettext("actions", "change email"),
2022-02-25 21:39:22 -05:00
class: "mx-auto btn btn-primary col-span-3"
) %>
2022-05-05 20:55:59 -04:00
</.form>
2022-02-25 21:39:22 -05:00
<hr class="hr" />
2022-05-05 20:55:59 -04:00
<.form
2022-11-16 21:11:02 -05:00
:let={f}
2022-05-05 20:55:59 -04:00
for={@password_changeset}
action={Routes.user_settings_path(@conn, :update)}
class="flex flex-col space-y-4 sm:space-y-0 sm:grid sm:grid-cols-3 sm:gap-4 justify-center items-center"
>
2022-07-25 22:04:10 -04:00
<h3 class="title text-primary-400 text-lg col-span-3">
2022-11-17 22:30:01 -05:00
<%= dgettext("actions", "change password") %>
2022-02-25 21:39:22 -05:00
</h3>
2023-02-04 11:29:06 -05:00
<div
:if={@password_changeset.action && not @password_changeset.valid?()}
class="alert alert-danger col-span-3"
>
<p>
<%= dgettext("errors", "Oops, something went wrong! Please check the errors below.") %>
</p>
</div>
2022-02-25 21:39:22 -05:00
2022-02-16 22:15:47 -05:00
<%= hidden_input(f, :action, name: "action", value: "update_password") %>
2022-02-25 21:39:22 -05:00
2022-11-17 22:30:01 -05:00
<%= label(f, :password, gettext("new password"), class: "title text-lg text-primary-400") %>
2022-02-25 21:39:22 -05:00
<%= password_input(f, :password,
required: true,
class: "mx-2 my-1 input input-primary col-span-2"
) %>
<%= error_tag(f, :password, "col-span-3") %>
2022-11-17 22:30:01 -05:00
<%= label(f, :password_confirmation, gettext("confirm new password"),
2022-07-25 22:04:10 -04:00
class: "title text-lg text-primary-400"
2022-02-25 21:39:22 -05:00
) %>
<%= password_input(f, :password_confirmation,
required: true,
class: "mx-2 my-1 input input-primary col-span-2"
) %>
<%= error_tag(f, :password_confirmation, "col-span-3") %>
2022-11-17 22:30:01 -05:00
<%= label(f, :current_password, gettext("current password"),
2022-02-25 21:39:22 -05:00
for: "current_password_for_password",
2022-07-25 22:04:10 -04:00
class: "title text-lg text-primary-400"
2022-02-25 21:39:22 -05:00
) %>
<%= password_input(f, :current_password,
required: true,
name: "current_password",
id: "current_password_for_password",
class: "mx-2 my-1 input input-primary col-span-2"
) %>
<%= error_tag(f, :current_password, "col-span-3") %>
2022-11-17 22:30:01 -05:00
<%= submit(dgettext("actions", "change password"),
2022-02-25 21:39:22 -05:00
class: "mx-auto btn btn-primary col-span-3"
) %>
2022-05-05 20:55:59 -04:00
</.form>
<hr class="hr" />
<.form
2022-11-16 21:11:02 -05:00
:let={f}
2022-05-05 20:55:59 -04:00
for={@locale_changeset}
action={Routes.user_settings_path(@conn, :update)}
class="flex flex-col space-y-4 justify-center items-center"
>
2022-07-25 22:04:10 -04:00
<h3 class="title text-primary-400 text-lg">
2022-11-17 22:30:01 -05:00
<%= dgettext("actions", "change language") %>
2022-05-05 20:55:59 -04:00
</h3>
2023-02-04 11:29:06 -05:00
<div
:if={@locale_changeset.action && not @locale_changeset.valid?()}
class="alert alert-danger"
>
<p>
<%= dgettext("errors", "oops, something went wrong! Please check the errors below") %>
</p>
</div>
2022-05-05 20:55:59 -04:00
<%= hidden_input(f, :action, name: "action", value: "update_locale") %>
2022-11-17 22:30:01 -05:00
<%= select(f, :locale, [{gettext("english"), "en_US"}, {"spanish", "es"}],
2022-05-05 20:55:59 -04:00
class: "mx-2 my-1 min-w-md input input-primary"
) %>
<%= error_tag(f, :locale) %>
2022-11-17 22:30:01 -05:00
<%= submit(dgettext("actions", "change language"),
2022-05-05 20:55:59 -04:00
class: "whitespace-nowrap mx-auto btn btn-primary",
2022-11-17 22:30:01 -05:00
data: [qa: dgettext("prompts", "are you sure you want to change your language?")]
2022-05-05 20:55:59 -04:00
) %>
</.form>
2022-02-25 21:39:22 -05:00
<hr class="hr" />
2022-12-20 19:15:08 -05:00
<div class="flex justify-center items-center">
<.link
href={Routes.export_path(@conn, :export, :json)}
class="mx-4 my-2 btn btn-primary"
target="_blank"
>
<%= dgettext("actions", "export data as json") %>
</.link>
<.link
href={Routes.user_settings_path(@conn, :delete, @current_user)}
method={:delete}
class="mx-4 my-2 btn btn-alert"
data-confirm={dgettext("prompts", "are you sure you want to delete your account?")}
>
<%= dgettext("actions", "delete user") %>
</.link>
</div>
2022-02-16 22:15:47 -05:00
</div>