generate excerpt from <!-- more --> placeholder
This commit is contained in:
parent
ad0d130fc8
commit
106f86521c
4 changed files with 46 additions and 40 deletions
|
@ -47,8 +47,8 @@
|
||||||
@apply flex md:flex-row lg:flex-col mb-6 lg:mb-0;
|
@apply flex md:flex-row lg:flex-col mb-6 lg:mb-0;
|
||||||
}
|
}
|
||||||
|
|
||||||
& .menu {
|
& ul.menu {
|
||||||
@apply flex-1;
|
@apply m-0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -102,6 +102,16 @@ defmodule Chiya.Notes.Note do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def note_excerpt(note_content) do
|
||||||
|
if String.contains?(note_content, "<!-- more -->") do
|
||||||
|
note_content
|
||||||
|
|> String.split("<!-- more -->")
|
||||||
|
|> List.first()
|
||||||
|
else
|
||||||
|
String.slice(note_content, 0..150) <> ".."
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
@doc false
|
@doc false
|
||||||
def changeset(note, attrs) do
|
def changeset(note, attrs) do
|
||||||
# if you need to have a preloaded note here,
|
# if you need to have a preloaded note here,
|
||||||
|
|
|
@ -72,11 +72,9 @@
|
||||||
|
|
||||||
<main id="site-content" class="container print:hidden">
|
<main id="site-content" class="container print:hidden">
|
||||||
<aside id="primary-sidebar">
|
<aside id="primary-sidebar">
|
||||||
<nav class="prose">
|
<nav class="prose max-w-none">
|
||||||
<div class="menu">
|
<h3>Channels</h3>
|
||||||
<strong>Channels</strong>
|
<ul class="menu">
|
||||||
|
|
||||||
<ul>
|
|
||||||
<%= for channel <- @channels do %>
|
<%= for channel <- @channels do %>
|
||||||
<li>
|
<li>
|
||||||
<a href={~p"/channel/#{channel.slug}"}>
|
<a href={~p"/channel/#{channel.slug}"}>
|
||||||
|
@ -85,17 +83,13 @@
|
||||||
</li>
|
</li>
|
||||||
<% end %>
|
<% end %>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="menu">
|
<h3>Elsewhere</h3>
|
||||||
<strong>Elsewhere</strong>
|
<ul class="menu">
|
||||||
|
|
||||||
<ul>
|
|
||||||
<%= for identity <- @public_identities do %>
|
<%= for identity <- @public_identities do %>
|
||||||
<li><a href={identity.url}><%= identity.name %></a></li>
|
<li><a href={identity.url}><%= identity.name %></a></li>
|
||||||
<% end %>
|
<% end %>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
|
||||||
</nav>
|
</nav>
|
||||||
</aside>
|
</aside>
|
||||||
|
|
||||||
|
|
|
@ -1,28 +1,30 @@
|
||||||
<section class="note-list default stack">
|
<section class="note-list default stack">
|
||||||
<%= for note <- assigns.notes do %>
|
<%= for note <- assigns.notes do %>
|
||||||
<article>
|
<article class="prose max-w-none">
|
||||||
<a href={~p"/note/#{note.slug}"} class="block">
|
|
||||||
<header class="flex flex-row items-center gap-1">
|
<header class="flex flex-row items-center gap-1">
|
||||||
<span class="text-theme-primary text-lg font-semibold leading-8 flex-1">
|
<span class="text-theme-primary text-lg font-semibold leading-8 flex-1">
|
||||||
|
<a href={~p"/note/#{note.slug}"}>
|
||||||
<%= note.name %>
|
<%= note.name %>
|
||||||
</span>
|
</a>
|
||||||
<span class="text-theme-base/75 text-sm">
|
|
||||||
<%= pretty_date(note.published_at) %>
|
|
||||||
</span>
|
</span>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<%= if assigns.show_content do %>
|
<%= if assigns.show_content do %>
|
||||||
<p class="text-theme-base">
|
<p class="text-theme-base mb-3">
|
||||||
<%= String.slice(note.content, 0..150) %>
|
<%= Chiya.Notes.Note.note_excerpt(note.content) %>
|
||||||
</p>
|
</p>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
|
<footer class="flex">
|
||||||
|
<span class="text-theme-base/75 flex-1">
|
||||||
|
<%= pretty_date(note.published_at) %>
|
||||||
|
</span>
|
||||||
<%= if not Enum.empty?(note.tags) do %>
|
<%= if not Enum.empty?(note.tags) do %>
|
||||||
<span class="inline-block">
|
<span class="inline-block">
|
||||||
<.tag_list note={note} linked={false} />
|
<.tag_list note={note} linked={false} />
|
||||||
</span>
|
</span>
|
||||||
<% end %>
|
<% end %>
|
||||||
</a>
|
</footer>
|
||||||
</article>
|
</article>
|
||||||
<% end %>
|
<% end %>
|
||||||
</section>
|
</section>
|
||||||
|
|
Loading…
Reference in a new issue