2022-08-30 22:32:48 +08:00
|
|
|
defmodule LivebookWeb.Hub.NewLive do
|
2022-08-18 21:34:27 +08:00
|
|
|
use LivebookWeb, :live_view
|
|
|
|
|
2023-02-28 00:06:38 +08:00
|
|
|
alias LivebookWeb.LayoutHelpers
|
2022-08-18 21:34:27 +08:00
|
|
|
alias Phoenix.LiveView.JS
|
|
|
|
|
|
|
|
on_mount LivebookWeb.SidebarHook
|
|
|
|
|
|
|
|
@impl true
|
|
|
|
def mount(_params, _session, socket) do
|
2023-03-08 05:43:52 +08:00
|
|
|
enabled? = Livebook.Config.feature_flag_enabled?(:create_hub)
|
|
|
|
{:ok, assign(socket, selected_type: nil, page_title: "Livebook - Hub", enabled?: enabled?)}
|
2022-08-18 21:34:27 +08:00
|
|
|
end
|
|
|
|
|
2022-10-11 22:27:27 +08:00
|
|
|
@impl true
|
|
|
|
def handle_params(_params, _url, socket), do: {:noreply, socket}
|
|
|
|
|
2022-08-18 21:34:27 +08:00
|
|
|
@impl true
|
2023-03-08 05:43:52 +08:00
|
|
|
def render(%{enabled?: false} = assigns) do
|
|
|
|
~H"""
|
|
|
|
TODO
|
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
2022-08-18 21:34:27 +08:00
|
|
|
def render(assigns) do
|
|
|
|
~H"""
|
2023-02-23 02:34:54 +08:00
|
|
|
<LayoutHelpers.layout current_page="/hub" current_user={@current_user} saved_hubs={@saved_hubs}>
|
2022-10-12 01:06:18 +08:00
|
|
|
<div class="p-4 md:px-12 md:py-7 max-w-screen-md mx-auto space-y-8">
|
2022-08-23 18:38:39 +08:00
|
|
|
<div>
|
2023-02-23 02:34:54 +08:00
|
|
|
<LayoutHelpers.title text="Add Hub" />
|
2022-08-23 18:38:39 +08:00
|
|
|
<p class="mt-4 text-gray-700">
|
|
|
|
Manage your Livebooks in the cloud with Hubs.
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="flex flex-col space-y-4">
|
2022-09-06 05:18:51 +08:00
|
|
|
<h2 class="text-xl text-gray-800 font-medium pb-2 border-b border-gray-200">
|
2022-08-23 18:38:39 +08:00
|
|
|
1. Select your Hub service
|
|
|
|
</h2>
|
|
|
|
|
2022-10-12 01:06:18 +08:00
|
|
|
<div class="grid grid-cols-1 sm:grid-cols-2 gap-4">
|
2022-08-30 22:32:48 +08:00
|
|
|
<.card_item id="fly" selected={@selected_type} title="Fly">
|
2022-08-23 18:38:39 +08:00
|
|
|
<:logo>
|
|
|
|
<%= Phoenix.HTML.raw(File.read!("static/images/fly.svg")) %>
|
|
|
|
</:logo>
|
|
|
|
<:headline>
|
|
|
|
Deploy notebooks to your Fly account.
|
|
|
|
</:headline>
|
|
|
|
</.card_item>
|
|
|
|
|
2022-08-30 22:32:48 +08:00
|
|
|
<.card_item id="enterprise" selected={@selected_type} title="Livebook Enterprise">
|
2022-08-23 18:38:39 +08:00
|
|
|
<:logo>
|
|
|
|
<img
|
2023-02-23 02:34:54 +08:00
|
|
|
src="/images/enterprise.png"
|
2022-08-23 18:38:39 +08:00
|
|
|
class="max-h-full max-w-[75%]"
|
|
|
|
alt="Livebook Enterprise logo"
|
|
|
|
/>
|
|
|
|
</:logo>
|
|
|
|
<:headline>
|
|
|
|
Control access, manage secrets, and deploy notebooks within your team.
|
|
|
|
</:headline>
|
|
|
|
</.card_item>
|
2022-08-18 21:34:27 +08:00
|
|
|
</div>
|
2022-08-23 18:38:39 +08:00
|
|
|
</div>
|
2022-08-18 21:34:27 +08:00
|
|
|
|
2023-02-23 02:34:54 +08:00
|
|
|
<div :if={@selected_type} class="flex flex-col space-y-4">
|
|
|
|
<h2 class="text-xl text-gray-800 font-medium pb-2 border-b border-gray-200">
|
|
|
|
2. Configure your Hub
|
|
|
|
</h2>
|
2022-08-18 21:34:27 +08:00
|
|
|
|
2023-02-23 02:34:54 +08:00
|
|
|
<.live_component
|
|
|
|
:if={@selected_type == "fly"}
|
|
|
|
module={LivebookWeb.Hub.New.FlyComponent}
|
|
|
|
id="fly-form"
|
|
|
|
/>
|
2022-08-23 18:38:39 +08:00
|
|
|
|
2023-02-23 02:34:54 +08:00
|
|
|
<.live_component
|
|
|
|
:if={@selected_type == "enterprise"}
|
|
|
|
module={LivebookWeb.Hub.New.EnterpriseComponent}
|
|
|
|
id="enterprise-form"
|
|
|
|
/>
|
|
|
|
</div>
|
2022-08-18 21:34:27 +08:00
|
|
|
</div>
|
2022-08-23 18:38:39 +08:00
|
|
|
</LayoutHelpers.layout>
|
2022-08-18 21:34:27 +08:00
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
|
|
|
defp card_item(assigns) do
|
|
|
|
~H"""
|
|
|
|
<div
|
|
|
|
id={@id}
|
2023-02-24 02:07:00 +08:00
|
|
|
class="flex flex-col cursor-pointer"
|
2022-08-30 22:32:48 +08:00
|
|
|
phx-click={JS.push("select_type", value: %{value: @id})}
|
2022-08-18 21:34:27 +08:00
|
|
|
>
|
2023-02-24 02:07:00 +08:00
|
|
|
<div class={[
|
|
|
|
"flex items-center justify-center p-6 border-2 rounded-t-2xl h-[150px]",
|
|
|
|
if(@id == @selected, do: "border-gray-200", else: "border-gray-100")
|
|
|
|
]}>
|
2022-08-18 21:34:27 +08:00
|
|
|
<%= render_slot(@logo) %>
|
|
|
|
</div>
|
2023-02-24 02:07:00 +08:00
|
|
|
<div class={[
|
|
|
|
"px-6 py-4 rounded-b-2xl grow",
|
|
|
|
if(@id == @selected, do: "bg-gray-200", else: "bg-gray-100")
|
|
|
|
]}>
|
2022-09-06 05:59:13 +08:00
|
|
|
<p class="text-gray-800 font-semibold cursor-pointer">
|
2022-08-18 21:34:27 +08:00
|
|
|
<%= @title %>
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p class="mt-2 text-sm text-gray-600">
|
|
|
|
<%= render_slot(@headline) %>
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
|
|
|
@impl true
|
2022-08-30 22:32:48 +08:00
|
|
|
def handle_event("select_type", %{"value" => service}, socket) do
|
|
|
|
{:noreply, assign(socket, selected_type: service)}
|
2022-08-18 21:34:27 +08:00
|
|
|
end
|
|
|
|
end
|