wagtail 7.2.1__py3-none-any.whl → 7.3__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- wagtail/__init__.py +1 -1
- wagtail/actions/copy_for_translation.py +4 -2
- wagtail/admin/action_menu.py +4 -1
- wagtail/admin/api/actions/convert_alias.py +2 -2
- wagtail/admin/api/actions/copy.py +2 -2
- wagtail/admin/api/actions/copy_for_translation.py +2 -2
- wagtail/admin/api/actions/create_alias.py +2 -2
- wagtail/admin/api/actions/delete.py +1 -1
- wagtail/admin/api/actions/move.py +1 -1
- wagtail/admin/api/actions/publish.py +2 -2
- wagtail/admin/api/actions/revert_to_page_revision.py +2 -2
- wagtail/admin/api/actions/unpublish.py +1 -1
- wagtail/admin/api/filters.py +2 -2
- wagtail/admin/compare.py +22 -0
- wagtail/admin/forms/account.py +52 -1
- wagtail/admin/forms/comments.py +53 -0
- wagtail/admin/forms/models.py +36 -0
- wagtail/admin/forms/pages.py +7 -0
- wagtail/admin/forms/workflows.py +5 -2
- wagtail/admin/icons.py +4 -3
- wagtail/admin/locale/af/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/af/LC_MESSAGES/djangojs.po +8 -1
- wagtail/admin/locale/ar/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ar/LC_MESSAGES/django.po +42 -16
- wagtail/admin/locale/ar/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ar/LC_MESSAGES/djangojs.po +20 -11
- wagtail/admin/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/az_AZ/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/az_AZ/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/be/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/be/LC_MESSAGES/djangojs.po +21 -3
- wagtail/admin/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/bg/LC_MESSAGES/django.po +299 -2
- wagtail/admin/locale/bg/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/bg/LC_MESSAGES/djangojs.po +37 -3
- wagtail/admin/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/bn/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/bn/LC_MESSAGES/djangojs.po +9 -3
- wagtail/admin/locale/ca/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ca/LC_MESSAGES/django.po +36 -18
- wagtail/admin/locale/ca/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ca/LC_MESSAGES/djangojs.po +34 -12
- wagtail/admin/locale/cs/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/cs/LC_MESSAGES/django.po +1 -7
- wagtail/admin/locale/cs/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/cs/LC_MESSAGES/djangojs.po +22 -4
- wagtail/admin/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/cy/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/cy/LC_MESSAGES/djangojs.po +15 -3
- wagtail/admin/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/da/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/da/LC_MESSAGES/djangojs.po +19 -4
- wagtail/admin/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/de/LC_MESSAGES/django.po +201 -21
- wagtail/admin/locale/de/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/de/LC_MESSAGES/djangojs.po +53 -14
- wagtail/admin/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/dv/LC_MESSAGES/django.po +7 -16
- wagtail/admin/locale/dv/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/dv/LC_MESSAGES/djangojs.po +20 -2
- wagtail/admin/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/el/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/el/LC_MESSAGES/djangojs.po +22 -13
- wagtail/admin/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/en/LC_MESSAGES/django.po +262 -234
- wagtail/admin/locale/en/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/en/LC_MESSAGES/djangojs.po +72 -43
- wagtail/admin/locale/en_IN/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/en_IN/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/es/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/es/LC_MESSAGES/django.po +1 -10
- wagtail/admin/locale/es/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/es/LC_MESSAGES/djangojs.po +22 -13
- wagtail/admin/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/es_419/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/es_419/LC_MESSAGES/djangojs.po +8 -2
- wagtail/admin/locale/es_VE/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/es_VE/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/es_VE/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/et/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/et/LC_MESSAGES/djangojs.po +17 -2
- wagtail/admin/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/eu/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/eu/LC_MESSAGES/djangojs.po +8 -2
- wagtail/admin/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/fa/LC_MESSAGES/django.po +5 -11
- wagtail/admin/locale/fa/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/fa/LC_MESSAGES/djangojs.po +18 -3
- wagtail/admin/locale/fi/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/fi/LC_MESSAGES/django.po +1 -12
- wagtail/admin/locale/fi/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/fi/LC_MESSAGES/djangojs.po +22 -12
- wagtail/admin/locale/fr/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/fr/LC_MESSAGES/django.po +38 -21
- wagtail/admin/locale/fr/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/fr/LC_MESSAGES/djangojs.po +35 -14
- wagtail/admin/locale/gl/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/gl/LC_MESSAGES/django.po +36 -18
- wagtail/admin/locale/gl/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/gl/LC_MESSAGES/djangojs.po +34 -12
- wagtail/admin/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/he_IL/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/he_IL/LC_MESSAGES/djangojs.po +20 -3
- wagtail/admin/locale/hi/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/hi/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/hr_HR/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/hr_HR/LC_MESSAGES/djangojs.po +17 -2
- wagtail/admin/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/ht/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ht/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/hu/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/hu/LC_MESSAGES/django.po +7 -18
- wagtail/admin/locale/hu/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/hu/LC_MESSAGES/djangojs.po +21 -11
- wagtail/admin/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/id_ID/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/id_ID/LC_MESSAGES/djangojs.po +18 -3
- wagtail/admin/locale/is_IS/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/is_IS/LC_MESSAGES/django.po +7 -17
- wagtail/admin/locale/is_IS/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/is_IS/LC_MESSAGES/djangojs.po +21 -12
- wagtail/admin/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/it/LC_MESSAGES/django.po +599 -19
- wagtail/admin/locale/it/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/it/LC_MESSAGES/djangojs.po +73 -13
- wagtail/admin/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/ja/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ja/LC_MESSAGES/djangojs.po +23 -3
- wagtail/admin/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/ka/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ka/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/ko/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ko/LC_MESSAGES/django.po +1 -11
- wagtail/admin/locale/ko/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ko/LC_MESSAGES/djangojs.po +23 -13
- wagtail/admin/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/lt/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/lt/LC_MESSAGES/djangojs.po +21 -12
- wagtail/admin/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/lv/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/lv/LC_MESSAGES/djangojs.po +22 -4
- wagtail/admin/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/mi/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/mi/LC_MESSAGES/djangojs.po +14 -2
- wagtail/admin/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/mn/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/mn/LC_MESSAGES/djangojs.po +17 -2
- wagtail/admin/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/my/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/my/LC_MESSAGES/djangojs.po +8 -2
- wagtail/admin/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/nb/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/nb/LC_MESSAGES/djangojs.po +18 -3
- wagtail/admin/locale/nl/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/nl/LC_MESSAGES/django.po +38 -21
- wagtail/admin/locale/nl/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/nl/LC_MESSAGES/djangojs.po +36 -13
- wagtail/admin/locale/pl/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/pl/LC_MESSAGES/django.po +1 -10
- wagtail/admin/locale/pl/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/pl/LC_MESSAGES/djangojs.po +21 -12
- wagtail/admin/locale/pt_BR/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/pt_BR/LC_MESSAGES/django.po +7 -16
- wagtail/admin/locale/pt_BR/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/pt_BR/LC_MESSAGES/djangojs.po +21 -13
- wagtail/admin/locale/pt_PT/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/pt_PT/LC_MESSAGES/django.po +1 -7
- wagtail/admin/locale/pt_PT/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/pt_PT/LC_MESSAGES/djangojs.po +18 -12
- wagtail/admin/locale/ro/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ro/LC_MESSAGES/django.po +7 -16
- wagtail/admin/locale/ro/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ro/LC_MESSAGES/djangojs.po +20 -11
- wagtail/admin/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ru/LC_MESSAGES/django.po +186 -22
- wagtail/admin/locale/ru/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ru/LC_MESSAGES/djangojs.po +53 -14
- wagtail/admin/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/sk_SK/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/sk_SK/LC_MESSAGES/djangojs.po +20 -3
- wagtail/admin/locale/sl/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/sl/LC_MESSAGES/django.po +7 -16
- wagtail/admin/locale/sl/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/sl/LC_MESSAGES/djangojs.po +21 -12
- wagtail/admin/locale/sr/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/sr/LC_MESSAGES/djangojs.po +15 -0
- wagtail/admin/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/sv/LC_MESSAGES/django.po +329 -23
- wagtail/admin/locale/sv/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/sv/LC_MESSAGES/djangojs.po +23 -13
- wagtail/admin/locale/ta/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ta/LC_MESSAGES/djangojs.po +5 -2
- wagtail/admin/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/tet/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/tet/LC_MESSAGES/djangojs.po +19 -4
- wagtail/admin/locale/th/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/th/LC_MESSAGES/django.po +1 -4
- wagtail/admin/locale/th/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/th/LC_MESSAGES/djangojs.po +22 -3
- wagtail/admin/locale/tr/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/tr/LC_MESSAGES/django.po +4 -10
- wagtail/admin/locale/tr/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/tr/LC_MESSAGES/djangojs.po +23 -5
- wagtail/admin/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/tr_TR/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/tr_TR/LC_MESSAGES/djangojs.po +19 -4
- wagtail/admin/locale/ug/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/ug/LC_MESSAGES/django.po +7 -16
- wagtail/admin/locale/ug/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/ug/LC_MESSAGES/djangojs.po +20 -11
- wagtail/admin/locale/uk/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/uk/LC_MESSAGES/django.po +5 -11
- wagtail/admin/locale/uk/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/uk/LC_MESSAGES/djangojs.po +22 -14
- wagtail/admin/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/vi/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/vi/LC_MESSAGES/djangojs.po +9 -2
- wagtail/admin/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/admin/locale/zh/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/zh/LC_MESSAGES/djangojs.po +20 -5
- wagtail/admin/locale/zh_Hans/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/zh_Hans/LC_MESSAGES/django.po +1 -7
- wagtail/admin/locale/zh_Hans/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/zh_Hans/LC_MESSAGES/djangojs.po +23 -13
- wagtail/admin/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/admin/locale/zh_Hant/LC_MESSAGES/django.po +1 -7
- wagtail/admin/locale/zh_Hant/LC_MESSAGES/djangojs.mo +0 -0
- wagtail/admin/locale/zh_Hant/LC_MESSAGES/djangojs.po +21 -3
- wagtail/admin/panels/comment_panel.py +1 -51
- wagtail/admin/panels/title_field_panel.py +3 -1
- wagtail/admin/static/wagtailadmin/css/core.css +1 -1
- wagtail/admin/static/wagtailadmin/js/bulk-actions.js +1 -1
- wagtail/admin/static/wagtailadmin/js/comments.js +1 -1
- wagtail/admin/static/wagtailadmin/js/core.js +1 -1
- wagtail/admin/static/wagtailadmin/js/core.js.LICENSE.txt +1 -1
- wagtail/admin/static/wagtailadmin/js/draftail.js +1 -1
- wagtail/admin/static/wagtailadmin/js/privacy-switch.js +1 -1
- wagtail/admin/static/wagtailadmin/js/sidebar.js +1 -1
- wagtail/admin/static/wagtailadmin/js/telepath/blocks.js +1 -1
- wagtail/admin/static/wagtailadmin/js/userbar.js +1 -1
- wagtail/admin/static/wagtailadmin/js/userbar.js.LICENSE.txt +1 -1
- wagtail/admin/static/wagtailadmin/js/vendor.js +1 -1
- wagtail/admin/static/wagtailadmin/js/wagtailadmin.js +1 -1
- wagtail/admin/templates/wagtailadmin/base.html +1 -1
- wagtail/admin/templates/wagtailadmin/generic/edit_partials.html +100 -0
- wagtail/admin/templates/wagtailadmin/generic/form.html +26 -5
- wagtail/admin/templates/wagtailadmin/generic/includes/_loaded_revision_inputs.html +3 -0
- wagtail/admin/templates/wagtailadmin/generic/listing_results.html +1 -17
- wagtail/admin/templates/wagtailadmin/pages/create.html +14 -4
- wagtail/admin/templates/wagtailadmin/pages/edit.html +16 -3
- wagtail/admin/templates/wagtailadmin/pages/edit_partials.html +19 -0
- wagtail/admin/templates/wagtailadmin/pages/index_results.html +1 -9
- wagtail/admin/templates/wagtailadmin/shared/autosave/indicator.html +36 -0
- wagtail/admin/templates/wagtailadmin/shared/breadcrumbs.html +1 -1
- wagtail/admin/templates/wagtailadmin/shared/editing_sessions/list.html +2 -2
- wagtail/admin/templates/wagtailadmin/shared/editing_sessions/module.html +19 -3
- wagtail/admin/templates/wagtailadmin/shared/headers/_actions.html +5 -0
- wagtail/admin/templates/wagtailadmin/shared/headers/_history_icon_link.html +2 -2
- wagtail/admin/templates/wagtailadmin/shared/headers/slim_header.html +8 -9
- wagtail/admin/templates/wagtailadmin/shared/listing/filter_partials.html +19 -0
- wagtail/admin/templates/wagtailadmin/shared/side_panel_toggle.html +3 -3
- wagtail/admin/templates/wagtailadmin/shared/side_panels/includes/side_panel.html +3 -0
- wagtail/admin/templates/wagtailadmin/shared/side_panels/includes/status/privacy.html +18 -6
- wagtail/admin/templates/wagtailadmin/shared/side_panels/includes/status/usage.html +11 -4
- wagtail/admin/templates/wagtailadmin/shared/side_panels/includes/status/workflow.html +22 -1
- wagtail/admin/templates/wagtailadmin/shared/side_panels/preview.html +1 -0
- wagtail/admin/templates/wagtailadmin/shared/side_panels.html +1 -2
- wagtail/admin/templates/wagtailadmin/shared/unsaved_changes_warning.html +20 -20
- wagtail/admin/templates/wagtailadmin/userbar/base.html +2 -0
- wagtail/admin/templates/wagtailadmin/userbar/item_accessibility.html +1 -1
- wagtail/admin/templatetags/wagtailadmin_tags.py +6 -14
- wagtail/admin/tests/pages/test_create_page.py +359 -1
- wagtail/admin/tests/pages/test_custom_listing.py +48 -2
- wagtail/admin/tests/pages/test_edit_page.py +987 -10
- wagtail/admin/tests/pages/test_explorer_view.py +9 -5
- wagtail/admin/tests/pages/test_page_search.py +15 -0
- wagtail/admin/tests/pages/test_preview.py +81 -0
- wagtail/admin/tests/pages/test_revisions.py +4 -0
- wagtail/admin/tests/test_account_management.py +88 -2
- wagtail/admin/tests/test_collections_views.py +15 -15
- wagtail/admin/tests/test_compare.py +34 -0
- wagtail/admin/tests/test_editing_sessions.py +230 -8
- wagtail/admin/tests/test_forms.py +192 -1
- wagtail/admin/tests/test_icon_sprite.py +22 -2
- wagtail/admin/tests/test_page_chooser.py +13 -13
- wagtail/admin/tests/test_reports_views.py +4 -1
- wagtail/admin/tests/test_userbar.py +69 -5
- wagtail/admin/tests/test_views_generic.py +5 -5
- wagtail/admin/tests/test_workflows.py +14 -12
- wagtail/admin/tests/viewsets/test_model_viewset.py +13 -0
- wagtail/admin/ui/autosave.py +5 -0
- wagtail/admin/ui/editing_sessions.py +3 -0
- wagtail/admin/ui/side_panels.py +19 -20
- wagtail/admin/userbar.py +48 -27
- wagtail/admin/views/bulk_action/dispatcher.py +2 -2
- wagtail/admin/views/chooser.py +6 -6
- wagtail/admin/views/editing_sessions.py +20 -7
- wagtail/admin/views/generic/__init__.py +1 -0
- wagtail/admin/views/generic/chooser.py +5 -5
- wagtail/admin/views/generic/mixins.py +143 -26
- wagtail/admin/views/generic/models.py +157 -27
- wagtail/admin/views/generic/ordering.py +1 -1
- wagtail/admin/views/generic/preview.py +12 -5
- wagtail/admin/views/home.py +3 -1
- wagtail/admin/views/pages/create.py +78 -29
- wagtail/admin/views/pages/edit.py +162 -34
- wagtail/admin/views/pages/preview.py +14 -5
- wagtail/admin/views/pages/revisions.py +3 -0
- wagtail/admin/views/pages/search.py +4 -4
- wagtail/admin/views/pages/usage.py +2 -2
- wagtail/admin/views/tags.py +2 -2
- wagtail/admin/views/workflows.py +73 -54
- wagtail/admin/viewsets/model.py +34 -8
- wagtail/admin/widgets/button.py +11 -4
- wagtail/admin/widgets/chooser.py +6 -4
- wagtail/admin/widgets/slug.py +1 -1
- wagtail/api/v2/filters.py +27 -21
- wagtail/api/v2/pagination.py +4 -4
- wagtail/api/v2/views.py +7 -7
- wagtail/blocks/list_block.py +0 -8
- wagtail/blocks/migrations/migrate_operation.py +8 -1
- wagtail/blocks/stream_block.py +2 -10
- wagtail/blocks/struct_block.py +192 -12
- wagtail/compat.py +2 -2
- wagtail/contrib/forms/locale/af/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/bg/LC_MESSAGES/django.po +4 -1
- wagtail/contrib/forms/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/forms/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/hy/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/forms/locale/it/LC_MESSAGES/django.po +40 -2
- wagtail/contrib/forms/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/frontend_cache/backends/azure.py +6 -6
- wagtail/contrib/frontend_cache/backends/cloudfront.py +2 -2
- wagtail/contrib/frontend_cache/utils.py +1 -1
- wagtail/contrib/redirects/forms.py +1 -1
- wagtail/contrib/redirects/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/bg/LC_MESSAGES/django.po +7 -1
- wagtail/contrib/redirects/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/de/LC_MESSAGES/django.po +15 -3
- wagtail/contrib/redirects/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/en/LC_MESSAGES/django.po +14 -14
- wagtail/contrib/redirects/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/en_IN/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/es_VE/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/es_VE/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/hi/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/hi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/hy/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/hy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/it/LC_MESSAGES/django.po +17 -4
- wagtail/contrib/redirects/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/ru/LC_MESSAGES/django.po +15 -2
- wagtail/contrib/redirects/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/sr/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/sr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/sv/LC_MESSAGES/django.po +17 -4
- wagtail/contrib/redirects/locale/ta/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/redirects/locale/ta/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/redirects/middleware.py +11 -7
- wagtail/contrib/redirects/models.py +17 -1
- wagtail/contrib/redirects/tests/test_import_admin_views.py +3 -3
- wagtail/contrib/redirects/tests/test_redirects.py +56 -8
- wagtail/contrib/search_promotions/locale/af/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/af/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/bg/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/de/LC_MESSAGES/django.po +9 -3
- wagtail/contrib/search_promotions/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/en/LC_MESSAGES/django.po +6 -6
- wagtail/contrib/search_promotions/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/it/LC_MESSAGES/django.po +44 -3
- wagtail/contrib/search_promotions/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/search_promotions/locale/ru/LC_MESSAGES/django.po +9 -3
- wagtail/contrib/search_promotions/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/sv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/search_promotions/tests.py +1 -1
- wagtail/contrib/search_promotions/views/settings.py +24 -25
- wagtail/contrib/settings/jinja2tags.py +2 -2
- wagtail/contrib/settings/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/{locale/af → contrib/settings/locale/bg}/LC_MESSAGES/django.po +7 -16
- wagtail/contrib/settings/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/de/LC_MESSAGES/django.po +7 -3
- wagtail/contrib/settings/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/en/LC_MESSAGES/django.po +2 -2
- wagtail/contrib/settings/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/en_IN/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/es_VE/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/hi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/it/LC_MESSAGES/django.po +7 -3
- wagtail/contrib/settings/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ru/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/sr/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/sr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/sv/LC_MESSAGES/django.po +4 -3
- wagtail/contrib/settings/locale/ta/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/zh/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/settings/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/settings/tests/generic/test_admin.py +118 -2
- wagtail/contrib/settings/tests/shared/test_preview.py +29 -0
- wagtail/contrib/settings/tests/site_specific/test_admin.py +78 -15
- wagtail/contrib/settings/tests/site_specific/test_model.py +2 -2
- wagtail/contrib/settings/views.py +15 -2
- wagtail/contrib/simple_translation/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/bg/LC_MESSAGES/django.po +26 -0
- wagtail/contrib/simple_translation/locale/el/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/simple_translation/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/it/LC_MESSAGES/django.po +5 -2
- wagtail/contrib/simple_translation/locale/mi/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/mn/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/nb/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/vi/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/simple_translation/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/af/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/af/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/bg/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/da/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/de/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/en/LC_MESSAGES/django.po +7 -7
- wagtail/contrib/styleguide/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/en_IN/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/es_VE/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/es_VE/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/he_IL/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/hi/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/hi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/it/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ru/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/sv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ta/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/ta/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/zh/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/styleguide/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/styleguide/tests.py +2 -0
- wagtail/contrib/styleguide/views.py +4 -5
- wagtail/contrib/table_block/locale/ar/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/ar/LC_MESSAGES/django.po +5 -1
- wagtail/contrib/table_block/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/de/LC_MESSAGES/django.po +6 -3
- wagtail/contrib/table_block/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/table_block/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/et/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/id_ID/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/it/LC_MESSAGES/django.po +5 -2
- wagtail/contrib/table_block/locale/ja/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/lv/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/mi/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/mn/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/my/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/nb/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/ru/LC_MESSAGES/django.po +6 -3
- wagtail/contrib/table_block/locale/sk_SK/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/tet/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/tr_TR/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/table_block/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/typed_table_block/blocks.py +37 -0
- wagtail/contrib/typed_table_block/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/de/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/typed_table_block/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/typed_table_block/locale/en/LC_MESSAGES/django.po +10 -10
- wagtail/contrib/typed_table_block/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/it/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/ru/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/typed_table_block/locale/sv/LC_MESSAGES/django.po +5 -4
- wagtail/contrib/typed_table_block/locale/th/LC_MESSAGES/django.mo +0 -0
- wagtail/contrib/typed_table_block/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/contrib/typed_table_block/tests.py +108 -0
- wagtail/coreutils.py +4 -4
- wagtail/documents/__init__.py +4 -4
- wagtail/documents/locale/af/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/af/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/bg/LC_MESSAGES/django.po +10 -1
- wagtail/documents/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/de/LC_MESSAGES/django.po +18 -3
- wagtail/documents/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/en/LC_MESSAGES/django.po +15 -15
- wagtail/documents/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/it/LC_MESSAGES/django.po +33 -3
- wagtail/documents/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/ru/LC_MESSAGES/django.po +7 -3
- wagtail/documents/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/documents/locale/sv/LC_MESSAGES/django.po +33 -5
- wagtail/documents/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/documents/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/documents/models.py +1 -1
- wagtail/documents/tests/test_admin_views.py +19 -4
- wagtail/documents/tests/test_search.py +0 -2
- wagtail/documents/tests/test_views.py +6 -4
- wagtail/documents/views/bulk_actions/add_tags.py +1 -1
- wagtail/embeds/finders/facebook.py +3 -3
- wagtail/embeds/finders/instagram.py +3 -3
- wagtail/embeds/finders/oembed.py +7 -2
- wagtail/embeds/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/da/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/embeds/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/lv/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/locale/my/LC_MESSAGES/django.mo +0 -0
- wagtail/embeds/oembed_providers.py +8 -0
- wagtail/embeds/tests/test_embeds.py +35 -0
- wagtail/images/__init__.py +4 -4
- wagtail/images/admin_urls.py +3 -3
- wagtail/images/blocks.py +1 -1
- wagtail/images/formats.py +2 -2
- wagtail/images/image_operations.py +2 -2
- wagtail/images/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/bg/LC_MESSAGES/django.po +13 -1
- wagtail/images/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ca/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/ca/LC_MESSAGES/django.po +6 -3
- wagtail/images/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/de/LC_MESSAGES/django.po +30 -3
- wagtail/images/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/en/LC_MESSAGES/django.po +44 -40
- wagtail/images/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/fr/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/fr/LC_MESSAGES/django.po +6 -3
- wagtail/images/locale/gl/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/gl/LC_MESSAGES/django.po +6 -3
- wagtail/images/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/it/LC_MESSAGES/django.po +54 -5
- wagtail/images/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/nl/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/nl/LC_MESSAGES/django.po +9 -6
- wagtail/images/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/ru/LC_MESSAGES/django.po +15 -3
- wagtail/images/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/images/locale/sv/LC_MESSAGES/django.po +50 -7
- wagtail/images/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/images/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/images/models.py +11 -10
- wagtail/images/templates/wagtailimages/images/index_results.html +1 -1
- wagtail/images/templates/wagtailimages/images/url_generator.html +17 -38
- wagtail/images/templates/wagtailimages/images/url_generator_output.html +28 -0
- wagtail/images/templatetags/wagtailimages_tags.py +4 -4
- wagtail/images/tests/test_admin_views.py +432 -59
- wagtail/images/tests/test_image_operations.py +2 -2
- wagtail/images/tests/test_models.py +0 -2
- wagtail/images/views/bulk_actions/add_tags.py +1 -1
- wagtail/images/views/images.py +72 -39
- wagtail/locale/ar/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ar/LC_MESSAGES/django.po +10 -19
- wagtail/locale/az_AZ/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/az_AZ/LC_MESSAGES/django.po +4 -4
- wagtail/locale/be/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/be/LC_MESSAGES/django.po +7 -19
- wagtail/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/bg/LC_MESSAGES/django.po +35 -11
- wagtail/locale/bn/LC_MESSAGES/django.po +4 -4
- wagtail/locale/ca/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ca/LC_MESSAGES/django.po +24 -21
- wagtail/locale/cs/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/cs/LC_MESSAGES/django.po +7 -19
- wagtail/locale/cy/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/cy/LC_MESSAGES/django.po +10 -13
- wagtail/locale/da/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/da/LC_MESSAGES/django.po +7 -16
- wagtail/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/de/LC_MESSAGES/django.po +41 -21
- wagtail/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/dv/LC_MESSAGES/django.po +7 -19
- wagtail/locale/el/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/el/LC_MESSAGES/django.po +10 -19
- wagtail/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/en/LC_MESSAGES/django.po +103 -105
- wagtail/locale/es/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/es/LC_MESSAGES/django.po +10 -19
- wagtail/locale/es_419/LC_MESSAGES/django.po +6 -6
- wagtail/locale/et/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/et/LC_MESSAGES/django.po +7 -16
- wagtail/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/eu/LC_MESSAGES/django.po +4 -10
- wagtail/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/fa/LC_MESSAGES/django.po +10 -16
- wagtail/locale/fi/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/fi/LC_MESSAGES/django.po +10 -19
- wagtail/locale/fr/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/fr/LC_MESSAGES/django.po +24 -21
- wagtail/locale/gl/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/gl/LC_MESSAGES/django.po +24 -21
- wagtail/locale/he_IL/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/he_IL/LC_MESSAGES/django.po +10 -16
- wagtail/locale/hr_HR/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/hr_HR/LC_MESSAGES/django.po +7 -16
- wagtail/locale/hu/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/hu/LC_MESSAGES/django.po +10 -19
- wagtail/locale/id_ID/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/id_ID/LC_MESSAGES/django.po +7 -16
- wagtail/locale/is_IS/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/is_IS/LC_MESSAGES/django.po +10 -19
- wagtail/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/it/LC_MESSAGES/django.po +126 -21
- wagtail/locale/ja/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ja/LC_MESSAGES/django.po +10 -19
- wagtail/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ka/LC_MESSAGES/django.po +9 -6
- wagtail/locale/ko/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ko/LC_MESSAGES/django.po +10 -19
- wagtail/locale/lt/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/lt/LC_MESSAGES/django.po +7 -19
- wagtail/locale/lv/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/lv/LC_MESSAGES/django.po +10 -19
- wagtail/locale/mi/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/mi/LC_MESSAGES/django.po +7 -13
- wagtail/locale/mn/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/mn/LC_MESSAGES/django.po +7 -16
- wagtail/locale/my/LC_MESSAGES/django.po +6 -6
- wagtail/locale/nb/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/nb/LC_MESSAGES/django.po +10 -16
- wagtail/locale/nl/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/nl/LC_MESSAGES/django.po +22 -21
- wagtail/locale/pl/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/pl/LC_MESSAGES/django.po +10 -19
- wagtail/locale/pt_BR/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/pt_BR/LC_MESSAGES/django.po +10 -19
- wagtail/locale/pt_PT/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/pt_PT/LC_MESSAGES/django.po +10 -19
- wagtail/locale/ro/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ro/LC_MESSAGES/django.po +10 -19
- wagtail/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ru/LC_MESSAGES/django.po +32 -21
- wagtail/locale/sk_SK/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/sk_SK/LC_MESSAGES/django.po +10 -16
- wagtail/locale/sl/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/sl/LC_MESSAGES/django.po +10 -19
- wagtail/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/sv/LC_MESSAGES/django.po +105 -31
- wagtail/locale/tet/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/tet/LC_MESSAGES/django.po +7 -16
- wagtail/locale/th/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/th/LC_MESSAGES/django.po +7 -19
- wagtail/locale/tr/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/tr/LC_MESSAGES/django.po +10 -19
- wagtail/locale/tr_TR/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/tr_TR/LC_MESSAGES/django.po +10 -16
- wagtail/locale/ug/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/ug/LC_MESSAGES/django.po +10 -19
- wagtail/locale/uk/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/uk/LC_MESSAGES/django.po +7 -19
- wagtail/locale/vi/LC_MESSAGES/django.po +7 -7
- wagtail/locale/zh/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/zh/LC_MESSAGES/django.po +6 -15
- wagtail/locale/zh_Hans/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/zh_Hans/LC_MESSAGES/django.po +10 -19
- wagtail/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/locale/zh_Hant/LC_MESSAGES/django.po +7 -19
- wagtail/locales/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/bg/LC_MESSAGES/django.po +9 -2
- wagtail/locales/locale/da/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/el/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/locales/locale/et/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/he_IL/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/id_ID/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/it/LC_MESSAGES/django.po +13 -2
- wagtail/locales/locale/ja/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/lv/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/mn/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/my/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/nb/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/ru/LC_MESSAGES/django.po +7 -2
- wagtail/locales/locale/sk_SK/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/sv/LC_MESSAGES/django.po +4 -3
- wagtail/locales/locale/tet/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/th/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/tr_TR/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/vi/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/zh/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/locales/tests.py +5 -5
- wagtail/models/i18n.py +4 -6
- wagtail/models/media.py +18 -0
- wagtail/models/pages.py +65 -11
- wagtail/models/reference_index.py +15 -0
- wagtail/models/revisions.py +40 -12
- wagtail/models/workflows.py +0 -3
- wagtail/permission_policies/base.py +2 -2
- wagtail/permission_policies/collections.py +2 -2
- wagtail/project_template/requirements.txt +2 -2
- wagtail/search/locale/ar/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/be/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ca/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/cs/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/cy/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/search/locale/es/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/et/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/fa/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/fi/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/fr/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/gl/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/hr_HR/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/hu/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/id_ID/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/is_IS/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ja/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ko/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/lt/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/mi/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/mn/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/my/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/nb/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/nl/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/pl/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/pt_BR/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/pt_PT/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ro/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/sl/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/tet/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/th/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/tr/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/tr_TR/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/ug/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/uk/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/vi/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/zh_Hans/LC_MESSAGES/django.mo +0 -0
- wagtail/search/locale/zh_Hant/LC_MESSAGES/django.mo +0 -0
- wagtail/signal_handlers.py +1 -0
- wagtail/sites/locale/bn/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/da/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/dv/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/en/LC_MESSAGES/django.po +1 -1
- wagtail/sites/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/es_419/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/es_VE/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/hi/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/sr/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/locale/sv/LC_MESSAGES/django.po +3 -2
- wagtail/sites/locale/ta/LC_MESSAGES/django.mo +0 -0
- wagtail/sites/tests.py +7 -7
- wagtail/snippets/action_menu.py +2 -1
- wagtail/snippets/locale/af/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/af/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/az_AZ/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/bg/LC_MESSAGES/django.po +10 -1
- wagtail/snippets/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ca/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/ca/LC_MESSAGES/django.po +11 -3
- wagtail/snippets/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/de/LC_MESSAGES/django.po +15 -3
- wagtail/snippets/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/en/LC_MESSAGES/django.po +23 -13
- wagtail/snippets/locale/en_IN/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/en_IN/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/es_VE/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/fr/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/fr/LC_MESSAGES/django.po +11 -3
- wagtail/snippets/locale/gl/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/gl/LC_MESSAGES/django.po +9 -1
- wagtail/snippets/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/hi/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/hi/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ht/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/ht/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/id_ID/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/it/LC_MESSAGES/django.po +11 -1
- wagtail/snippets/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ka/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/nl/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/nl/LC_MESSAGES/django.po +11 -3
- wagtail/snippets/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/ru/LC_MESSAGES/django.po +11 -3
- wagtail/snippets/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/sr/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/sr/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/sv/LC_MESSAGES/django.po +13 -2
- wagtail/snippets/locale/ta/LC_MESSAGES/django.mo +0 -0
- wagtail/snippets/locale/ta/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/snippets/tests/test_chooser_block.py +197 -0
- wagtail/snippets/tests/test_chooser_panel.py +149 -0
- wagtail/snippets/tests/test_chooser_views.py +375 -0
- wagtail/snippets/tests/test_chooser_widget.py +22 -0
- wagtail/snippets/tests/test_compare_revisions_view.py +167 -0
- wagtail/snippets/tests/test_copy_view.py +38 -0
- wagtail/snippets/tests/test_create_view.py +1163 -0
- wagtail/snippets/tests/test_delete_view.py +225 -0
- wagtail/snippets/tests/test_edit_view.py +3243 -0
- wagtail/snippets/tests/test_history_view.py +182 -0
- wagtail/snippets/tests/test_index_view.py +105 -0
- wagtail/snippets/tests/test_list_view.py +786 -0
- wagtail/snippets/tests/test_locking.py +28 -0
- wagtail/snippets/tests/test_permissions.py +167 -0
- wagtail/snippets/tests/test_preview.py +56 -3
- wagtail/snippets/tests/test_revert_view.py +343 -0
- wagtail/snippets/tests/test_snippet_models.py +112 -0
- wagtail/snippets/tests/test_unpublish_view.py +228 -0
- wagtail/snippets/tests/test_unschedule_view.py +151 -0
- wagtail/snippets/tests/test_viewset.py +38 -5
- wagtail/snippets/views/snippets.py +76 -30
- wagtail/snippets/widgets.py +2 -2
- wagtail/templatetags/wagtailcore_tags.py +2 -2
- wagtail/test/dummy_external_storage.py +1 -1
- wagtail/test/testapp/fixtures/test.json +22 -0
- wagtail/test/testapp/fixtures/test_empty.json +2 -0
- wagtail/test/testapp/fixtures/test_explorable_pages.json +10 -0
- wagtail/test/testapp/fixtures/test_specific.json +9 -0
- wagtail/test/testapp/migrations/0059_nopromotepage.py +25 -0
- wagtail/test/testapp/models.py +7 -0
- wagtail/test/testapp/views.py +5 -0
- wagtail/test/utils/page_tests.py +7 -7
- wagtail/test/utils/wagtail_factories/builder.py +2 -2
- wagtail/tests/streamfield_migrations/test_migrations.py +35 -0
- wagtail/tests/test_blocks.py +321 -61
- wagtail/tests/test_collection_model.py +12 -0
- wagtail/tests/test_page_model.py +190 -1
- wagtail/tests/test_page_privacy.py +5 -0
- wagtail/tests/test_reference_index.py +42 -0
- wagtail/tests/test_revision_model.py +118 -1
- wagtail/tests/test_utils.py +2 -2
- wagtail/users/locale/ar/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/be/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/bg/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/bg/LC_MESSAGES/django.po +10 -1
- wagtail/users/locale/bn/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ca/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/cs/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/cy/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/da/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/de/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/de/LC_MESSAGES/django.po +6 -3
- wagtail/users/locale/dv/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/el/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/en/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/en/LC_MESSAGES/django.po +14 -14
- wagtail/users/locale/es/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/es_419/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/et/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/eu/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/eu/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/fa/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/fi/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/fr/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/gl/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/he_IL/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/hr_HR/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/hu/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/hy/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/id_ID/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/id_ID/LC_MESSAGES/django.po +7 -3
- wagtail/users/locale/is_IS/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/it/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/it/LC_MESSAGES/django.po +15 -3
- wagtail/users/locale/ja/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ka/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ko/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/lt/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/lv/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/mi/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/mn/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/my/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/nb/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/nl/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/pl/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/pt_BR/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/pt_PT/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ro/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ru/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/ru/LC_MESSAGES/django.po +4 -4
- wagtail/users/locale/sk_SK/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/sl/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/sv/LC_MESSAGES/django.mo +0 -0
- wagtail/users/locale/sv/LC_MESSAGES/django.po +49 -18
- wagtail/users/locale/tet/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/th/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/tr/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/tr_TR/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/ug/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/uk/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/vi/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/zh/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/zh_Hans/LC_MESSAGES/django.po +1 -1
- wagtail/users/locale/zh_Hant/LC_MESSAGES/django.po +1 -1
- wagtail/users/tests/test_admin_views.py +39 -25
- wagtail/users/utils.py +4 -1
- wagtail/users/views/groups.py +19 -5
- wagtail/users/wagtail_hooks.py +1 -1
- wagtail/utils/loading.py +2 -2
- wagtail-7.3.data/data/AGENTS.md +21 -0
- wagtail-7.3.data/data/CHANGELOG.txt +4957 -0
- wagtail-7.3.data/data/CODE_OF_CONDUCT.md +71 -0
- wagtail-7.3.data/data/CONTRIBUTORS.md +1001 -0
- wagtail-7.3.data/data/SPONSORS.md +55 -0
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/METADATA +6 -6
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/RECORD +1301 -1267
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/WHEEL +1 -1
- wagtail/images/static/wagtailimages/js/image-url-generator.js +0 -1
- wagtail/snippets/tests/test_snippets.py +0 -6377
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/entry_points.txt +0 -0
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/licenses/LICENSE +0 -0
- {wagtail-7.2.1.dist-info → wagtail-7.3.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,1163 @@
|
|
|
1
|
+
import datetime
|
|
2
|
+
from unittest import mock
|
|
3
|
+
|
|
4
|
+
from django.contrib.admin.utils import quote
|
|
5
|
+
from django.contrib.auth.models import Permission
|
|
6
|
+
from django.core.files.uploadedfile import SimpleUploadedFile
|
|
7
|
+
from django.core.handlers.wsgi import WSGIRequest
|
|
8
|
+
from django.http import HttpRequest, HttpResponse, JsonResponse
|
|
9
|
+
from django.test import TestCase
|
|
10
|
+
from django.test.utils import override_settings
|
|
11
|
+
from django.urls import reverse
|
|
12
|
+
from django.utils.timezone import now
|
|
13
|
+
from freezegun import freeze_time
|
|
14
|
+
from taggit.models import Tag
|
|
15
|
+
|
|
16
|
+
from wagtail.models import Locale, ModelLogEntry, Revision
|
|
17
|
+
from wagtail.signals import published
|
|
18
|
+
from wagtail.snippets.action_menu import (
|
|
19
|
+
ActionMenuItem,
|
|
20
|
+
get_base_snippet_action_menu_items,
|
|
21
|
+
)
|
|
22
|
+
from wagtail.test.snippets.models import (
|
|
23
|
+
FileUploadSnippet,
|
|
24
|
+
)
|
|
25
|
+
from wagtail.test.testapp.models import (
|
|
26
|
+
Advert,
|
|
27
|
+
DraftStateModel,
|
|
28
|
+
RevisableModel,
|
|
29
|
+
)
|
|
30
|
+
from wagtail.test.utils import WagtailTestUtils
|
|
31
|
+
from wagtail.test.utils.timestamps import submittable_timestamp
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
class TestSnippetCreateView(WagtailTestUtils, TestCase):
|
|
35
|
+
def setUp(self):
|
|
36
|
+
self.user = self.login()
|
|
37
|
+
|
|
38
|
+
def get(self, params=None, model=Advert, headers=None):
|
|
39
|
+
return self.client.get(
|
|
40
|
+
reverse(model.snippet_viewset.get_url_name("add")), params, headers=headers
|
|
41
|
+
)
|
|
42
|
+
|
|
43
|
+
def post(self, post_data=None, model=Advert, headers=None):
|
|
44
|
+
return self.client.post(
|
|
45
|
+
reverse(model.snippet_viewset.get_url_name("add")),
|
|
46
|
+
post_data,
|
|
47
|
+
headers=headers,
|
|
48
|
+
)
|
|
49
|
+
|
|
50
|
+
def test_get_with_limited_permissions(self):
|
|
51
|
+
self.user.is_superuser = False
|
|
52
|
+
self.user.user_permissions.add(
|
|
53
|
+
Permission.objects.get(
|
|
54
|
+
content_type__app_label="wagtailadmin", codename="access_admin"
|
|
55
|
+
)
|
|
56
|
+
)
|
|
57
|
+
self.user.save()
|
|
58
|
+
|
|
59
|
+
response = self.get()
|
|
60
|
+
self.assertEqual(response.status_code, 302)
|
|
61
|
+
|
|
62
|
+
def test_simple(self):
|
|
63
|
+
response = self.get()
|
|
64
|
+
self.assertEqual(response.status_code, 200)
|
|
65
|
+
self.assertTemplateUsed(response, "wagtailsnippets/snippets/create.html")
|
|
66
|
+
self.assertNotContains(response, 'role="tablist"', html=True)
|
|
67
|
+
|
|
68
|
+
soup = self.get_soup(response.content)
|
|
69
|
+
|
|
70
|
+
# Should have the unsaved controller set up
|
|
71
|
+
editor_form = soup.select_one("#w-editor-form")
|
|
72
|
+
self.assertIsNotNone(editor_form)
|
|
73
|
+
self.assertIn("w-unsaved", editor_form.attrs.get("data-controller").split())
|
|
74
|
+
self.assertTrue(
|
|
75
|
+
{
|
|
76
|
+
"w-unsaved#submit",
|
|
77
|
+
"beforeunload@window->w-unsaved#confirm",
|
|
78
|
+
}.issubset(editor_form.attrs.get("data-action").split())
|
|
79
|
+
)
|
|
80
|
+
self.assertEqual(
|
|
81
|
+
editor_form.attrs.get("data-w-unsaved-confirmation-value"),
|
|
82
|
+
"true",
|
|
83
|
+
)
|
|
84
|
+
self.assertEqual(
|
|
85
|
+
editor_form.attrs.get("data-w-unsaved-force-value"),
|
|
86
|
+
"false",
|
|
87
|
+
)
|
|
88
|
+
|
|
89
|
+
def test_snippet_with_tabbed_interface(self):
|
|
90
|
+
response = self.client.get(
|
|
91
|
+
reverse("wagtailsnippets_tests_advertwithtabbedinterface:add")
|
|
92
|
+
)
|
|
93
|
+
|
|
94
|
+
self.assertEqual(response.status_code, 200)
|
|
95
|
+
self.assertTemplateUsed(response, "wagtailsnippets/snippets/create.html")
|
|
96
|
+
self.assertContains(response, 'role="tablist"')
|
|
97
|
+
self.assertContains(
|
|
98
|
+
response,
|
|
99
|
+
'<a id="tab-label-advert" href="#tab-advert" class="w-tabs__tab " role="tab" aria-selected="false" tabindex="-1" data-action="w-tabs#select:prevent" data-w-tabs-target="trigger">',
|
|
100
|
+
)
|
|
101
|
+
self.assertContains(
|
|
102
|
+
response,
|
|
103
|
+
'<a id="tab-label-other" href="#tab-other" class="w-tabs__tab " role="tab" aria-selected="false" tabindex="-1" data-action="w-tabs#select:prevent" data-w-tabs-target="trigger">',
|
|
104
|
+
)
|
|
105
|
+
self.assertContains(response, "Other panels help text")
|
|
106
|
+
self.assertContains(response, "Top-level help text")
|
|
107
|
+
|
|
108
|
+
def test_create_with_limited_permissions(self):
|
|
109
|
+
self.user.is_superuser = False
|
|
110
|
+
self.user.user_permissions.add(
|
|
111
|
+
Permission.objects.get(
|
|
112
|
+
content_type__app_label="wagtailadmin", codename="access_admin"
|
|
113
|
+
)
|
|
114
|
+
)
|
|
115
|
+
self.user.save()
|
|
116
|
+
|
|
117
|
+
response = self.post(
|
|
118
|
+
post_data={"text": "test text", "url": "http://www.example.com/"}
|
|
119
|
+
)
|
|
120
|
+
self.assertEqual(response.status_code, 302)
|
|
121
|
+
|
|
122
|
+
def test_create_invalid(self):
|
|
123
|
+
response = self.post(post_data={"foo": "bar"})
|
|
124
|
+
|
|
125
|
+
soup = self.get_soup(response.content)
|
|
126
|
+
|
|
127
|
+
header_messages = soup.css.select(".messages[role='status'] ul > li")
|
|
128
|
+
|
|
129
|
+
# there should be one header message that indicates the issue and has a go to error button
|
|
130
|
+
self.assertEqual(len(header_messages), 1)
|
|
131
|
+
message = header_messages[0]
|
|
132
|
+
self.assertIn(
|
|
133
|
+
"The advert could not be created due to errors.", message.get_text()
|
|
134
|
+
)
|
|
135
|
+
buttons = message.find_all("button")
|
|
136
|
+
self.assertEqual(len(buttons), 1)
|
|
137
|
+
self.assertEqual(buttons[0].attrs["data-controller"], "w-count w-focus")
|
|
138
|
+
self.assertEqual(
|
|
139
|
+
set(buttons[0].attrs["data-action"].split()),
|
|
140
|
+
{"click->w-focus#focus", "wagtail:panel-init@document->w-count#count"},
|
|
141
|
+
)
|
|
142
|
+
self.assertIn("Go to the first error", buttons[0].get_text())
|
|
143
|
+
|
|
144
|
+
# field specific error should be shown
|
|
145
|
+
error_messages = soup.css.select(".error-message")
|
|
146
|
+
self.assertEqual(len(error_messages), 1)
|
|
147
|
+
error_message = error_messages[0]
|
|
148
|
+
self.assertEqual(error_message.parent["id"], "panel-child-text-errors")
|
|
149
|
+
self.assertIn("This field is required", error_message.get_text())
|
|
150
|
+
|
|
151
|
+
# Should have the unsaved controller set up
|
|
152
|
+
editor_form = soup.select_one("#w-editor-form")
|
|
153
|
+
self.assertIsNotNone(editor_form)
|
|
154
|
+
self.assertIn("w-unsaved", editor_form.attrs.get("data-controller").split())
|
|
155
|
+
self.assertTrue(
|
|
156
|
+
{
|
|
157
|
+
"w-unsaved#submit",
|
|
158
|
+
"beforeunload@window->w-unsaved#confirm",
|
|
159
|
+
}.issubset(editor_form.attrs.get("data-action").split())
|
|
160
|
+
)
|
|
161
|
+
self.assertEqual(
|
|
162
|
+
editor_form.attrs.get("data-w-unsaved-confirmation-value"),
|
|
163
|
+
"true",
|
|
164
|
+
)
|
|
165
|
+
self.assertEqual(
|
|
166
|
+
editor_form.attrs.get("data-w-unsaved-force-value"),
|
|
167
|
+
# The form is invalid, we want to force it to be "dirty" on initial load
|
|
168
|
+
"true",
|
|
169
|
+
)
|
|
170
|
+
|
|
171
|
+
def test_create_invalid_with_json_response(self):
|
|
172
|
+
response = self.post(
|
|
173
|
+
post_data={"foo": "bar"}, headers={"Accept": "application/json"}
|
|
174
|
+
)
|
|
175
|
+
self.assertEqual(response.status_code, 400)
|
|
176
|
+
self.assertEqual(response["Content-Type"], "application/json")
|
|
177
|
+
self.assertEqual(
|
|
178
|
+
response.json(),
|
|
179
|
+
{
|
|
180
|
+
"success": False,
|
|
181
|
+
"error_code": "validation_error",
|
|
182
|
+
"error_message": "There are validation errors, click save to highlight them.",
|
|
183
|
+
},
|
|
184
|
+
)
|
|
185
|
+
|
|
186
|
+
def test_create(self):
|
|
187
|
+
response = self.post(
|
|
188
|
+
post_data={"text": "test_advert", "url": "http://www.example.com/"}
|
|
189
|
+
)
|
|
190
|
+
self.assertRedirects(response, reverse("wagtailsnippets_tests_advert:list"))
|
|
191
|
+
|
|
192
|
+
snippets = Advert.objects.filter(text="test_advert")
|
|
193
|
+
self.assertEqual(snippets.count(), 1)
|
|
194
|
+
self.assertEqual(snippets.first().url, "http://www.example.com/")
|
|
195
|
+
|
|
196
|
+
def test_create_with_json_response(self):
|
|
197
|
+
response = self.post(
|
|
198
|
+
post_data={"text": "test_advert", "url": "http://www.example.com/"},
|
|
199
|
+
headers={"Accept": "application/json"},
|
|
200
|
+
)
|
|
201
|
+
self.assertEqual(response.status_code, 200)
|
|
202
|
+
self.assertEqual(response["Content-Type"], "application/json")
|
|
203
|
+
|
|
204
|
+
snippets = Advert.objects.filter(text="test_advert")
|
|
205
|
+
self.assertEqual(snippets.count(), 1)
|
|
206
|
+
snippet = snippets.first()
|
|
207
|
+
self.assertEqual(snippet.url, "http://www.example.com/")
|
|
208
|
+
|
|
209
|
+
response_json = response.json()
|
|
210
|
+
edit_url = reverse(
|
|
211
|
+
snippet.snippet_viewset.get_url_name("edit"), args=(snippet.pk,)
|
|
212
|
+
)
|
|
213
|
+
self.assertEqual(response_json["success"], True)
|
|
214
|
+
self.assertEqual(response_json["pk"], snippet.pk)
|
|
215
|
+
self.assertEqual(response_json["field_updates"], {})
|
|
216
|
+
self.assertEqual(response_json["url"], edit_url)
|
|
217
|
+
self.assertEqual(
|
|
218
|
+
response_json["hydrate_url"],
|
|
219
|
+
f"{edit_url}?_w_hydrate_create_view=1",
|
|
220
|
+
)
|
|
221
|
+
|
|
222
|
+
def test_create_with_tags(self):
|
|
223
|
+
tags = ["hello", "world"]
|
|
224
|
+
response = self.post(
|
|
225
|
+
post_data={
|
|
226
|
+
"text": "test_advert",
|
|
227
|
+
"url": "http://example.com/",
|
|
228
|
+
"tags": ", ".join(tags),
|
|
229
|
+
}
|
|
230
|
+
)
|
|
231
|
+
|
|
232
|
+
self.assertRedirects(response, reverse("wagtailsnippets_tests_advert:list"))
|
|
233
|
+
|
|
234
|
+
snippet = Advert.objects.get(text="test_advert")
|
|
235
|
+
|
|
236
|
+
expected_tags = list(Tag.objects.order_by("name").filter(name__in=tags))
|
|
237
|
+
self.assertEqual(len(expected_tags), 2)
|
|
238
|
+
self.assertEqual(list(snippet.tags.order_by("name")), expected_tags)
|
|
239
|
+
|
|
240
|
+
def test_create_file_upload_multipart(self):
|
|
241
|
+
response = self.get(model=FileUploadSnippet)
|
|
242
|
+
self.assertContains(response, 'enctype="multipart/form-data"')
|
|
243
|
+
|
|
244
|
+
response = self.post(
|
|
245
|
+
model=FileUploadSnippet,
|
|
246
|
+
post_data={"file": SimpleUploadedFile("test.txt", b"Uploaded file")},
|
|
247
|
+
)
|
|
248
|
+
self.assertRedirects(
|
|
249
|
+
response,
|
|
250
|
+
reverse("wagtailsnippets_snippetstests_fileuploadsnippet:list"),
|
|
251
|
+
)
|
|
252
|
+
snippet = FileUploadSnippet.objects.get()
|
|
253
|
+
self.assertEqual(snippet.file.read(), b"Uploaded file")
|
|
254
|
+
|
|
255
|
+
def test_create_with_revision(self):
|
|
256
|
+
response = self.post(
|
|
257
|
+
model=RevisableModel, post_data={"text": "create_revisable"}
|
|
258
|
+
)
|
|
259
|
+
self.assertRedirects(
|
|
260
|
+
response, reverse("wagtailsnippets_tests_revisablemodel:list")
|
|
261
|
+
)
|
|
262
|
+
|
|
263
|
+
snippets = RevisableModel.objects.filter(text="create_revisable")
|
|
264
|
+
snippet = snippets.first()
|
|
265
|
+
self.assertEqual(snippets.count(), 1)
|
|
266
|
+
|
|
267
|
+
# The revision should be created
|
|
268
|
+
revisions = snippet.revisions
|
|
269
|
+
revision = revisions.first()
|
|
270
|
+
self.assertEqual(revisions.count(), 1)
|
|
271
|
+
self.assertEqual(revision.content["text"], "create_revisable")
|
|
272
|
+
|
|
273
|
+
# The log entry should have the revision attached
|
|
274
|
+
log_entries = ModelLogEntry.objects.for_instance(snippet).filter(
|
|
275
|
+
action="wagtail.create"
|
|
276
|
+
)
|
|
277
|
+
self.assertEqual(log_entries.count(), 1)
|
|
278
|
+
self.assertEqual(log_entries.first().revision, revision)
|
|
279
|
+
|
|
280
|
+
def test_before_create_snippet_hook_get(self):
|
|
281
|
+
def hook_func(request, model):
|
|
282
|
+
self.assertIsInstance(request, HttpRequest)
|
|
283
|
+
self.assertEqual(model, Advert)
|
|
284
|
+
return HttpResponse("Overridden!")
|
|
285
|
+
|
|
286
|
+
with self.register_hook("before_create_snippet", hook_func):
|
|
287
|
+
response = self.get()
|
|
288
|
+
|
|
289
|
+
self.assertEqual(response.status_code, 200)
|
|
290
|
+
self.assertEqual(response.content, b"Overridden!")
|
|
291
|
+
|
|
292
|
+
def test_before_create_snippet_hook_get_with_json_response(self):
|
|
293
|
+
def non_json_hook_func(request, model):
|
|
294
|
+
self.assertIsInstance(request, HttpRequest)
|
|
295
|
+
self.assertEqual(model, Advert)
|
|
296
|
+
return HttpResponse("Overridden!")
|
|
297
|
+
|
|
298
|
+
def json_hook_func(request, model):
|
|
299
|
+
self.assertIsInstance(request, HttpRequest)
|
|
300
|
+
self.assertEqual(model, Advert)
|
|
301
|
+
return JsonResponse({"status": "purple"})
|
|
302
|
+
|
|
303
|
+
with self.register_hook("before_create_snippet", non_json_hook_func):
|
|
304
|
+
response = self.get(headers={"Accept": "application/json"})
|
|
305
|
+
self.assertEqual(
|
|
306
|
+
response.json(),
|
|
307
|
+
{
|
|
308
|
+
"success": False,
|
|
309
|
+
"error_code": "blocked_by_hook",
|
|
310
|
+
"error_message": "Request to create advert was blocked by hook.",
|
|
311
|
+
},
|
|
312
|
+
)
|
|
313
|
+
|
|
314
|
+
with self.register_hook("before_create_snippet", json_hook_func):
|
|
315
|
+
response = self.get(headers={"Accept": "application/json"})
|
|
316
|
+
self.assertEqual(response.json(), {"status": "purple"})
|
|
317
|
+
|
|
318
|
+
def test_before_create_snippet_hook_post(self):
|
|
319
|
+
def hook_func(request, model):
|
|
320
|
+
self.assertIsInstance(request, HttpRequest)
|
|
321
|
+
self.assertEqual(model, Advert)
|
|
322
|
+
return HttpResponse("Overridden!")
|
|
323
|
+
|
|
324
|
+
with self.register_hook("before_create_snippet", hook_func):
|
|
325
|
+
post_data = {"text": "Hook test", "url": "http://www.example.com/"}
|
|
326
|
+
response = self.post(post_data=post_data)
|
|
327
|
+
|
|
328
|
+
self.assertEqual(response.status_code, 200)
|
|
329
|
+
self.assertEqual(response.content, b"Overridden!")
|
|
330
|
+
|
|
331
|
+
# Request intercepted before advert was created
|
|
332
|
+
self.assertFalse(Advert.objects.exists())
|
|
333
|
+
|
|
334
|
+
def test_before_create_snippet_hook_post_with_json_response(self):
|
|
335
|
+
def non_json_hook_func(request, model):
|
|
336
|
+
self.assertIsInstance(request, HttpRequest)
|
|
337
|
+
self.assertEqual(model, Advert)
|
|
338
|
+
return HttpResponse("Overridden!")
|
|
339
|
+
|
|
340
|
+
def json_hook_func(request, model):
|
|
341
|
+
self.assertIsInstance(request, HttpRequest)
|
|
342
|
+
self.assertEqual(model, Advert)
|
|
343
|
+
return JsonResponse({"status": "purple"})
|
|
344
|
+
|
|
345
|
+
with self.register_hook("before_create_snippet", non_json_hook_func):
|
|
346
|
+
post_data = {"text": "Hook test", "url": "http://www.example.com/"}
|
|
347
|
+
response = self.post(
|
|
348
|
+
post_data=post_data,
|
|
349
|
+
headers={"Accept": "application/json"},
|
|
350
|
+
)
|
|
351
|
+
|
|
352
|
+
self.assertEqual(response.status_code, 400)
|
|
353
|
+
self.assertEqual(
|
|
354
|
+
response.json(),
|
|
355
|
+
{
|
|
356
|
+
"success": False,
|
|
357
|
+
"error_code": "blocked_by_hook",
|
|
358
|
+
"error_message": "Request to create advert was blocked by hook.",
|
|
359
|
+
},
|
|
360
|
+
)
|
|
361
|
+
|
|
362
|
+
# Request intercepted before advert was created
|
|
363
|
+
self.assertFalse(Advert.objects.exists())
|
|
364
|
+
|
|
365
|
+
with self.register_hook("before_create_snippet", json_hook_func):
|
|
366
|
+
post_data = {"text": "Hook test", "url": "http://www.example.com/"}
|
|
367
|
+
response = self.post(
|
|
368
|
+
post_data=post_data,
|
|
369
|
+
headers={"Accept": "application/json"},
|
|
370
|
+
)
|
|
371
|
+
|
|
372
|
+
self.assertEqual(response.status_code, 200)
|
|
373
|
+
self.assertEqual(response.json(), {"status": "purple"})
|
|
374
|
+
|
|
375
|
+
# Request intercepted before advert was created
|
|
376
|
+
self.assertFalse(Advert.objects.exists())
|
|
377
|
+
|
|
378
|
+
def test_after_create_snippet_hook(self):
|
|
379
|
+
def hook_func(request, instance):
|
|
380
|
+
self.assertIsInstance(request, HttpRequest)
|
|
381
|
+
self.assertEqual(instance.text, "Hook test")
|
|
382
|
+
self.assertEqual(instance.url, "http://www.example.com/")
|
|
383
|
+
return HttpResponse("Overridden!")
|
|
384
|
+
|
|
385
|
+
with self.register_hook("after_create_snippet", hook_func):
|
|
386
|
+
post_data = {"text": "Hook test", "url": "http://www.example.com/"}
|
|
387
|
+
response = self.post(post_data=post_data)
|
|
388
|
+
|
|
389
|
+
self.assertEqual(response.status_code, 200)
|
|
390
|
+
self.assertEqual(response.content, b"Overridden!")
|
|
391
|
+
|
|
392
|
+
# Request intercepted after advert was created
|
|
393
|
+
self.assertTrue(Advert.objects.exists())
|
|
394
|
+
|
|
395
|
+
def test_after_create_snippet_hook_post_with_json_response(self):
|
|
396
|
+
def non_json_hook_func(request, instance):
|
|
397
|
+
self.assertIsInstance(request, HttpRequest)
|
|
398
|
+
self.assertEqual(instance.text, "Hook test")
|
|
399
|
+
self.assertEqual(instance.url, "http://www.example.com/")
|
|
400
|
+
return HttpResponse("Overridden!")
|
|
401
|
+
|
|
402
|
+
def json_hook_func(request, instance):
|
|
403
|
+
self.assertIsInstance(request, HttpRequest)
|
|
404
|
+
self.assertEqual(instance.text, "Another hook test")
|
|
405
|
+
self.assertEqual(instance.url, "http://www.example.com/")
|
|
406
|
+
return JsonResponse({"status": "purple"})
|
|
407
|
+
|
|
408
|
+
with self.register_hook("after_create_snippet", non_json_hook_func):
|
|
409
|
+
post_data = {"text": "Hook test", "url": "http://www.example.com/"}
|
|
410
|
+
response = self.post(
|
|
411
|
+
post_data=post_data,
|
|
412
|
+
headers={"Accept": "application/json"},
|
|
413
|
+
)
|
|
414
|
+
|
|
415
|
+
self.assertEqual(response.status_code, 200)
|
|
416
|
+
# hook response is ignored, since it's not a JSON response
|
|
417
|
+
self.assertEqual(response.json()["success"], True)
|
|
418
|
+
|
|
419
|
+
# Request intercepted after advert was created
|
|
420
|
+
self.assertTrue(Advert.objects.filter(text="Hook test").exists())
|
|
421
|
+
|
|
422
|
+
with self.register_hook("after_create_snippet", json_hook_func):
|
|
423
|
+
post_data = {"text": "Another hook test", "url": "http://www.example.com/"}
|
|
424
|
+
response = self.post(
|
|
425
|
+
post_data=post_data,
|
|
426
|
+
headers={"Accept": "application/json"},
|
|
427
|
+
)
|
|
428
|
+
|
|
429
|
+
self.assertEqual(response.status_code, 200)
|
|
430
|
+
# hook response is used, since it's a JSON response
|
|
431
|
+
self.assertEqual(response.json(), {"status": "purple"})
|
|
432
|
+
|
|
433
|
+
# Request intercepted after advert was created
|
|
434
|
+
self.assertTrue(Advert.objects.filter(text="Another hook test").exists())
|
|
435
|
+
|
|
436
|
+
def test_register_snippet_action_menu_item(self):
|
|
437
|
+
class TestSnippetActionMenuItem(ActionMenuItem):
|
|
438
|
+
label = "Test"
|
|
439
|
+
name = "test"
|
|
440
|
+
icon_name = "check"
|
|
441
|
+
classname = "custom-class"
|
|
442
|
+
|
|
443
|
+
def is_shown(self, context):
|
|
444
|
+
return True
|
|
445
|
+
|
|
446
|
+
def hook_func(model):
|
|
447
|
+
return TestSnippetActionMenuItem(order=0)
|
|
448
|
+
|
|
449
|
+
with self.register_hook("register_snippet_action_menu_item", hook_func):
|
|
450
|
+
get_base_snippet_action_menu_items.cache_clear()
|
|
451
|
+
|
|
452
|
+
response = self.get()
|
|
453
|
+
|
|
454
|
+
get_base_snippet_action_menu_items.cache_clear()
|
|
455
|
+
|
|
456
|
+
self.assertContains(
|
|
457
|
+
response,
|
|
458
|
+
'<button type="submit" name="test" value="Test" class="button custom-class"><svg class="icon icon-check icon" aria-hidden="true"><use href="#icon-check"></use></svg>Test</button>',
|
|
459
|
+
html=True,
|
|
460
|
+
)
|
|
461
|
+
|
|
462
|
+
def test_register_snippet_action_menu_item_as_none(self):
|
|
463
|
+
def hook_func(model):
|
|
464
|
+
return None
|
|
465
|
+
|
|
466
|
+
with self.register_hook("register_snippet_action_menu_item", hook_func):
|
|
467
|
+
get_base_snippet_action_menu_items.cache_clear()
|
|
468
|
+
|
|
469
|
+
response = self.get()
|
|
470
|
+
|
|
471
|
+
get_base_snippet_action_menu_items.cache_clear()
|
|
472
|
+
self.assertEqual(response.status_code, 200)
|
|
473
|
+
|
|
474
|
+
def test_construct_snippet_action_menu(self):
|
|
475
|
+
class TestSnippetActionMenuItem(ActionMenuItem):
|
|
476
|
+
label = "Test"
|
|
477
|
+
name = "test"
|
|
478
|
+
icon_name = "check"
|
|
479
|
+
classname = "custom-class"
|
|
480
|
+
|
|
481
|
+
def is_shown(self, context):
|
|
482
|
+
return True
|
|
483
|
+
|
|
484
|
+
class Media:
|
|
485
|
+
js = ["js/some-default-item.js"]
|
|
486
|
+
css = {"all": ["css/some-default-item.css"]}
|
|
487
|
+
|
|
488
|
+
def hook_func(menu_items, request, context):
|
|
489
|
+
self.assertIsInstance(menu_items, list)
|
|
490
|
+
self.assertIsInstance(request, WSGIRequest)
|
|
491
|
+
self.assertEqual(context["view"], "create")
|
|
492
|
+
self.assertEqual(context["model"], Advert)
|
|
493
|
+
|
|
494
|
+
# Replace save menu item
|
|
495
|
+
menu_items[:] = [TestSnippetActionMenuItem(order=0)]
|
|
496
|
+
|
|
497
|
+
with self.register_hook("construct_snippet_action_menu", hook_func):
|
|
498
|
+
response = self.get()
|
|
499
|
+
|
|
500
|
+
soup = self.get_soup(response.content)
|
|
501
|
+
custom_action = soup.select_one("form button[name='test']")
|
|
502
|
+
self.assertIsNotNone(custom_action)
|
|
503
|
+
|
|
504
|
+
# We're replacing the save button, so it should not be in a dropdown
|
|
505
|
+
# as it's the main action
|
|
506
|
+
dropdown_parent = custom_action.find_parent(attrs={"class": "w-dropdown"})
|
|
507
|
+
self.assertIsNone(dropdown_parent)
|
|
508
|
+
|
|
509
|
+
self.assertEqual(custom_action.text.strip(), "Test")
|
|
510
|
+
self.assertEqual(custom_action.attrs.get("class"), ["button", "custom-class"])
|
|
511
|
+
icon = custom_action.select_one("svg use[href='#icon-check']")
|
|
512
|
+
self.assertIsNotNone(icon)
|
|
513
|
+
|
|
514
|
+
# Should contain media files
|
|
515
|
+
js = soup.select_one("script[src='/static/js/some-default-item.js']")
|
|
516
|
+
self.assertIsNotNone(js)
|
|
517
|
+
css = soup.select_one("link[href='/static/css/some-default-item.css']")
|
|
518
|
+
self.assertIsNotNone(css)
|
|
519
|
+
|
|
520
|
+
save_item = soup.select_one("form button[name='action-save']")
|
|
521
|
+
self.assertIsNone(save_item)
|
|
522
|
+
|
|
523
|
+
def test_create_shows_status_side_panel_skeleton(self):
|
|
524
|
+
self.user.first_name = "Chrismansyah"
|
|
525
|
+
self.user.last_name = "Rahadi"
|
|
526
|
+
self.user.save()
|
|
527
|
+
response = self.get(model=RevisableModel)
|
|
528
|
+
soup = self.get_soup(response.content)
|
|
529
|
+
panel = soup.select_one('[data-side-panel="status"]')
|
|
530
|
+
self.assertIsNotNone(panel)
|
|
531
|
+
|
|
532
|
+
def assert_panel_section(label_id, label_text, description):
|
|
533
|
+
section = panel.select_one(f'[aria-labelledby="{label_id}"]')
|
|
534
|
+
self.assertIsNotNone(section)
|
|
535
|
+
label = section.select_one(f"#{label_id}")
|
|
536
|
+
self.assertIsNotNone(label)
|
|
537
|
+
self.assertEqual(label.get_text(separator="\n", strip=True), label_text)
|
|
538
|
+
self.assertEqual(
|
|
539
|
+
section.get_text(separator="\n", strip=True),
|
|
540
|
+
f"{label_text}\n{description}",
|
|
541
|
+
)
|
|
542
|
+
|
|
543
|
+
assert_panel_section(
|
|
544
|
+
"status-sidebar-live",
|
|
545
|
+
"Live",
|
|
546
|
+
"To be created by Chrismansyah Rahadi",
|
|
547
|
+
)
|
|
548
|
+
|
|
549
|
+
usage_section = panel.select("section")[-1]
|
|
550
|
+
self.assertIsNotNone(usage_section)
|
|
551
|
+
self.assertEqual(
|
|
552
|
+
usage_section.get_text(separator="\n", strip=True),
|
|
553
|
+
"Usage\nUsed 0 times",
|
|
554
|
+
)
|
|
555
|
+
|
|
556
|
+
|
|
557
|
+
@override_settings(WAGTAIL_I18N_ENABLED=True)
|
|
558
|
+
class TestLocaleSelectorOnCreate(WagtailTestUtils, TestCase):
|
|
559
|
+
fixtures = ["test.json"]
|
|
560
|
+
|
|
561
|
+
def setUp(self):
|
|
562
|
+
self.fr_locale = Locale.objects.create(language_code="fr")
|
|
563
|
+
self.user = self.login()
|
|
564
|
+
|
|
565
|
+
def test_locale_selector(self):
|
|
566
|
+
response = self.client.get(
|
|
567
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
568
|
+
)
|
|
569
|
+
|
|
570
|
+
self.assertContains(response, "Switch locales")
|
|
571
|
+
|
|
572
|
+
switch_to_french_url = (
|
|
573
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
574
|
+
+ "?locale=fr"
|
|
575
|
+
)
|
|
576
|
+
self.assertContains(
|
|
577
|
+
response,
|
|
578
|
+
f'<a href="{switch_to_french_url}" lang="fr">',
|
|
579
|
+
)
|
|
580
|
+
|
|
581
|
+
def test_locale_selector_with_existing_locale(self):
|
|
582
|
+
response = self.client.get(
|
|
583
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
584
|
+
+ "?locale=fr"
|
|
585
|
+
)
|
|
586
|
+
|
|
587
|
+
self.assertContains(response, "Switch locales")
|
|
588
|
+
|
|
589
|
+
switch_to_english_url = (
|
|
590
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
591
|
+
+ "?locale=en"
|
|
592
|
+
)
|
|
593
|
+
self.assertContains(
|
|
594
|
+
response,
|
|
595
|
+
f'<a href="{switch_to_english_url}" lang="en">',
|
|
596
|
+
)
|
|
597
|
+
|
|
598
|
+
@override_settings(WAGTAIL_I18N_ENABLED=False)
|
|
599
|
+
def test_locale_selector_not_present_when_i18n_disabled(self):
|
|
600
|
+
response = self.client.get(
|
|
601
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
602
|
+
)
|
|
603
|
+
|
|
604
|
+
self.assertNotContains(response, "Switch locales")
|
|
605
|
+
|
|
606
|
+
switch_to_french_url = (
|
|
607
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
608
|
+
+ "?locale=fr"
|
|
609
|
+
)
|
|
610
|
+
self.assertNotContains(
|
|
611
|
+
response,
|
|
612
|
+
f'<a href="{switch_to_french_url}" lang="fr">',
|
|
613
|
+
)
|
|
614
|
+
|
|
615
|
+
def test_locale_selector_not_present_on_non_translatable_snippet(self):
|
|
616
|
+
response = self.client.get(reverse("wagtailsnippets_tests_advert:add"))
|
|
617
|
+
|
|
618
|
+
self.assertNotContains(response, "Switch locales")
|
|
619
|
+
|
|
620
|
+
switch_to_french_url = (
|
|
621
|
+
reverse("wagtailsnippets_snippetstests_translatablesnippet:add")
|
|
622
|
+
+ "?locale=fr"
|
|
623
|
+
)
|
|
624
|
+
self.assertNotContains(
|
|
625
|
+
response,
|
|
626
|
+
f'<a href="{switch_to_french_url}" lang="fr">',
|
|
627
|
+
)
|
|
628
|
+
|
|
629
|
+
|
|
630
|
+
class TestCreateDraftStateSnippet(WagtailTestUtils, TestCase):
|
|
631
|
+
STATUS_TOGGLE_BADGE_REGEX = (
|
|
632
|
+
r'data-side-panel-toggle="status"[^<]+<svg[^<]+<use[^<]+</use[^<]+</svg[^<]+'
|
|
633
|
+
r"<div data-side-panel-toggle-counter[^>]+w-bg-critical-200[^>]+>\s*%(num_errors)s\s*</div>"
|
|
634
|
+
)
|
|
635
|
+
|
|
636
|
+
def setUp(self):
|
|
637
|
+
self.user = self.login()
|
|
638
|
+
|
|
639
|
+
def get(self):
|
|
640
|
+
return self.client.get(reverse("wagtailsnippets_tests_draftstatemodel:add"))
|
|
641
|
+
|
|
642
|
+
def post(self, post_data=None):
|
|
643
|
+
return self.client.post(
|
|
644
|
+
reverse("wagtailsnippets_tests_draftstatemodel:add"),
|
|
645
|
+
post_data,
|
|
646
|
+
)
|
|
647
|
+
|
|
648
|
+
def test_get(self):
|
|
649
|
+
add_url = reverse("wagtailsnippets_tests_draftstatemodel:add")
|
|
650
|
+
response = self.get()
|
|
651
|
+
|
|
652
|
+
self.assertEqual(response.status_code, 200)
|
|
653
|
+
self.assertTemplateUsed(response, "wagtailsnippets/snippets/create.html")
|
|
654
|
+
|
|
655
|
+
# The save button should be labelled "Save draft"
|
|
656
|
+
self.assertContains(response, "Save draft")
|
|
657
|
+
# The publish button should exist
|
|
658
|
+
self.assertContains(response, "Publish")
|
|
659
|
+
# The publish button should have name="action-publish"
|
|
660
|
+
self.assertContains(
|
|
661
|
+
response,
|
|
662
|
+
'<button\n type="submit"\n name="action-publish"\n value="action-publish"\n class="button action-save button-longrunning"\n data-controller="w-progress"\n data-action="w-progress#activate"\n',
|
|
663
|
+
)
|
|
664
|
+
# The status side panel should be rendered so that the
|
|
665
|
+
# publishing schedule can be configured
|
|
666
|
+
self.assertContains(
|
|
667
|
+
response,
|
|
668
|
+
'<div class="form-side__panel" data-side-panel="status" hidden>',
|
|
669
|
+
)
|
|
670
|
+
|
|
671
|
+
# The status side panel should show "No publishing schedule set" info
|
|
672
|
+
self.assertContains(response, "No publishing schedule set")
|
|
673
|
+
|
|
674
|
+
# Should show the "Set schedule" button
|
|
675
|
+
html = response.content.decode()
|
|
676
|
+
self.assertTagInHTML(
|
|
677
|
+
'<button type="button" data-a11y-dialog-show="schedule-publishing-dialog">Set schedule</button>',
|
|
678
|
+
html,
|
|
679
|
+
count=1,
|
|
680
|
+
allow_extra_attrs=True,
|
|
681
|
+
)
|
|
682
|
+
# Should show the dialog template pointing to the [data-edit-form] selector as the root
|
|
683
|
+
soup = self.get_soup(html)
|
|
684
|
+
dialog = soup.select_one(
|
|
685
|
+
"""
|
|
686
|
+
template[data-controller="w-teleport"][data-w-teleport-target-value="[data-edit-form]"]
|
|
687
|
+
#schedule-publishing-dialog
|
|
688
|
+
"""
|
|
689
|
+
)
|
|
690
|
+
self.assertIsNotNone(dialog)
|
|
691
|
+
# Should render the main form with data-edit-form attribute
|
|
692
|
+
self.assertTagInHTML(
|
|
693
|
+
f'<form action="{add_url}" method="POST" data-edit-form>',
|
|
694
|
+
html,
|
|
695
|
+
count=1,
|
|
696
|
+
allow_extra_attrs=True,
|
|
697
|
+
)
|
|
698
|
+
self.assertTagInHTML(
|
|
699
|
+
'<div id="schedule-publishing-dialog" class="w-dialog publishing" data-controller="w-dialog">',
|
|
700
|
+
html,
|
|
701
|
+
count=1,
|
|
702
|
+
allow_extra_attrs=True,
|
|
703
|
+
)
|
|
704
|
+
|
|
705
|
+
# Should show the correct subtitle in the dialog
|
|
706
|
+
self.assertContains(
|
|
707
|
+
response, "Choose when this draft state model should go live and/or expire"
|
|
708
|
+
)
|
|
709
|
+
|
|
710
|
+
# Should not show the Unpublish action menu item
|
|
711
|
+
unpublish_url = "/admin/snippets/tests/draftstatemodel/unpublish/"
|
|
712
|
+
self.assertNotContains(response, unpublish_url)
|
|
713
|
+
self.assertNotContains(response, "Unpublish")
|
|
714
|
+
|
|
715
|
+
def test_save_draft(self):
|
|
716
|
+
response = self.post(post_data={"text": "Draft-enabled Foo"})
|
|
717
|
+
snippet = DraftStateModel.objects.get(text="Draft-enabled Foo")
|
|
718
|
+
|
|
719
|
+
self.assertRedirects(
|
|
720
|
+
response,
|
|
721
|
+
reverse("wagtailsnippets_tests_draftstatemodel:edit", args=[snippet.pk]),
|
|
722
|
+
)
|
|
723
|
+
|
|
724
|
+
# The instance should be created
|
|
725
|
+
self.assertEqual(snippet.text, "Draft-enabled Foo")
|
|
726
|
+
|
|
727
|
+
# The instance should be a draft
|
|
728
|
+
self.assertFalse(snippet.live)
|
|
729
|
+
self.assertTrue(snippet.has_unpublished_changes)
|
|
730
|
+
self.assertIsNone(snippet.first_published_at)
|
|
731
|
+
self.assertIsNone(snippet.last_published_at)
|
|
732
|
+
self.assertIsNone(snippet.live_revision)
|
|
733
|
+
|
|
734
|
+
# A revision should be created and set as latest_revision
|
|
735
|
+
self.assertIsNotNone(snippet.latest_revision)
|
|
736
|
+
|
|
737
|
+
# The revision content should contain the data
|
|
738
|
+
self.assertEqual(snippet.latest_revision.content["text"], "Draft-enabled Foo")
|
|
739
|
+
|
|
740
|
+
# A log entry should be created
|
|
741
|
+
log_entry = ModelLogEntry.objects.for_instance(snippet).get(
|
|
742
|
+
action="wagtail.create"
|
|
743
|
+
)
|
|
744
|
+
self.assertEqual(log_entry.revision, snippet.latest_revision)
|
|
745
|
+
self.assertEqual(log_entry.label, "Draft-enabled Foo")
|
|
746
|
+
|
|
747
|
+
def test_create_skips_validation_when_saving_draft(self):
|
|
748
|
+
response = self.post(post_data={"text": ""})
|
|
749
|
+
snippet = DraftStateModel.objects.get(text="")
|
|
750
|
+
|
|
751
|
+
self.assertRedirects(
|
|
752
|
+
response,
|
|
753
|
+
reverse(
|
|
754
|
+
"wagtailsnippets_tests_draftstatemodel:edit", args=[quote(snippet.pk)]
|
|
755
|
+
),
|
|
756
|
+
)
|
|
757
|
+
|
|
758
|
+
self.assertFalse(snippet.live)
|
|
759
|
+
|
|
760
|
+
# A log entry should be created (with a fallback label)
|
|
761
|
+
log_entry = ModelLogEntry.objects.for_instance(snippet).get(
|
|
762
|
+
action="wagtail.create"
|
|
763
|
+
)
|
|
764
|
+
self.assertEqual(log_entry.revision, snippet.latest_revision)
|
|
765
|
+
self.assertEqual(log_entry.label, f"DraftStateModel object ({snippet.pk})")
|
|
766
|
+
|
|
767
|
+
def test_required_asterisk_on_reshowing_form(self):
|
|
768
|
+
"""
|
|
769
|
+
If a form is reshown due to a validation error elsewhere, fields whose validation
|
|
770
|
+
was deferred should still show the required asterisk.
|
|
771
|
+
"""
|
|
772
|
+
response = self.client.post(
|
|
773
|
+
reverse("some_namespace:add"),
|
|
774
|
+
{"text": "", "country_code": "UK", "some_number": "meef"},
|
|
775
|
+
)
|
|
776
|
+
|
|
777
|
+
self.assertEqual(response.status_code, 200)
|
|
778
|
+
|
|
779
|
+
# The empty text should not cause a validation error, but the invalid number should
|
|
780
|
+
self.assertNotContains(response, "This field is required.")
|
|
781
|
+
self.assertContains(response, "Enter a whole number.", count=1)
|
|
782
|
+
|
|
783
|
+
soup = self.get_soup(response.content)
|
|
784
|
+
self.assertTrue(soup.select_one('label[for="id_text"] > span.w-required-mark'))
|
|
785
|
+
|
|
786
|
+
def test_create_will_not_publish_invalid_snippet(self):
|
|
787
|
+
response = self.post(
|
|
788
|
+
post_data={"text": "", "action-publish": "Publish"},
|
|
789
|
+
)
|
|
790
|
+
self.assertEqual(response.status_code, 200)
|
|
791
|
+
self.assertContains(
|
|
792
|
+
response, "The draft state model could not be created due to errors."
|
|
793
|
+
)
|
|
794
|
+
|
|
795
|
+
snippets = DraftStateModel.objects.filter(text="")
|
|
796
|
+
self.assertEqual(snippets.count(), 0)
|
|
797
|
+
|
|
798
|
+
def test_publish(self):
|
|
799
|
+
# Connect a mock signal handler to published signal
|
|
800
|
+
mock_handler = mock.MagicMock()
|
|
801
|
+
published.connect(mock_handler)
|
|
802
|
+
|
|
803
|
+
try:
|
|
804
|
+
timestamp = now()
|
|
805
|
+
with freeze_time(timestamp):
|
|
806
|
+
response = self.post(
|
|
807
|
+
post_data={
|
|
808
|
+
"text": "Draft-enabled Foo, Published",
|
|
809
|
+
"action-publish": "action-publish",
|
|
810
|
+
}
|
|
811
|
+
)
|
|
812
|
+
snippet = DraftStateModel.objects.get(text="Draft-enabled Foo, Published")
|
|
813
|
+
|
|
814
|
+
self.assertRedirects(
|
|
815
|
+
response, reverse("wagtailsnippets_tests_draftstatemodel:list")
|
|
816
|
+
)
|
|
817
|
+
|
|
818
|
+
# The instance should be created
|
|
819
|
+
self.assertEqual(snippet.text, "Draft-enabled Foo, Published")
|
|
820
|
+
|
|
821
|
+
# The instance should be live
|
|
822
|
+
self.assertTrue(snippet.live)
|
|
823
|
+
self.assertFalse(snippet.has_unpublished_changes)
|
|
824
|
+
self.assertEqual(snippet.first_published_at, timestamp)
|
|
825
|
+
self.assertEqual(snippet.last_published_at, timestamp)
|
|
826
|
+
|
|
827
|
+
# A revision should be created and set as both latest_revision and live_revision
|
|
828
|
+
self.assertIsNotNone(snippet.live_revision)
|
|
829
|
+
self.assertEqual(snippet.live_revision, snippet.latest_revision)
|
|
830
|
+
|
|
831
|
+
# The revision content should contain the new data
|
|
832
|
+
self.assertEqual(
|
|
833
|
+
snippet.live_revision.content["text"],
|
|
834
|
+
"Draft-enabled Foo, Published",
|
|
835
|
+
)
|
|
836
|
+
|
|
837
|
+
# Check that the published signal was fired
|
|
838
|
+
self.assertEqual(mock_handler.call_count, 1)
|
|
839
|
+
mock_call = mock_handler.mock_calls[0][2]
|
|
840
|
+
|
|
841
|
+
self.assertEqual(mock_call["sender"], DraftStateModel)
|
|
842
|
+
self.assertEqual(mock_call["instance"], snippet)
|
|
843
|
+
self.assertIsInstance(mock_call["instance"], DraftStateModel)
|
|
844
|
+
finally:
|
|
845
|
+
published.disconnect(mock_handler)
|
|
846
|
+
|
|
847
|
+
def test_publish_bad_permissions(self):
|
|
848
|
+
# Only add create and edit permission
|
|
849
|
+
self.user.is_superuser = False
|
|
850
|
+
add_permission = Permission.objects.get(
|
|
851
|
+
content_type__app_label="tests",
|
|
852
|
+
codename="add_draftstatemodel",
|
|
853
|
+
)
|
|
854
|
+
edit_permission = Permission.objects.get(
|
|
855
|
+
content_type__app_label="tests",
|
|
856
|
+
codename="change_draftstatemodel",
|
|
857
|
+
)
|
|
858
|
+
admin_permission = Permission.objects.get(
|
|
859
|
+
content_type__app_label="wagtailadmin",
|
|
860
|
+
codename="access_admin",
|
|
861
|
+
)
|
|
862
|
+
self.user.user_permissions.add(
|
|
863
|
+
add_permission,
|
|
864
|
+
edit_permission,
|
|
865
|
+
admin_permission,
|
|
866
|
+
)
|
|
867
|
+
self.user.save()
|
|
868
|
+
|
|
869
|
+
# Connect a mock signal handler to published signal
|
|
870
|
+
mock_handler = mock.MagicMock()
|
|
871
|
+
published.connect(mock_handler)
|
|
872
|
+
|
|
873
|
+
try:
|
|
874
|
+
response = self.post(
|
|
875
|
+
post_data={
|
|
876
|
+
"text": "Draft-enabled Foo",
|
|
877
|
+
"action-publish": "action-publish",
|
|
878
|
+
}
|
|
879
|
+
)
|
|
880
|
+
snippet = DraftStateModel.objects.get(text="Draft-enabled Foo")
|
|
881
|
+
|
|
882
|
+
# Should be taken to the edit page
|
|
883
|
+
self.assertRedirects(
|
|
884
|
+
response,
|
|
885
|
+
reverse(
|
|
886
|
+
"wagtailsnippets_tests_draftstatemodel:edit",
|
|
887
|
+
args=[snippet.pk],
|
|
888
|
+
),
|
|
889
|
+
)
|
|
890
|
+
|
|
891
|
+
# The instance should still be created
|
|
892
|
+
self.assertEqual(snippet.text, "Draft-enabled Foo")
|
|
893
|
+
|
|
894
|
+
# The instance should not be live
|
|
895
|
+
self.assertFalse(snippet.live)
|
|
896
|
+
self.assertTrue(snippet.has_unpublished_changes)
|
|
897
|
+
|
|
898
|
+
# A revision should be created and set as latest_revision, but not live_revision
|
|
899
|
+
self.assertIsNotNone(snippet.latest_revision)
|
|
900
|
+
self.assertIsNone(snippet.live_revision)
|
|
901
|
+
|
|
902
|
+
# The revision content should contain the data
|
|
903
|
+
self.assertEqual(
|
|
904
|
+
snippet.latest_revision.content["text"],
|
|
905
|
+
"Draft-enabled Foo",
|
|
906
|
+
)
|
|
907
|
+
|
|
908
|
+
# Check that the published signal was not fired
|
|
909
|
+
self.assertEqual(mock_handler.call_count, 0)
|
|
910
|
+
finally:
|
|
911
|
+
published.disconnect(mock_handler)
|
|
912
|
+
|
|
913
|
+
def test_publish_with_publish_permission(self):
|
|
914
|
+
# Use create and publish permissions instead of relying on superuser flag
|
|
915
|
+
self.user.is_superuser = False
|
|
916
|
+
add_permission = Permission.objects.get(
|
|
917
|
+
content_type__app_label="tests",
|
|
918
|
+
codename="add_draftstatemodel",
|
|
919
|
+
)
|
|
920
|
+
publish_permission = Permission.objects.get(
|
|
921
|
+
content_type__app_label="tests",
|
|
922
|
+
codename="publish_draftstatemodel",
|
|
923
|
+
)
|
|
924
|
+
admin_permission = Permission.objects.get(
|
|
925
|
+
content_type__app_label="wagtailadmin",
|
|
926
|
+
codename="access_admin",
|
|
927
|
+
)
|
|
928
|
+
self.user.user_permissions.add(
|
|
929
|
+
add_permission,
|
|
930
|
+
publish_permission,
|
|
931
|
+
admin_permission,
|
|
932
|
+
)
|
|
933
|
+
self.user.save()
|
|
934
|
+
|
|
935
|
+
# Connect a mock signal handler to published signal
|
|
936
|
+
mock_handler = mock.MagicMock()
|
|
937
|
+
published.connect(mock_handler)
|
|
938
|
+
|
|
939
|
+
try:
|
|
940
|
+
timestamp = now()
|
|
941
|
+
with freeze_time(timestamp):
|
|
942
|
+
response = self.post(
|
|
943
|
+
post_data={
|
|
944
|
+
"text": "Draft-enabled Foo, Published",
|
|
945
|
+
"action-publish": "action-publish",
|
|
946
|
+
}
|
|
947
|
+
)
|
|
948
|
+
snippet = DraftStateModel.objects.get(text="Draft-enabled Foo, Published")
|
|
949
|
+
|
|
950
|
+
self.assertRedirects(
|
|
951
|
+
response, reverse("wagtailsnippets_tests_draftstatemodel:list")
|
|
952
|
+
)
|
|
953
|
+
|
|
954
|
+
# The instance should be created
|
|
955
|
+
self.assertEqual(snippet.text, "Draft-enabled Foo, Published")
|
|
956
|
+
|
|
957
|
+
# The instance should be live
|
|
958
|
+
self.assertTrue(snippet.live)
|
|
959
|
+
self.assertFalse(snippet.has_unpublished_changes)
|
|
960
|
+
self.assertEqual(snippet.first_published_at, timestamp)
|
|
961
|
+
self.assertEqual(snippet.last_published_at, timestamp)
|
|
962
|
+
|
|
963
|
+
# A revision should be created and set as both latest_revision and live_revision
|
|
964
|
+
self.assertIsNotNone(snippet.live_revision)
|
|
965
|
+
self.assertEqual(snippet.live_revision, snippet.latest_revision)
|
|
966
|
+
|
|
967
|
+
# The revision content should contain the new data
|
|
968
|
+
self.assertEqual(
|
|
969
|
+
snippet.live_revision.content["text"],
|
|
970
|
+
"Draft-enabled Foo, Published",
|
|
971
|
+
)
|
|
972
|
+
|
|
973
|
+
# Check that the published signal was fired
|
|
974
|
+
self.assertEqual(mock_handler.call_count, 1)
|
|
975
|
+
mock_call = mock_handler.mock_calls[0][2]
|
|
976
|
+
|
|
977
|
+
self.assertEqual(mock_call["sender"], DraftStateModel)
|
|
978
|
+
self.assertEqual(mock_call["instance"], snippet)
|
|
979
|
+
self.assertIsInstance(mock_call["instance"], DraftStateModel)
|
|
980
|
+
finally:
|
|
981
|
+
published.disconnect(mock_handler)
|
|
982
|
+
|
|
983
|
+
def test_create_scheduled(self):
|
|
984
|
+
go_live_at = now() + datetime.timedelta(days=1)
|
|
985
|
+
expire_at = now() + datetime.timedelta(days=2)
|
|
986
|
+
response = self.post(
|
|
987
|
+
post_data={
|
|
988
|
+
"text": "Some content",
|
|
989
|
+
"go_live_at": submittable_timestamp(go_live_at),
|
|
990
|
+
"expire_at": submittable_timestamp(expire_at),
|
|
991
|
+
}
|
|
992
|
+
)
|
|
993
|
+
|
|
994
|
+
snippet = DraftStateModel.objects.get(text="Some content")
|
|
995
|
+
|
|
996
|
+
# Should be redirected to the edit page
|
|
997
|
+
self.assertRedirects(
|
|
998
|
+
response,
|
|
999
|
+
reverse("wagtailsnippets_tests_draftstatemodel:edit", args=[snippet.pk]),
|
|
1000
|
+
)
|
|
1001
|
+
|
|
1002
|
+
# Should be saved as draft with the scheduled publishing dates
|
|
1003
|
+
self.assertEqual(snippet.go_live_at.date(), go_live_at.date())
|
|
1004
|
+
self.assertEqual(snippet.expire_at.date(), expire_at.date())
|
|
1005
|
+
self.assertIs(snippet.expired, False)
|
|
1006
|
+
self.assertEqual(snippet.status_string, "draft")
|
|
1007
|
+
|
|
1008
|
+
# No revisions with approved_go_live_at
|
|
1009
|
+
self.assertFalse(
|
|
1010
|
+
Revision.objects.for_instance(snippet)
|
|
1011
|
+
.exclude(approved_go_live_at__isnull=True)
|
|
1012
|
+
.exists()
|
|
1013
|
+
)
|
|
1014
|
+
|
|
1015
|
+
def test_create_scheduled_go_live_before_expiry(self):
|
|
1016
|
+
response = self.post(
|
|
1017
|
+
post_data={
|
|
1018
|
+
"text": "Some content",
|
|
1019
|
+
"go_live_at": submittable_timestamp(now() + datetime.timedelta(days=2)),
|
|
1020
|
+
"expire_at": submittable_timestamp(now() + datetime.timedelta(days=1)),
|
|
1021
|
+
}
|
|
1022
|
+
)
|
|
1023
|
+
|
|
1024
|
+
self.assertEqual(response.status_code, 200)
|
|
1025
|
+
|
|
1026
|
+
# Check that a form error was raised
|
|
1027
|
+
self.assertFormError(
|
|
1028
|
+
response.context["form"],
|
|
1029
|
+
"go_live_at",
|
|
1030
|
+
"Go live date/time must be before expiry date/time",
|
|
1031
|
+
)
|
|
1032
|
+
self.assertFormError(
|
|
1033
|
+
response.context["form"],
|
|
1034
|
+
"expire_at",
|
|
1035
|
+
"Go live date/time must be before expiry date/time",
|
|
1036
|
+
)
|
|
1037
|
+
|
|
1038
|
+
self.assertContains(
|
|
1039
|
+
response,
|
|
1040
|
+
'<div class="w-label-3 w-text-primary">Invalid schedule</div>',
|
|
1041
|
+
html=True,
|
|
1042
|
+
)
|
|
1043
|
+
|
|
1044
|
+
num_errors = 2
|
|
1045
|
+
|
|
1046
|
+
# Should show the correct number on the badge of the toggle button
|
|
1047
|
+
self.assertRegex(
|
|
1048
|
+
response.content.decode(),
|
|
1049
|
+
self.STATUS_TOGGLE_BADGE_REGEX % {"num_errors": num_errors},
|
|
1050
|
+
)
|
|
1051
|
+
|
|
1052
|
+
def test_create_scheduled_expire_in_the_past(self):
|
|
1053
|
+
response = self.post(
|
|
1054
|
+
post_data={
|
|
1055
|
+
"text": "Some content",
|
|
1056
|
+
"expire_at": submittable_timestamp(now() + datetime.timedelta(days=-1)),
|
|
1057
|
+
}
|
|
1058
|
+
)
|
|
1059
|
+
|
|
1060
|
+
self.assertEqual(response.status_code, 200)
|
|
1061
|
+
|
|
1062
|
+
# Check that a form error was raised
|
|
1063
|
+
self.assertFormError(
|
|
1064
|
+
response.context["form"],
|
|
1065
|
+
"expire_at",
|
|
1066
|
+
"Expiry date/time must be in the future.",
|
|
1067
|
+
)
|
|
1068
|
+
|
|
1069
|
+
self.assertContains(
|
|
1070
|
+
response,
|
|
1071
|
+
'<div class="w-label-3 w-text-primary">Invalid schedule</div>',
|
|
1072
|
+
html=True,
|
|
1073
|
+
)
|
|
1074
|
+
|
|
1075
|
+
num_errors = 1
|
|
1076
|
+
|
|
1077
|
+
# Should show the correct number on the badge of the toggle button
|
|
1078
|
+
self.assertRegex(
|
|
1079
|
+
response.content.decode(),
|
|
1080
|
+
self.STATUS_TOGGLE_BADGE_REGEX % {"num_errors": num_errors},
|
|
1081
|
+
)
|
|
1082
|
+
|
|
1083
|
+
def test_create_post_publish_scheduled(self):
|
|
1084
|
+
go_live_at = now() + datetime.timedelta(days=1)
|
|
1085
|
+
expire_at = now() + datetime.timedelta(days=2)
|
|
1086
|
+
response = self.post(
|
|
1087
|
+
post_data={
|
|
1088
|
+
"text": "Some content",
|
|
1089
|
+
"action-publish": "Publish",
|
|
1090
|
+
"go_live_at": submittable_timestamp(go_live_at),
|
|
1091
|
+
"expire_at": submittable_timestamp(expire_at),
|
|
1092
|
+
}
|
|
1093
|
+
)
|
|
1094
|
+
|
|
1095
|
+
# Should be redirected to the listing page
|
|
1096
|
+
self.assertRedirects(
|
|
1097
|
+
response, reverse("wagtailsnippets_tests_draftstatemodel:list")
|
|
1098
|
+
)
|
|
1099
|
+
|
|
1100
|
+
# Find the object and check it
|
|
1101
|
+
snippet = DraftStateModel.objects.get(text="Some content")
|
|
1102
|
+
self.assertEqual(snippet.go_live_at.date(), go_live_at.date())
|
|
1103
|
+
self.assertEqual(snippet.expire_at.date(), expire_at.date())
|
|
1104
|
+
self.assertIs(snippet.expired, False)
|
|
1105
|
+
|
|
1106
|
+
# A revision with approved_go_live_at should exist now
|
|
1107
|
+
self.assertTrue(
|
|
1108
|
+
Revision.objects.for_instance(snippet)
|
|
1109
|
+
.exclude(approved_go_live_at__isnull=True)
|
|
1110
|
+
.exists()
|
|
1111
|
+
)
|
|
1112
|
+
# But snippet won't be live
|
|
1113
|
+
self.assertFalse(snippet.live)
|
|
1114
|
+
self.assertFalse(snippet.first_published_at)
|
|
1115
|
+
self.assertEqual(snippet.status_string, "scheduled")
|
|
1116
|
+
|
|
1117
|
+
def test_create_shows_status_side_panel_skeleton(self):
|
|
1118
|
+
self.user.first_name = "Chrismansyah"
|
|
1119
|
+
self.user.last_name = "Rahadi"
|
|
1120
|
+
self.user.save()
|
|
1121
|
+
response = self.get()
|
|
1122
|
+
soup = self.get_soup(response.content)
|
|
1123
|
+
panel = soup.select_one('[data-side-panel="status"]')
|
|
1124
|
+
self.assertIsNotNone(panel)
|
|
1125
|
+
|
|
1126
|
+
def assert_panel_section(label_id, label_text, description):
|
|
1127
|
+
section = panel.select_one(f'[aria-labelledby="{label_id}"]')
|
|
1128
|
+
self.assertIsNotNone(section)
|
|
1129
|
+
label = section.select_one(f"#{label_id}")
|
|
1130
|
+
self.assertIsNotNone(label)
|
|
1131
|
+
self.assertEqual(label.get_text(separator="\n", strip=True), label_text)
|
|
1132
|
+
self.assertEqual(
|
|
1133
|
+
section.get_text(separator="\n", strip=True),
|
|
1134
|
+
f"{label_text}\n{description}",
|
|
1135
|
+
)
|
|
1136
|
+
|
|
1137
|
+
assert_panel_section(
|
|
1138
|
+
"status-sidebar-draft",
|
|
1139
|
+
"Draft",
|
|
1140
|
+
"To be created by Chrismansyah Rahadi",
|
|
1141
|
+
)
|
|
1142
|
+
|
|
1143
|
+
usage_section = panel.select("section")[-1]
|
|
1144
|
+
self.assertIsNotNone(usage_section)
|
|
1145
|
+
self.assertEqual(
|
|
1146
|
+
usage_section.get_text(separator="\n", strip=True),
|
|
1147
|
+
"Usage\nUsed 0 times",
|
|
1148
|
+
)
|
|
1149
|
+
|
|
1150
|
+
|
|
1151
|
+
class TestInlinePanelMedia(WagtailTestUtils, TestCase):
|
|
1152
|
+
"""
|
|
1153
|
+
Test that form media required by InlinePanels is correctly pulled in to the edit page
|
|
1154
|
+
"""
|
|
1155
|
+
|
|
1156
|
+
def test_inline_panel_media(self):
|
|
1157
|
+
self.login()
|
|
1158
|
+
|
|
1159
|
+
response = self.client.get(
|
|
1160
|
+
reverse("wagtailsnippets_snippetstests_multisectionrichtextsnippet:add")
|
|
1161
|
+
)
|
|
1162
|
+
self.assertEqual(response.status_code, 200)
|
|
1163
|
+
self.assertContains(response, "wagtailadmin/js/draftail.js")
|