Skip to main content

Show staff-only controls at website frontents

Project description

https://img.shields.io/travis/edoburu/django-staff-toolbar/master.svg?branch=master https://img.shields.io/pypi/v/django-staff-toolbar.svg https://img.shields.io/pypi/l/django-staff-toolbar.svg https://img.shields.io/codecov/c/github/edoburu/django-staff-toolbar/master.svg

django-staff-toolbar

Displaying staff-only controls at a webpage.

Features:

  • Linking to the admin page of the current object.

  • Full configuration of the displayed toolbar items.

  • API for adding custom menu items.

django-staff-toolbar preview

Installation

First install the module, preferably in a virtual environment:

pip install django-staff-toolbar

Configuration

Add the application to settings.py:

INSTALLED_APPS += (
    'staff_toolbar',
)

Make sure the django.core.context_processors.request is included in TEMPLATE_CONTEXT_PROCESSORS.

Add the HTML widget to the template:

{% load staff_toolbar_tags %}

{% staff_toolbar %}

Make sure the layout is loaded in the template:

<link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}staff_toolbar/staff_toolbar.css" />

Layout

By default, a simple layout is included. You can change this layout to your own liking.

The source SASS file is included, making it easier to integrate this into your project stylesheets when needed.

Customizing the admin URL

The admin URL is auto-detected using:

  • The object variable in the template.

  • The view.object variable in the template.

In some cases, this is not sufficient. When the auto-detected “Change object” link does not point to the right page, this can be resolved using two methods:

Using the view

When your class-based-view implements staff_toolbar.views.StaffUrlMixin, that information will be used to render the proper “Change object” link.

This requires Django 1.5, which exports the view variable to the template.

Using the template

In the template, you can include:

{% set_staff_object page %}

When needed, the URL can also be set:

{% set_staff_url %}{% url 'dashboard:catalogue-product' object.id %}{% end_set_staff_url %}

Customizing the menu

The default menu settings are:

STAFF_TOOLBAR_ITEMS = (
    'staff_toolbar.items.AdminIndexLink',
    'staff_toolbar.items.ChangeObjectLink',
    'staff_toolbar.items.LogoutLink',
)

Each line represents a callable, which is called using (request, context). When a tuple is included, this is converted into a new Group object, causing an additional <ul> tag to appear in the output.

A more complex example:

from django.core.urlresolvers import reverse_lazy
from django.utils.translation import ugettext_lazy as _
from staff_toolbar import toolbar_item, toolbar_link, toolbar_title, toolbar_literal

STAFF_TOOLBAR_ITEMS = (
    'staff_toolbar.items.AdminIndexLink',
    'staff_toolbar.items.ChangeObjectLink',
    (
        toolbar_title(_("User")),
        toolbar_link(url=reverse_lazy('admin:password_change'), title=_("Change password")),
        'staff_toolbar.items.LogoutLink',
    )
)

The toolbar_title() and toolbar_item() functions allow to pass additional arguments to the items, without having to load them already in the settings.

It’s also perfectly possible to instantiate the actual classes directly, however this may risk import errors as it causes your settings module to load a lot of other code. The following is functionally equivalent to the previous example:

from django.core.urlresolvers import reverse_lazy
from django.utils.translation import ugettext_lazy as _
from staff_toolbar.items import AdminIndexLink, ChangeObjectLink, Group, ToolbarTitle, Link, LogoutLink

STAFF_TOOLBAR_ITEMS = (
    AdminIndexLink(),
    ChangeObjectLink(),
    Group(
        ToolbarTitle(_("User")),
        Link(url=reverse_lazy('admin:password_change'), title=_("Change password")),
        LogoutLink(),
    )
)

Caveats

For HTTPS sites with SESSION_COOKIE_SECURE = True the toolbar obviously won’t show up in the standard pages that are served by HTTP.

Either display all pages on HTTPS (which is the Right Way™ after all), or please provide a good pull request that solves this nicely for mixed sites.

Contributing

This module is designed to be generic, and easy to plug into your site. Pull requests and improvements are welcome!

If you have any other valuable contribution, suggestion or idea, please let us know as well!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-staff-toolbar-2.0.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

django_staff_toolbar-2.0-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file django-staff-toolbar-2.0.tar.gz.

File metadata

  • Download URL: django-staff-toolbar-2.0.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.6

File hashes

Hashes for django-staff-toolbar-2.0.tar.gz
Algorithm Hash digest
SHA256 99fa1b031f79d86adcd9809f42321ef057e16cc7ea73338879b6d29f70eacb8a
MD5 7bf82d674db745f531d77b8a0edd3454
BLAKE2b-256 860c9eeabe6ca9c8f489963ad9e95fa9d63b1cef0fedde490fbf1f480e07f97b

See more details on using hashes here.

File details

Details for the file django_staff_toolbar-2.0-py3-none-any.whl.

File metadata

  • Download URL: django_staff_toolbar-2.0-py3-none-any.whl
  • Upload date:
  • Size: 17.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.6

File hashes

Hashes for django_staff_toolbar-2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 91783776f11ac2f41eb982fa9503b3a7a3ff97a44854d4ece6dc006e8d41cb35
MD5 8991cb2bccb624a11b7b25ec51555407
BLAKE2b-256 43220afd9988f3e0f53f03f285e7b837d07f3a01062f6bbca52055d2311b76ff

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page