Skip to main content

Simple navbar classes in clinicedc/edc projects

Project description

pypi actions codecov downloads

edc_navbar

Simple Navbar class for edc

Installation

Include edc_navbar.apps.AppConfig in INSTALLED_APPS.

Overiew

Navbars are declared in your apps navbars.py and will be autodiscovered by edc_navbar and stored in the site global site_navbars.

By default, a basic navbar is added to the site global. For it to load you need to define the named urls for home_url, administration_url and logout_url in your main project urls.py. The named urls defined in the default navbar do not include a namespace.

For example, in the “main” project app urls.py:

urlpatterns = [
    ...
    path('login', LoginView.as_view(), name='login_url'),
    path('logout', LogoutView.as_view(
        pattern_name='login_url'), name='logout_url'),
    path('admininistration/', AdministrationView.as_view(),
         name='administration_url'),
    path('', HomeView.as_view(manual_revision='1.0'), name='home_url'),
    ...
    ]

You can change the default navbar to another navbar by setting settings.DEFAULT_NAVBAR to the name of your custom navbar. You will need to declare and register your custom navbar manually. See edc_navbar.navbars.

The default template for NavbarItem is navbar_item.html. You can declare a custom template on the NavbarItem.

Render the Navbar

For example, in base.html:

{% load edc_dashboard_extras %}

...

{% show_edc_navbar %}

...

The rendered html comes from edc_navbar.html

Declaring and registering a navbar

A navbar is defined and registered to the site global in the navbars.py module of each app that needs a navbar.

An example navbars.py:

from edc_navbar import NavbarItem, site_navbars, Navbar

url_namespace = 'edc_pharmacy_dashboard'

# instantiate a Navbar
pharmacy_dashboard = Navbar(name='pharmacy_dashboard')

# add items to the navbar
pharmacy_dashboard.register(
    NavbarItem(
        name='prescribe',
        title='Prescribe',
        label='prescribe',
        glyphicon='glyphicon-edit',
        url_name=f'{url_namespace}:prescribe_listboard_url'))

pharmacy_dashboard.register(
    NavbarItem(
        name='dispense',
        title='Dispense',
        label='dispense',
        glyphicon='glyphicon-share',
        url_name=f'{url_namespace}:dispense_listboard_url'))

# register the navbar to the site
site_navbars.register(pharmacy_dashboard)

Accessing the navbar in your views

Next, add NavbarViewMixin to your views and set the navbar by name. The navbar will be rendered to string and added to the view context.

from edc_navbar import NavbarViewMixin

class HomeView(EdcViewMixin, NavbarViewMixin, TemplateView):

    navbar_name = 'pharmacy_dashboard'
    navbar_selected_item = 'prescribe'

Rendering Navbar items

The default template for NavbarItem is navbar_item.html. You can declare a custom template on the NavbarItem.

Permissions per NavbarItem

Each NavbarItem can declare a Django permissions codename. The codename will be associated with model edc_navbar.navbar.

For example:

from edc_navbar import NavbarItem, site_navbars, Navbar

url_namespace = 'edc_pharmacy_dashboard'

# instantiate a Navbar
pharmacy_dashboard = Navbar(name='pharmacy_dashboard')

# add items to the navbar
pharmacy_dashboard.register(
    NavbarItem(
        name='prescribe',
        title='Prescribe',
        label='prescribe',
        glyphicon='glyphicon-edit',
        permissions_codename='nav_pharmacy_prescribe',
        url_name=f'{url_namespace}:prescribe_listboard_url'))

pharmacy_dashboard.register(
    NavbarItem(
        name='dispense',
        title='Dispense',
        label='dispense',
        glyphicon='glyphicon-share',
        permissions_codename='nav_pharmacy_dispense',
        url_name=f'{url_namespace}:dispense_listboard_url'))

# register the navbar to the site
site_navbars.register(pharmacy_dashboard)

From the above, you can reference edc_navbar.nav_pharmacy_prescribe and edc_navbar.nav_pharmacy_dispense in your code.

{% if perms.edc_navbar.nav_pharmacy_dispense %}
    href="some_url"
{% else%}
    disabled
{% endif %}

See also:

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

edc-navbar-0.3.26.tar.gz (37.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

edc_navbar-0.3.26-py3-none-any.whl (40.1 kB view details)

Uploaded Python 3

File details

Details for the file edc-navbar-0.3.26.tar.gz.

File metadata

  • Download URL: edc-navbar-0.3.26.tar.gz
  • Upload date:
  • Size: 37.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for edc-navbar-0.3.26.tar.gz
Algorithm Hash digest
SHA256 9471670230a76a9f9e13f80aa90b477a3a2d6e40fac06f855470bab7f28ae216
MD5 4e2b981a8ff7224907aa9c94107e9122
BLAKE2b-256 01c4974e329c83de5eb2adccf3bd69f9acd97fd695e00fdffb42c61d37707a35

See more details on using hashes here.

File details

Details for the file edc_navbar-0.3.26-py3-none-any.whl.

File metadata

  • Download URL: edc_navbar-0.3.26-py3-none-any.whl
  • Upload date:
  • Size: 40.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for edc_navbar-0.3.26-py3-none-any.whl
Algorithm Hash digest
SHA256 20dd03b08db2d6c1f5f4ab891f8caac0a1ac661d011d12af0f418befaec9735c
MD5 daaa9f8a36ddc5c08683a39bef9d1eaf
BLAKE2b-256 131ad9c2b2a6e6f3892a283e4127ba16b3363a2b47505a9332fa9ce750b09265

See more details on using hashes here.

Supported by

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