69 lines
2 KiB
Elixir
69 lines
2 KiB
Elixir
defmodule CMSWeb.PostLive do
|
|
@moduledoc false
|
|
use CMSWeb, :live_view
|
|
|
|
alias CMS.Posts
|
|
alias CMS.Posts.Post
|
|
|
|
@impl true
|
|
def handle_params(_params, _uri, %{assigns: %{live_action: :new}} = socket) do
|
|
post = %Post{}
|
|
changeset = Post.changeset(post)
|
|
|
|
socket = assign(socket, post: post, form: to_form(changeset))
|
|
|
|
{:noreply, socket}
|
|
end
|
|
|
|
def handle_params(%{"post_id" => post_id}, _uri, %{assigns: %{live_action: :edit}} = socket) do
|
|
post = Posts.get_post!(post_id)
|
|
|
|
changeset = Post.changeset(post)
|
|
|
|
socket = assign(socket, post: post, form: to_form(changeset))
|
|
|
|
{:noreply, socket}
|
|
end
|
|
|
|
@impl true
|
|
def handle_event("save_post", %{"post" => attrs}, %{assigns: %{live_action: :new}} = socket) do
|
|
socket =
|
|
case Posts.create_post(attrs) do
|
|
{:ok, post} -> push_navigate(socket, to: ~p"/admin/posts/#{post}")
|
|
{:error, changeset} -> assign(socket, form: to_form(changeset))
|
|
end
|
|
|
|
{:noreply, socket}
|
|
end
|
|
|
|
def handle_event("save_post", %{"post" => attrs}, %{assigns: %{post: post, live_action: :edit}} = socket) do
|
|
socket =
|
|
case Posts.update_post(post, attrs) do
|
|
{:ok, post} ->
|
|
assign(socket, post: post, form: post |> Post.changeset() |> to_form())
|
|
|
|
{:error, changeset} ->
|
|
assign(socket, form: to_form(changeset))
|
|
end
|
|
|
|
{:noreply, socket}
|
|
end
|
|
|
|
@impl true
|
|
def render(assigns) do
|
|
~H"""
|
|
<.form for={@form} class="flex flex-col gap-y-2" phx-submit="save_post">
|
|
<.input type="hidden" field={@form[:contents]} />
|
|
<.input class="border-gray-400 rounded" field={@form[:title]} />
|
|
<div id="editor" phx-update="ignore">
|
|
<trix-editor input={@form[:contents].id} class="prose prose-gray max-w-full"></trix-editor>
|
|
</div>
|
|
|
|
<button type="submit" class="self-end">save</button>
|
|
</.form>
|
|
<link rel="stylesheet" type="text/css" href="https://unpkg.com/trix@2.0.8/dist/trix.css" />
|
|
<script defer phx-track-static type="text/javascript" src={~p"/assets/editor.js"}>
|
|
</script>
|
|
"""
|
|
end
|
|
end
|