dotfiles/app/lib/prymn_web/live/server_live/index.html.heex

46 lines
1.4 KiB
Text
Raw Normal View History

2023-06-09 19:13:27 +00:00
<.header>
All available servers to you
<:actions>
<.link patch={~p"/servers/new"}>
<.button>Connect a Server</.button>
</.link>
</:actions>
</.header>
<.table
id="servers"
rows={@streams.servers}
row_click={fn {_id, server} -> JS.navigate(~p"/servers/#{server}") end}
2023-06-19 20:28:24 +00:00
row_indicator={
2023-06-23 07:05:10 +00:00
fn
2023-07-09 16:41:41 +00:00
{_id, %Servers.Server{status: :unregistered}} ->
~H(<span class="text-grey-600">Awaiting registration</span>)
2023-06-23 07:05:10 +00:00
2023-07-09 16:41:41 +00:00
{_id, %Servers.Server{connection_status: nil, status: :registered}} ->
~H(<span class="text-yellow-600">Connecting...</span>)
2023-06-23 07:05:10 +00:00
2023-07-09 16:41:41 +00:00
{_id, %Servers.Server{connection_status: "Connected"}} ->
2023-06-23 07:05:10 +00:00
~H(<span class="text-green-600">Connected</span>)
2023-07-09 16:41:41 +00:00
{_id, %Servers.Server{connection_status: "Disconnected"}} ->
~H(<span class="text-red-600">Disconnected</span>)
2023-06-19 20:28:24 +00:00
end
}
indicator_label="Status"
2023-06-09 19:13:27 +00:00
>
<:col :let={{_id, server}} label="Name"><%= server.name %></:col>
2023-07-09 16:41:41 +00:00
<:col :let={{_id, server}} label="IP"><%= server.public_ip || "N/A" %></:col>
2023-06-09 19:13:27 +00:00
<:action :let={{id, server}}>
<.link
phx-click={JS.push("delete", value: %{id: server.id}) |> hide("##{id}")}
data-confirm="Are you sure?"
>
Delete
</.link>
</:action>
</.table>
2023-06-19 20:28:24 +00:00
<.modal :if={@live_action == :new} id="server-modal" show on_cancel={JS.patch(~p"/servers")}>
<.live_component module={PrymnWeb.ServerLive.NewServer} id={:new} patch={~p"/servers"} />
2023-06-09 19:13:27 +00:00
</.modal>