A template tag to create a div and json script tag for react to bind to
Project description
Django BYO React
A minimal template tag which creates a div element for React to bind to and a Django json_script
which can be used to pass values from Django into the root React element as props. This library remains unopinionated about the React code by design since there are so many ways to create and maintain React apps.
Usage
Install the app in settings.py
INSTALLED_APPS = [
"django_byo_react",
...
]
In the template that you want to install a react app load the tag and use it with the given kwargs
. You can add extra props to the root react component by adding kwargs
to the tag element. As long as is json serializable it can be included in the props.
{% load byo_react %}
"{% byo_react id='react-app-id' className='w-100' showActive=True %}"
Javascript/Typescript Example
The JS/TS side is left to the user as there are many ways in which one can create a react app. This leaves the most flexibility to integrate existing react apps and frameworks into a django page. The one important point is that the id
is the variable that ties the backend to the frontend so keep this in sync.
Here is a typical example for a very basic app.
import React, { FC } from "react";
import ReactDOM from 'react-dom/client';
// Example root component for a react app
const App: FC = (props) => <div {...props}></div>
const elementId = "react-element-id"
const container = document.getElementById(elementId)
if (!container) throw new Error(`Can't find element with id ${elementId}`);
// Extract props from the django json_script tag
const jsonContent = document.getElementById(container.dataset?.scriptId)?.textContent;
if (!jsonContent) throw new Error("No associated script found");
// props will be a dictionary containing the tag kwargs
// eg: The props constant will be an object with { showActive: true }
const props = JSON.parse(jsonContent);
const root = ReactDOM.createRoot(container)
root.render(<App {...props} />);
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
Built Distribution
Hashes for django_byo_react-0.2.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89ac23d633ef784165163e6c5eb130e9a7d83c06008f0880dd76c40a7453a1f6 |
|
MD5 | 96bb67f6ef8c6d5456ada52dc4d1f46a |
|
BLAKE2b-256 | b8c247e7e22ac9e36f9e1dd2fe29f8d67cf99af08c62dad0ab60819eeb1b9969 |