8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2025-01-13 11:44:29 +00:00

Déplace une partie des vérif dans views pour alléger le template

This commit is contained in:
Maël Kervella 2017-09-10 14:17:59 +00:00 committed by Pierre Cadart
parent c5e7431e1a
commit 67b271008b
3 changed files with 63 additions and 83 deletions

View file

@ -36,75 +36,50 @@ with this program; if not, write to the Free Software Foundation, Inc.,
<th></th> <th></th>
</tr> </tr>
</thead> </thead>
{% for revision in revisions_list %} {% for rev in reversions_list %}
{% for reversion in revision.revision.version_set.all %}
{% if reversion.content_type.name in 'ban,whitelist,user,vente,interface'|slice:',' %}
<tr> <tr>
<td>{{ revision.datetime }}</td> <td>{{ rev.datetime }}</td>
{% if reversion.content_type.name == 'ban' %} {% if rev.rev.content_type.name == 'ban' %}
<td> <td>
{% if revision.revision.user.et_username %} {{ rev.username }} a banni
{{ revision.revision.user.get_username }} <a href="{% url 'users:profil' rev.rev.object.user_id %}">{{ rev.rev.object.user.get_username }}</a>
{% else %} (<i>{{ rev.rev.object.raison }}</i>)
?
{% endif %}
a banni
<a href="{% url 'users:profil' reversion.object.user_id %}">{{ reversion.object.user.get_username }}</a>
(<i>{{ reversion.object.raison }}</i>)
</td> </td>
{% elif reversion.content_type.name == 'whitelist' %} {% elif rev.rev.content_type.name == 'whitelist' %}
<td> <td>
{% if revision.revision.user.get_username %} {{ rev.username }} a autorisé gracieusement
{{ revision.revision.user.get_username }} <a href="{% url 'users:profil' rev.rev.object.user_id %}">{{ rev.rev.object.user.get_username }}</a>
{% else %} (<i>{{ rev.rev.object.raison }}</i>)
?
{% endif %}
a autorisé gracieusement
<a href="{% url 'users:profil' reversion.object.user_id %}">{{ reversion.object.user.get_username }}</a>
(<i>{{ reversion.object.raison }}</i>)
</td> </td>
{% elif reversion.content_type.name == 'user' %} {% elif rev.rev.content_type.name == 'user' %}
<td> <td>
{% if revision.revision.user.get_username %} {{ rev.username }} a ajouté
{{ revision.revision.user.get_username }} <a href="{% url 'users:profil' rev.rev.object.id %}">{{ rev.rev.object.get_username }}</a>
{% else %}
?
{% endif %}
a ajouté
<a href="{% url 'users:profil' reversion.object.id %}">{{ reversion.object.get_username }}</a>
</td> </td>
{% elif reversion.content_type.name == 'vente' %} {% elif rev.rev.content_type.name == 'vente' %}
<td> <td>
<a href="{% url 'users:profil' reversion.object.facture.user_id %}">{{ reversion.object.facture.user.get_username }}</a> <a href="{% url 'users:profil' rev.rev.object.facture.user_id %}">{{ rev.rev.object.facture.user.get_username }}</a>
a acheté a acheté {{ rev.rev.object.number }}x {{ rev.rev.object.name }}
{{ reversion.object.number }}x {{ reversion.object.name }} {% if rev.rev.object.iscotisation %}
{% if reversion.object.iscotisation %} (<i>+{{ rev.rev.object.duration }} mois</i>)
(<i>+{{ reversion.object.duration }} mois</i>)
{% endif %} {% endif %}
</td> </td>
{% elif reversion.content_type.name == 'interface' %} {% elif rev.rev.content_type.name == 'interface' %}
<td> <td>
{% if revision.revision.user.get_username %} {{ rev.username }} a ajouté une interface à
{{ revision.revision.user.get_username }} <a href="{% url 'users:profil' rev.rev.object.machine.user_id %}">{{ rev.rev.object.machine.user.get_username }}</a>
{% else %} (<i>MAC : {{ rev.rev.object.mac_bare }}</i>)
?
{% endif %}
a ajouté une interface à
<a href="{% url 'users:profil' reversion.object.machine.user_id %}">{{ reversion.object.machine.user.get_username }}</a>
(<i>MAC : {{ reversion.object.mac_bare }}</i>)
</td> </td>
{% endif %} {% endif %}
{% if is_bureau %} {% if is_bureau %}
<td> <td>
<a class="btn btn-danger btn-sm" role="button" href="{% url 'logs:revert-action' revision.revision.id %}"> <a class="btn btn-danger btn-sm" role="button" href="{% url 'logs:revert-action' rev.id %}">
<i class="glyphicon glyphicon-remove"></i> <i class="glyphicon glyphicon-remove"></i>
Annuler Annuler
</a> </a>
</td> </td>
{% endif %} {% endif %}
</tr> </tr>
{% endif %}
{% endfor %}
{% endfor %} {% endfor %}
</table> </table>

View file

@ -29,7 +29,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
{% block content %} {% block content %}
<h2>Actions effectuées</h2> <h2>Actions effectuées</h2>
{% include "logs/aff_summary.html" with revisions_list=revisions_list %} {% include "logs/aff_summary.html" with reversions_list=reversions_list %}
<br /> <br />
<br /> <br />
<br /> <br />

View file

@ -70,26 +70,31 @@ def index(request):
options, created = GeneralOption.objects.get_or_create() options, created = GeneralOption.objects.get_or_create()
pagination_number = options.pagination_number pagination_number = options.pagination_number
revisions_not_filtered = Revision.objects.all().order_by('date_created').reverse().select_related('user').prefetch_related('version_set__object') revisions = Revision.objects.all().order_by('date_created').reverse().select_related('user').prefetch_related('version_set__object')
revisions = [] reversions = []
for revision in revisions_not_filtered : for revision in revisions :
reversions = revision.version_set.all() for reversion in revision.version_set.all() :
for reversion in reversions : if reversion.content_type.name in ['ban', 'whitelist', 'vente', 'cotisation', 'interface', 'user'] :
if reversion.content_type.name in ['ban', 'whitelist', 'vente', 'cotisation', 'interface', 'machine', 'user'] : reversions.append(
revisions.append( {'datetime':revision.date_created.strftime('%d/%m/%y %H:%M:%S'), 'revision':revision } ) {'id' : revision.id,
'datetime': revision.date_created.strftime('%d/%m/%y %H:%M:%S'),
'username': revision.user.get_username() if revision.user else '?',
'user_id': revision.user_id,
'rev': reversion }
)
break break
paginator = Paginator(revisions, pagination_number) paginator = Paginator(reversions, pagination_number)
page = request.GET.get('page') page = request.GET.get('page')
try: try:
revisions = paginator.page(page) reversions = paginator.page(page)
except PageNotAnInteger: except PageNotAnInteger:
# If page is not an integer, deliver first page. # If page is not an integer, deliver first page.
revisions = paginator.page(1) reversions = paginator.page(1)
except EmptyPage: except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results. # If page is out of range (e.g. 9999), deliver last page of results.
revisions = paginator.page(paginator.num_pages) reversions = paginator.page(paginator.num_pages)
return render(request, 'logs/index.html', {'revisions_list': revisions}) return render(request, 'logs/index.html', {'reversions_list': reversions})
@login_required @login_required
@permission_required('cableur') @permission_required('cableur')