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-04-02 04:22:30 +02:00
|
|
|
from events import location
|
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-04-17 03:52:24 +02:00
|
|
|
from .new_team import *
|
2018-04-24 16:22:16 +02:00
|
|
|
from .speakers 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-04-17 03:52:24 +02:00
|
|
|
g = location.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:
|
2018-04-02 04:22:30 +02:00
|
|
|
city = sorted(nearby_cities, key=lambda city: location.city_distance_from(ll, city))[0]
|
2018-04-21 16:28:04 +02:00
|
|
|
|
|
|
|
if request.user.profile.city is None:
|
|
|
|
profile = request.user.profile
|
|
|
|
profile.city = city
|
|
|
|
profile.save()
|
2018-03-25 20:40:29 +02:00
|
|
|
except:
|
|
|
|
pass # City lookup failed
|
|
|
|
|
2018-02-15 02:01:43 +01:00
|
|
|
except Exception as err:
|
|
|
|
context['geoip_lookup'] = False
|
2018-04-17 03:52:24 +02:00
|
|
|
print("Geocoder lookup failed for %s" % request.META.get('REMOTE_ADDR'), err)
|
2018-02-15 02:01:43 +01:00
|
|
|
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())
|
2018-04-02 04:22:30 +02:00
|
|
|
context['near_events'] = sorted(near_events, key=lambda searchable: location.searchable_distance_from(ll, searchable))
|
2018-02-15 02:01:43 +01:00
|
|
|
|
|
|
|
near_teams = Team.objects.filter(city__latitude__gte=minlat, city__latitude__lte=maxlat, city__longitude__gte=minlng, city__longitude__lte=maxlng)
|
2018-04-02 04:22:30 +02:00
|
|
|
context['near_teams'] = sorted(near_teams, key=lambda team: location.team_distance_from(ll, team))
|
2018-04-17 03:52:24 +02:00
|
|
|
|
|
|
|
# # If there aren't any teams in the user's geoip area, direct them to start one
|
|
|
|
if context['geoip_lookup'] and len(near_teams) < 1 and len(near_events) < 1:
|
|
|
|
messages.add_message(request, messages.INFO, message=_('There are no teams or events yet in your area, be the first to start one!'))
|
|
|
|
return redirect('create-team')
|
2018-02-15 02:01:43 +01:00
|
|
|
except Exception as err:
|
|
|
|
print("Error looking up nearby teams and events", err)
|
|
|
|
traceback.print_exc()
|
|
|
|
|
2018-03-27 01:23:12 +02:00
|
|
|
initial_search = {'distance': near_distance}
|
|
|
|
if city is not None and city.id > 0:
|
|
|
|
initial_search['city'] = city.id
|
|
|
|
search_form = SearchForm(initial=initial_search)
|
2018-02-15 02:01:43 +01:00
|
|
|
context['search_form'] = search_form
|
|
|
|
return render(request, 'get_together/index.html', context)
|
|
|
|
|