fix virtual fields with SQLFORM.grid fields=
Conflicts: gluon/sqlhtml.py
This commit is contained in:
@@ -1912,13 +1912,18 @@ class SQLFORM(FORM):
|
||||
for join in left:
|
||||
tablenames += db._adapter.tables(join)
|
||||
tables = [db[tablename] for tablename in tablenames]
|
||||
|
||||
if fields:
|
||||
#add missing tablename to virtual fields
|
||||
for table in tables:
|
||||
for k,f in table.iteritems():
|
||||
if isinstance(f,Field.Virtual):
|
||||
f.tablename = table._tablename
|
||||
columns = [f for f in fields if f.tablename in tablenames]
|
||||
else:
|
||||
fields = []
|
||||
columns = []
|
||||
filter1 = lambda f:isinstance(f,Field)
|
||||
filter2 = lambda f:isinstance(f,Field) and f.readable
|
||||
virtual_columns = []
|
||||
for table in tables:
|
||||
fields += filter(filter1, table)
|
||||
columns += filter(filter2, table)
|
||||
@@ -1926,8 +1931,10 @@ class SQLFORM(FORM):
|
||||
if not k.startswith('_'):
|
||||
if isinstance(f,Field.Virtual) and f.readable:
|
||||
f.tablename = table._tablename
|
||||
columns.append(f)
|
||||
fields.append(f)
|
||||
#show virtual fields after real fields so put at end of list
|
||||
virtual_columns.append(f) #add to fields as well
|
||||
fields = fields + virtual_columns
|
||||
columns = columns + virtual_columns
|
||||
|
||||
if not field_id:
|
||||
if groupby is None:
|
||||
@@ -2271,11 +2278,9 @@ class SQLFORM(FORM):
|
||||
limitby = (paginate*page,paginate*(page+1))
|
||||
else:
|
||||
limitby = None
|
||||
|
||||
try:
|
||||
table_fields = filter(
|
||||
lambda f: (f.tablename in tablenames) and \
|
||||
(not(isinstance(f,Field.Virtual))),fields)
|
||||
table_fields = [field for field in fields
|
||||
if (field.tablename in tablenames and not(isinstance(field,Field.Virtual)))]
|
||||
if dbset._db._adapter.dbengine=='google:datastore':
|
||||
rows = dbset.select(left=left,orderby=orderby,
|
||||
groupby=groupby,limitby=limitby,
|
||||
|
||||
Reference in New Issue
Block a user