Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 4 additions & 3 deletions app/controllers/admin/volunteers.py
Original file line number Diff line number Diff line change
Expand Up @@ -115,11 +115,12 @@ def volunteerDetailsPage(eventID):

waitlistUser = list(set([obj for obj in eventRsvpData if obj.rsvpWaitlist]))
rsvpUser = list(set([obj for obj in eventRsvpData if not obj.rsvpWaitlist ]))

attendedUser = list(set([obj for obj in eventParticipantData if not obj.rsvpWaitlist]))

return render_template("/events/volunteerDetails.html",
waitlistUser = waitlistUser,
attendedUser= eventParticipantData,
rsvpUser= rsvpUser,
attendedUser = attendedUser,
rsvpUser = rsvpUser,
event = event)


Expand Down
4 changes: 2 additions & 2 deletions app/logic/participants.py
Original file line number Diff line number Diff line change
Expand Up @@ -193,8 +193,8 @@ def sortParticipantsByStatus(event):
# if rsvp is required for the event, grab all volunteers that are in the waitlist
eventWaitlistData = [volunteer for volunteer in (eventParticipants + eventRsvpData) if volunteer.rsvpWaitlist and event.isRsvpRequired]

# put the rest of the users that are not on the waitlist into the volunteer data
eventVolunteerData = [volunteer for volunteer in eventNonAttendedData if volunteer not in eventWaitlistData]
# put all participants and non-waitlisted RSVPs into the volunteer data
eventVolunteerData = [volunteer for volunteer in (eventParticipants + eventNonAttendedData) if volunteer not in eventWaitlistData]
eventNonAttendedData = []

return eventNonAttendedData, eventWaitlistData, eventVolunteerData, eventParticipants
20 changes: 16 additions & 4 deletions app/templates/events/volunteerDetails.html
Original file line number Diff line number Diff line change
Expand Up @@ -59,20 +59,29 @@ <h4 class="nameSelect" nowrap><b>{{ participant.user.firstName }} {{ participant
{% macro printParticipants(type, attended, rsvp, waitlist) %}
{% set combinedParticipants = attended + rsvp + waitlist %}
{% for p in combinedParticipants | unique %}
{% if p in rsvp %}
{% if p in rsvp and not event.isRsvpRequired %}
{{createTable(p, 'invited') if type == 'table' else createCard(p, 'invited') }}
{% endif %}
{% if p in rsvp and event.isRsvpRequired %}
{{createTable(p, 'rsvp') if type == 'table' else createCard(p, 'rsvp') }}
{% endif %}
{% if p in attended%}
{{createTable(p, 'attended') if type == 'table' else createCard(p, 'attended') }}
{% endif %}
{% if p in waitlist %}
{{createTable(p, 'waitlist') if type == 'table' else createCard(p, 'waitlist') }}
{{createTable(p, 'waitlisted') if type == 'table' else createCard(p, 'waitlisted') }}
{% endif %}
{% endfor %}
{% endmacro %}

{% macro createCheckbox(checkboxName) %}
{% set labelText = "RSVP" if checkboxName == 'rsvp' else 'Waitlist' if checkboxName == 'waitlist' else 'Attended' %}
{%- set labelMap = {
'rsvp': 'RSVP',
'waitlist': 'Waitlisted',
'attended': 'Attended',
'invited': 'Invited'
} -%}
{% set labelText = labelMap.get(checkboxName, 'Invited') %}
<input class="displayCheckbox noprint" type="checkbox" name="selected_items" id="{{checkboxName}}Select" checked>
<label for="{{checkboxName}}Select">{{labelText}}</label><br>
{% endmacro %}
Expand All @@ -94,7 +103,7 @@ <h3 style="text-align: center; width:180%;">
<div class="row">
<div class="col">
<label><b>Volunteer Groups:</b></label><br>
{% if rsvpUser %}
{% if rsvpUser and event.isRsvpRequired %}
{{createCheckbox('rsvp')}}
{% endif %}
{% if waitlistUser %}
Expand All @@ -103,6 +112,9 @@ <h3 style="text-align: center; width:180%;">
{% if attendedUser %}
{{createCheckbox('attended')}}
{% endif %}
{% if rsvpUser and not event.isRsvpRequired %}
{{createCheckbox('invited')}}
{% endif %}
</div>
<div class="col">
<label><b>Included Information:</b></label><br>
Expand Down