Index: openacs-4/packages/xowiki/tcl/form-field-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/xowiki/tcl/form-field-procs.tcl,v diff -u -r1.160 -r1.161 --- openacs-4/packages/xowiki/tcl/form-field-procs.tcl 21 Nov 2009 00:42:11 -0000 1.160 +++ openacs-4/packages/xowiki/tcl/form-field-procs.tcl 24 Nov 2009 14:08:36 -0000 1.161 @@ -48,6 +48,7 @@ {help_text ""} {error_msg ""} {validator ""} + {validate_via_ajax} locale default object @@ -392,6 +393,17 @@ # If no special renderer is defined, we fall back to this one, # which is in most cases a simple input fied of type string. # + if {[my exists validate_via_ajax] && [my validator] ne ""} { + set ajaxhelper 1 + ::xowiki::Includelet require_YUI_JS -ajaxhelper 0 "yahoo/yahoo-min.js" + ::xowiki::Includelet require_YUI_JS -ajaxhelper 0 "dom/dom-min.js" + ::xowiki::Includelet require_YUI_JS -ajaxhelper 0 "event/event-min.js" + ::xowiki::Includelet require_YUI_JS -ajaxhelper 0 "connection/connection-min.js" + ::xo::Page requireJS "/resources/xowiki/yui-form-field-validate.js" + set package_url [[[my object] package_id] package_url] + ::xo::Page requireJS "YAHOO.xo_form_field_validate.add('[my id]','$package_url');" + } + ::html::input [my get_attributes type size maxlength id name value disabled {CSSclass class}] {} # # Disabled fieds are not returned by the browsers. For some Index: openacs-4/packages/xowiki/tcl/xowiki-www-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/xowiki/tcl/xowiki-www-procs.tcl,v diff -u -r1.244 -r1.245 --- openacs-4/packages/xowiki/tcl/xowiki-www-procs.tcl 23 Nov 2009 09:55:36 -0000 1.244 +++ openacs-4/packages/xowiki/tcl/xowiki-www-procs.tcl 24 Nov 2009 14:08:36 -0000 1.245 @@ -833,7 +833,8 @@ Page ad_instproc get_form_data {-field_names form_fields} { Get the values from the form and store it as - instance attributes. + instance attributes. If the field names are not specified, + all form parameters are used. } { #my msg "get_form_data [self] [my name] [self args]" set validation_errors 0 @@ -1104,11 +1105,37 @@ return $field_names } - Page instproc save_attributes {} { - my log "**** Method save_attributes is deprecated, use save-attributes instead" - my save-attributes + Page instproc validate-attribute {} { + set field_names [my field_names] + set validation_errors 0 + + # get the first transmitted form field + foreach field_name $field_names { + if {[::xo::cc exists_form_parameter $field_name]} { + set form_fields [my create_form_field $field_name] + set query_field_names $field_name + break + } + } + foreach {validation_errors category_ids} \ + [my get_form_data -field_names $query_field_names $form_fields] break + set error "" + if {$validation_errors == 0} { + set status_code 200 + } else { + set status_code 406 + foreach f $form_fields { + if {[$f error_msg] ne ""} {set error [$f error_msg]} + } + } + ns_return $status_code text/html $error } - Page instproc save-attributes {} { + + Page ad_instproc save-attributes {} { + The method save-attributes is typically called over the + REST interface. It allows to save attributes of a + page without adding a new revision. + } { my instvar package_id set field_names [my field_names] set form_fields [list]