type remun #1542
[auf_rh_dae.git] / project / rh / lib.py
index 492455b..ff72388 100644 (file)
@@ -2,35 +2,41 @@
 
 from django.db import models
 from django.contrib import admin
 
 from django.db import models
 from django.contrib import admin
-
+from auf.django.metadata.admin import AUFMetadataAdminMixin, AUFMetadataInlineAdminMixin, AUF_METADATA_READONLY_FIELDS
 from project.rh import models as rh
 
 from project.rh import models as rh
 
+# Inlines
 
 
-class ReadonlyInlineMixin(object):
+class ReadOnlyInlineMixin(object):
     def get_readonly_fields(self, request, obj=None):
     def get_readonly_fields(self, request, obj=None):
-        return [f.name for f in self.model._meta.fields]
+        return [f.name for f in self.model._meta.fields if f.name not in AUF_METADATA_READONLY_FIELDS]
 
 
 
 
-# Inlines
-
-class AyantDroitInline(admin.TabularInline):
+class AyantDroitInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 
 
-class AyantDroitCommentaireInline(admin.TabularInline):
+class AyantDroitCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 
 
-class ContratInline(admin.TabularInline):
+class ContratInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 
 
-class DossierROInline(ReadonlyInlineMixin, admin.TabularInline):
+class DossierROInline(ReadOnlyInlineMixin, admin.TabularInline):
+    exclude = AUF_METADATA_READONLY_FIELDS
     model = models.Model  # à remplacer dans admin.py
 
 
     model = models.Model  # à remplacer dans admin.py
 
 
-class DossierCommentaireInline(admin.TabularInline):
+class DossierCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+    readonly_fields = ('owner', )
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class DossierPieceInline(admin.TabularInline):
 
 
 class DossierPieceInline(admin.TabularInline):
@@ -40,29 +46,34 @@ class DossierPieceInline(admin.TabularInline):
 class EmployeInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 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
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class EmployePieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
 
 
 class EmployePieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
-class EvenementInline(admin.TabularInline):
+class EvenementInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 
 
-class EvenementRemunerationInline(admin.TabularInline):
+class EvenementRemunerationInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class PosteInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
 
 
 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
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 class PosteFinancementInline(admin.TabularInline):
 
 
 class PosteFinancementInline(admin.TabularInline):
@@ -73,11 +84,12 @@ class PostePieceInline(admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
 
 
     model = models.Model  # à remplacer dans admin.py
 
 
-class RemunerationInline(admin.TabularInline):
+class RemunerationInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
     model = models.Model  # à remplacer dans admin.py
     model = models.Model  # à remplacer dans admin.py
+    extra = 1
 
 
 
 
-class RemunerationROInline(ReadonlyInlineMixin, RemunerationInline):
+class RemunerationROInline(ReadOnlyInlineMixin, RemunerationInline):
     pass
 
 
     pass
 
 
@@ -87,9 +99,43 @@ class TypePosteInline(admin.TabularInline):
 
 # Admins
 
 
 # Admins
 
-class AyantDroitAdmin(admin.ModelAdmin):
+class AyantDroitAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    """
+    L'ajout d'un nouvel ayantdroit se fait dans l'admin de l'employé.
+    """
+    search_fields = ('nom', 'prenom', 'employe__nom', 'employe__prenom', )
+    list_display = ('_employe', 'lien_parente', '_ayantdroit', )
     inlines = (AyantDroitCommentaireInline,)
     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', )
+        }),
+    )
+
+    def save_formset(self, request, form, formset, change):
+        super(AyantDroitAdmin, self).save_formset(request, form, formset, change)
+        instances = formset.save(commit=False)
+        for instance in instances:
+            if instance.__class__ == rh.AyantDroitCommentaire:
+                instance.owner = request.user
+            instance.save()
+        formset.save_m2m()
+
+    def _ayantdroit(self, obj):
+        return unicode(obj)
+    _ayantdroit.short_description = u'Ayant droit'
+
+    def _employe(self, obj):
+        return unicode(obj.employe)
+    _employe.short_description = u'Employé'
 
 
+    def has_add_permission(self, request):
+        return False
 
 class AyantDroitCommentaireAdmin(admin.ModelAdmin):
     pass
 
 class AyantDroitCommentaireAdmin(admin.ModelAdmin):
     pass
@@ -104,17 +150,40 @@ class CommentaireAdmin(admin.ModelAdmin):
 
 
 class ContratAdmin(admin.ModelAdmin):
 
 
 class ContratAdmin(admin.ModelAdmin):
-    pass
+    search_fields = ('dossier__employe__nom', 'dossier__employe__prenom', )
+    list_display = ('id', 'dossier', '_poste', )
+
+    def _poste(self, obj):
+        return obj.dossier.poste
+    _poste.short_description = "Poste"
 
 
 class DeviseAdmin(admin.ModelAdmin):
     pass
 
 
 
 
 class DeviseAdmin(admin.ModelAdmin):
     pass
 
 
-class DossierAdmin(admin.ModelAdmin):
-    list_display = ('_employe', '_poste')
-    inlines = (DossierPieceInline, DossierCommentaireInline, ContratInline,
-               RemunerationInline, EvenementInline)
+class DossierAdmin(AUFMetadataAdminMixin, admin.ModelAdmin,):
+    search_fields = ('employe__nom', 'employe__prenom', )
+    list_display = ('_employe', '_poste', 'date_debut', 'date_fin', )
+    inlines = (DossierPieceInline, ContratInline,
+               RemunerationInline,
+               #EvenementInline,
+               DossierCommentaireInline,
+              )
+    fieldsets = AUFMetadataAdminMixin.fieldsets + (
+        ('Identification', {
+            'fields': ('employe', 'poste', 'statut', 'organisme_bstg',)
+        }),
+        ('Recrutement', {
+            'fields': ('remplacement', 'statut_residence', )
+        }),
+        ('Rémunération', {
+            'fields': ('classement', 'regime_travail', 'regime_travail_nb_heure_semaine',)
+        }),
+        ('Occupation du Poste par cet Employe', {
+            'fields': ('date_debut', 'date_fin', )
+        }),
+    )
 
     def _poste(self, dossier):
         return unicode(dossier.poste.nom)
 
     def _poste(self, dossier):
         return unicode(dossier.poste.nom)
@@ -123,7 +192,15 @@ class DossierAdmin(admin.ModelAdmin):
     def _employe(self, dossier):
         return unicode(dossier.employe)
     _employe.short_description = u'Employé'
     def _employe(self, dossier):
         return unicode(dossier.employe)
     _employe.short_description = u'Employé'
-
+    
+    def save_formset(self, request, form, formset, change):
+        super(DossierAdmin, self).save_formset(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
 
 class DossierPieceAdmin(admin.ModelAdmin):
     pass
@@ -133,12 +210,32 @@ class DossierCommentaireAdmin(admin.ModelAdmin):
     pass
 
 
     pass
 
 
-class EmployeAdmin(admin.ModelAdmin):
+class EmployeAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+    search_fields = ('id', 'nom', 'prenom', 'nom_affichage', )
     inlines = (AyantDroitInline,
                DossierROInline,
                EmployePieceInline,
                EmployeCommentaireInline)
     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):
+        super(EmployeAdmin, self).save_formset(request, form, formset, change)
+        instances = formset.save(commit=False)
+        for instance in instances:
+            if instance.__class__ == rh.EmployeCommentaire:
+                instance.owner = request.user
+            instance.save()
+        formset.save_m2m()
 
 class EmployeCommentaireAdmin(admin.ModelAdmin):
     pass
 
 class EmployeCommentaireAdmin(admin.ModelAdmin):
     pass
@@ -161,10 +258,13 @@ class FamilleEmploiAdmin(admin.ModelAdmin):
 
 
 class OrganismeBstgAdmin(admin.ModelAdmin):
 
 
 class OrganismeBstgAdmin(admin.ModelAdmin):
+    list_display = ('nom', 'type', 'pays', )
     inlines = (DossierROInline,)
 
 
 class PosteAdmin(admin.ModelAdmin):
     inlines = (DossierROInline,)
 
 
 class PosteAdmin(admin.ModelAdmin):
+    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 = (
         (None, {
             'fields': ('nom', 'nom_feminin', 'implantation', 'type_poste',
     fieldsets = (
         (None, {
             'fields': ('nom', 'nom_feminin', 'implantation', 'type_poste',
@@ -199,9 +299,16 @@ class PosteAdmin(admin.ModelAdmin):
 
     inlines = (PosteFinancementInline,
                PostePieceInline,
 
     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):
     pass
 
 class PosteCommentaireAdmin(admin.ModelAdmin):
     pass
@@ -232,18 +339,21 @@ class StatutAdmin(admin.ModelAdmin):
 
 
 class TauxChangeAdmin(admin.ModelAdmin):
 
 
 class TauxChangeAdmin(admin.ModelAdmin):
-    pass
-
+    list_display = ('taux', 'devise', 'annee', )
+    list_filter = ('devise', )
 
 class TypeContratAdmin(admin.ModelAdmin):
     inlines = (ContratInline,)
 
 
 class TypePosteAdmin(admin.ModelAdmin):
 
 class TypeContratAdmin(admin.ModelAdmin):
     inlines = (ContratInline,)
 
 
 class TypePosteAdmin(admin.ModelAdmin):
+    list_display = ('nom', 'famille_emploi', )
+    list_filter = ('famille_emploi', )
     inlines = (PosteInline,)
 
 
 class TypeRemunerationAdmin(admin.ModelAdmin):
     inlines = (PosteInline,)
 
 
 class TypeRemunerationAdmin(admin.ModelAdmin):
+    list_display = ('nom', 'type_paiement', 'nature_remuneration', )
     inlines = (RemunerationROInline,)
 
 
     inlines = (RemunerationROInline,)