[#1823] Première phase pour régionnalisation
[auf_rh_dae.git] / project / rh / lib.py
index 84cfd0b..e832a89 100644 (file)
 # -*- encoding: utf-8 -*-
 
-import datetime
 from django.db import models
 from django.contrib import admin
-
+from django.conf import settings
+from django.db.models import Q
+from auf.django.metadata.admin import AUFMetadataAdminMixin, AUFMetadataInlineAdminMixin, AUF_METADATA_READONLY_FIELDS
 from project.rh import models as rh
+from forms import DossierForm, ContratForm
+from dae.utils import get_employe_from_user
 
-# MetaData
-METADATA_READONLY_FIELDS = ('supprime',
-                       'date_creation',
-                       'user_creation',
-                       'date_modification',
-                       'user_modification',
-                       'date_activation',
-                       'user_activation',
-                       'date_desactivation',
-                       'user_desactivation', )
-
-METADATA_FIELDSET_FIELDS = ('actif', 'date_creation', 'user_creation',
-                       'date_modification', 'user_modification',
-                       'date_activation', 'user_activation',
-                       'date_desactivation', 'user_desactivation',)
-
-class MetadataAdminMixin(object):
-    """
-    Surcharge l'admin de base, pour setter automatiquement les metadata
-    """
-    def save_model(self, request, obj, form, change):
-        if change is False:
-            obj.user_creation = request.user
-            obj.date_creation = datetime.datetime.now()
-        obj.user_modification = request.user
-        obj.date_modification = datetime.datetime.now()
-        if form.initial['actif'] is True and obj.actif is False:
-            obj.user_desactivation = request.user
-            obj.date_desactivation = datetime.datetime.now()
-        if form.initial['actif'] is False and obj.actif is True:
-            obj.user_activation = request.user
-            obj.date_activation = datetime.datetime.now()
-        obj.save()
-
-class ReadonlyInlineMixin(object):
-    def get_readonly_fields(self, request, obj=None):
-        return [f.name for f in self.model._meta.fields]
+
+class ProtectRegionMixin(object):
+
+    def queryset(self, request):
+        qs = super(ProtectRegionMixin, self).queryset(request)
+
+        if request.user.is_superuser:
+            return qs
+
+        employe = get_employe_from_user(request.user)
+
+        q = Q(**{self.model.prefix_implantation: employe.implantation.region})
+        qs = qs.filter(q).distinct()
+        return qs
+
+    def has_change_permission(self, request, obj=None):
+        if request.user.is_superuser:
+            return True
+
+        if obj:
+            employe = get_employe_from_user(request.user)
+            if employe.implantation.region in obj.get_regions():
+                return True
+            else:
+                return False
+
+        return True
 
 
 # Inlines
 
-class AyantDroitInline(admin.TabularInline):
+class ReadOnlyInlineMixin(object):
+    def get_readonly_fields(self, request, obj=None):
+        return [f.name for f in self.model._meta.fields if f.name not in AUF_METADATA_READONLY_FIELDS]
+
+
+class AyantDroitInline(AUFMetadataInlineAdminMixin, admin.StackedInline):
     model = models.Model  # à remplacer dans admin.py
+    extra = 0
 
 
-class AyantDroitCommentaireInline(admin.TabularInline):
+class AyantDroitCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
-class ContratInline(admin.TabularInline):
+class ContratInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    form = ContratForm
     model = models.Model  # à remplacer dans admin.py
-    exclude = METADATA_READONLY_FIELDS + ('actif', )
     extra = 1
 
 
-class DossierROInline(ReadonlyInlineMixin, admin.TabularInline):
+class DossierROInline(ReadOnlyInlineMixin, admin.TabularInline):
+    exclude = AUF_METADATA_READONLY_FIELDS
     model = models.Model  # à remplacer dans admin.py
 
 
-class DossierCommentaireInline(admin.TabularInline, MetadataAdminMixin):
-    exclude = METADATA_READONLY_FIELDS + ('actif', )
+class DossierCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
     extra = 1
 
+
 class DossierPieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
+    extra = 4
 
 
 class EmployeInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
-
-class EmployeCommentaireInline(admin.TabularInline):
+class EmployeCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class EmployePieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
+    extra = 4
 
 
-class EvenementInline(admin.TabularInline, MetadataAdminMixin):
+class EvenementInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
-    exclude = METADATA_READONLY_FIELDS + ('actif', )
     extra = 1
 
 
-class EvenementRemunerationInline(admin.TabularInline, MetadataAdminMixin):
+class EvenementRemunerationInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
-    exclude = METADATA_READONLY_FIELDS + ('actif', )
     extra = 1
 
 
-class PosteInline(admin.TabularInline):
-    model = models.Model  # à remplacer dans admin.py
-
-
-class PosteCommentaireInline(admin.TabularInline):
+class PosteCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class PosteFinancementInline(admin.TabularInline):
@@ -115,58 +116,120 @@ class PostePieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
-class RemunerationInline(admin.TabularInline):
+class RemunerationInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
-    exclude = METADATA_READONLY_FIELDS + ('actif', )
     extra = 1
 
 
-class RemunerationROInline(ReadonlyInlineMixin, RemunerationInline):
+class RemunerationROInline(ReadOnlyInlineMixin, RemunerationInline):
     pass
 
 
-class TypePosteInline(admin.TabularInline):
+class TypePosteInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
 # Admins
 
-class AyantDroitAdmin(admin.ModelAdmin):
+class AyantDroitAdmin(AUFMetadataAdminMixin, ProtectRegionMixin, admin.ModelAdmin):
+    """
+    L'ajout d'un nouvel ayantdroit se fait dans l'admin de l'employé.
+    """
+    alphabet_filter = 'nom'
+    search_fields = ('nom', 'prenom', 'employe__nom', 'employe__prenom', )
+    list_display = ('_employe', 'lien_parente', '_ayantdroit', )
     inlines = (AyantDroitCommentaireInline,)
+    readonly_fields = AUFMetadataAdminMixin.readonly_fields + ('employe',)
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
+        ("Lien avec l'employé", {
+            'fields': ('employe', 'lien_parente', )
+        }),
 
+        ('Identification', {
+            'fields': ('nom', 'prenom', 'nom_affichage', 'nationalite', 'date_naissance', 'genre', )
+        }),
+    )
 
-class AyantDroitCommentaireAdmin(admin.ModelAdmin):
-    pass
+    def save_formset(self, request, form, formset, change):
+        instances = formset.save(commit=False)
+        for instance in instances:
+            if instance.__class__ == rh.AyantDroitCommentaire:
+                instance.owner = request.user
+            instance.save()
 
+    def _ayantdroit(self, obj):
+        return unicode(obj)
+    _ayantdroit.short_description = u'Ayant droit'
 
-class ClassementAdmin(admin.ModelAdmin):
-    pass
+    def _employe(self, obj):
+        return unicode(obj.employe)
+    _employe.short_description = u'Employé'
 
+    def has_add_permission(self, request):
+        return False
 
-class CommentaireAdmin(admin.ModelAdmin):
+class AyantDroitCommentaireAdmin(admin.ModelAdmin):
     pass
 
 
-class ContratAdmin(admin.ModelAdmin):
-    pass
+class ClassementAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
+        (None, {
+            'fields': ('type', 'echelon', 'degre', 'coefficient',  )
+        }),
+    )
 
 
-class DeviseAdmin(admin.ModelAdmin):
+class CommentaireAdmin(admin.ModelAdmin):
     pass
 
 
-class DossierAdmin(MetadataAdminMixin, admin.ModelAdmin,):
-    search_fields = ('employe__nom', 'employe__prenom', )
-    list_display = ('_employe', '_poste', 'date_debut', 'date_fin', )
+#class ContratAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+#    form = ContratForm
+#    alphabet_filter = 'dossier__employe__nom'
+#    search_fields = ('dossier__employe__nom', 'dossier__employe__prenom', 'dossier__poste__nom', 'dossier__poste__nom_feminin', )
+#    list_display = ('id', '_employe', '_poste', 'date_debut', 'date_fin', '_implantation', )
+#    fieldsets = AUFMetadataAdminMixin.fieldsets + (
+#        (None, {
+#            'fields': ('dossier', 'type_contrat', 'date_debut', 'date_fin', )
+#        }),
+#    )
+#
+#    def lookup_allowed(self, key, value):
+#        if key in ('dossier__employe__nom__istartswith',  ):
+#            return True
+#
+#    def _employe(self, obj):
+#        return unicode(obj.dossier.employe)
+#    _employe.short_description = "Employé"
+#
+#    def _poste(self, obj):
+#        return obj.dossier.poste.nom
+#    _poste.short_description = "Poste"
+#
+#    def _implantation(self, obj):
+#        return obj.dossier.poste.implantation
+#    _poste.short_description = "Implantation"
+
+class DeviseAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
+        (None, {
+            'fields': ('code', 'nom', ),
+        }),
+    )
+
+
+class DossierAdmin(AUFMetadataAdminMixin, ProtectRegionMixin, admin.ModelAdmin,):
+    form = DossierForm
+    alphabet_filter = 'employe__nom'
+    search_fields = ('employe__nom', 'employe__prenom', 'poste__nom', 'poste__nom_feminin')
+    list_display = ('_employe', '_poste', 'date_debut', 'date_fin', '_actif')
     inlines = (DossierPieceInline, ContratInline,
-               RemunerationInline, EvenementInline, DossierCommentaireInline,
+               RemunerationInline,
+               #EvenementInline,
+               DossierCommentaireInline,
               )
-    readonly_fields = METADATA_READONLY_FIELDS
-    fieldsets = (
-        ('Metadata', {
-            'classes': ('collapse',),
-            'fields': METADATA_FIELDSET_FIELDS,
-        }),
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
         ('Identification', {
             'fields': ('employe', 'poste', 'statut', 'organisme_bstg',)
         }),
@@ -181,21 +244,36 @@ class DossierAdmin(MetadataAdminMixin, admin.ModelAdmin,):
         }),
     )
 
+    def lookup_allowed(self, key, value):
+        if key in ('employe__nom__istartswith', 'actif__exact', ):
+            return True
+
+    def _actif(self, dossier):
+        if dossier.employe.actif:
+          html = """<img alt="True" src="%simg/admin/icon-yes.gif">"""
+        else:
+          html = """<img alt="False" src="%simg/admin/icon-no.gif">"""
+        return html % settings.ADMIN_MEDIA_PREFIX 
+    _actif.allow_tags = u'Employé actif'
+    _actif.short_description = u'Employé actif'
+    _actif.admin_order_field = 'employe__actif'
+
     def _poste(self, dossier):
         return unicode(dossier.poste.nom)
     _poste.short_description = u'Poste'
+    _poste.admin_order_field = 'poste__nom'
 
     def _employe(self, dossier):
         return unicode(dossier.employe)
     _employe.short_description = u'Employé'
-    
+    _employe.admin_order_field = 'employe__nom'
+   
     def save_formset(self, request, form, formset, change):
         instances = formset.save(commit=False)
         for instance in instances:
             if instance.__class__ == rh.DossierCommentaire:
                 instance.owner = request.user
             instance.save()
-        formset.save_m2m()
 
 class DossierPieceAdmin(admin.ModelAdmin):
     pass
@@ -205,12 +283,35 @@ class DossierCommentaireAdmin(admin.ModelAdmin):
     pass
 
 
-class EmployeAdmin(admin.ModelAdmin):
+class EmployeAdmin(AUFMetadataAdminMixin, ProtectRegionMixin, admin.ModelAdmin):
+    alphabet_filter = 'nom'
+    search_fields = ('id', 'nom', 'prenom', 'nom_affichage', 'actif', )
+    list_filter = ('actif', )
+    ordering = ('nom', )
+    actions = ('desactiver', )
+    list_display = ('nom', 'prenom', 'actif', )
     inlines = (AyantDroitInline,
                DossierROInline,
                EmployePieceInline,
                EmployeCommentaireInline)
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        ('Identification', {
+            'fields': ('nom', 'prenom', 'nom_affichage', 'nationalite', 'date_naissance', 'genre', )
+        }),
+        ('Informations personnelles', {
+            'fields': ('situation_famille', 'date_entree', )
+        }),
+        ('Coordonnées', {
+            'fields': ('tel_domicile', 'tel_cellulaire', 'adresse', 'ville', 'province', 'code_postal', 'pays', )
+        }),
+        )
 
+    def save_formset(self, request, form, formset, change):
+        instances = formset.save(commit=False)
+        for instance in instances:
+            if instance.__class__ == rh.EmployeCommentaire:
+                instance.owner = request.user
+            instance.save()
 
 class EmployeCommentaireAdmin(admin.ModelAdmin):
     pass
@@ -228,16 +329,31 @@ class EvenementRemunerationAdmin(admin.ModelAdmin):
     pass
 
 
-class FamilleEmploiAdmin(admin.ModelAdmin):
+class FamilleEmploiAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
     inlines = (TypePosteInline,)
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', )
+        }),
+        )
 
 
-class OrganismeBstgAdmin(admin.ModelAdmin):
+class OrganismeBstgAdmin(AUFMetadataAdminMixin, ProtectRegionMixin, admin.ModelAdmin):
+    search_fields = ('nom', )
+    list_display = ('nom', 'type', 'pays', )
     inlines = (DossierROInline,)
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', 'type', 'pays', )
+        }),
+        )
 
 
-class PosteAdmin(admin.ModelAdmin):
-    fieldsets = (
+class PosteAdmin(AUFMetadataAdminMixin, ProtectRegionMixin, admin.ModelAdmin):
+    alphabet_filter = 'nom'
+    search_fields = ('nom', 'implantation__code', 'implantation__nom', 'implantation__region__code', 'implantation__region__nom', )
+    list_display = ('nom', 'implantation', 'service', 'type_poste', 'date_debut', 'date_fin', )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
         (None, {
             'fields': ('nom', 'nom_feminin', 'implantation', 'type_poste',
                        'service', 'responsable')
@@ -271,8 +387,16 @@ class PosteAdmin(admin.ModelAdmin):
 
     inlines = (PosteFinancementInline,
                PostePieceInline,
-               PosteCommentaireInline,
-               DossierROInline)
+               DossierROInline,
+               PosteCommentaireInline, )
+
+    def save_formset(self, request, form, formset, change):
+        instances = formset.save(commit=False)
+        for instance in instances:
+            if instance.__class__ == rh.PosteCommentaire:
+                instance.owner = request.user
+            instance.save()
+        formset.save_m2m()
 
 
 class PosteCommentaireAdmin(admin.ModelAdmin):
@@ -291,37 +415,84 @@ class RemunerationAdmin(admin.ModelAdmin):
     pass
 
 
-class ResponsableImplantationAdmin(admin.ModelAdmin):
-    pass
-
-
-class ServiceAdmin(admin.ModelAdmin):
-    inlines = (PosteInline,)
-
+class ResponsableImplantationAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('employe', 'implantation', ),
+        }),
+        )
+    
 
-class StatutAdmin(admin.ModelAdmin):
-    inlines = (EmployeInline,)
+class ServiceAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    list_display = ('nom', 'actif', )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', ),
+        }),
+        )
 
+class StatutAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('code', 'nom', ),
+        }),
+        )
 
 class TauxChangeAdmin(admin.ModelAdmin):
-    pass
-
+    list_display = ('taux', 'devise', 'annee', )
+    list_filter = ('devise', )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('taux', 'devise', 'annee', ),
+        }),
+        )
 
 class TypeContratAdmin(admin.ModelAdmin):
     inlines = (ContratInline,)
 
 
-class TypePosteAdmin(admin.ModelAdmin):
-    inlines = (PosteInline,)
+class TypePosteAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    search_fields = ('nom', 'nom_feminin', )
+    list_display = ('nom', 'famille_emploi', )
+    list_filter = ('famille_emploi', )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', 'nom_feminin', 'is_responsable', 'famille_emploi',  )
+        }),
+        )
 
 
-class TypeRemunerationAdmin(admin.ModelAdmin):
-    inlines = (RemunerationROInline,)
+class TypeRemunerationAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    list_display = ('nom', 'type_paiement', 'nature_remuneration', )
+    #inlines = (RemunerationROInline,) utilité?
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', 'type_paiement', 'nature_remuneration', )
+        }),
+        )
 
 
-class TypeRevalorisationAdmin(admin.ModelAdmin):
-    inlines = (RemunerationROInline,)
+class TypeRevalorisationAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    #inlines = (RemunerationROInline,) utilité?
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('nom', )
+        }),
+        )
 
 
-class ValeurPointAdmin(admin.ModelAdmin):
-    pass
+class ValeurPointAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    list_display = ('_devise_code', '_devise_nom', 'annee', 'valeur', )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + ( 
+        (None, {
+            'fields': ('valeur', 'devise', 'implantation', 'annee', )
+        }),
+        )
+
+    def _devise_code(self, obj):
+        return obj.devise.code
+    _devise_code.short_description = "Code de la devise"
+
+    def _devise_nom(self, obj):
+        return obj.devise.nom
+    _devise_nom.short_description = "Nom de la devise"