X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/fb08d6c6a6dca486303ca69b5c47dd29e548fd11..86530a9e72f32d28ef1971ac9fa705c85b1bd3b6:/src/catalogue/urls.py diff --git a/src/catalogue/urls.py b/src/catalogue/urls.py index fb6a7b465..91c66a2fe 100644 --- a/src/catalogue/urls.py +++ b/src/catalogue/urls.py @@ -1,105 +1,71 @@ -# -*- coding: utf-8 -*- -# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. -# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. +# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Wolne Lektury. See NOTICE for more information. # -from django.conf.urls import patterns, url +from django.urls import path, re_path from django.db.models import Max from django.views.generic import ListView, RedirectView from catalogue.feeds import AudiobookFeed -from catalogue.views import CustomPDFFormView from catalogue.models import Book +from catalogue import views +import search.views -SLUG = r'[a-z0-9-]*' - -urlpatterns = patterns( - 'picture.views', - - url(r'^obraz/strona/$', 'picture_page', name='picture_page'), - # pictures - currently pictures are coupled with catalogue, hence the url is here - url(r'^obraz/$', 'picture_list_thumb', name='picture_list_thumb'), - url(r'^obraz/(?P%s).html$' % SLUG, 'picture_viewer', name='picture_viewer'), - url(r'^obraz/(?P%s)/$' % SLUG, 'picture_detail'), - - url(r'^p/(?P\d+)/mini\.(?P.+)\.html', 'picture_mini', name='picture_mini'), - url(r'^p/(?P\d+)/short\.(?P.+)\.html', 'picture_short', name='picture_short'), - url(r'^pa/(?P\d+)/short\.(?P.+)\.html', 'picturearea_short', name='picture_area_short'), -) - -urlpatterns += patterns( - '', +urlpatterns = [ # old search page - redirected - url(r'^szukaj/$', RedirectView.as_view( - url='/szukaj/', query_string=True, permanent=True)), -) - -urlpatterns += patterns( - 'catalogue.views', - url(r'^$', 'catalogue', name='catalogue'), - - url(r'^autor/$', 'tag_catalogue', {'category': 'author'}, name='author_catalogue'), - url(r'^epoka/$', 'tag_catalogue', {'category': 'epoch'}, name='epoch_catalogue'), - url(r'^gatunek/$', 'tag_catalogue', {'category': 'genre'}, name='genre_catalogue'), - url(r'^rodzaj/$', 'tag_catalogue', {'category': 'kind'}, name='kind_catalogue'), - url(r'^motyw/$', 'tag_catalogue', {'category': 'theme'}, name='theme_catalogue'), - - url(r'^galeria/$', 'gallery', name='gallery'), - url(r'^kolekcje/$', 'collections', name='catalogue_collections'), - - url(r'^lektury/$', 'literature', name='book_list'), - url(r'^lektury/(?P[a-zA-Z0-9-]+)/$', 'collection', name='collection'), - url(r'^audiobooki/$', 'audiobooks', name='audiobook_list'), - url(r'^daisy/$', 'daisy_list', name='daisy_list'), - url(r'^tags/$', 'tags_starting_with', name='hint'), - url(r'^jtags/?$', 'json_tags_starting_with', name='jhint'), - url(r'^nowe/$', ListView.as_view( - queryset=Book.objects.filter(parent=None).order_by('-created_at'), + path('szukaj/', RedirectView.as_view( + url='/szukaj/', query_string=True, permanent=True)), + + path('', views.catalogue, name='catalogue'), + + path('autor/', views.tag_catalogue, {'category': 'author'}, name='author_catalogue'), + path('epoka/', views.tag_catalogue, {'category': 'epoch'}, name='epoch_catalogue'), + path('gatunek/', views.tag_catalogue, {'category': 'genre'}, name='genre_catalogue'), + path('rodzaj/', views.tag_catalogue, {'category': 'kind'}, name='kind_catalogue'), + path('motyw/', views.tag_catalogue, {'category': 'theme'}, name='theme_catalogue'), + + path('kolekcje/', views.collections, name='catalogue_collections'), + + path('lektury/', views.LiteratureView.as_view(), name='book_list'), + path('lektury//', views.collection, name='collection'), + path('audiobooki/', views.AudiobooksView.as_view(), name='audiobook_list'), + path('daisy/', views.daisy_list, name='daisy_list'), + path('jtags/', search.views.hint, {'param': 'q', 'mozhint': True}, name='jhint'), + path('nowe/', ListView.as_view( + queryset=Book.objects.filter(parent=None, findable=True).order_by('-created_at')[:100], template_name='catalogue/recent_list.html'), name='recent_list'), - url(r'^nowe/audiobooki/$', ListView.as_view( - queryset=Book.objects.filter(media__type='ogg').annotate(m=Max('media__uploaded_at')).order_by('-m'), + path('nowe/audiobooki/', ListView.as_view( + queryset=Book.objects.filter(media__type='ogg').annotate(m=Max('media__uploaded_at')).order_by('-m')[:100], template_name='catalogue/recent_audiobooks_list.html'), name='recent_audiobooks_list'), - url(r'^nowe/daisy/$', ListView.as_view( - queryset=Book.objects.filter(media__type='daisy').annotate(m=Max('media__uploaded_at')).order_by('-m'), + path('nowe/daisy/', ListView.as_view( + queryset=Book.objects.filter(media__type='daisy').annotate(m=Max('media__uploaded_at')).order_by('-m')[:100], template_name='catalogue/recent_daisy_list.html'), name='recent_daisy_list'), - url(r'^custompdf/(?P%s)/$' % SLUG, CustomPDFFormView(), name='custom_pdf_form'), + path('custompdf//', views.CustomPDFFormView(), name='custom_pdf_form'), - url(r'^audiobooki/(?Pmp3|ogg|daisy|all).xml$', AudiobookFeed(), name='audiobook_feed'), + re_path(r'^audiobooki/(?Pmp3|ogg|daisy|all).xml$', AudiobookFeed(), name='audiobook_feed'), + path('pobierz//.', views.embargo_link, name='embargo_link'), # zip - url(r'^zip/pdf\.zip$', 'download_zip', {'format': 'pdf', 'slug': None}, 'download_zip_pdf'), - url(r'^zip/epub\.zip$', 'download_zip', {'format': 'epub', 'slug': None}, 'download_zip_epub'), - url(r'^zip/mobi\.zip$', 'download_zip', {'format': 'mobi', 'slug': None}, 'download_zip_mobi'), - url(r'^zip/mp3/(?P%s)\.zip' % SLUG, 'download_zip', {'format': 'mp3'}, 'download_zip_mp3'), - url(r'^zip/ogg/(?P%s)\.zip' % SLUG, 'download_zip', {'format': 'ogg'}, 'download_zip_ogg'), + path('zip/pdf.zip', views.download_zip, {'file_format': 'pdf', 'slug': None}, 'download_zip_pdf'), + path('zip/epub.zip', views.download_zip, {'file_format': 'epub', 'slug': None}, 'download_zip_epub'), + path('zip/mobi.zip', views.download_zip, {'file_format': 'mobi', 'slug': None}, 'download_zip_mobi'), + path('zip/mp3/.zip', views.download_zip, {'media_format': 'mp3'}, 'download_zip_mp3'), + path('zip/ogg/.zip', views.download_zip, {'media_format': 'ogg'}, 'download_zip_ogg'), # Public interface. Do not change this URLs. - url(r'^lektura/(?P%s)\.html$' % SLUG, 'book_text', name='book_text'), - url(r'^lektura/(?P%s)/audiobook/$' % SLUG, 'player', name='book_player'), - url(r'^lektura/(?P%s)/$' % SLUG, 'book_detail', name='book_detail'), - url(r'^lektura/(?P%s)/motyw/(?P[a-zA-Z0-9-]+)/$' % SLUG, - 'book_fragments', name='book_fragments'), + path('lektura/.html', views.book_text, name='book_text'), + path('lektura//', views.book_detail, name='book_detail'), + path('lektura//motyw//', + views.book_fragments, name='book_fragments'), - url(r'^okladka-ridero/(?P%s).png$' % SLUG, 'ridero_cover'), - url(r'^isbn/(?P(pdf|epub|mobi|txt|html))/(?P%s)/' % SLUG, 'get_isbn'), - - # Includes. - url(r'^b/(?P\d+)/mini\.(?P.+)\.html', 'book_mini', name='catalogue_book_mini'), - url(r'^b/(?P\d+)/mini_nolink\.(?P.+)\.html', 'book_mini', {'with_link': False}, - name='catalogue_book_mini_nolink'), - url(r'^b/(?P\d+)/short\.(?P.+)\.html', 'book_short', name='catalogue_book_short'), - url(r'^b/(?P\d+)/wide\.(?P.+)\.html', 'book_wide', name='catalogue_book_wide'), - url(r'^f/(?P\d+)/promo\.(?P.+)\.html', 'fragment_promo', name='catalogue_fragment_promo'), - url(r'^f/(?P\d+)/short\.(?P.+)\.html', 'fragment_short', name='catalogue_fragment_short'), - url(r'^t/(?P\d+)/box\.(?P.+)\.html', 'tag_box', name='catalogue_tag_box'), - url(r'^c/(?P.+)/box\.(?P.+)\.html', 'collection_box', name='catalogue_collection_box'), + path('okladka-ridero/.png', views.ridero_cover), + path('isbn///', views.get_isbn), # This should be the last pattern. - url(r'^galeria/(?P[a-zA-Z0-9-/]*)/$', 'tagged_object_list', {'list_type': 'gallery'}, - name='tagged_object_list_gallery'), - url(r'^audiobooki/(?P[a-zA-Z0-9-/]*)/$', 'tagged_object_list', {'list_type': 'audiobooks'}, + re_path(r'^audiobooki/(?P[a-zA-Z0-9-/]*)/$', views.tagged_object_list, {'list_type': 'audiobooks'}, name='tagged_object_list_audiobooks'), - url(r'^(?P[a-zA-Z0-9-/]*)/$', 'tagged_object_list', {'list_type': 'books'}, + re_path(r'^(?P[a-zA-Z0-9-/]*)/$', views.tagged_object_list, {'list_type': 'books'}, name='tagged_object_list'), -) + +]