1 # -*- encoding: utf-8 -*-
5 from django
import template
7 from project
import groups
9 from project
.dae
.workflow
import ETATS_EDITABLE
12 register
= template
.Library()
15 def test_membre_drh(user
):
16 grps
= [g
.name
for g
in user
.groups
.all()]
17 if groups
.DRH_NIVEAU_1
in grps
or groups
.DRH_NIVEAU_2
in grps
:
23 def peut_ajouter(user
):
24 for g
in [g
.name
for g
in user
.groups
.all()]:
25 if g
in (groups
.ADMINISTRATEURS
,
26 groups
.CORRESPONDANT_RH
,
33 def peut_importer(user
):
34 return groups
.DRH_NIVEAU_1
in [g
.name
for g
in user
.groups
.all()]
37 def est_editable(obj
, user
):
39 groupes_users
= [g
.name
for g
in user
.groups
.all()]
40 if obj
.etat
in ETATS_EDITABLE
and \
41 (obj
in klass
.objects
.mes_choses_a_faire(user
).all() or \
42 groups
.DRH_NIVEAU_1
in groupes_users
or \
43 groups
.DRH_NIVEAU_2
in groupes_users
):
50 return os
.path
.basename(path
)
52 @register.inclusion_tag('dae/sort_header.html', takes_context
=True)
53 def sort_header(context
, field
, title
):
54 """Génère une entête qu'on peut cliquer pour trier la colonne correspondante dans une table."""
55 qs
= context
['request'].GET
.copy()
56 current
= qs
.get('tri', None)
58 cls
= 'header headerSortUp'
59 qs
['tri'] = '-' + field
60 elif current
== '-' + field
:
61 cls
= 'header headerSortDown'
66 return {'title': title
, 'qs': qs
.urlencode(), 'cls': cls
}
68 @register.inclusion_tag('dae/pagination.html', takes_context
=True)
69 def pagination(context
, page
):
70 """Génère la navigation permettant de se promener de page en page."""
71 qs
= context
['request'].GET
72 previous_qs
= qs
.copy()
73 previous_qs
['page'] = page
.previous_page_number()
75 next_qs
['page'] = page
.next_page_number()
76 return {'page': page
, 'previous_qs': previous_qs
.urlencode(), 'next_qs': next_qs
.urlencode()}