compile hierarchic pages

This commit is contained in:
Michael Jerger 2017-03-12 10:33:50 +01:00
parent 6cf7b1a72b
commit e8d7069598
2 changed files with 23 additions and 22 deletions

View file

@ -251,7 +251,9 @@
:home false
:servlet-context (cryogen-io/path "/" blog-prefix "/")
:page page
:uri uri}))))))
:uri uri})))
(compile-pages params (:children page)))
))
(defn compile-posts
"Compiles all the posts into html and spits them out into the public folder"
@ -495,11 +497,15 @@
posts-by-tag (group-by-tags posts)
posts (tag-posts posts config)
latest-posts (->> posts (take recent-posts) vec)
pages (map klipsify (read-pages config))
home-page (->> pages
klipsified-pages (map klipsify (read-pages config))
modelled-pages (cond
(= page-model :flat) klipsified-pages
(= page-model :hierarchic) (hierarchic/build-hierarchic-map klipsified-pages)
)
home-page (->> modelled-pages
(filter #(boolean (:home? %)))
(first))
other-pages (->> pages
other-pages (->> modelled-pages
(remove #{home-page})
(add-prev-next))
params (merge config
@ -508,10 +514,7 @@
:active-page "home"
:tags (map (partial tag-info config) (keys posts-by-tag))
:latest-posts latest-posts
:pages (cond
(= page-model :flat) other-pages
(= page-model :hierarchic) (hierarchic/build-hierarchic-map other-pages)
)
:pages other-pages
:home-page (if home-page
home-page
(assoc (first latest-posts) :layout "home.html"))
@ -523,8 +526,6 @@
(when debug?
(println (blue "debug: page-model:"))
(println "\t-->" (cyan page-model))
(println (blue "debug: pages:"))
(println "\t-->" (cyan (-> params :pages)))
(println (blue "debug: home-page:"))
(println "\t-->" (cyan (-> params :home-page)))
)
@ -535,7 +536,7 @@
(println (blue "copying resources"))
(cryogen-io/copy-resources config)
(copy-resources-from-markup-folders config)
(compile-pages params other-pages)
(compile-pages params modelled-pages)
(compile-posts params posts)
(compile-tags params posts-by-tag)
(compile-tags-page params)

View file

@ -19,7 +19,7 @@
)
(defn build-hierarchic-level
"builds one level of nav-map and recurs to next level."
"builds one level of hierarchic tree recurs to next level."
[parent-uri pages]
(let [current-level (+ 1 (uri-level parent-uri))
pages-of-parent (filter-pages-for-uri parent-uri pages)
@ -36,7 +36,7 @@
))
(defn build-hierarchic-map
"builds a nav-map from pages"
"builds a hierarchic tree from pages"
[pages]
(let [sorted-pages (sort-by :uri pages)]
(build-hierarchic-level "/pages/" sorted-pages)