- Python 2.6 or 2.7
Install virtualenv:
$ wget http://pypi.python.org/packages/source/v/virtualenv/virtualenv-1.10.1.tar.gz
$ tar zxf virtualenv-1.10.1.tar.gz
$ cd virtualenv-1.10.1
$ python setup.py install
You may need to do that last step as root. Just make sure you use the correct Python binary for OSes with multiple Python versions.
Create a virtual environment for the project:
$ virtualenv myproject-env
$ cd myproject-env
$ source bin/activate
$ pip install django
Now run the startproject
command:
$ django-admin.py startproject --template https://github.com/bruth/wicked-django-template/zipball/master -e py,ini,gitignore,in,conf,md,sample,json -n Gruntfile.coffee myproject
$ cd myproject
Install the base requirements:
$ pip install -r requirements.txt
Build your base javascript and css files:
$ npm install
$ grunt
Then either start the built-in Django server:
$ ./bin/manage.py runserver
or run a uwsgi
process:
$ uwsgi --ini server/uwsgi/local.ini --protocol http --socket 127.0.0.1:8000 --check-static _site
- clean project structure
_site
directory for web server document root- copied static files and user uploaded media files
- works well with nginx's
try_files
directive maintenance
directory for toggling maintenance mode's
- server configurations for nginx, uWSGI, and Supervisor
- note: the paths will need to be updated to match your environment
- tiered settings for easier cross-environment support
global_settings.py
for environment-independent settingslocal_settings.py
for environment-specific settings (not versioned)settings.py
for bringing them together and post-setup
local_settings.py.sample
template- a clean static directory for large Web app development
- wicked hot Gruntfile for watching static files pre-processors:
grunt watch
- CoffeeScript (requires Node and CoffeeScript)
- SCSS (requires Ruby and Sass)
- compiles scss => css
- compiles coffee => javascript/src
- integration with r.js
grunt requirejs
- compiles javascript/src => javascript/min
- context processor for including more direct static urls
{{ CSS_URL }}
{{ JAVASCRIPT_URL }}
{{ IMAGES_URL }}
- full-featured fabfile.py for one-command deployment
- Ruby
- Node
- Ruby Compass gem
- Node CoffeeScript module
build
- builds and initializes all submodules, compiles SCSS and CoffeeScript and optimizes JavaScriptwatch
- watches the CoffeeScript and SCSS files in the background for changes and automatically recompiles the filescompass
- one-time explicit recompilation of SCSS filescoffee
- one-time explicit recompilation of CoffeeScript files
mm_on
- turns on maintenance modemm_off
- turns off maintenance modedeploy
- deploy a specific Git tag on the host
local_settings.py
is intentionally not versioned (via .gitignore). It should
contain any environment-specific settings and/or sensitive settings such as
passwords, the SECRET_KEY
and other information that should not be in version
control. Defining local_settings.py
is not mandatory but will warn if it does
not exist.
Ensure Node, NPM and CoffeeScript are installed:
$ npm install coffee-script -g
CoffeeScript is lovely. The flow is simple:
- write some CoffeeScript which automatically gets compiled in JavaScript
(by doing
make watch
) - when ready to test non-
DEBUG
mode, runmake optimize
The 'Gruntfile.coffee' file will need to be updated to define which modules should be compiled to single files. It is recommended to take a tiered approach to reduce overall file size across pages and increase cache potential for libraries that won't change for a while, for example jQuery.
Ensure Ruby and the Compass gem are installed:
$ gem install compass
Sass is awesome. SCSS is a superset of CSS so you can use as much or as little SCSS syntax as you want. It is recommended to write all of your CSS rules as SCSS, since at the very least the Sass minifier can be taken advantage of.
Execute the following commands to begin watching the static files and collect the files (using Django's collectstatic command):
$ grunt sass coffee watch collect
Note, the sass
and coffee
targets are called first to ensure the compiled
files exist before attempting to collect them. Just running watch
spawns
background processes and may result in a race condition with the collect
command.