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
+
+
+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
return [f.name for f in self.model._meta.fields if f.name not in AUF_METADATA_READONLY_FIELDS]
-class AyantDroitInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+class AyantDroitInline(AUFMetadataInlineAdminMixin, admin.StackedInline):
model = models.Model # à remplacer dans admin.py
- extra = 1
+ extra = 0
class AyantDroitCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
class ContratInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
+ form = ContratForm
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):
class EmployePieceInline(admin.TabularInline):
model = models.Model # à remplacer dans admin.py
+ extra = 4
class EvenementInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
extra = 1
-class PosteInline(admin.TabularInline):
- model = models.Model # à remplacer dans admin.py
-
-
class PosteCommentaireInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
readonly_fields = ('owner', )
model = models.Model # à remplacer dans admin.py
pass
-class TypePosteInline(admin.TabularInline):
+class TypePosteInline(AUFMetadataInlineAdminMixin, admin.TabularInline):
model = models.Model # à remplacer dans admin.py
# Admins
-class AyantDroitAdmin(AUFMetadataAdminMixin, 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 = ('_ayantdroit', '_employe', )
+ list_display = ('_employe', 'lien_parente', '_ayantdroit', )
inlines = (AyantDroitCommentaireInline,)
readonly_fields = AUFMetadataAdminMixin.readonly_fields + ('employe',)
fieldsets = AUFMetadataAdminMixin.fieldsets + (
)
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)
pass
-class ClassementAdmin(admin.ModelAdmin):
- pass
+class ClassementAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
+ fieldsets = AUFMetadataAdminMixin.fieldsets + (
+ (None, {
+ 'fields': ('type', 'echelon', 'degre', 'coefficient', )
+ }),
+ )
class CommentaireAdmin(admin.ModelAdmin):
pass
-class ContratAdmin(admin.ModelAdmin):
- pass
-
-
-class DeviseAdmin(admin.ModelAdmin):
- pass
+#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, admin.ModelAdmin,):
- search_fields = ('employe__nom', 'employe__prenom', )
- list_display = ('_employe', '_poste', 'date_debut', 'date_fin', )
+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,
}),
)
+ 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):
- 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
pass
-class EmployeAdmin(AUFMetadataAdminMixin, admin.ModelAdmin):
- search_fields = ('id', 'nom', 'prenom', 'nom_affichage', )
+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,
)
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
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):
+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 = (
+ fieldsets = AUFMetadataAdminMixin.fieldsets + (
(None, {
'fields': ('nom', 'nom_feminin', 'implantation', 'type_poste',
'service', 'responsable')
instance.save()
formset.save_m2m()
+
class PosteCommentaireAdmin(admin.ModelAdmin):
pass
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"