2018-01-27 03:52:10 +01:00
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
|
|
|
|
from django.contrib import messages
|
|
|
|
from django.contrib.auth import logout as logout_user
|
|
|
|
from django.shortcuts import render, redirect
|
|
|
|
from django.http import HttpResponse, JsonResponse
|
|
|
|
|
2018-02-15 02:01:43 +01:00
|
|
|
from events.models.locale import City
|
|
|
|
from events.models.events import Event, Place, Attendee
|
2018-01-27 03:52:10 +01:00
|
|
|
from events.models.profiles import Team, UserProfile, Member
|
2018-02-15 02:01:43 +01:00
|
|
|
from events.models.search import Searchable
|
|
|
|
from events.forms import SearchForm
|
2018-01-27 03:52:10 +01:00
|
|
|
|
2018-03-04 20:10:37 +01:00
|
|
|
from accounts.decorators import setup_wanted
|
2018-02-15 02:01:43 +01:00
|
|
|
from django.conf import settings
|
2018-01-27 03:52:10 +01:00
|
|
|
|
|
|
|
import datetime
|
|
|
|
import simplejson
|
2018-02-15 02:01:43 +01:00
|
|
|
import geocoder
|
|
|
|
import math
|
|
|
|
import traceback
|
2018-01-27 03:52:10 +01:00
|
|
|
|
|
|
|
from .teams import *
|
|
|
|
from .events import *
|
|
|
|
from .places import *
|
|
|
|
from .user import *
|
2018-02-26 17:53:50 +01:00
|
|
|
from .new_user import *
|
2018-03-04 20:10:37 +01:00
|
|
|
from .utils import *
|
2018-01-27 03:52:10 +01:00
|
|
|
|
2018-02-15 02:01:43 +01:00
|
|
|
KM_PER_DEGREE_LAT = 110.574
|
|
|
|
KM_PER_DEGREE_LNG = 111.320 # At the equator
|
|
|
|
DEFAULT_NEAR_DISTANCE = 100 # kilometeres
|
2018-01-27 03:52:10 +01:00
|
|
|
# Create your views here.
|
|
|
|
|
2018-03-04 20:10:37 +01:00
|
|
|
@setup_wanted
|
2018-01-27 03:52:10 +01:00
|
|
|
def home(request, *args, **kwards):
|
2018-02-15 02:01:43 +01:00
|
|
|
context = {}
|
2018-01-27 03:52:10 +01:00
|
|
|
if request.user.is_authenticated:
|
|
|
|
user_teams = Team.objects.filter(owner_profile=request.user.profile)
|
|
|
|
if len(user_teams) > 0:
|
2018-02-15 02:01:43 +01:00
|
|
|
context['user_teams'] = user_teams
|
|
|
|
|
|
|
|
near_distance = int(request.GET.get("distance", DEFAULT_NEAR_DISTANCE))
|
|
|
|
context['distance'] = near_distance
|
|
|
|
|
2018-03-25 20:40:29 +02:00
|
|
|
city=None
|
2018-02-15 02:01:43 +01:00
|
|
|
ll = None
|
|
|
|
if "city" in request.GET and request.GET.get("city"):
|
|
|
|
context['city_search'] = True
|
|
|
|
city = City.objects.get(id=request.GET.get("city"))
|
|
|
|
context['city'] = city
|
|
|
|
ll = [city.latitude, city.longitude]
|
|
|
|
else :
|
|
|
|
context['city_search'] = False
|
|
|
|
try:
|
2018-03-04 20:10:37 +01:00
|
|
|
g = get_geoip(request)
|
2018-02-15 02:42:01 +01:00
|
|
|
if g.latlng is not None and g.latlng[0] is not None and g.latlng[1] is not None:
|
2018-02-15 02:01:43 +01:00
|
|
|
ll = g.latlng
|
|
|
|
context['geoip_lookup'] = True
|
2018-03-25 20:40:29 +02:00
|
|
|
|
|
|
|
try:
|
|
|
|
city_distance = 1 #km
|
|
|
|
while city is None and city_distance < 100:
|
|
|
|
minlat = ll[0]-(city_distance/KM_PER_DEGREE_LAT)
|
|
|
|
maxlat = ll[0]+(city_distance/KM_PER_DEGREE_LAT)
|
|
|
|
minlng = ll[1]-(city_distance/(KM_PER_DEGREE_LNG*math.cos(math.radians(ll[0]))))
|
|
|
|
maxlng = ll[1]+(city_distance/(KM_PER_DEGREE_LNG*math.cos(math.radians(ll[0]))))
|
|
|
|
nearby_cities = City.objects.filter(latitude__gte=minlat, latitude__lte=maxlat, longitude__gte=minlng, longitude__lte=maxlng)
|
|
|
|
if len(nearby_cities) == 0:
|
|
|
|
city_distance += 1
|
|
|
|
else:
|
|
|
|
city = nearby_cities[0]
|
|
|
|
except:
|
|
|
|
pass # City lookup failed
|
|
|
|
|
2018-02-15 02:01:43 +01:00
|
|
|
except Exception as err:
|
|
|
|
context['geoip_lookup'] = False
|
|
|
|
print("Geocoder lookup failed for %s" % client_ip, err)
|
|
|
|
traceback.print_exc()
|
2018-01-27 03:52:10 +01:00
|
|
|
|
2018-02-15 02:01:43 +01:00
|
|
|
#import pdb; pdb.set_trace()
|
|
|
|
if ll is not None:
|
|
|
|
context['latitude'] = ll[0]
|
|
|
|
context['longitude'] = ll[1]
|
|
|
|
try:
|
|
|
|
minlat = ll[0]-(near_distance/KM_PER_DEGREE_LAT)
|
|
|
|
maxlat = ll[0]+(near_distance/KM_PER_DEGREE_LAT)
|
|
|
|
minlng = ll[1]-(near_distance/(KM_PER_DEGREE_LNG*math.cos(math.radians(ll[0]))))
|
|
|
|
maxlng = ll[1]+(near_distance/(KM_PER_DEGREE_LNG*math.cos(math.radians(ll[0]))))
|
|
|
|
context['minlat'] = minlat
|
|
|
|
context['maxlat'] = maxlat
|
|
|
|
context['minlng'] = minlng
|
|
|
|
context['maxlng'] = maxlng
|
|
|
|
|
|
|
|
near_events = Searchable.objects.filter(latitude__gte=minlat, latitude__lte=maxlat, longitude__gte=minlng, longitude__lte=maxlng, end_time__gte=datetime.datetime.now())
|
|
|
|
context['near_events'] = near_events
|
|
|
|
|
|
|
|
near_teams = Team.objects.filter(city__latitude__gte=minlat, city__latitude__lte=maxlat, city__longitude__gte=minlng, city__longitude__lte=maxlng)
|
|
|
|
context['near_teams'] = near_teams
|
|
|
|
except Exception as err:
|
|
|
|
print("Error looking up nearby teams and events", err)
|
|
|
|
traceback.print_exc()
|
|
|
|
|
2018-03-25 20:40:29 +02:00
|
|
|
search_form = SearchForm(initial={'city': city.id, 'distance': near_distance})
|
2018-02-15 02:01:43 +01:00
|
|
|
context['search_form'] = search_form
|
|
|
|
return render(request, 'get_together/index.html', context)
|
|
|
|
|