forms.py
5.67 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
"""
Copyright 2016, 2017 UFPE - Universidade Federal de Pernambuco
Este arquivo é parte do programa Amadeus Sistema de Gestão de Aprendizagem, ou simplesmente Amadeus LMS
O Amadeus LMS é um software livre; você pode redistribui-lo e/ou modifica-lo dentro dos termos da Licença Pública Geral GNU como publicada pela Fundação do Software Livre (FSF); na versão 2 da Licença.
Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU para maiores detalhes.
Você deve ter recebido uma cópia da Licença Pública Geral GNU, sob o título "LICENSE", junto com este programa, se não, escreva para a Fundação do Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
"""
# coding=utf-8
from django import forms
from django.utils.translation import ugettext_lazy as _
from django.utils.html import strip_tags
from django.forms.models import inlineformset_factory
import datetime
from subjects.models import Tag
from subjects.forms import ParticipantsMultipleChoiceField
from .models import Webconference, ConferenceSettings
from pendencies.forms import PendenciesLimitedForm
from pendencies.models import Pendencies
class WebconferenceForm(forms.ModelForm):
subject = None
control_subject = forms.CharField(widget = forms.HiddenInput())
students = ParticipantsMultipleChoiceField(queryset = None, required = False)
def __init__(self, *args, **kwargs):
super(WebconferenceForm, self).__init__(*args, **kwargs)
self.subject = kwargs['initial'].get('subject', None)
if self.instance.id:
self.subject = self.instance.topic.subject
self.initial['tags'] = ", ".join(self.instance.tags.all().values_list("name", flat = True))
self.initial['control_subject'] = self.subject.id
self.fields['students'].queryset = self.subject.students.all()
self.fields['groups'].queryset = self.subject.group_subject.all()
tags = forms.CharField(label = _('Tags'), required = False)
class Meta:
model = Webconference
fields = ['name', 'presentation', 'start', 'end', 'brief_description', 'all_students', 'students', 'groups', 'show_window', 'visible']
labels = {
'name': _('Web Conference Title'),
'presentation': _('Presentation'),
}
widgets = {
'presentation': forms.Textarea,
'brief_description': forms.Textarea,
'students': forms.SelectMultiple,
'groups': forms.SelectMultiple,
}
def clean(self):
cleaned_data = super(WebconferenceForm, self).clean()
start = cleaned_data.get('start', None)
end = cleaned_data.get('end', None)
name = self.cleaned_data.get('name', '')
topics = self.subject.topic_subject.all()
for topic in topics:
if self.instance.id:
same_name = topic.resource_topic.filter(name__unaccent__iexact = name).exclude(id = self.instance.id).count()
else:
same_name = topic.resource_topic.filter(name__unaccent__iexact = name).count()
if same_name > 0:
self.add_error('name', _('This subject already has a web conference with this name'))
if start and end:
if not start == ValueError and not end == ValueError:
if start > end:
self.add_error('start', _('This input should be filled with a date equal or before the End.'))
self.add_error('end', _('This input should be filled with a date equal or after the Start.'))
if not start == ValueError:
if not self.instance.id and start.date() < datetime.datetime.today().date():
self.add_error('start', _("This input should be filled with a date equal or after today's date."))
if start.date() < self.subject.init_date:
self.add_error('start', _('This input should be filled with a date equal or after the subject begin date.("%s")')%(self.subject.init_date))
if start.date() > self.subject.end_date:
self.add_error('start', _('This input should be filled with a date equal or before the subject end date.("%s")')%(self.subject.end_date))
if not end == ValueError:
if not self.instance.id and end.date() < datetime.datetime.today().date():
self.add_error('end', _("This input should be filled with a date equal or after today's date."))
if end.date() < self.subject.init_date:
self.add_error('end', _('This input should be filled with a date equal or after the subject begin date.("%s")')%(self.subject.init_date))
if end.date() > self.subject.end_date:
self.add_error('end', _('This input should be filled with a date equal or before the subject end date.("%s")')%(self.subject.end_date))
return cleaned_data
def save(self, commit = True):
super(WebconferenceForm, self).save(commit = True)
self.instance.save()
previous_tags = self.instance.tags.all()
tags = self.cleaned_data['tags'].split(",")
#Excluding unwanted tags
for prev in previous_tags:
if not prev.name in tags:
self.instance.tags.remove(prev)
for tag in tags:
tag = tag.strip()
exist = Tag.objects.filter(name = tag).exists()
if exist:
new_tag = Tag.objects.get(name = tag)
else:
new_tag = Tag.objects.create(name = tag)
if not new_tag in self.instance.tags.all():
self.instance.tags.add(new_tag)
return self.instance
class WebConferenceUpdateForm(WebconferenceForm):
def clean_start(self):
return self.cleaned_data['start']
class SettingsForm(forms.ModelForm):
class Meta:
model = ConferenceSettings
fields = ['domain']
labels = {
'domain': _('Domain'),
}
help_texts = {
'domain': _('The domain of the jitsi server, e.g. meet.jit.si'),
}
InlinePendenciesFormset = inlineformset_factory(Webconference, Pendencies, form = PendenciesLimitedForm, extra = 1, max_num = 3, validate_max = True, can_delete = True)