2026-02-17 20:26:42 -05:00
|
|
|
from django.http import HttpResponseForbidden
|
2026-01-13 20:58:05 -05:00
|
|
|
from django.shortcuts import redirect, render
|
2026-01-23 22:30:42 -05:00
|
|
|
from .forms import ExistingListItemForm, ItemForm
|
2026-01-13 20:58:05 -05:00
|
|
|
from .models import Item, List
|
2026-02-08 22:18:41 -05:00
|
|
|
from apps.lyric.models import User
|
2026-01-13 20:58:05 -05:00
|
|
|
|
|
|
|
|
def home_page(request):
|
2026-01-24 13:00:12 -05:00
|
|
|
return render(request, "apps/dashboard/home.html", {"form": ItemForm()})
|
2026-01-13 20:58:05 -05:00
|
|
|
|
|
|
|
|
def new_list(request):
|
2026-01-20 15:14:05 -05:00
|
|
|
form = ItemForm(data=request.POST)
|
|
|
|
|
if form.is_valid():
|
|
|
|
|
nulist = List.objects.create()
|
2026-02-08 22:33:15 -05:00
|
|
|
if request.user.is_authenticated:
|
|
|
|
|
nulist.owner = request.user
|
|
|
|
|
nulist.save()
|
2026-01-24 13:00:12 -05:00
|
|
|
form.save(for_list=nulist)
|
2026-01-20 15:14:05 -05:00
|
|
|
return redirect(nulist)
|
|
|
|
|
else:
|
|
|
|
|
return render(request, "apps/dashboard/home.html", {"form": form})
|
2026-01-13 20:58:05 -05:00
|
|
|
|
2026-01-19 16:35:00 -05:00
|
|
|
def view_list(request, list_id):
|
|
|
|
|
our_list = List.objects.get(id=list_id)
|
2026-01-23 22:30:42 -05:00
|
|
|
form = ExistingListItemForm(for_list=our_list)
|
2026-01-19 19:09:11 -05:00
|
|
|
|
2026-01-19 18:48:21 -05:00
|
|
|
if request.method == "POST":
|
2026-01-23 22:30:42 -05:00
|
|
|
form = ExistingListItemForm(for_list=our_list, data=request.POST)
|
2026-01-21 14:41:25 -05:00
|
|
|
if form.is_valid():
|
2026-01-23 22:39:12 -05:00
|
|
|
form.save()
|
2026-01-19 19:25:04 -05:00
|
|
|
return redirect(our_list)
|
2026-01-24 13:00:12 -05:00
|
|
|
return render(request, "apps/dashboard/list.html", {"list": our_list, "form": form})
|
2026-01-19 19:09:11 -05:00
|
|
|
|
2026-02-07 22:47:04 -05:00
|
|
|
def my_lists(request, user_id):
|
2026-02-08 22:18:41 -05:00
|
|
|
owner = User.objects.get(id=user_id)
|
2026-02-17 20:26:42 -05:00
|
|
|
if not request.user.is_authenticated:
|
|
|
|
|
return redirect("/")
|
|
|
|
|
if request.user.id != owner.id:
|
|
|
|
|
return HttpResponseForbidden()
|
2026-02-08 22:18:41 -05:00
|
|
|
return render(request, "apps/dashboard/my_lists.html", {"owner": owner})
|
2026-02-18 13:53:05 -05:00
|
|
|
|
|
|
|
|
def share_list(request, list_id):
|
|
|
|
|
our_list = List.objects.get(id=list_id)
|
2026-02-18 15:14:35 -05:00
|
|
|
try:
|
|
|
|
|
recipient = User.objects.get(email=request.POST["recipient"])
|
|
|
|
|
our_list.shared_with.add(recipient)
|
|
|
|
|
except User.DoesNotExist:
|
|
|
|
|
pass
|
2026-02-18 13:53:05 -05:00
|
|
|
return redirect(our_list)
|