devel #228

Merged
inhji merged 3 commits from devel into main 2023-07-24 18:44:01 +02:00
9 changed files with 59 additions and 20 deletions

View file

@ -31,6 +31,7 @@ defmodule ChiyaWeb.CoreComponents do
end
attr :class, :string, default: nil
def darkmode_toggle(assigns) do
~H"""
<.link href="#" id="dark-mode-toggle" class={["text-sm leading-6", @class]}>

View file

@ -4,12 +4,7 @@
</.error>
<.input field={f[:name]} type="text" />
<.input field={f[:content]}
type="textarea"
label="Content"
rows="15"
class="font-mono"
/>
<.input field={f[:content]} type="textarea" label="Content" rows="15" class="font-mono" />
<.input field={f[:slug]} type="text" label="Slug" />
<.input field={f[:published_at]} type="datetime-local" label="Published at" />
<.input

View file

@ -1,6 +1,5 @@
<section class="max-w-2xl mx-auto">
<article class="h-card hcard">
<section class="flex gap-3">
<img
class="rounded-lg block text-center w-28 h-28 | u-photo"
@ -10,7 +9,6 @@
<span class="p-name"><%= @user.name %></span>
<:subtitle><%= @user.bio %></:subtitle>
</.header>
</section>
<%= if @note do %>

View file

@ -6,19 +6,22 @@
<%= if @current_user do %>
<section class="max-w-2xl mx-auto mt-8">
<ul class="flex gap-3">
<li><a href={~p"/admin/notes/#{@note}/edit"} class="button">
<.icon name="hero-pencil-square" /> Edit</a></li>
<li>
<a href={~p"/admin/notes/#{@note}/edit"} class="button">
<.icon name="hero-pencil-square" /> Edit
</a>
</li>
<li><a href={~p"/admin/notes/#{@note}"} class="button">Show in Admin</a></li>
</ul>
</section>
<% end %>
<%= if has_outline?(@note) do %>
<aside class="max-w-2xl mx-auto mt-8 prose prose-gruvbox">
<div class="bg-theme-background1 rounded p-2">
<%= raw(render_outline(@note)) %>
</div>
</aside>
<aside class="max-w-2xl mx-auto mt-8 prose prose-gruvbox">
<div class="bg-theme-background1 rounded p-2">
<%= raw(render_outline(@note)) %>
</div>
</aside>
<% end %>
<section class="mt-8 mx-auto prose prose-gruvbox md:prose-lg lg:prose-xl | p-summary e-content">

View file

@ -11,8 +11,8 @@ defmodule ChiyaWeb.Indie.Micropub do
with {:ok, note_attrs} <- get_attrs(type, properties, channel_id),
{:ok, note} <- Chiya.Notes.create_note(note_attrs) do
create_photos(note, properties)
Logger.info("Note created!")
Logger.info("Note created!")
{:ok, :created, Chiya.Notes.Note.note_url(note)}
else
error ->
@ -23,6 +23,33 @@ defmodule ChiyaWeb.Indie.Micropub do
end
end
def find_note(note_url) do
slug = Chiya.Notes.Note.note_slug(note_url)
Chiya.Notes.get_note_preloaded_by_slug(slug)
end
def update_note(note, replace, add, _delete) do
settings = Chiya.Site.get_settings()
channel_id = settings.micropub_channel_id
properties =
%{}
|> Enum.into(replace)
|> Enum.into(add)
with {:ok, note_attrs} <- get_attrs("entry", properties, channel_id),
{:ok, note} <- Chiya.Notes.update_note(note, note_attrs) do
Logger.info("Note updated!")
{:ok, note}
else
error ->
Logger.error("Error occurred while creating note from micropub:")
Logger.error(inspect(error))
{:error, :invalid_request}
end
end
defp create_photos(note, properties) do
properties
|> Props.get_photos()

View file

@ -41,8 +41,14 @@ defmodule ChiyaWeb.Indie.MicropubHandler do
end
@impl true
def handle_update(_, _, _, _, _) do
{:error, :insufficient_scope}
def handle_update(url, replace, add, delete, access_token) do
with :ok <- Micropub.verify_token(access_token),
{:ok, note} <- Micropub.find_note(url),
{:ok, note} <- Micropub.update_note(note, replace, add, delete) do
:ok
else
error -> error
end
end
@impl true

View file

@ -4,6 +4,7 @@ defmodule ChiyaWeb.MicropubTest do
alias ChiyaWeb.Indie.Micropub
alias Chiya.Notes.Note
alias Chiya.Channels.Channel
import Chiya.NoteFixtures
@valid_props %{
"content" => ["this is a test"]
@ -22,6 +23,14 @@ defmodule ChiyaWeb.MicropubTest do
end
end
describe "update_note" do
test "updates a note" do
note = note_fixture()
assert :ok = Micropub.update_note(note, %{"content" => ["replaced content"]})
end
end
setup do
{:ok, channel} =
Chiya.Channels.create_channel(%{