we don't need to pass self() on to client functions
This commit is contained in:
@ -3,15 +3,15 @@ defmodule SomethingErlang.Grover do
|
|||||||
|
|
||||||
require Logger
|
require Logger
|
||||||
|
|
||||||
def mount(lv_pid, user, thread_id) do
|
def mount(user, thread_id) do
|
||||||
DynamicSupervisor.start_child(
|
DynamicSupervisor.start_child(
|
||||||
SomethingErlang.Supervisor.Grovers,
|
SomethingErlang.Supervisor.Grovers,
|
||||||
{__MODULE__, [lv_pid, user, thread_id]}
|
{__MODULE__, [self(), user, thread_id]}
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_thread!(lv_pid, thread_id, page_number) do
|
def get_thread!(thread_id, page_number) do
|
||||||
GenServer.call(via(lv_pid), {:show_thread, thread_id, page_number})
|
GenServer.call(via(self()), {:show_thread, thread_id, page_number})
|
||||||
end
|
end
|
||||||
|
|
||||||
def start_link([lv_pid, user, thread_id]) do
|
def start_link([lv_pid, user, thread_id]) do
|
||||||
@ -47,9 +47,9 @@ defmodule SomethingErlang.Grover do
|
|||||||
Logger.debug "received :DOWN from: #{inspect(state.lv_pid)} reason: #{inspect(reason)}"
|
Logger.debug "received :DOWN from: #{inspect(state.lv_pid)} reason: #{inspect(reason)}"
|
||||||
case reason do
|
case reason do
|
||||||
{:shutdown, _} -> {:stop, :normal, state}
|
{:shutdown, _} -> {:stop, :normal, state}
|
||||||
|
:killed -> {:stop, :normal, state}
|
||||||
_ -> {:noreply, state}
|
_ -> {:noreply, state}
|
||||||
end
|
end
|
||||||
|> IO.inspect()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
defp via(lv_pid),
|
defp via(lv_pid),
|
||||||
|
@ -9,13 +9,13 @@ defmodule SomethingErlangWeb.ThreadLive.Show do
|
|||||||
|
|
||||||
@impl true
|
@impl true
|
||||||
def mount(%{"id" => id} = _params, _session, socket) do
|
def mount(%{"id" => id} = _params, _session, socket) do
|
||||||
Grover.mount(self(), socket.assigns.current_user, id)
|
Grover.mount(socket.assigns.current_user, id)
|
||||||
{:ok, socket}
|
{:ok, socket}
|
||||||
end
|
end
|
||||||
|
|
||||||
@impl true
|
@impl true
|
||||||
def handle_params(%{"id" => id, "page" => page}, _, socket) do
|
def handle_params(%{"id" => id, "page" => page}, _, socket) do
|
||||||
thread = Grover.get_thread!(self(), id, page |> String.to_integer())
|
thread = Grover.get_thread!(id, page |> String.to_integer())
|
||||||
{:noreply,
|
{:noreply,
|
||||||
socket
|
socket
|
||||||
|> assign(:thread, thread)}
|
|> assign(:thread, thread)}
|
||||||
@ -40,12 +40,43 @@ defmodule SomethingErlangWeb.ThreadLive.Show do
|
|||||||
|
|
||||||
def user(assigns) do
|
def user(assigns) do
|
||||||
~H"""
|
~H"""
|
||||||
<aside class="userinfo shrink-0 w-[13em]">
|
<aside class="userinfo bg-base-100 shrink-0 w-[13em]">
|
||||||
<h3><%= @info.name %></h3>
|
<h3 class="mb-4"><%= @info.name %></h3>
|
||||||
<div class="title">
|
<div class="title text-sm pr-4">
|
||||||
<%= raw @info.title %>
|
<%= raw @info.title %>
|
||||||
</div>
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
"""
|
"""
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def pagination(assigns) do
|
||||||
|
%{page: page_number, page_count: page_count} = assigns.thread
|
||||||
|
|
||||||
|
first_page_disabled_button = if page_number == 1, do: " btn-disabled", else: ""
|
||||||
|
last_page_disabled_button = if page_number == page_count, do: " btn-disabled", else: ""
|
||||||
|
active_page_button = " btn-active"
|
||||||
|
|
||||||
|
prev_button_target = if page_number >= 1, do: page_number - 1, else: 1
|
||||||
|
next_button_target = if page_number < page_count, do: page_number + 1, else: page_count
|
||||||
|
|
||||||
|
buttons = [
|
||||||
|
%{label: "«", page: 1, special: first_page_disabled_button},
|
||||||
|
%{label: "‹", page: prev_button_target, special: first_page_disabled_button},
|
||||||
|
%{label: "#{page_number}", page: page_number, special: active_page_button},
|
||||||
|
%{label: "›", page: next_button_target, special: last_page_disabled_button},
|
||||||
|
%{label: "»", page: page_count, special: last_page_disabled_button}
|
||||||
|
]
|
||||||
|
|
||||||
|
~H"""
|
||||||
|
<div class="navbar my-4 bg-base-200">
|
||||||
|
<div class="flex-1"></div>
|
||||||
|
<div class="flex-none btn-group">
|
||||||
|
<%= for btn <- buttons do %>
|
||||||
|
<%= live_redirect btn.label, class: "btn btn-sm" <> btn.special,
|
||||||
|
to: Routes.thread_show_path(@socket, :show, @thread.id, page: btn.page) %>
|
||||||
|
<% end %>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
"""
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user