Edit goal

This commit is contained in:
Mouse Reeve 2021-01-16 12:39:51 -08:00
parent 112b9f9332
commit f3f6592e72
7 changed files with 70 additions and 33 deletions

View file

@ -3,7 +3,18 @@
<section class="block"> <section class="block">
<h1 class="title">{{ year }} Reading Progress</h1> <h1 class="title">{{ year }} Reading Progress</h1>
{% if not goal and user == request.user %} {% if user == request.user %}
<div class="block">
{% if goal %}
<input type="radio" class="toggle-control" name="edit-goal" id="hide-edit-goal" checked>
<div class="toggle-content hidden">
{% include 'snippets/toggle/toggle_button.html' with text="Edit goal" controls_text="show-edit-goal" %}
</div>
{% endif %}
</div>
<div class="block">
<input type="radio" class="toggle-control" name="edit-goal" id="show-edit-goal">
<div class="toggle-content{% if goal %} hidden{% endif %}">
{% now 'Y' as year %} {% now 'Y' as year %}
<article class="card"> <article class="card">
<header class="card-header"> <header class="card-header">
@ -14,12 +25,18 @@
<section class="card-content content"> <section class="card-content content">
<p>Set a goal for how many books you'll finish reading in {{ year }}, and track your progress throughout the year.</p> <p>Set a goal for how many books you'll finish reading in {{ year }}, and track your progress throughout the year.</p>
{% include 'snippets/goal_form.html' %} {% include 'snippets/goal_form.html' with goal=goal year=year %}
</section> </section>
</article> </article>
{% elif not goal and user != request.user %} </div>
</div>
{% endif %}
{% if not goal and user != request.user %}
<p>{{ user.display_name }} hasn't set a reading goal for {{ year }}.</p> <p>{{ user.display_name }} hasn't set a reading goal for {{ year }}.</p>
{% else %} {% endif %}
{% if goal %}
{% include 'snippets/goal_progress.html' with goal=goal %} {% include 'snippets/goal_progress.html' with goal=goal %}
{% endif %} {% endif %}
</section> </section>

View file

@ -1,6 +1,6 @@
<form method="post" name="goal" action="{{ request.user.local_path }}/goal/{{ year }}"> <form method="post" name="goal" action="{{ request.user.local_path }}/goal/{{ year }}">
{% csrf_token %} {% csrf_token %}
<input type="hidden" name="year" value="{{ year }}"> <input type="hidden" name="year" value="{% if goal %}{{ goal.year }}{% else %}{{ year }}{% endif %}">
<input type="hidden" name="user" value="{{ request.user.id }}"> <input type="hidden" name="user" value="{{ request.user.id }}">
<div class="columns"> <div class="columns">
@ -8,7 +8,7 @@
<label class="label" for="id_goal">Reading goal:</label> <label class="label" for="id_goal">Reading goal:</label>
<div class="field has-addons"> <div class="field has-addons">
<div class="control"> <div class="control">
<input type="number" class="input" name="goal" id="id_goal" value="12"> <input type="number" class="input" name="goal" id="id_goal" value="{% if goal %}{{ goal.goal }}{% else %}12{% endif %}">
</div> </div>
<p class="button is-static">books</p> <p class="button is-static">books</p>
</div> </div>
@ -16,7 +16,7 @@
<div class="column"> <div class="column">
<label class="label"><p class="mb-2">Goal privacy:</p> <label class="label"><p class="mb-2">Goal privacy:</p>
{% include 'snippets/privacy_select.html' with no_label=True %} {% include 'snippets/privacy_select.html' with no_label=True current=goal.privacy %}
</label> </label>
</div> </div>
</div> </div>
@ -27,5 +27,8 @@
<p> <p>
<button type="submit" class="button is-link">Set goal</button> <button type="submit" class="button is-link">Set goal</button>
{% if goal %}
{% include 'snippets/toggle/toggle_button.html' with text="Cancel" controls_text="hide-edit-goal" %}
{% endif %}
</p> </p>
</form> </form>

View file

@ -40,6 +40,17 @@
<small><a href="{{ user.local_path }}/shelves">See all {{ shelf_count }} shelves</a></small> <small><a href="{{ user.local_path }}/shelves">See all {{ shelf_count }} shelves</a></small>
</div> </div>
{% if goal %}
<div class="block">
<h2 class="title">{% now 'Y' %} Reading Goal</h2>
{% include 'snippets/goal_progress.html' with goal=goal %}
</div>
{% elif user == request.user %}
<div class="block">
<h2 class="title is-4"><a href="{{ user.local_path }}/goal/{% now 'Y' %}">Set a reading goal for {% now 'Y' %}</a></h2>
</div>
{% endif %}
<div> <div>
<div class="block"> <div class="block">
<h2 class="title">User Activity</h2> <h2 class="title">User Activity</h2>

View file

@ -7,7 +7,7 @@ from django.utils.decorators import method_decorator
from django.views import View from django.views import View
from bookwyrm import forms, models from bookwyrm import forms, models
from .helpers import get_user_from_username from .helpers import get_user_from_username, object_visible_to_user
# pylint: disable= no-self-use # pylint: disable= no-self-use
@ -24,9 +24,7 @@ class Goal(View):
if not goal and user != request.user: if not goal and user != request.user:
return redirect('/') return redirect('/')
if goal and user != request.user: if goal and not object_visible_to_user(request.user, goal):
if goal.privacy == 'direct' or \
(goal.privacy == 'followers' and not follower):
return HttpResponseNotFound() return HttpResponseNotFound()
data = { data = {

View file

@ -34,15 +34,16 @@ def is_bookworm_request(request):
return True return True
def status_visible_to_user(viewer, status): def object_visible_to_user(viewer, obj):
''' is a user authorized to view a status? ''' ''' is a user authorized to view an object? '''
if viewer == status.user or status.privacy in ['public', 'unlisted']: if viewer == obj.user or obj.privacy in ['public', 'unlisted']:
return True return True
if status.privacy == 'followers' and \ if obj.privacy == 'followers' and \
status.user.followers.filter(id=viewer.id).first(): obj.user.followers.filter(id=viewer.id).first():
return True return True
if status.privacy == 'direct' and \ if isinstance(obj, models.Status):
status.mention_users.filter(id=viewer.id).first(): if obj.privacy == 'direct' and \
obj.mention_users.filter(id=viewer.id).first():
return True return True
return False return False

View file

@ -16,7 +16,7 @@ from bookwyrm.settings import DOMAIN
from bookwyrm.status import create_notification, delete_status from bookwyrm.status import create_notification, delete_status
from bookwyrm.utils import regex from bookwyrm.utils import regex
from .helpers import get_user_from_username, handle_remote_webfinger from .helpers import get_user_from_username, handle_remote_webfinger
from .helpers import is_api_request, is_bookworm_request, status_visible_to_user from .helpers import is_api_request, is_bookworm_request, object_visible_to_user
# pylint: disable= no-self-use # pylint: disable= no-self-use
@ -35,7 +35,7 @@ class Status(View):
return HttpResponseNotFound() return HttpResponseNotFound()
# make sure the user is authorized to see the status # make sure the user is authorized to see the status
if not status_visible_to_user(request.user, status): if not object_visible_to_user(request.user, status):
return HttpResponseNotFound() return HttpResponseNotFound()
if is_api_request(request): if is_api_request(request):

View file

@ -9,6 +9,7 @@ from django.core.paginator import Paginator
from django.http import HttpResponseNotFound from django.http import HttpResponseNotFound
from django.shortcuts import redirect from django.shortcuts import redirect
from django.template.response import TemplateResponse from django.template.response import TemplateResponse
from django.utils import timezone
from django.utils.decorators import method_decorator from django.utils.decorators import method_decorator
from django.views import View from django.views import View
@ -17,6 +18,7 @@ from bookwyrm.activitypub import ActivitypubResponse
from bookwyrm.broadcast import broadcast from bookwyrm.broadcast import broadcast
from bookwyrm.settings import PAGE_LENGTH from bookwyrm.settings import PAGE_LENGTH
from .helpers import get_activity_feed, get_user_from_username, is_api_request from .helpers import get_activity_feed, get_user_from_username, is_api_request
from .helpers import object_visible_to_user
# pylint: disable= no-self-use # pylint: disable= no-self-use
@ -70,6 +72,10 @@ class User(View):
queryset=models.Status.objects.filter(user=user) queryset=models.Status.objects.filter(user=user)
) )
paginated = Paginator(activities, PAGE_LENGTH) paginated = Paginator(activities, PAGE_LENGTH)
goal = models.AnnualGoal.objects.filter(
user=user, year=timezone.now().year).first()
if not object_visible_to_user(request.user, goal):
goal = None
data = { data = {
'title': user.name, 'title': user.name,
'user': user, 'user': user,
@ -77,6 +83,7 @@ class User(View):
'shelves': shelf_preview, 'shelves': shelf_preview,
'shelf_count': shelves.count(), 'shelf_count': shelves.count(),
'activities': paginated.page(page), 'activities': paginated.page(page),
'goal': goal,
} }
return TemplateResponse(request, 'user.html', data) return TemplateResponse(request, 'user.html', data)