mirror of
https://github.com/getzola/zola
synced 2024-12-14 06:12:27 +00:00
Small refactor for serialized page/sections
This commit is contained in:
parent
dc94aa219b
commit
4e3d231ca9
4 changed files with 224 additions and 211 deletions
|
@ -1,7 +1,9 @@
|
||||||
mod file_info;
|
mod file_info;
|
||||||
mod page;
|
mod page;
|
||||||
mod section;
|
mod section;
|
||||||
|
mod ser;
|
||||||
|
|
||||||
pub use self::file_info::FileInfo;
|
pub use self::file_info::FileInfo;
|
||||||
pub use self::page::{Page, SerializingPage};
|
pub use self::page::Page;
|
||||||
pub use self::section::{Section, SerializingSection};
|
pub use self::section::Section;
|
||||||
|
pub use self::ser::{SerializingPage, SerializingSection};
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
use tera::{Tera, Context as TeraContext, Value, Map};
|
use tera::{Tera, Context as TeraContext};
|
||||||
use slug::slugify;
|
use slug::slugify;
|
||||||
use slotmap::{Key};
|
use slotmap::{Key};
|
||||||
|
|
||||||
|
@ -16,129 +16,8 @@ use rendering::{RenderContext, Header, render_content};
|
||||||
use library::Library;
|
use library::Library;
|
||||||
|
|
||||||
use content::file_info::FileInfo;
|
use content::file_info::FileInfo;
|
||||||
|
use content::ser::SerializingPage;
|
||||||
|
|
||||||
/// What we are sending to the templates when rendering them
|
|
||||||
#[derive(Clone, Debug, PartialEq, Serialize)]
|
|
||||||
pub struct SerializingPage<'a> {
|
|
||||||
relative_path: &'a str,
|
|
||||||
content: &'a str,
|
|
||||||
permalink: &'a str,
|
|
||||||
slug: &'a str,
|
|
||||||
ancestors: Vec<String>,
|
|
||||||
title: &'a Option<String>,
|
|
||||||
description: &'a Option<String>,
|
|
||||||
date: &'a Option<String>,
|
|
||||||
year: Option<i32>,
|
|
||||||
month: Option<u32>,
|
|
||||||
day: Option<u32>,
|
|
||||||
taxonomies: &'a HashMap<String, Vec<String>>,
|
|
||||||
extra: &'a Map<String, Value>,
|
|
||||||
path: &'a str,
|
|
||||||
components: &'a [String],
|
|
||||||
summary: &'a Option<String>,
|
|
||||||
word_count: Option<usize>,
|
|
||||||
reading_time: Option<usize>,
|
|
||||||
toc: &'a [Header],
|
|
||||||
assets: Vec<String>,
|
|
||||||
draft: bool,
|
|
||||||
lighter: Option<Box<SerializingPage<'a>>>,
|
|
||||||
heavier: Option<Box<SerializingPage<'a>>>,
|
|
||||||
earlier: Option<Box<SerializingPage<'a>>>,
|
|
||||||
later: Option<Box<SerializingPage<'a>>>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> SerializingPage<'a> {
|
|
||||||
/// Grabs all the data from a page, including sibling pages
|
|
||||||
pub fn from_page(page: &'a Page, library: &'a Library) -> Self {
|
|
||||||
let mut year = None;
|
|
||||||
let mut month = None;
|
|
||||||
let mut day = None;
|
|
||||||
if let Some(d) = page.meta.datetime_tuple {
|
|
||||||
year = Some(d.0);
|
|
||||||
month = Some(d.1);
|
|
||||||
day = Some(d.2);
|
|
||||||
}
|
|
||||||
let pages = library.pages();
|
|
||||||
let lighter = page.lighter.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
|
||||||
let heavier = page.heavier.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
|
||||||
let earlier = page.earlier.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
|
||||||
let later = page.later.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
|
||||||
let ancestors = page.ancestors.iter().map(|k| library.get_section_by_key(*k).file.relative.clone()).collect();
|
|
||||||
|
|
||||||
SerializingPage {
|
|
||||||
relative_path: &page.file.relative,
|
|
||||||
ancestors,
|
|
||||||
content: &page.content,
|
|
||||||
permalink: &page.permalink,
|
|
||||||
slug: &page.slug,
|
|
||||||
title: &page.meta.title,
|
|
||||||
description: &page.meta.description,
|
|
||||||
extra: &page.meta.extra,
|
|
||||||
date: &page.meta.date,
|
|
||||||
year,
|
|
||||||
month,
|
|
||||||
day,
|
|
||||||
taxonomies: &page.meta.taxonomies,
|
|
||||||
path: &page.path,
|
|
||||||
components: &page.components,
|
|
||||||
summary: &page.summary,
|
|
||||||
word_count: page.word_count,
|
|
||||||
reading_time: page.reading_time,
|
|
||||||
toc: &page.toc,
|
|
||||||
assets: page.serialize_assets(),
|
|
||||||
draft: page.is_draft(),
|
|
||||||
lighter,
|
|
||||||
heavier,
|
|
||||||
earlier,
|
|
||||||
later,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Same as from_page but does not fill sibling pages
|
|
||||||
pub fn from_page_basic(page: &'a Page, library: Option<&'a Library>) -> Self {
|
|
||||||
let mut year = None;
|
|
||||||
let mut month = None;
|
|
||||||
let mut day = None;
|
|
||||||
if let Some(d) = page.meta.datetime_tuple {
|
|
||||||
year = Some(d.0);
|
|
||||||
month = Some(d.1);
|
|
||||||
day = Some(d.2);
|
|
||||||
}
|
|
||||||
let ancestors = if let Some(ref lib) = library {
|
|
||||||
page.ancestors.iter().map(|k| lib.get_section_by_key(*k).file.relative.clone()).collect()
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
};
|
|
||||||
|
|
||||||
SerializingPage {
|
|
||||||
relative_path: &page.file.relative,
|
|
||||||
ancestors,
|
|
||||||
content: &page.content,
|
|
||||||
permalink: &page.permalink,
|
|
||||||
slug: &page.slug,
|
|
||||||
title: &page.meta.title,
|
|
||||||
description: &page.meta.description,
|
|
||||||
extra: &page.meta.extra,
|
|
||||||
date: &page.meta.date,
|
|
||||||
year,
|
|
||||||
month,
|
|
||||||
day,
|
|
||||||
taxonomies: &page.meta.taxonomies,
|
|
||||||
path: &page.path,
|
|
||||||
components: &page.components,
|
|
||||||
summary: &page.summary,
|
|
||||||
word_count: page.word_count,
|
|
||||||
reading_time: page.reading_time,
|
|
||||||
toc: &page.toc,
|
|
||||||
assets: page.serialize_assets(),
|
|
||||||
draft: page.is_draft(),
|
|
||||||
lighter: None,
|
|
||||||
heavier: None,
|
|
||||||
earlier: None,
|
|
||||||
later: None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq)]
|
#[derive(Clone, Debug, PartialEq)]
|
||||||
pub struct Page {
|
pub struct Page {
|
||||||
|
@ -343,7 +222,7 @@ impl Page {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a vectors of asset URLs.
|
/// Creates a vectors of asset URLs.
|
||||||
fn serialize_assets(&self) -> Vec<String> {
|
pub fn serialize_assets(&self) -> Vec<String> {
|
||||||
self.assets.iter()
|
self.assets.iter()
|
||||||
.filter_map(|asset| asset.file_name())
|
.filter_map(|asset| asset.file_name())
|
||||||
.filter_map(|filename| filename.to_str())
|
.filter_map(|filename| filename.to_str())
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
use tera::{Tera, Context as TeraContext, Value};
|
use tera::{Tera, Context as TeraContext};
|
||||||
use slotmap::{Key};
|
use slotmap::Key;
|
||||||
|
|
||||||
use config::Config;
|
use config::Config;
|
||||||
use front_matter::{SectionFrontMatter, split_section_content};
|
use front_matter::{SectionFrontMatter, split_section_content};
|
||||||
|
@ -13,91 +13,10 @@ use utils::site::get_reading_analytics;
|
||||||
use rendering::{RenderContext, Header, render_content};
|
use rendering::{RenderContext, Header, render_content};
|
||||||
|
|
||||||
use content::file_info::FileInfo;
|
use content::file_info::FileInfo;
|
||||||
use content::SerializingPage;
|
use content::ser::SerializingSection;
|
||||||
use library::Library;
|
use library::Library;
|
||||||
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Serialize)]
|
|
||||||
pub struct SerializingSection<'a> {
|
|
||||||
relative_path: &'a str,
|
|
||||||
content: &'a str,
|
|
||||||
permalink: &'a str,
|
|
||||||
ancestors: Vec<String>,
|
|
||||||
title: &'a Option<String>,
|
|
||||||
description: &'a Option<String>,
|
|
||||||
extra: &'a HashMap<String, Value>,
|
|
||||||
path: &'a str,
|
|
||||||
components: &'a [String],
|
|
||||||
word_count: Option<usize>,
|
|
||||||
reading_time: Option<usize>,
|
|
||||||
toc: &'a [Header],
|
|
||||||
assets: Vec<String>,
|
|
||||||
pages: Vec<SerializingPage<'a>>,
|
|
||||||
subsections: Vec<&'a str>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> SerializingSection<'a> {
|
|
||||||
pub fn from_section(section: &'a Section, library: &'a Library) -> Self {
|
|
||||||
let mut pages = Vec::with_capacity(section.pages.len());
|
|
||||||
let mut subsections = Vec::with_capacity(section.subsections.len());
|
|
||||||
|
|
||||||
for k in §ion.pages {
|
|
||||||
pages.push(library.get_page_by_key(*k).to_serialized(library));
|
|
||||||
}
|
|
||||||
|
|
||||||
for k in §ion.subsections {
|
|
||||||
subsections.push(library.get_section_path_by_key(*k));
|
|
||||||
}
|
|
||||||
|
|
||||||
let ancestors = section.ancestors.iter().map(|k| library.get_section_by_key(*k).file.relative.clone()).collect();
|
|
||||||
|
|
||||||
SerializingSection {
|
|
||||||
relative_path: §ion.file.relative,
|
|
||||||
ancestors,
|
|
||||||
content: §ion.content,
|
|
||||||
permalink: §ion.permalink,
|
|
||||||
title: §ion.meta.title,
|
|
||||||
description: §ion.meta.description,
|
|
||||||
extra: §ion.meta.extra,
|
|
||||||
path: §ion.path,
|
|
||||||
components: §ion.components,
|
|
||||||
word_count: section.word_count,
|
|
||||||
reading_time: section.reading_time,
|
|
||||||
toc: §ion.toc,
|
|
||||||
assets: section.serialize_assets(),
|
|
||||||
pages,
|
|
||||||
subsections,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Same as from_section but doesn't fetch pages and sections
|
|
||||||
pub fn from_section_basic(section: &'a Section, library: Option<&'a Library>) -> Self {
|
|
||||||
let ancestors = if let Some(ref lib) = library {
|
|
||||||
section.ancestors.iter().map(|k| lib.get_section_by_key(*k).file.relative.clone()).collect()
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
};
|
|
||||||
|
|
||||||
SerializingSection {
|
|
||||||
relative_path: §ion.file.relative,
|
|
||||||
ancestors,
|
|
||||||
content: §ion.content,
|
|
||||||
permalink: §ion.permalink,
|
|
||||||
title: §ion.meta.title,
|
|
||||||
description: §ion.meta.description,
|
|
||||||
extra: §ion.meta.extra,
|
|
||||||
path: §ion.path,
|
|
||||||
components: §ion.components,
|
|
||||||
word_count: section.word_count,
|
|
||||||
reading_time: section.reading_time,
|
|
||||||
toc: §ion.toc,
|
|
||||||
assets: section.serialize_assets(),
|
|
||||||
pages: vec![],
|
|
||||||
subsections: vec![],
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq)]
|
#[derive(Clone, Debug, PartialEq)]
|
||||||
pub struct Section {
|
pub struct Section {
|
||||||
/// All info about the actual file
|
/// All info about the actual file
|
||||||
|
@ -260,7 +179,7 @@ impl Section {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a vectors of asset URLs.
|
/// Creates a vectors of asset URLs.
|
||||||
fn serialize_assets(&self) -> Vec<String> {
|
pub fn serialize_assets(&self) -> Vec<String> {
|
||||||
self.assets.iter()
|
self.assets.iter()
|
||||||
.filter_map(|asset| asset.file_name())
|
.filter_map(|asset| asset.file_name())
|
||||||
.filter_map(|filename| filename.to_str())
|
.filter_map(|filename| filename.to_str())
|
||||||
|
|
213
components/library/src/content/ser.rs
Normal file
213
components/library/src/content/ser.rs
Normal file
|
@ -0,0 +1,213 @@
|
||||||
|
//! What we are sending to the templates when rendering them
|
||||||
|
use std::collections::HashMap;
|
||||||
|
|
||||||
|
use tera::{Value, Map};
|
||||||
|
|
||||||
|
use library::Library;
|
||||||
|
use content::{Page, Section};
|
||||||
|
use rendering::Header;
|
||||||
|
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Serialize)]
|
||||||
|
pub struct SerializingPage<'a> {
|
||||||
|
relative_path: &'a str,
|
||||||
|
content: &'a str,
|
||||||
|
permalink: &'a str,
|
||||||
|
slug: &'a str,
|
||||||
|
ancestors: Vec<String>,
|
||||||
|
title: &'a Option<String>,
|
||||||
|
description: &'a Option<String>,
|
||||||
|
date: &'a Option<String>,
|
||||||
|
year: Option<i32>,
|
||||||
|
month: Option<u32>,
|
||||||
|
day: Option<u32>,
|
||||||
|
taxonomies: &'a HashMap<String, Vec<String>>,
|
||||||
|
extra: &'a Map<String, Value>,
|
||||||
|
path: &'a str,
|
||||||
|
components: &'a [String],
|
||||||
|
summary: &'a Option<String>,
|
||||||
|
word_count: Option<usize>,
|
||||||
|
reading_time: Option<usize>,
|
||||||
|
toc: &'a [Header],
|
||||||
|
assets: Vec<String>,
|
||||||
|
draft: bool,
|
||||||
|
lighter: Option<Box<SerializingPage<'a>>>,
|
||||||
|
heavier: Option<Box<SerializingPage<'a>>>,
|
||||||
|
earlier: Option<Box<SerializingPage<'a>>>,
|
||||||
|
later: Option<Box<SerializingPage<'a>>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> SerializingPage<'a> {
|
||||||
|
/// Grabs all the data from a page, including sibling pages
|
||||||
|
pub fn from_page(page: &'a Page, library: &'a Library) -> Self {
|
||||||
|
let mut year = None;
|
||||||
|
let mut month = None;
|
||||||
|
let mut day = None;
|
||||||
|
if let Some(d) = page.meta.datetime_tuple {
|
||||||
|
year = Some(d.0);
|
||||||
|
month = Some(d.1);
|
||||||
|
day = Some(d.2);
|
||||||
|
}
|
||||||
|
let pages = library.pages();
|
||||||
|
let lighter = page.lighter.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
||||||
|
let heavier = page.heavier.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
||||||
|
let earlier = page.earlier.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
||||||
|
let later = page.later.map(|k| Box::new(Self::from_page_basic(pages.get(k).unwrap(), Some(library))));
|
||||||
|
let ancestors = page.ancestors.iter().map(|k| library.get_section_by_key(*k).file.relative.clone()).collect();
|
||||||
|
|
||||||
|
SerializingPage {
|
||||||
|
relative_path: &page.file.relative,
|
||||||
|
ancestors,
|
||||||
|
content: &page.content,
|
||||||
|
permalink: &page.permalink,
|
||||||
|
slug: &page.slug,
|
||||||
|
title: &page.meta.title,
|
||||||
|
description: &page.meta.description,
|
||||||
|
extra: &page.meta.extra,
|
||||||
|
date: &page.meta.date,
|
||||||
|
year,
|
||||||
|
month,
|
||||||
|
day,
|
||||||
|
taxonomies: &page.meta.taxonomies,
|
||||||
|
path: &page.path,
|
||||||
|
components: &page.components,
|
||||||
|
summary: &page.summary,
|
||||||
|
word_count: page.word_count,
|
||||||
|
reading_time: page.reading_time,
|
||||||
|
toc: &page.toc,
|
||||||
|
assets: page.serialize_assets(),
|
||||||
|
draft: page.is_draft(),
|
||||||
|
lighter,
|
||||||
|
heavier,
|
||||||
|
earlier,
|
||||||
|
later,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Same as from_page but does not fill sibling pages
|
||||||
|
pub fn from_page_basic(page: &'a Page, library: Option<&'a Library>) -> Self {
|
||||||
|
let mut year = None;
|
||||||
|
let mut month = None;
|
||||||
|
let mut day = None;
|
||||||
|
if let Some(d) = page.meta.datetime_tuple {
|
||||||
|
year = Some(d.0);
|
||||||
|
month = Some(d.1);
|
||||||
|
day = Some(d.2);
|
||||||
|
}
|
||||||
|
let ancestors = if let Some(ref lib) = library {
|
||||||
|
page.ancestors.iter().map(|k| lib.get_section_by_key(*k).file.relative.clone()).collect()
|
||||||
|
} else {
|
||||||
|
vec![]
|
||||||
|
};
|
||||||
|
|
||||||
|
SerializingPage {
|
||||||
|
relative_path: &page.file.relative,
|
||||||
|
ancestors,
|
||||||
|
content: &page.content,
|
||||||
|
permalink: &page.permalink,
|
||||||
|
slug: &page.slug,
|
||||||
|
title: &page.meta.title,
|
||||||
|
description: &page.meta.description,
|
||||||
|
extra: &page.meta.extra,
|
||||||
|
date: &page.meta.date,
|
||||||
|
year,
|
||||||
|
month,
|
||||||
|
day,
|
||||||
|
taxonomies: &page.meta.taxonomies,
|
||||||
|
path: &page.path,
|
||||||
|
components: &page.components,
|
||||||
|
summary: &page.summary,
|
||||||
|
word_count: page.word_count,
|
||||||
|
reading_time: page.reading_time,
|
||||||
|
toc: &page.toc,
|
||||||
|
assets: page.serialize_assets(),
|
||||||
|
draft: page.is_draft(),
|
||||||
|
lighter: None,
|
||||||
|
heavier: None,
|
||||||
|
earlier: None,
|
||||||
|
later: None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, PartialEq, Serialize)]
|
||||||
|
pub struct SerializingSection<'a> {
|
||||||
|
relative_path: &'a str,
|
||||||
|
content: &'a str,
|
||||||
|
permalink: &'a str,
|
||||||
|
ancestors: Vec<String>,
|
||||||
|
title: &'a Option<String>,
|
||||||
|
description: &'a Option<String>,
|
||||||
|
extra: &'a HashMap<String, Value>,
|
||||||
|
path: &'a str,
|
||||||
|
components: &'a [String],
|
||||||
|
word_count: Option<usize>,
|
||||||
|
reading_time: Option<usize>,
|
||||||
|
toc: &'a [Header],
|
||||||
|
assets: Vec<String>,
|
||||||
|
pages: Vec<SerializingPage<'a>>,
|
||||||
|
subsections: Vec<&'a str>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> SerializingSection<'a> {
|
||||||
|
pub fn from_section(section: &'a Section, library: &'a Library) -> Self {
|
||||||
|
let mut pages = Vec::with_capacity(section.pages.len());
|
||||||
|
let mut subsections = Vec::with_capacity(section.subsections.len());
|
||||||
|
|
||||||
|
for k in §ion.pages {
|
||||||
|
pages.push(library.get_page_by_key(*k).to_serialized(library));
|
||||||
|
}
|
||||||
|
|
||||||
|
for k in §ion.subsections {
|
||||||
|
subsections.push(library.get_section_path_by_key(*k));
|
||||||
|
}
|
||||||
|
|
||||||
|
let ancestors = section.ancestors.iter().map(|k| library.get_section_by_key(*k).file.relative.clone()).collect();
|
||||||
|
|
||||||
|
SerializingSection {
|
||||||
|
relative_path: §ion.file.relative,
|
||||||
|
ancestors,
|
||||||
|
content: §ion.content,
|
||||||
|
permalink: §ion.permalink,
|
||||||
|
title: §ion.meta.title,
|
||||||
|
description: §ion.meta.description,
|
||||||
|
extra: §ion.meta.extra,
|
||||||
|
path: §ion.path,
|
||||||
|
components: §ion.components,
|
||||||
|
word_count: section.word_count,
|
||||||
|
reading_time: section.reading_time,
|
||||||
|
toc: §ion.toc,
|
||||||
|
assets: section.serialize_assets(),
|
||||||
|
pages,
|
||||||
|
subsections,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Same as from_section but doesn't fetch pages and sections
|
||||||
|
pub fn from_section_basic(section: &'a Section, library: Option<&'a Library>) -> Self {
|
||||||
|
let ancestors = if let Some(ref lib) = library {
|
||||||
|
section.ancestors.iter().map(|k| lib.get_section_by_key(*k).file.relative.clone()).collect()
|
||||||
|
} else {
|
||||||
|
vec![]
|
||||||
|
};
|
||||||
|
|
||||||
|
SerializingSection {
|
||||||
|
relative_path: §ion.file.relative,
|
||||||
|
ancestors,
|
||||||
|
content: §ion.content,
|
||||||
|
permalink: §ion.permalink,
|
||||||
|
title: §ion.meta.title,
|
||||||
|
description: §ion.meta.description,
|
||||||
|
extra: §ion.meta.extra,
|
||||||
|
path: §ion.path,
|
||||||
|
components: §ion.components,
|
||||||
|
word_count: section.word_count,
|
||||||
|
reading_time: section.reading_time,
|
||||||
|
toc: §ion.toc,
|
||||||
|
assets: section.serialize_assets(),
|
||||||
|
pages: vec![],
|
||||||
|
subsections: vec![],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue