Only show voteresult-table where there is at least one published poll.

Also fix AssignmentPDF-Poll-Table
This commit is contained in:
Oskar Hahn 2012-07-10 00:47:00 +02:00
parent cd245e4605
commit 333349a1f2
4 changed files with 110 additions and 132 deletions

View File

@ -108,8 +108,7 @@ class Assignment(models.Model, SlideMixin):
return poll return poll
@property def vote_results(self, only_published):
def vote_results(self):
""" """
returns a table represented as a list with all candidates from all returns a table represented as a list with all candidates from all
related polls and their vote results. related polls and their vote results.
@ -117,6 +116,8 @@ class Assignment(models.Model, SlideMixin):
vote_results_dict = {} vote_results_dict = {}
# All polls related to this assigment # All polls related to this assigment
polls = self.poll_set.all() polls = self.poll_set.all()
if only_published:
polls = polls.filter(published=True)
# All PollOption-Objects related to this assignment # All PollOption-Objects related to this assignment
options = [] options = []
for poll in polls: for poll in polls:
@ -128,18 +129,15 @@ class Assignment(models.Model, SlideMixin):
continue continue
vote_results_dict[candidate] = [] vote_results_dict[candidate] = []
for poll in polls: for poll in polls:
votes = { votes = {}
'votes': {},
'published': poll.published,
}
try: try:
# candidate related to this poll # candidate related to this poll
poll_option = poll.get_options().get(candidate=candidate) poll_option = poll.get_options().get(candidate=candidate)
for vote in poll_option.get_votes(): for vote in poll_option.get_votes():
votes['votes'][vote.value] = vote.get_weight() votes[vote.value] = vote.get_weight()
except AssignmentOption.DoesNotExist: except AssignmentOption.DoesNotExist:
# candidate not in related to this poll # candidate not in related to this poll
votes['votes'] = None votes = None
vote_results_dict[candidate].append(votes) vote_results_dict[candidate].append(votes)
return vote_results_dict return vote_results_dict
@ -159,8 +157,8 @@ class Assignment(models.Model, SlideMixin):
data = super(Assignment, self).slide() data = super(Assignment, self).slide()
data['assignment'] = self data['assignment'] = self
data['title'] = self.name data['title'] = self.name
data['polls'] = self.poll_set.all() data['polls'] = self.poll_set.filter(published=True)
data['vote_results'] = self.vote_results data['vote_results'] = self.vote_results(only_published=True)
data['assignment_publish_winner_results_only'] = config['assignment_publish_winner_results_only'] data['assignment_publish_winner_results_only'] = config['assignment_publish_winner_results_only']
data['template'] = 'projector/Assignment.html' data['template'] = 'projector/Assignment.html'
return data return data

View File

@ -112,21 +112,19 @@
<tr> <tr>
<th>{% trans "Candidates" %}</th> <th>{% trans "Candidates" %}</th>
{% for poll in polls %} {% for poll in polls %}
{% if poll.published or perms.assignment.can_manage_assignment %} <th style="vertical-align: top; white-space:nowrap;">
<th style="vertical-align: top; white-space:nowrap;"> {{ poll.get_ballot }}. {% trans 'ballot' %}
{{ forloop.counter }}. {% trans 'ballot' %} {% if perms.assignment.can_manage_assignment %}
{% if perms.assignment.can_manage_assignment %} <br>
<br> <a class="publish_link {% if poll.published %}published{% endif %}"
<a class="publish_link {% if poll.published %}published{% endif %}" href="{% url assignment_poll_publish_status poll.id %}"
href="{% url assignment_poll_publish_status poll.id %}" title="{%trans 'Publish/unpublish results' %}">
title="{%trans 'Publish/unpublish results' %}"> <span></span>
<span></span> </a>
</a> <a href="{% url assignment_poll_view poll.id %}"><img src="{% static 'images/icons/edit.png' %}" title="{% trans 'Edit' %}"></a>
<a href="{% url assignment_poll_view poll.id %}"><img src="{% static 'images/icons/edit.png' %}" title="{% trans 'Edit' %}"></a> <a href="{% url assignment_poll_delete poll.id %}"><img src="{% static 'images/icons/delete.png' %}" title="{% trans 'Delete' %}"></a>
<a href="{% url assignment_poll_delete poll.id %}"><img src="{% static 'images/icons/delete.png' %}" title="{% trans 'Delete' %}"></a> {% endif %}
{% endif %} </th>
</th>
{% endif %}
{% endfor %} {% endfor %}
{% if assignment.profile.exists and perms.assignment.can_manage_assignment and assignment.status == "vot" %} {% if assignment.profile.exists and perms.assignment.can_manage_assignment and assignment.status == "vot" %}
<th> <th>
@ -144,7 +142,6 @@
<td class="candidate"> <td class="candidate">
{% if candidate in assignment.elected.all %} {% if candidate in assignment.elected.all %}
{% if perms.assignment.can_manage_assignment %} {% if perms.assignment.can_manage_assignment %}
{# What does this line do #}
<a class="election_link elected" href='{% url assignment_user_not_elected assignment.id candidate.id %}'></a> <a class="election_link elected" href='{% url assignment_user_not_elected assignment.id candidate.id %}'></a>
{% else %} {% else %}
<a class="elected"> <a class="elected">
@ -158,24 +155,20 @@
{% endif %} {% endif %}
{{ candidate }} {{ candidate }}
</td> </td>
{% for poll_dict in poll_list %} {% for vote in poll_list %}
{% if perms.assignment.can_manage_assignment or poll_dict.published %} <td style="white-space:nowrap;">
{% with vote=poll_dict.votes %} {% if 'Yes' in vote and 'No' in vote and 'Abstain' in vote %}
<td style="white-space:nowrap;"> <img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Yes }}<br>
{% if 'Yes' in vote and 'No' in vote and 'Abstain' in vote %} <img src="{% static 'images/icons/voting-no.png' %}" title="{% trans 'No' %}"> {{ vote.No }}<br>
<img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Yes }}<br> <img src="{% static 'images/icons/voting-abstention.png' %}" title="{% trans 'Abstention' %}"> {{ vote.Abstain }}<br>
<img src="{% static 'images/icons/voting-no.png' %}" title="{% trans 'No' %}"> {{ vote.No }}<br> {% elif 'Votes' in vote %}
<img src="{% static 'images/icons/voting-abstention.png' %}" title="{% trans 'Abstention' %}"> {{ vote.Abstain }}<br> <img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Votes }}
{% elif 'Votes' in vote %} {% elif vote == None %}
<img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Votes }} {% trans 'was not a <br> candidate'%}
{% elif vote == None %} {% else %}
{% trans 'was not a <br> candidate'%} &nbsp;
{% else %} {% endif %}
&nbsp; </td>
{% endif %}
</td>
{% endwith %}
{% endif %}
{% endfor %} {% endfor %}
{% if assignment.profile.exists and perms.assignment.can_manage_assignment and assignment.status == "vot" %} {% if assignment.profile.exists and perms.assignment.can_manage_assignment and assignment.status == "vot" %}
<td></td> <td></td>

View File

@ -54,10 +54,8 @@
<tr> <tr>
<th>{% trans "Candidates" %}</th> <th>{% trans "Candidates" %}</th>
{% for poll in assignment.poll_set.all %} {% for poll in polls %}
{% if poll.published %} <th><nobr>{{ poll.get_ballot }}. {% trans "ballot" %}</nobr></th>
<th><nobr>{{forloop.counter}}. {% trans "ballot" %}</nobr></th>
{% endif %}
{% endfor %} {% endfor %}
</tr> </tr>
@ -71,28 +69,24 @@
{% endif %} {% endif %}
{{ candidate }} {{ candidate }}
</td> </td>
{% for poll_dict in poll_list %} {% for vote in poll_list %}
{% if poll_dict.published %} <td style="white-space:nowrap;"{% if candidate in assignment.elected.all %} class="elected"{% endif %}>
{% with vote=poll_dict.votes %} {% if not assignment_publish_winner_results_only or candidate in assignment.elected.all %}
<td style="white-space:nowrap;"{% if candidate in assignment.elected.all %} class="elected"{% endif %}> {% if 'Yes' in vote and 'No' in vote and 'Abstain' in vote %}
{% if not assignment_publish_winner_results_only or candidate in assignment.elected.all %} <img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Yes }}<br>
{% if 'Yes' in vote and 'No' in vote and 'Abstain' in vote %} <img src="{% static 'images/icons/voting-no.png' %}" title="{% trans 'No' %}"> {{ vote.No }}<br>
<img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Yes }}<br> <img src="{% static 'images/icons/voting-abstention.png' %}" title="{% trans 'Abstention' %}"> {{ vote.Abstain }}<br>
<img src="{% static 'images/icons/voting-no.png' %}" title="{% trans 'No' %}"> {{ vote.No }}<br> {% elif 'Votes' in vote %}
<img src="{% static 'images/icons/voting-abstention.png' %}" title="{% trans 'Abstention' %}"> {{ vote.Abstain }}<br> <img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Votes }}
{% elif 'Votes' in vote %} {% elif vote == None %}
<img src="{% static 'images/icons/voting-yes.png' %}" title="{% trans 'Yes' %}"> {{ vote.Votes }} {% trans 'was not a <br> candidate'%}
{% elif vote == None %} {% else %}
{% trans 'was not a <br> candidate'%} &nbsp;
{% else %} {% endif %}
&nbsp; {% else %}
{% endif %} &nbsp;
{% else %} {% endif %}
&nbsp; </td>
{% endif %}
</td>
{% endwith %}
{% endif %}
{% endfor %} {% endfor %}
</tr> </tr>
{% endfor %} {% endfor %}

View File

@ -84,8 +84,14 @@ def view(request, assignment_id=None):
if request.user.has_perm('assignment.can_nominate_other'): if request.user.has_perm('assignment.can_nominate_other'):
form = AssignmentRunForm() form = AssignmentRunForm()
vote_results = assignment.vote_results
polls = assignment.poll_set.all() polls = assignment.poll_set.all()
if not request.user.has_perm('assignment.can_manage_assignment'):
polls = assignment.poll_set.filter(published=True)
vote_results = assignment.vote_results(only_published=True)
else:
polls = assignment.poll_set.all()
vote_results = assignment.vote_results(only_published=False)
return { return {
'assignment': assignment, 'assignment': assignment,
'form': form, 'form': form,
@ -328,10 +334,12 @@ class AssignmentPDF(PDFView):
# Assignment details (each assignment on single page) # Assignment details (each assignment on single page)
for assignment in assignments: for assignment in assignments:
story.append(PageBreak()) story.append(PageBreak())
story = self.get_assignment(assignment, story) # append the assignment to the story-object
self.get_assignment(assignment, story)
else: # print selected assignment else: # print selected assignment
assignment = Assignment.objects.get(id=assignment_id) assignment = Assignment.objects.get(id=assignment_id)
story = self.get_assignment(assignment, story) # append the assignment to the story-object
self.get_assignment(assignment, story)
def get_assignment(self, assignment, story): def get_assignment(self, assignment, story):
# title # title
@ -349,52 +357,56 @@ class AssignmentPDF(PDFView):
for c in assignment.profile.all(): for c in assignment.profile.all():
cell2b.append(Paragraph("<seq id='counter'/>.&nbsp; %s" % unicode(c), stylesheet['Signaturefield'])) cell2b.append(Paragraph("<seq id='counter'/>.&nbsp; %s" % unicode(c), stylesheet['Signaturefield']))
if assignment.status == "sea": if assignment.status == "sea":
for x in range(0,2*assignment.posts): for x in range(0, 2 * assignment.posts):
cell2b.append(Paragraph("<seq id='counter'/>.&nbsp; __________________________________________",stylesheet['Signaturefield'])) cell2b.append(Paragraph("<seq id='counter'/>.&nbsp; __________________________________________",stylesheet['Signaturefield']))
cell2b.append(Spacer(0,0.2*cm)) cell2b.append(Spacer(0,0.2*cm))
# Vote results # Vote results
# Preparing # Preparing
vote_results = assignment.vote_results vote_results = assignment.vote_results(only_published=True)
polls = assignment.poll_set.filter(published=True)
data_votes = [] data_votes = []
# Left side # Left side
cell3a = [] cell3a = []
cell3a.append(Paragraph("%s:" % (_("Vote results")), stylesheet['Heading4'])) cell3a.append(Paragraph("%s:" % (_("Vote results")), stylesheet['Heading4']))
if assignment.poll_set.count() > 1: if polls.count() == 1:
cell3a.append(Paragraph("%s %s" % (assignment.poll_set.count(), _("ballots")), stylesheet['Normal'])) cell3a.append(Paragraph("%s %s" % (polls.count(), _("ballot")), stylesheet['Normal']))
elif polls.count() > 1:
cell3a.append(Paragraph("%s %s" % (polls.count(), _("ballots")), stylesheet['Normal']))
# Add table head row # Add table head row
headrow = [] headrow = []
headrow.append(_("Candidates")) headrow.append(_("Candidates"))
for poll in assignment.poll_set.all(): for poll in polls:
if poll.published: headrow.append("%s." % poll.get_ballot())
headrow.append("%s." % poll.get_ballot())
data_votes.append(headrow) data_votes.append(headrow)
# Add result rows # Add result rows
elected_candidates = assignment.elected.all()
for candidate, poll_list in vote_results.iteritems(): for candidate, poll_list in vote_results.iteritems():
row = [] row = []
if candidate in assignment.elected.all():
row.append("* %s" % str(candidate).split('(',1)[0]) candidate_string = candidate.user.get_full_name()
else: if candidate in elected_candidates:
row.append(str(candidate).split('(',1)[0]) candidate_string = "* " + candidate_string
for poll_dict in poll_list: if candidate.group:
if poll_dict['published']: candidate_string += "\n(%s)" % candidate.group
vote = poll_dict['votes'] row.append(candidate_string)
if vote == None: for vote in poll_list:
row.append(_('was not a \ncandidate')) if vote == None:
elif 'Yes' in vote and 'No' in vote and 'Abstain' in vote: row.append('')
tmp = _("Y")+": "+str(vote['Yes'])+"\n" elif 'Yes' in vote and 'No' in vote and 'Abstain' in vote:
tmp += _("N")+": "+str(vote['No'])+"\n" tmp = _("Y")+": " + vote['Yes'] + "\n"
tmp += _("A")+": "+str(vote['Abstain']) tmp += _("N")+": " + vote['No'] + "\n"
row.append(tmp) tmp += _("A")+": " + vote['Abstain']
elif 'Votes' in vote: row.append(tmp)
row.append(str(vote['Votes'])) elif 'Votes' in vote:
else: row.append(vote['Votes'])
pass
else: else:
pass pass
data_votes.append(row) data_votes.append(row)
@ -402,37 +414,35 @@ class AssignmentPDF(PDFView):
# Add votes invalid row # Add votes invalid row
footrow_one = [] footrow_one = []
footrow_one.append(_("Invalid votes")) footrow_one.append(_("Invalid votes"))
for poll in assignment.poll_set.all(): for poll in polls:
if poll.published: footrow_one.append(poll.print_votesinvalid())
footrow_one.append(poll.print_votesinvalid())
data_votes.append(footrow_one) data_votes.append(footrow_one)
# Add votes cast row # Add votes cast row
footrow_two = [] footrow_two = []
footrow_two.append(_("Votes cast")) footrow_two.append(_("Votes cast"))
for poll in assignment.poll_set.all(): for poll in polls:
if poll.published: footrow_two.append(poll.print_votescast())
footrow_two.append(poll.print_votescast())
data_votes.append(footrow_two) data_votes.append(footrow_two)
table_votes=Table(data_votes) table_votes=Table(data_votes)
table_votes.setStyle( TableStyle([ table_votes.setStyle( TableStyle([
('GRID', (0,0), (-1,-1), 0.5, colors.grey), ('GRID', (0, 0), (-1, -1), 0.5, colors.grey),
('VALIGN',(0,0),(-1,-1), 'TOP'), ('VALIGN',(0, 0),(-1, -1), 'TOP'),
('LINEABOVE',(0,0),(-1,0),2,colors.black), ('LINEABOVE',(0, 0),(-1, 0), 2, colors.black),
('LINEABOVE',(0,1),(-1,1),1,colors.black), ('LINEABOVE',(0, 1),(-1, 1), 1, colors.black),
('LINEBELOW',(0,-1),(-1,-1),2,colors.black), ('LINEBELOW',(0, -1),(-1, -1), 2, colors.black),
('ROWBACKGROUNDS', (0, 1), (-1, -1), (colors.white, (.9, .9, .9))), ('ROWBACKGROUNDS', (0, 1), (-1, -1), (colors.white, (.9, .9, .9))),
])) ]))
# table # table
data = [] data = []
data.append([cell1a,cell1b]) data.append([cell1a,cell1b])
if table_votes: if polls:
data.append([cell3a,table_votes]) data.append([cell3a,table_votes])
data.append(['','* = '+_('elected')]) data.append(['', '* = '+_('elected')])
else: else:
data.append([cell2a,cell2b]) data.append([cell2a, cell2b])
data.append([Spacer(0,0.2*cm),'']) data.append([Spacer(0,0.2*cm),''])
t=Table(data) t=Table(data)
t._argW[0]=4.5*cm t._argW[0]=4.5*cm
@ -442,26 +452,9 @@ class AssignmentPDF(PDFView):
])) ]))
story.append(t) story.append(t)
story.append(Spacer(0,1*cm)) story.append(Spacer(0,1*cm))
# text # text
story.append(Paragraph("%s" % assignment.description.replace('\r\n','<br/>'), stylesheet['Paragraph'])) story.append(Paragraph("%s" % assignment.description.replace('\r\n','<br/>'), stylesheet['Paragraph']))
return story
def get_assignment_votes(self, assignment):
votes = []
for candidate in assignment.candidates:
tmplist = ((candidate, assignment.is_elected(candidate)), [])
for poll in assignment.poll_set.all():
if poll.published:
if poll.get_options().filter(candidate=candidate).exists():
option = AssignmentOption.objects.filter(poll=poll).get(candidate=candidate)
try:
tmplist[1].append(option.get_votes()[0])
except IndexError:
tmplist[1].append('')
else:
tmplist[1].append("-")
votes.append(tmplist)
return votes
class CreateAgendaItem(RedirectView): class CreateAgendaItem(RedirectView):