Forums / Setup & design / Form processing not working

Form processing not working

Author Message

Xavier Serna

Tuesday 12 December 2006 1:34:22 am

Hi all,

this is my first message to the forum, so I apologize if this question has been discussed previously, but I didn't find any solution to this.

My problem is that I have a custom form created, and every time I submit it, I only get the form reloaded, without any errors or debug messages. Simply, the form is not processed, but I can't figure why. The only thing that I can suppose that is causing this, can be that in the form, there are missing fields from the class (in the class there are now attribs that are not used by the moment), but I can't find anywhere if this is required or not that all attribs from the class set up as information collectors need to be present in the form.

Thanks in advance for your support.
Xavier

--
Xavier Serna
eZ Publish Certified Developer
Departament de Software
Microblau S.L. - http://www.microblau.net
+34 937 466 205

Claudia Kosny

Wednesday 13 December 2006 12:20:00 pm

Hi Xavier

First check that the action attribute of your form is correct. If you use some form processing capabilities of EZ make sure that the name of your submit button is correct. EZ often decides on what to do depending of the name of the button and if it does not find any match, it might well just reload the page.

Also enable debug redirection, which will tell you if you are redirected to another page. This is usually the case of you post to e.g. content/action.

If there is no input for fields that are marked as required, you should get some error messages. Maybe your template does not display them anymore? Usually the error messages are in the variable $validation.attributes, although this might not be always the case.
Required fields are marked as required if you edit an object in the admin view. You can also check the class definition of the object in question, each attribute has a checkbox for the required status there.

If you still have problems, post the relevant part of your form (form tag, submit button(s) and a few sample form fields) here and describe what you expect to happen on submit.

Claudia

Xavier Serna

Thursday 14 December 2006 12:39:01 am

Hi Claudia,

thanks for your answer. I think that I've found the problem. If I put all the Information Collector fields in the form, it works correctly as expected. The problem is if I don't need/want to put some of the fields. If there are some missing fields, present in the class as attributes, but not present in the actual form, the form is not processed, and we don't get any validation errors or something similar. I suppose that including the missing fields as hidden input fields it will work correctly. The question is if it is the correct way to get the form working, or there is another procedure for that?
The action of the form is "content/action" and the submit button name is: ActionCollectInformation

thanks for your support!!

--
Xavier Serna
eZ Publish Certified Developer
Departament de Software
Microblau S.L. - http://www.microblau.net
+34 937 466 205

Claudia Kosny

Thursday 14 December 2006 2:36:39 am

Hi Xavier

I think the problem occurs because some datatypes do not validate correctly. E.g. ezstring, eztext and ezdate automatically return an EZ_INPUT_VALIDATOR_STATE_INVALID (without setting any validation error) if the respective post variables are not there, no matter whether the attribute is required or not.

I don't have the time right now to see whether this is really the source of the problem, so if you have the time to check this and confirm this you should maybe post a bug report. For a quick solution I would just do as you said before and post the attributes as hidden fields.

Claudia

Xavier Serna

Thursday 14 December 2006 9:32:04 am

Hi again Claudia,

after some testing, I've found that the problem is that when a missing classattribute is found, it returns as you say, EZ_INPUT_VALIDATOR_STATE_INVALID, and then in collectinformation.php sets the $canCollect to false without checking if the attribute has content or not, or is required or not, so, as the attribute has no content, it have the $hasValidationError set to false, so it don't generate any error message.
I've found that including a simple check to see if the attribute has content or is required, the problem is solved.

I've changed this line in collectinformation.php from

            else if ( $status == EZ_INPUT_VALIDATOR_STATE_INVALID )

to this one

            else if ( $status == EZ_INPUT_VALIDATOR_STATE_INVALID && ($contentObjectAttribute->attribute( 'has_content' ) || $contentObjectAttribute->attribute( 'is_required' )) )

and now the form is processed correctly and the object information is collected, obviously without any attributes that you don't have put in the form.

I don't know if it is a bug or a feature :s

kind regards!

--
Xavier Serna
eZ Publish Certified Developer
Departament de Software
Microblau S.L. - http://www.microblau.net
+34 937 466 205

eZ debug

Timing: Jan 18 2025 18:38:52
Script start
Timing: Jan 18 2025 18:38:52
Module start 'content'
Timing: Jan 18 2025 18:38:52
Module end 'content'
Timing: Jan 18 2025 18:38:52
Script end

Main resources:

Total runtime0.1646 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0071 588.8281180.8359
Module start 'content' 0.00710.0056 769.6641101.9922
Module end 'content' 0.01270.1518 871.6563530.5234
Script end 0.1645  1,402.1797 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00362.1783200.0002
Check MTime0.00150.8891200.0001
Mysql Total
Database connection0.00080.494610.0008
Mysqli_queries0.116870.97921410.0008
Looping result0.00130.80011390.0000
Template Total0.151492.010.1514
Template load0.00080.494610.0008
Template processing0.150691.487310.1506
Override
Cache load0.00060.345710.0006
Sytem overhead
Fetch class attribute can translate value0.00060.389610.0006
XML
Image XML parsing0.00030.182810.0003
General
dbfile0.00342.0815200.0002
String conversion0.00000.002530.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs