From 7483cb59192a216ff8951f2d18f361b39d314427 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Wed, 31 Mar 2021 13:56:26 -0700 Subject: [PATCH] Adds getting started find books view --- bookwyrm/static/css/format.css | 4 + bookwyrm/templates/get_started/books.html | 98 +++++++++++++++++++++++ bookwyrm/urls.py | 2 + bookwyrm/views/__init__.py | 1 + bookwyrm/views/get_started.py | 35 ++++++++ 5 files changed, 140 insertions(+) create mode 100644 bookwyrm/templates/get_started/books.html create mode 100644 bookwyrm/views/get_started.py diff --git a/bookwyrm/static/css/format.css b/bookwyrm/static/css/format.css index 65fd56aba..e3ae1ce79 100644 --- a/bookwyrm/static/css/format.css +++ b/bookwyrm/static/css/format.css @@ -21,6 +21,10 @@ html { overflow-x: auto; } +.modal-card.is-fullwidth { + min-width: 75% !important; +} + /* --- SHELVING --- */ /** @todo Replace icons with SVG symbols. diff --git a/bookwyrm/templates/get_started/books.html b/bookwyrm/templates/get_started/books.html new file mode 100644 index 000000000..7ead07107 --- /dev/null +++ b/bookwyrm/templates/get_started/books.html @@ -0,0 +1,98 @@ +{% extends 'layout.html' %} +{% load i18n %} +{% load bookwyrm_tags %} +{% load humanize %} + +{% block title %}{% trans "Welcome" %}{% endblock %} + +{% block content %} +{% with site_name=site.name %} + +{% endwith %} +{% endblock %} + diff --git a/bookwyrm/urls.py b/bookwyrm/urls.py index 27fb678fa..6d14beeb1 100644 --- a/bookwyrm/urls.py +++ b/bookwyrm/urls.py @@ -109,6 +109,8 @@ urlpatterns = [ re_path(r"^discover/?$", views.Discover.as_view()), re_path(r"^notifications/?$", views.Notifications.as_view()), re_path(r"^directory/?", views.Directory.as_view(), name="directory"), + # Get started + re_path(r"^get-started/?$", views.GetStarted.as_view(), name="get-started"), # feeds re_path(r"^(?Phome|local|federated)/?$", views.Feed.as_view()), re_path( diff --git a/bookwyrm/views/__init__.py b/bookwyrm/views/__init__.py index fead2a32b..9ea5ebebe 100644 --- a/bookwyrm/views/__init__.py +++ b/bookwyrm/views/__init__.py @@ -9,6 +9,7 @@ from .federation import Federation, FederatedServer from .feed import DirectMessage, Feed, Replies, Status from .follow import follow, unfollow from .follow import accept_follow_request, delete_follow_request +from .get_started import GetStarted from .goal import Goal, hide_goal from .import_data import Import, ImportStatus from .inbox import Inbox diff --git a/bookwyrm/views/get_started.py b/bookwyrm/views/get_started.py new file mode 100644 index 000000000..7db458068 --- /dev/null +++ b/bookwyrm/views/get_started.py @@ -0,0 +1,35 @@ +""" Helping new users figure out the lay of the land """ +from django.contrib.auth.decorators import login_required +from django.db.models import Count +from django.template.response import TemplateResponse +from django.utils.decorators import method_decorator +from django.views import View + +from bookwyrm import models +from bookwyrm.connectors import connector_manager + + +# pylint: disable= no-self-use +@method_decorator(login_required, name="dispatch") +class GetStarted(View): + """ a book! this is the stuff """ + + def get(self, request): + """ info about a book """ + query = request.GET.get('query') + book_results = [] + if query: + book_results = connector_manager.local_search(query, raw=True)[:5] + if len(book_results) < 5: + popular_books = models.Edition.objects.exclude( + parent_work__in=[b.parent_work for b in book_results], + ).annotate( + Count("shelfbook") + ).order_by("-shelfbook__count")[: 5 - len(book_results)] + + + data = { + "book_results": book_results, + "popular_books": popular_books, + } + return TemplateResponse(request, "get_started/books.html", data)