Opening a Dialog
view codeOpening a static Dialog
The layout of the Dialog is fully described by the referenced HTML template: either the default "#dialog_generic" of a specific one.
You can fully customize the rendering with CSS; the default styles are provided by static/frontend_forms/css/frontend_forms.css
dialog1 = new Dialog({ dialog_selector: '#dialog_generic', html: '<h1>Static content goes here ...</h1>', width: '600px', min_height: '200px', title: '<i class="fa fa-calculator"></i> Select an object ...', footer_text: 'testing dialog ...', enable_trace: true }); dialog1.open()
A simple static Dialog
Opening a dynamic Dialog
In most cases, you will rather produce the dialog content dynamically.
To obtain that, just add an "url" option to the Djalog constructor, and it will be automatically used to obtain the Dialog content from the server via an Ajax call.
dialog1 = new Dialog({ ... url: "/samples/simple-content", ...
Sometimes it is convenient to reuse the very same single view to render either a modal dialog, or a standalone HTML page.
This can be easily accomplished providing:
- an "inner" template which renders the content
- an "outer" container template which renders the full page, then includes the "inner" template
- in the view, detect the call context and render one or another
def simple_content2(request): # Either render only the modal content, or a full standalone page if request.is_ajax(): template_name = 'frontend/includes/simple_content2_inner.html' else: template_name = 'frontend/includes/simple_content2.html' return render(request, template_name, { })
here, the "inner" template provides the content:
<div class="row"> <div class="col-sm-4"> <p>Nam nulla dignissimos fuga quaerat corporis in iusto, itaque placeat id porro, illo nihil delectus sint fugit vitae officiis nam, eveniet quo excepturi exercitationem pariatur placeat obcaecati dolore aperiam ipsum incidunt.</p> </div> <div class="col-sm-4"> <p>Ut ipsa iure officia ipsum beatae dolor corporis cupiditate maxime minus recusandae, odio voluptate omnis ea, nihil repellat quasi illo nemo eos ea perspiciatis consequatur saepe, vero unde minima quis aliquam quas quod saepe qui beatae alias, quaerat quam nihil soluta repellat minus numquam enim adipisci.</p> </div> <div class="col-sm-4"> <p>Temporibus accusamus unde ut ullam obcaecati a ipsam, inventore cum quam maiores, repudiandae neque alias corporis, voluptate fugit eaque ullam debitis dolor maiores nobis expedita minima enim, soluta voluptatem eaque est eius perspiciatis magni repellendus velit quisquam aperiam? Dolor quaerat non cupiditate at provident similique reiciendis deleniti voluptas eos, pariatur dolorem enim commodi eos minima obcaecati, illo facilis aperiam eligendi dolor, vitae quia illum laborum rem similique quas eligendi deleniti quidem obcaecati labore, dolor perferendis ea voluptatum deserunt? Quia accusantium nostrum est et laudantium beatae ipsam, voluptatum excepturi nesciunt.</p> </div> </div>
while the "outer" one renders the full page:
{% extends "base.html" %}
{% load static staticfiles i18n %}
{% block content %}
{% include 'frontend/includes/simple_content2_inner.html' %}
{% endblock content %}