Posted by naseem_sarwar on
hi,
i have very frustrating question. i am trying to make a form module which have a three fields together like sortcode have three different fields. now i have to make a validation in which if one of the three ll be wrong all three fields will be highlighted. but problem is this i want to show only one error message.
only solution in the below but it ll create two empty list items. which is not good for usibility.
form_set_error('element1',$message');
form_set_error('element2', ' ');
form_set_error('element3', ' ');
is there anyother solution is there. so we can highlight three fields and show only one message.
thanks
Comments
Hi, here is a possible
Hi,
here is a possible solution for you. The idea is to group the form items within a parent. See below a small example:
The important line is
In the validation of the form, you can do something like:
So, instead of putting 3 errors, you just put one single error on the parent. Also, please remember that if you specify the #tree attribute in the form, you must also consider the values in the $form_state['values'] as a tree. Something like this:
Hope this helps,
Vasi.
improvments
hi,
your code was quite helpful. i just need a final step from you. i have implemented that code but it is not working. only thing is this i have 15 fields and only 3 of them should be together. i made like your example. i got the values in validation but when i put the error it give the one message but it did not highlight the fields.
any idea? why it is not doin it.
$form['name']['AccountName'] = array(
'#type' => 'textfield',
'#title' => t('Account Name* '),
);
$form['payment']['element1'] = array(
'#type' => 'textfield',
'#title' => t('element1* '),
//'#required' => TRUE,
'#size' => 2,
'#maxlength' => 2,
);
$form['payment']['element2'] = array(
'#type' => 'textfield',
'#size' => 2,
'#maxlength' => 2,
);
$form['payment']['element3'] = array(
'#type' => 'textfield',
'#size' => 2,
'#maxlength' => 2,
);
$form['payment']['#tree'] = TRUE;
then i have more fields with [name] too.
now on validation
if(validation)
{
form_set_error('payment', t('Please enter '));
}
it show one message on top. but if does not highlight any of the fields.
Hi, can you try to put all
Hi,
can you try to put all the fields inside a common parent, even if they do not logically belong to that parent. For example:
and in the validation:
Can you try like that?
Vasi.
it helps
hi,
i again try your example. but only one problem i got. in above code i want to show error only on payment elements. how can i do that?
i tried this but it didnt work.
form_set_error('parent_name][payment', t('Please enter'));
am i doing right? please advise!
Hi, for that, you should
Hi,
for that, you should only need this:
and then, in validation,
form_set_error Question
Does anyone know if it’s possible to have form_set_error() apply to multiple fields?
Or maybe something like…
Does anything like this make sense?
Thanks
Comments
Hmm...
Interesting question. I don't see what you couldn't at least do the second method. I'll be interested in what other answers come up.
Nancy W.
Drupal Cookbook (for New Drupallers)
Adding Hidden Design or How To notes in your database
NancyDru
not tested, but it should
not tested, but it should work...
José San Martin
http://www.verinco.com/
http://www.gare7.org/
http://www.studying-linguistics.com/
José San Martin
http://www.chuva-inc.com/
Worked.
That did work, thanks!
There might have been some weird issues with resolution after the error message, but the initial error display worked fine. I say 'might' because we ended up changing our logic, yielding that condition useless, so I did not test it further. But thanks for your help!
one error message, multiple fields
I came across this question today.
I'm not sure what version you're referring to, but under Drupal 5.x your (albeit untested) example doesn't work. If you look at the code for form_set_error it's easy to see why. Setting the first name parameter to NULL will cause isset() to return false. Also, not defining the second message parameter will prevent drupal_set_message() from firing.
According to the documentation, form_set_error is suppose to allow setting errors for multiple fields by grouping them together as child elements, but I wasn't able to get this to work either.
...
Yeah, the above example is not supposed to work.
Could you please open a feature request?
before creating a feature request
I'd be curious to know if anyone has successfully used form_set_error() according to the documentation.
If you mean...
If you mean in the standard manner (one error, one field, one message), yes - there are many examples throughout core as well.
Nancy W.
Drupal Cookbook (for New Drupallers)
Adding Hidden Design or How To notes in your database
NancyDru
And if you mean...
It works. Perhaps you didn't use
#tree => TRUE
on the parent element?(There's one small error in the doc: Nowadays elements aren't named
edit[foo][bar]
but simplyfoo[bar]
. But don't mention this in your issue; it isn't relevant.)I mean the latter
That is: one error, multiple fields, one message.
I have the #tree attribute set to TRUE.
I also noted the syntax error.
Still no success. I've moved on to other more important project tasks, but will revisit this later.
dirty solution
Well, after lot's of testing, I find a solution, while not very nice, it just works.
The above code didn't worked for me (Drupal 6 right now) as when adding NULL to the error won't print and fields won't get marked if an error message is not passed (neither with '' as message), so I fixed it passing a blank space as message.
This worked for me:
Now I have the two fields marked as error and just a blank list entry on the errors list... can live with it.. :)
Hopes this helps anybody.
interesting
botum, thanks for sharing your findings.
I discovered another technique for displaying multiple error messages is to use form_set_error for the first message and drupal_set_message (with the second parameter set to 'error') for any additional messages. This won't solve the problem you're talking about though.
form_set_error and multiple fields
up. I've this problem, too. I'd like to get a single error message, while highlighting two or more fields. Is it possible to do that?
I tried also with form_set_error( array('FirstField', 'SecondField'), t('FF has to be > than SF!') ) but it doesn't work...
No solution for this (common?) question?
time to revisit this issue and find a solution
So nearly 1 1/2 years later since the original post of this thread the inability to display one error message for multiple fields still persists.
I need the ability to highlight (i.e. red outline style by default) multiple fields while only displaying one error message. For example:
Currently in the above example only the 'address1' field is highlighted.
Interesting excluding the second message string argument from form_set_error() still allows the fieldname to be added to the static form array, but the field highlighting is ignored.
Yeah, I can define the second argument as a space like so
but this is a lame workaround and adds extra space to the error message div.
-------------------------------------------------------
"If you don't read the newspaper you are uninformed;
if you do read the newspaper you are misinformed."
-- Mark Twain
Example of a solution
An example can be seen here: http://api.drupal.org/api/function/password_confirm_validate/6
I'm pretty sure the above
I'm pretty sure the above solution only works if the password fields are the only fields being passed into password_confirm_validate().
If you don't want to set the two, or more, comparative form elements under a common parent (looking at the code, this is what seems to make form_error() really work), I suggest setting the first element with form_set_error() as explained a bit further above, and then setting a flag value to rebuild the attributes of the other form elements.
Looking at the source code, I found that the error highlighting around form fields is turned on by adding the class 'error' to the form element.
So starting within your hook_validate function with form elements 'email' and 'confirm_email':
The key above being setting $form_state['rebuild'] = TRUE, after setting your flag value to be 1. Also, we need another sentinel value $error to mark if there are any other errors in the validation process. Because $form_state['rebuild'] ignores any $form_state['redirect'] value, the $error needs to be turned on. That way if there are any previous failures in validation the form will rebuild itself, and re-present itself to the user. Otherwise, the form will proceed as expected.
Then in your hook_form:
Setting $form_state['rebuild'] = TRUE will allow you to reset the attributes after validation. For additional form fields, just set '#atttributes' => $attributes.
I included the form element 'name' to illustrate that any values that you want repopulated when the form rebuilds, you have to use the '#default_value' property for the form element, otherwise the value is not populated.
Not all pretty, but does work.
Hate to bring up old stuff but...
Has this changed? I'm doing something similar to this, but I can't seem to get past form.inc line 141 if I set an error - it doesn't rebuild the form, it just re-renders it, which doesn't seem to give my form function a chance to do anything differently...
dnotes.net
Sometimes trying to do things
Sometimes trying to do things 'The Drupal Way' seems just waaay too much work, assuming it's even possible. I just use something like this. Crude. Works.
If your repeated errors are not sequential, you'll need to expand on that a bit...
Yep, waaay too hard :)
John,
I agree with the waaay too much work sometimes. Your solution worked fine thanks, just popped every message as I created them and then did the below to get an actual message up.
Anthony.
Popping all but one makes
Popping all but one makes more sense to me.
Better yet
Simply filter the array to remove duplicates.
$_SESSION['messages']['error'] = array_filter($_SESSION['messages']['error']);
Live long ... and prosper!
I think you
I think you mean
which would remove all duplicate error messages. I recently used this to solve the problem described in this thread.
any example to that
i am strggling to do that. can anyone give me example for that. i am really struggling to get this done.
worked great!
Thanks for this one! Elegant solution!
Thank keyfarmer. That's wha i
Thank keyfarmer. That's wha i meant.
Live long ... and prosper!
solution found folks
set #parents => array('foo'), on each element that is to be highlighted together (in my case i require either a telephone number or an email address for my form)
in your validation/submission function put form_set_error($name = 'foo', $message = 'how much do you all love me?');
don't forget
don't forget to apply $form['#tree'] = TRUE
The array_pop method would
The array_pop method would remove other error messages, so that can't be assumed "safe".
The message above about setting #parent would certainly work, but you'd set errors on every child, even those that contain data and are already correct.
I think the best thing to do is run
<?php $_SESSION['messages']['error'] = array_unique($_SESSION['messages']['error']); ?>
at the end of your _form_validate() function after setting errors on everything that's an error.Edit: Well, you'd really want to make sure the ['error'] array exists before setting it, otherwise you'll print errors even when there are none!
There is a way...
There is a way to mark form element as error suppressing error message.
This worked for me with clean
This worked for me with clean HTML output in the error box:Sorry - spoke too soon, it is only highlighting one of the fields!
form_set_error('username',
That is tested and Works
not recommended
$messages = drupal_get_messages('error', true);
This example will "get rid" (aka. clear queue) of all messages of "error" type, not just "the first error message". In many/most cases this is not desirable as you risk clearing other relevant error messages.
This is working in D7
The following code is showing error message only once but highlighting in red three fields:
blank error message strings work (finally)
It's funny how this issue still crops up from time to time. That is, highlighting multiple fields while displaying only one error message.
Indeed, setting additional fields via form_set_error() with an empty message string works in Drupal 7. It seems like back in Drupal 6 days doing so would output extra line breaks.
@rag_gupta, it's considered best practice to pass variables to the translate (T) function as an associative array of replacements versus inserting them directly into the string via PHP.
来自 https://www.drupal.org/node/155695