You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 7-8.RSVP
Socket
Socket
Sign inDemoInstall

DjangoLightbox

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

DjangoLightbox

alternative for a full screen javascript lightbox for the django framework


Maintainers
1

Readme

============= LIGHTBOX PAGE

This is an alternative for a full screen javascript lightbox. LIGHTBOX PAGE brings the user to a separate page, not an overlay. So this is only useful for full screen lightbox.

Quick Start

Add lightbox to your INSTALLED APPS To settings, add LIGHTBOX_MODEL with the parent model name, and LIGHTBOX_APP with the app where this model lives. Defaults are model: 'Page', app: 'base'

Add lightbox.middleware.MobileDetectMiddleware to your middleware classes.

Add the following to your urls.py:

from lightbox.views import ImagePageView

In url patterns, you need to do 2 things:

  1. add something like this::

    url(r'^lightbox/(?P\d+)/(?P.*)/$', ImagePageView.as_view(), {'app': 'projects', 'model': 'project', 'related_name': 'projectimage_set'}, name="projectlightbox"),

As you can see, you will need to specify app, model and related name as keyword arguments.

  1. add

    url(r'^lightbox/', include('lightbox.urls')),

    to your base urls.py

Add ImagePageContextMixin to your views. This will provide the context.

Then, in your own templates, you may call lightbox like so:

	<a href="{% url 'projects:projectlightbox' object.pk path %}?page={{ forloop.counter }}">
		<img src="{{ im.url }}">

	</a>

Example:

from lightbox.views import ImagePageContextMixin from django.views.generic import ListView from models import Page

class CustomView(ImagePageContextMixin, ListView): template_name = 'index.html'

If you are not using class-based views, and you wish to use the last call structure, you may enter the context for the path variable as follows:

from lightbox.views import encode_url

def some_function(request, [...]):

path = encode_url(request)
return render_to_response('your_template_name.html', {'path': path, [...: ...]})

Options:

LIGHTBOX_WIDTH = '1600' LIGHTBOX_WIDTH_MOBILE = '800' LIGHTBOX_IMAGE_CLICKABLE = False LIGHTBOX_BG_COLOR = '#000' LIGHTBOX_TXT_COLOR = '#fff'

LIGHTBOX_VIEWABLE_HEIGHT_FACTOR = 0.85 LIGHTBOX_VIEWABLE_WIDTH_FACTOR = 0.85

LIGHTBOX_IMAGE_WINDOW_HEIGHT_FACTOR = 0.71 LIGHTBOX_IMAGE_WINDOW_WIDTH_FACTOR = 0.71

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc