chore: section 12 closed, had to do with map and atoms
This commit is contained in:
@@ -2,6 +2,7 @@ defmodule BDS.Rendering.ListArchive do
|
||||
@moduledoc false
|
||||
|
||||
alias BDS.I18n
|
||||
alias BDS.MapUtils
|
||||
alias BDS.Persistence
|
||||
alias BDS.Rendering.LinksAndLanguages
|
||||
alias BDS.Rendering.Metadata, as: RenderMetadata
|
||||
@@ -12,18 +13,19 @@ defmodule BDS.Rendering.ListArchive do
|
||||
metadata = RenderMetadata.project_metadata(project_id)
|
||||
template_context = TemplateSelection.template_render_context(project_id)
|
||||
|
||||
language =
|
||||
Map.get(assigns, :language, Map.get(assigns, "language", metadata.main_language || "en"))
|
||||
language = MapUtils.attr(assigns, :language, metadata.main_language || "en")
|
||||
|
||||
main_language = metadata.main_language || language
|
||||
archive_context = Map.get(assigns, :archive_context, Map.get(assigns, "archive_context", %{}))
|
||||
archive_context = MapUtils.attr(assigns, :archive_context, %{})
|
||||
|
||||
canonical_post_paths =
|
||||
LinksAndLanguages.canonical_post_path_by_slug(project_id, main_language)
|
||||
|
||||
canonical_post_paths = LinksAndLanguages.canonical_post_path_by_slug(project_id, main_language)
|
||||
canonical_media_paths = LinksAndLanguages.canonical_media_path_by_source_path(project_id)
|
||||
|
||||
posts =
|
||||
normalize_list_posts(
|
||||
Map.get(assigns, :posts, Map.get(assigns, "posts", [])),
|
||||
MapUtils.attr(assigns, :posts, []),
|
||||
canonical_post_paths,
|
||||
canonical_media_paths,
|
||||
language,
|
||||
@@ -31,7 +33,7 @@ defmodule BDS.Rendering.ListArchive do
|
||||
)
|
||||
|
||||
pagination =
|
||||
normalize_pagination(Map.get(assigns, :pagination, Map.get(assigns, "pagination")), posts)
|
||||
normalize_pagination(MapUtils.attr(assigns, :pagination), posts)
|
||||
|
||||
day_blocks = build_day_blocks(posts)
|
||||
min_date = min_date(posts)
|
||||
@@ -44,15 +46,23 @@ defmodule BDS.Rendering.ListArchive do
|
||||
Map.get(
|
||||
assigns,
|
||||
:language_prefix,
|
||||
Map.get(assigns, "language_prefix", LinksAndLanguages.language_prefix(language, main_language))
|
||||
Map.get(
|
||||
assigns,
|
||||
"language_prefix",
|
||||
LinksAndLanguages.language_prefix(language, main_language)
|
||||
)
|
||||
),
|
||||
page_title: Map.get(assigns, :page_title, Map.get(assigns, "page_title")),
|
||||
page_title: MapUtils.attr(assigns, :page_title),
|
||||
posts: posts,
|
||||
pico_stylesheet_href:
|
||||
Map.get(
|
||||
assigns,
|
||||
:pico_stylesheet_href,
|
||||
Map.get(assigns, "pico_stylesheet_href", RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme))
|
||||
Map.get(
|
||||
assigns,
|
||||
"pico_stylesheet_href",
|
||||
RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme)
|
||||
)
|
||||
),
|
||||
html_theme_attribute:
|
||||
Map.get(
|
||||
@@ -66,7 +76,8 @@ defmodule BDS.Rendering.ListArchive do
|
||||
calendar_initial_year: calendar_initial_year_from_posts(posts),
|
||||
calendar_initial_month: calendar_initial_month_from_posts(posts),
|
||||
archive_context: normalized_archive_context,
|
||||
show_archive_range_heading: show_archive_range_heading?(normalized_archive_context, day_blocks),
|
||||
show_archive_range_heading:
|
||||
show_archive_range_heading?(normalized_archive_context, day_blocks),
|
||||
min_date: min_date,
|
||||
max_date: max_date,
|
||||
is_list_page: true,
|
||||
@@ -91,25 +102,32 @@ defmodule BDS.Rendering.ListArchive do
|
||||
def not_found_assigns(project_id, assigns) do
|
||||
metadata = RenderMetadata.project_metadata(project_id)
|
||||
|
||||
language =
|
||||
Map.get(assigns, :language, Map.get(assigns, "language", metadata.main_language || "en"))
|
||||
language = MapUtils.attr(assigns, :language, metadata.main_language || "en")
|
||||
|
||||
main_language = metadata.main_language || language
|
||||
|
||||
%{
|
||||
page_title: Map.get(assigns, :page_title, Map.get(assigns, "page_title", "404")),
|
||||
page_title: MapUtils.attr(assigns, :page_title, "404"),
|
||||
language: language,
|
||||
language_prefix:
|
||||
Map.get(
|
||||
assigns,
|
||||
:language_prefix,
|
||||
Map.get(assigns, "language_prefix", LinksAndLanguages.language_prefix(language, main_language))
|
||||
Map.get(
|
||||
assigns,
|
||||
"language_prefix",
|
||||
LinksAndLanguages.language_prefix(language, main_language)
|
||||
)
|
||||
),
|
||||
pico_stylesheet_href:
|
||||
Map.get(
|
||||
assigns,
|
||||
:pico_stylesheet_href,
|
||||
Map.get(assigns, "pico_stylesheet_href", RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme))
|
||||
Map.get(
|
||||
assigns,
|
||||
"pico_stylesheet_href",
|
||||
RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme)
|
||||
)
|
||||
),
|
||||
html_theme_attribute:
|
||||
Map.get(
|
||||
@@ -143,20 +161,27 @@ defmodule BDS.Rendering.ListArchive do
|
||||
}
|
||||
end
|
||||
|
||||
defp normalize_list_posts(posts, canonical_post_paths, canonical_media_paths, language, template_context) do
|
||||
defp normalize_list_posts(
|
||||
posts,
|
||||
canonical_post_paths,
|
||||
canonical_media_paths,
|
||||
language,
|
||||
template_context
|
||||
) do
|
||||
Enum.map(posts, fn post ->
|
||||
post_record = PostRendering.load_post_record(post)
|
||||
|
||||
raw_content =
|
||||
Map.get(
|
||||
post,
|
||||
:content,
|
||||
Map.get(post, "content", Map.get(post, :excerpt, Map.get(post, "excerpt", "")))
|
||||
MapUtils.attr(post, :excerpt, "")
|
||||
)
|
||||
|
||||
%{
|
||||
id: Map.get(post, :id, Map.get(post, "id")),
|
||||
slug: Map.get(post, :slug, Map.get(post, "slug")),
|
||||
title: Map.get(post, :title, Map.get(post, "title")),
|
||||
id: MapUtils.attr(post, :id),
|
||||
slug: MapUtils.attr(post, :slug),
|
||||
title: MapUtils.attr(post, :title),
|
||||
content:
|
||||
PostRendering.render_post_content(
|
||||
raw_content,
|
||||
@@ -166,29 +191,30 @@ defmodule BDS.Rendering.ListArchive do
|
||||
template_context
|
||||
),
|
||||
raw_content: raw_content,
|
||||
excerpt:
|
||||
Map.get(post, :excerpt, Map.get(post, "excerpt", Map.get(post_record || %{}, :excerpt))),
|
||||
author: Map.get(post, :author, Map.get(post, "author", Map.get(post_record || %{}, :author))),
|
||||
excerpt: MapUtils.attr(post, :excerpt, Map.get(post_record || %{}, :excerpt)),
|
||||
author: MapUtils.attr(post, :author, Map.get(post_record || %{}, :author)),
|
||||
language:
|
||||
Map.get(
|
||||
post,
|
||||
:language,
|
||||
Map.get(post, "language", Map.get(post_record || %{}, :language))
|
||||
Map.get(post_record || %{}, :language)
|
||||
),
|
||||
published_at:
|
||||
Map.get(post, :published_at, Map.get(post, "published_at", Map.get(post_record || %{}, :published_at))),
|
||||
created_at:
|
||||
Map.get(post, :created_at, Map.get(post, "created_at", Map.get(post_record || %{}, :created_at))),
|
||||
updated_at:
|
||||
Map.get(post, :updated_at, Map.get(post, "updated_at", Map.get(post_record || %{}, :updated_at))),
|
||||
tags: Map.get(post, :tags, Map.get(post, "tags", Map.get(post_record || %{}, :tags, []))) || [],
|
||||
MapUtils.attr(post, :published_at, Map.get(post_record || %{}, :published_at)),
|
||||
created_at: MapUtils.attr(post, :created_at, Map.get(post_record || %{}, :created_at)),
|
||||
updated_at: MapUtils.attr(post, :updated_at, Map.get(post_record || %{}, :updated_at)),
|
||||
tags: MapUtils.attr(post, :tags, Map.get(post_record || %{}, :tags, [])) || [],
|
||||
categories:
|
||||
Map.get(post, :categories, Map.get(post, "categories", Map.get(post_record || %{}, :categories, []))) || [],
|
||||
MapUtils.attr(post, :categories, Map.get(post_record || %{}, :categories, [])) || [],
|
||||
template_slug:
|
||||
Map.get(post, :template_slug, Map.get(post, "template_slug", Map.get(post_record || %{}, :template_slug))),
|
||||
MapUtils.attr(post, :template_slug, Map.get(post_record || %{}, :template_slug)),
|
||||
do_not_translate:
|
||||
Map.get(post, :do_not_translate, Map.get(post, "do_not_translate", Map.get(post_record || %{}, :do_not_translate, false))),
|
||||
href: Map.get(post, :href, Map.get(post, "href")),
|
||||
MapUtils.attr(
|
||||
post,
|
||||
:do_not_translate,
|
||||
Map.get(post_record || %{}, :do_not_translate, false)
|
||||
),
|
||||
href: MapUtils.attr(post, :href),
|
||||
show_title: true,
|
||||
linked_media: [],
|
||||
outgoing_links: [],
|
||||
@@ -214,24 +240,20 @@ defmodule BDS.Rendering.ListArchive do
|
||||
|
||||
defp normalize_pagination(%{} = pagination, posts) do
|
||||
total_items =
|
||||
Map.get(pagination, :total_items, Map.get(pagination, "total_items", length(posts)))
|
||||
MapUtils.attr(pagination, :total_items, length(posts))
|
||||
|
||||
items_per_page =
|
||||
Map.get(pagination, :items_per_page, Map.get(pagination, "items_per_page", total_items))
|
||||
MapUtils.attr(pagination, :items_per_page, total_items)
|
||||
|
||||
%{
|
||||
current_page: Map.get(pagination, :current_page, Map.get(pagination, "current_page", 1)),
|
||||
total_pages: Map.get(pagination, :total_pages, Map.get(pagination, "total_pages", 1)),
|
||||
current_page: MapUtils.attr(pagination, :current_page, 1),
|
||||
total_pages: MapUtils.attr(pagination, :total_pages, 1),
|
||||
total_items: total_items,
|
||||
items_per_page: items_per_page,
|
||||
has_prev_page:
|
||||
Map.get(pagination, :has_prev_page, Map.get(pagination, "has_prev_page", false)),
|
||||
prev_page_href:
|
||||
Map.get(pagination, :prev_page_href, Map.get(pagination, "prev_page_href", "")),
|
||||
has_next_page:
|
||||
Map.get(pagination, :has_next_page, Map.get(pagination, "has_next_page", false)),
|
||||
next_page_href:
|
||||
Map.get(pagination, :next_page_href, Map.get(pagination, "next_page_href", ""))
|
||||
has_prev_page: MapUtils.attr(pagination, :has_prev_page, false),
|
||||
prev_page_href: MapUtils.attr(pagination, :prev_page_href, ""),
|
||||
has_next_page: MapUtils.attr(pagination, :has_next_page, false),
|
||||
next_page_href: MapUtils.attr(pagination, :next_page_href, "")
|
||||
}
|
||||
end
|
||||
|
||||
@@ -239,11 +261,11 @@ defmodule BDS.Rendering.ListArchive do
|
||||
|
||||
defp normalize_archive_context(%{} = archive_context) do
|
||||
%{
|
||||
kind: Map.get(archive_context, :kind, Map.get(archive_context, "kind")),
|
||||
name: Map.get(archive_context, :name, Map.get(archive_context, "name")),
|
||||
month: Map.get(archive_context, :month, Map.get(archive_context, "month")),
|
||||
year: Map.get(archive_context, :year, Map.get(archive_context, "year")),
|
||||
day: Map.get(archive_context, :day, Map.get(archive_context, "day"))
|
||||
kind: MapUtils.attr(archive_context, :kind),
|
||||
name: MapUtils.attr(archive_context, :name),
|
||||
month: MapUtils.attr(archive_context, :month),
|
||||
year: MapUtils.attr(archive_context, :year),
|
||||
day: MapUtils.attr(archive_context, :day)
|
||||
}
|
||||
end
|
||||
|
||||
@@ -251,7 +273,12 @@ defmodule BDS.Rendering.ListArchive do
|
||||
grouped_blocks =
|
||||
posts
|
||||
|> Enum.filter(&is_integer(Map.get(&1, :created_at)))
|
||||
|> Enum.group_by(&(Map.get(&1, :created_at) |> Persistence.from_unix_ms!() |> DateTime.to_date() |> Date.to_iso8601()))
|
||||
|> Enum.group_by(
|
||||
&(Map.get(&1, :created_at)
|
||||
|> Persistence.from_unix_ms!()
|
||||
|> DateTime.to_date()
|
||||
|> Date.to_iso8601())
|
||||
)
|
||||
|> Enum.sort_by(fn {label, _posts} -> label end)
|
||||
|
||||
grouped_blocks
|
||||
@@ -287,9 +314,13 @@ defmodule BDS.Rendering.ListArchive do
|
||||
defp show_archive_range_heading?(%{kind: "date"}, _day_blocks), do: true
|
||||
defp show_archive_range_heading?(_archive_context, _day_blocks), do: false
|
||||
|
||||
defp calendar_initial_year_from_posts([post | _rest]), do: RenderMetadata.calendar_initial_year(post)
|
||||
defp calendar_initial_year_from_posts([post | _rest]),
|
||||
do: RenderMetadata.calendar_initial_year(post)
|
||||
|
||||
defp calendar_initial_year_from_posts([]), do: nil
|
||||
|
||||
defp calendar_initial_month_from_posts([post | _rest]), do: RenderMetadata.calendar_initial_month(post)
|
||||
defp calendar_initial_month_from_posts([post | _rest]),
|
||||
do: RenderMetadata.calendar_initial_month(post)
|
||||
|
||||
defp calendar_initial_month_from_posts([]), do: nil
|
||||
end
|
||||
|
||||
@@ -5,6 +5,7 @@ defmodule BDS.Rendering.PostRendering do
|
||||
alias BDS.Rendering.LinksAndLanguages
|
||||
alias BDS.Rendering.Metadata, as: RenderMetadata
|
||||
alias BDS.Rendering.TemplateSelection
|
||||
alias BDS.MapUtils
|
||||
alias BDS.Posts.Post
|
||||
alias BDS.Posts.Translation
|
||||
alias BDS.Repo
|
||||
@@ -13,8 +14,7 @@ defmodule BDS.Rendering.PostRendering do
|
||||
metadata = RenderMetadata.project_metadata(project_id)
|
||||
template_context = TemplateSelection.template_render_context(project_id)
|
||||
|
||||
language =
|
||||
Map.get(assigns, :language, Map.get(assigns, "language", metadata.main_language || "en"))
|
||||
language = MapUtils.attr(assigns, :language, metadata.main_language || "en")
|
||||
|
||||
main_language = metadata.main_language || language
|
||||
post_record = load_post_record(assigns)
|
||||
@@ -22,12 +22,27 @@ defmodule BDS.Rendering.PostRendering do
|
||||
post_id = canonical_post_id(post_record, assigns)
|
||||
post_categories = Map.get(post_record || %{}, :categories, []) || []
|
||||
post_tags = Map.get(post_record || %{}, :tags, []) || []
|
||||
canonical_post_paths = LinksAndLanguages.canonical_post_path_by_slug(project_id, main_language)
|
||||
|
||||
canonical_post_paths =
|
||||
LinksAndLanguages.canonical_post_path_by_slug(project_id, main_language)
|
||||
|
||||
canonical_media_paths = LinksAndLanguages.canonical_media_path_by_source_path(project_id)
|
||||
raw_content = Map.get(assigns, :content, Map.get(assigns, "content"))
|
||||
rendered_content = render_post_content(raw_content, canonical_post_paths, canonical_media_paths, language, template_context)
|
||||
incoming_links = LinksAndLanguages.link_contexts(project_id, post_id, :incoming, main_language)
|
||||
outgoing_links = LinksAndLanguages.link_contexts(project_id, post_id, :outgoing, main_language)
|
||||
raw_content = MapUtils.attr(assigns, :content)
|
||||
|
||||
rendered_content =
|
||||
render_post_content(
|
||||
raw_content,
|
||||
canonical_post_paths,
|
||||
canonical_media_paths,
|
||||
language,
|
||||
template_context
|
||||
)
|
||||
|
||||
incoming_links =
|
||||
LinksAndLanguages.link_contexts(project_id, post_id, :incoming, main_language)
|
||||
|
||||
outgoing_links =
|
||||
LinksAndLanguages.link_contexts(project_id, post_id, :outgoing, main_language)
|
||||
|
||||
post_assigns =
|
||||
assigns
|
||||
@@ -40,19 +55,27 @@ defmodule BDS.Rendering.PostRendering do
|
||||
Map.get(
|
||||
assigns,
|
||||
:language_prefix,
|
||||
Map.get(assigns, "language_prefix", LinksAndLanguages.language_prefix(language, main_language))
|
||||
Map.get(
|
||||
assigns,
|
||||
"language_prefix",
|
||||
LinksAndLanguages.language_prefix(language, main_language)
|
||||
)
|
||||
),
|
||||
page_title:
|
||||
Map.get(
|
||||
assigns,
|
||||
:page_title,
|
||||
Map.get(assigns, "page_title", Map.get(assigns, :title, Map.get(assigns, "title")))
|
||||
MapUtils.attr(assigns, :title)
|
||||
),
|
||||
pico_stylesheet_href:
|
||||
Map.get(
|
||||
assigns,
|
||||
:pico_stylesheet_href,
|
||||
Map.get(assigns, "pico_stylesheet_href", RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme))
|
||||
Map.get(
|
||||
assigns,
|
||||
"pico_stylesheet_href",
|
||||
RenderMetadata.default_pico_stylesheet_href(metadata.pico_theme)
|
||||
)
|
||||
),
|
||||
html_theme_attribute:
|
||||
Map.get(
|
||||
@@ -77,7 +100,7 @@ defmodule BDS.Rendering.PostRendering do
|
||||
end
|
||||
|
||||
def load_post_record(assigns) do
|
||||
case Map.get(assigns, :id, Map.get(assigns, "id")) do
|
||||
case MapUtils.attr(assigns, :id) do
|
||||
nil -> nil
|
||||
post_id -> Repo.get(Post, post_id) || Repo.get(Translation, post_id)
|
||||
end
|
||||
@@ -89,17 +112,33 @@ defmodule BDS.Rendering.PostRendering do
|
||||
|
||||
defp canonical_post_id(%Translation{translation_for: post_id}, _assigns), do: post_id
|
||||
defp canonical_post_id(%Post{id: post_id}, _assigns), do: post_id
|
||||
defp canonical_post_id(_post_record, assigns), do: Map.get(assigns, :id, Map.get(assigns, "id"))
|
||||
defp canonical_post_id(_post_record, assigns), do: MapUtils.attr(assigns, :id)
|
||||
|
||||
defp post_data_json(assigns, post_record) do
|
||||
id = Map.get(assigns, :id, Map.get(assigns, "id"))
|
||||
id = MapUtils.attr(assigns, :id)
|
||||
|
||||
if is_binary(id) do
|
||||
incoming_links = LinksAndLanguages.link_contexts(Map.get(post_record || %{}, :project_id), canonical_post_id(post_record, assigns), :incoming, Map.get(post_record || %{}, :language))
|
||||
outgoing_links = LinksAndLanguages.link_contexts(Map.get(post_record || %{}, :project_id), canonical_post_id(post_record, assigns), :outgoing, Map.get(post_record || %{}, :language))
|
||||
incoming_links =
|
||||
LinksAndLanguages.link_contexts(
|
||||
Map.get(post_record || %{}, :project_id),
|
||||
canonical_post_id(post_record, assigns),
|
||||
:incoming,
|
||||
Map.get(post_record || %{}, :language)
|
||||
)
|
||||
|
||||
outgoing_links =
|
||||
LinksAndLanguages.link_contexts(
|
||||
Map.get(post_record || %{}, :project_id),
|
||||
canonical_post_id(post_record, assigns),
|
||||
:outgoing,
|
||||
Map.get(post_record || %{}, :language)
|
||||
)
|
||||
|
||||
%{
|
||||
id => post_data_json_value(build_post_context(assigns, post_record, incoming_links, outgoing_links))
|
||||
id =>
|
||||
post_data_json_value(
|
||||
build_post_context(assigns, post_record, incoming_links, outgoing_links)
|
||||
)
|
||||
}
|
||||
else
|
||||
%{}
|
||||
@@ -124,23 +163,23 @@ defmodule BDS.Rendering.PostRendering do
|
||||
|
||||
defp build_post_context(assigns, post_record, incoming_links, outgoing_links) do
|
||||
%{
|
||||
id: Map.get(assigns, :id, Map.get(assigns, "id")),
|
||||
slug: Map.get(assigns, :slug, Map.get(assigns, "slug")),
|
||||
title: Map.get(assigns, :title, Map.get(assigns, "title")),
|
||||
content: Map.get(assigns, :content, Map.get(assigns, "content")),
|
||||
raw_content: Map.get(assigns, :raw_content, Map.get(assigns, "raw_content")),
|
||||
id: MapUtils.attr(assigns, :id),
|
||||
slug: MapUtils.attr(assigns, :slug),
|
||||
title: MapUtils.attr(assigns, :title),
|
||||
content: MapUtils.attr(assigns, :content),
|
||||
raw_content: MapUtils.attr(assigns, :raw_content),
|
||||
excerpt:
|
||||
Map.get(
|
||||
assigns,
|
||||
:excerpt,
|
||||
Map.get(assigns, "excerpt", Map.get(post_record || %{}, :excerpt))
|
||||
Map.get(post_record || %{}, :excerpt)
|
||||
),
|
||||
author: Map.get(post_record || %{}, :author),
|
||||
language:
|
||||
Map.get(
|
||||
assigns,
|
||||
:language,
|
||||
Map.get(assigns, "language", Map.get(post_record || %{}, :language))
|
||||
Map.get(post_record || %{}, :language)
|
||||
),
|
||||
show_title: true,
|
||||
published_at: Map.get(post_record || %{}, :published_at),
|
||||
@@ -152,7 +191,7 @@ defmodule BDS.Rendering.PostRendering do
|
||||
Map.get(
|
||||
post_record || %{},
|
||||
:template_slug,
|
||||
Map.get(assigns, :template_slug, Map.get(assigns, "template_slug"))
|
||||
MapUtils.attr(assigns, :template_slug)
|
||||
),
|
||||
do_not_translate: Map.get(post_record || %{}, :do_not_translate, false),
|
||||
linked_media: [],
|
||||
@@ -161,7 +200,19 @@ defmodule BDS.Rendering.PostRendering do
|
||||
}
|
||||
end
|
||||
|
||||
def render_post_content(content, canonical_post_paths, canonical_media_paths, language, template_context) do
|
||||
Filters.render_markdown(content, canonical_post_paths, canonical_media_paths, language, template_context)
|
||||
def render_post_content(
|
||||
content,
|
||||
canonical_post_paths,
|
||||
canonical_media_paths,
|
||||
language,
|
||||
template_context
|
||||
) do
|
||||
Filters.render_markdown(
|
||||
content,
|
||||
canonical_post_paths,
|
||||
canonical_media_paths,
|
||||
language,
|
||||
template_context
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user