lib.itmens/catalog/views.py

320 lines
9.8 KiB
Python
Raw Normal View History

2022-12-15 17:29:35 -05:00
import logging
2022-12-15 17:29:35 -05:00
from django.contrib.auth.decorators import login_required, permission_required
from django.core.cache import cache
from django.core.exceptions import BadRequest, ObjectDoesNotExist, PermissionDenied
2022-12-15 17:29:35 -05:00
from django.core.paginator import Paginator
from django.db.models import Count
from django.http import Http404
from django.shortcuts import get_object_or_404, redirect, render
from django.utils.translation import gettext_lazy as _
2023-02-10 15:56:13 -05:00
from django.views.decorators.clickjacking import xframe_options_exempt
from common.config import PAGE_LINK_NUMBER
from common.utils import PageLinksGenerator, get_uuid_or_404
from journal.models import (
Comment,
Mark,
Review,
ShelfMember,
ShelfType,
ShelfTypeNames,
query_following,
query_item_category,
query_visible,
)
2023-01-05 03:06:13 -05:00
from .forms import *
from .models import *
2023-01-05 03:06:13 -05:00
from .search.views import *
2023-06-19 15:40:27 -04:00
from .views_edit import *
2022-12-15 17:29:35 -05:00
_logger = logging.getLogger(__name__)
2022-12-24 01:28:24 -05:00
NUM_REVIEWS_ON_ITEM_PAGE = 5
NUM_REVIEWS_ON_LIST_PAGE = 20
def retrieve_by_uuid(request, item_uid):
item = get_object_or_404(Item, uid=item_uid)
return redirect(item.url)
2023-02-10 15:56:13 -05:00
@xframe_options_exempt
def embed(request, item_path, item_uuid):
if request.method != "GET":
raise BadRequest()
item = Item.get_by_url(item_uuid)
if item is None:
raise Http404()
if item.merged_to_item:
return redirect(item.merged_to_item.url)
if item.is_deleted:
raise Http404()
focus_item = None
if request.GET.get("focus"):
focus_item = get_object_or_404(
Item, uid=get_uuid_or_404(request.GET.get("focus"))
2022-12-15 17:29:35 -05:00
)
2023-02-10 15:56:13 -05:00
return render(
request,
"embed_" + item.class_name + ".html",
{"item": item, "focus_item": focus_item},
)
def retrieve(request, item_path, item_uuid):
if request.method != "GET":
2023-02-04 00:45:17 -05:00
raise BadRequest()
# item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
2023-02-10 15:56:13 -05:00
item = Item.get_by_url(item_uuid)
if item is None:
raise Http404()
item_url = f"/{item_path}/{item_uuid}"
if item.url != item_url:
return redirect(item.url)
2023-06-12 15:07:55 -04:00
skipcheck = request.GET.get("skipcheck", False) and request.user.is_authenticated
2023-02-10 15:56:13 -05:00
if not skipcheck and item.merged_to_item:
return redirect(item.merged_to_item.url)
if not skipcheck and item.is_deleted:
raise Http404()
focus_item = None
if request.GET.get("focus"):
focus_item = get_object_or_404(
Item, uid=get_uuid_or_404(request.GET.get("focus"))
2023-02-10 15:56:13 -05:00
)
mark = None
review = None
my_collections = []
2023-02-10 15:56:13 -05:00
collection_list = []
2023-06-18 20:53:10 -04:00
child_item_comments = []
2023-02-10 15:56:13 -05:00
shelf_types = [(n[1], n[2]) for n in iter(ShelfTypeNames) if n[0] == item.category]
if request.user.is_authenticated:
visible = query_visible(request.user)
mark = Mark(request.user, item)
2023-06-18 20:53:10 -04:00
child_item_comments = Comment.objects.filter(
owner=request.user, item__in=item.child_items.all()
)
2023-02-10 15:56:13 -05:00
review = mark.review
my_collections = item.collections.all().filter(owner=request.user)
2023-02-10 15:56:13 -05:00
collection_list = (
item.collections.all()
.exclude(owner=request.user)
2023-02-10 15:56:13 -05:00
.filter(visible)
.annotate(like_counts=Count("likes"))
.order_by("-like_counts")
)
else:
collection_list = (
item.collections.all()
.filter(visibility=0)
.annotate(like_counts=Count("likes"))
.order_by("-like_counts")
2023-02-10 15:56:13 -05:00
)
return render(
request,
item.class_name + ".html",
{
"item": item,
"focus_item": focus_item,
"mark": mark,
"review": review,
2023-06-18 20:53:10 -04:00
"child_item_comments": child_item_comments,
"my_collections": my_collections,
2023-02-10 15:56:13 -05:00
"collection_list": collection_list,
"shelf_types": shelf_types,
},
)
2022-12-24 01:28:24 -05:00
2023-06-12 15:07:55 -04:00
def episode_data(request, item_uuid):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
qs = item.episodes.all().order_by("-pub_date")
if request.GET.get("last"):
qs = qs.filter(pub_date__lt=request.GET.get("last"))
return render(
request, "podcast_episode_data.html", {"item": item, "episodes": qs[:5]}
)
@login_required
2022-12-24 01:28:24 -05:00
def mark_list(request, item_path, item_uuid, following_only=False):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
2022-12-24 01:28:24 -05:00
if not item:
2023-02-04 00:45:17 -05:00
raise Http404()
2022-12-29 23:57:02 -05:00
queryset = ShelfMember.objects.filter(item=item).order_by("-created_time")
2022-12-24 01:28:24 -05:00
if following_only:
queryset = queryset.filter(query_following(request.user))
else:
queryset = queryset.filter(query_visible(request.user))
paginator = Paginator(queryset, NUM_REVIEWS_ON_LIST_PAGE)
2022-12-29 23:57:02 -05:00
page_number = request.GET.get("page", default=1)
2022-12-24 01:28:24 -05:00
marks = paginator.get_page(page_number)
pagination = PageLinksGenerator(PAGE_LINK_NUMBER, page_number, paginator.num_pages)
2022-12-24 01:28:24 -05:00
return render(
request,
2022-12-29 23:57:02 -05:00
"item_mark_list.html",
2022-12-24 01:28:24 -05:00
{
2022-12-29 23:57:02 -05:00
"marks": marks,
"item": item,
2023-05-20 14:17:02 -04:00
"followeing_only": following_only,
"pagination": pagination,
2022-12-29 23:57:02 -05:00
},
2022-12-24 01:28:24 -05:00
)
def review_list(request, item_path, item_uuid):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
2022-12-24 01:28:24 -05:00
if not item:
2023-02-04 00:45:17 -05:00
raise Http404()
2022-12-29 23:57:02 -05:00
queryset = Review.objects.filter(item=item).order_by("-created_time")
2022-12-24 01:28:24 -05:00
queryset = queryset.filter(query_visible(request.user))
paginator = Paginator(queryset, NUM_REVIEWS_ON_LIST_PAGE)
2022-12-29 23:57:02 -05:00
page_number = request.GET.get("page", default=1)
2022-12-24 01:28:24 -05:00
reviews = paginator.get_page(page_number)
pagination = PageLinksGenerator(PAGE_LINK_NUMBER, page_number, paginator.num_pages)
2022-12-24 01:28:24 -05:00
return render(
request,
2022-12-29 23:57:02 -05:00
"item_review_list.html",
2022-12-24 01:28:24 -05:00
{
2022-12-29 23:57:02 -05:00
"reviews": reviews,
"item": item,
"pagination": pagination,
2022-12-29 23:57:02 -05:00
},
2022-12-24 01:28:24 -05:00
)
2023-04-19 22:31:27 -04:00
@login_required
def comments(request, item_path, item_uuid):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
if not item:
raise Http404()
2023-06-12 15:07:55 -04:00
ids = item.child_item_ids + [item.id]
queryset = Comment.objects.filter(item_id__in=ids).order_by("-created_time")
queryset = queryset.filter(query_visible(request.user))
before_time = request.GET.get("last")
if before_time:
queryset = queryset.filter(created_time__lte=before_time)
return render(
request,
2023-06-09 02:45:27 -04:00
"_item_comments.html",
{
"item": item,
"comments": queryset[:11],
},
)
@login_required
def comments_by_episode(request, item_path, item_uuid):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
if not item:
raise Http404()
episode_uuid = request.GET.get("episode_uuid")
if episode_uuid:
episode = TVEpisode.get_by_url(episode_uuid)
ids = [episode.pk] if episode else []
else:
ids = item.child_item_ids
queryset = Comment.objects.filter(item_id__in=ids).order_by("-created_time")
queryset = queryset.filter(query_visible(request.user))
before_time = request.GET.get("last")
if before_time:
queryset = queryset.filter(created_time__lte=before_time)
return render(
request,
"_item_comments_by_episode.html",
{
"item": item,
"episode_uuid": episode_uuid,
"comments": queryset[:11],
},
)
@login_required
def reviews(request, item_path, item_uuid):
item = get_object_or_404(Item, uid=get_uuid_or_404(item_uuid))
if not item:
raise Http404()
2023-06-12 15:07:55 -04:00
ids = item.child_item_ids + [item.id]
queryset = Review.objects.filter(item_id__in=ids).order_by("-created_time")
queryset = queryset.filter(query_visible(request.user))
before_time = request.GET.get("last")
if before_time:
queryset = queryset.filter(created_time__lte=before_time)
return render(
request,
2023-06-09 02:45:27 -04:00
"_item_reviews.html",
{
"item": item,
"reviews": queryset[:11],
},
)
2023-04-19 22:31:27 -04:00
def discover(request):
if request.method != "GET":
raise BadRequest()
user = request.user
if user.is_authenticated:
layout = user.preference.discover_layout
2023-04-19 22:31:27 -04:00
else:
layout = []
cache_key = "public_gallery"
2023-04-19 22:31:27 -04:00
gallery_list = cache.get(cache_key, [])
# for gallery in gallery_list:
# ids = (
# random.sample(gallery["item_ids"], 10)
# if len(gallery["item_ids"]) > 10
# else gallery["item_ids"]
# )
# gallery["items"] = Item.objects.filter(id__in=ids)
2023-04-19 22:31:27 -04:00
if user.is_authenticated:
podcast_ids = [
p.item_id
for p in user.shelf_manager.get_latest_members(
2023-04-19 22:31:27 -04:00
ShelfType.PROGRESS, ItemCategory.Podcast
)
]
recent_podcast_episodes = PodcastEpisode.objects.filter(
program_id__in=podcast_ids
).order_by("-pub_date")[:10]
books_in_progress = Edition.objects.filter(
id__in=[
p.item_id
for p in user.shelf_manager.get_latest_members(
ShelfType.PROGRESS, ItemCategory.Book
)[:10]
]
2023-04-19 22:31:27 -04:00
)
tvshows_in_progress = Item.objects.filter(
id__in=[
p.item_id
for p in user.shelf_manager.get_latest_members(
ShelfType.PROGRESS, ItemCategory.TV
)[:10]
]
)
else:
recent_podcast_episodes = []
books_in_progress = []
tvshows_in_progress = []
2023-04-19 22:31:27 -04:00
return render(
request,
"discover.html",
{
"user": user,
"gallery_list": gallery_list,
"recent_podcast_episodes": recent_podcast_episodes,
"books_in_progress": books_in_progress,
"tvshows_in_progress": tvshows_in_progress,
2023-04-19 22:31:27 -04:00
"layout": layout,
},
)