@@ -111,6 +111,13 @@ class JM2L_Year(Base): | |||
date_list = filter(lambda x: x.hour<12 or x.hour>=13, date_list) | |||
return date_list | |||
@property | |||
def DocLinks(self): | |||
from .upload import MediaPath | |||
return zip( MediaPath().get_list('presse', self.year_uid, 'Other'), | |||
MediaPath().get_thumb('presse', self.year_uid, 'Other') | |||
) | |||
class User(Base): | |||
__tablename__ = 'users' | |||
uid = Column(Integer, primary_key=True) | |||
@@ -271,16 +278,23 @@ class Tiers(Base): | |||
.filter(Media.media_table == 'tiers') \ | |||
.filter(Media.media_type == 'Image') \ | |||
.filter(Media.link_id == self.uid) | |||
@property | |||
def DocLinks(self): | |||
from .upload import MediaPath | |||
return zip( MediaPath().get_list('tiers', self.uid, 'Other'), | |||
MediaPath().get_thumb('tiers', self.uid, 'Other') | |||
) | |||
@property | |||
def PhotosLinks(self): | |||
from .upload import MediaPath | |||
return MediaPath().get_list('tiers', self.uid) | |||
return MediaPath().get_list('tiers', self.uid, 'Image') | |||
@property | |||
def ThumbLinks(self): | |||
from .upload import MediaPath | |||
return MediaPath().get_thumb('tiers', self.uid) | |||
return MediaPath().get_thumb('tiers', self.uid) | |||
class Role_Tiers(Base): | |||
""" Créer le lien entre le tiers et son rôle dans l'évenement en fonction de l'année""" | |||
@@ -14,19 +14,19 @@ | |||
</filter> | |||
<linearGradient id="BoxGradient-Conference" spreadMethod="pad" x1="100%" y1="0%" x2="50%" y2="100%"> | |||
<stop offset="0%" stop-color="#EEE" stop-opacity="0"/> | |||
<stop offset="15%" stop-color="#f9fde8" stop-opacity="1"/> | |||
<stop offset="15%" stop-color="#BDF86B" stop-opacity=".5"/> | |||
</linearGradient> | |||
<linearGradient id="BoxGradient-Atelier" spreadMethod="pad" x1="100%" y1="0%" x2="50%" y2="100%"> | |||
<stop offset="0%" stop-color="#EEE" stop-opacity="0"/> | |||
<stop offset="15%" stop-color="#faebeb" stop-opacity="1"/> | |||
<stop offset="15%" stop-color="#FF856E" stop-opacity=".5"/> | |||
</linearGradient> | |||
<linearGradient id="BoxGradient-Table-ronde" spreadMethod="pad" x1="100%" y1="0%" x2="50%" y2="100%"> | |||
<stop offset="0%" stop-color="#EEE" stop-opacity="0"/> | |||
<stop offset="15%" stop-color="#fff4e5" stop-opacity="1"/> | |||
<stop offset="15%" stop-color="#F369A5" stop-opacity=".5"/> | |||
</linearGradient> | |||
<linearGradient id="BoxGradient-Concert" spreadMethod="pad" x1="100%" y1="0%" x2="50%" y2="100%"> | |||
<stop offset="0%" stop-color="#EEE" stop-opacity="0"/> | |||
<stop offset="15%" stop-color="#2EE" stop-opacity="1"/> | |||
<stop offset="15%" stop-color="#65EA92" stop-opacity=".5"/> | |||
</linearGradient> | |||
</defs> | |||
</svg> |
@@ -1,7 +1,7 @@ | |||
<%namespace name="h" file="jm2l:templates/helpers.mako"/> | |||
<%namespace name="tables" file="jm2l:templates/Logistique/Tables.mako"/> | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
<%def name="Main(Exchanges)"> | |||
<%def name="Main(Exchanges, miam_form)"> | |||
<% | |||
DicExch = Exchanges.get_overview( request.user.uid ) | |||
%> | |||
@@ -17,7 +17,7 @@ DicExch = Exchanges.get_overview( request.user.uid ) | |||
<div class="tab-content"> | |||
<div class="tab-pane fade active in" id="ResumeInt">${Route_wrapper(DicExch)}</div> | |||
<div class="tab-pane fade" id="Miam">${Miam_wrapper()}</div> | |||
<div class="tab-pane fade" id="Miam">${Miam_wrapper(miam_form)}</div> | |||
<div class="tab-pane fade" id="Covoiturage">${Exchange_wrapper('C', DicExch['C'])}</div> | |||
<div class="tab-pane fade" id="Hebergement">${Exchange_wrapper('H', DicExch['H'])}</div> | |||
<div class="tab-pane fade" id="Materiel">${Exchange_wrapper('M', DicExch['M'])}</div> | |||
@@ -35,9 +35,14 @@ DicExch = Exchanges.get_overview( request.user.uid ) | |||
</fieldset> | |||
</%def> | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
<%def name="Miam_wrapper()"> | |||
<%def name="Miam_wrapper(miam_form)"> | |||
<fieldset> | |||
<legend>Qu'est ce qu'on mange ?</legend> | |||
<% | |||
DicForm = { | |||
} | |||
%> | |||
${h.DisplayForm(miam_form, DicForm)} | |||
</fieldset> | |||
</%def> | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
@@ -84,26 +84,26 @@ fieldset:disabled { | |||
<legend>Départ</legend> | |||
<div class="form-inline"> | |||
Je repars | |||
<select style="width:12em;" id="Departure:Place" class="formforform-field" name="field_7" title="Alors, j'arrive"> | |||
<select style="width:12em;" id="Departure:Place" class="formforform-field" name="Departure:Place" title="Alors, j'arrive"> | |||
% for place in Places: | |||
<option value="${place.place_id}">${place.display_name}</option> | |||
% endfor | |||
</select> | |||
le | |||
<select style="width:7em;" id="Departure:Day" class="formforform-field" name="field_8" title="Le"> | |||
<select style="width:7em;" id="Departure:Day" class="formforform-field" name="Departure:Day" title="Le"> | |||
<option value="28">Samedi</option> | |||
<option value="29">Dimanche</option> | |||
<option value="30">Lundi</option> | |||
</select> | |||
, | |||
<select style="width:14em;" id="Departure:Confidence" class="formforform-field" name="field_8" title="Le"> | |||
<select style="width:14em;" id="Departure:Confidence" class="formforform-field" name="Departure:Confidence" title="Le"> | |||
<option value="Exacte" selected="selected">exactement</option> | |||
<option value="Approximative">approximativement</option> | |||
<option value="à peu près">à peu près (5 à 15 min)</option> | |||
<option value="à une vache près">à une vache près (1h)</option> | |||
</select> | |||
à | |||
<select style="width:6em;" id="Departure:Hour" class="formforform-field" name="field_8" title="à"> | |||
<select style="width:6em;" id="Departure:Hour" class="formforform-field" name="Departure:Hour" title="à"> | |||
% for hour in range(24): | |||
% for minutes in range(0,60,10): | |||
<option value="${hour}h${minutes}" | |||
@@ -156,9 +156,15 @@ fieldset:disabled { | |||
</p> | |||
</fieldset> | |||
<center> | |||
% if 1: | |||
<button type="submit" class="btn btn-large btn-primary" /> | |||
<i class="icon-ok icon-white"></i> Enregistrer | |||
<i class="icon-ok icon-white"></i> Je viens aux JM2L 2015 | |||
</button> | |||
% else: | |||
<button type="submit" class="btn btn-large btn-primary" /> | |||
<i class="icon-ok icon-white"></i> Enregistrer les modifications | |||
</button> | |||
% endif | |||
</center> | |||
</form> | |||
@@ -10,6 +10,7 @@ DisplayYear = request.session.get('year',2015) | |||
% if content and content.doss_presse: | |||
<div class="span8 offset1"> | |||
${content.doss_presse | n} | |||
${helpers.medias(content)} | |||
</div> | |||
% endif | |||
<div class="span3"> | |||
@@ -29,20 +29,8 @@ TabDisplay = [ | |||
padding:5px; | |||
height:100%; | |||
} | |||
.Conference { | |||
fill: #f9fde8; | |||
} | |||
.Concert { | |||
fill: #2EE; | |||
} | |||
.Atelier { | |||
fill: #faebeb; | |||
} | |||
.Table-ronde { | |||
fill: #fff4e5; | |||
} | |||
.Repas { | |||
fill: #2EE; | |||
.EvtBox a { | |||
color: #666; | |||
} | |||
svg { | |||
font: 10px sans-serif; | |||
@@ -200,8 +200,19 @@ TabJs = {'select':[], 'desc':[]} | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
## Wrapper pour afficher les fichiers | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
<%def name="medias(MediaType, UID, desc=None)"> \ | |||
<%def name="medias(Entity, UID=None, desc=None)"> \ | |||
<hr> | |||
<ul class="thumbnails"> | |||
% for filelink, thumb in Entity.DocLinks: | |||
<li class="span2"> | |||
<div class="media"> | |||
<a class="pull-left" href="${filelink}"> | |||
<img class="media-object" src="${thumb}" /> | |||
</a> | |||
</div> | |||
</li> | |||
% endfor | |||
</ul> | |||
</%def> | |||
## -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= | |||
## Wrapper pour uploader | |||
@@ -112,7 +112,7 @@ | |||
</div> | |||
<div class="tab-pane fade" id="Logistique"> | |||
${intendance.Main(Exchanges)} | |||
${intendance.Main(Exchanges, miam_form)} | |||
</div> | |||
<div class="tab-pane fade" id="Frais"> | |||
@@ -124,6 +124,7 @@ ${helpers.uploader_js()} | |||
% if request.user: | |||
% if request.user.Staff: | |||
<li><a href="/Staff">Partie Staff</a></li> | |||
<li><a href="/ListSalles">Gérer les salles</a></li> | |||
% endif | |||
<li><a href="/sign/out">Me déconnecter</a></li> | |||
% else: | |||
@@ -17,11 +17,11 @@ ${event.start_time.strftime('%H:%M')} à ${event.end_time.strftime('%H:%M')} | |||
- <strong>Salle</strong>: ${event.Salle.name} | |||
%endif | |||
</div> | |||
%if event.event_uid: | |||
<a href="http://jm2l.linux-azur.org/node/${event.event_uid}">Link</a> - | |||
%endif | |||
##%if event.event_uid: | |||
## <a href="http://jm2l.linux-azur.org/node/${event.event_uid}">Link</a> - | |||
##%endif | |||
% if event.for_year==2015 and request.user and (request.user.Staff or request.user in event.intervenants): | |||
<a href="/MesJM2L/${event.for_year}/${event.event_type}/${event.slug}">Editer</a> | |||
<a href="/MesJM2L/${event.for_year}/${event.event_type}/${event.slug}">Modifier</a> | |||
% elif request.user and request.user.Staff: | |||
<a href="/MesJM2L/${event.for_year}/${event.event_type}/${event.slug}">Editer</a> | |||
% endif | |||
@@ -111,7 +111,7 @@ ${event.start_time.strftime('%H:%M')} à ${event.end_time.strftime('%H:%M')} | |||
<div class="footborderbox"> | |||
% if iterv.website: | |||
<div style="float:right;"> | |||
<a href="http://${iterv.website}">${iterv.website}</a> | |||
<a href="${iterv.website}">${iterv.website}</a> | |||
</div> | |||
% endif | |||
</div> | |||
@@ -28,7 +28,7 @@ ${The_entity_type.entity_subtype} | |||
% if entity.PhotosLinks: | |||
<div style="float:right;padding:5px;border: 1px solid #eee;background-color:white;"> | |||
% for img_path in entity.PhotosLinks: | |||
<img src="${img_path}" alt="logo" /> | |||
<img src="${img_path}" style="max-height:205px;max-width:335px;" alt="logo" /> | |||
% endfor | |||
</div> | |||
% endif | |||
@@ -37,6 +37,9 @@ ${The_entity_type.entity_subtype} | |||
% else: | |||
<p>Cette entité n'a pas de description.</p> | |||
% endif | |||
% if entity.DocLinks: | |||
${helpers.medias(entity)} | |||
% endif | |||
</div> | |||
<div class="footborderbox"> | |||
% if entity.website: | |||
@@ -88,7 +91,7 @@ ${The_entity_type.entity_subtype} | |||
<div class="footborderbox"> | |||
% if iterv.website: | |||
<div style="float:right;"> | |||
<a href="http://${iterv.website}">${iterv.website}</a> | |||
<a href="${iterv.website}">${iterv.website}</a> | |||
</div> | |||
% endif | |||
</div> | |||
@@ -43,7 +43,7 @@ mimetypes.init() | |||
class MediaPath(): | |||
def get_list(self, media_table, linked_id): | |||
def get_list(self, media_table, linked_id, MediaType=None): | |||
filelist = list() | |||
curpath = self.get_mediapath(media_table, linked_id, None) | |||
if not os.path.isdir(curpath): | |||
@@ -54,24 +54,36 @@ class MediaPath(): | |||
if f.endswith('.type'): | |||
continue | |||
if f: | |||
filename, ext = os.path.splitext( f ) | |||
tmpurl = '/image/%s/%d/%s' % (media_table, linked_id, f) | |||
filelist.append(tmpurl) | |||
if MediaType is None: | |||
filelist.append(tmpurl) | |||
elif MediaType=='Image' and ext.lower() in ['.gif','.jpg','.png','.svg','.jpeg']: | |||
filelist.append(tmpurl) | |||
elif MediaType=='Other' and ext.lower() not in ['.gif','.jpg','.png','.svg','.jpeg']: | |||
filelist.append(tmpurl) | |||
return filelist | |||
def get_thumb(self, media_table, linked_id): | |||
def get_thumb(self, media_table, linked_id, MediaType=None): | |||
filelist = list() | |||
curpath = self.get_mediapath(media_table, linked_id, None) | |||
curpath = os.path.join( curpath, 'thumbnails') | |||
if not os.path.isdir(curpath): | |||
return list() | |||
for f in os.listdir(curpath): | |||
filename, ext = os.path.splitext( f ) | |||
if os.path.isdir(os.path.join(curpath,f)): | |||
continue | |||
if f.endswith('.type'): | |||
continue | |||
if f: | |||
tmpurl = '/image/%s/%d/thumbnails/%s' % (media_table, linked_id, f) | |||
filelist.append(tmpurl) | |||
if MediaType is None: | |||
filelist.append(tmpurl) | |||
elif MediaType=='Image' and len( os.path.splitext(filename)[1] )==0: | |||
filelist.append(tmpurl) | |||
elif MediaType=='Other' and len( os.path.splitext(filename)[1] ): | |||
filelist.append(tmpurl) | |||
return filelist | |||
def get_mediapath(self, media_table, linked_id, name): | |||