livebook/lib/livebook_web/live/user_component.ex
Cristine Guadelupe 29b712917e
ZTA - user identity (#2015)
* Get user identity

* Moves current_user_id to identity_data

* Renames cookies to session_identity

* Keep zta keys in the state

* User id from GoogleIap

* Update cloudflare.ex

* Update googleiap.ex

* Email only for ZTA

* Get the current_user_id from the identity_data

* Applying suggestions

* Applying suggestions

* Fix verify_token

---------

Co-authored-by: José Valim <jose.valim@gmail.com>
2023-06-29 23:10:00 +02:00

97 lines
2.7 KiB
Elixir

defmodule LivebookWeb.UserComponent do
use LivebookWeb, :live_component
import LivebookWeb.UserHelpers
alias Livebook.EctoTypes.HexColor
alias Livebook.Users
@impl true
def update(assigns, socket) do
socket = assign(socket, assigns)
user = socket.assigns.user
changeset = Users.change_user(user)
{:ok, assign(socket, changeset: changeset, user: user)}
end
@impl true
def render(assigns) do
~H"""
<div class="p-6 flex flex-col space-y-5">
<h3 class="text-2xl font-semibold text-gray-800">
User profile
</h3>
<div class="flex justify-center">
<.user_avatar user={@user} class="h-20 w-20" text_class="text-3xl" />
</div>
<.form
:let={f}
for={@changeset}
phx-submit={@on_save |> JS.push("save")}
phx-change="validate"
phx-target={@myself}
id="user_form"
phx-hook="UserForm"
>
<div class="flex flex-col space-y-5">
<.text_field
field={f[:name]}
label="Display name"
spellcheck="false"
disabled={Livebook.Config.identity_readonly?()}
/>
<%= if @user.email do %>
<.text_field field={f[:email]} label="email" spellcheck="false" disabled="true" />
<% end %>
<.hex_color_field
field={f[:hex_color]}
label="Cursor color"
randomize={JS.push("randomize_color", target: @myself)}
/>
<button
class="button-base button-blue flex space-x-1 justify-center items-center"
type="submit"
disabled={not @changeset.valid?}
>
<.remix_icon icon="save-line" />
<span>Save</span>
</button>
</div>
</.form>
</div>
"""
end
@impl true
def handle_event("randomize_color", %{}, socket) do
hex_color = HexColor.random(except: [socket.assigns.user.hex_color])
handle_event("validate", %{"user" => %{"hex_color" => hex_color}}, socket)
end
def handle_event("validate", %{"user" => params}, socket) do
changeset =
socket.assigns.user
|> Users.change_user(params)
|> Map.put(:action, :validate)
user =
if changeset.valid? do
Ecto.Changeset.apply_action!(changeset, :update)
else
socket.assigns.user
end
{:noreply, assign(socket, changeset: changeset, user: user)}
end
def handle_event("save", %{"user" => params}, socket) do
case Users.update_user(socket.assigns.user, params) do
{:ok, user} ->
{:noreply, assign(socket, changeset: Users.change_user(user), user: user)}
{:error, changeset} ->
{:noreply, assign(socket, changeset: changeset)}
end
end
end