Skip to main content

A zero-fuss way to create non single page apps with react.

Project description

React Pages

A zero-fuss way to create non single page apps with react.
  • Zero Configuration required. Mostly thanks to create-react-app.
  • Custom react scripts inbuilt.
  • Import non-compiled JSX from anywhere (create-react-app doesn't allow this).
  • Ready-to-serve production builds with the proper paths. (using --static-url option)
  • Natively use react in django.
  • Go from development to production with ease.
  • Caches npm stuff. You'll notice that the command react-pages project runs much after the 1st time.

Terminology

Project

The project contains the node.js modules necessary to use react and the pages you create.

└── my_project
    ├── package.json
    ├── package-lock.json
    ├── .env
    ├── .gitignore
    ├── public
    │   ├── favicon.ico
    │   ├── index.html
    │   └── manifest.json
    <pages>

Page:

A page is a directory containing at least an index.js file, (and other css/js files specific to your application.)

└── my_page
    ├── App.css
    ├── App.js
    ├── App.test.js
    ├── index.css
    ├── index.js
    ├── logo.svg
    └── registerServiceWorker.js

Install

PyPI version (tag)

pip install react-pages

License: MIT License (MIT)
Requires: Python >=3.6


If you don't have node,

For bash, use nvm.

For fish shell, you can use fisher fnm (get fisher).

Once you have npm/node, react pages will work as expected.

TODO: make react-pages automatically install node

Commands

# Basic

$ react-pages project my_project # create a "project"

$ cd my_project # don't forget to do this!

$ react-pages page my_page # create a "page"

$ react-pages develop # development

$ react-pages deploy # production

# (open ./my_project/build/my_page/index.html in browser)

# Misc

$ react-pages runserver # django runserver alternative

$ react-pages clear-cache

Django Integration

Quickstart

settings.py

INSTALLED_APPS = [
    ...
    'react_pages',
    ...
]

# specify the react-pages project directory
REACT_PAGES_PROJECT_DIR = os.path.join(BASE_DIR, 'my_project')

STATICFILES_DIRS = [
    ...
    os.path.join(REACT_PAGES_PROJECT_DIR, 'build')  # mark the build dir as a static file dir
    ...
]

template.html

{% load react_pages %}
...
{% render_react_page 'my_page' %}
...

Remember to use react-pages runserver instead of manage.py runserver!

(This was done to remove the manual build step).

That's it!
React Pages will pick-up the "my_page" page from "my_project" project and do the necessary work to transpile react JSX.

Django Context

You can pass django template context varialbes like so -

views.py

context['py_var'] = [1, 2, 3]

template.html

{% render_react_page 'my_page' js_var=py_var %}

App.js

console.log(js_var);

Note: These must be JSON serializable or JSON serialized.

For production, just put DEBUG=False in settings.py and relax.

Note: This is not implemented yet.

Existing projects

React Pages will automatically patch itsef into any existing project, that was created using create-react-app.

Just run react-pages project . from your project directory!

Projects not using create-react-app will probably work, but no guarantees can be made.

Issues

  • It might not uninstall using pip.

    This is a side-effect of react-page's caching.
    As a temporary fix, Run react-pages clear-cache, and then pip uninstall react-pages will work as expected.


Buy Me A Coffee

🐍🏕️

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

react-pages-0.1.7.tar.gz (135.4 kB view details)

Uploaded Source

Built Distribution

react_pages-0.1.7-py2.py3-none-any.whl (150.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file react-pages-0.1.7.tar.gz.

File metadata

  • Download URL: react-pages-0.1.7.tar.gz
  • Upload date:
  • Size: 135.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for react-pages-0.1.7.tar.gz
Algorithm Hash digest
SHA256 44a80775e88644a870647783f5d09ae91512e0bfabed0dd3ff5d875e72d85c8a
MD5 9e54c1ed2afc00b4a4c8ea5a30fc2a08
BLAKE2b-256 ff351cd1fb0d7b1fca0c351c25393dd32c96e48f079eaee52af7febd76bf041a

See more details on using hashes here.

File details

Details for the file react_pages-0.1.7-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for react_pages-0.1.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 84810ba7bdfac7e482c7f976666fafab5e04b19c651e092f1f6c04e7d669662e
MD5 73cbf7d5d77876acd00631ac1ea048a9
BLAKE2b-256 ef5f945dc3a669358df76d806e3dd1987cffa9e9eba4bd9476de21f99366df2f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page