miti.sh/site.moon

81 lines
2.5 KiB
Plaintext

sitegen = require "sitegen"
tools = require "sitegen.tools"
site = require "sitegen.site"
path = require "sitegen.path"
html = require "sitegen.html"
-- import slugify from "sitegen.common"
lfs = require "lfs"
date = require "date"
-- Monkey-patch sitegen to use pandoc for markdown conversion
os.execute "moonc -t \\
/usr/local/openresty/luajit/share/lua/5.1/sitegen/renderers/ markdown.moon"
-- Change output dir to what Openresty prefers
site.config.out_dir = "html/"
-- Deactivate "pygments" plugin because it conflicts with pandoc highlighting
site.default_plugins = for v in *site.default_plugins
if v\find "pygments" then continue else v
rootname = (str) ->
result = string.gsub str, "%..+", ""
result
split = (str, delimiter="/") ->
[capture for capture in string.gmatch str, "[^#{delimiter}]+"]
last = (list) -> list[#list]
join = (first, last, delimiter="/") -> table.concat { first, last }, delimiter
target = (path, prefix) -> join prefix, rootname(last(split path))
posts = (path=".") ->
files = [file for file in lfs.dir path when file != "." and file != ".."]
{join(path, file), target(file, "/posts") for _, file in ipairs files}
extract_id = (source) -> string.match path.filename(source), "%a[%w%-]+"
extract_date = (source) -> string.match path.filename(source), "%d+%-%d%d%-%d%d"
format_date = (str) -> date(str)\fmt "%b %d, %Y"
publish_date = (path) -> format_date extract_date path
list_posts = (page, limit) ->
posts = page.site\query_pages { is_a: "post" }
table.sort posts, (a, b) -> a.source > b.source
html.build ->
[section {
h3 { a { href: meta.target .. ".html", meta.title or meta.id }}
time { publish_date source }
{ "—", if meta.blurb then text meta.blurb }
a { class: "read-post-link", href: meta.target .. ".html",
"Read post →"
}
} for { meta: meta, source: source } in *posts[1, limit or #posts]]
sitegen.create =>
@site_title = "WebDevCat.me · Catalin Mititiuc"
@app_name = "stasis"
@version = "0.2.12"
@list_posts = list_posts
add "index.html"
add "blog.html", target: "posts/index", template: "blog"
for path, target in pairs posts "docs"
add path,
target: target
template: "post"
is_a: "post"
publish_date: publish_date(path)
id: extract_id(path)
-- replace post markdown yaml headers with moonscript headers
filter "docs", (body) =>
body\gsub "^%-%-%-.-%.%.%.", (yaml_header) ->
header = yaml_header\gsub "%-%-%-", "{"
moonscript_header = header\gsub "%.%.%.", "}"
moonscript_header
copy "app.css"