Merge in requirements error fix
This commit is contained in:
root
2015-01-27 01:06:09 +00:00
6 changed files with 93 additions and 11 deletions

View File

@@ -63,7 +63,7 @@ class Person(models.Model, RevisionMixin):
@property
def latest_events(self):
return self.event_set.order_by('-start_date')
return self.event_set.order_by('-start_date').select_related('person','organisation','venue','mic')
class Meta:
permissions = (
@@ -98,7 +98,7 @@ class Organisation(models.Model, RevisionMixin):
@property
def latest_events(self):
return self.event_set.order_by('-start_date')
return self.event_set.order_by('-start_date').select_related('person','organisation','venue','mic')
class Meta:
permissions = (
@@ -158,7 +158,7 @@ class Venue(models.Model, RevisionMixin):
@property
def latest_events(self):
return self.event_set.order_by('-start_date')
return self.event_set.order_by('-start_date').select_related('person','organisation','venue','mic')
class Meta:
permissions = (
@@ -181,11 +181,11 @@ class EventManager(models.Manager):
models.Q(dry_hire=True, checked_in_by__isnull=False, status__gt=Event.CANCELLED) | # Active dry hire GT
models.Q(dry_hire=True, status=Event.CANCELLED, start_date__gte=datetime.date.today())
# Canceled but not started
).order_by('meet_at', 'start_date')
).order_by('meet_at', 'start_date').select_related('person','organisation','venue','mic')
return events
def rig_count(self):
events = self.filter(
event_count = self.filter(
models.Q(start_date__gte=datetime.date.today(), end_date__isnull=True,
is_rig=True) | # Starts after with no end
models.Q(end_date__gte=datetime.date.today(), is_rig=True) | # Ends after
@@ -193,8 +193,8 @@ class EventManager(models.Manager):
is_rig=True) | # Active dry hire LT
models.Q(dry_hire=True, checked_in_by__isnull=False, status__gt=Event.CANCELLED, is_rig=True)
# Active dry hire GT
).order_by('meet_at', 'start_date')
return len(events)
).order_by('meet_at', 'start_date').count()
return event_count
@reversion.register(follow=['items'])

View File

@@ -10,10 +10,12 @@ from django.template import Context, RequestContext
from django.template.loader import get_template
from django.conf import settings
from django.http import HttpResponse
from django.db.models import Q
from z3c.rml import rml2pdf
from PyPDF2 import PdfFileMerger, PdfFileReader
from RIGS import models, forms
import datetime
__author__ = 'ghost'
@@ -101,7 +103,6 @@ class EventPrint(generic.View):
class EventDuplicate(generic.RedirectView):
def get_redirect_url(self, *args, **kwargs):
new = get_object_or_404(models.Event, pk=kwargs['pk'])
new.pk = None
@@ -113,4 +114,29 @@ class EventDuplicate(generic.RedirectView):
item.event = new
item.save()
return reverse_lazy('event_update', kwargs={'pk': new.pk})
return reverse_lazy('event_update', kwargs={'pk': new.pk})
class EventArchive(generic.ArchiveIndexView):
model = models.Event
date_field = "start_date"
paginate_by = 25
def get_queryset(self):
start = self.request.GET.get('start', None)
end = self.request.GET.get('end', datetime.date.today())
filter = False
if end != "":
filter = Q(start_date__lte=end)
if start:
if filter:
filter = filter & Q(start_date__gte=start)
else:
filter = Q(start_date__gte=start)
if filter:
qs = self.model.objects.filter(filter)
else:
qs = self.model.objects.all()
return qs.select_related('person', 'organisation', 'venue', 'mic')

View File

@@ -0,0 +1,45 @@
{% extends 'base.html' %}
{% load paginator from filters %}
{% block title %}Event Archive{% endblock %}
{% block content %}
<div class="row">
<h2>Event Archive</h2>
<div class="col-sm-12 col-md-6 pagination">
<form class="form-inline">
<div class="form-group">
<label for="start">Start</label>
<input type="date" name="start" id="start" value="{{ request.GET.start }}" placeholder="Start" class="form-control" />
</div>
<div class="form-group">
<label for="end">End</label>
<input type="date" name="end" id="end" value="{% if request.GET.end %}{{ request.GET.end }}{% else %}{% now "Y-m-d" %}{% endif %}" placeholder="End" class="form-control" />
</div>
<div class="form-group">
<input type="submit" class="btn btn-primary" />
</div>
</form>
</div>
{% if is_paginated %}
<div class="col-md-6 text-right">
{% paginator %}
</div>
{% endif %}
</div>
<div class="row">
{% with latest as events %}
{% include 'RIGS/event_table.html' %}
{% endwith %}
</div>
{% if is_paginated %}
<div class="row">
<div class="text-right">
{% paginator %}
</div>
</div>
{% endif %}
{% endblock %}

View File

@@ -1,6 +1,7 @@
from django.conf.urls import patterns, include, url
from django.contrib.auth.decorators import login_required
from RIGS import views, rigboard
from django.views.generic import RedirectView
from PyRIGS.decorators import permission_required_with_403
@@ -56,6 +57,8 @@ urlpatterns = patterns('',
# Rigboard
url(r'^rigboard/$', rigboard.RigboardIndex.as_view(), name='rigboard'),
url(r'^rigboard/archive/$', RedirectView.as_view(pattern_name='event_archive')),
url(r'^event/(?P<pk>\d+)/$',
permission_required_with_403('RIGS.view_event')(rigboard.EventDetail.as_view()),
name='event_detail'),
@@ -69,11 +72,19 @@ urlpatterns = patterns('',
permission_required_with_403('RIGS.change_event')(rigboard.EventUpdate.as_view()),
name='event_update'),
url(r'^event/(?P<pk>\d+)/duplicate/$',
permission_required_with_403('RIGS.change_event')(rigboard.EventDuplicate.as_view()),
permission_required_with_403('RIGS.add_event')(rigboard.EventDuplicate.as_view()),
name='event_duplicate'),
url(r'^event/archive/$', login_required()(rigboard.EventArchive.as_view()), name='event_archive'),
# API
url(r'^api/(?P<model>\w+)/$', (views.SecureAPIRequest.as_view()), name="api_secure"),
url(r'^api/(?P<model>\w+)/(?P<pk>\d+)/$', (views.SecureAPIRequest.as_view()), name="api_secure"),
# Legacy URL's
url(r'^rig/show/(?P<pk>\d+)/$', RedirectView.as_view(pattern_name='event_detail')),
url(r'^bookings/$', RedirectView.as_view(pattern_name='rigboard')),
url(r'^bookings/past/$', RedirectView.as_view(pattern_name='event_archive')),
# Calendar may have gone away, redirect to the archive for now
url(r'^rigboard/calendar/$', RedirectView.as_view(pattern_name='event_archive', permanent=False)),
)

Binary file not shown.

View File

@@ -40,7 +40,7 @@
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Rigboard<b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a href="{% url 'rigboard' %}">Rigboard</a></li>
<li><a href="#">Calendar</a></li>
<li><a href="{% url 'event_archive' %}">Archive</a></li>
</ul>
</li>
{% if perms.RIGS.view_invoice %}