better ordering for tags
[redakcja.git] / apps / organizations / forms.py
index 63f9c02..98efeab 100644 (file)
@@ -1,6 +1,39 @@
+# -*- coding: utf-8 -*-
+#
+# This file is part of MIL/PEER, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+#
 from django import forms
 from django import forms
+from django.contrib.sites.models import Site
+from django.utils.translation import ugettext as _
+
+from redakcja.utlis import send_notify_email
 from .models import Organization, UserCard, countries
 
 from .models import Organization, UserCard, countries
 
+
+def clean_projects(projects):
+    lines = []
+    for line in projects.split('\n'):
+        line = line.strip()
+        if line:
+            try:
+                url, lang, desc = [part.strip(',') for part in line.split(None, 2)]
+            except ValueError:
+                raise forms.ValidationError(
+                    _('Each line has to consist of an Internet address, language and description, '
+                      'separated with spaces. Failed on: %s' % line))
+            # naive check
+            if '.' not in url or url.endswith('.'):
+                raise forms.ValidationError(
+                    _('The first item in each line should be an Internet address. Failed on: %s') % url)
+            if not url.startswith('http'):
+                url = 'http://' + url
+            lines.append(' '.join((url, lang, desc)))
+        else:
+            lines.append('')
+    return '\n'.join(lines)
+
+
 class OrganizationForm(forms.ModelForm):
     cts = countries
 
 class OrganizationForm(forms.ModelForm):
     cts = countries
 
@@ -8,6 +41,23 @@ class OrganizationForm(forms.ModelForm):
         model = Organization
         exclude = ['_html']
 
         model = Organization
         exclude = ['_html']
 
+    def save(self, commit=True):
+        new = self.instance.id is None
+        organization = super(OrganizationForm, self).save(commit=commit)
+        if new:
+            site = Site.objects.get_current()
+            send_notify_email(
+                'New organization in MIL/PEER',
+                '''New organization in MIL/PEER: %s. View their profile: https://%s%s.
+
+--
+MIL/PEER team.''' % (organization.name, site.domain, organization.get_absolute_url()))
+        return organization
+
+    def clean_projects(self):
+        return clean_projects(self.cleaned_data.get('projects', ''))
+
+
 class UserCardForm(forms.ModelForm):
     cts = countries
 
 class UserCardForm(forms.ModelForm):
     cts = countries
 
@@ -24,7 +74,7 @@ class UserCardForm(forms.ModelForm):
                 'first_name': kwargs['instance'].user.first_name,
                 'last_name': kwargs['instance'].user.last_name,
             }
                 'first_name': kwargs['instance'].user.first_name,
                 'last_name': kwargs['instance'].user.last_name,
             }
-        return super(UserCardForm, self).__init__(*args, **kwargs)
+        super(UserCardForm, self).__init__(*args, **kwargs)
 
     def save(self, *args, **kwargs):
         self.instance.user.first_name = self.cleaned_data.get('first_name', '')
 
     def save(self, *args, **kwargs):
         self.instance.user.first_name = self.cleaned_data.get('first_name', '')
@@ -32,3 +82,5 @@ class UserCardForm(forms.ModelForm):
         self.instance.user.save()
         return super(UserCardForm, self).save(*args, **kwargs)
 
         self.instance.user.save()
         return super(UserCardForm, self).save(*args, **kwargs)
 
+    def clean_projects(self):
+        return clean_projects(self.cleaned_data.get('projects', ''))