2017-08-20 00:39:19 +02:00
|
|
|
from datetime import timedelta, date
|
2017-08-19 01:32:26 +02:00
|
|
|
from django import template
|
|
|
|
from django.conf import settings
|
2018-10-14 15:50:55 +02:00
|
|
|
from django.utils import timezone, formats
|
2017-08-26 18:05:20 +02:00
|
|
|
import locale
|
2017-08-20 00:39:19 +02:00
|
|
|
|
2018-01-28 23:44:48 +01:00
|
|
|
from django.utils.translation import ugettext as _
|
|
|
|
|
|
|
|
from ..models import COFActuPage, COFUtilPage
|
2017-08-19 01:32:26 +02:00
|
|
|
|
|
|
|
import re
|
|
|
|
|
|
|
|
register = template.Library()
|
|
|
|
|
|
|
|
@register.filter()
|
|
|
|
def obfuscate_mail(value):
|
2017-08-22 00:58:18 +02:00
|
|
|
val = value.replace('', '-').replace('@', 'arbre').replace('.', 'pont')[1:]
|
2017-08-19 01:32:26 +02:00
|
|
|
return val
|
2017-08-20 00:39:19 +02:00
|
|
|
|
2018-01-28 23:44:48 +01:00
|
|
|
@register.inclusion_tag("cofcms/calendar.html", takes_context=True)
|
|
|
|
def calendar(context, month=None, year=None):
|
2017-08-20 00:39:19 +02:00
|
|
|
now = timezone.now()
|
2018-01-28 23:44:48 +01:00
|
|
|
if month is None:
|
|
|
|
month_start = date(now.year, now.month, 1)
|
|
|
|
else:
|
|
|
|
month_start = date(year, month, 1)
|
2017-08-20 00:39:19 +02:00
|
|
|
next_month = month_start + timedelta(days=32)
|
|
|
|
next_month = date(next_month.year, next_month.month, 1)
|
2018-01-28 23:44:48 +01:00
|
|
|
prev_month = month_start - timedelta(days=2)
|
2017-08-22 00:58:18 +02:00
|
|
|
month_prestart = month_start - timedelta(days=month_start.weekday())
|
2017-08-20 00:39:19 +02:00
|
|
|
month_postend = next_month + timedelta(days=(next_month.weekday()+6)%7)
|
2018-01-22 21:24:20 +01:00
|
|
|
events = COFActuPage.objects.live()\
|
|
|
|
.filter(date_start__range=[month_prestart,
|
2018-01-28 23:44:48 +01:00
|
|
|
month_postend],
|
|
|
|
is_event=True)\
|
2018-01-22 21:24:20 +01:00
|
|
|
.order_by('-date_start')
|
2017-08-20 00:39:19 +02:00
|
|
|
events = list(events)
|
|
|
|
weeks = []
|
|
|
|
curday = month_prestart
|
|
|
|
deltaday = timedelta(days=1)
|
|
|
|
while curday < next_month and len(weeks)<10:
|
|
|
|
week = []
|
|
|
|
for k in range(7):
|
|
|
|
curevents = []
|
|
|
|
for k in range(len(events)-1, -1, -1):
|
|
|
|
e = events[k]
|
|
|
|
if e.date_start.date() > curday: break
|
|
|
|
if (e.date_start if e.date_end is None else e.date_end).date() < curday:
|
|
|
|
del events[k]
|
|
|
|
else:
|
|
|
|
curevents.append(e)
|
|
|
|
day = {'day': curday.day,
|
2018-01-28 23:44:48 +01:00
|
|
|
'date': curday,
|
2018-10-14 15:50:55 +02:00
|
|
|
'class': (('today ' if curday == now.date() else '')
|
2018-01-28 23:44:48 +01:00
|
|
|
+ ('in ' if (curday.month == month_start.month
|
|
|
|
and curday.year == month_start.year)
|
|
|
|
else 'out ')
|
2017-08-26 18:05:20 +02:00
|
|
|
+ ('hasevent' if len(curevents) > 0 else '')),
|
2017-08-20 00:39:19 +02:00
|
|
|
'events': curevents}
|
|
|
|
week.append(day)
|
|
|
|
curday += deltaday
|
|
|
|
weeks.append(week)
|
2017-08-22 00:58:18 +02:00
|
|
|
|
2018-01-28 23:44:48 +01:00
|
|
|
|
|
|
|
# Calendar next/prev urls
|
2017-08-26 18:05:20 +02:00
|
|
|
try:
|
2018-01-28 23:44:48 +01:00
|
|
|
utilpage = COFUtilPage.objects.live()[0]
|
|
|
|
except COFUtilPage.DoesNotExist:
|
|
|
|
utilpage = None
|
|
|
|
request = context['request']
|
|
|
|
burl = utilpage.debugged_get_url(request) + "/"
|
|
|
|
prev_url = burl + utilpage.reverse_subpage("calendar",
|
2018-10-14 15:50:55 +02:00
|
|
|
args=[str(prev_month.year),
|
|
|
|
str(prev_month.month)])
|
2018-01-28 23:44:48 +01:00
|
|
|
next_url = burl + utilpage.reverse_subpage("calendar",
|
2018-10-14 15:50:55 +02:00
|
|
|
args=[str(next_month.year),
|
|
|
|
str(next_month.month)])
|
2018-01-28 23:44:48 +01:00
|
|
|
context.push({"events": events, "weeks": weeks, "this_month": month_start,
|
|
|
|
"prev_month": prev_url, "next_month": next_url})
|
|
|
|
return context
|
|
|
|
|
|
|
|
@register.inclusion_tag("cofcms/mini_calendar.html")
|
|
|
|
def mini_calendar(event):
|
2017-08-22 00:58:18 +02:00
|
|
|
days = []
|
|
|
|
today = timezone.now().date()
|
|
|
|
date_start = event.date_start.date()
|
|
|
|
date_end = event.date_end.date() if event.date_end else date_start
|
|
|
|
week_start = date_start - timedelta(days=date_start.weekday())
|
|
|
|
curday = week_start
|
|
|
|
for i in range(7):
|
|
|
|
days.append({'day': curday.day,
|
|
|
|
'hasevent': curday >= date_start and curday <= date_end,
|
|
|
|
'today': curday == today})
|
|
|
|
curday += timedelta(days=1)
|
|
|
|
return {"days": days}
|
2018-01-28 23:44:48 +01:00
|
|
|
|
|
|
|
|
|
|
|
@register.filter()
|
2018-10-14 15:50:55 +02:00
|
|
|
def dates(event):
|
|
|
|
def factorize_suffix(a, b):
|
|
|
|
i = -1
|
|
|
|
imin = -min(len(a), len(b))
|
|
|
|
while i>imin and a[i] == b[i]:
|
|
|
|
i -= 1
|
|
|
|
if i == -1:
|
|
|
|
return (a, b, '')
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
2018-10-14 15:50:55 +02:00
|
|
|
return (a[:i+1], b[:i+1], a[i+1:])
|
|
|
|
|
|
|
|
datestart_string = formats.date_format(event.date_start)
|
|
|
|
timestart_string = formats.time_format(event.date_start)
|
2018-01-28 23:44:48 +01:00
|
|
|
if event.date_end:
|
|
|
|
if event.date_end.date() == event.date_start.date():
|
|
|
|
if event.all_day:
|
2018-10-14 15:50:55 +02:00
|
|
|
return _("le %s") % datestart_string
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
|
|
|
return _("le %s de %s à %s") % \
|
2018-10-14 15:50:55 +02:00
|
|
|
(datestart_string,
|
|
|
|
timestart_string,
|
|
|
|
formats.time_format(event.date_end))
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
2018-10-14 15:50:55 +02:00
|
|
|
dateend_string = formats.date_format(event.date_end)
|
|
|
|
timeend_string = formats.time_format(event.date_end)
|
|
|
|
diffstart, diffend, common = factorize_suffix(datestart_string,
|
|
|
|
dateend_string)
|
2018-01-28 23:44:48 +01:00
|
|
|
if event.all_day:
|
2018-10-14 15:50:55 +02:00
|
|
|
return _("du %s au %s%s") % \
|
|
|
|
(diffstart, diffend, common)
|
|
|
|
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
2018-10-14 15:50:55 +02:00
|
|
|
return _("du %s%s à %s au %s à %s") % \
|
|
|
|
(diffstart, common, timestart_string,
|
|
|
|
diffend, formats.time_format(event.date_end))
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
|
|
|
if event.all_day:
|
2018-10-14 15:50:55 +02:00
|
|
|
return _("le %s") % datestart_string
|
2018-01-28 23:44:48 +01:00
|
|
|
else:
|
2018-10-14 15:50:55 +02:00
|
|
|
return _("le %s à %s") % (datestart_string, timestart_string)
|