From 83e0e709e2091b4f50d487eb6297fd7970983f0e Mon Sep 17 00:00:00 2001 From: Michael Hall Date: Sun, 15 Jul 2018 14:13:37 -0400 Subject: [PATCH] If no teams or events are near the viewer (by geoip lookup) show them the 3 closest to them instead of redirecting them to create a team --- .../templates/get_together/index.html | 54 ++++++++++++++++++- get_together/views/__init__.py | 12 +++-- 2 files changed, 60 insertions(+), 6 deletions(-) diff --git a/get_together/templates/get_together/index.html b/get_together/templates/get_together/index.html index 034a5c8..13b272e 100644 --- a/get_together/templates/get_together/index.html +++ b/get_together/templates/get_together/index.html @@ -49,13 +49,40 @@ {% else %}
- There are no events near you. + There are no events within {{ distance }}km of you. Create one now or View all events
{% endif %} + {% if closest_events %} + {% for event in closest_events %} +
+
+ +
+

{{event.event_title}}

+
+ {{ event.local_start_time }}
{{event.location_name}}
+
+ View +
+
+
+
+
+ {% endfor %} + {% endif %}
@@ -88,13 +115,36 @@ {% else %}
- There are no teams near you. + There are no teams within {{ distance }}km of you. Create one now or View all teams
{% endif %} + {% if closest_teams %} + {% for team in closest_teams %} +
+
+
+ + {{team.name}} + +

{{team.name}}

+
+
+

{{team.city}}

+
+ {{ team.members.count }} members +
+ View +
+
+
+
+
+ {% endfor %} + {% endif %}
{% else %}
diff --git a/get_together/views/__init__.py b/get_together/views/__init__.py index 8eff573..529c2e3 100644 --- a/get_together/views/__init__.py +++ b/get_together/views/__init__.py @@ -106,13 +106,17 @@ def home(request, *args, **kwards): 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'] = sorted(near_events, key=lambda searchable: location.searchable_distance_from(ll, searchable)) +# # If there aren't any teams in the user's geoip area, show them the closest ones + if context['geoip_lookup'] and len(near_events) < 1: + context['closest_events'] = sorted(Searchable.objects.filter(end_time__gte=datetime.datetime.now()), + key=lambda searchable: location.searchable_distance_from(ll, searchable))[:3] + near_teams = Team.objects.filter(city__latitude__gte=minlat, city__latitude__lte=maxlat, city__longitude__gte=minlng, city__longitude__lte=maxlng) context['near_teams'] = sorted(near_teams, key=lambda team: location.team_distance_from(ll, team)) -# # 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') +# # If there aren't any teams in the user's geoip area, show them the closest ones + if context['geoip_lookup'] and len(near_teams) < 1: + context['closest_teams'] = sorted(Team.objects.all(), key=lambda team: location.team_distance_from(ll, team))[:3] except Exception as err: print("Error looking up nearby teams and events", err) traceback.print_exc()