AngularJS is a Model-View-Controller framework to build dynamic user interfaces. It does double-data binding at its core.
We are transitioning to Vuejs, which is waaaaay better (better doc, better error messages, easier creation of components and unit tests).
Angularjs is now deprecated in favor of Angular2.
Read our Angular crash course to learn how to add Angular to a Django project, how to build everything, and how everything works.
The Node Package Manager. Install dependencies listed in package.json (it must be a valid json: no commentaries, beware of trailing commas) and execute post-install actions.
Run:
npm install
It installs gulp, bower, etc.
Post-actions:
Todo: enable js tests: https://github.com/bearstech/cookiecutter-django-bootstrap-angular/blob/master/{{cookiecutter.project_name}}/package.json
Now a few words about npm libraries we use.
http://www.datejs.com/2007/11/27/getting-started-with-datejs/
It enhances the javascript Date object with many useful methods. For example, we can print a date to a given format with date.toString(“yyyy-MM-dd”). With bare javascript this isn’t possible (as cleanly).
Bower is a package manager (of js libraries) optimized for the front-end. It uses a flat dependency-tree, requiring only one version for each package. It requires nodejs, npm and git.
django-bower leverages some actions to install bower packages.
Given some configuration into settings.py, it provides a management command to install packages in static/bower_components/.:
./manage.py bower install
The list of requirements lies in settings.py into the variable BOWER_INSTALLED_APPS.
Then we can add scripts in templates like::
{% load static %}
<script type="text/javascript" src='{% static 'jquery/jquery.js' %}'></script>
Note
we are now using Brunch with Vuejs.
Gulp defines itself as the streaming build system. We configure actions to:
The defined actions are (see gulpfile.js):
A loader, like Webpack but simpler (less configuration to write), sufficient for our needs. http://brunch.io/
A browser understands javascript, so the front end of a web app must be written in js. However, it is a very unconsistent language with many pitfalls, and a bit of a pain to write because of its many parenthesis and brackets, especially for a python developer.
Many alternatives exist and LiveScript is a fantastic one. It is a little language that transpiles to javascript. It solves many inconsistencies of js, it doesn’t get in our way, it is indentation-aware like Python, it is very concise, it greatly encourages functional programming and it has a good tooling and community. See what’s possible to do in very few lines of code with its prelude library.
Livescript has many more to offer than other alternatives like Coffeescript or RapydScript (the “pythonic” javascript).
Quick reference:
functions are declared like in coffeescript with the arrow notation. They return the last expression by default, unless we declare the function with !->, in which case we need to write the return statement.
save = (arg) ->
    ...
the do notation helps in many things, like creating dictionnaries (javascript objects)
params = do
  card_id: $scope.card_id
the functional methods are handy to manipulate data. We can chain them with the |> pipe:
cards_with_stock = all_cards
|> filter (.quantity > 0)
which is a shortcut to access an object’s attribute or method. We can also write anonymous functions where it represents the method argument:
cards_with_stock = all_cards |> filter ( -> it[quantity] > 0)
When a user action takes a long time and we want the server to respond quickly, or when we want to run periodic tasks: we need a tasks queue, and `Huey < https://huey.readthedocs.io/en/latest/ >`_ is one of them.
The most common solution is Celery, but it’s a huge beast, with many dependencies, and can be tricky to setup. Huey only depends on Redis and on its python binding. It’s also straightforward to use. Django-rq could have been a solution, with the advantage of a Django dashboard.
We use Huey to apply inventories. See search.tasks.py. To create an async function we just add the db_task() decorator. Calling an async function is just a regular function call. See search.models.api.py.
Another nice usage will be sending periodic emails, or checking that books prices didn’t change.
Fabric helps to run remote management commands to instances through ssh. See the fabfile.py.
Whitenoise makes it easier (than nginx and apache modules) to self-contain a web app.
Gunicorn is full python (so has similar avantages).
Tox is a generic virtualenv management and test command line tool we can use for:
checking our package installs correctly with different Python
test tool of choice
reducing boilerplate and merging CI and shell-based testing.
Abelujo only runs on python2.7 at the moment. Tox helps us test that our application installs and runs correctly in a fresh virtual environment.
`Sentry <https://docs.sentry.io/clients/python/integrations/django/`_ is a tool that sends all uncaught exceptions to an online app. Logs on steroids.
We have to create an account on give our sentry token to an Abelujo instance. See the fabfile and its save_variables task. We put the token in a sentry.txt file which Django settings read if the file exists. Fabric is in charge of sending the token to a remote server on installation.
Test with python manage.py raven test and see the new log in your dashboard.