X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=plugins%2Fquerytable%2F__init__.py;h=fe486d5e8c42f1614349cc5da38374deeed00aad;hb=873a1e187cfdf103fe56b62ee565770b2d9f4b10;hp=b435b38e345e3877252cd68a2082a9ab068106f5;hpb=ef9e572f3c703640218a44ea7f86aa71805cbcfe;p=unfold.git diff --git a/plugins/querytable/__init__.py b/plugins/querytable/__init__.py index b435b38e..fe486d5e 100644 --- a/plugins/querytable/__init__.py +++ b/plugins/querytable/__init__.py @@ -33,6 +33,7 @@ Current implementation makes the following assumptions as we use 'aoColumnDefs' instead. """ + def __init__ (self, query=None, query_all=None, checkboxes=False, columns=None, init_key=None, @@ -43,20 +44,38 @@ Current implementation makes the following assumptions self.query_all = query_all self.query_all_uuid = query_all.query_uuid if query_all else None self.checkboxes = checkboxes + # XXX We need to have some hidden columns until we properly handle dynamic queries if columns is not None: - self.columns=columns - self.hidden_columns = [] + _columns = columns + _hidden_columns = [] elif self.query: - self.columns = self.query.fields + print "self.query.fields = ", self.query_all.fields + # Columns displayed by default + if self.default_fields is not None: + _columns = [field for field in self.default_fields if not field == 'urn'] + else: + _columns = [field for field in self.query.fields if not field == 'urn'] if query_all: # We need a list because sets are not JSON-serializable - self.hidden_columns = list(self.query_all.fields - self.query.fields) + if self.default_fields is not None: + print self.query_all.fields + _hidden_columns = list(self.query_all.fields - set(self.default_fields)) + else: + _hidden_columns = list(self.query_all.fields - self.query.fields) + _hidden_columns.append('urn') else: - self.hidden_columns = [] + _hidden_columns = [] else: - self.columns = [] - self.hidden_columns = [] + _columns = [] + _hidden_columns = [] + + print "_columns=", _columns + self.columns = { self.mapping.get(c, c) : c for c in _columns } + self.hidden_columns = { self.mapping.get(c, c) : c for c in _hidden_columns } + print "self.columns", self.columns + print "self.hidden_columns", self.hidden_columns + self.init_key=init_key self.datatables_options=datatables_options # if checkboxes were required, we tell datatables about this column's type @@ -71,7 +90,7 @@ Current implementation makes the following assumptions aoColumnDefs = self.datatables_options.setdefault ('aoColumnDefs',[]) # here 'checkbox' is the class that we give to the dom elem # dom-checkbox is a sorting type that we define in querytable.js - aoColumnDefs.append ( {'aTargets': ['checkbox'], 'sSortDataType': 'dom-checkbox' } ) + #aoColumnDefs.insert (0, {'aTargets': ['checkbox'], 'sSortDataType': 'dom-checkbox' } ) def template_file (self): return "querytable.html" @@ -84,7 +103,7 @@ Current implementation makes the following assumptions def requirements (self): reqs = { - 'js_files' : [ "js/spin.presets.js", "js/spin.min.js", "js/jquery.spin.js", + 'js_files' : [ "js/spin-presets.js", "js/spin.min.js", "js/jquery.spin.js", "js/dataTables.js", "js/dataTables.bootstrap.js", "js/with-datatables.js", "js/manifold.js", "js/manifold-query.js", "js/unfold-helper.js", @@ -92,10 +111,10 @@ Current implementation makes the following assumptions # dataTableExt.afnSortData "js/querytable.js", ] , - 'css_files': [ "css/dataTables.bootstrap.css", + 'css_files': [ #"css/dataTables.bootstrap.css", # hopefully temporary, when/if datatables supports sPaginationType=bootstrap3 # for now we use full_numbers, with our own ad hoc css - "css/dataTables.full_numbers.css", + #"css/dataTables.full_numbers.css", "css/querytable.css" , ], }