diff --git a/bookwyrm/templates/book/book.html b/bookwyrm/templates/book/book.html
index aef8fba1..95cf86ad 100644
--- a/bookwyrm/templates/book/book.html
+++ b/bookwyrm/templates/book/book.html
@@ -76,24 +76,7 @@
{% endif %}
-
- {% if book.physical_format and not book.pages %}
- {{ book.physical_format | title }}
- {% elif book.physical_format and book.pages %}
- {% blocktrans with format=book.physical_format|title pages=book.pages %}{{ format }}, {{ pages }} pages{% endblocktrans %}
- {% elif book.pages %}
- {% blocktrans with pages=book.pages %}{{ pages }} pages{% endblocktrans %}
- {% endif %}
-
-
- {% if book.published_date and book.publishers %}
- {% blocktrans with date=book.published_date|date:'M jS Y' publisher=book.publishers|join:', ' %}Published {{ date }} by {{ publisher }}.{% endblocktrans %}
- {% elif book.published_date %}
- {% blocktrans with date=book.published_date|date:'M jS Y' %}Published {{ date }}{% endblocktrans %}
- {% elif book.publishers %}
- {% blocktrans with publisher=book.publishers|join:', ' %}Published by {{ publisher }}.{% endblocktrans %}
- {% endif %}
-
+ {% include 'book/publisher_info.html' with book=book %}
{% if book.openlibrary_key %}
{% trans "View on OpenLibrary" %}
diff --git a/bookwyrm/templates/book/edition_filters.html b/bookwyrm/templates/book/edition_filters.html
new file mode 100644
index 00000000..a55b72af
--- /dev/null
+++ b/bookwyrm/templates/book/edition_filters.html
@@ -0,0 +1,6 @@
+{% extends 'snippets/filters_panel/filters_panel.html' %}
+
+{% block filter_fields %}
+{% include 'book/language_filter.html' %}
+{% include 'book/format_filter.html' %}
+{% endblock %}
diff --git a/bookwyrm/templates/book/editions.html b/bookwyrm/templates/book/editions.html
new file mode 100644
index 00000000..7290cce9
--- /dev/null
+++ b/bookwyrm/templates/book/editions.html
@@ -0,0 +1,36 @@
+{% extends 'layout.html' %}
+{% load i18n %}
+{% load bookwyrm_tags %}
+
+{% block title %}{% blocktrans with book_title=work.title %}Editions of {{ book_title }}{% endblocktrans %}{% endblock %}
+
+{% block content %}
+
+
{% blocktrans with work_path=work.local_path work_title=work.title %}Editions of "{{ work_title }}" {% endblocktrans %}
+
+
+{% include 'book/edition_filters.html' %}
+
+
+ {% for book in editions %}
+
+
+
+
+ {% include 'book/publisher_info.html' with book=book %}
+
+
+ {% include 'snippets/shelve_button/shelve_button.html' with book=book switch_mode=True %}
+
+
+ {% endfor %}
+
+{% endblock %}
diff --git a/bookwyrm/templates/book/format_filter.html b/bookwyrm/templates/book/format_filter.html
new file mode 100644
index 00000000..c722b24f
--- /dev/null
+++ b/bookwyrm/templates/book/format_filter.html
@@ -0,0 +1,16 @@
+{% extends 'snippets/filters_panel/filter_field.html' %}
+{% load i18n %}
+
+{% block filter %}
+{% trans "Format:" %}
+
+
+ {% trans "Any" %}
+ {% for format in formats %}{% if format %}
+
+ {{ format|title }}
+
+ {% endif %}{% endfor %}
+
+
+{% endblock %}
diff --git a/bookwyrm/templates/book/language_filter.html b/bookwyrm/templates/book/language_filter.html
new file mode 100644
index 00000000..d9051fd8
--- /dev/null
+++ b/bookwyrm/templates/book/language_filter.html
@@ -0,0 +1,16 @@
+{% extends 'snippets/filters_panel/filter_field.html' %}
+{% load i18n %}
+
+{% block filter %}
+{% trans "Language:" %}
+
+
+ {% trans "Any" %}
+ {% for language in languages %}
+
+ {{ language }}
+
+ {% endfor %}
+
+
+{% endblock %}
diff --git a/bookwyrm/templates/book/publisher_info.html b/bookwyrm/templates/book/publisher_info.html
new file mode 100644
index 00000000..0ab35401
--- /dev/null
+++ b/bookwyrm/templates/book/publisher_info.html
@@ -0,0 +1,24 @@
+{% load i18n %}
+
+ {% if book.physical_format and not book.pages %}
+ {{ book.physical_format | title }}
+ {% elif book.physical_format and book.pages %}
+ {% blocktrans with format=book.physical_format|title pages=book.pages %}{{ format }}, {{ pages }} pages{% endblocktrans %}
+ {% elif book.pages %}
+ {% blocktrans with pages=book.pages %}{{ pages }} pages{% endblocktrans %}
+ {% endif %}
+
+{% if book.languages %}
+
+ {% blocktrans with languages=book.languages|join:", " %}{{ languages }} language{% endblocktrans %}
+
+{% endif %}
+
+ {% if book.published_date and book.publishers %}
+ {% blocktrans with date=book.published_date|date:'M jS Y' publisher=book.publishers|join:', ' %}Published {{ date }} by {{ publisher }}.{% endblocktrans %}
+ {% elif book.published_date %}
+ {% blocktrans with date=book.published_date|date:'M jS Y' %}Published {{ date }}{% endblocktrans %}
+ {% elif book.publishers %}
+ {% blocktrans with publisher=book.publishers|join:', ' %}Published by {{ publisher }}.{% endblocktrans %}
+ {% endif %}
+
diff --git a/bookwyrm/templates/directory/community_filter.html b/bookwyrm/templates/directory/community_filter.html
new file mode 100644
index 00000000..bd0ba778
--- /dev/null
+++ b/bookwyrm/templates/directory/community_filter.html
@@ -0,0 +1,14 @@
+{% extends 'snippets/filters_panel/filter_field.html' %}
+{% load i18n %}
+
+{% block filter %}
+{% trans "Community" %}
+
+
+ {% trans "Local users" %}
+
+
+
+ {% trans "Federated community" %}
+
+{% endblock %}
diff --git a/bookwyrm/templates/directory.html b/bookwyrm/templates/directory/directory.html
similarity index 56%
rename from bookwyrm/templates/directory.html
rename to bookwyrm/templates/directory/directory.html
index 3d47e26b..7413f67d 100644
--- a/bookwyrm/templates/directory.html
+++ b/bookwyrm/templates/directory/directory.html
@@ -36,64 +36,7 @@
{% endif %}
-
-
- Filters
-
-
- {% trans "Show filters" as text %}
- {% include 'snippets/toggle/open_button.html' with text=text controls_text="filters" icon="arrow-down" class="is-small" focus="filters" %}
- {% trans "Hide filters" as text %}
- {% include 'snippets/toggle/close_button.html' with text=text controls_text="filters" icon="x" class="is-small" %}
-
-
-
-
- {% if request.GET %}
-
{% trans "Clear filters" %}
- {% endif %}
-
+{% include 'directory/filters.html' %}
{% for user in users %}
diff --git a/bookwyrm/templates/directory/filters.html b/bookwyrm/templates/directory/filters.html
new file mode 100644
index 00000000..c6bbe157
--- /dev/null
+++ b/bookwyrm/templates/directory/filters.html
@@ -0,0 +1,7 @@
+{% extends 'snippets/filters_panel/filters_panel.html' %}
+
+{% block filter_fields %}
+{% include 'directory/user_type_filter.html' %}
+{% include 'directory/community_filter.html' %}
+{% include 'directory/sort_filter.html' %}
+{% endblock %}
diff --git a/bookwyrm/templates/directory/sort_filter.html b/bookwyrm/templates/directory/sort_filter.html
new file mode 100644
index 00000000..82b561fb
--- /dev/null
+++ b/bookwyrm/templates/directory/sort_filter.html
@@ -0,0 +1,12 @@
+{% extends 'snippets/filters_panel/filter_field.html' %}
+{% load i18n %}
+
+{% block filter %}
+
{% trans "Order by" %}
+
+
+ {% trans "Suggested" %}
+ {% trans "Recently active" %}
+
+
+{% endblock %}
diff --git a/bookwyrm/templates/directory/user_type_filter.html b/bookwyrm/templates/directory/user_type_filter.html
new file mode 100644
index 00000000..b5961c82
--- /dev/null
+++ b/bookwyrm/templates/directory/user_type_filter.html
@@ -0,0 +1,14 @@
+{% extends 'snippets/filters_panel/filter_field.html' %}
+{% load i18n %}
+
+{% block filter %}
+
{% trans "User type" %}
+
+
+ {% trans "BookWyrm users" %}
+
+
+
+ {% trans "All known users" %}
+
+{% endblock %}
diff --git a/bookwyrm/templates/editions.html b/bookwyrm/templates/editions.html
deleted file mode 100644
index f8319757..00000000
--- a/bookwyrm/templates/editions.html
+++ /dev/null
@@ -1,14 +0,0 @@
-{% extends 'layout.html' %}
-{% load i18n %}
-{% load bookwyrm_tags %}
-
-{% block title %}{% blocktrans with book_title=work.title %}Editions of {{ book_title }}{% endblocktrans %}{% endblock %}
-
-{% block content %}
-
-
{% blocktrans with work_path=work.local_path work_title=work.title %}Editions of "{{ work_title }}" {% endblocktrans %}
-
- {% include 'snippets/book_tiles.html' with books=editions %}
-
-{% endblock %}
-
diff --git a/bookwyrm/templates/snippets/filters_panel/filter_field.html b/bookwyrm/templates/snippets/filters_panel/filter_field.html
new file mode 100644
index 00000000..0a8daaa1
--- /dev/null
+++ b/bookwyrm/templates/snippets/filters_panel/filter_field.html
@@ -0,0 +1,6 @@
+
+
+ {% block filter %}
+ {% endblock %}
+
+
diff --git a/bookwyrm/templates/snippets/filters_panel/filters_panel.html b/bookwyrm/templates/snippets/filters_panel/filters_panel.html
new file mode 100644
index 00000000..185f5bc4
--- /dev/null
+++ b/bookwyrm/templates/snippets/filters_panel/filters_panel.html
@@ -0,0 +1,25 @@
+{% load i18n %}
+
+
+ Filters
+
+
+ {% trans "Show filters" as text %}
+ {% include 'snippets/toggle/open_button.html' with text=text controls_text="filters" icon="arrow-down" class="is-small" focus="filters" %}
+ {% trans "Hide filters" as text %}
+ {% include 'snippets/toggle/close_button.html' with text=text controls_text="filters" icon="x" class="is-small" %}
+
+
+
+
+
+ {% if request.GET %}
+
{% trans "Clear filters" %}
+ {% endif %}
+
diff --git a/bookwyrm/views/books.py b/bookwyrm/views/books.py
index cabc3223..895c7ec9 100644
--- a/bookwyrm/views/books.py
+++ b/bookwyrm/views/books.py
@@ -252,12 +252,25 @@ class Editions(View):
if is_api_request(request):
return ActivitypubResponse(work.to_edition_list(**request.GET))
+ filters = {}
+
+ if request.GET.get("language"):
+ filters["languages__contains"] = [request.GET.get("language")]
+ if request.GET.get("format"):
+ filters["physical_format__iexact"] = request.GET.get("format")
+
+ editions = work.editions.order_by("-edition_rank").all()
+ languages = set(sum([e.languages for e in editions], []))
data = {
- "editions": work.editions.order_by("-edition_rank").all(),
+ "editions": editions.filter(**filters).all(),
"work": work,
+ "languages": languages,
+ "formats": set(
+ e.physical_format.lower() for e in editions if e.physical_format
+ ),
}
- return TemplateResponse(request, "editions.html", data)
+ return TemplateResponse(request, "book/editions.html", data)
@login_required
diff --git a/bookwyrm/views/directory.py b/bookwyrm/views/directory.py
index c57b47f7..b329eede 100644
--- a/bookwyrm/views/directory.py
+++ b/bookwyrm/views/directory.py
@@ -41,7 +41,7 @@ class Directory(View):
data = {
"users": paginated.page(page),
}
- return TemplateResponse(request, "directory.html", data)
+ return TemplateResponse(request, "directory/directory.html", data)
def post(self, request):
""" join the directory """