Base templates for management interfaces
Go to file
Benjamin Dauvergne 354a63126c setup.py: remove long description (#32187) 2019-04-11 09:51:02 +02:00
debian debian: drop obsolete libjpeg8-dev from build-depends (#24394) 2018-06-11 08:37:40 +02:00
gadjo style: add back a yellow/black banner on tests (#31348) 2019-03-13 10:18:36 +01:00
icons style: redesign for winter 2018 (#28303) 2018-11-24 13:54:13 +01:00
.gitignore integrate icons for the various services (#7455) 2015-06-04 10:24:12 +02:00
AUTHORS initial commit with authors and license 2014-03-23 21:32:17 +01:00
COPYING initial commit with authors and license 2014-03-23 21:32:17 +01:00
MANIFEST.in misc: distribute css map file (#24660) 2018-06-20 10:10:27 +02:00
README.txt add generic pagination template (#14939) 2018-01-02 10:41:37 +01:00
setup.py setup.py: remove long description (#32187) 2019-04-11 09:51:02 +02:00

README.txt

=====
Gadjo
=====

Gadjo is a base template for Django applications, tailored for
management interfaces, built to provide a nice and modern look, while
using progressive enhancement and responsive designs to adapt to
different environments.


Usage
=====

Make your application base template {% extends "gadjo/base.html" %}.


You should add gadjo.finders.XStaticFinder to STATICFILES_FINDERS,

  from django.conf import global_settings

  STATICFILES_FINDERS = global_settings.STATICFILES_FINDERS + \
    ('gadjo.finders.XStaticFinder',)

There is a CDNS settings, that can contain a list of (cdn name, protocol)
tuples; for example:

  CDNS = [('google', 'https')]


Additional static files
------------------------

Additional static files libraries can be added via INSTALLED_APPS,
for example 'xstatic.pkg.jquery_tablesorter'; its static files can
then be referred in a template using the xstatic template tag:

  {% xstatic 'jquery_tablesorter' 'jquery.tablesorter.js' %}


Progressive enhancement -- Dialogs
----------------------------------

Links marked with rel="popup" will be opened into dialog boxes.

The dialog title is extracted from "#appbar h2" (this selector can be
changed with a @data-title-selector attribute on the anchor tag).

The dialog content is extracted from "form" (this selector can be
changed with a @data-selector attribute).

Buttons (both <button> and <a>) are extracted from the content and
converted into proper dialog buttons.  A button with "cancel" as its
class will have its action changed to simply close the dialog, without
server processing.

After loading the dialog content, a gadjo:dialog-loaded event is
triggered on the anchor with the dialog content as argument.

Alternatively the server may notice the ajax request and answer with
an appropriate JSON response. In that case it should have a 'content'
attribute with the HTML content, or a 'location' attribute in case of
a redirect.

In case of such a redirect, a gadjo:dialog-done event is triggered on
the anchor and can be cancelled to prevent the default redirect
behaviour.


Licence
=======

Python, Javascript and CSS files are published under the GNU AFFERO GENERAL
PUBLIC LICENSE (see the COPYING file for the complete text).

gadjo/static/images/info-icon.png and icons/*.svg are derived work of icons
from gnome-icon-theme-symbolic, published under the Creative Commons
Attribution-Share Alike 3.0 United States License by the GNOME Project, see
http://www.gnome.org/.

gadjo/static/css/header-03.jpeg is copied from let's encrypt website, licensed
under Mozilla Public License Version 2.0, see their repository at
https://github.com/letsencrypt/website.git.

The querystring template tag is originally from django-tables2, copyright (c)
2011, Bradley Ayers, copyright (c) 2008, Michael Elsdörfer, published under
the MIT license.
https://raw.githubusercontent.com/jieter/django-tables2/master/LICENSE