Reorganize headers, page templates
This commit is contained in:
@@ -32,20 +32,19 @@ struct IndexPageGenerator {
|
||||
to url: URL) throws {
|
||||
let localized = site.localized(for: language)
|
||||
|
||||
var content = [OverviewPageTemplate.Key : String]()
|
||||
var content = [PageTemplate.Key : String]()
|
||||
content[.head] = try makeHead(site: site, language: language)
|
||||
content[.topBar] = factory.topBar.generate(section: nil, languageButton: languageButton)
|
||||
content[.title] = localized.title
|
||||
content[.subtitle] = localized.subtitle
|
||||
content[.titleText] = localized.description
|
||||
content[.contentClass] = "overview"
|
||||
content[.header] = makeHeader(localized: localized)
|
||||
let sections = site.elements.compactMap { $0 as? Section }
|
||||
content[.sections] = try factory.overviewSection.generate(
|
||||
content[.content] = try factory.overviewSection.generate(
|
||||
sections: sections,
|
||||
in: site,
|
||||
language: language,
|
||||
sectionItemCount: sectionItemCount)
|
||||
content[.footer] = SiteGenerator.pageFooter
|
||||
try factory.overviewPage.generate(content, to: url)
|
||||
try factory.page.generate(content, to: url)
|
||||
}
|
||||
|
||||
private func makeHead(site: Site, language: String) throws -> String {
|
||||
@@ -57,4 +56,12 @@ struct IndexPageGenerator {
|
||||
linkPreviewImage: site.linkPreviewImage(for: language),
|
||||
customHeadContent: try site.customHeadContent()))
|
||||
}
|
||||
|
||||
private func makeHeader(localized: Site.LocalizedMetadata) -> String {
|
||||
var content = [HeaderKey : String]()
|
||||
content[.title] = localized.title
|
||||
content[.subtitle] = localized.subtitle
|
||||
content[.titleText] = localized.description
|
||||
return factory.factory.centeredHeader.generate(content)
|
||||
}
|
||||
}
|
||||
|
@@ -19,19 +19,17 @@ struct OverviewPageGenerator {
|
||||
|
||||
let metadata = section.localized(for: language)
|
||||
|
||||
var content = [OverviewPageTemplate.Key : String]()
|
||||
var content = [PageTemplate.Key : String]()
|
||||
content[.head] = try makeHead(section: section, language: language)
|
||||
let languageButton = section.nextLanguage(for: language)
|
||||
content[.topBar] = factory.topBar.generate(
|
||||
section: section.sectionId,
|
||||
languageButton: languageButton)
|
||||
content[.sections] = try makeContent(section: section, language: language)
|
||||
content[.title] = metadata.title
|
||||
content[.subtitle] = metadata.subtitle
|
||||
content[.titleText] = metadata.description
|
||||
content[.contentClass] = "overview"
|
||||
content[.header] = makeHeader(metadata: metadata, language: language, backText: backText)
|
||||
content[.content] = try makeContent(section: section, language: language)
|
||||
content[.footer] = SiteGenerator.pageFooter
|
||||
content[.backLink] = backText.unwrapped { factory.makeBackLink(text: $0, language: language) }
|
||||
try factory.overviewPage.generate(content, to: url)
|
||||
try factory.page.generate(content, to: url)
|
||||
}
|
||||
|
||||
private func makeContent(section: Section, language: String) throws -> String {
|
||||
@@ -59,4 +57,15 @@ struct OverviewPageGenerator {
|
||||
customHeadContent: try section.customHeadContent())
|
||||
return try factory.pageHead.generate(page: info)
|
||||
}
|
||||
|
||||
private func makeHeader(metadata: Section.LocalizedMetadata,
|
||||
language: String,
|
||||
backText: String?) -> String {
|
||||
var content = [HeaderKey : String]()
|
||||
content[.title] = metadata.title
|
||||
content[.subtitle] = metadata.subtitle
|
||||
content[.titleText] = metadata.description
|
||||
content[.backLink] = backText.unwrapped { factory.makeBackLink(text: $0, language: language) }
|
||||
return factory.factory.centeredHeader.generate(content)
|
||||
}
|
||||
}
|
||||
|
@@ -31,13 +31,11 @@ struct PageGenerator {
|
||||
#warning("Make prev and next navigation relative")
|
||||
let metadata = page.localized(for: language)
|
||||
let nextLanguage = page.nextLanguage(for: language)
|
||||
var content = [ContentPageTemplate.Key : String]()
|
||||
var content = [PageTemplate.Key : String]()
|
||||
content[.head] = try makeHead(page: page, language: language)
|
||||
content[.topBar] = factory.topBar.generate(section: page.sectionId, languageButton: nextLanguage)
|
||||
content[.backLink] = factory.makeBackLink(text: backText, language: language)
|
||||
content[.title] = metadata.title
|
||||
content[.subtitle] = metadata.subtitle
|
||||
content[.date] = factory.makeDateString(start: page.metadata.date, end: page.metadata.endDate)
|
||||
content[.contentClass] = "content"
|
||||
content[.header] = makeHeader(page: page.metadata, metadata: metadata, language: language, backText: backText)
|
||||
content[.content] = try makeContent(page: page, language: language, url: inputContentUrl)
|
||||
content[.previousPageLinkText] = previousPage.unwrapped { factory.makePrevText($0.text) }
|
||||
content[.previousPageUrl] = previousPage?.link
|
||||
@@ -45,8 +43,8 @@ struct PageGenerator {
|
||||
content[.nextPageUrl] = nextPage?.link
|
||||
content[.footer] = try page.customFooterContent()
|
||||
|
||||
try factory.contentPage.generate(content, to: url)
|
||||
let url = files.outputFolder.appendingPathComponent(path)
|
||||
try factory.page.generate(content, to: url)
|
||||
}
|
||||
|
||||
private func makeContent(page: Page, language: String, url: URL) throws -> String {
|
||||
@@ -68,4 +66,13 @@ struct PageGenerator {
|
||||
customHeadContent: try page.customHeadContent())
|
||||
return try factory.pageHead.generate(page: info)
|
||||
}
|
||||
|
||||
private func makeHeader(page: Page.Metadata, metadata: Page.LocalizedMetadata, language: String, backText: String) -> String {
|
||||
var content = [HeaderKey : String]()
|
||||
content[.backLink] = factory.makeBackLink(text: backText, language: language)
|
||||
content[.title] = metadata.title
|
||||
content[.subtitle] = metadata.subtitle
|
||||
content[.date] = factory.makeDateString(start: page.date, end: page.endDate)
|
||||
return factory.factory.leftHeader.generate(content)
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user