forms.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  1. from django import forms
  2. from django.conf import settings
  3. from django.core.files import File
  4. from django.contrib.auth.forms import UserCreationForm
  5. from django_file_form.forms import UploadedFileField, FileFormMixin, CharField, MultipleUploadedFileField
  6. from django.contrib.auth.models import User
  7. from django.urls import reverse, reverse_lazy
  8. from django.forms import *
  9. from django.forms.widgets import HiddenInput
  10. from django.forms.models import inlineformset_factory
  11. # from django.views.generic.edit.FormMixin
  12. # from crispy_forms.layout.buttons import Submit, InputButton
  13. from crispy_forms.layout import *
  14. from crispy_forms.bootstrap import InlineField, InlineCheckboxes
  15. from crispy_forms.helper import FormHelper
  16. from captcha.fields import CaptchaField
  17. from tinymce.widgets import TinyMCE
  18. from newsletter.forms import *
  19. from newsletter.models import *
  20. from marktplatz.widgets import *
  21. from .models import *
  22. from .urls import *
  23. def extend_help_text( help_text, myList ):
  24. extended_text = help_text
  25. extended_text += " z.B. "
  26. for x in myList:
  27. extended_text += x[1] + ", "
  28. extended_text = extended_text[:-2]
  29. extended_text += "."
  30. return extended_text
  31. class GeneralFields(forms.Form):
  32. terms = forms.BooleanField(required=True, )
  33. def __init__(self, *args, **kwargs):
  34. super(GeneralFields, self).__init__(*args, **kwargs)
  35. drurl = reverse_lazy( 'pages-generic', kwargs= { 'page': 'DATENSCHUTZRICHTLINIE' } )
  36. tmurl = reverse_lazy( 'pages-generic', kwargs= { 'page': 'TEILNAHME' } )
  37. self.fields ['terms'].label = 'Ich akzeptiere die <a target="_blank" href="{}"> Datenschutzrichtlinie</a> sowie die <a target="_blank" href="{}"> Teilnahmebedingungen</a> und habe sie gelesen.'.format(drurl, tmurl)
  38. class textSearchForm(forms.Form):
  39. mywidget = forms.TextInput( attrs={'onfocus': "this.value=''", 'class' : "border-thin"} )
  40. searchText = forms.CharField ( label='', widget = mywidget, max_length = 2048, min_length=3, empty_value="Suche...", initial='Suche...' )
  41. def __init__(self, *args, **kwargs):
  42. super(textSearchForm, self).__init__(*args, **kwargs)
  43. self.helper = FormHelper()
  44. self.helper.form_tag = False
  45. self.helper.layout = Layout(
  46. Div(
  47. Div('searchText', css_class='col-sm-4 col-4'),
  48. Div(
  49. ButtonHolder(
  50. Submit('submit', 'Suche', css_class='border-thin mybtn')
  51. ),
  52. css_class='col-sm-2 col-2'),
  53. css_class='form-row row mab-search-bar'),
  54. )
  55. class searchAgentForm(forms.ModelForm):
  56. agent_layout = Layout()
  57. class Meta:
  58. model = SearchAgent
  59. fields = ('ort', 'email')
  60. def __init__(self,*args, **kwargs):
  61. super().__init__(*args, **kwargs)
  62. # self.fields['ort'].widget = CheckboxSelectMultiple( attrs= { 'style' : "min-height: 250px;"} )
  63. self.agent_layout = Layout(
  64. Fieldset(
  65. ('Suchagent einrichten'),
  66. # 'ort',
  67. Div(
  68. Div(
  69. HTML("""
  70. <br>
  71. <button onclick=" ganz_wien()" class="btn btn-primary border-thin border-dark mybtn">Ganz Wien</button>
  72. <script>
  73. function ganz_wien(){
  74. $(".checkbox-ort .custom-control-label:contains('Wien')").each(function() {
  75. $this = $(this);
  76. var selector = "#" + $this.attr('for') ;
  77. $( selector ).prop('checked', true);
  78. });
  79. }
  80. </script>
  81. <br><br>
  82. """),
  83. css_class='col-sm-6 col-6'),
  84. css_class='form-row row'),
  85. Div(
  86. Div(
  87. InlineCheckboxes('ort'),
  88. css_class='col-sm-8 col-8 checkbox-ort'
  89. ),
  90. css_class='form-row row'),
  91. ),
  92. )
  93. class AgentNewslwtterForm( searchAgentForm, GeneralFields):
  94. email_field = forms.EmailField( label = 'Email', help_text="Du kannst den Suchagenten und den Newsletter jederzeit abbestellen - über einen Link in den Mails.", required=True, max_length=254 )
  95. subscribe = forms.BooleanField( label = 'Newsletter abonnieren', help_text='', required = False )
  96. captcha = CaptchaField( label = 'Bitte lösen Sie die Gleichung', generator='captcha.helpers.math_challenge' )
  97. def __init__(self, *args, **kwargs):
  98. # super(searchAgentForm, self).__init__(*args, **kwargs)
  99. super(AgentNewslwtterForm, self).__init__(*args, **kwargs)
  100. self.helper = FormHelper(self)
  101. self.helper.attrs = { 'enctype' : "multipart/form-data" }
  102. self.helper.form_action = reverse('agent-newsletter-create', kwargs={'newsletter_slug': "gemeinschaffen-newsletter"} )
  103. self.helper.layout = Layout(
  104. self.agent_layout,
  105. 'email_field',
  106. 'subscribe',
  107. 'terms',
  108. 'captcha',
  109. ButtonHolder(
  110. Submit('submit', 'Suchagent aktivieren', css_class='border-thin border-dark mybtn')
  111. ),
  112. )
  113. class NewsletterForm(SubscribeRequestForm, GeneralFields):
  114. class Meta:
  115. model = SubscribeRequestForm.Meta.model
  116. fields = SubscribeRequestForm.Meta.fields + (
  117. 'terms', )
  118. def __init__(self,*args, **kwargs):
  119. super(SubscribeRequestForm, self).__init__(*args, **kwargs)
  120. self.helper = FormHelper()
  121. self.helper.form_tag = False
  122. self.layout = Layout(
  123. Fieldset(
  124. ('Anmelden'),
  125. 'name_field',
  126. 'email_field',
  127. 'terms',
  128. Div(
  129. ButtonHolder(
  130. Submit('submit', 'Anmelden', css_class='border-thin mybtn')
  131. ),
  132. ),
  133. Div(HTML("&nbsp;") ),
  134. ),
  135. )
  136. self.helper.layout = self.layout
  137. class RegisterForm(forms.ModelForm, GeneralFields):
  138. class Meta:
  139. model = Contact
  140. fields = ('first_name','last_name','email','adress','postcode','city','country',
  141. 'phonenumber','alternate_phonenumber','skype_name','website', 'terms')
  142. class SignUpForm(UserCreationForm):
  143. captcha = CaptchaField( generator='captcha.helpers.math_challenge' )
  144. class Meta:
  145. model = User
  146. fields = ('username', 'password1', 'password2')
  147. class ProductForm(forms.ModelForm, GeneralFields):
  148. # terms = forms.BooleanField(required=True, label= ('Ich habe die Teilnahmebedingungen gelesen und akzeptiert.'))
  149. class Meta:
  150. model = Product
  151. type = 'BASE'
  152. fields = ( 'terms', 'name','claim','beschreibung','learning','gruendungsjahr','betriebgenommen','status',
  153. 'adresse', 'adresse_zusatz', 'plz', 'website','email','frei','kfrei','ort','rechtsform','orga','mitmachen',
  154. 'edit','public','type', )
  155. def __init__(self,*args, **kwargs):
  156. super(ProductForm, self).__init__(*args, **kwargs)
  157. self.fields['orga'].widget = ListTextWidget(data_list=Product.ORGANIZATION, name='orga_list')
  158. self.fields['rechtsform'].widget = ListTextWidget(data_list=Product.RECHTSFORM, name='rechtsform_list')
  159. self.fields['beschreibung'].widget = TinyMCE(attrs={'cols': 80, 'rows': 30})
  160. self.fields['learning'].widget = TinyMCE(attrs={'cols': 80, 'rows': 30})
  161. self.fields['edit'].widget = HiddenInput()
  162. self.fields['public'].widget = HiddenInput()
  163. self.fields['type'].widget = HiddenInput()
  164. self.fields['type'].initial = 'BASE'
  165. #
  166. # extend_help_text
  167. #
  168. self.fields['orga'].help_text = extend_help_text (self.fields['orga'].help_text, Product.ORGANIZATION)
  169. self.fields['rechtsform'].help_text = extend_help_text (self.fields['rechtsform'].help_text, Product.RECHTSFORM)
  170. self.helper = FormHelper( )
  171. self.helper.attrs = {'id': 'upload_mab', 'enctype': 'multipart/form-dat' }
  172. # self.helper.form_tag = True
  173. self.product_layout = Layout(
  174. Fieldset(
  175. ('Über dein Projekt'),
  176. 'name','claim','beschreibung',
  177. Div(
  178. Div('frei', css_class='col-sm-6 col-6 '),
  179. Div('kfrei', css_class='col-sm-6 col-6 ' ),
  180. css_class='form-row row mab-field-highlight'),
  181. 'learning','status',
  182. Div(
  183. Div('adresse', css_class='col-sm-6 col-6'),
  184. Div('adresse_zusatz', css_class='col-sm-6 col-6'),
  185. css_class='form-row row'),
  186. Div(
  187. Div('plz', css_class='col-sm-6 col-6'),
  188. Div('ort', css_class='col-sm-6 col-6'),
  189. css_class='form-row row'),
  190. 'rechtsform','orga',
  191. Div(
  192. Div('website', css_class='col-sm-6 col-6'),
  193. Div('email', css_class='col-sm-6 col-6'),
  194. css_class='form-row row'),
  195. Div(
  196. Div('gruendungsjahr', css_class='col-sm-6 col-6'),
  197. Div('betriebgenommen', css_class='col-sm-6 col-6'),
  198. css_class='form-row row'),
  199. 'edit','public', 'mitmachen', 'type',
  200. ),
  201. )
  202. self.submit_layout = Layout(
  203. 'terms',
  204. HTML("<br>"),
  205. Div(
  206. Div(
  207. ButtonHolder(
  208. Submit('submit', 'Speichern',
  209. onclick='this.form.action="./";',
  210. css_class='border-thin mybtn')
  211. ),
  212. css_class='col-sm-4 col-4'),
  213. Div(
  214. ButtonHolder(
  215. Submit('submit', 'Speichern & Bilder hochladen',
  216. onclick='this.form.action="{}";'.format( reverse_lazy( 'neues-projekt-submit-pics', kwargs= { 'type': self.Meta.type } ) ),
  217. css_class='border-thin mybtn')
  218. ),
  219. css_class='col-sm-4 col-4'),
  220. Div(
  221. ButtonHolder(
  222. Submit('submit', 'Speichern und Freischaltung Anfragen',
  223. onclick='this.form.action="{}";'.format( reverse_lazy( 'neues-projekt-publish', kwargs= { 'type': self.Meta.type } ) ),
  224. css_class='border-thin mybtn'
  225. ),
  226. HTML("<br><p>Dein Projekt ist noch nicht für jede Person sichtbar, damit wir dein Projekt freischalten, klicke auf diesen Button.</p>")
  227. ),
  228. css_class='col-sm-4 col-4'),
  229. css_class='form-row row'),
  230. )
  231. self.helper.layout = Layout(
  232. self.product_layout,
  233. self.submit_layout,
  234. )
  235. class MobilitaetsForm(ProductForm):
  236. class Meta():
  237. model = MobilitaetsProjekt
  238. type = 'MOBI'
  239. fields = ProductForm.Meta.fields + ( )
  240. def __init__(self,*args, **kwargs):
  241. super(MobilitaetsForm, self).__init__(*args, **kwargs)
  242. self.fields['type'].initial = 'MOBI'
  243. class ErnaehrungsForm(ProductForm):
  244. class Meta():
  245. model = ErnaehrungsProjekt
  246. type = 'ERNA'
  247. fields = ProductForm.Meta.fields + ( )
  248. def __init__(self,*args, **kwargs):
  249. super(ErnaehrungsForm, self).__init__(*args, **kwargs)
  250. self.fields['type'].initial = 'ERNA'
  251. class EnergyForm(ProductForm):
  252. class Meta():
  253. model = EnergyProjekt
  254. type = 'ENER'
  255. fields = ProductForm.Meta.fields + ( )
  256. def __init__(self,*args, **kwargs):
  257. super(EnergyForm, self).__init__(*args, **kwargs)
  258. self.fields['type'].initial = 'ENER'
  259. class WohnprojektForm(ProductForm):
  260. class Meta:
  261. model = Wohnprojekt
  262. type = 'WOHN'
  263. fields = ProductForm.Meta.fields + (
  264. 'eigentum', 'inseratstext', 'altneu', 'schwerpunkt', 'wohnbaufoerderung', 'artmodell', 'bautraeger', 'architektur', 'aerwachsene', 'akinder', 'awohnungen', 'wohnflaeche', 'gewerbeflaechen', 'gemeinschaftsflaeche', 'sonstige_flaechen', 'flaeche', 'kflaechen', 'gemeinschaftr', 'kgemeinschaftr', 'gewerbe', 'sonderwohnformen', 'raumangebot', 'kraumangebot', 'parbeiten', 'karbeiten', 'bauweise', 'zielgruppen', 'gprojekte', 'oekologie', 'freiraumangebote', 'gaestwohnungen', 'urbanem',
  265. )
  266. def __init__(self,*args, **kwargs):
  267. super(WohnprojektForm, self).__init__(*args, **kwargs)
  268. #
  269. #
  270. self.fields['artmodell'].widget = ListTextWidget(data_list=Wohnprojekt.ARTMODELL, name='artmodell_list')
  271. self.fields['bautraeger'].widget = ListTextWidget(data_list=Wohnprojekt.BAUTRAEGER, name='bautraeger_list')
  272. self.fields['bauweise'].widget = ListTextWidget(data_list=Wohnprojekt.BAUWEISE, name='bauweise_list')
  273. self.fields['zielgruppen'].widget = ListTextWidget(data_list=Wohnprojekt.ZIELGRUPPEN, name='zielgruppen_list')
  274. self.fields['gprojekte'].widget = ListTextWidget(data_list=Wohnprojekt.GPROJEKTE, name='gprojekte_list')
  275. self.fields['freiraumangebote'].widget = ListTextWidget(data_list=Wohnprojekt.FREIANGEBOT, name='freiraumangebote_list')
  276. # self.fields['gewerbe'].widget = ListTextWidget(data_list=Wohnprojekt.GEWERBE, name='gewerbe_list')
  277. #
  278. #
  279. self.fields['bauweise'].help_text = extend_help_text (self.fields['bauweise'].help_text, Wohnprojekt.BAUWEISE)
  280. self.fields['zielgruppen'].help_text = extend_help_text (self.fields['zielgruppen'].help_text, Wohnprojekt.ZIELGRUPPEN)
  281. self.fields['gprojekte'].help_text = extend_help_text (self.fields['gprojekte'].help_text, Wohnprojekt.GPROJEKTE)
  282. #
  283. #
  284. self.fields['frei'].label = "Wohnung Frei"
  285. self.fields['inseratstext'].label = "Inseratstext für Raumangebote"
  286. #
  287. #
  288. self.fields['type'].initial = 'WOHN'
  289. #
  290. # self.helper = FormHelper()
  291. # self.helper.form_tag = False
  292. self.helper.layout = Layout(
  293. self.product_layout,
  294. Fieldset( 'Wohnprojekt',
  295. 'eigentum',
  296. 'artmodell',
  297. 'altneu',
  298. 'schwerpunkt',
  299. 'wohnbaufoerderung',
  300. 'bautraeger',
  301. 'architektur',
  302. Div(
  303. Div('aerwachsene', css_class='col-sm-6 col-6'),
  304. Div('akinder', css_class='col-sm-6 col-6'),
  305. css_class='form-row row'),
  306. 'awohnungen',
  307. 'gaestwohnungen',
  308. Fieldset ( 'Flächen',
  309. Div(
  310. Div('wohnflaeche', css_class='col-sm-3 col-3'),
  311. Div('gewerbeflaechen', css_class='col-sm-3 col-3'),
  312. Div('gemeinschaftsflaeche', css_class='col-sm-3 col-3'),
  313. Div('sonstige_flaechen', css_class='col-sm-3 col-3'),
  314. css_class='form-row row'),
  315. 'flaeche',
  316. 'kflaechen',
  317. ),
  318. Div(
  319. Div('gemeinschaftr', css_class='col-sm-6 col-6'),
  320. Div('raumangebot', css_class='col-sm-6 col-6'),
  321. Div('kgemeinschaftr', css_class='col-sm-6 col-6'),
  322. Div('kraumangebot', css_class='col-sm-6 col-6'),
  323. css_class='form-row row'),
  324. 'gewerbe',
  325. Div('inseratstext', css_class = "mab-field-highlight"),
  326. 'sonderwohnformen',
  327. Div(
  328. Div('parbeiten', css_class='col-sm-6 col-6'),
  329. Div('karbeiten', css_class='col-sm-6 col-6'),
  330. css_class='form-row row'),
  331. 'bauweise', 'zielgruppen', 'gprojekte', 'oekologie', 'freiraumangebote', 'urbanem',
  332. ),
  333. self.submit_layout,
  334. )
  335. class MediaForm(FileFormMixin, forms.Form):
  336. image = UploadedFileField()
  337. name_for = forms.CharField()
  338. copyright = forms.CharField()
  339. #prefix = 'upload'
  340. def __init__(self, *args, **kwargs):
  341. super(MediaForm, self).__init__(*args, **kwargs)
  342. self.helper = FormHelper()
  343. self.helper.form_tag = False
  344. self.fields['name_for'].label = 'Bildbeschriftung'
  345. self.fields['copyright'].label = 'Urheberrechte'
  346. self.fields['image'].label = 'Bild oder Video'
  347. self.fields['image'].help_text = 'Bitte laden Sie Bilder im PNG- oder JPEG-Format hoch. Laden Sie Videos im MP4-Format hoch.'
  348. self.layout = Layout(
  349. Fieldset(
  350. (''),
  351. Div(
  352. Div('name_for', css_class='form-group col-md-6 mb-0'),
  353. Div('copyright', css_class='form-group col-md-4 mb-0')
  354. , css_class='form-row'),
  355. Div(
  356. Div('image', css_class='form-group col-md-6 mb-0'),
  357. css_class='form-row'),
  358. ))