# ------------------------------------------------------------------------------ # This file is part of Appy, a framework for building applications in the Python # language. Copyright (C) 2007 Gaetan Delannay # Appy is free software; you can redistribute it and/or modify it under the # terms of the GNU General Public License as published by the Free Software # Foundation; either version 3 of the License, or (at your option) any later # version. # Appy is distributed in the hope that it will be useful, but WITHOUT ANY # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR # A PARTICULAR PURPOSE. See the GNU General Public License for more details. # You should have received a copy of the GNU General Public License along with # Appy. If not, see . # ------------------------------------------------------------------------------ from appy.fields import Field from appy.px import Px # ------------------------------------------------------------------------------ class Computed(Field): # Ajax-called view content of a non sync Computed field. pxViewContent = Px(''' :field.pxView''') pxView = pxCell = pxEdit = Px(''' :value::value
''') pxSearch = Px('''
  
''') def __init__(self, validator=None, multiplicity=(0,1), default=None, show='view', page='main', group=None, layouts=None, move=0, indexed=False, searchable=False, specificReadPermission=False, specificWritePermission=False, width=None, height=None, maxChars=None, colspan=1, method=None, plainText=False, master=None, masterValue=None, focus=False, historized=False, sync=True, mapping=None, label=None, sdefault='', scolspan=1, swidth=None, sheight=None, context=None): # The Python method used for computing the field value, or a PX. self.method = method # Does field computation produce plain text or XHTML? self.plainText = plainText if isinstance(method, Px): # When field computation is done with a PX, the result is XHTML. self.plainText = False # If method is a PX, its context can be given in p_context. self.context = context Field.__init__(self, None, multiplicity, default, show, page, group, layouts, move, indexed, searchable, specificReadPermission, specificWritePermission, width, height, None, colspan, master, masterValue, focus, historized, sync, mapping, label, sdefault, scolspan, swidth, sheight) self.validable = False def getValue(self, obj): '''Computes the value instead of getting it in the database.''' if not self.method: return if isinstance(self.method, Px): obj = obj.appy() tool = obj.tool ctx = {'obj': obj, 'field': self, 'req': obj.request, 'tool': tool, '_': tool.translate, 'url': tool.o.getIncludeUrl} if self.context: ctx.update(self.context) return self.method(ctx) else: # self.method is a method that will return the field value return self.callMethod(obj, self.method, cache=False) def getFormattedValue(self, obj, value, showChanges=False): if not isinstance(value, basestring): return str(value) return value # ------------------------------------------------------------------------------