forked from 0x2620/pandora
my/personal
This commit is contained in:
parent
356d850f34
commit
3e9fbb28f2
3 changed files with 48 additions and 32 deletions
|
@ -225,8 +225,8 @@ def addList(request):
|
||||||
qs = models.Position.objects.filter(section='featured')
|
qs = models.Position.objects.filter(section='featured')
|
||||||
else:
|
else:
|
||||||
pos, created = models.Position.objects.get_or_create(list=list,
|
pos, created = models.Position.objects.get_or_create(list=list,
|
||||||
user=request.user, section='my')
|
user=request.user, section='personal')
|
||||||
qs = models.Position.objects.filter(user=request.user, section='my')
|
qs = models.Position.objects.filter(user=request.user, section='personal')
|
||||||
pos.position = qs.aggregate(Max('position'))['position__max'] + 1
|
pos.position = qs.aggregate(Max('position'))['position__max'] + 1
|
||||||
pos.save()
|
pos.save()
|
||||||
response = json_response(status=200, text='created')
|
response = json_response(status=200, text='created')
|
||||||
|
@ -278,7 +278,7 @@ def editList(request):
|
||||||
qs = models.Position.objects.filter(user=request.user, section='section', list=list)
|
qs = models.Position.objects.filter(user=request.user, section='section', list=list)
|
||||||
if qs.count() > 1:
|
if qs.count() > 1:
|
||||||
pos = qs[0]
|
pos = qs[0]
|
||||||
pos.section = 'my'
|
pos.section = 'personal'
|
||||||
pos.save()
|
pos.save()
|
||||||
elif value == 'featured':
|
elif value == 'featured':
|
||||||
if not request.user.is_staff:
|
if not request.user.is_staff:
|
||||||
|
@ -293,9 +293,10 @@ def editList(request):
|
||||||
models.Position.objects.filter(list=list).exclude(id=pos.id).delete()
|
models.Position.objects.filter(list=list).exclude(id=pos.id).delete()
|
||||||
else:
|
else:
|
||||||
models.Position.objects.filter(list=list).delete()
|
models.Position.objects.filter(list=list).delete()
|
||||||
pos, created = models.Position.objects.get_or_create(list=list, user=list.user,
|
pos, created = models.Position.objects.get_or_create(list=list,
|
||||||
section='my')
|
user=list.user,section='personal')
|
||||||
qs = models.Position.objects.filter(user=list.user, section='my')
|
qs = models.Position.objects.filter(user=list.user,
|
||||||
|
section='personal')
|
||||||
pos.position = qs.aggregate(Max('position'))['position__max'] + 1
|
pos.position = qs.aggregate(Max('position'))['position__max'] + 1
|
||||||
pos.save()
|
pos.save()
|
||||||
for u in list.subscribed_users.all():
|
for u in list.subscribed_users.all():
|
||||||
|
@ -323,7 +324,7 @@ def editList(request):
|
||||||
pos.position = data['position']
|
pos.position = data['position']
|
||||||
pos.section = 'featured'
|
pos.section = 'featured'
|
||||||
if list.status == 'private':
|
if list.status == 'private':
|
||||||
pos.section = 'my'
|
pos.section = 'personal'
|
||||||
pos.save()
|
pos.save()
|
||||||
list.save()
|
list.save()
|
||||||
response['data'] = list.json(user=request.user)
|
response['data'] = list.json(user=request.user)
|
||||||
|
@ -411,10 +412,10 @@ actions.register(unsubscribeFromList, cache=False)
|
||||||
def sortLists(request):
|
def sortLists(request):
|
||||||
'''
|
'''
|
||||||
param data {
|
param data {
|
||||||
section: 'my',
|
section: 'personal',
|
||||||
ids: [1,2,4,3]
|
ids: [1,2,4,3]
|
||||||
}
|
}
|
||||||
known sections: 'my', 'public', 'featured'
|
known sections: 'personal', 'public', 'featured'
|
||||||
featured can only be edited by admins
|
featured can only be edited by admins
|
||||||
return {
|
return {
|
||||||
status: {'code': int, 'text': string},
|
status: {'code': int, 'text': string},
|
||||||
|
@ -425,27 +426,29 @@ def sortLists(request):
|
||||||
data = json.loads(request.POST['data'])
|
data = json.loads(request.POST['data'])
|
||||||
position = 0
|
position = 0
|
||||||
section = data['section']
|
section = data['section']
|
||||||
|
#ids = list(set(data['ids']))
|
||||||
|
ids = data['ids']
|
||||||
if section == 'featured' and not request.user.is_staff:
|
if section == 'featured' and not request.user.is_staff:
|
||||||
response = json_response(status=403, text='not allowed')
|
response = json_response(status=403, text='not allowed')
|
||||||
else:
|
else:
|
||||||
user = request.user
|
user = request.user
|
||||||
if section == 'featured':
|
if section == 'featured':
|
||||||
for i in data['ids']:
|
for i in ids:
|
||||||
list = get_list_or_404_json(i)
|
l = get_list_or_404_json(i)
|
||||||
qs = models.Position.objects.filter(section=section, list=list)
|
qs = models.Position.objects.filter(section=section, list=l)
|
||||||
if qs.count() > 0:
|
if qs.count() > 0:
|
||||||
pos = qs[0]
|
pos = qs[0]
|
||||||
else:
|
else:
|
||||||
pos = models.Position(list=list, user=user, section=section)
|
pos = models.Position(list=l, user=user, section=section)
|
||||||
if pos.position != position:
|
if pos.position != position:
|
||||||
pos.position = position
|
pos.position = position
|
||||||
pos.save()
|
pos.save()
|
||||||
position += 1
|
position += 1
|
||||||
models.Position.objects.filter(section=section, list=list).exclude(id=pos.id).delete()
|
models.Position.objects.filter(section=section, list=l).exclude(id=pos.id).delete()
|
||||||
else:
|
else:
|
||||||
for i in data['ids']:
|
for i in ids:
|
||||||
list = get_list_or_404_json(i)
|
l = get_list_or_404_json(i)
|
||||||
pos, created = models.Position.objects.get_or_create(list=list,
|
pos, created = models.Position.objects.get_or_create(list=l,
|
||||||
user=request.user, section=section)
|
user=request.user, section=section)
|
||||||
if pos.position != position:
|
if pos.position != position:
|
||||||
pos.position = position
|
pos.position = position
|
||||||
|
|
|
@ -67,11 +67,12 @@
|
||||||
"sectionName": "{{settings.SITENAME}}",
|
"sectionName": "{{settings.SITENAME}}",
|
||||||
"url": "{{settings.URL}}"
|
"url": "{{settings.URL}}"
|
||||||
},
|
},
|
||||||
"sections": [
|
"sitePages": [
|
||||||
{"id": "history", "title": "History"},
|
{"id": "about", "title": "About"},
|
||||||
{"id": "my", "title": "My Lists"},
|
{"id": "news", "title": "News"},
|
||||||
{"id": "public", "title": "Public Lists"},
|
{"id": "tour", "title": "Take a Tour"},
|
||||||
{"id": "featured", "title": "Featured Lists"}
|
{"id": "faq", "title": "Frequently Asked Questions"},
|
||||||
|
{"id": "tos", "title": "Terms of Service"}
|
||||||
],
|
],
|
||||||
"sortKeys": [
|
"sortKeys": [
|
||||||
{"id": "title", "title": "Title", "width": 180, "removable": false, "type": "title"},
|
{"id": "title", "title": "Title", "width": 180, "removable": false, "type": "title"},
|
||||||
|
@ -131,14 +132,14 @@
|
||||||
"history": [
|
"history": [
|
||||||
{"id": "all_movies", "title": "All Movies", "query": {}}
|
{"id": "all_movies", "title": "All Movies", "query": {}}
|
||||||
],
|
],
|
||||||
"my": [
|
"personal": [
|
||||||
{"user": "foo", "name": "Favorites", "featured": false, "public": true},
|
{"user": "foo", "name": "Favorites", "featured": false, "public": true},
|
||||||
{"id": "favorites", "title": "Favorites", "public": true, "items": []},
|
{"id": "favorites", "title": "Favorites", "public": true, "items": []},
|
||||||
{"id": "most_popular", "title": "Most Popular", "query": {}},
|
{"id": "most_popular", "title": "Most Popular", "query": {}},
|
||||||
{"id": "recently_viewed", "title": "Recently Viewed", "query": {}},
|
{"id": "recently_viewed", "title": "Recently Viewed", "query": {}},
|
||||||
{"id": "1960s", "title": "1960s", "query": {"conditions": [{"key": "year", "value": "196", "operator": "^"}], "operator": ""}}
|
{"id": "1960s", "title": "1960s", "query": {"conditions": [{"key": "year", "value": "196", "operator": "^"}], "operator": ""}}
|
||||||
],
|
],
|
||||||
"public": [
|
"favorite": [
|
||||||
{"id": "rlx:watchme", "title": "rlx: watchme", "public": true, "items": [0, 1, 2, 3, 4]}
|
{"id": "rlx:watchme", "title": "rlx: watchme", "public": true, "items": [0, 1, 2, 3, 4]}
|
||||||
],
|
],
|
||||||
"featured": [
|
"featured": [
|
||||||
|
@ -170,16 +171,22 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"section": "items",
|
"section": "items",
|
||||||
"sections": ["my", "public", "featured"],
|
|
||||||
"showAnnotations": true,
|
"showAnnotations": true,
|
||||||
"showControls": true,
|
"showControls": true,
|
||||||
"showGroups": true,
|
"showGroups": true,
|
||||||
"showInfo": true,
|
"showInfo": true,
|
||||||
"showMovies": true,
|
"showMovies": true,
|
||||||
"showSection": {
|
"showFolder": {
|
||||||
"my": true,
|
"site": {
|
||||||
"public": true,
|
"site": true,
|
||||||
|
"user": true,
|
||||||
|
"admin": true
|
||||||
|
},
|
||||||
|
"items": {
|
||||||
|
"personal": true,
|
||||||
|
"favorite": true,
|
||||||
"featured": true
|
"featured": true
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"showSidebar": true,
|
"showSidebar": true,
|
||||||
"sidebarSize": 256,
|
"sidebarSize": 256,
|
||||||
|
|
|
@ -53,7 +53,13 @@ class UserProfile(models.Model):
|
||||||
for l in lists:
|
for l in lists:
|
||||||
qs = Position.objects.filter(section=section)
|
qs = Position.objects.filter(section=section)
|
||||||
if section == 'featured':
|
if section == 'featured':
|
||||||
pos, created = Position.objects.get_or_create(list=l, section=section)
|
try:
|
||||||
|
pos = Position.objects.get(list=l, section=section)
|
||||||
|
created = False
|
||||||
|
except Position.DoesNotExist:
|
||||||
|
pos = Position(list=l, section=section, user=self.user)
|
||||||
|
pos.save()
|
||||||
|
created = True
|
||||||
else:
|
else:
|
||||||
pos, created = Position.objects.get_or_create(list=l, user=self.user, section=section)
|
pos, created = Position.objects.get_or_create(list=l, user=self.user, section=section)
|
||||||
qs = qs.filter(user=self.user)
|
qs = qs.filter(user=self.user)
|
||||||
|
@ -70,8 +76,8 @@ class UserProfile(models.Model):
|
||||||
return ids
|
return ids
|
||||||
|
|
||||||
ids = ['']
|
ids = ['']
|
||||||
ids += add(self.user.lists.exclude(status="featured"), 'my')
|
ids += add(self.user.lists.exclude(status="featured"), 'personal')
|
||||||
ids += add(self.user.subscribed_lists.all(), 'public')
|
ids += add(self.user.subscribed_lists.filter(status='public'), 'public')
|
||||||
ids += add(List.objects.filter(status='featured'), 'featured')
|
ids += add(List.objects.filter(status='featured'), 'featured')
|
||||||
for i in ui['lists'].keys():
|
for i in ui['lists'].keys():
|
||||||
if i not in ids:
|
if i not in ids:
|
||||||
|
|
Loading…
Reference in a new issue