summaryrefslogtreecommitdiff
path: root/statistics_app/forms.py
diff options
context:
space:
mode:
authoradityacp2020-08-13 16:51:11 +0530
committeradityacp2020-08-13 16:51:11 +0530
commit4fb30bc7dc02a4ca17aec13ca83d2d23fe9ae632 (patch)
treee66223bcb6e8549f9cb391d143478e48757b58bc /statistics_app/forms.py
parent8e7c9aeadcae850155e17a0323b1079e0e642010 (diff)
downloadworkshop_booking-4fb30bc7dc02a4ca17aec13ca83d2d23fe9ae632.tar.gz
workshop_booking-4fb30bc7dc02a4ca17aec13ca83d2d23fe9ae632.tar.bz2
workshop_booking-4fb30bc7dc02a4ca17aec13ca83d2d23fe9ae632.zip
Fix and refactor statistics app
Diffstat (limited to 'statistics_app/forms.py')
-rw-r--r--statistics_app/forms.py48
1 files changed, 48 insertions, 0 deletions
diff --git a/statistics_app/forms.py b/statistics_app/forms.py
new file mode 100644
index 0000000..cd04cd3
--- /dev/null
+++ b/statistics_app/forms.py
@@ -0,0 +1,48 @@
+from django import forms
+from django.utils import timezone
+
+from workshop_app.models import states, WorkshopType
+
+
+class FilterForm(forms.Form):
+ from_date = forms.DateField(
+ widget=forms.DateInput(
+ attrs={'type': 'date', 'class': 'form-control'}
+ )
+ )
+ to_date = forms.DateField(
+ widget=forms.DateInput(
+ attrs={'type': 'date', 'class': 'form-control'}
+ )
+ )
+ workshop_type = forms.ModelChoiceField(
+ queryset=WorkshopType.objects.all(), required=False,
+ widget=forms.Select(attrs={'class': 'form-control'})
+ )
+ state = forms.ChoiceField(
+ choices=states, required=False,
+ widget=forms.Select(attrs={'class': 'form-control'})
+ )
+ show_workshops = forms.BooleanField(
+ help_text="Show my workshops only", required=False,
+ )
+ sort = forms.ChoiceField(
+ choices=(("date", "Oldest"), ("-date", "Latest")),
+ help_text="Sort by",
+ widget=forms.Select(attrs={'class': 'form-control'})
+ )
+ def __init__(self, *args, **kwargs):
+ start = kwargs.pop("start") if "start" in kwargs else None
+ end = kwargs.pop("end") if "end" in kwargs else None
+ selected_state = kwargs.pop("state") if "state" in kwargs else None
+ selected_type = kwargs.pop("type") if "type" in kwargs else None
+ show_workshops = (kwargs.pop("show_workshops")
+ if "show_workshops" in kwargs else None)
+ sort = kwargs.pop("sort") if "sort" in kwargs else None
+ super(FilterForm, self).__init__(*args, **kwargs)
+ self.fields["from_date"].initial = start
+ self.fields["to_date"].initial = end
+ self.fields["state"].initial = selected_state
+ self.fields["workshop_type"].initial = selected_type
+ self.fields["show_workshops"].initial = show_workshops
+ self.fields["sort"].initial = sort