From 54c0fa63d126f53af9b96135cebdf8ac12654ce4 Mon Sep 17 00:00:00 2001 From: Romain Courteaud <romain@nexedi.com> Date: Wed, 11 Jul 2007 10:11:29 +0000 Subject: [PATCH] Improve compatibility between PlanningBox and ProxyField, in order to surcharge Javascript configuration. git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@15182 20353a03-c40f-0410-a6d1-a30d3c3de9de --- product/ERP5Form/FormulatorPatch.py | 9 ++++++++- product/ERP5Form/PlanningBox.py | 26 +++++++++++++------------- product/ERP5Form/ProxyField.py | 21 ++++++++++----------- 3 files changed, 31 insertions(+), 25 deletions(-) diff --git a/product/ERP5Form/FormulatorPatch.py b/product/ERP5Form/FormulatorPatch.py index 0d4a9b7de7..fa95794d9f 100644 --- a/product/ERP5Form/FormulatorPatch.py +++ b/product/ERP5Form/FormulatorPatch.py @@ -462,6 +462,13 @@ def Widget_render_css(self, field, REQUEST): pass Widget.render_css = Widget_render_css +def Widget_get_javascript_list(self, field, REQUEST): + """ + Return JS needed by the widget + """ + return [] +Widget.get_javascript_list = Widget_get_javascript_list + from Products.Formulator.Validator import LinesValidator def LinesValidator_validate(self, field, key, REQUEST): @@ -1262,7 +1269,7 @@ def Field_get_javascript_list(self, REQUEST=None): """ Returns list of javascript needed by the field """ - return [] + return self.widget.get_javascript_list(self, REQUEST) Field.get_javascript_list = Field_get_javascript_list diff --git a/product/ERP5Form/PlanningBox.py b/product/ERP5Form/PlanningBox.py index ead7b72984..6da80076f7 100644 --- a/product/ERP5Form/PlanningBox.py +++ b/product/ERP5Form/PlanningBox.py @@ -928,6 +928,19 @@ class PlanningBoxWidget(Widget.Widget): default=2, required=0) + def get_javascript_list(self, field, REQUEST=None): + """ + Returns list of javascript needed by the widget + """ + if field.get_value('js_enabled'): + context = getContext(field, REQUEST) + # XXX Instead of harcoding library name + # it should be better to call a python script, as + # it is done on type base method. + return ['%s/wz_dragdrop.js' % context.portal_url.getPortalPath()] + else: + return [] + def render_css(self, field, REQUEST): """ first method called for rendering by PageTemplate form_view @@ -3154,19 +3167,6 @@ class PlanningBox(ZMIField): def render_css(self, REQUEST=None): return self.widget.render_css(self, REQUEST) - def get_javascript_list(self, REQUEST=None): - """ - Returns list of javascript needed by the field - """ - if self.get_value('js_enabled'): - context = getContext(self, REQUEST) - # XXX Instead of harcoding library name - # it should be better to call a python script, as - # it is done on type base method. - return ['%s/wz_dragdrop.js' % context.portal_url.getPortalPath()] - else: - return [] - # XXX Copy paste from listbox def getContext(field, REQUEST): """ diff --git a/product/ERP5Form/ProxyField.py b/product/ERP5Form/ProxyField.py index 1df06e8cc2..f0f43e321c 100644 --- a/product/ERP5Form/ProxyField.py +++ b/product/ERP5Form/ProxyField.py @@ -126,6 +126,16 @@ class ProxyWidget(Widget.Widget): result = proxy_field.widget.render_css(field, REQUEST) return result + def get_javascript_list(self, field, REQUEST): + """ + Render proxy field + """ + result = [] + proxy_field = field.getRecursiveTemplateField() + if proxy_field is not None: + result = proxy_field.widget.get_javascript_list(field, REQUEST) + return result + class ProxyValidator(Validator.Validator): """ Validation of entered value through proxy field @@ -498,14 +508,3 @@ class ProxyField(ZMIField): else: result = ZMIField._get_user_input_value(self, key, REQUEST) return result - - def get_javascript_list(self, REQUEST=None): - """ - Returns list of javascript needed by the field - """ - proxy_field = self.getTemplateField() - if proxy_field is not None: - result = proxy_field.get_javascript_list(REQUEST) - else: - result = ZMIField.get_javascript_list(self, REQUEST) - return result -- 2.30.9