More stuff
This commit is contained in:
@@ -8,6 +8,7 @@ defmodule Wish.Wishlist.Item do
|
|||||||
field :url, :string
|
field :url, :string
|
||||||
field :received, :boolean, default: false
|
field :received, :boolean, default: false
|
||||||
field :desire, :integer
|
field :desire, :integer
|
||||||
|
field :image_url, :string
|
||||||
|
|
||||||
timestamps(type: :utc_datetime)
|
timestamps(type: :utc_datetime)
|
||||||
end
|
end
|
||||||
@@ -15,7 +16,7 @@ defmodule Wish.Wishlist.Item do
|
|||||||
@doc false
|
@doc false
|
||||||
def changeset(item, attrs) do
|
def changeset(item, attrs) do
|
||||||
item
|
item
|
||||||
|> cast(attrs, [:title, :description, :url, :received, :desire])
|
|> cast(attrs, [:title, :description, :url, :received, :desire, :image_url])
|
||||||
|> validate_required([:title, :description, :url, :received, :desire])
|
|> validate_required([:url])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
15
lib/wish_web/live/home_live/details.ex
Normal file
15
lib/wish_web/live/home_live/details.ex
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
defmodule WishWeb.HomeLive.Details do
|
||||||
|
use WishWeb, :live_view
|
||||||
|
|
||||||
|
alias Wish.Wishlist
|
||||||
|
|
||||||
|
def mount(_params, _session, socket) do
|
||||||
|
{:ok, socket}
|
||||||
|
end
|
||||||
|
|
||||||
|
def handle_params(%{"id" => id}, _, socket) do
|
||||||
|
{:noreply,
|
||||||
|
socket
|
||||||
|
|> assign(:item, Wishlist.get_item!(id))}
|
||||||
|
end
|
||||||
|
end
|
||||||
10
lib/wish_web/live/home_live/details.html.heex
Normal file
10
lib/wish_web/live/home_live/details.html.heex
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
<.link navigate={~p"/"}>
|
||||||
|
<.icon name="hero-arrow-left" /> Back to list
|
||||||
|
</.link>
|
||||||
|
<.header>
|
||||||
|
<%= @item.title %>
|
||||||
|
</.header>
|
||||||
|
|
||||||
|
<div :if={@item.image_url}>
|
||||||
|
<img src={@item.image_url} />
|
||||||
|
</div>
|
||||||
@@ -2,7 +2,6 @@ defmodule WishWeb.HomeLive.Index do
|
|||||||
use WishWeb, :live_view
|
use WishWeb, :live_view
|
||||||
|
|
||||||
alias Wish.Wishlist
|
alias Wish.Wishlist
|
||||||
alias Wish.Wishlist.Item
|
|
||||||
|
|
||||||
@impl true
|
@impl true
|
||||||
def mount(_params, _session, socket) do
|
def mount(_params, _session, socket) do
|
||||||
|
|||||||
@@ -2,38 +2,25 @@
|
|||||||
Listing Items
|
Listing Items
|
||||||
</.header>
|
</.header>
|
||||||
|
|
||||||
<.table
|
<div class="grid grid-cols-3" id="items" phx-update="stream">
|
||||||
id="items"
|
<div
|
||||||
rows={@streams.items}
|
:for={{dom_id, item} <- @streams.items}
|
||||||
row_click={fn {_id, item} -> JS.navigate(~p"/items/#{item}") end}
|
id={dom_id}
|
||||||
|
phx-click={JS.navigate(~p"/details/#{item}")}
|
||||||
>
|
>
|
||||||
<:col :let={{_id, item}} label="Title"><%= item.title %></:col>
|
<img :if={item.image_url} src={item.image_url} />
|
||||||
<:col :let={{_id, item}} label="Description"><%= item.description %></:col>
|
<%= item.title %>
|
||||||
<:col :let={{_id, item}} label="Url"><%= item.url %></:col>
|
</div>
|
||||||
<:col :let={{_id, item}} label="Desire"><%= item.desire %></:col>
|
|
||||||
<:action :let={{_id, item}}>
|
|
||||||
<div class="sr-only">
|
|
||||||
<.link navigate={~p"/items/#{item}"}>Show</.link>
|
|
||||||
</div>
|
</div>
|
||||||
<.link patch={~p"/items/#{item}/edit"}>Edit</.link>
|
|
||||||
</:action>
|
|
||||||
<:action :let={{id, item}}>
|
|
||||||
<.link
|
|
||||||
phx-click={JS.push("delete", value: %{id: item.id}) |> hide("##{id}")}
|
|
||||||
data-confirm="Are you sure?"
|
|
||||||
>
|
|
||||||
Delete
|
|
||||||
</.link>
|
|
||||||
</:action>
|
|
||||||
</.table>
|
|
||||||
|
|
||||||
<.modal :if={@live_action in [:new, :edit]} id="item-modal" show on_cancel={JS.patch(~p"/items")}>
|
<div class="" id="items" phx-update="stream">
|
||||||
<.live_component
|
<div
|
||||||
module={WishWeb.ItemLive.FormComponent}
|
:for={{dom_id, item} <- @streams.items}
|
||||||
id={@item.id || :new}
|
id={dom_id}
|
||||||
title={@page_title}
|
phx-click={JS.navigate(~p"/details/#{item}")}
|
||||||
action={@live_action}
|
class="flex flex-row h-20"
|
||||||
item={@item}
|
>
|
||||||
patch={~p"/items"}
|
<img :if={item.image_url} src={item.image_url} />
|
||||||
/>
|
<%= item.title %>
|
||||||
</.modal>
|
</div>
|
||||||
|
</div>
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ defmodule WishWeb.ItemLive.FormComponent do
|
|||||||
<.input field={@form[:title]} type="text" label="Title" />
|
<.input field={@form[:title]} type="text" label="Title" />
|
||||||
<.input field={@form[:description]} type="text" label="Description" />
|
<.input field={@form[:description]} type="text" label="Description" />
|
||||||
<.input field={@form[:url]} type="text" label="Url" />
|
<.input field={@form[:url]} type="text" label="Url" />
|
||||||
|
<.input field={@form[:image_url]} type="text" label="Image URL" />
|
||||||
<.input field={@form[:received]} type="checkbox" label="Received" />
|
<.input field={@form[:received]} type="checkbox" label="Received" />
|
||||||
<.input field={@form[:desire]} type="number" label="Desire" />
|
<.input field={@form[:desire]} type="number" label="Desire" />
|
||||||
<:actions>
|
<:actions>
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ defmodule WishWeb.Router do
|
|||||||
pipe_through :browser
|
pipe_through :browser
|
||||||
|
|
||||||
live "/", HomeLive.Index, :index
|
live "/", HomeLive.Index, :index
|
||||||
|
live "/details/:id", HomeLive.Details, :index
|
||||||
end
|
end
|
||||||
|
|
||||||
# Other scopes may use custom stacks.
|
# Other scopes may use custom stacks.
|
||||||
|
|||||||
9
priv/repo/migrations/20231123173824_add_image_url.exs
Normal file
9
priv/repo/migrations/20231123173824_add_image_url.exs
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
defmodule Wish.Repo.Migrations.AddImageUrl do
|
||||||
|
use Ecto.Migration
|
||||||
|
|
||||||
|
def change do
|
||||||
|
alter table("items") do
|
||||||
|
add :image_url, :string
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Reference in New Issue
Block a user