PyJan26
PyJan26 is a static site generator written in Python. It allows you to generate static websites from templates and content files, with support for pagination, custom pages, custom filters, and custom collections.
Install PyJan26 using pip:
pip install pyjan26
Initialize a new project:
python -m pyjan26.main s <project_name>
cd <project_name>
Generate static site:
python -m pyjan26.main g
To run your generated static site :
python -m http.server --directory public/
Directory Structure
PyJan26 follows a specific directory structure:
project_directory/
│
├── _templates/
│ ├── base.html
│ └── custom_template.html
│
├── _content/
│ ├── post1.md
│ ├── post2.md
│ └── about.md
│
└── public/
├── index.html
├── post1/
│ └── index.html
├── post2/
│ └── index.html
└── about/
└── index.html
To configure pagination, add the following YAML front matter to your content files:
layout: custom_template.html
title: Blog Post 1
paginated:
items: blogs
size: 10
alias: myblogs
When pagination is enabled, PyJan26 provides built-in template variables that you can use to generate pagination links:
{% if myblogs %}
{% for blog in myblogs %}
<span><a href="/blog/{{ blog.name }}">{{ blog.name }}</a></span>
{% endfor %}
{% endif %}
{% if pagination.prev_page %}
<a href="{{ pagination.prev_page }}">Previous</a>
{% endif %}
{% for page_num in pagination.page_numbers %}
<a href="{{ page_num.url }}">{{ page_num.page_number }}</a>
{% endfor %}
{% if pagination.page_number and pagination.total_pages %}
Page {{ pagination.page_number}} of: {{ pagination.total_pages }}
{% endif %}
{% if pagination.next_page %}
<a href="{{ pagination.next_page }}">Next</a>
{% endif %}
In this example:
- myblogs represents the paginated blogs.
- pagination.total_pages represents the total pages.
- pagination.prev_page provides a link to the previous page.
- pagination.page_number represents the current page number.
- pagination.page_numbers generates links to each page.
- pagination.next_page provides a link to the next page.
Copy Static Files
To specify static files to be copied to the public directory, add them to the STATIC_PATHS variable in your configuration (settings.py):
STATIC_PATHS = [
"images",
"assets/robots.txt"
]
Adjust the paths as needed to include directories or specific files you want to copy.
Custom Collections
Define custom collections in custom_collections.py:
from pyjan26.registry import register_custom_collections
def tag_list(collections):
"""
Define a list of tags for the 'tags' collection.
"""
return {'tags': [{'tag': 'javascript'}, {'tag': 'python'}]}
register_custom_collections([tag_list])
Custom Filters
Define custom filters in custom_filters.py:
from pyjan26.registry import register_custom_filters
def capitalize_words(value):
return ' '.join(word.capitalize() for word in value.split())
register_custom_filters([capitalize_words])
To use the custom filter in your templates, follow this syntax:
{{ content | capitalize_words }}
Custom Page Rendering
Define custom page rendering in custom_page.py:
from pyjan26.registry import register_custom_page
from pyjan26.core import render_page, render_string
def custom_page1(*args, **kwargs):
"""
Custom page rendering function.
"""
item, collection_name, collections, settings = args
out_dir = kwargs.get('out_dir')
if out_dir:
out_dir = render_string(out_dir, item)
page_data = {
'collection_name': collection_name,
'collections': collections,
'items': item,
'out_dir': out_dir
}
render_page(page_data)
return { 'skip_next': False }
register_custom_page([custom_page1])
To apply custom page rendering to a content markdown file, add custom_page1: True to the YAML front matter:
layout: custom_template.html
title: Post 1
custom_page1: True
This instructs PyJan26 to use the custom_page1 function for rendering this specific content. Adjust metadata as needed.
Global Variable
To create a global variable, simply define it in settings.py:
AUTHOR = 'Josnin'
This renders the template value of AUTHOR defined in the settings.py module.
{{ settings.AUTHOR }}
How to run development server?
git clone https://github.com/josnin/pyjan26.git
cd ~/Documents/pyjan26/
Help
Need help? Open an issue in: ISSUES
Contributing
Want to improve and add feature? Fork the repo, add your changes and send a pull request.