Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unfoldadmin/formula
Unfold Django admin theme demo repository for demonstration purposes implemening various admin possibilities
https://github.com/unfoldadmin/formula
admin dashboard django django-unfold tailwindcss theme ui
Last synced: 6 days ago
JSON representation
Unfold Django admin theme demo repository for demonstration purposes implemening various admin possibilities
- Host: GitHub
- URL: https://github.com/unfoldadmin/formula
- Owner: unfoldadmin
- License: mit
- Created: 2023-09-08T18:18:44.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-07T11:37:54.000Z (about 1 month ago)
- Last Synced: 2024-12-26T20:12:48.312Z (13 days ago)
- Topics: admin, dashboard, django, django-unfold, tailwindcss, theme, ui
- Language: Python
- Homepage: https://unfoldadmin.com
- Size: 1.11 MB
- Stars: 53
- Watchers: 3
- Forks: 16
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Formula - Django Unfold Admin Demo
The Formula repository contains a sample project build upon the Unfold theme for Django. It includes the best practices when it comes to Unfold but keep in mind that it does not incorporate any more in-depth business logic. Everything is composed just for demonstration purposes.
- [Unfold](https://github.com/unfoldadmin/django-unfold) - Admin theme for Django
- [Turbo](https://github.com/unfoldadmin/turbo) - Django & Next.js starter kit including Unfold## Table of contents
- [Installation](#installation)
- [Loading sample data](#loading-sample-data)
- [Custom Dashboard](#custom-dashboard)
- [Compiling Styles](#compiling-styles)## Installation
First of all, it is required to create new `.env` file containing environment variables for the project. In this case, there are just two most important variables needed to be configured. If you are on local machine, set `DEBUG=1` to enable debug mode for further development. Second variable is `SECRET_KEY` which needs to be configured with some random long and secure string. Project is quite simple and it should be possible to run it without Docker at all. Make sure Python 3.10 is installed together with Poetry and follow the commands below to install all required dependencies and run migrations.
```bash
git clone [email protected]:unfoldadmin/formula.git
```Run these commands inside `formula` directory, to install all dependencies and to run all migrations.
```bash
pip install poetry
poetry install
poetry run env $(cat .env) python src/manage.py migrate
```Create the admin user or you can't access to the instance.
```bash
poetry run env $(cat .env) python src/manage.py createsuperuser
```Run the command below to start the local development server.
```bash
poetry run env $(cat .env) python src/manage.py runserver
```## Loading sample data
After successful installation, database will be empty and there will be no data to observe through the admin area. Unfold provides some sample data available under `src/formula/fixtures`. These data can be loaded via commands below. It is important to run this command against empty database so primary keys will match.
```bash
poetry run env $(cat .env) python src/manage.py loaddata src/formula/fixtures/*
```## Custom Dashboard
The Formula demonstration project includes a custom dashboard. All components available in the dashboard are custom-made just for showcase and are not a part of Unfold. It means that any real data are used there and in case that real data are involved it is necessary to pass additional data into the template from the database.
All custom widgets used in Formula are located inside `src/formula/templates/admin/components/`. The main layout for the dashboard is created by overriding `index.html` and the content can be found here `src/formula/templates/admin/index.html`. For more information check official Unfold documentation.
## Compiling Styles
When creating a custom admin dashboard, you are going to locate all your HTML code with Tailwind classes in your project, so newly added dashboard styles are not compiled. To do so, the first thing which is needed is to edit `UNFOLD` variable in `settings.py` and add `STYLES` key pointing at the new CSS stylesheet containing all new styles.
```python
# settings.py
from django.templatetags.static import staticUNFOLD = {
"STYLES": [
lambda request: static("css/styles.css"),
],
}
```To compile new styles, run one of the commands below depending on your needs. To see what exactly the commands are doing and how the files are linked check `scripts` section inside `package.json`.
```bash
npm run tailwind:build # one-time build
npm run tailwind:watch # watch all files for changes
```Before compiling the styles it is important to install all node dependencies as well which in our case contain just TailwindCSS and its typography plugin for styling formatted blocks of texts inside the WYSIWYG editor.
```bash
npm install
```