2015-11-24 15:09:46 +00:00
|
|
|
from django.shortcuts import render, redirect, get_object_or_404
|
|
|
|
from django.db import models
|
2016-08-19 00:53:44 +00:00
|
|
|
from django.http import JsonResponse
|
|
|
|
from django.core import serializers
|
|
|
|
from django.db.models import Q
|
|
|
|
from django.contrib.auth.decorators import login_required
|
2015-11-24 15:09:46 +00:00
|
|
|
|
2016-08-10 03:48:06 +00:00
|
|
|
import os
|
2016-08-19 00:53:44 +00:00
|
|
|
import json
|
|
|
|
from itertools import chain
|
|
|
|
|
|
|
|
from core.models import User
|
|
|
|
from club.models import Club
|
2016-08-10 03:48:06 +00:00
|
|
|
|
2015-11-24 15:09:46 +00:00
|
|
|
def index(request, context=None):
|
2016-08-19 00:53:44 +00:00
|
|
|
return render(request, "core/index.jinja")
|
|
|
|
|
2016-08-19 21:24:23 +00:00
|
|
|
def search_user(query, as_json=False):
|
|
|
|
users = []
|
2016-08-19 00:53:44 +00:00
|
|
|
if query:
|
2016-08-19 01:12:20 +00:00
|
|
|
exact_nick = User.objects.filter(nick_name__iexact=query).all()
|
|
|
|
nicks = User.objects.filter(nick_name__icontains=query).exclude(id__in=exact_nick).all()
|
|
|
|
users = User.objects.filter(Q(first_name__icontains=query) |
|
|
|
|
Q(last_name__icontains=query)).exclude(id__in=exact_nick).exclude(id__in=nicks).all()
|
2016-08-19 00:53:44 +00:00
|
|
|
nicks = nicks[:5]
|
|
|
|
users = users[:5]
|
|
|
|
if as_json: # Re-loads json to avoid double encoding by JsonResponse, but still benefit from serializers
|
2016-08-19 01:12:20 +00:00
|
|
|
exact_nick = json.loads(serializers.serialize('json', exact_nick, fields=('nick_name', 'last_name', 'first_name', 'profile_pict')))
|
2016-08-19 00:53:44 +00:00
|
|
|
nicks = json.loads(serializers.serialize('json', nicks, fields=('nick_name', 'last_name', 'first_name', 'profile_pict')))
|
|
|
|
users = json.loads(serializers.serialize('json', users, fields=('nick_name', 'last_name', 'first_name', 'profile_pict')))
|
|
|
|
else:
|
2016-08-19 01:12:20 +00:00
|
|
|
exact_nick = list(exact_nick)
|
|
|
|
nicks = list(nicks)
|
|
|
|
users = list(users)
|
2016-08-19 21:24:23 +00:00
|
|
|
users = exact_nick + nicks + users
|
|
|
|
return users
|
|
|
|
|
|
|
|
def search_club(query, as_json=False):
|
|
|
|
clubs = []
|
|
|
|
if query:
|
|
|
|
clubs = Club.objects.filter(name__icontains=query).all()
|
|
|
|
clubs = clubs[:5]
|
|
|
|
if as_json: # Re-loads json to avoid double encoding by JsonResponse, but still benefit from serializers
|
|
|
|
clubs = json.loads(serializers.serialize('json', clubs, fields=('name')))
|
|
|
|
else:
|
2016-08-19 01:12:20 +00:00
|
|
|
clubs = list(clubs)
|
2016-08-19 21:24:23 +00:00
|
|
|
return clubs
|
2016-08-19 00:53:44 +00:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
def search_view(request):
|
2016-08-19 21:24:23 +00:00
|
|
|
result = {
|
|
|
|
'users': search_user(request.GET.get('query', '')),
|
|
|
|
'clubs': search_club(request.GET.get('query', '')),
|
|
|
|
}
|
|
|
|
return render(request, "core/search.jinja", context={'result': result})
|
|
|
|
|
|
|
|
@login_required
|
|
|
|
def search_user_json(request):
|
|
|
|
result = {
|
|
|
|
'users': search_user(request.GET.get('query', ''), True),
|
|
|
|
}
|
|
|
|
return JsonResponse(result)
|
2016-08-19 00:53:44 +00:00
|
|
|
|
|
|
|
@login_required
|
|
|
|
def search_json(request):
|
2016-08-19 21:24:23 +00:00
|
|
|
result = {
|
|
|
|
'users': search_user(request.GET.get('query', ''), True),
|
|
|
|
'clubs': search_club(request.GET.get('query', ''), True),
|
|
|
|
}
|
|
|
|
return JsonResponse(result)
|
2015-11-24 15:09:46 +00:00
|
|
|
|