klank-docs/app.py

159 lines
4.1 KiB
Python
Raw Normal View History

2024-11-25 15:01:56 +00:00
import os
from pathlib import Path
import shutil
import csv
2024-12-02 22:40:59 +00:00
import re
import datetime
2024-11-25 15:01:56 +00:00
from jinja2 import Environment, PackageLoader, select_autoescape
import frontmatter
import markdown
from markdown_include.include import MarkdownInclude
from slugify import slugify
markdown_include = MarkdownInclude(
configs={'base_path': 'src/content/'}
)
env = Environment(
loader=PackageLoader("src"),
autoescape=select_autoescape()
)
CONTENT_D = os.path.abspath("src/content")
OUTPUT_D = "dist"
documents = {}
2024-12-02 22:40:59 +00:00
def showlist(param):
template = env.select_template(["snippets/show-list.jinja"])
html = template.render(documents=documents, type=param.strip())
return html
2024-12-18 17:24:39 +00:00
def showGrid(param):
template = env.select_template(["snippets/show-grid.jinja"])
html = template.render(documents=documents, type=param.strip())
return html
2024-12-02 22:40:59 +00:00
2024-11-25 15:01:56 +00:00
def slugify_filter(value):
return slugify(value)
2024-12-02 22:40:59 +00:00
def shortcode_filter(value):
2024-12-18 17:24:39 +00:00
2024-12-02 22:40:59 +00:00
shortcode_callbacks = {
2024-12-18 17:24:39 +00:00
"showlist": showlist,
"showGrid": showGrid
2024-12-02 22:40:59 +00:00
}
2024-12-18 17:24:39 +00:00
2024-12-02 22:40:59 +00:00
def shortcode_replacer(match):
shortcode_name = match.group(1).strip()
param = match.group(2).strip()
if shortcode_name in shortcode_callbacks:
return shortcode_callbacks[shortcode_name](param)
return match.group(0)
pattern = re.compile(r"{{\s*(\w+)\s+([^{}]+?)\s*}}")
return pattern.sub(shortcode_replacer, value)
env.filters["shortcode"] = shortcode_filter
env.filters["slugify"] = slugify_filter
2024-11-25 15:01:56 +00:00
def render_single_file(template, page, path, dist):
html = template.render(documents=documents, page=page)
name = Path(path).stem
if not os.path.exists(dist):
os.makedirs(dist)
with open(f"{dist}/{name}.html", "w", encoding="utf-8") as output_file:
output_file.write(html)
def get_page_data(path):
filename = Path(path).stem
2024-12-02 22:40:59 +00:00
2024-11-25 15:01:56 +00:00
page = frontmatter.load(path)
page['slug'] = slugify(filename)
2024-12-02 22:40:59 +00:00
page.filename = filename
2024-11-25 15:01:56 +00:00
page.body = markdown.markdown(page.content, extensions=['def_list', 'footnotes', markdown_include])
2024-12-18 17:24:39 +00:00
2024-11-25 15:01:56 +00:00
return page
def render_posts(path):
name = Path(path).stem
print(f"looking for {name}.jinja")
template = env.select_template([f"{name}.jinja", "post.jinja"])
for filename in os.listdir(path):
if filename.endswith(".md"):
post_path = os.path.join(path, filename)
page = get_page_data(post_path)
render_single_file(template, page, post_path, f"{OUTPUT_D}/{name}")
def preload_documents():
print("preload any needed data")
for subdir in os.listdir(CONTENT_D):
path = os.path.join(CONTENT_D, subdir)
if os.path.isdir(path):
name = Path(path).stem
if name not in documents:
documents[name] = []
for filename in os.listdir(path):
if filename.endswith(".md"):
post_path = os.path.join(path, filename)
documents[name].append(get_page_data(post_path))
elif Path(path).suffix == '.md':
documents[Path(path).stem] = get_page_data(path)
2024-12-02 22:40:59 +00:00
2024-11-25 15:01:56 +00:00
def copy_assets():
if os.path.exists("dist/assets"):
shutil.rmtree("dist/assets")
shutil.copytree("src/assets", "dist/assets")
2024-12-02 22:40:59 +00:00
2024-11-25 15:01:56 +00:00
def get_inventory():
with open("src/content/component-inventory.csv") as f:
documents['inventory'] = []
2024-12-18 17:24:39 +00:00
for line in csv.DictReader(f, fieldnames=('ID', 'Name', 'Value', 'type', 'Date', 'Where', 'Mounting type')):
2024-11-25 15:01:56 +00:00
documents['inventory'].append(line)
2024-12-02 22:40:59 +00:00
2024-11-25 15:01:56 +00:00
def main():
get_inventory()
preload_documents()
print("render the content")
for subdir in os.listdir(CONTENT_D):
path = os.path.join(CONTENT_D, subdir)
if os.path.isdir(path):
render_posts(path)
elif Path(path).suffix == '.md':
template = env.select_template(
[f"{Path(path).stem}.jinja", "post.jinja"])
page = get_page_data(path)
render_single_file(template, page, path, OUTPUT_D)
else:
print("i cannot handle this file yet")
copy_assets()
main()