1HTML::FormHandler::ManuUasle:r:ECrornotrrsi(b3u)ted PerlHTDMoLc:u:mFeonrtmaHtainodnler::Manual::Errors(3)
2
3
4
6 HTML::FormHandler::Manual::Errors - FormHandler error methods
7
9 version 0.40068
10
12 Manual Index
13
14 Errors and error messages for HTML::FormHandler.
15
17 Errors are added to field or form objects by the field 'add_error'
18 method or the form 'add_form_error' method. FormHandler will perform
19 the 'add_error' for you for built-in validation or 'apply' actions.
20 When performing your own validation in a validation method, you must do
21 the 'add_error' yourself.
22
23 Errors, along with 'input' and 'value' attributes, are collected in the
24 FormHandler 'result' objects. A number of error retrieving methods are
25 delegated to the field and form classes.
26
27 The existence (or not) of errors determines whether or not the form has
28 been 'validated'.
29
31 errors
32 Returns an array of localized error strings (both field and form
33 errors):
34
35 my @errors = $form->errors;
36
37 Note: this is a form method, not a result method. For the same
38 thing from a result object, use "$result->form_and_field_errors".
39
40 has_errors
41 Both 'form' errors and errors from the tree of subfields
42
43 if( $form->has_errors ) {
44 <do something>
45 }
46
47 form_errors, all_form_errors
48 Returns an arrayref / array of error strings on the form (not
49 including field errors).
50
51 foreach my $err ( $self->all_form_errors ) {
52 $output .= "<span class="error">$err</span>";
53 }
54
55 has_form_errors
56 Does the form have form_errors?
57
58 add_form_error
59 Add an error to the form which is not associated with a specific
60 field.
61
62 sub validate {
63 my $self = shift;
64 unless( <some condition> ) {
65 $self->add_form_error('....');
66 }
67 }
68
69 push_form_errors
70 Add a non-localized error to the form.
71
73 The most common error method is probably 'add_error', which you use in
74 the validation process.
75
76 sub validate_foo {
77 my ( $self, $field ) = @_;
78 unless ( <some_condition> ) {
79 $field->add_error('Error condition');
80 }
81 }
82
83 errors
84 Returns an array of error strings.
85
86 has_errors
87 Does the field have errors? Note that a compound field that
88 contains subfields with errors will not return true for this
89 method. If you want to know if there are errors in the subfields,
90 do 'has_error_fields'.
91
92 num_errors
93 add_error
94 Add an error to the field. Localization is performed.
95
96 push_errors
97 Add an error without localization.
98
99 error_fields
100 In a compound field (and its subclasses, like 'Repeatable'), the
101 list of fields with errors.
102
104 The input, value, and error attributes are actually stored in the
105 result objects. Although most of the methods are delegated to the form
106 and field classes, there are times, such as when rendering (because you
107 might be rendering a result that's been peeled off of the form object),
108 that you may need to use result methods.
109
110 These are the main methods that you might need to use.
111
112 has_errors
113 errors
114 error_results
115 The results with errors; 'error_fields' is a wrapper around this.
116
118 The base field class and the field subclasses have some 'built-in'
119 error messages. These can be modified by setting the 'messages'
120 hashref in the form or the individual fields.
121
122 When a message is retrieved in a field with
123 "$field->get_message('upload_file_')" for example, the 'get_message'
124 method will look first in user-set field specific messages, then in
125 user-supplied form messages, finally in messages provided by the field
126 classes.
127
128 package MyApp::Form;
129 use HTML::FormHandler::Moose;
130 extends 'HTML::FormHandler';
131
132 sub build_messages {
133 return { required => '....', my_message => '....' };
134 }
135 ...
136 my $form = MyApp::Form->new( messages => { required => '...', ...} );
137 ...
138 has_field 'my_field' => ( messages => { required => 'Please provide a my_field' },
139 required => 1 );
140
142 FormHandler Contributors - see HTML::FormHandler
143
145 This software is copyright (c) 2017 by Gerda Shank.
146
147 This is free software; you can redistribute it and/or modify it under
148 the same terms as the Perl 5 programming language system itself.
149
150
151
152perl v5.36.0 2023-01-2H0TML::FormHandler::Manual::Errors(3)