print killing wsgi; minor fix.
[htsworkflow.git] / htsworkflow / frontend / experiments / admin.py
index 50b8e3f6b442cedddd0c89d0c81966e091840048..9b8cf4f15d51f9fd08062ccd5cbf3a5b10c1c289 100644 (file)
@@ -1,7 +1,12 @@
-from htsworkflow.frontend.experiments.models import FlowCell, DataRun
+from htsworkflow.frontend.experiments.models import FlowCell, DataRun, ClusterStation, Sequencer, Lane
 from django.contrib import admin
 from django.utils.translation import ugettext_lazy as _
 
+class LaneInline(admin.StackedInline):
+  model = Lane
+  max_num = 8
+  extra = 8
+
 class DataRunOptions(admin.ModelAdmin):
   search_fields = [
       'run_folder',
@@ -15,7 +20,14 @@ class DataRunOptions(admin.ModelAdmin):
       '=fcid__lane_6_library__library_id',
       '=fcid__lane_7_library__library_id',
       '=fcid__lane_8_library__library_id'
-  ]
+      'fcid__lane_1_library__library_name',
+      'fcid__lane_2_library__library_name',
+      'fcid__lane_3_library__library_name',
+      'fcid__lane_4_library__library_name',
+      'fcid__lane_5_library__library_name',
+      'fcid__lane_6_library__library_name',
+      'fcid__lane_7_library__library_name',
+      'fcid__lane_8_library__library_name'  ]
   list_display = [
       'run_folder', 
       'Flowcell_Info', 
@@ -29,8 +41,8 @@ class FlowCellOptions(admin.ModelAdmin):
     date_hierarchy = "run_date"
     save_on_top = True
     search_fields = ('flowcell_id',
-        'seq_mac_id',
-        'cluster_mac_id',
+        'sequencer__name',
+        'cluster_station__name',
         '=lane_1_library__library_id',
         '=lane_2_library__library_id',
         '=lane_3_library__library_id',
@@ -38,18 +50,53 @@ class FlowCellOptions(admin.ModelAdmin):
         '=lane_5_library__library_id',
         '=lane_6_library__library_id',
         '=lane_7_library__library_id',
-        '=lane_8_library__library_id')
+        '=lane_8_library__library_id',
+        'lane_1_library__library_name',
+        'lane_2_library__library_name',
+        'lane_3_library__library_name',
+        'lane_4_library__library_name',
+        'lane_5_library__library_name',
+        'lane_6_library__library_name',
+        'lane_7_library__library_name',
+        'lane_8_library__library_name')
     list_display = ('flowcell_id','run_date','Lanes')
-    list_filter = ('seq_mac_id','cluster_mac_id')
+    list_filter = ('sequencer','cluster_station')
     fieldsets = (
         (None, {
-            'fields': ('run_date', ('flowcell_id','cluster_mac_id','seq_mac_id'), ('read_length', 'paired_end'),)
+            'fields': ('run_date', ('flowcell_id','cluster_station','sequencer'), ('read_length', 'paired_end'),)
         }),
         ('Lanes:', {
            'fields' : (('lane_1_library', 'lane_1_pM', 'lane_1_cluster_estimate'), ('lane_2_library', 'lane_2_pM', 'lane_2_cluster_estimate'), ('lane_3_library', 'lane_3_pM', 'lane_3_cluster_estimate'), ('lane_4_library', 'lane_4_pM', 'lane_4_cluster_estimate'), ('lane_5_library', 'lane_5_pM', 'lane_5_cluster_estimate'), ('lane_6_library', 'lane_6_pM', 'lane_6_cluster_estimate'), ('lane_7_library', 'lane_7_pM', 'lane_7_cluster_estimate'), ('lane_8_library', 'lane_8_pM', 'lane_8_cluster_estimate'),)
         }),
+        ('Notes:', { 'fields': ('notes',),}),
     )
+    inlines = [
+      LaneInline,
+    ]
+
+class ClusterStationOptions(admin.ModelAdmin):
+    list_display = ('name', )
+    fieldsets = ( ( None, { 'fields': ( 'name', ) } ), )
+
+class SequencerOptions(admin.ModelAdmin):
+    list_display = ('name', )
+    fieldsets = ( ( None, { 'fields': ( 'name', ) } ), )
+    
+class LaneOptions(admin.ModelAdmin):
+    list_display = ('flowcell', 'lane_number', 'library', 'comment')
+    fieldsets = (
+      (None, {
+        'fields': ('lane_number', 'flowcell', 'library', 'pM', 'cluster_estimate')
+      }),
+      ('Optional', {
+        'classes': ('collapse', ),
+        'fields': ('comment', )
+      }),
+    )
+    
 
 admin.site.register(DataRun, DataRunOptions)
 admin.site.register(FlowCell, FlowCellOptions)
-
+admin.site.register(ClusterStation, ClusterStationOptions)
+admin.site.register(Sequencer, SequencerOptions)
+admin.site.register(Lane, LaneOptions)