Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Jinja version of bakerydemo #452

Open
wants to merge 1 commit into
base: jinjademo
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
59 changes: 59 additions & 0 deletions bakerydemo/base/jinja2tags.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
from django.template.context_processors import csrf
from django.template.defaultfilters import (
cut,
date,
linebreaks,
pluralize,
slugify,
truncatewords,
urlencode,
)
from django.contrib.staticfiles.storage import staticfiles_storage
from jinja2 import pass_context
from jinja2.ext import Extension

from wagtail.contrib.search_promotions.templatetags.wagtailsearchpromotions_tags import (
get_search_promotions,
)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the only bakerydemo feature for which we don’t have Jinja support directly in Wagtail.


from bakerydemo.base.templatetags.navigation_tags import (
breadcrumbs,
get_footer_text,
get_site_root,
top_menu,
top_menu_children,
)
from bakerydemo.base.templatetags.gallery_tags import gallery


class BaseExtension(Extension):
def __init__(self, environment):
super().__init__(environment)
self.environment.globals.update(
{
"static": staticfiles_storage.url,
"csrf": csrf,
"get_search_promotions": get_search_promotions,
"breadcrumbs": pass_context(breadcrumbs),
"get_footer_text": pass_context(get_footer_text),
"get_site_root": pass_context(get_site_root),
"top_menu": top_menu,
"top_menu_children": top_menu_children,
"gallery": gallery,
}
)

self.environment.filters.update(
{
"cut": cut,
"date": date,
"linebreaks": linebreaks,
"pluralize": pluralize,
"slugify": slugify,
"truncatewords": truncatewords,
"urlencode": urlencode,
}
)


base = BaseExtension
7 changes: 1 addition & 6 deletions bakerydemo/base/templatetags/gallery_tags.py
Original file line number Diff line number Diff line change
@@ -1,15 +1,10 @@
from django import template
from wagtail.images.models import Image

register = template.Library()


# Retrieves a single gallery item and returns a gallery of images
@register.inclusion_tag("tags/gallery.html", takes_context=True)
def gallery(context, gallery):
def gallery(gallery):
images = Image.objects.filter(collection=gallery)

return {
"images": images,
"request": context["request"],
}
21 changes: 4 additions & 17 deletions bakerydemo/base/templatetags/navigation_tags.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,8 @@
from django import template
from wagtail.models import Page, Site

from bakerydemo.base.models import FooterText

register = template.Library()
# https://docs.djangoproject.com/en/3.2/howto/custom-template-tags/


@register.simple_tag(takes_context=True)
def get_site_root(context):
# This returns a core.Page. The main menu needs to have the site.root_page
# defined else will return an object attribute error ('str' object has no
Expand Down Expand Up @@ -35,8 +30,7 @@ def is_active(page, current_page):
# Retrieves the top menu items - the immediate children of the parent page
# The has_menu_children method is necessary because the Foundation menu requires
# a dropdown class to be applied to a parent
@register.inclusion_tag("tags/top_menu.html", takes_context=True)
def top_menu(context, parent, calling_page=None):
def top_menu(parent, calling_page=None):
menuitems = parent.get_children().live().in_menu()
for menuitem in menuitems:
menuitem.show_dropdown = has_menu_children(menuitem)
Expand All @@ -51,14 +45,11 @@ def top_menu(context, parent, calling_page=None):
return {
"calling_page": calling_page,
"menuitems": menuitems,
# required by the pageurl tag that we want to use within this template
"request": context["request"],
}


# Retrieves the children of the top menu items for the drop downs
@register.inclusion_tag("tags/top_menu_children.html", takes_context=True)
def top_menu_children(context, parent, calling_page=None):
def top_menu_children(parent, calling_page=None):
menuitems_children = parent.get_children()
menuitems_children = menuitems_children.live().in_menu()
for menuitem in menuitems_children:
Expand All @@ -75,27 +66,23 @@ def top_menu_children(context, parent, calling_page=None):
return {
"parent": parent,
"menuitems_children": menuitems_children,
# required by the pageurl tag that we want to use within this template
"request": context["request"],
}


@register.inclusion_tag("tags/breadcrumbs.html", takes_context=True)
def breadcrumbs(context):
self = context.get("self")
self = context.get("page")
if self is None or self.depth <= 2:
# When on the home page, displaying breadcrumbs is irrelevant.
ancestors = ()
else:
ancestors = Page.objects.ancestor_of(self, inclusive=True).filter(depth__gt=1)
return {
"ancestors": ancestors,
"request": context["request"],
}


@register.inclusion_tag("base/include/footer_text.html", takes_context=True)
def get_footer_text(context):
# Use together with base/include/footer_text.html.
# Get the footer text from the context if exists,
# so that it's possible to pass a custom instance e.g. for previews
# or page types that need a custom footer
Expand Down
2 changes: 1 addition & 1 deletion bakerydemo/blog/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -188,7 +188,7 @@ def tag_archive(self, request, tag=None):
return redirect(self.url)

posts = self.get_posts(tag=tag)
context = {"self": self, "tag": tag, "posts": posts}
context = {"page": self, "tag": tag, "posts": posts}
return render(request, "blog/blog_index_page.html", context)

def serve_preview(self, request, mode_name):
Expand Down
18 changes: 8 additions & 10 deletions bakerydemo/jinja2/base.html
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
{% load navigation_tags static wagtailuserbar %}
<!DOCTYPE html>
<html lang="en">
<head>
Expand All @@ -12,7 +11,7 @@
{% endif %}
{% endblock %}
{% block title_suffix %}
| {{ settings.base.SiteSettings.title_suffix }}
| {{ settings("base.SiteSettings").title_suffix }}
{% endblock %}
</title>
<meta name="description" content="{% block search_description %}{% if page.search_description %}{{ page.search_description }}{% endif %}{% endblock %}">
Expand All @@ -23,21 +22,20 @@
<base target="_blank">
{% endif %}

<link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}">
<link rel="stylesheet" href="{% static 'css/font-marcellus.css' %}">
<link rel="stylesheet" href="{% static 'css/main.css' %}">
<link rel="stylesheet" href="{{ static('css/bootstrap.min.css') }}">
<link rel="stylesheet" href="{{ static('css/font-marcellus.css') }}">
<link rel="stylesheet" href="{{ static('css/main.css') }}">
</head>

<body class="{% block body_class %}template-{{ self.get_verbose_name|slugify }}{% endblock %}">
{% wagtailuserbar %}
<body class="{% block body_class %}template-{{ page.get_verbose_name()|slugify }}{% endblock %}">
{{ wagtailuserbar() }}

{% block header %}
{% include "includes/header.html" %}
{% endblock header %}

{% block breadcrumbs %}
{# breadcrumbs is defined in base/templatetags/navigation_tags.py #}
{% breadcrumbs %}
{% include "tags/breadcrumbs.html" %}
{% endblock breadcrumbs %}

{% block messages %}
Expand All @@ -53,6 +51,6 @@

{% include "includes/footer.html" %}

<script type="module" src="{% static 'js/main.js' %}"></script>
<script type="module" src="{{ static('js/main.js') }}"></script>
</body>
</html>
11 changes: 5 additions & 6 deletions bakerydemo/jinja2/base/form_page.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
{% extends "base.html" %}
{% load wagtailcore_tags navigation_tags wagtailimages_tags %}

{% block content %}

Expand All @@ -22,12 +21,12 @@ <h1 class="index-header__title">{{ page.title }}</h1>
<div class="container">
<div class="row">
<div class="col-md-8 form-page">
{% comment %}
{#
You could render your form using a Django rendering shortcut such as `{{ form.as_p }}` but that will tend towards unsemantic code, and make it difficult to style. You can read more on Django form at:
https://docs.djangoproject.com/en/3.2/topics/forms/#form-rendering-options
{% endcomment %}
<form action="{% pageurl page %}" method="POST">
{% csrf_token %}
#}
<form action="{{ pageurl(page) }}" method="POST">
<input type="hidden" name="csrfmiddlewaretoken" value="{{ csrf(request).csrf_token }}">
{% if form.subject.errors %}
<ol>
{% for error in form.subject.errors %}
Expand All @@ -39,7 +38,7 @@ <h1 class="index-header__title">{{ page.title }}</h1>
{% for field in form %}
<div class="form-page__field" aria-required={% if field.field.required %}"true"{% else %}"false"{% endif %}>

{{ field.label_tag }}{% if field.field.required %}<span class="required">*</span>{% endif %}
{{ field.label_tag() }}{% if field.field.required %}<span class="required">*</span>{% endif %}

{% if field.help_text %}
<p class="help">{{ field.help_text }}</p>
Expand Down
1 change: 0 additions & 1 deletion bakerydemo/jinja2/base/form_page_landing.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
{% extends "base.html" %}
{% load wagtailcore_tags %}

{% block content %}

Expand Down
3 changes: 1 addition & 2 deletions bakerydemo/jinja2/base/gallery_page.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
{% extends "base.html" %}
{% load wagtailimages_tags gallery_tags %}

{% block content %}
{% include "base/include/header-hero.html" %}
Expand All @@ -13,7 +12,7 @@
</div>
</div>
<div class="gallery__grid">
{% gallery page.collection %}
{% include "tags/gallery.html" %}
</div>
</div>
{% endblock content %}
27 changes: 13 additions & 14 deletions bakerydemo/jinja2/base/home_page.html
Original file line number Diff line number Diff line change
@@ -1,19 +1,18 @@
{% extends "base.html" %}
{% load wagtailimages_tags wagtailcore_tags %}

{% block content %}
<div class="homepage">

<div class="container-fluid hero">
{% image page.image fill-1920x600 class="hero-image" alt="" %}
{{ image(page.image, "fill-1920x600", class="hero-image", alt="") }}
<div class="hero-gradient-mask"></div>
<div class="container">
<div class="row">
<div class="col-md-6 col-md-offset-1 col-lg-5 home-hero">
<h1>{{ page.title }}</h1>
<p class="lead">{{ page.hero_text }}</p>
{% if page.hero_cta_link %}
<a href="{% pageurl page.hero_cta_link %}" class="hero-cta-link">
<a href="{{ pageurl(page.hero_cta_link) }}" class="hero-cta-link">
{{ page.hero_cta }}
</a>
{% else %}
Expand All @@ -30,15 +29,16 @@ <h1>{{ page.title }}</h1>
{% if page.featured_section_1 %}
<h2 class="featured-cards__title">{{ page.featured_section_1_title }}</h2>
<ul class="featured-cards__list">
{% for childpage in page.featured_section_1.specific.children|slice:"3" %}
{% for page in page.featured_section_1.specific.children()[:3] %}
<li>
{% include "includes/card/listing-card.html" with page=childpage %}
{% include "includes/card/listing-card.html" %}
</li>
{% endfor %}
</ul>
<a class="featured-cards__link" href="/breads">
<span>View more of our breads</span>
{% include "includes/chevron-icon.html" with class="featured-cards__chevron-icon" %}
{% set class="featured-cards__chevron-icon" %}
{% include "includes/chevron-icon.html" %}
</a>
{% endif %}
</div>
Expand All @@ -49,13 +49,11 @@ <h2 class="featured-cards__title">{{ page.featured_section_1_title }}</h2>
{% if page.promo_title %}
<h2>{{ page.promo_title }}</h2>
{% endif %}
{% if page.promo_text %}
{{ page.promo_text|richtext }}
{% endif %}
{{ page.promo_text|richtext if page.promo_text }}
</div>
{% endif %}
{% if page.promo_image %}
<figure>{% image page.promo_image fill-590x413-c100 %}</figure>
<figure>{{ image(page.promo_image, "fill-590x413-c100") }}</figure>
{% endif %}
</div>
</div>
Expand All @@ -76,8 +74,8 @@ <h2>{{ page.promo_title }}</h2>
<div class="col-md-12 locations-section">
{% if page.featured_section_2 %}
<h2 class="locations-section__title">{{ page.featured_section_2_title }}</h2>
{% for childpage in page.featured_section_2.specific.children|slice:"3" %}
{% include "includes/card/location-card.html" with page=childpage %}
{% for page in page.featured_section_2.specific.children()[:3] %}
{% include "includes/card/location-card.html" %}
{% endfor %}
{% endif %}
</div>
Expand All @@ -91,8 +89,9 @@ <h2 class="locations-section__title">{{ page.featured_section_2_title }}</h2>
<div class="col-md-12 blog-section">
<h2 class="blog-section__title">{{ page.featured_section_3_title }}</h2>
<div class="blog-section__grid">
{% for childpage in page.featured_section_3.specific.children|slice:"6" %}
{% include "includes/card/picture-card.html" with page=childpage portrait=True %}
{% for page in page.featured_section_3.specific.children()[:6] %}
{% set portrait=True %}
{% include "includes/card/picture-card.html" %}
{% endfor %}
</div>
</div>
Expand Down
2 changes: 1 addition & 1 deletion bakerydemo/jinja2/base/include/footer_text.html
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
{% load wagtailcore_tags %}
{% set footer_text=get_footer_text().footer_text %}

<div class="copyright">
{{ footer_text|richtext }}
Expand Down
6 changes: 2 additions & 4 deletions bakerydemo/jinja2/base/include/header-blog.html
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
{% load wagtailcore_tags wagtailimages_tags %}

{% if page.image %}
<div class="container-fluid hero hero--blog">
{% image page.image fill-1920x600 class="hero-image" alt="" %}
{{ image(page.image, "fill-1920x600", class="hero-image", alt="") }}
</div>
{% endif %}
<div class="container">
Expand All @@ -19,7 +17,7 @@ <h1 class="index-header__title index-header__title--blog">{{ page.title }}</h1>
{% endif %}
{% if page.date_published %}
<div class="blog__published">
{{ page.date_published }}
{{ page.date_published|date("DATE_FORMAT") }}
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I’m surprised Jinja doesn’t do this by default, perhaps there’s a way with configuration.

</div>
{% endif %}
</div>
Expand Down
4 changes: 1 addition & 3 deletions bakerydemo/jinja2/base/include/header-hero.html
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
{% load wagtailcore_tags wagtailimages_tags %}

{% if page.image %}
<div class="container-fluid hero">
{% image page.image fill-1920x600 class="hero-image" alt="" %}
{{ image(page.image, "fill-1920x600", class="hero-image", alt="") }}
<div class="hero__container">
<h1 class="hero__title">{{ page.title }}</h1>
</div>
Expand Down
2 changes: 0 additions & 2 deletions bakerydemo/jinja2/base/include/header-index.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
{% load wagtailcore_tags wagtailimages_tags %}

<div class="container">
<div class="row">
<div class="col-md-12">
Expand Down
4 changes: 1 addition & 3 deletions bakerydemo/jinja2/base/include/header.html
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
{% load wagtailcore_tags wagtailimages_tags %}

<div class="container">
<div class="row">
<div class="col-md-7 base-header">
{% if page.image %}
<div class="image">
{% image page.image width-500 as photo %}
{% set photo=image(page.image, "width-500") %}
<img src="{{ photo.url }}" width="{{ photo.width }}" height="{{ photo.height }}" alt="{{ photo.alt }}" />
</div>
{% endif %}
Expand Down
Loading