Skip to content

lee2sman/panblog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

panblog

panblog is a simple, minimal bash and pandoc-based static site generator. It takes markdown files and converts them to a website you can host on your own server, github pages, neocities and the like.

panblog makes use of Pandoc, the swiss army knife of text file conversion. It makes use of pandoc's remarkable conversion tools, frontmatter variables, and custom templating: practically everything needed to make a static site.

DEMO SITE on tildepages

Rationale

panblog was created as an alternative to Jekyll, Hugo, and 11ty and other static site generators. These three are great but I got frustrated with Jekyll breaking with dependency hell every couple months, or having to re-install the 'correct' version of ruby, bundler, and gems. I also didn't love that themes would break as Jekyll got progressively updated. Hugo was often mentioned to me as an alternative, and not changing nearly as often, but it's a large piece of complicated software. And the number of additional options to add-on can feel overwhelming. In contrast, 11ty was easy to jump into but I don't love npm and the node.js ecosystem because of how often there are changes, occasional security issues, and how packages get so bloated. I also looked into bashblog but at 1500 lines of code, it was hard to hack on, and had features like Google analytics and Twitter integrations that I just didn't want. In contrast to all of these, 95% of the time I just need a landing page, blog pages, a header, and a folder of images, maybe a contact or about page, and optional rss feed. For this reason over the years I often found myself reaching for pandoc when creating small devlogs, class websites and the like. Over time I started creating small build scripts to automate using pandoc, which eventually grew into the foundation of panblog.

Requirements

  • Pandoc
  • Bash
  • tac (You probably have it already, such as from GNU coreutils or busybox)
  • basename (You probably have it already. If not, install coreutils)

Quickstart to test out

The fastest way to get started is to download or clone this repo and then 1. change or modify the files in the posts directory, 2. change the variable names in the config.conf file, then 3. run the build.sh script bash build.sh.

To see your site live in the browser, run a local server in the output _site directory (such as python3 -m http.server) and visit the url http://localhost:8000 in a web browser.

Installing

Git clone or download this directory to your computer.

Get it from Tildegit or from Github. (Pick one)

git clone https://tildegit.org/exquisitecorp/panblog.git

or

git clone https://github.com/lee2sman/panblog.git

Enter the new directory:

cd panblog

Give permissions to the build script:

chmod +x build.sh

You can now build the site at once with ./build.sh

Setup

All custom variables are set in config.conf. Start by opening that file in any text editor and changing your site name, url and description. Multi-word strings should be placed in quotes.

All posts should be placed in the specified posts directory with the file name formatted in YYYY-MM-DD-title-name.md.

All non-post pages can be placed in the pages directory. By default, these pages will be built but won't be linked from any other page. Pages must be manually linked from other pages such as your site's home page, in templates/site_template.html or maybe a navigation bar in templates/header.html. There are examples included in the default template pages.

Place css stylesheet(s) in the themes directory. Place templates in the templates directory. Place your images in the images asset directory.

Usage

All posts and pages can optionally include frontmatter, which pandoc and the build script will use when rendering the page. Frontmatter variables are placed between two sets of --- at the top of a page of markdown, in the format:

---
title: Title of your post
css: stylesheet-name.css
image: optional opengraph image file
description: optional opengraph page description
---

Opengraph (image, text, etc) are the preview you see populated when posting a link to a page on social media, for example.

A post or page without frontmatter still builds and uses a default title from its filename, and the config.conf default css theme. You can modify page templates, including the header and footer, nav or any other html elements in the templates folder.

All images should be placed in your images assets folder. You can just write the image filename in your posts and pages. When pandoc renders the markdown pages to html it will prepend the path to your image.

Build entire site

./build.sh

This looks for all markdown files in the pages and posts directories, then builds a folder _site/ (or change site name directory in config.conf) with each post by default in its own sub-folder so you can have a clean URLs. All pages are built and placed in their own directory within pages.

The difference between pages and posts

Posts are sourced from the posts directory and are automatically linked from your website's landing page, like a traditional blog. They must be saved under a file name with YYYY-MM-DD-title.md format. Pages are any markdown page in the pages directory, not the posts directory. Pages are built and placed in the root folder but not automatically linked from the site homepage. You can manually link to them from any other page, or type their full URL path directly into the browser, such as https://example.com/contact/.

Example from a site landing page footer:

To get in touch, [contact](contact/) me.

This will link to the contact page directly.

Testing your site

Run a local server inside your _site folder through many different methods. Most computers have Python installed, so a local server is easy to setup.

First, go into your output folder, which is _site by default. For GitHub pages, you should change the config.conf output variable to docs.

Then run the local server there. If you have python3 installed:

python3 -m http.server

If you have python2 installed:

python -m SimpleHTTPServer

You can then visit the site running locally from your web browser at http://localhost:8000

The default port is 8000. You can optionally specify a port by appending it to the end, e.g. python3 -m http.server 8080

Getting your site online

FTP or otherwise upload the contents of your site's built directory (by default: _site) to the root of your web hosting folder, or to the www/ folder depending on how your server is set up.

Optionally, you can host the site via GitHub pages, GitLab, Sourcehut, and some other forges. If you're a member of a tilde server community, then you have access to tildegit and can host on TildePages.

To host a site via GitHub pages easily, simply set your site_folder in the config.conf to docs. Then build your site. Then push your site including your docs/ directory to your remote GitHub repo. On the GitHub project repo under Settings > Pages select Deploy from a branch, and select docs and save. You could optionally add a custom domain here. The site will build and deploy within minutes.

More info at Configuring a publishing source for your GitHub Pages site.

Example sites

Panblog demo site, hosted via Tildepages

Drawing, Moving and Seeing with Code class website, hosted via GitHub pages

Directory structure

Running build.sh will render the following default output site.

_site/
- index.md        #compiled in build step
- index.html      #rendered output
- rss.xml
-----/css/
-------theme.css
-----/images/
-------image1.jpg
-------image2.jpg
-----/post1/      #linked from site index 
-------index.html 
-----/post2/      #linked from site index
-------index.html
-----/page1/      #not linked by default
-------index.html

Image path

All images for your site can be placed in an image asset directory specified in the config.conf. This allows you to link to an image file on your posts and pages by just listing the image file name without the full qualified image path.

Error checking

There's some but not all. You'll have to interpret any errors you see when running the bash script.

Themes

panblog comes with several theme options, which are just css files. A theme for your landing page should be specified in your templates files. Individual posts or pages can use override and build with a different theme by specifying a css theme file in their front matter with the css keyword.

License

cc0 Public Domain