Add fields list to a few ModelForms Meta class.
[htsworkflow.git] / htsworkflow / frontend / experiments / admin.py
index 23c8098400643c402d302f1a4c3668f2988529d2..e2ea65962e2305200f6212c0e334beb47cb78b23 100644 (file)
@@ -1,6 +1,6 @@
 from itertools import chain
 from htsworkflow.frontend.experiments.models import \
-     FlowCell, DataRun, DataFile, FileType, ClusterStation, Sequencer, Lane
+     FlowCell, FlowCellModel, DataRun, DataFile, FileType, ClusterStation, Sequencer, Lane
 from django.contrib import admin
 from django.contrib.admin.widgets import FilteredSelectMultiple
 from django.forms import ModelForm
@@ -13,6 +13,7 @@ from django.utils.translation import ugettext_lazy as _
 class DataFileForm(ModelForm):
     class Meta:
         model = DataFile
+        fields = ('random_key', 'data_run', 'library', 'file_type', 'relative_pathname')
 
 class DataFileInline(admin.TabularInline):
     model = DataFile
@@ -49,7 +50,13 @@ admin.site.register(DataRun, DataRunOptions)
 
 
 class FileTypeAdmin(admin.ModelAdmin):
-    list_display = ('name', 'mimetype', 'regex')
+    list_display = ('name', 'mimetype', 'regex', 'regex_is_valid')
+    fieldsets = (
+        (None, {
+            'fields': (('name', 'mimetype'),
+                       ('regex'))
+            }
+        )),
 admin.site.register(FileType, FileTypeAdmin)
 
 # lane form setup needs to come before Flowcell form config
@@ -59,6 +66,8 @@ class LaneForm(ModelForm):
 
     class Meta:
         model = Lane
+        fields = ('flowcell', 'lane_number', 'library', 'pM', 'cluster_estimate',
+                  'status', 'comment')
 
 class LaneInline(admin.StackedInline):
     """
@@ -96,6 +105,14 @@ class LaneOptions(admin.ModelAdmin):
     )
 admin.site.register(Lane, LaneOptions)
 
+class FlowCellModelOptions(admin.ModelAdmin):
+    search_fields = ('name',)
+    list_display = ('name', 'fixed_time', 'per_cycle_time', 'isdefault')
+    fieldsets = (
+        (None, { 'fields': ('name', 'fixed_time', 'per_cycle_time', 'isdefault') }),
+        )
+admin.site.register(FlowCellModel, FlowCellModelOptions)
+
 class FlowCellOptions(admin.ModelAdmin):
     class Media:
         css = { 'all': ('css/admin_flowcell.css',) }
@@ -107,11 +124,11 @@ class FlowCellOptions(admin.ModelAdmin):
         '=lane__library__id',
         'lane__library__library_name')
     list_display = ('flowcell_id','run_date','Lanes')
-    list_filter = ('sequencer','cluster_station')
+    list_filter = ('sequencer','cluster_station', 'paired_end')
     fieldsets = (
         (None, {
           'fields': ('run_date', ('flowcell_id','cluster_station','sequencer'),
-                    ('read_length', 'control_lane', 'paired_end'),)
+                    ('flowcell_model', 'read_length', 'paired_end', 'control_lane', ),)
         }),
         ('Notes:', { 'fields': ('notes',),}),
     )