UNC BACS 350

Web Apps with Python/Django

Logo

Document View Design Pattern

Overview

Goals

Build a common way to display Markdown documents on web pages.

Provide one place in code for each feature.

Encapsulate all common logic for reuse.

Build views without thinking (up and running in 5 minutes).

Use Bootstrap to create high visual impact.

Use Partial Template "documents.html" to organize your code logic.

Pass in data as a dictionary.

Steps

Data

Reading a File

python markdown_text = open('Documents/README.md').read()

Converting Markdown Text

python html = markdown(markdown_text)

Passing Doc Data

```python def document_card(document): markdown_text = open(f'Documents/{document}.md').read() return dict(body=markdown(markdown_text), file=document)

def document_data(document): return dict(documents=[document_card(document), document_card('Markdown')]) ```

Template

Document Template

templates/document.html

```html {% extends 'theme.html' %}

{% block content %}

{% for card in documents %}

    <div class="card">
        <div class="card-header">
            <div class="row">
                DOCUMENT: {{ card.file }}
            </div>
        </div>
        <div class="card-body">

            {% autoescape off %}
            <p>{{ card.body }}</p>
            {% endautoescape %}

        </div>
    </div>

{% endfor %}

{% endblock content %} ```

Views

doc/views.py

```python class DocumentView(TemplateView): template_name = 'document.html'

def get_context_data(self, **kwargs):
    document = self.kwargs.get('doc', 'Index')
    return document_data(document)

```

URL Routes

doc/urls.py

python urlpatterns = [ path('doc/', DocumentView.as_view(), name='document'), path('doc/<str:doc>', DocumentView.as_view()), ]

Tests

doc/tests.py

```python from django.test import TestCase

class DocViewTest(TestCase):

def test_doc_view(self):
    response = self.client.get('doc/')
    self.assertContains(response, 'Index')

```