Releases: jazzband/wagtailmenus
v2.3.2
This is a minor maintenance / bug fix release.
- Fixed a bug that would result in {% sub_menu %} being called recursively (until raising a "maximum recursion depth exceeded" exception) if a 'repeated menu item' was added at anything past the 2nd level. Thanks to @pyMan for raising/investigating.
v2.2.3
This is a minor maintenance / bug fix release.
- Fixed a bug that would result in {% sub_menu %} being called recursively (until raising a "maximum recursion depth exceeded" exception) if a 'repeated menu item' was added at anything past the 2nd level. Thanks to @pyMan for raising/investigating.
v.2.1.4
This is a minor maintenance / bug fix release.
- Fixed a bug that would result in {% sub_menu %} being called recursively (until raising a "maximum recursion depth exceeded" exception) if a 'repeated menu item' was added at anything past the 2nd level. Thanks to @pyMan for raising/investigating.
v2.3.1
Minor maintenance release
- Code example formatting fixes, and better use of headings in README.md.
- Added 'on_delete=models.CASCADE' to all relationship fields on models where
no 'on_delete' behaviour was previously set (Django 2.0 compatibility). - Marked a missing string for translation (@einsfr)
- Updated translations for Lithuanian, Portuguese (Brazil), and Russian.
Many thanks to @mamorim, @treavis and @einsfr!
v.2.3.0
New / updated features
- Added an 'AbstractLinkPage' model to wagtailmenus.models that can be easily sub-classed and used in projects to create 'link pages' that act in a similar fashion to menu items when appearing in menus, but can be placed in any part of the page tree. Find out more about this feature
- Most of the functionality from
MenuPage
model has been abstracted out to aMenuPageMixin
model, that can more easily be mixed in to existing page type models. - The 'modify_submenu_items', 'has_submenu_items' and 'get_repeated_menu_item' methods on
MenuPageMixin
/MenuPage
have been updated to accept a newrequest
keyword argument, which is used to pass in the currentHttpRequest
that the menu is being rendered for. See below for more details. - Added the
WAGTAILMENUS_SECTION_MENU_CLASS_PATH
setting, which can be used to override theMenu
class used when using the{% section_menu %}
tag. - Added the
WAGTAILMENUS_CHILDREN_MENU_CLASS_PATH
setting, which can be used to override theMenu
class used when using the{% children_menu %}
tag. - All
Menu
classes are now 'request aware', meaningself.request
will return the currentHttpRequest
object within most methods (the menu tags set the value using a newset_request
method, immediately after initialisation) - Added a
get_base_page_queryset()
method to allMenu
classes, that can be overridden to change the base QuerySet used when identifying pages to be included in a menu when rendering. For example developers could useself.request.user
to only ever include pages that the current user has some permissions for. - Added Russian translations (submitted by Alex einsfr).
Under the hood
- Added wagtail 1.10 and django 1.11 test environments to tox
- Renamed
test_frontend.py
totest_menu_rendering.py
- In situations where
request.site
hasn't been set by wagtail'sSiteMiddleware
, the wagtailmenus context processor will now use the default site to generate menus with. - Updated
AbstractMenuItem.clean()
to only ever return field-specific validation errors, because Wagtail doesn't render non-field errors for related models added to the editor interface usingInlinePanel
. - Refactored
runtest.py
to accept adeprecation
argument that can be used to surface deprecation warnings that arise when running tests.
Upgrade considerations
Deprecated behavior
Several methods on the MenuPage
model have been updated to accept a request
parameter. If you're upgrading to version 2.3.0
from a previous version, it's not necessary to make any changes immediately in order for wagtailmenus to work, but if you're using the MenuPage
class in your project, and are overridingmodify_submenu_items()
, has_submenu_items()
or get_repeated_menu_item()
, you should think about updating the signatures of those methods to accept the new argument and pass it through when calling super()
. See the following code for an example:
from wagtailmenus.models import MenuPage
class ContactPage(MenuPage):
...
def modify_submenu_items(
self, menu_items, current_page, current_ancestor_ids,
current_site, allow_repeating_parents, apply_active_classes,
original_menu_tag, menu_instance, request
):
# Apply default modifications first of all
menu_items = super(ContactPage, self).modify_submenu_items(
menu_items, current_page, current_ancestor_ids, current_site, allow_repeating_parents, apply_active_classes, original_menu_tag,
menu_instance, request)
"""
If rendering a 'main_menu', add some additional menu items to the end
of the list that link to various anchored sections on the same page
"""
if original_menu_tag == 'main_menu':
base_url = self.relative_url(current_site)
"""
Additional menu items can be objects with the necessary attributes,
or simple dictionaries. `href` is used for the link URL, and `text`
is the text displayed for each link. Below, I've also used
`active_class` to add some additional CSS classes to these items,
so that I can target them with additional CSS
"""
menu_items.extend((
{
'text': 'Get support',
'href': base_url + '#support',
'active_class': 'support',
},
{
'text': 'Speak to someone',
'href': base_url + '#call',
'active_class': 'call',
},
{
'text': 'Map & directions',
'href': base_url + '#map',
'active_class': 'map',
},
))
return menu_items
def has_submenu_items(
self, current_page, allow_repeating_parents, original_menu_tag,
menu_instance, request
):
"""
Because `modify_submenu_items` is being used to add additional menu
items, we need to indicate in menu templates that `ContactPage` objects
do have submenu items in main menus, even if they don't have children
pages.
"""
if original_menu_tag == 'main_menu':
return True
return super(ContactPage, self).has_submenu_items(
current_page, allow_repeating_parents, original_menu_tag,
menu_instance, request)
If you choose not to update your versions of those methods to accept the request
keyword argument, you will continue to see deprecation warnings until version 2.5.0
, when it will be a requirement, and your existing code will no longer work.
v.2.2.2
This is just a minor release, so no feature changes or backwards-compatibility issues to worry about
What's changed?
- Got the project set up in Transifex (finally) https://www.transifex.com/rkhleics/wagtailmenus/
- Updated translatable strings throughout the project to use named variable substitution, and unmarked a few exception messages.
- Added Lithuanian translations (submitted by Matas Dailyda).
- Update codebase to better handle situations where
request
isn't available in the context, orrequest.site
hasn't been set.
v2.2.1
This is just a minor release to addresses a few 'under the hood' things, and shouldn't introduce any backwards-incompatible changes.
What's changed?
- Updated travis/tox test settings to test against Wagtail 1.9 & Django 1.10.
- Removed a couple of less useful travis/tox environment tests to help with test speed.
- Made use of 'extras_require' in setup.py to replace multiple requirements files.
- Optimised the app_settings module so that we can ditch the questionably stuff
we're doing with global value manipulation on app load (inspired by django-allauth). - Added new semantic version solution to the project (inspired by wagtail)
v2.2.0
New / updated features
- Wagtailmenus now makes use of django's built-in
django.template.loader.select_template()
method
to provide a more intuitive way for developers to override templates for specific menus without having to explicitly specify alternative templates via settings or via thetemplate
andsub_menu_template
options for each menu tag. See the updated documentation for each tag for information about where wagtailmenus looks for templates. - Added the
WAGTAILMENUS_SITE_SPECIFIC_TEMPLATE_DIRS
setting to allow developers to choose to have wagtailmenus look in additional site-specific locations for templates to render menus. - Brazilian Portuguese language translations added by @MaxKurama.
Under the hood
- Added a try/except to
AbstractMenuItem.relative_url()
so that errors aren't thrown whenPage.relative_url()
returnsNone
for some reason. - Moved some methods out of
template_tags/menu_tags.py
into a newutils.py
file to makemenu_tags.py
easier to read / manage.
Upgrade considerations
N/A
v2.1.3
This release fixes a bug in the section_menu
tag when attempting to apply the correct active class to section_root
when the modify_submenu_items()
method has been overridden to return additional items without an active_class
attribute (like in the example code in README)