* setup new 'statistiques' module * added 'graphos' package and created first test graph * put graphos in requirements, deleted local folder * added "load_csv" management command ! * added update of premiere_rencontre field in 'load_csv' management command * added missing urls.py file * added 'merge' action and view * added 'info_completed' ratio * linked sujets:merge views inside suivi:details * added link to maraudes:details in notes table headers, if any * Major reorganisation, moved 'suivi' and 'sujets' to 'notes', cleanup in 'maraudes', dropping 'website' mixins (mostly useless) * small cleanup * worked on Maraude and Sujet lists * corrected missing line in notes.__init__ * restored 'details' view for maraudes and sujets insie 'notes' module * worked on 'notes': added navigation between maraude's compte-rendu, right content in details, header to list tables * changed queryset for CompteRenduDetailsView to all notes of same date, minor layout changes * added right content to 'details-sujet', created 'statistiques' view and update templates * restored 'statistiques' ajax view in 'details-sujet', fixed 'merge_two' util function * added auto-creation of FicheStatistique (plus some tests), pagination for notes in 'details-sujet' * added error-prone cases in paginator * fixed non-working modals, added titles * added UpdateStatistiques capacity in CompteRenduCreate view * fixed missing AjaxTemplateMixin for CreateSujetView, worked on compte-rendu creation scripts * fixed MaraudeManager.all_of() for common Maraudeurs, added color hints in planning * re-instated statistiques module link and first test page * added FinalizeView to send a mail before finalizing compte-rendu * Added PieChart view for FicheStatistique fields * small style updates, added 'age' and 'genre' fields from sujets in statistiques.PieChartView * worked on statistiques, fixed small issues in 'notes' list views * small theme change * removed some dead code * fixed notes.tests, fixed statistiques.info_completed display, added filter in SujetLisView * added some tests * added customised admin templates * added authenticate in CustomAuthenticatationBackend, more verbose login thanks to messages * added django-nose for test coverage * Corrected raising exception on first migration On first migration, qs.exists() would previously be called and raising an Exception, sot he migrations would fail. * Better try block * cleaned up custom settings.py, added some overrides of django base_settings * corrected bad dictionnary key
93 lines
2.6 KiB
Python
93 lines
2.6 KiB
Python
import datetime
|
|
|
|
from django.core.exceptions import ImproperlyConfigured
|
|
from django.conf import settings
|
|
|
|
from django.db import models
|
|
from django.contrib.auth.models import User
|
|
|
|
from .managers import MaraudeurManager
|
|
# Create your models here.
|
|
|
|
if not settings.MARAUDEURS:
|
|
raise ImproperlyConfigured("No configuration for Maraudeur model")
|
|
else:
|
|
try:
|
|
assert(isinstance(settings.MARAUDEURS.get('organisme'), dict))
|
|
except:
|
|
raise ImproperlyConfigured("'organisme' key of MARAUDEURS settings is not a dict !")
|
|
|
|
|
|
def get_email_suffix(organisme):
|
|
if not organisme.email:
|
|
return "unconfigured.org"
|
|
else:
|
|
return organisme.email.split("@")[1]
|
|
|
|
|
|
|
|
class Organisme(models.Model):
|
|
""" Organisme : Association, Entreprise, Service public, ..."""
|
|
|
|
nom = models.CharField(max_length=64, primary_key=True)
|
|
email = models.EmailField("e-mail")
|
|
adresse = models.CharField(max_length=128, blank=True, null=True)
|
|
|
|
class Meta:
|
|
verbose_name = "Organisme"
|
|
|
|
def __str__(self):
|
|
return self.nom
|
|
|
|
|
|
|
|
class Professionnel(User):
|
|
""" Professionnel d'un organisme """
|
|
organisme = models.ForeignKey(Organisme,
|
|
models.CASCADE,
|
|
related_name="professionnels",
|
|
)
|
|
|
|
def make_username(self):
|
|
""" Build the username for this Professionel instance. Must be overriden."""
|
|
raise NotImplementedError
|
|
|
|
def save(self, *args, **kwargs):
|
|
self.username = self.make_username()
|
|
if not self.pk:
|
|
self.email = "%s@%s" % (self.username, get_email_suffix(self.organisme))
|
|
return super().save(*args, **kwargs)
|
|
|
|
|
|
|
|
class Maraudeur(Professionnel):
|
|
""" Professionnel qui participe aux maraudes """
|
|
|
|
@staticmethod
|
|
def get_organisme():
|
|
return Organisme.objects.get_or_create(**settings.MARAUDEURS['organisme'])[0]
|
|
|
|
def est_referent(self):
|
|
return self.is_superuser
|
|
est_referent.boolean = True
|
|
est_referent.short_description = 'Référent Maraude'
|
|
|
|
objects = MaraudeurManager()
|
|
|
|
class Meta:
|
|
verbose_name = "Maraudeur"
|
|
|
|
def make_username(self):
|
|
return "%s.%s" % (self.first_name[0].lower(), self.last_name.lower())
|
|
|
|
def save(self, *args, **kwargs):
|
|
if not self.pk:
|
|
self.is_staff = True
|
|
self.organisme = Maraudeur.get_organisme()
|
|
self.set_password(settings.MARAUDEURS['password'])
|
|
return super().save(*args, **kwargs)
|
|
|
|
def __str__(self):
|
|
return "%s %s." % (self.first_name, self.last_name[0])
|
|
|