Static Page Generation with Flask-like simplicity and flair ✨
Project description
What is RenderEngine
The idea of Render Engine is that you have the flexibility of dynamic webpages with the performance of static sites.
Render Engine was built out of frustration with existing tools. Larger frameworks are too vast. Dynamic Services like Flask required overhead of a server where in many cases were not necessary. Extensions to Flask that provided a static component added even more unnecessary complexity and updates have been inconsistent. Other static-site generators like Pelican were built without modern architectures and design practices in mind.
The 3 layer Architecture
- Page - A single webpage item built from content, a template, raw data, or a combination of those things.
- Collection - A group of webpages built from the same template, organized in a single directory
- Site - The container that holds all Pages and Collections and gives access to global configurations and settings.
Your site will have an Engine that can render your html (and other things), hence the name.
You can expand any of these areas to customize your engine to your liking.
Things you can do in with Render Engine:
- Create Custom Page Objects (Like Blog or MicroBlog Posts)
- Create all types of Page Objects, not just 'html' pages
- Run Multiple Engines for subdomains or multiple template systems or Multiple Sites!
- Dynamically create content at runtime to include into your static sites
As simple/complex as required
- Render Engine uses Jinja2 as the defaul engine to bring the power of templates to your page. You can create your own custom engines if you have a specific need.
- Content can be markdown/html/or RAW DATA to give you the content you need.
Installing Render Engine
Dependencies:
- Python3.8 or later.
Other Dependencies that install with render-engine
- Jinja2 - for template things
- Pendulum - for datetime things
- Click - for some commandline goodness
- more-itertools - for iteration things
- markdown - for markdown things
Using pip
pip install render-engine
Get Started Quickly
The Quick Way
render-engine-quickstart
This will create your essential files and a run.py
that you can use to build
your output file using python run.py
Render Engine DOESN'T Need the following but this model can quickly get you on your way.
content/ # store content for collections here
run.py # use `python run.py` to build your site.
templates/
- page.html # default template for Page objects. Modify this file to fit your design
- all_posts.html # default template for Collection objects. Modify this file to fit your design
static/ # will be copied into your generated output. great for storing css/.js/image files
Sponsors
This and much of the work that I do is made possible by those that sponsor me on github.
Sponsors at the $20/month and higher Level
Thank you to them and all of those that continue to support this project!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.