View your notes as a static HTML site.
Go to file
2024-01-02 18:24:33 +00:00
css begin rewrite 2024-01-02 18:22:15 +00:00
js begin rewrite 2024-01-02 18:22:15 +00:00
templates remove commit gronk commit information for now 2024-01-02 18:24:33 +00:00
.dockerignore dockerize 2024-01-02 18:24:27 +00:00
.gitignore dockerize 2024-01-02 18:24:27 +00:00
.notes2web.conf add development config 2021-05-01 13:05:22 +01:00
docker-compose.yml dockerize 2024-01-02 18:24:27 +00:00
Dockerfile dockerize 2024-01-02 18:24:27 +00:00
gronk_add_uuid.py formatting 2024-01-02 18:23:25 +00:00
gronk.py dockerize 2024-01-02 18:24:27 +00:00
LICENSE Create LICENSE 2021-09-01 17:02:29 +01:00
Makefile mark script as executable once copied 2024-01-02 18:22:56 +00:00
readme.md dockerize 2024-01-02 18:24:27 +00:00
requirements-dev.txt rename to gronk 2024-01-02 18:22:56 +00:00
requirements.txt update requirements 2024-01-02 18:23:18 +00:00
screenshot.png Update screenshot 2021-12-22 21:25:20 +00:00

gronk

View your notes as a static html site. Browse a live sample of it here.

Tested with pandoc v2.19.2.

Why?

  • View notes as a website, on any device
  • Easily share notes
  • Powered by Pandoc, and therefore supports Pandoc's markdown (I mainly care about equations)
  • flatnotes is cool but I really would rather type my notes in Vim
  • Lightweight HTML generated
  • Minimal JavaScript

Install

Docker

Run the following, modifing the -v arguments as needed to mount the correct folders and setting the value of ARCH to either amd64 or arm64 as appropriate.

docker build . -t gronk --build-arg ARCH=amd64 
docker run -v ./n:/usr/src/app/notes -v ./web:/usr/src/app/web gronk

Compose

A docker compose file file has been provided.

Set the following environment variables (or create a .env file) and run docker compose up:

  • ARCH
  • SOURCE
  • OUTPUT

Locally

  1. Install Pandoc and Pip, python3-dev, and a C compiler
  2. sudo make install

Other Things to Know

  • gronk indexes ATX-style headings for searching
  • gronk looks for the plaintext file LICENSE in the root directory of your notes

Custom Directory Index and Metadata

To add custom content to a directory index, put it in a file called index.md under the directory.

You can set the following frontmatter variables to customise the directory index of a directory:

variable default value description
tags [] list of tags, used by search and inherited by any notes and subdirectories
uuid none unique id to reference directory, used for permalinking
content_after_search false show custom content in index.md after search bar and directory index
automatic_index true show the automatically generated directory index. required for search bar to function.
search_bar true show search bar to search directory items. requires automatic_index (enabled by default)

Notes Metadata

gronk reads the following YAML frontmatter variables for metadata:

variable description
author The person(s) who wrote the article
tags A YAML list of tags which the article relates to - this is used for browsing and also
title The title of the article
uuid A unique identifier used for permalinks.
lecture_slides a list of paths pointing to lecture slides used while taking notes
lecture_notes a list of paths pointing to other notes used while taking notes

Permalinks are currently rather basic and requires JavaScript to be enabled on the local computer. In order to identify documents between file changes, a unique identifier is used to identify a file.

This unique identifier can be generated using the uuidgen command in the uuid-runtime package or str(uuid.uuid()) in the uuid python package.

The included n2w_add_uuid.py will add a UUID to a markdown file which does not have a UUID in it already. Combine it with find to UUIDify all your markdown files (but make a backup first).

Custom Styling

To completely replace the existing styling, set the environment variable GRONK_CSS_DIR to another directory with a file called styles.css.

To add additional styling, the default styling will attempt to import styles.css from the root of the notes directory.

To add additional content to the homepage, create a file called index.md at the top level of your notes directory. To set the HTML title tag, set title in the frontmatter of index.md:

---
title: "alv's notes"
---

# alv's notes

these notes are probably wrong

CLI Usage

$ gronk.py notes_directory

Output of gronk.py --help:

usage: gronk.py [-h] [-o OUTPUT_DIR] [-F] notes

positional arguments:
  notes

options:
  -h, --help            show this help message and exit
  -o OUTPUT_DIR, --output-dir OUTPUT_DIR
  -F, --force           Generate new output html even if source file was modified before output
                        html

The command will generate a website in the output-dir directory (./web by default). It will then generate a list of all note files and put it in index.html.

Then you just have to point a webserver at output-dir.

Uninstall

# make uninstall

Acknowledgements

Default synatx highlighting is based off Pygments' default theme and made using Pandoc v2.7.2. I found the theme here.