https://github.com/metakermit/django-spa
Simple Django configuration to serve a single-page app
https://github.com/metakermit/django-spa
angular django django-rest-framework heroku react spa whitenoise
Last synced: 5 months ago
JSON representation
Simple Django configuration to serve a single-page app
- Host: GitHub
- URL: https://github.com/metakermit/django-spa
- Owner: metakermit
- License: mit
- Created: 2017-04-08T10:31:29.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T03:20:07.000Z (over 3 years ago)
- Last Synced: 2025-03-18T01:01:47.602Z (about 1 year ago)
- Topics: angular, django, django-rest-framework, heroku, react, spa, whitenoise
- Language: Python
- Size: 163 KB
- Stars: 99
- Watchers: 7
- Forks: 19
- Open Issues: 16
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE
Awesome Lists containing this project
README
==========
django-spa
==========
.. image:: https://badge.fury.io/py/django-spa.svg
:target: https://badge.fury.io/py/django-spa
.. image:: https://travis-ci.org/metakermit/django-spa.svg?branch=master
:target: https://travis-ci.org/metakermit/django-spa
.. image:: https://readthedocs.org/projects/django-spa/badge/?version=latest
:target: https://django-spa.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status
.. image:: https://pyup.io/repos/github/metakermit/django-spa/shield.svg
:target: https://pyup.io/repos/github/metakermit/django-spa/
:alt: Updates
.. image:: https://img.shields.io/badge/license-MIT-blue.svg
:target: https://raw.githubusercontent.com/metakermit/django-spa/master/LICENSE
:alt: GitHub license
Django package to serve a single-page app (SPA).
The following settings that make serving SPAs easier
are handled in django-spa:
* *index.html* served when ``/`` requested
* all ``/static/…`` files served on ``/…`` as well
* Django's urls still work (Django admin, templates, Django REST framework APIs)
* everything else goes to ``/`` for frontend routing (e.g. `react-router`_)
Usage
------
For an example of using django-spa to serve a create-react-app frontend
that consumes a Django REST framework API, check out generator-django-rest_.
As part of setting up django-spa, you also need to set up WhiteNoise_,
which we'll summarise here.
First, add ``django-spa`` to your *requirements.txt*
and ``pip install -r requirements.txt`` (or ``pipenv install django-spa``).
Whitenoise is installed as a dependency, so no need to specify it extra.
Update *settings.py* with the Whitenoise & django-spa middleware::
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'whitenoise.middleware.WhiteNoiseMiddleware',
'spa.middleware.SPAMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
Disable runserver's static file serving by adding ``runserver_nostatic``
to the top of your INSTALLED_APPS list::
INSTALLED_APPS = [
'whitenoise.runserver_nostatic',
'django.contrib.staticfiles',
# ...
]
Set the django-spa static file storage::
STATICFILES_STORAGE = 'spa.storage.SPAStaticFilesStorage'
You should be good to go!
Credits
---------
Used some parts of the solution suggested in this `WhiteNoise issue`_
for serving index.html on ``/``.
This package was created with Cookiecutter_
and the `audreyr/cookiecutter-pypackage`_ project template.
License
--------
MIT_
.. _Whitenoise: http://whitenoise.evans.io/en/stable/django.html
.. _`Whitenoise issue`: https://github.com/evansd/whitenoise/issues/12
.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage
.. _`react-router`: https://reacttraining.com/react-router/
.. _generator-django-rest: https://github.com/metakermit/generator-django-rest
.. _MIT: LICENSE