X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=portal%2Fcontactview.py;h=95fb44e8ec557e02c7f35a0b2a48336294050267;hb=d08e5d9101b056425d1a00d2b7b434ee31eada74;hp=de6a31781b16e39aa7075bb43312d278866f3ca4;hpb=67f6ffe4742ada4c7243b528891289304fc4016d;p=unfold.git diff --git a/portal/contactview.py b/portal/contactview.py index de6a3178..95fb44e8 100644 --- a/portal/contactview.py +++ b/portal/contactview.py @@ -1,35 +1,66 @@ from django.shortcuts import render - +from django.template.loader import render_to_string from django.views.generic import View -from myslice.viewutils import topmenu_items, the_user +from unfold.loginrequired import FreeAccessView +from ui.topmenu import topmenu_items, the_user from portal.forms import ContactForm +from myslice.theme import ThemeView + # splitting the 2 functions done here # GET is for displaying the empty form # POST is to process it once filled - or show the form again if anything is missing -class ContactView (View): +class ContactView (FreeAccessView, ThemeView): def post (self, request): form = ContactForm(request.POST) # A form bound to the POST data if form.is_valid(): # All validation rules pass # Process the data in form.cleaned_data first_name = form.cleaned_data['first_name'] last_name = form.cleaned_data['last_name'] - affiliation = form.cleaned_data['affiliation'] + authority = form.cleaned_data['authority'] subject = form.cleaned_data['subject'] - message = form.cleaned_data['message'] + description = form.cleaned_data['description'] email = form.cleaned_data['email'] # email of the sender cc_myself = form.cleaned_data['cc_myself'] - #recipients = authority_get_pi_emails(authority_hrn) - recipients = ['yasin.upmc@gmail.com', 'thierry.parmentelat@inria.fr', ] - if cc_myself: - recipients.append(email) + try: + # Send an email: the support recipients + theme.template_name = 'email_support.txt' + recipients = render_to_string(theme.template, form.cleaned_data) + recipients = subject.replace('\n', '') + if cc_myself: + recipients.append(email) + + theme.template_name = 'contact_support_email.html' + html_content = render_to_string(theme.template, form.cleaned_data) + + theme.template_name = 'contact_support_email.txt' + text_content = render_to_string(theme.template, form.cleaned_data) + + theme.template_name = 'contact_support_email_subject.txt' + subject = render_to_string(theme.template, form.cleaned_data) + subject = subject.replace('\n', '') + + if not email: + theme.template_name = 'email_default_sender.txt' + sender = render_to_string(theme.template, form.cleaned_data) + sender = sender.replace('\n', '') + else: + sender = email + + msg = EmailMultiAlternatives(subject, text_content, sender, [recipients]) + msg.attach_alternative(html_content, "text/html") + msg.send() + except Exception, e: + print "Failed to send email, please check the mail templates and the SMTP configuration of your server" - from django.core.mail import send_mail - send_mail("Onelab user submitted a query ", [first_name,last_name,affiliation,subject,message], email, recipients) - return render(request,'contact_sent.html') # Redirect after POST + if request.user.is_authenticated() : + username = request.user.email + else : + username = None + return render(request,'contact_sent.html', { 'theme' : self.theme, 'username': username}) # Redirect after POST else: return self._display (request, form) @@ -37,8 +68,14 @@ class ContactView (View): return self._display (request, ContactForm()) # A fresh unbound form def _display (self, request, form): + if request.user.is_authenticated() : + username = request.user.email + else : + username = None return render(request, 'contact.html', { 'form': form, - 'topmenu_items': topmenu_items('Contact Us', request), - 'username': the_user (request) + 'topmenu_items': topmenu_items('Contact', request), + 'theme' : self.theme, + 'username': username, + 'section': "Contact" })