Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emilstenstrom/django-components
Create simple reusable template components in Django.
https://github.com/emilstenstrom/django-components
components django django-templates pypi-package reusable-components
Last synced: 9 days ago
JSON representation
Create simple reusable template components in Django.
- Host: GitHub
- URL: https://github.com/emilstenstrom/django-components
- Owner: EmilStenstrom
- License: mit
- Created: 2015-06-11T17:23:48.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T09:17:58.000Z (3 months ago)
- Last Synced: 2024-10-29T11:37:10.829Z (3 months ago)
- Topics: components, django, django-templates, pypi-package, reusable-components
- Language: Python
- Homepage:
- Size: 6 MB
- Stars: 1,157
- Watchers: 16
- Forks: 76
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
#
[![PyPI - Version](https://img.shields.io/pypi/v/django-components)](https://pypi.org/project/django-components/) [![PyPI - Python Version](https://img.shields.io/pypi/pyversions/django-components)](https://pypi.org/project/django-components/) [![PyPI - License](https://img.shields.io/pypi/l/django-components)](https://github.com/EmilStenstrom/django-components/blob/master/LICENSE/) [![PyPI - Downloads](https://img.shields.io/pypi/dm/django-components)](https://pypistats.org/packages/django-components) [![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/EmilStenstrom/django-components/tests.yml)](https://github.com/EmilStenstrom/django-components/actions/workflows/tests.yml)
### [Read the full documentation](https://EmilStenstrom.github.io/django-components/latest/)
Django-components is a package that introduces component-based architecture to Django's server-side rendering. It aims to combine Django's templating system with the modularity seen in modern frontend frameworks.
A component in django-components can be as simple as a Django template and Python code to declare the component:
```htmldjango title="calendar.html"
Today's date is {{ date }}
``````py title="calendar.py"
from django_components import Componentclass Calendar(Component):
template_file = "calendar.html"
```Or a combination of Django template, Python, CSS, and Javascript:
```htmldjango title="calendar.html"
Today's date is {{ date }}
``````css title="calendar.css"
.calendar {
width: 200px;
background: pink;
}
``````js title="calendar.js"
document.querySelector(".calendar").onclick = function () {
alert("Clicked calendar!");
};
``````py title="calendar.py"
from django_components import Componentclass Calendar(Component):
template_file = "calendar.html"
js_file = "calendar.js"
css_file = "calendar.css"
```Alternatively, you can "inline" HTML, JS, and CSS right into the component class:
```py
from django_components import Componentclass Calendar(Component):
template = """
Today's date is {{ date }}
"""css = """
.calendar {
width: 200px;
background: pink;
}
"""js = """
document.querySelector(".calendar").onclick = function () {
alert("Clicked calendar!");
};
"""
```## Features
1. 🧩 **Reusability:** Allows creation of self-contained, reusable UI elements.
2. 📦 **Encapsulation:** Each component can include its own HTML, CSS, and JavaScript.
3. 🚀 **Server-side rendering:** Components render on the server, improving initial load times and SEO.
4. 🐍 **Django integration:** Works within the Django ecosystem, using familiar concepts like template tags.
5. ⚡ **Asynchronous loading:** Components can render independently opening up for integration with JS frameworks like HTMX or AlpineJS.Potential benefits:
- 🔄 Reduced code duplication
- 🛠️ Improved maintainability through modular design
- 🧠 Easier management of complex UIs
- 🤝 Enhanced collaboration between frontend and backend developersDjango-components can be particularly useful for larger Django projects that require a more structured approach to UI development, without necessitating a shift to a separate frontend framework.
## Quickstart
django-components lets you create reusable blocks of code needed to generate the front end code you need for a modern app.
Define a component in `components/calendar/calendar.py` like this:
```python
@register("calendar")
class Calendar(Component):
template_file = "template.html"def get_context_data(self, date):
return {"date": date}
```With this `template.html` file:
```htmldjango
Today's date is {{ date }}
```Use the component like this:
```htmldjango
{% component "calendar" date="2024-11-06" %}{% endcomponent %}
```And this is what gets rendered:
```html
Today's date is 2024-11-06
```### [Read the full documentation](https://EmilStenstrom.github.io/django-components/latest/)
... or jump right into the code, [check out the example project](https://github.com/EmilStenstrom/django-components/tree/master/sampleproject))
## Release notes
Read the [Release Notes](https://github.com/EmilStenstrom/django-components/tree/master/CHANGELOG.md)
to see the latest features and fixes.## Community examples
One of our goals with `django-components` is to make it easy to share components between projects. If you have a set of components that you think would be useful to others, please open a pull request to add them to the list below.
- [django-htmx-components](https://github.com/iwanalabs/django-htmx-components): A set of components for use with [htmx](https://htmx.org/). Try out the [live demo](https://dhc.iwanalabs.com/).
- [djc-heroicons](https://pypi.org/project/djc-heroicons/): A component that renders icons from [Heroicons.com](https://heroicons.com/).
## Contributing and development
Get involved or sponsor this project - [See here](https://emilstenstrom.github.io/django-components/dev/overview/contributing/)
Running django-components locally for development - [See here](https://emilstenstrom.github.io/django-components/dev/overview/development/)