from auf.django.metadata.models import AUFMetadata
from auf.django.metadata.managers import NoDeleteManager
import datamaster_modeles.models as ref
-
+from validators import validate_date_passee
# Constantes
HELP_TEXT_DATE = "format: aaaa-mm-jj"
# Autres Metadata
date_validation = models.DateTimeField(null=True, blank=True) # de dae
- date_debut = models.DateField(verbose_name="Date de début", null=True,
- help_text=HELP_TEXT_DATE)
+ date_debut = models.DateField(verbose_name="Date de début",
+ help_text=HELP_TEXT_DATE,
+ null=True, blank=True)
date_fin = models.DateField(verbose_name="Date de fin",
help_text=HELP_TEXT_DATE,
null=True, blank=True)
nom = models.CharField(verbose_name="Poste", max_length=255, null=True, blank=True)
montant = models.IntegerField(null=True)
devise = models.ForeignKey("Devise", default=5, related_name='+', null=True, blank=True)
- montant_euros = models.IntegerField(null=True)
+
+ def taux_devise(self):
+ liste_taux = self.devise.tauxchange_set.order_by('-annee').filter(implantation=self.implantation)
+ if len(liste_taux) == 0:
+ raise Exception(u"La devise %s n'a pas de taux pour l'implantation %s" % (self.devise, self.implantation))
+ else:
+ return liste_taux[0].taux
+
+ def montant_euros(self):
+ return round(float(self.montant) * float(self.taux_devise()), 2)
class PosteCommentaire(Commentaire):
verbose_name="Nationalité")
date_naissance = models.DateField(help_text=HELP_TEXT_DATE,
verbose_name="Date de naissance",
+ validators=[validate_date_passee],
null=True, blank=True)
genre = models.CharField(max_length=1, choices=GENRE_CHOICES)
verbose_name="Nationalité")
date_naissance = models.DateField(help_text=HELP_TEXT_DATE,
verbose_name="Date de naissance",
+ validators=[validate_date_passee],
null=True, blank=True)
genre = models.CharField(max_length=1, choices=GENRE_CHOICES)
class Meta:
abstract = True
- ordering = ['employe__nom_affichage', 'employe__nom', 'poste__nom']
+ ordering = ['employe__nom', ]
verbose_name = "Dossier"
verbose_name_plural = "Dossiers"
dossier = models.ForeignKey('Dossier', db_column='dossier',
related_name='+')
+class DossierComparaison(models.Model):
+ """
+ Photo d'une comparaison salariale au moment de l'embauche.
+ """
+ dossier = models.ForeignKey('Dossier', related_name='comparaisons')
+ implantation = models.ForeignKey(ref.Implantation, related_name="+", null=True, blank=True)
+ poste = models.CharField(max_length=255, null=True, blank=True)
+ personne = models.CharField(max_length=255, null=True, blank=True)
+ montant = models.IntegerField(null=True)
+ devise = models.ForeignKey('Devise', default=5, related_name='+', null=True, blank=True)
+
+ def taux_devise(self):
+ liste_taux = self.devise.tauxchange_set.order_by('-annee').filter(implantation=self.dossier.poste.implantation)
+ if len(liste_taux) == 0:
+ raise Exception(u"La devise %s n'a pas de taux pour l'implantation %s" % (self.devise, self.dossier.poste.implantation))
+ else:
+ return liste_taux[0].taux
+
+ def montant_euros(self):
+ return round(float(self.montant) * float(self.taux_devise()), 2)
+
### RÉMUNÉRATION