This article explains how to integrate a bootstrap template in Django. I am using renowned bootstrap admin template SBAdmin in this tutorial.This tutorial is written in Ubuntu 16.04.
Watch the demo here:- (Click the gear icon and select video quality to 1080p HD, then click the full screen button for good quality)
Go to this link to subscribe to my YouTube channel to stay updated:- https://www.youtube.com/channel/UCxTp2yDew9m48Ch_hArOoYw
A bootstrap theme may have many dependencies like bootstrap library, jquery and other javascript plugins and css files.
So integrate these all to a Django project is something tricky.
We need to load the dependent libraries as static files. Then create parent templates for admin pages and normal pages. Copy body sections of each page in the template, then paste it into equivalent pages in our project. Then set view functions and urls correctly. I am explaining all these steps in this tutorial.
To download the full source file go to end of the tutorial.
First, create a directory named admin_proj somewhere in your home directory. Open that folder, then open a terminal window in that location. Then run these commands to install Django.
Then create a project named admin_proj and app named admin_app by run following commands
For detailed tutorial about installing Django locally, then create a project go to this link:- http://newprograminglogics.blogspot.com/2018/02/install-python-3-and-set-up-local.html
Open admin_proj/admin_proj/settings.py then add 'admin_app' to the INSTALLED_APPS section.
Watch the demo here:- (Click the gear icon and select video quality to 1080p HD, then click the full screen button for good quality)
Go to this link to subscribe to my YouTube channel to stay updated:- https://www.youtube.com/channel/UCxTp2yDew9m48Ch_hArOoYw
A bootstrap theme may have many dependencies like bootstrap library, jquery and other javascript plugins and css files.
So integrate these all to a Django project is something tricky.
We need to load the dependent libraries as static files. Then create parent templates for admin pages and normal pages. Copy body sections of each page in the template, then paste it into equivalent pages in our project. Then set view functions and urls correctly. I am explaining all these steps in this tutorial.
To download the full source file go to end of the tutorial.
First, create a directory named admin_proj somewhere in your home directory. Open that folder, then open a terminal window in that location. Then run these commands to install Django.
virtualenv -p python3 env
source env/bin/activate
pip install Django
source env/bin/activate
pip install Django
Then create a project named admin_proj and app named admin_app by run following commands
django-admin startproject admin_proj .
django-admin startapp admin_app
django-admin startapp admin_app
For detailed tutorial about installing Django locally, then create a project go to this link:- http://newprograminglogics.blogspot.com/2018/02/install-python-3-and-set-up-local.html
Open admin_proj/admin_proj/settings.py then add 'admin_app' to the INSTALLED_APPS section.
Next open admin_proj/admin_proj/urls.py.
Add an include keyword in the line from django.urls import path
Now it will look like
from django.urls import path,include
Add this line in the urlpatterns section
path('admin_app/', include('admin_app.urls'))
Now download SBAdmin 2 template files from this link, https://github.com/BlackrockDigital/startbootstrap-sb-admin-2/archive/gh-pages.zip
Then extract the zip file.
It is the time to load these template files to our Django project as static files.
For this check following line is included in the INSTALLED_APPS section of admin_proj/admin_proj/settings.py
'django.contrib.staticfiles'
Then check this line is exist in the same settings.py file
STATIC_URL = '/static/'
Go to this link, for the detailed tutorial about load static files: - http://newprograminglogics.blogspot.com/2018/03/load-static-files-in-django-20.html
Then create a folder named static in admin_app folder.
Create a folder named admin_app inside it. Then copy vendor,dist,data directories from the extracted SBAdmin directory to admin_proj/admin_app/static/admin_app directory.
Now the static directory will look like this
├── migrations
├── static
│ └── admin_app
│ ├── data
│ ├── dist
│ └── vendor
All js and css files are now in correct location. Now we can create some templates to display.
In the admin_app folder, create a folder named templates Create another folder named admin_app in it. I am going to create two base templates. One for admin pages with sidebar and header and another for login and regular pages without sidebar and header. Create a file named admin.html
Now the templates directory will look like this
├── migrations
├── static
├── templates
│ └── admin_app
│ ├── admin.html
Open index.html in pages directory of downloaded SBAdmin theme. Copy and paste the contents to admin.html. Delete the content inside the div with id "page-wrapper".
Now add the code inside "page-wrapper" div.
{% block content %}{% endblock %}
Our admin template is ready now. Now we can create a child html file to consume this template.
Create a file named dashboard.html in the same location of admin.html. Once again open index.html in pages directory of downloaded SBAdmin theme. Copy the content inside "page-wrapper" div and paste to dashboard.html
Then add these line in top of the same file.
{% extends "admin_app/admin.html" %}
{% block content %}
{% block content %}
Add this code at the bottom of the file
{% endblock %}
Now we are going to change the source url of script files.
../vendor/jquery/jquery.min.js should change to
{% static 'admin_app/vendor/jquery/jquery.min.js' %}
Similarly ../data/morris-data.js should change to
{% static 'admin_app/data/morris-data.js' %}
Do this for all js files and css files. You should add this line in the top of the file
{% load static %}
Copy all scripts into <head> section. Keep only common scripts and css like jquery.js and bootstrap.js in admin.html. Move other scripts like morris-data.js into dashboard.html. Because it is only needed on the dashboard page.
Add the same code at the top of dashboard.html also
{% load static %}
Then change the sidebar menu urls like this {% url 'admin_app:index' %} in admin.html.
This will create a url to localhost:8000/admin_app .We hadn't created any urls yet, but we will create it later.
Now we have created an admin.html template and a file named dashboard.html which consume the admin.html.
In the same way you can create equivalent pages for every page in the downloaded theme like buttons.html,forms.html, flot.html, gridhtml,icons.html etc.
In the same manner create another template named front_end.html and page named login.html from login.html page of downloaded theme.
Open admin_proj/admin_app/views.py. Then add this code
def index(request):
return render(request, 'admin_app/dashboard.html')
return render(request, 'admin_app/dashboard.html')
This means the view function named index return the contents of dashboard.html. Similarly create functions for all other pages we created earlier.
Now create a file named urls.py in the same location of views.py, then add these code
from django.urls import path
from . import views
app_name = 'admin_app'
urlpatterns = [
path('', views.index, name='index')
]
from . import views
app_name = 'admin_app'
urlpatterns = [
path('', views.index, name='index')
]
In this code path('', views.index, name='index') means that call to root url should call the index function in views.py.
Similarly, connect all views functions to equivalent urls.
Done we have successfully integrated a bootstrap template to Django. Now run python manage.py runserver, the open http:localhost:8000/admin_app in any browser.
If you don't have time to execute all the steps mentioned above you can buy the example source code from here:- https://payhip.com/b/I3sTL
After download completed, extract the folder to somewhere on your computer, then open a terminal window inside the extracted project directory. Then run the following commands
virtualenv -p python3 env
source env/bin/activate
pip install django
python manage.py runserver
source env/bin/activate
pip install django
python manage.py runserver
Then open http://127.0.0.1:8000/admin_app in any browser.
This comment has been removed by a blog administrator.
ReplyDeleteFor Windows please use the below
ReplyDeleteD:\Development\admin_proj>pip install virtualenv
Collecting virtualenv
Using cached https://files.pythonhosted.org/packages/7e/1b/6c00d57127608793e16e8b7f813e64d58a1938505c42fe190d1386ab41e1/virtualenv-16.4.0-py2.py3-none-any.whl
Installing collected packages: virtualenv
Successfully installed virtualenv-16.4.0
You are using pip version 19.0.1, however version 19.0.2 is available.
You should consider upgrading via the 'python -m pip install --upgrade pip' command.
D:\Development\admin_proj>virtualenv env
Using base prefix 'c:\\program files (x86)\\python37-32'
New python executable in D:\Development\admin_proj\env\Scripts\python.exe
Installing setuptools, pip, wheel...
done.
D:\Development\admin_proj>
D:\Development\admin_proj>env\Scripts\activate.bat
(env) D:\Development\admin_proj>pip install django
Collecting django
Downloading https://files.pythonhosted.org/packages/c7/87/fbd666c4f87591ae25b7bb374298e8629816e87193c4099d3608ef11fab9/Django-2.1.7-py3-none-any.whl (7.3MB)
100% |¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦| 7.3MB 1.1MB/s
Collecting pytz (from django)
Using cached https://files.pythonhosted.org/packages/61/28/1d3920e4d1d50b19bc5d24398a7cd85cc7b9a75a490570d5a30c57622d34/pytz-2018.9-py2.py3-none-any.whl
Installing collected packages: pytz, django
Successfully installed django-2.1.7 pytz-2018.9
(env) D:\Development\admin_proj>python manage.py runserver 0.0.0.0:8000
Performing system checks...
System check identified no issues (0 silenced).
You have 15 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.
February 14, 2019 - 09:47:05
Django version 2.1.7, using settings 'admin_proj.settings'
Starting development server at http://0.0.0.0:8000/
Quit the server with CTRL-BREAK.
This comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteperfect post.
ReplyDeleteeven pass 2 years,but this idea is cool.
i do it for the new bootstrap template for django 3.0.4, only cost 3 hours.
just copy one by one.
This comment has been removed by a blog administrator.
ReplyDeleteunable to find dist,data directories from the downloaded and extracted SBAdmin directory
ReplyDeleteNice articel, This article help me very well. Thank you. Also please check my article on my site about What Is Angular?.
ReplyDeleteArticles can explore the history and cultural significance of ancient civilizations, such as the Maya, Inca, and Ancient Egypt. Nord VPN Offer Blogs can offer tips and strategies for managing and overcoming syndrome.
ReplyDelete