fix for 500 error
[auf_rh_dae.git] / project / dae / admin.py
index 76443eb..7f3b137 100644 (file)
@@ -1,16 +1,32 @@
 # -*- encoding: utf-8 -*-
 
-from django.contrib import admin
 from django import forms
-from reversion.admin import VersionAdmin
+from django.contrib import admin
+
 from auf.django.workflow.models import WorkflowCommentaire
-from models import Poste, Dossier
 
-class PosteAdmin(VersionAdmin):
+from project.dae.models import Poste, Dossier, ProxyDossierStatut, \
+        ProxyPosteStatut
+
+
+class BaseAdmin(admin.ModelAdmin):
+
+    class Media:
+        css = {'screen': (
+            'css/admin_custom.css',
+            'jquery-autocomplete/jquery.autocomplete.css',
+        )}
+        js = (
+            'https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js',
+            'jquery-autocomplete/jquery.autocomplete.min.js',
+        )
+
+
+class PosteAdmin(BaseAdmin):
     list_display = ('nom', 'implantation', 'etat', )
 
 
-class DossierAdmin(VersionAdmin):
+class DossierAdmin(BaseAdmin):
     list_display = ('_poste', '_implantation', 'employe', 'etat', )
     list_filter = ('etat', )
     exclude = ('etat', )
@@ -22,28 +38,12 @@ class DossierAdmin(VersionAdmin):
         return obj.poste.implantation
 
 
-class ProxyDossierStatut(Dossier):
-    class Meta:
-        proxy = True
-        verbose_name = "Statut du dossier"
-        verbose_name_plural = "Statut des dossiers"
-
-
-class ProxyPosteStatut(Poste):
-    class Meta:
-        proxy = True
-        verbose_name = "Statut du poste"
-        verbose_name_plural = "Statut des postes"
-
-
 class StatutForm(forms.ModelForm):
-
     commentaire = forms.CharField(label="Commentaire",
             widget=forms.widgets.Textarea())
 
     def __init__(self, *args, **kwargs):
         super(StatutForm, self).__init__(*args, **kwargs)
-        
         # On retire le controle check des états pour faire ce qu'on veut
         self._meta.model.__setattr__ = object.__setattr__
 
@@ -51,33 +51,36 @@ class StatutForm(forms.ModelForm):
         self.wf = WorkflowCommentaire()
         self.wf.etat_initial = self.instance.etat
         self.wf.owner_id = self.user.id
-    
+
     def save(self, *args, **kwargs):
         # Le dossier se voit attribuée un commentaire WF verbeux
         obj = super(StatutForm, self).save(*args, **kwargs)
         self.wf.content_object = obj
         self.wf.etat_final = obj.etat
-        commentaire = u"%s => %s : %s" % (self.wf.etat_initial, self.wf.etat_final,
+        commentaire = u"%s => %s : %s" % (
+                self.wf.get_etat_label(self.wf.etat_initial),
+                self.wf.get_etat_label(self.wf.etat_final),
                 self.data['commentaire'])
         self.wf.texte = commentaire
         self.wf.save()
         return obj
 
+
 class StatutDossierForm(StatutForm):
-    
+
     class Meta:
         model = ProxyDossierStatut
         fields = ('etat', )
 
 
 class StatutPosteForm(StatutForm):
-    
+
     class Meta:
         model = ProxyPosteStatut
         fields = ('etat', )
 
 
-class StatutAdmin(VersionAdmin):
+class StatutAdmin(BaseAdmin):
     action = None
 
     def has_delete_permission(self, request, obj=None):
@@ -97,11 +100,14 @@ class StatutAdmin(VersionAdmin):
 
     def _etat(self, obj):
         return obj.get_etat_display()
+    _etat.short_description = "État"
+    _etat.admin_order_field = "etat"
 
 
 class DossierStatutAdmin(StatutAdmin):
     search_fields = ('employe__nom', 'employe__prenom', 'poste__nom', )
     list_display = ('_poste', '_implantation', 'employe', '_etat', )
+    list_filter = ('poste__implantation', )
     form = StatutDossierForm
 
     def _poste(self, obj):
@@ -109,12 +115,14 @@ class DossierStatutAdmin(StatutAdmin):
 
     def _implantation(self, obj):
         return obj.poste.implantation
-
+    _implantation.short_description = u"Implantation"
+    _implantation.admin_order_field = "poste__implantation"
 
 
 class PosteStatutAdmin(StatutAdmin):
     search_fields = ('nom', )
-    list_display = ('nom', 'implantation', '_etat', )
+    list_display = ('nom', 'implantation', )
+    list_filter = ('implantation', 'etat', )
     form = StatutPosteForm