mirror of
https://expo.survex.com/repositories/troggle/.git
synced 2024-11-22 07:11:52 +00:00
tunnelfiles scheme added
This commit is contained in:
parent
f21cddb2d0
commit
ced45c92f7
@ -51,7 +51,7 @@ class PhotoInline(admin.TabularInline):
|
|||||||
class PersonTripInline(admin.TabularInline):
|
class PersonTripInline(admin.TabularInline):
|
||||||
model = PersonTrip
|
model = PersonTrip
|
||||||
exclude = ['persontrip_next','Delete']
|
exclude = ['persontrip_next','Delete']
|
||||||
raw_id_fields = ('person_expedition',)
|
raw_id_fields = ('personexpedition',)
|
||||||
extra = 1
|
extra = 1
|
||||||
|
|
||||||
#class LogbookEntryAdmin(VersionAdmin):
|
#class LogbookEntryAdmin(VersionAdmin):
|
||||||
|
@ -5,6 +5,7 @@ from django.contrib import admin
|
|||||||
from django.core.files.storage import FileSystemStorage
|
from django.core.files.storage import FileSystemStorage
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
from django.db.models import Min, Max
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from decimal import Decimal, getcontext
|
from decimal import Decimal, getcontext
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
@ -65,21 +66,18 @@ class TroggleImageModel(ImageModel):
|
|||||||
class Expedition(TroggleModel):
|
class Expedition(TroggleModel):
|
||||||
year = models.CharField(max_length=20, unique=True)
|
year = models.CharField(max_length=20, unique=True)
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
# these will become min and max dates
|
|
||||||
date_from = models.DateField(blank=True,null=True)
|
|
||||||
date_to = models.DateField(blank=True,null=True)
|
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return self.year
|
return self.year
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-year',)
|
ordering = ('-year',)
|
||||||
get_latest_by = 'date_from'
|
get_latest_by = 'year'
|
||||||
|
|
||||||
def get_absolute_url(self):
|
def get_absolute_url(self):
|
||||||
return urlparse.urljoin(settings.URL_ROOT, reverse('expedition', args=[self.year]))
|
return urlparse.urljoin(settings.URL_ROOT, reverse('expedition', args=[self.year]))
|
||||||
|
|
||||||
|
# construction function. should be moved out
|
||||||
def get_expedition_day(self, date):
|
def get_expedition_day(self, date):
|
||||||
expeditiondays = self.expeditionday_set.filter(date=date)
|
expeditiondays = self.expeditionday_set.filter(date=date)
|
||||||
if expeditiondays:
|
if expeditiondays:
|
||||||
@ -89,11 +87,28 @@ class Expedition(TroggleModel):
|
|||||||
res.save()
|
res.save()
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
def day_min(self):
|
||||||
|
res = self.expeditionday_set.all()
|
||||||
|
return res and res[0] or None
|
||||||
|
|
||||||
|
def day_max(self):
|
||||||
|
res = self.expeditionday_set.all()
|
||||||
|
return res and res[len(res) - 1] or None
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class ExpeditionDay(TroggleModel):
|
class ExpeditionDay(TroggleModel):
|
||||||
expedition = models.ForeignKey("Expedition")
|
expedition = models.ForeignKey("Expedition")
|
||||||
date = models.DateField()
|
date = models.DateField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
ordering = ('date',)
|
||||||
|
|
||||||
|
def GetPersonTrip(self, personexpedition):
|
||||||
|
personexpeditions = self.persontrip_set.filter(expeditionday=self)
|
||||||
|
return personexpeditions and personexpeditions[0] or None
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# single Person, can go on many years
|
# single Person, can go on many years
|
||||||
#
|
#
|
||||||
@ -159,8 +174,8 @@ class Person(TroggleModel):
|
|||||||
class PersonExpedition(TroggleModel):
|
class PersonExpedition(TroggleModel):
|
||||||
expedition = models.ForeignKey(Expedition)
|
expedition = models.ForeignKey(Expedition)
|
||||||
person = models.ForeignKey(Person)
|
person = models.ForeignKey(Person)
|
||||||
date_from = models.DateField(blank=True,null=True)
|
|
||||||
date_to = models.DateField(blank=True,null=True)
|
|
||||||
is_guest = models.BooleanField(default=False)
|
is_guest = models.BooleanField(default=False)
|
||||||
COMMITTEE_CHOICES = (
|
COMMITTEE_CHOICES = (
|
||||||
('leader','Expo leader'),
|
('leader','Expo leader'),
|
||||||
@ -184,7 +199,6 @@ class PersonExpedition(TroggleModel):
|
|||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-expedition',)
|
ordering = ('-expedition',)
|
||||||
#order_with_respect_to = 'expedition'
|
#order_with_respect_to = 'expedition'
|
||||||
get_latest_by = 'expedition'
|
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return "%s: (%s)" % (self.person, self.expedition)
|
return "%s: (%s)" % (self.person, self.expedition)
|
||||||
@ -205,11 +219,21 @@ class PersonExpedition(TroggleModel):
|
|||||||
survexblocks = [personrole.survexblock for personrole in self.personrole_set.all() ]
|
survexblocks = [personrole.survexblock for personrole in self.personrole_set.all() ]
|
||||||
return sum([survexblock.totalleglength for survexblock in set(survexblocks)])
|
return sum([survexblock.totalleglength for survexblock in set(survexblocks)])
|
||||||
|
|
||||||
|
# would prefer to return actual person trips so we could link to first and last ones
|
||||||
|
def day_min(self):
|
||||||
|
res = self.persontrip_set.aggregate(day_min=Min("expeditionday__date"))
|
||||||
|
return res["day_min"]
|
||||||
|
|
||||||
|
def day_max(self):
|
||||||
|
res = self.persontrip_set.all().aggregate(day_max=Max("expeditionday__date"))
|
||||||
|
return res["day_max"]
|
||||||
|
|
||||||
#
|
#
|
||||||
# Single parsed entry from Logbook
|
# Single parsed entry from Logbook
|
||||||
#
|
#
|
||||||
class LogbookEntry(TroggleModel):
|
class LogbookEntry(TroggleModel):
|
||||||
date = models.DateField()
|
date = models.DateField()
|
||||||
|
expeditionday = models.ForeignKey("ExpeditionDay", null=True)
|
||||||
expedition = models.ForeignKey(Expedition,blank=True,null=True) # yes this is double-
|
expedition = models.ForeignKey(Expedition,blank=True,null=True) # yes this is double-
|
||||||
author = models.ForeignKey(PersonExpedition,blank=True,null=True) # the person who writes it up doesn't have to have been on the trip.
|
author = models.ForeignKey(PersonExpedition,blank=True,null=True) # the person who writes it up doesn't have to have been on the trip.
|
||||||
# Re: the above- so this field should be "typist" or something, not "author". - AC 15 jun 09
|
# Re: the above- so this field should be "typist" or something, not "author". - AC 15 jun 09
|
||||||
@ -249,12 +273,14 @@ class LogbookEntry(TroggleModel):
|
|||||||
"""Produces a link to a new QM with the next number filled in and this LogbookEntry set as 'found by' """
|
"""Produces a link to a new QM with the next number filled in and this LogbookEntry set as 'found by' """
|
||||||
return settings.URL_ROOT + r'/admin/core/qm/add/?' + r'found_by=' + str(self.pk) +'&number=' + str(self.new_QM_number())
|
return settings.URL_ROOT + r'/admin/core/qm/add/?' + r'found_by=' + str(self.pk) +'&number=' + str(self.new_QM_number())
|
||||||
|
|
||||||
|
def DayIndex(self):
|
||||||
|
return list(self.expeditionday.logbookentry_set.all()).index(self)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Single Person going on a trip, which may or may not be written up (accounts for different T/U for people in same logbook entry)
|
# Single Person going on a trip, which may or may not be written up (accounts for different T/U for people in same logbook entry)
|
||||||
#
|
#
|
||||||
class PersonTrip(TroggleModel):
|
class PersonTrip(TroggleModel):
|
||||||
person_expedition = models.ForeignKey(PersonExpedition,null=True)
|
personexpedition = models.ForeignKey("PersonExpedition",null=True)
|
||||||
|
|
||||||
expeditionday = models.ForeignKey("ExpeditionDay")
|
expeditionday = models.ForeignKey("ExpeditionDay")
|
||||||
date = models.DateField()
|
date = models.DateField()
|
||||||
@ -271,9 +297,8 @@ class PersonTrip(TroggleModel):
|
|||||||
return self.logbook_entry.cave and self.logbook_entry.cave or self.logbook_entry.place
|
return self.logbook_entry.cave and self.logbook_entry.cave or self.logbook_entry.place
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return "%s (%s)" % (self.person_expedition, self.date)
|
return "%s (%s)" % (self.personexpedition, self.date)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
##########################################
|
##########################################
|
||||||
|
@ -113,6 +113,8 @@ class SurvexBlock(models.Model):
|
|||||||
ss.save()
|
ss.save()
|
||||||
return ss
|
return ss
|
||||||
|
|
||||||
|
def DayIndex(self):
|
||||||
|
return list(self.expeditionday.survexblock_set.all()).index(self)
|
||||||
|
|
||||||
|
|
||||||
class SurvexTitle(models.Model):
|
class SurvexTitle(models.Model):
|
||||||
@ -143,7 +145,8 @@ class SurvexPersonRole(models.Model):
|
|||||||
person = models.ForeignKey('Person', blank=True, null=True)
|
person = models.ForeignKey('Person', blank=True, null=True)
|
||||||
personexpedition = models.ForeignKey('PersonExpedition', blank=True, null=True)
|
personexpedition = models.ForeignKey('PersonExpedition', blank=True, null=True)
|
||||||
persontrip = models.ForeignKey('PersonTrip', blank=True, null=True)
|
persontrip = models.ForeignKey('PersonTrip', blank=True, null=True)
|
||||||
|
expeditionday = models.ForeignKey("ExpeditionDay", null=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return unicode(self.person) + " - " + unicode(self.survexblock) + " - " + unicode(self.nrole)
|
return unicode(self.person) + " - " + unicode(self.survexblock) + " - " + unicode(self.nrole)
|
||||||
|
|
||||||
@ -164,4 +167,11 @@ class SurvexScanSingle(models.Model):
|
|||||||
return urlparse.urljoin(settings.URL_ROOT, reverse('surveyscansingle', kwargs={"path":re.sub("#", "%23", self.survexscansfolder.walletname), "file":self.name}))
|
return urlparse.urljoin(settings.URL_ROOT, reverse('surveyscansingle', kwargs={"path":re.sub("#", "%23", self.survexscansfolder.walletname), "file":self.name}))
|
||||||
|
|
||||||
|
|
||||||
|
class TunnelFile(models.Model):
|
||||||
|
tunnelpath = models.CharField(max_length=200)
|
||||||
|
bfontcolours = models.BooleanField()
|
||||||
|
survexscans = models.ManyToManyField("SurvexScanSingle")
|
||||||
|
survexblocks = models.ManyToManyField("SurvexBlock")
|
||||||
|
tunnelcontains = models.ManyToManyField("TunnelFile") # case when its a frame type
|
||||||
|
|
||||||
|
|
@ -4,7 +4,7 @@ from django.shortcuts import render_to_response
|
|||||||
from django.http import HttpResponse, Http404
|
from django.http import HttpResponse, Http404
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
from troggle.core.models import SurvexScansFolder, SurvexScanSingle, SurvexBlock
|
from troggle.core.models import SurvexScansFolder, SurvexScanSingle, SurvexBlock, TunnelFile
|
||||||
|
|
||||||
# inline fileabstraction into here if it's not going to be useful anywhere else
|
# inline fileabstraction into here if it's not going to be useful anywhere else
|
||||||
# keep things simple and ignore exceptions everywhere for now
|
# keep things simple and ignore exceptions everywhere for now
|
||||||
@ -47,6 +47,7 @@ extmimetypes = {".txt": "text/plain",
|
|||||||
".jpg": "image/jpeg",
|
".jpg": "image/jpeg",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# dead
|
||||||
def jgtfile(request, f):
|
def jgtfile(request, f):
|
||||||
fp = os.path.join(settings.SURVEYS, f)
|
fp = os.path.join(settings.SURVEYS, f)
|
||||||
# could also surf through SURVEX_DATA
|
# could also surf through SURVEX_DATA
|
||||||
@ -175,4 +176,9 @@ def surveyscansingle(request, path, file):
|
|||||||
def surveyscansfolders(request):
|
def surveyscansfolders(request):
|
||||||
survexscansfolders = SurvexScansFolder.objects.all()
|
survexscansfolders = SurvexScansFolder.objects.all()
|
||||||
return render_to_response('survexscansfolders.html', { 'survexscansfolders':survexscansfolders, 'settings': settings })
|
return render_to_response('survexscansfolders.html', { 'survexscansfolders':survexscansfolders, 'settings': settings })
|
||||||
|
|
||||||
|
|
||||||
|
def tunneldata(request):
|
||||||
|
tunnelfiles = TunnelFile.objects.all()
|
||||||
|
return render_to_response('tunnelfiles.html', { 'tunnelfiles':tunnelfiles, 'settings': settings })
|
||||||
|
|
@ -44,16 +44,21 @@ def personindex(request):
|
|||||||
|
|
||||||
|
|
||||||
def expedition(request, expeditionname):
|
def expedition(request, expeditionname):
|
||||||
year = int(expeditionname)
|
expedition = Expedition.objects.get(year=int(expeditionname))
|
||||||
expedition = Expedition.objects.get(year=year)
|
expeditions = Expedition.objects.all()
|
||||||
expedition_next = Expedition.objects.filter(year=year+1) and Expedition.objects.get(year=year+1) or None
|
personexpeditiondays = [ ]
|
||||||
expedition_prev = Expedition.objects.filter(year=year-1) and Expedition.objects.get(year=year-1) or None
|
for personexpedition in expedition.personexpedition_set.all():
|
||||||
message = "No message"
|
prow = [ ]
|
||||||
|
for expeditionday in expedition.expeditionday_set.all():
|
||||||
|
pcell = { "persontrips":expeditionday.persontrip_set.filter(personexpedition=personexpedition) }
|
||||||
|
pcell["survexblocks"] = set([survexpersonrole.survexblock for survexpersonrole in expeditionday.survexpersonrole_set.filter(personexpedition=personexpedition)])
|
||||||
|
prow.append(pcell)
|
||||||
|
personexpeditiondays.append({"personexpedition":personexpedition, "personrow":prow})
|
||||||
|
|
||||||
|
message = ""
|
||||||
if "reload" in request.GET:
|
if "reload" in request.GET:
|
||||||
message = LoadLogbookForExpedition(expedition)
|
message = LoadLogbookForExpedition(expedition)
|
||||||
#message = str(GetPersonExpeditionNameLookup(expedition).keys())
|
return render_with_context(request,'expedition.html', {'expedition': expedition, 'expeditions':expeditions, 'personexpeditiondays':personexpeditiondays, 'message':message, 'settings':settings })
|
||||||
logbookentries = expedition.logbookentry_set.order_by('date')
|
|
||||||
return render_with_context(request,'expedition.html', {'expedition': expedition, 'expedition_next':expedition_next, 'expedition_prev':expedition_prev, 'logbookentries':logbookentries, 'message':message, 'settings':settings })
|
|
||||||
|
|
||||||
def get_absolute_url(self):
|
def get_absolute_url(self):
|
||||||
return ('expedition', (expedition.year))
|
return ('expedition', (expedition.year))
|
||||||
|
@ -45,23 +45,6 @@ def todo(request):
|
|||||||
totallogbookentries = LogbookEntry.objects.count()
|
totallogbookentries = LogbookEntry.objects.count()
|
||||||
return render_with_context(request,'index.html', {'expeditions':expeditions, 'all':'all', 'totallogbookentries':totallogbookentries, "message":message})
|
return render_with_context(request,'index.html', {'expeditions':expeditions, 'all':'all', 'totallogbookentries':totallogbookentries, "message":message})
|
||||||
|
|
||||||
def calendar(request, year):
|
|
||||||
week=['S','S','M','T','W','T','F']
|
|
||||||
expedition = Expedition.objects.get(year=year)
|
|
||||||
personexpeditions = expedition.personexpedition_set.all()
|
|
||||||
|
|
||||||
listdays = [ ] # the columns of the table
|
|
||||||
date = expedition.date_from
|
|
||||||
while date <= expedition.date_to:
|
|
||||||
listdays.append(date)
|
|
||||||
date += datetime.timedelta(days=1)
|
|
||||||
|
|
||||||
personexpeditiondays = [ ]
|
|
||||||
for personexpedition in personexpeditions:
|
|
||||||
pelistdays = [ (personexpedition.date_from and (personexpedition.date_from <= date < personexpedition.date_to)) for date in listdays ]
|
|
||||||
personexpeditiondays.append([personexpedition, pelistdays])
|
|
||||||
|
|
||||||
return render_with_context(request,'calendar.html', {"expedition":expedition, "listdays":listdays, "personexpeditiondays":personexpeditiondays})
|
|
||||||
|
|
||||||
def controlPanel(request):
|
def controlPanel(request):
|
||||||
jobs_completed=[]
|
jobs_completed=[]
|
||||||
|
@ -75,6 +75,11 @@ def parse_descriptions():
|
|||||||
parsers.descriptions.parseDescriptions()
|
parsers.descriptions.parseDescriptions()
|
||||||
parsers.descriptions.parseDescriptionsOnCaveObjects()
|
parsers.descriptions.parseDescriptionsOnCaveObjects()
|
||||||
|
|
||||||
|
def import_tunnelfiles():
|
||||||
|
import parsers.surveys
|
||||||
|
parsers.surveys.LoadTunnelFiles(settings.TUNNEL_DATA)
|
||||||
|
|
||||||
|
|
||||||
def reset():
|
def reset():
|
||||||
""" Wipe the troggle database and import everything from legacy data
|
""" Wipe the troggle database and import everything from legacy data
|
||||||
"""
|
"""
|
||||||
@ -86,7 +91,8 @@ def reset():
|
|||||||
import_survex()
|
import_survex()
|
||||||
import_logbooks()
|
import_logbooks()
|
||||||
import_QMs()
|
import_QMs()
|
||||||
import_surveys()
|
import_tunnelfiles()
|
||||||
|
#import_surveys()
|
||||||
import_descriptions()
|
import_descriptions()
|
||||||
parse_descriptions()
|
parse_descriptions()
|
||||||
|
|
||||||
@ -112,6 +118,8 @@ if __name__ == "__main__":
|
|||||||
resetdesc()
|
resetdesc()
|
||||||
elif "scans" in sys.argv:
|
elif "scans" in sys.argv:
|
||||||
import_surveyscans()
|
import_surveyscans()
|
||||||
|
elif "tunnel" in sys.argv:
|
||||||
|
import_tunnelfiles()
|
||||||
elif "reset" in sys.argv:
|
elif "reset" in sys.argv:
|
||||||
reset()
|
reset()
|
||||||
elif "survex" in sys.argv:
|
elif "survex" in sys.argv:
|
||||||
|
@ -33,6 +33,60 @@ div.logbookentry p
|
|||||||
margin:10px;
|
margin:10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
div#content {
|
||||||
|
Zmargin-top: 50px;
|
||||||
|
Zmargin-left: 120px;
|
||||||
|
Zmargin-right: 120px;
|
||||||
|
padding-top: 10px;
|
||||||
|
padding-left: 5em;
|
||||||
|
padding-right: 5em;
|
||||||
|
padding-bottom:5em;
|
||||||
|
Zbackground:#CCC;
|
||||||
|
background-color:#f9f9f9;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.expeditionpersonlist th
|
||||||
|
{
|
||||||
|
padding:0 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.expeditionpersonlist td.persondayactivity
|
||||||
|
{
|
||||||
|
width:4em;
|
||||||
|
font-size:70%;
|
||||||
|
padding:0 0 0 0;
|
||||||
|
}
|
||||||
|
table.expeditionpersonlist td.persondayactivity-nothing
|
||||||
|
{
|
||||||
|
background-color:#bbb;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.expeditionpersonlist a
|
||||||
|
{
|
||||||
|
text-decoration:none;
|
||||||
|
color:#009;
|
||||||
|
}
|
||||||
|
table.expeditionpersonlist a:visited
|
||||||
|
{
|
||||||
|
color:#509;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.expeditionpersonlist a.dayindexlog-1
|
||||||
|
{ background-color: #440; color: white; }
|
||||||
|
table.expeditionpersonlist a.dayindexlog-2
|
||||||
|
{ background-color: #9fa; }
|
||||||
|
table.expeditionpersonlist a.dayindexsurvex-1
|
||||||
|
{ background-color: #000; color: #55f; }
|
||||||
|
table.expeditionpersonlist a.dayindexsurvex-2
|
||||||
|
{ background-color: #6ff; }
|
||||||
|
|
||||||
|
table.expeditionpersonlist a:hover
|
||||||
|
{
|
||||||
|
color:white;
|
||||||
|
background-color:#e00;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
div#content div#col2
|
div#content div#col2
|
||||||
{
|
{
|
||||||
@ -95,7 +149,7 @@ p.indent
|
|||||||
|
|
||||||
#currentLocation {
|
#currentLocation {
|
||||||
float:right;
|
float:right;
|
||||||
background:#999;
|
Zbackground:#999;
|
||||||
line-height: 80%;
|
line-height: 80%;
|
||||||
font-variant: small-caps;
|
font-variant: small-caps;
|
||||||
margin: 0px;
|
margin: 0px;
|
||||||
@ -259,22 +313,13 @@ div#editLinks {
|
|||||||
filter:alpha(opacity=75);
|
filter:alpha(opacity=75);
|
||||||
-moz-opacity:.75;
|
-moz-opacity:.75;
|
||||||
opacity:.75;
|
opacity:.75;
|
||||||
|
text-align:right;
|
||||||
}
|
}
|
||||||
|
|
||||||
div#editLinks a{
|
div#editLinks a{
|
||||||
color:#FFF;
|
color:#FFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
div#content {
|
|
||||||
Zmargin-top: 50px;
|
|
||||||
Zmargin-left: 120px;
|
|
||||||
Zmargin-right: 120px;
|
|
||||||
padding-top: 10px;
|
|
||||||
padding-left: 5em;
|
|
||||||
padding-right: 5em;
|
|
||||||
padding-bottom:5em;
|
|
||||||
background:#CCC;
|
|
||||||
}
|
|
||||||
|
|
||||||
.toolbarlinks
|
.toolbarlinks
|
||||||
{
|
{
|
||||||
|
@ -88,14 +88,14 @@ def EnterLogIntoDbase(date, place, title, text, trippeople, expedition, logtime_
|
|||||||
cave=GetCaveLookup().get(lplace)
|
cave=GetCaveLookup().get(lplace)
|
||||||
|
|
||||||
#Check for an existing copy of the current entry, and save
|
#Check for an existing copy of the current entry, and save
|
||||||
|
expeditionday = expedition.get_expedition_day(date)
|
||||||
lookupAttribs={'date':date, 'title':title}
|
lookupAttribs={'date':date, 'title':title}
|
||||||
nonLookupAttribs={'place':place, 'text':text, 'author':author, 'expedition':expedition, 'cave':cave, 'slug':slugify(title)[:50]}
|
nonLookupAttribs={'place':place, 'text':text, 'author':author, 'expedition':expedition, 'expeditionday':expeditionday, 'cave':cave, 'slug':slugify(title)[:50]}
|
||||||
lbo, created=save_carefully(models.LogbookEntry, lookupAttribs, nonLookupAttribs)
|
lbo, created=save_carefully(models.LogbookEntry, lookupAttribs, nonLookupAttribs)
|
||||||
expeditiondate = expedition.get_expedition_date(date)
|
|
||||||
|
|
||||||
for tripperson, time_underground in trippersons:
|
for tripperson, time_underground in trippersons:
|
||||||
lookupAttribs={'person_expedition':tripperson, 'logbook_entry':lbo}
|
lookupAttribs={'personexpedition':tripperson, 'logbook_entry':lbo}
|
||||||
nonLookupAttribs={'time_underground':time_underground, 'date':date, 'expeditiondate':expeditiondate, 'is_logbook_entry_author':(tripperson == author)}
|
nonLookupAttribs={'time_underground':time_underground, 'date':date, 'expeditionday':expeditionday, 'is_logbook_entry_author':(tripperson == author)}
|
||||||
#print nonLookupAttribs
|
#print nonLookupAttribs
|
||||||
save_carefully(models.PersonTrip, lookupAttribs, nonLookupAttribs)
|
save_carefully(models.PersonTrip, lookupAttribs, nonLookupAttribs)
|
||||||
|
|
||||||
@ -281,10 +281,6 @@ def SetDatesFromLogbookEntries(expedition):
|
|||||||
"""
|
"""
|
||||||
for personexpedition in expedition.personexpedition_set.all():
|
for personexpedition in expedition.personexpedition_set.all():
|
||||||
persontrips = personexpedition.persontrip_set.order_by('logbook_entry__date')
|
persontrips = personexpedition.persontrip_set.order_by('logbook_entry__date')
|
||||||
personexpedition.date_from = min([persontrip.logbook_entry.date for persontrip in persontrips] or [None])
|
|
||||||
personexpedition.date_to = max([persontrip.logbook_entry.date for persontrip in persontrips] or [None])
|
|
||||||
personexpedition.save()
|
|
||||||
|
|
||||||
# sequencing is difficult to do
|
# sequencing is difficult to do
|
||||||
lprevpersontrip = None
|
lprevpersontrip = None
|
||||||
for persontrip in persontrips:
|
for persontrip in persontrips:
|
||||||
@ -296,46 +292,11 @@ def SetDatesFromLogbookEntries(expedition):
|
|||||||
lprevpersontrip = persontrip
|
lprevpersontrip = persontrip
|
||||||
persontrip.save()
|
persontrip.save()
|
||||||
|
|
||||||
# from trips rather than logbook entries, which may include events outside the expedition
|
|
||||||
expedition.date_from = min([personexpedition.date_from for personexpedition in expedition.personexpedition_set.all() if personexpedition.date_from] or [None])
|
|
||||||
expedition.date_to = max([personexpedition.date_to for personexpedition in expedition.personexpedition_set.all() if personexpedition.date_to] or [None])
|
|
||||||
expedition.save()
|
|
||||||
|
|
||||||
# The below has been replaced with the methods get_next_by_id and get_previous_by_id
|
|
||||||
# # order by appearance in the logbook (done by id)
|
|
||||||
# lprevlogbookentry = None
|
|
||||||
# for logbookentry in expedition.logbookentry_set.order_by('id'):
|
|
||||||
# logbookentry.logbookentry_prev = lprevlogbookentry
|
|
||||||
# if lprevlogbookentry:
|
|
||||||
# lprevlogbookentry.logbookentry_next = logbookentry
|
|
||||||
# lprevlogbookentry.save()
|
|
||||||
# logbookentry.logbookentry_next = None
|
|
||||||
# logbookentry.save()
|
|
||||||
# lprevlogbookentry = logbookentry
|
|
||||||
|
|
||||||
# This combined date / number key is a weird way of doing things. Use the primary key instead. If we are going to use the date for looking up entries, we should set it up to allow multiple results.
|
|
||||||
# order by date for setting the references
|
|
||||||
# lprevlogbookentry = None
|
|
||||||
# for logbookentry in expedition.logbookentry_set.order_by('date'):
|
|
||||||
# if lprevlogbookentry and lprevlogbookentry.date == logbookentry.date:
|
|
||||||
# mcount = re.search("_(\d+)$", lprevlogbookentry.href)
|
|
||||||
# mc = mcount and (int(mcount.group(1)) + 1) or 1
|
|
||||||
# logbookentry.href = "%s_%d" % (logbookentry.date, mc)
|
|
||||||
# else:
|
|
||||||
# logbookentry.href = "%s" % logbookentry.date
|
|
||||||
# logbookentry.save()
|
|
||||||
# lprevlogbookentry = logbookentry
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def LoadLogbookForExpedition(expedition):
|
def LoadLogbookForExpedition(expedition):
|
||||||
""" Parses all logbook entries for one expedition """
|
""" Parses all logbook entries for one expedition """
|
||||||
|
|
||||||
#We're checking for stuff that's changed in admin before deleting it now.
|
|
||||||
#print "deleting logbooks for", expedition
|
|
||||||
#expedition.logbookentry_set.all().delete()
|
|
||||||
#models.PersonTrip.objects.filter(person_expedition__expedition=expedition).delete()
|
|
||||||
|
|
||||||
expowebbase = os.path.join(settings.EXPOWEB, "years")
|
expowebbase = os.path.join(settings.EXPOWEB, "years")
|
||||||
year = str(expedition.year)
|
year = str(expedition.year)
|
||||||
for lyear, lloc, parsefunc in yearlinks:
|
for lyear, lloc, parsefunc in yearlinks:
|
||||||
@ -347,7 +308,7 @@ def LoadLogbookForExpedition(expedition):
|
|||||||
fin.close()
|
fin.close()
|
||||||
parsefunc(year, expedition, txt)
|
parsefunc(year, expedition, txt)
|
||||||
SetDatesFromLogbookEntries(expedition)
|
SetDatesFromLogbookEntries(expedition)
|
||||||
return "TOLOAD: " + year + " " + str(expedition.personexpedition_set.all()[1].logbookentry_set.count()) + " " + str(models.PersonTrip.objects.filter(person_expedition__expedition=expedition).count())
|
return "TOLOAD: " + year + " " + str(expedition.personexpedition_set.all()[1].logbookentry_set.count()) + " " + str(models.PersonTrip.objects.filter(personexpedition__expedition=expedition).count())
|
||||||
|
|
||||||
|
|
||||||
def LoadLogbooks():
|
def LoadLogbooks():
|
||||||
|
@ -69,7 +69,6 @@ def RecursiveLoad(survexblock, survexfile, fin, textlines):
|
|||||||
mref = comment and re.match('.*?ref.*?(\d+)\s*#\s*(\d+)', comment)
|
mref = comment and re.match('.*?ref.*?(\d+)\s*#\s*(\d+)', comment)
|
||||||
if mref:
|
if mref:
|
||||||
refscan = "%s#%s" % (mref.group(1), mref.group(2))
|
refscan = "%s#%s" % (mref.group(1), mref.group(2))
|
||||||
print refscan
|
|
||||||
survexscansfolders = models.SurvexScansFolder.objects.filter(walletname=refscan)
|
survexscansfolders = models.SurvexScansFolder.objects.filter(walletname=refscan)
|
||||||
if survexscansfolders:
|
if survexscansfolders:
|
||||||
survexblock.survexscansfolder = survexscansfolders[0]
|
survexblock.survexscansfolder = survexscansfolders[0]
|
||||||
@ -125,7 +124,9 @@ def RecursiveLoad(survexblock, survexfile, fin, textlines):
|
|||||||
if expeditions:
|
if expeditions:
|
||||||
assert len(expeditions) == 1
|
assert len(expeditions) == 1
|
||||||
survexblock.expedition = expeditions[0]
|
survexblock.expedition = expeditions[0]
|
||||||
survexblock.expeditiondate = survexblock.expedition.get_expedition_day(survexblock.date)
|
survexblock.expeditionday = survexblock.expedition.get_expedition_day(survexblock.date)
|
||||||
|
survexblock.save()
|
||||||
|
|
||||||
elif re.match("team$(?i)", cmd):
|
elif re.match("team$(?i)", cmd):
|
||||||
mteammember = re.match("(Insts|Notes|Tape|Dog|Useless|Pics|Helper|Disto|Consultant)\s+(.*)$(?i)", line)
|
mteammember = re.match("(Insts|Notes|Tape|Dog|Useless|Pics|Helper|Disto|Consultant)\s+(.*)$(?i)", line)
|
||||||
if mteammember:
|
if mteammember:
|
||||||
@ -135,6 +136,7 @@ def RecursiveLoad(survexblock, survexfile, fin, textlines):
|
|||||||
if (personexpedition, tm) not in teammembers:
|
if (personexpedition, tm) not in teammembers:
|
||||||
teammembers.append((personexpedition, tm))
|
teammembers.append((personexpedition, tm))
|
||||||
personrole = models.SurvexPersonRole(survexblock=survexblock, nrole=mteammember.group(1).lower(), personexpedition=personexpedition, personname=tm)
|
personrole = models.SurvexPersonRole(survexblock=survexblock, nrole=mteammember.group(1).lower(), personexpedition=personexpedition, personname=tm)
|
||||||
|
personrole.expeditionday = survexblock.expeditionday
|
||||||
if personexpedition:
|
if personexpedition:
|
||||||
personrole.person=personexpedition.person
|
personrole.person=personexpedition.person
|
||||||
personrole.save()
|
personrole.save()
|
||||||
|
@ -24,6 +24,7 @@ def get_or_create_placeholder(year):
|
|||||||
placeholder_logbook_entry, newly_created = save_carefully(LogbookEntry, lookupAttribs, nonLookupAttribs)
|
placeholder_logbook_entry, newly_created = save_carefully(LogbookEntry, lookupAttribs, nonLookupAttribs)
|
||||||
return placeholder_logbook_entry
|
return placeholder_logbook_entry
|
||||||
|
|
||||||
|
# dead
|
||||||
def readSurveysFromCSV():
|
def readSurveysFromCSV():
|
||||||
try: # could probably combine these two
|
try: # could probably combine these two
|
||||||
surveytab = open(os.path.join(settings.SURVEY_SCANS, "Surveys.csv"))
|
surveytab = open(os.path.join(settings.SURVEY_SCANS, "Surveys.csv"))
|
||||||
@ -75,6 +76,7 @@ def readSurveysFromCSV():
|
|||||||
|
|
||||||
logging.info("added survey " + survey[header['Year']] + "#" + surveyobj.wallet_number + "\r")
|
logging.info("added survey " + survey[header['Year']] + "#" + surveyobj.wallet_number + "\r")
|
||||||
|
|
||||||
|
# dead
|
||||||
def listdir(*directories):
|
def listdir(*directories):
|
||||||
try:
|
try:
|
||||||
return os.listdir(os.path.join(settings.SURVEYS, *directories))
|
return os.listdir(os.path.join(settings.SURVEYS, *directories))
|
||||||
@ -134,11 +136,13 @@ def parseSurveyScans(year, logfile=None):
|
|||||||
continue
|
continue
|
||||||
scanObj.save()
|
scanObj.save()
|
||||||
|
|
||||||
|
# dead
|
||||||
def parseSurveys(logfile=None):
|
def parseSurveys(logfile=None):
|
||||||
readSurveysFromCSV()
|
readSurveysFromCSV()
|
||||||
for year in Expedition.objects.filter(year__gte=2000): #expos since 2000, because paths and filenames were nonstandard before then
|
for year in Expedition.objects.filter(year__gte=2000): #expos since 2000, because paths and filenames were nonstandard before then
|
||||||
parseSurveyScans(year)
|
parseSurveyScans(year)
|
||||||
|
|
||||||
|
# dead
|
||||||
def isInterlacedPNG(filePath): #We need to check for interlaced PNGs because the thumbnail engine can't handle them (uses PIL)
|
def isInterlacedPNG(filePath): #We need to check for interlaced PNGs because the thumbnail engine can't handle them (uses PIL)
|
||||||
file=Image.open(filePath)
|
file=Image.open(filePath)
|
||||||
print filePath
|
print filePath
|
||||||
@ -148,10 +152,11 @@ def isInterlacedPNG(filePath): #We need to check for interlaced PNGs because the
|
|||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
# handles url or file
|
# handles url or file, so we can refer to a set of scans on another server
|
||||||
def GetListDir(sdir):
|
def GetListDir(sdir):
|
||||||
res = [ ]
|
res = [ ]
|
||||||
if sdir[:7] == "http://":
|
if sdir[:7] == "http://":
|
||||||
|
assert False, "Not written"
|
||||||
s = urllib.urlopen(sdir)
|
s = urllib.urlopen(sdir)
|
||||||
else:
|
else:
|
||||||
for f in os.listdir(sdir):
|
for f in os.listdir(sdir):
|
||||||
@ -198,4 +203,30 @@ def LoadListScans(surveyscansdir):
|
|||||||
survexscansingle.save()
|
survexscansingle.save()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def LoadTunnelFiles(tunneldatadir):
|
||||||
|
TunnelFile.objects.all().delete()
|
||||||
|
tunneldirs = [ "" ]
|
||||||
|
while tunneldirs:
|
||||||
|
tunneldir = tunneldirs.pop()
|
||||||
|
for f in os.listdir(os.path.join(tunneldatadir, tunneldir)):
|
||||||
|
if f[0] == "." or f[-1] == "~":
|
||||||
|
continue
|
||||||
|
lf = os.path.join(tunneldir, f)
|
||||||
|
ff = os.path.join(tunneldatadir, lf)
|
||||||
|
if os.path.isdir(ff):
|
||||||
|
tunneldirs.append(lf)
|
||||||
|
elif f[-4:] == ".xml":
|
||||||
|
fin = open(ff)
|
||||||
|
mtype = re.search("<(fontcolours|sketch)", fin.read(200))
|
||||||
|
assert mtype, lf
|
||||||
|
fin.close()
|
||||||
|
tunnelfile = TunnelFile(tunnelpath=lf, bfontcolours=(mtype.group(1)=="fontcolours"))
|
||||||
|
tunnelfile.save()
|
||||||
|
|
||||||
|
|
||||||
|
# survexscans = models.ManyToManyField("SurvexScanSingle")
|
||||||
|
# survexblocks = models.ManyToManyField("SurvexBlock")
|
||||||
|
# tunnelcontains = models.ManyToManyField("TunnelFile") # case when its a frame type
|
||||||
|
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
<div id="header">
|
<div id="header">
|
||||||
<h1>CUCC Expeditions to Austria: 1976 - 2009</h1>
|
<h1>CUCC Expeditions to Austria: 1976 - 2009</h1>
|
||||||
<div id="editLinks"> {% block loginInfo %}
|
<div id="editLinks"> {% block loginInfo %}
|
||||||
|
<a href="{{ settings.URL_ROOT }}">Home</a> |
|
||||||
{% if user.username %}
|
{% if user.username %}
|
||||||
You are logged in as {{ user.username }}
|
You are logged in as {{ user.username }}
|
||||||
{% if user.person %}(<a href="{{ user.person.get_absolute_url }}">{{ user.person }}</a>)
|
{% if user.person %}(<a href="{{ user.person.get_absolute_url }}">{{ user.person }}</a>)
|
||||||
@ -25,15 +26,15 @@
|
|||||||
{% endif %}.
|
{% endif %}.
|
||||||
| <a href="{% url auth_logout %}">Log out</a> {% else %} <a href="{% url registration_register %}">Sign up</a> | <a href="{% url auth_login %}">Log in</a> {% endif %}
|
| <a href="{% url auth_logout %}">Log out</a> {% else %} <a href="{% url registration_register %}">Sign up</a> | <a href="{% url auth_login %}">Log in</a> {% endif %}
|
||||||
{% endblock%}
|
{% endblock%}
|
||||||
| <a href="{{ settings.URL_ROOT }}">Home</a> | <a class="killEyeCandy">Kill Eyecandy</a><a class="showEyeCandy" style="display: none;">Show Eyecandy</a>
|
|
||||||
{% block editLink %}
|
{% block editLink %}
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="toolbarlinks">
|
<div class="toolbarlinks">
|
||||||
<a href="{% url survexcaveslist %}">All Cave Survex</a> |
|
<a href="{% url survexcaveslist %}">All Survex</a> |
|
||||||
<a href="{% url surveyscansfolders %}">All scans</a> |
|
<a href="{% url surveyscansfolders %}">Scans</a> |
|
||||||
|
<a href="{% url tunneldata %}">Tunneldata</a> |
|
||||||
<a href="{% url survexcavessingle 161 %}">161</a> |
|
<a href="{% url survexcavessingle 161 %}">161</a> |
|
||||||
<a href="{% url survexcavessingle 204 %}">204</a> |
|
<a href="{% url survexcavessingle 204 %}">204</a> |
|
||||||
<a href="{% url survexcavessingle 258 %}">258</a> |
|
<a href="{% url survexcavessingle 258 %}">258</a> |
|
||||||
@ -95,7 +96,6 @@
|
|||||||
<li><a href="{% url stats %}">statistics</a></li>
|
<li><a href="{% url stats %}">statistics</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
<li><a href="{% url calendar 2008 %}">expedition calendar</a></li>
|
|
||||||
<li><a href="#">admin</a>
|
<li><a href="#">admin</a>
|
||||||
<ul class="sub_menu">
|
<ul class="sub_menu">
|
||||||
<li><a id="cuccLink" href="{% url controlpanel %}">Import / export data</a></li>
|
<li><a id="cuccLink" href="{% url controlpanel %}">Import / export data</a></li>
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
{% extends "base.html" %}
|
|
||||||
|
|
||||||
{% block title %}
|
|
||||||
CUCC expedition calendar:
|
|
||||||
{% if expedition %}
|
|
||||||
{{ expedition.year }}
|
|
||||||
{% else %}
|
|
||||||
choose a year
|
|
||||||
{% endif %}
|
|
||||||
{% endblock %}
|
|
||||||
|
|
||||||
{% block head %}
|
|
||||||
<style type="text/css">
|
|
||||||
<!--
|
|
||||||
.no { background: #7f96e8; width: 80pt; font-size: 10pt }
|
|
||||||
.yes { background: #ff6666; width: 80pt; font-size: 10pt }
|
|
||||||
.name { background: #999; width: 80pt; text-align:right; font-size: 10pt }
|
|
||||||
.date { background: #999; width: 80pt; text-align:right; font-size: 10pt }
|
|
||||||
-->
|
|
||||||
</style>
|
|
||||||
|
|
||||||
{% endblock %}
|
|
||||||
|
|
||||||
{% block contentheader %}
|
|
||||||
<h2>Expedition members present calendar for {{ expedition.year }}</h2>
|
|
||||||
<table style="margin:0 auto">
|
|
||||||
<tr>
|
|
||||||
<td class='yes' width="10"></td><td>Expedition member present in Austria</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class='no' width="10"></td><td>Expedition member absent in Austria</td>
|
|
||||||
</tr></table>
|
|
||||||
<br />
|
|
||||||
{% endblock%}
|
|
||||||
|
|
||||||
{% block content %}
|
|
||||||
{% if expedition %}
|
|
||||||
<table>
|
|
||||||
<tr><td />
|
|
||||||
{% for date in listdays %}
|
|
||||||
{% ifchanged date.month %}
|
|
||||||
<td class="date">{{ date|date:"F" }}</td>
|
|
||||||
{% else %}
|
|
||||||
<td class="date"></td>
|
|
||||||
{% endifchanged %}
|
|
||||||
{% endfor %}
|
|
||||||
</tr>
|
|
||||||
<tr><td />
|
|
||||||
{% for date in listdays %}
|
|
||||||
<td class="date">{{ date|date:"D" }}</td>
|
|
||||||
{% endfor %}
|
|
||||||
</tr>
|
|
||||||
<tr><td />
|
|
||||||
{% for date in listdays %}
|
|
||||||
<td class="date">{{ date|date:"d" }}</td>
|
|
||||||
{% endfor %}
|
|
||||||
</tr>
|
|
||||||
|
|
||||||
{% for personexpedition, pelistdays in personexpeditiondays %}
|
|
||||||
<tr>
|
|
||||||
<td class="name">
|
|
||||||
<a href="{{ personexpedition.person.get_absolute_url }}">{{ personexpedition.person }}</a>
|
|
||||||
</td>
|
|
||||||
{% for peday in pelistdays %}
|
|
||||||
<td {{ peday|yesno:"class='yes',class='no'"|safe }}></td>
|
|
||||||
{% endfor %}
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</table>
|
|
||||||
{% endif %}
|
|
||||||
{% endblock %}
|
|
@ -6,64 +6,84 @@
|
|||||||
{% block editLink %}<a href={{expedition.get_admin_url}}>Edit expedition {{expedition|wiki_to_html_short}}</a>{% endblock %}
|
{% block editLink %}<a href={{expedition.get_admin_url}}>Edit expedition {{expedition|wiki_to_html_short}}</a>{% endblock %}
|
||||||
|
|
||||||
{% block related %}
|
{% block related %}
|
||||||
<table class="prevnextexpeditions">
|
|
||||||
<tr>
|
|
||||||
<td>{% if expedition_prev %}< < {{ expedition_prev|link }} {% endif %}</td>
|
|
||||||
<td>{% if expedition_next %}> > {{ expedition_next|link }} {% endif %}</td>
|
|
||||||
</tr>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<table class="expeditionpersonlist">
|
|
||||||
<tr><th>Caver</th><th>From</th><th>To</th></tr>
|
|
||||||
{% for personexpedition in expedition.personexpedition_set.all %}
|
|
||||||
<tr>
|
|
||||||
<td><a href="{{ personexpedition.get_absolute_url }}">{{personexpedition.person}}</a></td>
|
|
||||||
<td>{{personexpedition.date_from}}</td>
|
|
||||||
<td>{{personexpedition.date_to}}</td>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</table>
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<h2>{{expedition.name}}: {{expedition.date_from}} - {{expedition.date_to}}</h2>
|
|
||||||
|
|
||||||
|
{% if message %}
|
||||||
<div id="col1">
|
|
||||||
<h3>Logbook entries</h3>
|
|
||||||
<form action="" method="GET"><input type="submit" name="reload" value="Reload"></form>
|
|
||||||
<p>debug message: {{message}}</p>
|
<p>debug message: {{message}}</p>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<h2>{{expedition.name}}</h2>
|
||||||
|
|
||||||
|
<p><b>Other years:</b>
|
||||||
|
{% for otherexpedition in expeditions %}
|
||||||
|
{% ifequal otherexpedition expedition %}
|
||||||
|
| <b>{{otherexpedition.year}}</b>
|
||||||
|
{% else %}
|
||||||
|
| <a href="{{otherexpedition.get_absolute_url}}">{{ otherexpedition.year }}</a>
|
||||||
|
{% endifequal %}
|
||||||
|
{% endfor %}
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p><b>At a single glance:</b> The table shows all expo cavers and their recorded trips.
|
||||||
|
The columns are the date in the month (July or August), with a "T" for a logbook entry, and
|
||||||
|
an "S" for a survey trip. The colours are the same for people on the same trip.</p>
|
||||||
|
|
||||||
|
<table class="expeditionpersonlist">
|
||||||
|
<tr>
|
||||||
|
<th>Caver</th>
|
||||||
|
{% for expeditionday in expedition.expeditionday_set.all %}
|
||||||
|
<th>
|
||||||
|
{{expeditionday.date.day}}
|
||||||
|
</th>
|
||||||
|
{% endfor %}
|
||||||
|
</tr>
|
||||||
|
{% for personexpeditionday in personexpeditiondays %}
|
||||||
|
<tr>
|
||||||
|
<td><a href="{{ personexpeditionday.personexpedition.get_absolute_url }}">{{personexpeditionday.personexpedition.person}}</a></td>
|
||||||
|
{% for persondayactivities in personexpeditionday.personrow %}
|
||||||
|
|
||||||
|
{% if persondayactivities.persontrips or persondayactivities.survexblocks %}
|
||||||
|
<td class="persondayactivity">
|
||||||
|
{% for persontrip in persondayactivities.persontrips %}
|
||||||
|
<a href="{{persontrip.logbook_entry.get_absolute_url}}" class="dayindexlog-{{persontrip.logbook_entry.DayIndex}}">T</a>
|
||||||
|
{% endfor %}
|
||||||
|
<br/>
|
||||||
|
{% for survexblock in persondayactivities.survexblocks %}
|
||||||
|
<a href="{% url svx survexblock.survexfile.path %}" class="dayindexsurvex-{{survexblock.DayIndex}}">S</a>
|
||||||
|
{% endfor %}
|
||||||
|
</td>
|
||||||
|
{% else %}
|
||||||
|
<td class="persondayactivity-nothing">
|
||||||
|
</td>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% endfor %}
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<form action="" method="GET"><input type="submit" name="reload" value="Reload"></form>
|
||||||
|
|
||||||
|
<h3>Logbooks and survey trips per day</h3>
|
||||||
<table class="expeditionlogbooks">
|
<table class="expeditionlogbooks">
|
||||||
<tr><th>Date</th><th>Title</th><th>Author</th><th>Place</th></tr>
|
<tr><th>Date</th><th>Logged trips</th><th>Surveys</th></tr>
|
||||||
{% for logbookentry in logbookentries %}
|
{% for expeditionday in expedition.expeditionday_set.all %}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{logbookentry.date}}</td>
|
<td>{{expeditionday.date}}</td>
|
||||||
<td><a href="{{ logbookentry.get_absolute_url }}">{{logbookentry.title|safe}}</td>
|
<td>
|
||||||
<td><a href="{{ logbookentry.author.get_absolute_url }}">{{logbookentry.author.name}}</a></td>
|
{% for logbookentry in expeditionday.logbookentry_set.all %}
|
||||||
|
<a href="{{ logbookentry.get_absolute_url }}">{{logbookentry.title|safe}}</a><br/>
|
||||||
{% if logbookentry.cave %}
|
{% endfor %}
|
||||||
<td><a href="{{ logbookentry.cave.get_absolute_url }}">{{logbookentry.place}}</a></td>
|
</td>
|
||||||
{% else %}
|
<td>
|
||||||
<td>{{logbookentry.place}}</td>
|
{% for survexblock in expeditionday.survexblock_set.all %}
|
||||||
{% endif %}
|
<a href="{% url svx survexblock.survexfile.path %}">{{survexblock.name}}</a>
|
||||||
</tr>
|
{% endfor %}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</table>
|
</table>
|
||||||
</div>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<h3 id="surveysdone">Surveys done</h3>
|
|
||||||
<table class="survextrip">
|
|
||||||
<tr><th>Date</th><th>Name</th><th>Length</th></tr>
|
|
||||||
{% for survexblock in expedition.survexblock_set.all %}
|
|
||||||
<tr>
|
|
||||||
<td>{{survexblock.date}}</td>
|
|
||||||
<td><a href="{% url svx survexblock.survexfile.path %}">{{survexblock.name}}</a></td>
|
|
||||||
<td>{{survexblock.totalleglength}}</td>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@ -17,7 +17,7 @@ p { clear: both }
|
|||||||
|
|
||||||
<div class="tripdate" id="t{{logbook_entry.date}}A">{{logbook_entry.date}}</div>
|
<div class="tripdate" id="t{{logbook_entry.date}}A">{{logbook_entry.date}}</div>
|
||||||
<div class="trippeople"><u>{{logbook_entry.author.person}}</u>
|
<div class="trippeople"><u>{{logbook_entry.author.person}}</u>
|
||||||
{% for persontrip in logbook_entry.persontrip_set.all %}{{ persontrip.person_expedition.person }} {{ persontrip.person_expedition.time_underground }}, {% endfor %}
|
{% for persontrip in logbook_entry.persontrip_set.all %}{{ persontrip.personexpedition.person }} {{ persontrip.personexpedition.time_underground }}, {% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="triptitle">{{logbook_entry.place}} - {{logbook_entry.title}}</div>
|
<div class="triptitle">{{logbook_entry.place}} - {{logbook_entry.title}}</div>
|
||||||
|
@ -29,12 +29,12 @@
|
|||||||
<tr><th>Caver</th><th>T/U</th><th>Prev</th><th>Next</th></tr>
|
<tr><th>Caver</th><th>T/U</th><th>Prev</th><th>Next</th></tr>
|
||||||
{% for persontrip in logbookentry.persontrip_set.all %}
|
{% for persontrip in logbookentry.persontrip_set.all %}
|
||||||
<tr>
|
<tr>
|
||||||
{% ifequal persontrip.person_expedition logbookentry.author %}
|
{% ifequal persontrip.personexpedition logbookentry.author %}
|
||||||
<td class="author">
|
<td class="author">
|
||||||
{% else %}
|
{% else %}
|
||||||
<td>
|
<td>
|
||||||
{% endifequal %}
|
{% endifequal %}
|
||||||
<a href="{{ persontrip.person_expedition.get_absolute_url }}">{{persontrip.person_expedition.person}}</a>
|
<a href="{{ persontrip.personexpedition.get_absolute_url }}">{{persontrip.personexpedition.person}}</a>
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td>
|
<td>
|
||||||
|
20
templates/tunnelfiles.html
Normal file
20
templates/tunnelfiles.html
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
{% load wiki_markup %}
|
||||||
|
{% load survex_markup %}
|
||||||
|
|
||||||
|
{% block title %}Tunnel files{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
<h3>All Tunnel files</h3>
|
||||||
|
<table>
|
||||||
|
<tr><th>File</th><th>Font</th><th>Frame</th><th>SurvexBlocks</th><th>Size</th></tr>
|
||||||
|
{% for tunnelfile in tunnelfiles %}
|
||||||
|
<tr>
|
||||||
|
<td>{{tunnelfile.tunnelpath}}</td>
|
||||||
|
<td>{{tunnelfile.bfontcolours}}</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</table>
|
||||||
|
|
||||||
|
{% endblock %}
|
5
urls.py
5
urls.py
@ -55,8 +55,6 @@ urlpatterns = patterns('',
|
|||||||
|
|
||||||
url(r'^statistics/?$', views_other.stats, name="stats"),
|
url(r'^statistics/?$', views_other.stats, name="stats"),
|
||||||
|
|
||||||
url(r'^calendar/(?P<year>\d\d\d\d)/?$', views_other.calendar, name="calendar"),
|
|
||||||
|
|
||||||
url(r'^survey/?$', surveyindex, name="survey"),
|
url(r'^survey/?$', surveyindex, name="survey"),
|
||||||
url(r'^survey/(?P<year>\d\d\d\d)\#(?P<wallet_number>\d*)$', survey, name="survey"),
|
url(r'^survey/(?P<year>\d\d\d\d)\#(?P<wallet_number>\d*)$', survey, name="survey"),
|
||||||
|
|
||||||
@ -110,7 +108,8 @@ urlpatterns = patterns('',
|
|||||||
url(r'^survey_scans/(?P<path>[^/]+)/$', view_surveys.surveyscansfolder, name="surveyscansfolder"),
|
url(r'^survey_scans/(?P<path>[^/]+)/$', view_surveys.surveyscansfolder, name="surveyscansfolder"),
|
||||||
url(r'^survey_scans/(?P<path>[^/]+)/(?P<file>[^/]+(?:png|jpg))$',
|
url(r'^survey_scans/(?P<path>[^/]+)/(?P<file>[^/]+(?:png|jpg))$',
|
||||||
view_surveys.surveyscansingle, name="surveyscansingle"),
|
view_surveys.surveyscansingle, name="surveyscansingle"),
|
||||||
|
url(r'^tunneldata/$', view_surveys.tunneldata, name="tunneldata"),
|
||||||
|
|
||||||
(r'^photos/(?P<path>.*)$', 'django.views.static.serve',
|
(r'^photos/(?P<path>.*)$', 'django.views.static.serve',
|
||||||
{'document_root': settings.PHOTOS_ROOT, 'show_indexes':True}),
|
{'document_root': settings.PHOTOS_ROOT, 'show_indexes':True}),
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user