add profile view of a member

This commit is contained in:
2020-08-27 16:55:55 +00:00
parent c9491f4d43
commit 18d519c157
6 changed files with 82 additions and 44 deletions

View File

@@ -5,6 +5,7 @@ from . import views
urlpatterns = [ urlpatterns = [
path('', views.index, name='members'), path('', views.index, name='members'),
path('<str:filter>', views.index), path('<str:filter>', views.members_view),
path('jobs/<str:slug>', views.index), path('jobs/<str:slug>', views.jobs_view),
path('member/<str:member_name>', views.profile_view),
] ]

View File

@@ -10,19 +10,10 @@ from rest_framework import permissions
# from django_filters.rest_framework import DjangoFilterBackend # from django_filters.rest_framework import DjangoFilterBackend
def index(request, slug=None, filter=None): def index(request, filter=None):
job_group = deque(JobGroup.objects.all()) job_group = deque(JobGroup.objects.all())
job_list = []
members = None members = None
if slug is not None:
job_names = JobMember.jobs.get_job_names(slug=slug)
active_members = JobMember.active_member.get_members_of_job(job_names=job_names)
inactive_members = JobMember.inactive_member.get_members_of_job(job_names=job_names)
for idx, item in enumerate(job_names):
job_list.append((job_names[idx], active_members[idx], inactive_members[idx]))
else:
if filter is None: if filter is None:
members = deque(Member.all_members.all()) members = deque(Member.all_members.all())
elif filter in Member.MemberRole: elif filter in Member.MemberRole:
@@ -32,13 +23,63 @@ def index(request, slug=None, filter=None):
context = { context = {
"job_group": job_group, "job_group": job_group,
"job_list": job_list,
"members": members, "members": members,
} }
return render(request, 'members/index.html', context) return render(request, 'members/index.html', context)
def jobs_view(request, slug=None):
job_group = deque(JobGroup.objects.all())
job_list = []
job_names = JobMember.jobs.get_job_names(slug=slug)
active_members = JobMember.active_member.get_members_of_job(job_names=job_names)
inactive_members = JobMember.inactive_member.get_members_of_job(job_names=job_names)
for idx, item in enumerate(job_names):
job_list.append((job_names[idx], active_members[idx], inactive_members[idx]))
context = {
"job_group": job_group,
"job_list": job_list,
}
return render(request, 'members/index.html', context)
def members_view(request, filter=None):
job_group = deque(JobGroup.objects.all())
if filter is None:
members = deque(Member.all_members.all())
elif filter in Member.MemberRole:
members = deque(Member.all_members.filter(role=filter))
else:
members = None
context = {
"job_group": job_group,
"members": members,
}
return render(request, 'members/index.html', context)
def profile_view(request, member_name=None):
job_group = deque(JobGroup.objects.all())
member = None
member = deque(Member.all_members.filter(mailaccount=member_name))
context = {
"job_group": job_group,
"member": member,
}
return render(request, 'members/index.html', context)
class MemberViewSet(viewsets.ModelViewSet): class MemberViewSet(viewsets.ModelViewSet):
""" """
API endpoint that allows users to be viewed or edited. API endpoint that allows users to be viewed or edited.

View File

@@ -11,34 +11,38 @@
<a id="members" data-toggle="tab" href="/members/A">Aktive Mitglieder</a> <a id="members" data-toggle="tab" href="/members/A">Aktive Mitglieder</a>
<a id="members" data-toggle="tab" href="/members/P">Inaktive Mitglieder</a> <a id="members" data-toggle="tab" href="/members/P">Inaktive Mitglieder</a>
{% for job in job_group %} {% for job in job_group %}
<a id="jobs-{{job.id}}" data-toggle="tab" href="/members/jobs/{{job.slug}}">{{job.name}}</a> <a id="jobs-{{job.slug}}" data-toggle="tab" href="/members/jobs/{{job.slug}}">{{job.name}}</a>
{% endfor %} {% endfor %}
</ul> </ul>
<!-- Tab panes --> <!-- Tab panes -->
<div class="tab-content" id="nav-tabContent"> <div class="tab-content" id="nav-tabContent">
{% for mem in member %}
{% with member=mem %}
{% include 'members/partials/_member_details.html' %}
{% endwith %}
{% endfor %}
<div id="members" class="tab-pane fade in active"> <div id="members" class="tab-pane fade in active">
{% if members == None %} {% if members is not None %}
{% else %}
{% include 'members/members_list.html' %} {% include 'members/members_list.html' %}
{% endif %} {% endif %}
</div> </div>
<div id="jobs-{{job.id}}" class="tab-pane">
{% if members is None %}
{% for job in job_list %} {% for job in job_list %}
<div id="jobs-{{job.slug}}" class="tab-pane">
<div class="grid-container">
{% if job_list|length > 1 %} {% if job_list|length > 1 %}
<h2>{{job.0}}</h2> <h2>{{job.0}}</h2>
{% endif %} {% endif %}
{% with active_members=job.1 inactive_members=job.2 %} {% with active_members=job.1 inactive_members=job.2 %}
{% include 'members/jobs_list.html' %} {% include 'members/jobs_list.html' %}
{% endwith %} {% endwith %}
{% endfor %}
{% endif %}
</div> </div>
{% endfor %}
</div> </div>
</div> </div>

View File

@@ -1,6 +1,4 @@
<div class="grid-container">
Aktuelle Mitglieder: {{active_members.count}} Aktuelle Mitglieder: {{active_members.count}}
<div class="grid-x"> <div class="grid-x">
{% for mem in active_members %} {% for mem in active_members %}

View File

@@ -1,6 +1,5 @@
<div class="grid-container"> <div class="grid-container">
<h1> Mitarbeiter Liste </h1>
<h2> Grid Style</h2> <h2> Grid Style</h2>
<div class="grid-x"> <div class="grid-x">
{% for member in members %} {% for member in members %}
@@ -16,11 +15,4 @@
{% include 'members/partials/_member.html' %} {% include 'members/partials/_member.html' %}
{% endfor %} {% endfor %}
</div> </div>
<h2>Detail List</h2>
<div class="grid-container">
{% for member in members %}
{% include 'members/partials/_member_details.html' %}
{% endfor %}
</div>
</div> </div>

View File

@@ -2,7 +2,9 @@
{# only thumb and name of member #} {# only thumb and name of member #}
{% load thumbnail %} {% load thumbnail %}
<a class="thumbnail member-thumb" style="width:150px;height:150px"> <a class="thumbnail member-thumb" href="/members/member/{{member.mailaccount}}" style="width:150px;height:150px">
{% if member.image %}<img src="{{member.image | thumbnail_url:'thumb'}}" />{% endif %} {% if member.image %}
<img src="{{member.image | thumbnail_url:'thumb'}}" />
{% endif %}
<div class="thumb-layer"><div><h1>{{member.nickname}}</h1> <p>{{member.firstname}} {{member.surname}}</p></div></div> <div class="thumb-layer"><div><h1>{{member.nickname}}</h1> <p>{{member.firstname}} {{member.surname}}</p></div></div>
</a> </a>