Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/runekaagaard/django-hypergen
Take a break from javascript. Write server-rendered reactive HTML liveviews for Django in pure python 💫
https://github.com/runekaagaard/django-hypergen
django liveview python reactive
Last synced: 2 months ago
JSON representation
Take a break from javascript. Write server-rendered reactive HTML liveviews for Django in pure python 💫
- Host: GitHub
- URL: https://github.com/runekaagaard/django-hypergen
- Owner: runekaagaard
- License: mpl-2.0
- Created: 2021-01-21T10:25:39.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-12-11T10:20:51.000Z (about 1 year ago)
- Last Synced: 2024-10-31T10:42:37.169Z (2 months ago)
- Topics: django, liveview, python, reactive
- Language: Python
- Homepage: https://hypergen.it
- Size: 2.75 MB
- Stars: 68
- Watchers: 6
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
.. raw:: html
Hypergen
Take a break from javascript
Write server-rendered reactive HTML liveviews for Django in pure python 💫
Homepage •
Documentation •
Support
**Hypergen: A Hypertext Generator**:
Craft templates using pure Python. Instead of declaring ``hi
`` in an HTML file, simply invoke ``p("hi")`` within your view. Composing Python functions keeps templates DRY and streamlined. If you've ever written JSX, Hypergen's syntax will feel familiar.**Reactive Liveviews**:
Effortlessly bridge frontend and backend. Connect browser events like `onclick` straight to backend actions. With these actions, Django views can instantly refresh the frontend with new HTML, send notifications, and more, all while natively working with Python data types.**Websockets**:
Hypergen brings realtime to the forefront with Django Channels. Set up is a breeze - quickly establish consumers and instantly react to live events. It's realtime made simple and friendly, just the way we like it.**Production Ready**:
We've deployed Hypergen in projects spanning tens of thousands of lines, serving over 100,000 unique users more than 10 million requests.**Quickstart**:
Kickstart your Hypergen journey in minutes. Execute ``pip install django-hypergen``, append ``'hypergen'`` to ``INSTALLED_APPS``, include ``'hypergen.context.context_middleware'`` in ``MIDDLEWARE``, and you're all set to dive in.
How does it look?
=================Using Hypergens most high-level constructs, a simple counter looks like this:
.. code-block:: python
@liveview(perm=NO_PERM_REQUIRED)
def counter(request):
with html(), body(), div(id="content"):
template(0)@action(perm=NO_PERM_REQUIRED, target_id="content")
def increment(request, n):
template(n + 1)def template(n):
label("Current value: ")
input_el = input_(id="n", type_="number", value=n)
button("Increment", id="increment", onclick=callback(increment, input_el))You can `see it in action `_.
The ``callback(func, arg1, arg2, ..., **settings)`` function connects the onclick event to the ``increment(request, n)`` action. The ``n`` argument is the value of the input field.DOM elements are nested with the ``with`` statement.
It's python all the way down. 🔥🔥🔥
Features
========- 🧩 **Composable** - structure your app with ... TADAAA ... python functions
- 🌐 **Less infrastructure** - take a break from npm, npx, yarn, webpack, parcel, react, redux, gulp, angular, vue and friends
- 🚀 **Build truly singlepage apps** - avoid abstraction gaps to a template language and javascript
- ⏳ **Async not needed** - uses the vanilla Django Request-Response cycle by default
- 🔀 **Automatic (de)serialization** - use python builtin types and move on
- 🎯 **No magic strings** - reactivity is defined by referencing python functions
- 📦 **Free partial loading** - no special setup required, includes back/forward history support
- 🔒 **Control over client side events** - inbuilt confirmation dialogs, blocking and debouncing
- 📤 **Easy uploading of files** - with progress bar
- 💛 **Still loves javascript** - trivially call client functions from the server
- ⚡ **Realtime** - Create websocket consumers trivially
- 📜 **History buff?** - don't worry, Hypergen supports from Django 1.11, Python 3.6 and up to as of this writing Django 4.2.6 and python 3.12.
- 🛠️ **Hyperfy** - the command line app that converts html to hypergen python codeRunning the examples
====================.. code-block:: bash
git clone [email protected]:runekaagaard/django-hypergen.git
cd django-hypergen/
virtualenv -p python3.9 venv
source venv/bin/activate
pip install -r requirements-dev.txt
cd examples
python manage.py runserverThen browse to http://127.0.0.1:8000.
Contributing
============Bug reports and feature requests are `very welcome `_. So are pull requests or diffs.
Authors
=======Hypergen is written by `Jeppe Tuxen `_ and `Rune Kaagaard `_, both located around Copenhagen, Denmark.
We are using Hypergen extensively at work so it's a big focus of ours.
Why not Hypergen?
=================- Every frontend event calls the server. Not good for e.g. games.
- Python templating might not be for everyone. We found it works great in practice.Developing
==========Backend
-------Hypergen is located in ``src/hypergen``. Format all python code with yapf, a .yapf config file is present in the repository.
Frontend
--------Compile the javascript files:
.. code-block:: bash
cd hypergen/static/hypergen
npm install # use node 18 lts
# watch hypergen.js to dist/hypergen.js
npm start
# build hypergen.js to dist/hypergen.js
npm run build
Profiling
---------How fast are we?:
.. code-block:: bash
rm -f /tmp/hypergen.profile && python -m cProfile -o /tmp/hypergen.profile manage.py runserver 127.0.0.1:8002
echo -e 'sort tottime\nstats' | python3 -m pstats /tmp/hypergen.profile | less
# or
pyprof2calltree -i /tmp/hypergen.profile -k# or
rm -f /tmp/hypergen.profile && python -m cProfile -o /tmp/hypergen.profile manage.py inputs_profile && \
echo -e 'sort tottime\nstats' | python3 -m pstats /tmp/hypergen.profile | lessTesting
=======We have a `Github Action `_ that automatically tests a matrix of Django and Python versions. You can run the pytest tests locally like so:
.. code-block:: bash
pip install -r requirements-dev.txt
make pytest-runAnd the testcafe end-to-end_ tests:
.. code-block:: bash
npm i -g testcafe
make testcafe-run
# or
make testcafe-run-headlessRequires that the examples are running on ``127.0.0.1:8002``.
Thanks
======- `Django `_ - for making work fun
- `Morphdom `_ - for fast updating of the DOM tree
- `Pyrsistent `_ - for providing an immutable dict
- `sockette `_ - The cutest little WebSocket wrapper! 🧦
- `Simple.css `_ - for the no-class styling on the homepage
- `DALL-E mini `_ - for the logo generated with the query "a vibrant logo of the letter H"