merged
This commit is contained in:
@@ -72,11 +72,13 @@ class MemberManager(models.Manager):
|
|||||||
|
|
||||||
class JobManager(models.Manager):
|
class JobManager(models.Manager):
|
||||||
def get_job_names(self, slug):
|
def get_job_names(self, slug):
|
||||||
tmp_list = []
|
job_list = []
|
||||||
|
slug_list = []
|
||||||
for i in self.get_queryset().filter(Q(job__job_group__slug=slug)):
|
for i in self.get_queryset().filter(Q(job__job_group__slug=slug)):
|
||||||
if i.job.name not in tmp_list:
|
if i.job.name not in job_list:
|
||||||
tmp_list.append(i.job.name)
|
job_list.append(i.job.name)
|
||||||
return tmp_list
|
slug_list.append(i.job.slug)
|
||||||
|
return job_list, slug_list
|
||||||
|
|
||||||
|
|
||||||
class Member(models.Model):
|
class Member(models.Model):
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
from django.http import Http404
|
||||||
from django.shortcuts import render
|
from django.shortcuts import render
|
||||||
|
|
||||||
from collections import deque
|
from collections import deque
|
||||||
@@ -9,16 +10,9 @@ 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):
|
||||||
job_group = deque(JobGroup.objects.all())
|
job_group = deque(JobGroup.objects.all())
|
||||||
members = None
|
members = deque(Member.all_members.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 = {
|
context = {
|
||||||
"job_group": job_group,
|
"job_group": job_group,
|
||||||
@@ -32,12 +26,18 @@ def jobs_view(request, slug=None):
|
|||||||
job_group = deque(JobGroup.objects.all())
|
job_group = deque(JobGroup.objects.all())
|
||||||
job_list = []
|
job_list = []
|
||||||
|
|
||||||
job_names = JobMember.jobs.get_job_names(slug=slug)
|
job_names, slug_list = JobMember.jobs.get_job_names(slug=slug)
|
||||||
|
|
||||||
|
if not job_names:
|
||||||
|
raise Http404("no jobs")
|
||||||
|
|
||||||
active_members = JobMember.active_member.get_members_of_job(job_names=job_names)
|
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)
|
inactive_members = JobMember.inactive_member.get_members_of_job(job_names=job_names)
|
||||||
|
|
||||||
for idx, item in enumerate(job_names):
|
for idx, item in enumerate(job_names):
|
||||||
job_list.append((job_names[idx], active_members[idx], inactive_members[idx]))
|
job_list.append(
|
||||||
|
(job_names[idx], active_members[idx], inactive_members[idx], slug_list[idx])
|
||||||
|
)
|
||||||
|
|
||||||
context = {
|
context = {
|
||||||
"job_group": job_group, # Das sind die Tabs
|
"job_group": job_group, # Das sind die Tabs
|
||||||
@@ -49,12 +49,10 @@ def jobs_view(request, slug=None):
|
|||||||
def members_view(request, filter=None):
|
def members_view(request, filter=None):
|
||||||
job_group = deque(JobGroup.objects.all())
|
job_group = deque(JobGroup.objects.all())
|
||||||
|
|
||||||
if filter is None:
|
if filter in Member.MemberRole:
|
||||||
members = deque(Member.all_members.all())
|
|
||||||
elif filter in Member.MemberRole:
|
|
||||||
members = deque(Member.all_members.filter(role=filter))
|
members = deque(Member.all_members.filter(role=filter))
|
||||||
else:
|
else:
|
||||||
members = None
|
raise Http404("no member role")
|
||||||
|
|
||||||
context = {
|
context = {
|
||||||
"job_group": job_group,
|
"job_group": job_group,
|
||||||
@@ -66,10 +64,10 @@ def members_view(request, filter=None):
|
|||||||
|
|
||||||
def profile_view(request, member_name=None):
|
def profile_view(request, member_name=None):
|
||||||
job_group = deque(JobGroup.objects.all())
|
job_group = deque(JobGroup.objects.all())
|
||||||
member = None
|
|
||||||
jobs = None
|
|
||||||
|
|
||||||
member = deque(Member.all_members.filter(nickname=member_name))
|
member = deque(Member.all_members.filter(nickname=member_name))
|
||||||
|
if not member:
|
||||||
|
raise Http404("no member")
|
||||||
|
|
||||||
jobs = deque(JobMember.members.filter(member__nickname=member_name))
|
jobs = deque(JobMember.members.filter(member__nickname=member_name))
|
||||||
|
|
||||||
context = {
|
context = {
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ class MyPostAdmin(admin.ModelAdmin):
|
|||||||
form = MyPostForm
|
form = MyPostForm
|
||||||
model = Post
|
model = Post
|
||||||
list_filter = ['is_pinned', 'is_hidden']
|
list_filter = ['is_pinned', 'is_hidden']
|
||||||
list_display = ['title', 'subtitle', 'slug', 'public_date', 'is_pinned', 'is_hidden']
|
list_display = ['title', 'slug', 'public_date', 'is_pinned', 'is_hidden']
|
||||||
ordering = ['is_hidden', '-public_date']
|
ordering = ['is_hidden', '-public_date']
|
||||||
|
|
||||||
def add_view(self, request, form_url='', extra_context=None):
|
def add_view(self, request, form_url='', extra_context=None):
|
||||||
@@ -60,7 +60,8 @@ class MyPostAdmin(admin.ModelAdmin):
|
|||||||
class MyEventAdmin(MyPostAdmin):
|
class MyEventAdmin(MyPostAdmin):
|
||||||
form = MyEventForm
|
form = MyEventForm
|
||||||
model = Event
|
model = Event
|
||||||
list_display = ['title', 'subtitle', 'slug', 'event_start', 'public_date', 'is_pinned']
|
list_filter = ['is_pinned']
|
||||||
|
list_display = ['title', 'slug', 'event_start', 'public_date', 'is_pinned']
|
||||||
ordering = ['-event_start']
|
ordering = ['-event_start']
|
||||||
actions = [make_fetmeeting]
|
actions = [make_fetmeeting]
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
from ckeditor_uploader.widgets import CKEditorUploadingWidget
|
|
||||||
from django import forms
|
from django import forms
|
||||||
|
from django.utils.translation import gettext_lazy as _
|
||||||
|
|
||||||
|
from ckeditor_uploader.widgets import CKEditorUploadingWidget
|
||||||
|
|
||||||
from .models import Post, Event, News, FetMeeting
|
from .models import Post, Event, News, FetMeeting
|
||||||
|
|
||||||
@@ -25,6 +27,23 @@ class MyNewsForm(MyPostForm):
|
|||||||
'title', 'subtitle', 'tags', 'image', 'body', 'slug', 'author', 'public_date',
|
'title', 'subtitle', 'tags', 'image', 'body', 'slug', 'author', 'public_date',
|
||||||
'is_pinned', 'is_hidden',
|
'is_pinned', 'is_hidden',
|
||||||
]
|
]
|
||||||
|
labels = {
|
||||||
|
'title': _('Titel des Posts'),
|
||||||
|
'image': _('Hintergrundbild des Posts'),
|
||||||
|
'body': _('Beschreibung des Posts'),
|
||||||
|
'author': _('Autor'),
|
||||||
|
'public_date': _('Veröffentlichung'),
|
||||||
|
'is_pinned': _('Post anheften'),
|
||||||
|
'is_hidden': _('Post verstecken'),
|
||||||
|
}
|
||||||
|
help_texts = {
|
||||||
|
'is_pinned': _(
|
||||||
|
'Dieser Post soll an die Startseite als erster Post angeheftet werden.'
|
||||||
|
),
|
||||||
|
'is_hidden': _(
|
||||||
|
'Dieser Post soll im News Feed nicht auftauchen, z.B. Impressum.'
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
widgets = {'body': CKEditorUploadingWidget(config_name='default')}
|
widgets = {'body': CKEditorUploadingWidget(config_name='default')}
|
||||||
|
|
||||||
@@ -39,6 +58,22 @@ class MyEventForm(MyPostForm):
|
|||||||
'title', 'subtitle', 'tags', 'image', 'body', 'event_start', 'event_end',
|
'title', 'subtitle', 'tags', 'image', 'body', 'event_start', 'event_end',
|
||||||
'event_place', 'slug', 'author', 'public_date', 'is_pinned',
|
'event_place', 'slug', 'author', 'public_date', 'is_pinned',
|
||||||
]
|
]
|
||||||
|
labels = {
|
||||||
|
'title': _('Titel des Events'),
|
||||||
|
'image': _('Hintergrundbild des Posts'),
|
||||||
|
'body': _('Beschreibung des Events'),
|
||||||
|
'event_start': _('Start des Events'),
|
||||||
|
'event_end': _('Ende des Events'),
|
||||||
|
'event_place': _('Ort des Events'),
|
||||||
|
'author': _('Autor'),
|
||||||
|
'public_date': _('Veröffentlichung'),
|
||||||
|
'is_pinned': _('Event anheften'),
|
||||||
|
}
|
||||||
|
help_texts = {
|
||||||
|
'is_pinned': _(
|
||||||
|
'Dieses Event soll an die Startseite als erster Post angeheftet werden.'
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
widgets = {'body': CKEditorUploadingWidget(config_name='default')}
|
widgets = {'body': CKEditorUploadingWidget(config_name='default')}
|
||||||
|
|
||||||
@@ -55,10 +90,25 @@ class MyEventForm(MyPostForm):
|
|||||||
class MyFetMeetingForm(MyEventForm):
|
class MyFetMeetingForm(MyEventForm):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = FetMeeting
|
model = FetMeeting
|
||||||
fields = ['event_start', 'event_end', 'tags', 'has_agenda','agenda_key']
|
|
||||||
|
fields = ['event_start', 'event_end', 'tags', 'has_agenda', 'has_protocol']
|
||||||
|
labels = {
|
||||||
|
'event_start': _('Start der Sitzung'),
|
||||||
|
'event_end': _('Ende der Sitzung'),
|
||||||
|
'has_agenda': _('Agenda'),
|
||||||
|
'has_protocol': _('Protokoll'),
|
||||||
|
}
|
||||||
|
help_texts = {
|
||||||
|
'has_agenda': _('Agenda zur Sitzung hinzufügen.'),
|
||||||
|
'has_protocol': _('Protokoll zur Sitzung hinzufügen.'),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super().__init__(*args, **kwargs) # to get the self.fields set
|
super().__init__(*args, **kwargs) # to get the self.fields set
|
||||||
|
|
||||||
self.fields['event_start'].required = True
|
self.fields['event_start'].required = True
|
||||||
self.fields['event_end'].required = False
|
self.fields['event_end'].required = False
|
||||||
|
|
||||||
|
self.fields['has_agenda'].initial = True
|
||||||
|
self.fields['has_protocol'].initial = True
|
||||||
|
|||||||
@@ -75,10 +75,10 @@ class Post(models.Model):
|
|||||||
post_type = models.CharField(max_length=1, choices=__choices, editable=False)
|
post_type = models.CharField(max_length=1, choices=__choices, editable=False)
|
||||||
|
|
||||||
# post is pinned at main page
|
# post is pinned at main page
|
||||||
is_pinned = models.BooleanField(default=False)
|
is_pinned = models.BooleanField(verbose_name="ANGEHEFTET", default=False)
|
||||||
|
|
||||||
# post is hidden from newsfeed (e.g. about)
|
# post is hidden from newsfeed (e.g. about)
|
||||||
is_hidden = models.BooleanField(default=False)
|
is_hidden = models.BooleanField(verbose_name="UNSICHTBAR", default=False)
|
||||||
|
|
||||||
# Zusatz Info wenn ein Event gepostet wird
|
# Zusatz Info wenn ein Event gepostet wird
|
||||||
event_start = models.DateTimeField('Event Start', null=True, blank=True)
|
event_start = models.DateTimeField('Event Start', null=True, blank=True)
|
||||||
@@ -142,7 +142,10 @@ class Post(models.Model):
|
|||||||
return reverse('posts.show', kwargs={"id": self.slug})
|
return reverse('posts.show', kwargs={"id": self.slug})
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
"save the post with some defaults"
|
# save the post with some defaults
|
||||||
|
if not self.public_date:
|
||||||
|
self.public_date = timezone.now()
|
||||||
|
|
||||||
if (self.id is None) and (not self.slug):
|
if (self.id is None) and (not self.slug):
|
||||||
self.slug = slugify(self.public_date.date()) + "-" + slugify(self.title)
|
self.slug = slugify(self.public_date.date()) + "-" + slugify(self.title)
|
||||||
|
|
||||||
@@ -259,9 +262,6 @@ class FetMeeting(Event):
|
|||||||
# TODO
|
# TODO
|
||||||
# self.image
|
# self.image
|
||||||
|
|
||||||
self.has_protocol = True
|
|
||||||
self.has_agenda = True
|
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
# self.protocol_key
|
# self.protocol_key
|
||||||
# self.agenda_key
|
# self.agenda_key
|
||||||
|
|||||||
@@ -11,7 +11,7 @@
|
|||||||
<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.slug}}" 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>
|
||||||
|
|
||||||
@@ -24,21 +24,25 @@
|
|||||||
{% endwith %}
|
{% endwith %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
||||||
<div id="members" class="tab-pane fade in active">
|
{% if members is not None %}
|
||||||
{% if members is not None %}
|
<div id="members" class="tab-pane">
|
||||||
{% include 'members/members_list.html' %}
|
{% include 'members/members_list.html' %}
|
||||||
{% endif %}
|
</div>
|
||||||
</div>
|
{% endif %}
|
||||||
|
|
||||||
{% for job in job_list %}
|
{% for job in job_list %}
|
||||||
<div id="jobs-{{job.slug}}" class="tab-pane">
|
<div id="jobs" class="tab-pane">
|
||||||
<div class="grid-container">
|
<div class="grid-container">
|
||||||
|
|
||||||
<h2>{{job.0}}</h2>
|
<div id="{{job.3}}">
|
||||||
|
|
||||||
{% with active_members=job.1 inactive_members=job.2 %}
|
<h2>{{job.0}}<a class="headerlink" href="#{{job.3}}" title="Permalink to {{job.0}}"> #</a></h2>
|
||||||
{% include 'members/jobs_list.html' %}
|
|
||||||
{% endwith %}
|
{% with active_members=job.1 inactive_members=job.2 %}
|
||||||
|
{% include 'members/jobs_list.html' %}
|
||||||
|
{% endwith %}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
<div class="medium-3 large-2 small-6 cell">
|
<div class="medium-3 large-2 small-6 cell">
|
||||||
<h2>{{mem.member.surname}}</h2>
|
<h2>{{mem.member.surname}}</h2>
|
||||||
{% include 'members/partials/_member.html' %}
|
{% include 'members/partials/_member.html' %}
|
||||||
<h2>{{mem.get_job_role_display}} ({{mem.job_start}} - {{mem.job_end}})</h2>
|
<h2>{{mem.get_job_role_display}} ({{mem.job_start|date}} - {{mem.job_end|date}})</h2>
|
||||||
</div>
|
</div>
|
||||||
{%endwith %}
|
{%endwith %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|||||||
Reference in New Issue
Block a user