Enhanced Map control

This commit is contained in:
Martin Bauer 2013-09-26 21:56:32 +02:00
parent 204c8773a2
commit 11135b5592
43 changed files with 574 additions and 563 deletions

Binary file not shown.

View File

Before

Width:  |  Height:  |  Size: 37 KiB

After

Width:  |  Height:  |  Size: 37 KiB

View File

Before

Width:  |  Height:  |  Size: 42 KiB

After

Width:  |  Height:  |  Size: 42 KiB

View File

@ -53,7 +53,7 @@ USE_TZ = True
# Absolute filesystem path to the directory that will hold user-uploaded files. # Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/var/www/example.com/media/" # Example: "/var/www/example.com/media/"
MEDIA_ROOT = PROJECT_PATH + "/../media/" MEDIA_ROOT = PROJECT_PATH + "/media/"
# URL that handles the media served from MEDIA_ROOT. Make sure to use a # URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash. # trailing slash.

View File

@ -5,8 +5,8 @@ from eventplanner.models import Event, EventParticipation
class EventParticipationInline(admin.TabularInline): class EventParticipationInline(admin.TabularInline):
model = EventParticipation model = EventParticipation
extra = 1 extra = 1
readonly_fields = ('musician',) readonly_fields = ('user',)
fields = ( 'musician', 'status', 'comment', ) fields = ( 'user', 'status', 'comment', )
has_add_permission = lambda self, req : False has_add_permission = lambda self, req : False
has_delete_permission = lambda self, req, obj : False has_delete_permission = lambda self, req, obj : False

View File

@ -1,7 +1,8 @@
from django.db import models from django.db import models
from django.utils.translation import ugettext as _ from django.utils.translation import ugettext as _
from django.contrib.auth.models import User
from musicians.models import Musician
from datetime import datetime from datetime import datetime
from location_field.models import PlainLocationField from location_field.models import PlainLocationField
@ -26,9 +27,7 @@ class Event ( models.Model ):
time = models.TimeField( null=True, blank=True, verbose_name = _("time") ) time = models.TimeField( null=True, blank=True, verbose_name = _("time") )
meeting_time = models.TimeField( null=True, blank=True, verbose_name = _("meeting_time") ) meeting_time = models.TimeField( null=True, blank=True, verbose_name = _("meeting_time") )
participants = models.ManyToManyField( User, through='EventParticipation', verbose_name=_("participants") )
participants = models.ManyToManyField( Musician, through='EventParticipation', verbose_name=_("participants") )
def __unicode__(self): def __unicode__(self):
return self.title + " ( " + self.get_type_display() + " ) " return self.title + " ( " + self.get_type_display() + " ) "
@ -39,9 +38,9 @@ class Event ( models.Model ):
super(Event, self).save(*args, **kwargs) super(Event, self).save(*args, **kwargs)
# Create a "Don't Know" participation for each Musician # Create a "Don't Know" participation for each Musician
for m in Musician.objects.all(): for u in User.objects.all():
if not m in self.participants.all(): if not u in self.participants.all():
EventParticipation.objects.create( event=self, musician = m, status='?', comment = '' ) EventParticipation.objects.create( event=self, user = u, status='?', comment = '' )
@property @property
def displaytime(self): def displaytime(self):
@ -60,19 +59,18 @@ class EventParticipation( models.Model ):
) )
event = models.ForeignKey( Event, verbose_name=_("event") ) event = models.ForeignKey( Event, verbose_name=_("event") )
musician = models.ForeignKey( Musician, verbose_name=_("musician") ) user = models.ForeignKey( User, verbose_name=_("user") )
status = models.CharField ( max_length=3, choices = OPTIONS, default='?', verbose_name=_("status") ) status = models.CharField ( max_length=3, choices = OPTIONS, default='?', verbose_name=_("status") )
comment = models.CharField ( max_length=64, blank=True, verbose_name=_("comment") ) comment = models.CharField ( max_length=64, blank=True, verbose_name=_("comment") )
def get_username(self):
def get_musician_username(self): return self.user.username
return self.musician.user.username
@staticmethod @staticmethod
def hasUserSetParticipationForAllEvents( user ): def hasUserSetParticipationForAllEvents( user ):
futurePart = EventParticipation.objects.filter( event__date__gte = datetime.now() ) futurePart = EventParticipation.objects.filter( event__date__gte = datetime.now() )
maybeObjects = futurePart.filter( musician__user = user ).filter( status = '?' )
maybeObjects = futurePart.filter( user = user ).filter( status = '?' )
if len( maybeObjects ) > 0: if len( maybeObjects ) > 0:
return False return False
else: else:
@ -80,16 +78,16 @@ class EventParticipation( models.Model ):
@staticmethod @staticmethod
def get_or_create( musician , event ): def get_or_create( user , event ):
try: try:
result = EventParticipation.objects.get( event = event, musician = musician ) result = EventParticipation.objects.get( event = event, user = user )
except EventParticipation.DoesNotExist: except EventParticipation.DoesNotExist:
result = EventParticipation.objects.create( event = event, musician = musician, status='?', comment = '' ) result = EventParticipation.objects.create( event = event, user = user, status='?', comment = '' )
return result return result
class Meta: class Meta:
unique_together = ("event", "musician") unique_together = ("event", "user")
permissions = ( permissions = (
("change_others_participation", _("Can modify participation status of other users") ), ("change_others_participation", _("Can modify participation status of other users") ),
) )

View File

@ -5,20 +5,19 @@ from models import EventParticipation
class ParticipationSerializer(serializers.ModelSerializer): class ParticipationSerializer(serializers.ModelSerializer):
event = serializers.PrimaryKeyRelatedField( many=False, read_only = False ) event = serializers.PrimaryKeyRelatedField( many=False, read_only = False )
musician = serializers.Field( source='get_musician_username' ) user = serializers.Field( source='get_username' )
# musician = serializers.PrimaryKeyRelatedField( many=False, read_only = False )
def get_identity(self, data): def get_identity(self, data):
""" This hook is required for bulk update. """ """ This hook is required for bulk update. """
try: try:
return ( data.get('event', None), data.get('musician') ) return ( data.get('event', None), data.get('user') )
except AttributeError: except AttributeError:
return None return None
class Meta: class Meta:
model = EventParticipation model = EventParticipation
fields = ('event', 'musician', 'status', 'comment') fields = ('event', 'user', 'status', 'comment')

View File

@ -44,7 +44,7 @@
function putStatus( button, status ) { function putStatus( button, status ) {
p = button.parent(); p = button.parent();
putObject = [ { "event": p.data("event-id"), putObject = [ { "event": p.data("event-id"),
"musician": p.data("username"), "user": p.data("username"),
"status": status } ]; "status": status } ];
request = $.ajax( { request = $.ajax( {
@ -66,7 +66,7 @@
putObject = [ { "event": $(this).data("event-id"), putObject = [ { "event": $(this).data("event-id"),
"musician": $(this).data("username"), "user": $(this).data("username"),
"comment": $(this).val() } ]; "comment": $(this).val() } ];
$.ajax( { $.ajax( {

View File

@ -72,7 +72,7 @@
dataObject = { dataObject = {
"event" : $(this).data("event"), "event" : $(this).data("event"),
"musician": $(this).data("musician"), "user" : $(this).data("username"),
"status" : $(this).children("button").data("status") "status" : $(this).children("button").data("status")
}; };
@ -117,7 +117,7 @@
<tr> <tr>
<th> Termin </th> <th> Termin </th>
<th> Datum </th> <th> Datum </th>
{% for name in musicianNames %} {% for name in usernames %}
<th> {{ name|capfirst }} </th> <th> {{ name|capfirst }} </th>
{% endfor %} {% endfor %}
@ -133,7 +133,7 @@
{% for p in event.participation %} {% for p in event.participation %}
<td class="center userEventTableData" data-musician="{{p.musician.user.username}}" data-event="{{event.pk}}"> <td class="center userEventTableData" data-username="{{p.user.username}}" data-event="{{event.pk}}">
{% if p.status == "Yes" %} {% if p.status == "Yes" %}
<button class="btn btn-mini btn-success eventButton" title="{{p.comment}}" data-status="{{p.status}}"> <button class="btn btn-mini btn-success eventButton" title="{{p.comment}}" data-status="{{p.status}}">
{% if p.comment %} <i class="icon-comment icon-white"></i> {% endif %} {% if p.comment %} <i class="icon-comment icon-white"></i> {% endif %}

View File

@ -1,12 +1,13 @@
from django.shortcuts import render, get_object_or_404, redirect from django.shortcuts import render, redirect
from django.http import HttpResponse from django.http import HttpResponse
from django.contrib.auth.decorators import login_required from django.contrib.auth.decorators import login_required
from django.forms.models import ModelForm from django.forms.models import ModelForm
from django.forms import TextInput from django.forms import TextInput
from models import Event, EventParticipation from models import Event, EventParticipation
from musicians.models import Musician from django.contrib.auth.models import User
from serializers import ParticipationSerializer from serializers import ParticipationSerializer
@ -29,14 +30,13 @@ def event_api( request, username = None, eventId = None ):
try: try:
participationQs = EventParticipation.objects.filter( event__date__gte = datetime.date.today() ) participationQs = EventParticipation.objects.filter( event__date__gte = datetime.date.today() )
if username: if username:
participationQs = EventParticipation.objects.filter( musician__user__username = username ) participationQs = EventParticipation.objects.filter( user__username = username )
if eventId: if eventId:
participationQs = participationQs.filter( event__pk = eventId ) participationQs = participationQs.filter( event__pk = eventId )
except EventParticipation.DoesNotExist: except EventParticipation.DoesNotExist:
return HttpResponse( status=404 ) return HttpResponse( status=404 )
if request.method == 'GET': if request.method == 'GET':
serializer = ParticipationSerializer( participationQs ) serializer = ParticipationSerializer( participationQs )
return Response( serializer.data ) return Response( serializer.data )
@ -45,7 +45,7 @@ def event_api( request, username = None, eventId = None ):
serializer = ParticipationSerializer ( participationQs, data = request.DATA, many=True ) serializer = ParticipationSerializer ( participationQs, data = request.DATA, many=True )
if serializer.is_valid(): if serializer.is_valid():
for serializedObject in serializer.object: for serializedObject in serializer.object:
if serializedObject.musician.user != request.user: if serializedObject.user != request.user:
if not request.user.has_perm('change_others_participation') : if not request.user.has_perm('change_others_participation') :
return Response( status = status.HTTP_403_FORBIDDEN ) return Response( status = status.HTTP_403_FORBIDDEN )
@ -73,10 +73,8 @@ def eventplanning( request ):
# All events in the future sorted by date # All events in the future sorted by date
all_future_events = list ( Event.objects.filter( date__gte = datetime.date.today() ) ) all_future_events = list ( Event.objects.filter( date__gte = datetime.date.today() ) )
musician = get_object_or_404( Musician, user=request.user )
for e in all_future_events: for e in all_future_events:
e.participation = EventParticipation.get_or_create( event = e, musician = musician ) e.participation = EventParticipation.get_or_create( event = e, user = request.user )
context = { 'events' : all_future_events } context = { 'events' : all_future_events }
return render ( request, 'eventplanner/eventplanning_view.html', context ) return render ( request, 'eventplanner/eventplanning_view.html', context )
@ -86,17 +84,16 @@ def eventplanning( request ):
@login_required @login_required
def events_grid( request ): def events_grid( request ):
musicians = Musician.objects.all() usernames = [ u.username for u in User.objects.all() ]
musicianNames = [ m.user.username for m in musicians ]
all_future_events = list ( Event.objects.filter( date__gte = datetime.date.today() ) ) all_future_events = list ( Event.objects.filter( date__gte = datetime.date.today() ) )
for e in all_future_events: for e in all_future_events:
e.participation = [ EventParticipation.get_or_create( event = e, musician = m ) for m in musicians ] e.participation = [ EventParticipation.get_or_create( event = e, user = u ) for u in User.objects.all() ]
context = { 'events': all_future_events,
'usernames' : usernames }
context = { 'events': all_future_events,
'musicianNames' : musicianNames }
return render ( request, 'eventplanner/events_grid.html', context ) return render ( request, 'eventplanner/events_grid.html', context )

View File

@ -13,9 +13,11 @@
{% block content %} {% block content %}
{% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/portfolio.css" media="screen, projection">{% endaddtoblock %} {% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/portfolio.css" media="screen, projection">{% endaddtoblock %}
{% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/lib/isotope.css">{% endaddtoblock %}
{% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/lib/animate.css">{% endaddtoblock %}
{% addtoblock "css" %} {% addtoblock "css" %}
<style> <style>
.addressbook_entry { .addressbook_entry {
@ -110,12 +112,11 @@
<div class="row"> <div class="row">
<div class="span12"> <div class="span12">
<div id="gallery_container" > <div id="gallery_container" >
{% for m in musicians %} {% for m in musicians %}
<div class="photo isotope-item addressbook_entry {% if m.isDeepBrass %} unterstimme {% elif m.isHighBrass %} oberstimme {% else %} rest {% endif %} "> <div class="photo isotope-item addressbook_entry {% if m.isDeepBrass %} unterstimme {% elif m.isHighBrass %} oberstimme {% else %} rest {% endif %} ">
<div class="span1"> <div class="span1">
<img src="{{MEDIA_URL}}/user_images/{{m.user}}_circle.png" class="img-circle picture"> <img src="{{MEDIA_URL}}/user_images/{{m.user}}_thumb.png" class="img-circle picture">
</div> </div>
<div class="name"> <div class="name">

View File

@ -0,0 +1,148 @@
#map{
margin: 0;
width: 100%;
height: 480px;
}
#concert_route .map iframe{
display: block;
}
#concert_route .map .box_wrapp{
position: absolute;
margin: 0;
box-shadow: 0 0 7px 0 rgba(26, 26, 26, 0.4);
padding: 33px 0 33px;
background: white;
top: 67%;
border-radius: 4px;
}
#concert_route .map .box_wrapp .box_cont{
margin: 0 auto;
width: 76%;
}
#concert_route .map .box_wrapp .head{
width: 100%;
margin-bottom: 17px;
overflow: hidden;
}
#concert_route .map .box_wrapp .head h6{
font-size: 24px;
margin: 0;
font-style: italic;
float: left;
padding-bottom: 2px;
border-bottom: 1px solid;
font-weight: normal;
}
#concert_route .map .box_wrapp ul.street{
list-style: none;
margin: 0;
padding:0;
}
#concert_route .map .box_wrapp ul.street li{
color: #777777;
font-size: 14px;
}
#concert_route .map .box_wrapp ul.street li.icon{
margin-top: 3px;
}
#concert_route .map .box_wrapp ul.street li.icon span.ico1{
float: left;
height: 20px;
}
#concert_route .map .box_wrapp ul.street li.icon span.ico2{
float: left;
height: 20px;
background-position: 0px -23px;
}
#concert_route .map .box_wrapp ul.street li.icon .text{
font-size: 15px;
color: #777777;
margin-left: 6px;
}
#concert_route .map .box_wrapp ul.street li.icon a:hover{
color: #187CCC;
-webkit-transition: all .2s;
-moz-transition: all .2s;
-ms-transition: all .2s;
transition: all .2s;
}
#concert_route .map .box_wrapp ul.street li.icontop{
margin-top: 13px;
}
#concert_route .map .box_wrapp .headbottom{
margin-top: 42px;
}
#concert_route .map .box_wrapp p{
color: #777777;
font-size: 14px;
margin-bottom: 32px;
}
#concert_route .map .box_wrapp a.btn{
text-transform: uppercase;
color: #fff;
font-size: 15px;
background: #187CCC;
text-shadow: none;
padding: 6px 0 6px;
font-weight: bold;
border: 0 none;
box-shadow: none;
border-radius: 3px;
margin: 0 auto;
margin-top: 20px;
display: block;
width: 56%;
-webkit-transition: background linear .2s, box-shadow linear .2s;
-moz-transition: background linear .2s, box-shadow linear .2s;
-o-transition: background linear .2s, box-shadow linear .2s;
transition: background linear .2s, box-shadow linear .2s;
}
#concert_route .map .box_wrapp a.btn:hover{
background: #252528;
}
.concert_routeicos{
background: url('../img/concert_route_icos.png') no-repeat;
width: 24px;
height: 44px;
}
/* Responsive
-------------------------------------------------- */
/* Large desktop */
@media (min-width: 1200px) {
}
@media (min-width: 980px) {
}
@media (max-width: 979px) {
}
/* Portrait tablet to landscape and desktop */
@media (min-width: 768px) and (max-width: 979px) {
}
/* Landscape phone to portrait tablet */
@media (max-width: 767px) {
#concert_route .map .box_wrapp{
width: 90%;
position: relative;
margin: 0 auto 80px;
}
#concert_route .map .box_wrapp .box_cont{
}
#concert_route .map iframe{
display: none;
}
#concert_route .map .box_wrapp a.btn{
width: 65%;
}
}
/* Landscape phones and down */
@media (max-width: 480px) {
#concert_route .map .box_wrapp{
width: 100%;
}
}

View File

@ -1,240 +0,0 @@
#contact {
margin-top: 70px;
}
#contact .contact{
margin: 40px 0 100px 0;
}
#contact .contact p{
color: #939394;
font-size: 19px;
margin-bottom: 47px;
font-style: italic;
line-height: 24px;
}
#contact .form{
margin: 0;
}
#contact .contact form{
margin: 0;
}
#contact .form .box{
margin: 0;
}
#contact .form .box input[type="text"]{
padding-left: 39px;
margin-bottom: 10px;
color: black;
height: 29px;
border-radius: 3px;
width: 89%;
}
#contact .form .box input.name{
background: url('../img/formname.png') #fff no-repeat 5px;
}
#contact .form .box input.mail{
background: url('../img/formmail.png') #fff no-repeat 5px;
}
#contact .form .box input.phone{
background: url('../img/formphone.png') #fff no-repeat 5px;
}
#contact .form .box_r{
float: right;
}
#contact .form .box textarea{
padding: 11px;
width: 94%;
margin: 0;
border-radius: 3px;
height: 113px;
}
#contact .contact .submit{
margin: 0;
}
#contact .contact .submit .box{
margin: 0
}
#contact .contact .submit label.checkbox{
color: #394350;
font-style: 14px;
}
#contact .contact .submit .right{
float: right;
}
#contact .contact .submit .right input[type="submit"]{
float: right;
text-transform: uppercase;
color: #fff;
background: #187CCC;
font-size: 15px;
padding: 4px 12px;
border: 0 none;
border-radius: 3px;
-webkit-transition: background linear .2s, box-shadow linear .2s;
-moz-transition: background linear .2s, box-shadow linear .2s;
-o-transition: background linear .2s, box-shadow linear .2s;
transition: background linear .2s, box-shadow linear .2s;
}
#contact .contact .submit .right input[type="submit"]:hover{
background: #252528;
}
#contact .map{
margin: 0;
}
#contact .map iframe{
display: block;
}
#contact .map .box_wrapp{
position: absolute;
margin: 0;
box-shadow: 0 0 7px 0 rgba(26, 26, 26, 0.4);
padding: 33px 0 33px;
background: white;
top: 70%;
border-radius: 4px;
}
#contact .map .box_wrapp .box_cont{
margin: 0 auto;
width: 76%;
}
#contact .map .box_wrapp .head{
width: 100%;
margin-bottom: 17px;
overflow: hidden;
}
#contact .map .box_wrapp .head h6{
font-size: 24px;
margin: 0;
font-style: italic;
float: left;
padding-bottom: 2px;
border-bottom: 1px solid;
font-weight: normal;
}
#contact .map .box_wrapp ul.street{
list-style: none;
margin: 0;
padding:0;
}
#contact .map .box_wrapp ul.street li{
color: #777777;
font-size: 14px;
}
#contact .map .box_wrapp ul.street li.icon{
margin-top: 3px;
}
#contact .map .box_wrapp ul.street li.icon span.ico1{
float: left;
height: 20px;
}
#contact .map .box_wrapp ul.street li.icon span.ico2{
float: left;
height: 20px;
background-position: 0px -23px;
}
#contact .map .box_wrapp ul.street li.icon .text{
font-size: 15px;
color: #777777;
margin-left: 6px;
}
#contact .map .box_wrapp ul.street li.icon a:hover{
color: #187CCC;
-webkit-transition: all .2s;
-moz-transition: all .2s;
-ms-transition: all .2s;
transition: all .2s;
}
#contact .map .box_wrapp ul.street li.icontop{
margin-top: 13px;
}
#contact .map .box_wrapp .headbottom{
margin-top: 42px;
}
#contact .map .box_wrapp p{
color: #777777;
font-size: 14px;
margin-bottom: 32px;
}
#contact .map .box_wrapp a.btn{
text-transform: uppercase;
color: #fff;
font-size: 15px;
background: #187CCC;
text-shadow: none;
padding: 6px 0 6px;
font-weight: bold;
border: 0 none;
box-shadow: none;
border-radius: 3px;
margin: 0 auto;
margin-top: 20px;
display: block;
width: 56%;
-webkit-transition: background linear .2s, box-shadow linear .2s;
-moz-transition: background linear .2s, box-shadow linear .2s;
-o-transition: background linear .2s, box-shadow linear .2s;
transition: background linear .2s, box-shadow linear .2s;
}
#contact .map .box_wrapp a.btn:hover{
background: #252528;
}
.contacticos{
background: url('../img/contact_icos.png') no-repeat;
width: 24px;
height: 44px;
}
/* Responsive
-------------------------------------------------- */
/* Large desktop */
@media (min-width: 1200px) {
}
@media (min-width: 980px) {
}
@media (max-width: 979px) {
}
/* Portrait tablet to landscape and desktop */
@media (min-width: 768px) and (max-width: 979px) {
}
/* Landscape phone to portrait tablet */
@media (max-width: 767px) {
#contact .contact .submit .box{
margin: 10px 0 24px;
}
#contact .form .box input[type="text"]{
width: 87%;
}
#contact .contact .submit .right input[type="submit"]{
margin: 0 auto;
float: none;
width: 53%;
display: block;
padding: 7px;
}
#contact .map .box_wrapp{
width: 90%;
position: relative;
margin: 0 auto 80px;
}
#contact .map .box_wrapp .box_cont{
}
#contact .map iframe{
display: none;
}
#contact .map .box_wrapp a.btn{
width: 65%;
}
}
/* Landscape phones and down */
@media (max-width: 480px) {
#contact .contact .submit .right input[type="submit"]{
width: 60%;
}
#contact .map .box_wrapp{
width: 100%;
}
}

View File

Before

Width:  |  Height:  |  Size: 183 KiB

After

Width:  |  Height:  |  Size: 183 KiB

View File

Before

Width:  |  Height:  |  Size: 139 KiB

After

Width:  |  Height:  |  Size: 139 KiB

View File

Before

Width:  |  Height:  |  Size: 286 KiB

After

Width:  |  Height:  |  Size: 286 KiB

View File

Before

Width:  |  Height:  |  Size: 88 KiB

After

Width:  |  Height:  |  Size: 88 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 253 KiB

View File

Before

Width:  |  Height:  |  Size: 172 KiB

After

Width:  |  Height:  |  Size: 172 KiB

View File

Before

Width:  |  Height:  |  Size: 317 KiB

After

Width:  |  Height:  |  Size: 317 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 247 KiB

View File

Before

Width:  |  Height:  |  Size: 180 KiB

After

Width:  |  Height:  |  Size: 180 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 197 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 90 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 180 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 62 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 86 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 35 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

View File

Before

Width:  |  Height:  |  Size: 304 KiB

After

Width:  |  Height:  |  Size: 304 KiB

View File

Before

Width:  |  Height:  |  Size: 288 KiB

After

Width:  |  Height:  |  Size: 288 KiB

View File

Before

Width:  |  Height:  |  Size: 168 KiB

After

Width:  |  Height:  |  Size: 168 KiB

View File

Before

Width:  |  Height:  |  Size: 159 KiB

After

Width:  |  Height:  |  Size: 159 KiB

View File

Before

Width:  |  Height:  |  Size: 88 KiB

After

Width:  |  Height:  |  Size: 88 KiB

View File

@ -135,21 +135,21 @@ $.ajaxSetup({
<section id="feature_slider" class=""> <section id="feature_slider" class="">
<article class="slide" id="showcasing" style="background: url('{{STATIC_URL}}/img/backgrounds/silver.jpg') repeat-x top center;"> <article class="slide" id="showcasing" style="background: url('{{STATIC_URL}}/img/backgrounds/silver.jpg') repeat-x top center;">
<img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/blechreiz01/gruppe.png" /> <img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/gruppe.png" />
<div class="info"> <div class="info">
<h2>Blechreiz</h2> <h2>Blechreiz</h2>
<h3>12 Musiker für einen guten Zweck </h3> <h3>12 Musiker für einen guten Zweck </h3>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/ticotico2.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/ticotico2.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/daempfer.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/daempfer.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
@ -157,35 +157,35 @@ $.ajaxSetup({
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/andi.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/andi.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/andi2.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/andi2.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/applaus.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/applaus.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/eindruck.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/eindruck.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
</div> </div>
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/publikum.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/publikum.jpg') repeat-x top center;">
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Termine</a> <a href="features.html">Termine</a>
@ -193,12 +193,12 @@ $.ajaxSetup({
</article> </article>
<article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/spielen2.jpg') repeat-x top center;"> <article class="slide" id="tour" style="background: url('{{STATIC_URL}}/img/slides/spielen2.jpg') repeat-x top center;">
</article> </article>
<article class="slide" id="showcasing" style="background: url('{{STATIC_URL}}/img/backgrounds/black_red_01.jpg') repeat-x top center;"> <article class="slide" id="showcasing" style="background: url('{{STATIC_URL}}/img/backgrounds/black_red_01.jpg') repeat-x top center;">
<img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/blechreiz01/tuba.png" /> <img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/tuba.png" />
<div class="info"> <div class="info">
<h2>Konzerte</h2> <h2>Konzerte</h2>
<a href="features.html">Nächste Termine</a> <a href="features.html">Nächste Termine</a>
@ -212,9 +212,6 @@ $.ajaxSetup({
{% block content %} {% endblock %} {% block content %} {% endblock %}
<!-- footer --> <!-- footer -->
<footer id="footer"> <footer id="footer">
<div class="container"> <div class="container">

View File

@ -0,0 +1,177 @@
{% comment %}
Displays google map with directions to next conert
Context:
Coordinates or textual adresses:
{{routeInfo.origin}}
{{routeInfo.destination}}
Event object:
{{nextConcert}}
{% endcomment %}
{% load sekizai_tags staticfiles %}
{% if hasNextConcertInfo %}
{% addtoblock "css" strip %}<link rel="stylesheet" href="{{STATIC_URL}}/css/concert_route.css" type="text/css" media="screen" />{% endaddtoblock %}
{% addtoblock "js" strip %}<script type="text/javascript" src="//maps.google.com/maps/api/js?sensor=false&amp;language=de"></script>{% endaddtoblock %}
{% addtoblock "js" %}
<script type="text/javascript">
function OpenWindowControl(controlDiv, map) {
// Set CSS styles for the DIV containing the control
// Setting padding to 5 px will offset the control
// from the edge of the map
controlDiv.style.paddingTop = '6px';
// Set CSS for the control border
var controlUI = document.createElement('div');
controlUI.style.backgroundColor = 'white';
controlUI.style.borderStyle = 'solid';
controlUI.style.borderWidth = '1px';
controlUI.style.cursor = 'pointer';
controlUI.style.textAlign = 'center';
controlUI.title = 'Fenster mit Konzert Info anzeigen';
controlDiv.appendChild(controlUI);
// Set CSS for the control interior
var controlText = document.createElement('div');
controlText.style.fontFamily = 'Arial,sans-serif';
controlText.style.fontSize = '12px';
controlText.style.paddingLeft = '4px';
controlText.style.paddingRight = '4px';
controlText.innerHTML = 'Konzert Info anzeigen';
controlUI.appendChild(controlText);
google.maps.event.addDomListener(controlUI, 'click', function() {
$("#map_box").show();
});
}
function ShowTargetControl(controlDiv, map) {
// Set CSS styles for the DIV containing the control
// Setting padding to 5 px will offset the control
// from the edge of the map
controlDiv.style.paddingTop = '6px';
controlDiv.style.paddingRight = '6px';
// Set CSS for the control border
var controlUI = document.createElement('div');
controlUI.style.backgroundColor = 'white';
controlUI.style.borderStyle = 'solid';
controlUI.style.borderWidth = '1px';
controlUI.style.cursor = 'pointer';
controlUI.style.textAlign = 'center';
controlUI.title = 'Zum Zielpunkt springen';
controlDiv.appendChild(controlUI);
// Set CSS for the control interior
var controlText = document.createElement('div');
controlText.style.fontFamily = 'Arial,sans-serif';
controlText.style.fontSize = '12px';
controlText.style.paddingLeft = '4px';
controlText.style.paddingRight = '4px';
controlText.innerHTML = 'Konzertort anzeigen';
controlUI.appendChild(controlText);
var target = new google.maps.LatLng( {{routeInfo.destination}} );
google.maps.event.addDomListener(controlUI, 'click', function() {
map.setMapTypeId( google.maps.MapTypeId.HYBRID );
map.setZoom( 19 );
map.setCenter( target );
});
}
$(document).ready(function() {
var m = $("#map")[0];
var myOptions = {
zoom: 10,
mapTypeId: google.maps.MapTypeId.ROAD,
zoomControl: false
}
var directionsService = new google.maps.DirectionsService();
var directionsDisplay = new google.maps.DirectionsRenderer();
var map = new google.maps.Map(m, myOptions);
directionsDisplay.setMap( map );
var request = {
origin: "{{routeInfo.origin}}",
destination: "{{routeInfo.destination}}",
travelMode: google.maps.DirectionsTravelMode.DRIVING
}
directionsService.route(request, function(response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
var leg = response.routes[0].legs[0];
$("#route_duration").html( leg.duration.text );
$("#route_distance").html( leg.distance.text ) ;
}
});
var showInfoControlDiv = document.createElement('div');
var showInfoControl = new OpenWindowControl(showInfoControlDiv, map);
showInfoControlDiv.index = 1;
map.controls[google.maps.ControlPosition.TOP_RIGHT].push( showInfoControlDiv );
var showTargetControlDiv = document.createElement('div');
var showTargetControl = new ShowTargetControl(showTargetControlDiv, map);
showTargetControlDiv.index = 2;
map.controls[google.maps.ControlPosition.TOP_RIGHT].push(showTargetControlDiv);
$("#map_box a").click( function() {
$("#map_box").hide();
});
}
);
</script>
{% endaddtoblock %}
<div id="concert_route">
<div id="map"></div>
<div id="map_box" class="row map">
<div class="container">
<div id="route_info_box" class="span5 box_wrapp">
<div class="box_cont">
<div class="head">
<h6>Fahrt zum Konzert:</h6>
</div>
Nächstes Konzert ist in {{nextConcert.location}} <br/> am {{nextConcert.date}} um {{nextConcert.time | time:"H:i" }} <br/>
{% if nextConcert.meeting_time %} Treffpunkt ist um {{ nextConcert.meeting_time | time:"H:i" }} <br/> {% endif %}
<table>
<tr> <td> Fahrzeit:</td> <td> <span id="route_duration"></span> </td> </tr>
<tr> <td> Strecke: </td> <td> <span id="route_distance"></span> </td> </tr>
</table>
<a class="btn" >Schliessen</a>
</div>
</div>
</div>
</div>
</div>
{% endif %}

View File

@ -0,0 +1,77 @@
{% load sekizai_tags staticfiles %}
{% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/lib/animate.css" media="screen, projection">{% endaddtoblock %}
{% addtoblock "css" strip %}<link rel="stylesheet" href="{{STATIC_URL}}/css/coming-soon.css" type="text/css" media="screen" />{% endaddtoblock %}
{% if countdown %}
{% addtoblock "js" %}
<script type="text/javascript">
$(function () {
function callback(event) {
$this = $(this);
$this.find('span#'+event.type).html(event.value);
switch(event.type) {
case "seconds":
case "minutes":
case "hours":
case "days":
case "weeks":
case "daysLeft":
case "finished":
}
}
$('div#clock').countdown(new Date().valueOf() + {{ countdown.epoch }} , callback);
});
</script>
{% endaddtoblock %}
<div id="coming_soon">
<div class="head">
<div class="container">
<div class="span6 text">
<h4>Der nächste Termin:</h4>
<p>
{{countdown.event.title}} ist am {{countdown.event.date}}
um {{countdown.event.displaytime | time:"H:i" }}
in {{countdown.event.location}}
<br/>
{% if countdown.participation == "?" %}
Du hast dich noch nicht für diesen Termin eingetragen!
{% elif countdown.participation == "Yes" %}
Du hast für diesen Termin zugesagt.
{% elif countdown.participation == "No" %}
Du hast für diesen Termin abgesagt.
{%endif %}
</p>
</div>
<div class="span6 count" id="clock">
<div class="box last">
<div class="circle"> <span id="seconds"></span> </div>
<p>Sekunden</p>
</div>
<div class="box">
<div class="circle"> <span id="minutes"></span> </div>
<p>Minuten</p>
</div>
<div class="box">
<div class="circle"> <span id="hours"></span> </div>
<p>Stunden</p>
</div>
<div class="box">
<div class="circle"> <span id="days"></span> </div>
<p>Tage</p>
</div>
</div>
</div>
</div>
</div>
{% endif %}

View File

@ -3,261 +3,14 @@
{% load sekizai_tags staticfiles %} {% load sekizai_tags staticfiles %}
{% block feature_slider %} {% block feature_slider %}
{% include "website/slider_intern_area.html" %}
{% addtoblock "css" %}
<style>
#eventManagement.slide .info {
position: absolute;
top: 260px;
left: 8%;
width: 24%;
display: none;
z-index: 10;
}
#eventManagement.slide .info a {
text-transform: uppercase;
color: rgb(255, 255, 255);
background: none repeat scroll 0% 0% rgb(166, 3, 3);
font-size: 25px;
font-weight: bolder;
padding: 15px 24px;
border: 0px none;
border-radius: 6px 6px 6px 6px;
transition: background 0.2s linear 0s, box-shadow 0.2s linear 0s;
}
#eventManagement.slide .info .subtitle {
margin: 25px;
font-size: 20px;
font-style: italic;
}
#eventManagement.slide .info .subtitlebg
{
background: none repeat scroll 0% 0% rgb(243, 243, 243);
padding: 15px 24px;
border-radius: 6px 6px 6px 6px;
}
</style>
{% endaddtoblock %}
<section id="feature_slider" class="">
<article class="slide" id="eventManagement" style="background: url('{{STATIC_URL}}/img/slides/blechreiz01/andi2.jpg') repeat-x top center;">
<div class="info">
<a href="/events">Einsatzplanung</a>
<div class="subtitle subtitlebg">
{% if hasParticipationSetForAllEvents %}
Sehr gut - du hast dich für alles eingetragen
{% else %}
Du hast dich noch nicht für alle Termine eingetragen!!
{% endif %}
</div>
</div>
</article>
<article class="slide" id="eventManagement" style="background: url('{{STATIC_URL}}/img/backgrounds/silver.jpg') repeat-x top center;">
<img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/blechreiz01/gruppe.png" />
<div class="info">
<a href="/messages">Forum</a>
<div class="subtitle"> Nachricht an alle schreiben... </div>
</div>
</article>
</section>
{% endblock %} {% endblock %}
{% block content %} {% block content %}
{% addtoblock "css" strip %}<link rel="stylesheet" type="text/css" href="{{STATIC_URL}}/css/lib/animate.css" media="screen, projection">{% endaddtoblock %} {% include "website/event_countdown.html" %}
{% addtoblock "css" strip %}<link rel="stylesheet" href="{{STATIC_URL}}/css/coming-soon.css" type="text/css" media="screen" />{% endaddtoblock %} {% include "website/concert_route.html" %}
{% addtoblock "css" strip %}<link rel="stylesheet" href="{{STATIC_URL}}/css/contact.css" type="text/css" media="screen" />{% endaddtoblock %}
{% if event %}
{% addtoblock "js" %}
<script type="text/javascript">
$(function () {
function callback(event) {
$this = $(this);
$this.find('span#'+event.type).html(event.value);
switch(event.type) {
case "seconds":
case "minutes":
case "hours":
case "days":
case "weeks":
case "daysLeft":
case "finished":
}
}
$('div#clock').countdown(new Date().valueOf() + {{epoch}} , callback);
});
</script>
{% endaddtoblock %}
<div id="coming_soon">
<div class="head">
<div class="container">
<div class="span6 text">
<h4>Der nächste Termin:</h4>
<p>
{{event.title}} ist am {{event.date}} um {{event.displaytime | time:"H:i" }} in {{event.location}}
<br/>
{% if participation == "?" %}
Du hast dich noch nicht für diesen Termin eingetragen!
{% elif participation == "Yes" %}
Du hast für diesen Termin zugesagt.
{% elif participation == "No" %}
Du hast für diesen Termin abgesagt.
{%endif %}
</p>
</div>
<div class="span6 count" id="clock">
<div class="box last">
<div class="circle">
<span id="seconds"></span>
</div>
<p>Sekunden</p>
</div>
<div class="box">
<div class="circle">
<span id="minutes"></span>
</div>
<p>Minuten</p>
</div>
<div class="box">
<div class="circle">
<span id="hours"></span>
</div>
<p>Stunden</p>
</div>
<div class="box">
<div class="circle">
<span id="days"></span>
</div>
<p>Tage</p>
</div>
<!-- <div class="box">
<div class="circle">
<span id="weeks"></span>
</div>
<p>Weeks</p>
</div> -->
</div>
</div>
</div>
</div>
{% endif %}
{% addtoblock "js" %}
<script type="text/javascript" src="//maps.google.com/maps/api/js?sensor=false&amp;language=de"></script>
<script type="text/javascript" src="{{STATIC_URL}}/js/jquery-ui-1.10.0.custom.min.js" ></script>
{% if hasNextConcertInfo %}
<script type="text/javascript">
// Kartenparameter beim Laden der Seite festlegen
$(document).ready(function() {
// Das Element für die Anzeige suchen
var m = $("#map")[0];
// Mittelpunkt der Karte
var myLatlng = new google.maps.LatLng(49.340174,10.890595);
var myOptions = {
zoom: 10,
center: myLatlng,
mapTypeId: google.maps.MapTypeId.ROAD,
}
var directionsService = new google.maps.DirectionsService();
var directionsDisplay = new google.maps.DirectionsRenderer();
var map = new google.maps.Map(m, myOptions);
directionsDisplay.setMap( map );
var request = {
origin: "{{routeInfo.origin}}",
destination: "{{routeInfo.destination}}",
travelMode: google.maps.DirectionsTravelMode.DRIVING
}
directionsService.route(request, function(response, status) {
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
var leg = response.routes[0].legs[0];
$("#route_duration").html( leg.duration.text );
$("#route_distance").html( leg.distance.text ) ;
}
});
$("#map_box a").click( function() {
$("#map_box").hide();
});
}
);
</script>
{% endif %}
{% endaddtoblock %}
{% addtoblock "css" %}
<style>
#map {
width: 100%;
height: 480px;
}
#map_box a {
margin-top: 30px;
}
</style>
{% endaddtoblock %}
{% if hasNextConcertInfo %}
<div id="contact">
<div id="map"></div>
<div id="map_box" class="row map">
<div class="container">
<div id="route_info_box" class="span5 box_wrapp">
<div class="box_cont">
<div class="head">
<h6>Fahrt zum nächsten Konzert:</h6>
</div>
Nächstes Konzert ist in {{nextConcert.location}} am {{nextConcert.date}} um {{nextConcert.time | time:"H:i" }} <br/>
{% if nextConcert.meeting_time %} Treffpunkt ist um {{ nextConcert.meeting_time | time:"H:i" }} <br/> {% endif %}
<table>
<tr> <td> Fahrzeit:</td> <td> <span id="route_duration"></span> </td> </tr>
<tr> <td> Strecke: </td> <td> <span id="route_distance"></span> </td> </tr>
</table>
<a class="btn" >Schliessen</a>
</div>
</div>
</div>
</div>
</div>
{% endif %}
{% endblock %} {% endblock %}

View File

@ -0,0 +1,99 @@
{% load sekizai_tags staticfiles %}
{% comment %}
Displays a slider linking to
/events
/messages
/addressbook
Requires context "hasParticipationSetForAllEvents"
to diplay if a user has finished the event planning
{% endcomment %}
{% addtoblock "css" %}
<style>
.slide .info {
position: absolute;
top: 260px;
left: 8%;
width: 24%;
display: none;
z-index: 10;
}
.slide .info a {
text-transform: uppercase;
color: rgb(255, 255, 255);
background: none repeat scroll 0% 0% rgb(166, 3, 3);
font-size: 25px;
font-weight: bolder;
padding: 15px 24px;
border: 0px none;
border-radius: 6px 6px 6px 6px;
transition: background 0.2s linear 0s, box-shadow 0.2s linear 0s;
}
.slide .info .subtitle {
margin: 25px;
font-size: 20px;
font-style: italic;
}
.slide .info .subtitlebg
{
background: none repeat scroll 0% 0% rgb(243, 243, 243);
padding: 10px;
padding-top: 20px;
padding-bottom: 20px;
border-radius: 8px;
}
</style>
{% endaddtoblock %}
<section id="feature_slider" class="">
<article class="slide" id="slide_eventManagement"
style="background: url('{{STATIC_URL}}/img/slides/andi2.jpg') repeat-x top center;">
<div class="info">
<a href="/events">Einsatzplanung</a>
<div class="subtitle subtitlebg">
{% if hasParticipationSetForAllEvents %}
Sehr gut - du hast dich für alles eingetragen
{% else %}
Du hast dich noch nicht für alle Termine eingetragen!!
{% endif %}
</div>
</div>
</article>
<article class="slide" id="slide_messages" style="background: url('{{STATIC_URL}}/img/backgrounds/silver.jpg') repeat-x top center;">
<img class="asset left-30 sp600 t120 z1" src="{{STATIC_URL}}/img/slides/gruppe.png" />
<div class="info">
<a href="/messages">Forum</a>
<div class="subtitle">Nachricht an alle schreiben...</div>
</div>
</article>
<article class="slide" id="adressbook"
style="background: url('{{STATIC_URL}}/img/slides/spielen2.jpg') repeat-x top center;">
<div class="info">
<a href="/addressbook">Adressbuch</a>
<div class="subtitle subtitlebg">Geburtstage, Telefonnummern, ...</div>
</div>
</article>
</section>

View File

@ -3,7 +3,6 @@
from django.shortcuts import render, redirect from django.shortcuts import render, redirect
from django.contrib.auth import authenticate, login, logout from django.contrib.auth import authenticate, login, logout
from django.core.urlresolvers import reverse
from django.http import HttpResponse from django.http import HttpResponse
from django.utils import simplejson from django.utils import simplejson
@ -15,37 +14,42 @@ from musicians.models import Musician
from datetime import datetime from datetime import datetime
@login_required @login_required
def home_view(request): def home_view(request):
context = dict() context = dict()
# Event participation for slider text
context['hasParticipationSetForAllEvents'] = EventParticipation.hasUserSetParticipationForAllEvents( request.user)
# Countdown
countdown = dict()
events = Event.objects.filter( date__gte = datetime.now() ).order_by('date')[:1] events = Event.objects.filter( date__gte = datetime.now() ).order_by('date')[:1]
if ( len(events) > 0 ): if ( len(events) > 0 ):
print "len(events): " + str( len(events ))
nextEvent = events[0] nextEvent = events[0]
part = EventParticipation.objects.filter( musician__user = request.user ).filter( event = nextEvent ) part = EventParticipation.objects.filter( user = request.user ).filter( event = nextEvent )
eventTime = datetime( events[0].date.year, events[0].date.month, events[0].date.day, eventTime = datetime( events[0].date.year, events[0].date.month, events[0].date.day,
events[0].displaytime.hour, events[0].displaytime.minute ) events[0].displaytime.hour, events[0].displaytime.minute )
context['hasParticipationSetForAllEvents'] = EventParticipation.hasUserSetParticipationForAllEvents( request.user) countdown['event'] = events[0]
context['event'] = events[0] countdown['epoch'] = int( (eventTime - datetime.now() ).total_seconds() * 1000 )
countdown['participation'] = part[0].status
context['epoch'] = int( (eventTime - datetime.now() ).total_seconds() * 1000 )
context['participation'] = part[0].status
else:
context['hasParticipationSetForAllEvents'] = True
context['countdown'] = countdown
# Route to concert
nextConcerts = Event.objects.filter( date__gte = datetime.now(), type = 'Conc' ).order_by('date')[:1] nextConcerts = Event.objects.filter( date__gte = datetime.now(), type = 'Conc' ).order_by('date')[:1]
if len( nextConcerts) > 0 : if len( nextConcerts) > 0 :
nextConcert = nextConcerts[0] nextConcert = nextConcerts[0]
routeInfo = dict() routeInfo = dict()
user = Musician.objects.get( user = request.user ); musician = Musician.objects.get( user = request.user );
routeInfo['origin'] = user.street + ", " + str( user.zip_code ) + " " + user.city routeInfo['origin'] = musician.street + ", " + str( musician.zip_code ) + " " + musician.city
if nextConcert.map_location: if nextConcert.map_location:
# map_location has format "lat,longitute,zoomlevel" # map_location has format "lat,longitute,zoomlevel"
@ -59,6 +63,7 @@ def home_view(request):
else: else:
context['hasNextConcertInfo'] = False context['hasNextConcertInfo'] = False
return render( request, 'website/mainpage.html', context ) return render( request, 'website/mainpage.html', context )