Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
ErrorsField |
|
| 1.8653846153846154;1.865 |
1 | /* | |
2 | * Copyright 2007 The Kuali Foundation | |
3 | * | |
4 | * Licensed under the Educational Community License, Version 1.0 (the "License"); | |
5 | * you may not use this file except in compliance with the License. | |
6 | * You may obtain a copy of the License at | |
7 | * | |
8 | * http://www.opensource.org/licenses/ecl1.php | |
9 | * | |
10 | * Unless required by applicable law or agreed to in writing, software | |
11 | * distributed under the License is distributed on an "AS IS" BASIS, | |
12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
13 | * See the License for the specific language governing permissions and | |
14 | * limitations under the License. | |
15 | */ | |
16 | package org.kuali.rice.kns.uif.field; | |
17 | ||
18 | import java.text.MessageFormat; | |
19 | import java.util.ArrayList; | |
20 | import java.util.Arrays; | |
21 | import java.util.List; | |
22 | ||
23 | import org.apache.commons.lang.StringUtils; | |
24 | import org.kuali.rice.core.api.config.property.ConfigurationService; | |
25 | import org.kuali.rice.kns.service.KNSServiceLocator; | |
26 | import org.kuali.rice.kns.uif.container.ContainerBase; | |
27 | import org.kuali.rice.kns.uif.container.PageGroup; | |
28 | import org.kuali.rice.kns.uif.container.View; | |
29 | import org.kuali.rice.kns.uif.core.Component; | |
30 | import org.kuali.rice.kns.util.ErrorMessage; | |
31 | import org.kuali.rice.kns.util.GlobalVariables; | |
32 | import org.kuali.rice.kns.util.MessageMap; | |
33 | import org.springframework.util.AutoPopulatingList; | |
34 | ||
35 | /** | |
36 | * Field that displays error, warning, and info messages for the keys that are | |
37 | * matched. By default, an ErrorsField will match on id and bindingPath (if this | |
38 | * ErrorsField is for an AttributeField), but can be set to match on | |
39 | * additionalKeys and nested components keys (of the its parentComponent). | |
40 | * | |
41 | * In addition, there are a variety of options which can be toggled to effect | |
42 | * the display of these messages during both client and server side validation | |
43 | * display. See documentation on each get method for more details on the effect | |
44 | * of each option. | |
45 | * | |
46 | * @author Kuali Rice Team (rice.collab@kuali.org) | |
47 | */ | |
48 | public class ErrorsField extends FieldBase { | |
49 | private static final long serialVersionUID = 780940788435330077L; | |
50 | ||
51 | private List<String> additionalKeysToMatch; | |
52 | ||
53 | // Title variables | |
54 | private String errorTitle; | |
55 | private String warningTitle; | |
56 | private String infoTitle; | |
57 | ||
58 | private boolean displayErrorTitle; | |
59 | private boolean displayWarningTitle; | |
60 | private boolean displayInfoTitle; | |
61 | ||
62 | // Field variables | |
63 | private boolean highlightOnError; | |
64 | private boolean displayFieldErrorIcon; | |
65 | ||
66 | // Message construction variables | |
67 | private boolean displayFieldLabelWithMessages; | |
68 | private boolean combineMessages; | |
69 | ||
70 | // Message display flags | |
71 | private boolean displayNestedMessages; | |
72 | private boolean allowMessageRepeat; | |
73 | ||
74 | private boolean displayMessages; | |
75 | private boolean displayErrorMessages; | |
76 | private boolean displayInfoMessages; | |
77 | private boolean displayWarningMessages; | |
78 | private boolean displayCounts; | |
79 | private boolean alternateContainer; | |
80 | ||
81 | // Error messages | |
82 | private List<String> errors; | |
83 | private List<String> warnings; | |
84 | private List<String> infos; | |
85 | ||
86 | // Counts | |
87 | private int errorCount; | |
88 | private int warningCount; | |
89 | private int infoCount; | |
90 | ||
91 | // internal | |
92 | private int tempCount; | |
93 | ||
94 | // not used | |
95 | private boolean displayLockMessages; | |
96 | ||
97 | public ErrorsField() { | |
98 | 0 | super(); |
99 | 0 | } |
100 | ||
101 | /** | |
102 | * PerformFinalize will generate the messages and counts used by the | |
103 | * errorsField based on the keys that were matched from the MessageMap for | |
104 | * this ErrorsField. It will also set up nestedComponents of its | |
105 | * parentComponent correctly based on the flags that were chosen for this | |
106 | * ErrorsField. | |
107 | * | |
108 | * @see org.kuali.rice.kns.uif.field.FieldBase#performFinalize(org.kuali.rice.kns.uif.container.View, | |
109 | * java.lang.Object, org.kuali.rice.kns.uif.core.Component) | |
110 | */ | |
111 | @Override | |
112 | public void performFinalize(View view, Object model, Component parent) { | |
113 | 0 | super.performFinalize(view, model, parent); |
114 | ||
115 | 0 | List<String> masterKeyList = getKeys(parent); |
116 | 0 | errors = new ArrayList<String>(); |
117 | 0 | warnings = new ArrayList<String>(); |
118 | 0 | infos = new ArrayList<String>(); |
119 | 0 | errorCount = 0; |
120 | 0 | warningCount = 0; |
121 | 0 | infoCount = 0; |
122 | 0 | MessageMap messageMap = GlobalVariables.getMessageMap(); |
123 | ||
124 | 0 | if (!displayFieldLabelWithMessages) { |
125 | 0 | this.addStyleClass("noLabels"); |
126 | } | |
127 | 0 | if (!highlightOnError) { |
128 | 0 | this.addStyleClass("noHighlight"); |
129 | } | |
130 | 0 | if (displayFieldErrorIcon) { |
131 | 0 | this.addStyleClass("addFieldIcon"); |
132 | } | |
133 | ||
134 | 0 | if (displayMessages) { |
135 | 0 | if (displayNestedMessages) { |
136 | 0 | this.addNestedKeys(masterKeyList, parent); |
137 | } | |
138 | ||
139 | 0 | for (String key : masterKeyList) { |
140 | 0 | if (displayErrorMessages) { |
141 | 0 | errors.addAll(getMessages(view, key, |
142 | messageMap.getErrorMessagesForProperty(key, true))); | |
143 | 0 | errorCount = errorCount + tempCount; |
144 | } | |
145 | 0 | if (displayWarningMessages) { |
146 | 0 | warnings.addAll(getMessages(view, key, |
147 | messageMap.getWarningMessagesForProperty(key, true))); | |
148 | 0 | warningCount = warningCount + tempCount; |
149 | } | |
150 | 0 | if (displayInfoMessages) { |
151 | 0 | infos.addAll(getMessages(view, key, |
152 | messageMap.getInfoMessagesForProperty(key, true))); | |
153 | 0 | infoCount = infoCount + tempCount; |
154 | } | |
155 | } | |
156 | 0 | } else if (displayFieldErrorIcon) { |
157 | // Checks to see if any errors exist for this field, if they do set | |
158 | // errorCount as positive | |
159 | // so the jsp will call the corresponding js to show the icon | |
160 | // messages do not need to be generated because they are not being shown | |
161 | 0 | for (String key : masterKeyList) { |
162 | 0 | if (!messageMap.getErrorMessagesForProperty(key, true) |
163 | .isEmpty()) { | |
164 | 0 | errorCount = 1; |
165 | 0 | break; |
166 | } | |
167 | } | |
168 | } | |
169 | ||
170 | //Check for errors that are not matched on the page(only applies when parent is page) | |
171 | 0 | if(parent instanceof PageGroup){ |
172 | 0 | if(errorCount < messageMap.getErrorCount()){ |
173 | 0 | List<String> diff = messageMap.getPropertiesWithErrors(); |
174 | 0 | diff.removeAll(masterKeyList); |
175 | 0 | for (String key : diff) { |
176 | 0 | errors.addAll(getMessages(view, key, |
177 | messageMap.getErrorMessagesForProperty(key, true))); | |
178 | 0 | errorCount = errorCount+ tempCount; |
179 | } | |
180 | ||
181 | } | |
182 | 0 | if(warningCount < messageMap.getWarningCount()){ |
183 | 0 | List<String> diff = messageMap.getPropertiesWithWarnings(); |
184 | 0 | diff.removeAll(masterKeyList); |
185 | 0 | for (String key : diff) { |
186 | 0 | warnings.addAll(getMessages(view, key, |
187 | messageMap.getWarningMessagesForProperty(key, true))); | |
188 | 0 | warningCount = warningCount + tempCount; |
189 | } | |
190 | } | |
191 | 0 | if(infoCount < messageMap.getInfoCount()){ |
192 | 0 | List<String> diff = messageMap.getPropertiesWithInfo(); |
193 | 0 | diff.removeAll(masterKeyList); |
194 | 0 | for (String key : diff) { |
195 | 0 | infos.addAll(getMessages(view, key, |
196 | messageMap.getInfoMessagesForProperty(key, true))); | |
197 | 0 | infoCount = infoCount + tempCount; |
198 | } | |
199 | } | |
200 | } | |
201 | ||
202 | // dont display anything if there are no messages | |
203 | 0 | if (errorCount + warningCount + infoCount == 0 || !displayMessages) { |
204 | 0 | this.setStyle("display: none;"); |
205 | } else { | |
206 | 0 | this.setStyle("display: visible"); |
207 | } | |
208 | 0 | } |
209 | ||
210 | /** | |
211 | * Gets all the messages from the list of lists passed in (which are | |
212 | * lists of ErrorMessages associated to the key) and uses the configuration | |
213 | * service to get the message String associated. This will also combine | |
214 | * error messages per a field if that option is turned on. If | |
215 | * displayFieldLabelWithMessages is turned on, it will also find the label | |
216 | * by key passed in. | |
217 | * | |
218 | * @param view | |
219 | * @param key | |
220 | * @param lists | |
221 | * @return | |
222 | */ | |
223 | private List<String> getMessages(View view, String key, | |
224 | List<AutoPopulatingList<ErrorMessage>> lists) { | |
225 | 0 | List<String> result = new ArrayList<String>(); |
226 | 0 | tempCount = 0; |
227 | 0 | for (List<ErrorMessage> errorList : lists) { |
228 | 0 | if (errorList != null && StringUtils.isNotBlank(key)) { |
229 | 0 | ConfigurationService configService = KNSServiceLocator |
230 | .getKualiConfigurationService(); | |
231 | 0 | String comboMessage = ""; |
232 | 0 | String label = ""; |
233 | ||
234 | 0 | for (ErrorMessage e : errorList) { |
235 | 0 | tempCount++; |
236 | 0 | String message = configService.getPropertyString(e |
237 | .getErrorKey()); | |
238 | 0 | if (e.getMessageParameters() != null) { |
239 | 0 | message = message.replace("'", "''"); |
240 | 0 | message = MessageFormat.format(message, |
241 | (Object[]) e.getMessageParameters()); | |
242 | } | |
243 | 0 | if (displayFieldLabelWithMessages) { |
244 | 0 | AttributeField field = view.getViewIndex() |
245 | .getAttributeFieldByPath(key); | |
246 | 0 | if (field != null && field.getLabel() != null) { |
247 | 0 | label = field.getLabel(); |
248 | } | |
249 | else{ | |
250 | 0 | label = key; |
251 | } | |
252 | } | |
253 | ||
254 | // adding them to combo string instead of the list | |
255 | 0 | if (combineMessages) { |
256 | 0 | if (comboMessage.isEmpty()) { |
257 | 0 | comboMessage = message; |
258 | } else { | |
259 | 0 | comboMessage = comboMessage + ", " + message; |
260 | } | |
261 | } else { | |
262 | // add it directly to the list - non combined messages | |
263 | 0 | if (StringUtils.isNotEmpty(label)) { |
264 | 0 | result.add(label + " - " + message); |
265 | } else { | |
266 | 0 | result.add(message); |
267 | } | |
268 | ||
269 | } | |
270 | 0 | } |
271 | // add the single combo string to the returned list | |
272 | // combineMessages will also be checked in the template to | |
273 | // further | |
274 | // combine them | |
275 | 0 | if (StringUtils.isNotEmpty(comboMessage)) { |
276 | 0 | if (StringUtils.isNotEmpty(label)) { |
277 | 0 | result.add(label + " - " + comboMessage); |
278 | } else { | |
279 | 0 | result.add(comboMessage); |
280 | } | |
281 | } | |
282 | 0 | } |
283 | } | |
284 | ||
285 | 0 | return result; |
286 | } | |
287 | ||
288 | /** | |
289 | * Gets all the keys associated to this ErrorsField. This includes the id of | |
290 | * the parent component, additional keys to match, and the bindingPath if | |
291 | * this is an ErrorsField for an AttributeField. These are the keys that are | |
292 | * used to match errors with their component and display them as part of its | |
293 | * ErrorsField. | |
294 | * | |
295 | * @return | |
296 | */ | |
297 | protected List<String> getKeys(Component parent) { | |
298 | 0 | List<String> keyList = new ArrayList<String>(); |
299 | 0 | if (additionalKeysToMatch != null) { |
300 | 0 | keyList.addAll(additionalKeysToMatch); |
301 | } | |
302 | 0 | if (StringUtils.isNotBlank(parent.getId())) { |
303 | 0 | keyList.add(parent.getId()); |
304 | } | |
305 | 0 | if (parent instanceof AttributeField) { |
306 | 0 | if (((AttributeField) parent).getBindingInfo() != null |
307 | && StringUtils.isNotEmpty(((AttributeField) parent) | |
308 | .getBindingInfo().getBindingPath())) { | |
309 | 0 | keyList.add(((AttributeField) parent).getBindingInfo() |
310 | .getBindingPath()); | |
311 | } | |
312 | } | |
313 | // Will there be additional components to check beyond AttributeField? | |
314 | ||
315 | 0 | return keyList; |
316 | } | |
317 | ||
318 | /** | |
319 | * Adds all the nestedKeys of this component by calling getKeys on each of | |
320 | * its nestedComponents' ErrorsFields and adding them to the list. If | |
321 | * allowMessageRepeat is false, it will also turn off error display for its | |
322 | * parent's nestedComponents' ErrorsFields. | |
323 | * | |
324 | * @param keyList | |
325 | * @param component | |
326 | */ | |
327 | private void addNestedKeys(List<String> keyList, Component component) { | |
328 | 0 | for (Component c : component.getNestedComponents()) { |
329 | 0 | ErrorsField ef = null; |
330 | 0 | if (c instanceof AttributeField) { |
331 | 0 | ef = ((AttributeField) c).getErrorsField(); |
332 | 0 | } else if (c instanceof ContainerBase) { |
333 | 0 | ef = ((ContainerBase) c).getErrorsField(); |
334 | } | |
335 | 0 | if (ef != null) { |
336 | 0 | if (!allowMessageRepeat) { |
337 | 0 | ef.setDisplayMessages(false); |
338 | } | |
339 | 0 | keyList.addAll(ef.getKeys(c)); |
340 | 0 | addNestedKeys(keyList, c); |
341 | } | |
342 | 0 | } |
343 | 0 | } |
344 | ||
345 | /** | |
346 | * ErrorTitle is the title that will be shown before any error | |
347 | * messages/error counts are displayed | |
348 | * | |
349 | * @return | |
350 | */ | |
351 | public String getErrorTitle() { | |
352 | 0 | return this.errorTitle; |
353 | } | |
354 | ||
355 | public void setErrorTitle(String errorTitle) { | |
356 | 0 | this.errorTitle = errorTitle; |
357 | 0 | } |
358 | ||
359 | /** | |
360 | * WarningTitle is the title that will be shown before any warning | |
361 | * messages/warning counts are displayed | |
362 | * | |
363 | * @return | |
364 | */ | |
365 | public String getWarningTitle() { | |
366 | 0 | return this.warningTitle; |
367 | } | |
368 | ||
369 | public void setWarningTitle(String warningTitle) { | |
370 | 0 | this.warningTitle = warningTitle; |
371 | 0 | } |
372 | ||
373 | /** | |
374 | * InfoTitle is the title that will be shown before any info messages/info | |
375 | * counts are displayed | |
376 | * | |
377 | * @return | |
378 | */ | |
379 | public String getInfoTitle() { | |
380 | 0 | return this.infoTitle; |
381 | } | |
382 | ||
383 | public void setInfoTitle(String infoTitle) { | |
384 | 0 | this.infoTitle = infoTitle; |
385 | 0 | } |
386 | ||
387 | /** | |
388 | * If displayErrorMessages is true, error messages will be displayed, | |
389 | * otherwise they will not. Unlike many of the options contained on | |
390 | * ErrorsField, this will not effect client side validations; ie this will | |
391 | * not turn off errorMessage display for client side validation, as it may | |
392 | * prevent a user from completing a form. To turn off client side validation | |
393 | * AND its messaging use the applyClientSide flag on the Constraint itself. | |
394 | * | |
395 | * TODO this may be changed to: if this is set on a field it will attempt | |
396 | * show client side validation errors in the closest parent container error | |
397 | * container | |
398 | * | |
399 | * @return | |
400 | */ | |
401 | public boolean isDisplayErrorMessages() { | |
402 | 0 | return this.displayErrorMessages; |
403 | } | |
404 | ||
405 | public void setDisplayErrorMessages(boolean displayErrorMessages) { | |
406 | 0 | this.displayErrorMessages = displayErrorMessages; |
407 | 0 | } |
408 | ||
409 | /** | |
410 | * If displayInfoMessages is true, info messages will be displayed, | |
411 | * otherwise they will not. Client side validation has no concept of warning | |
412 | * or info messages, so this will not effect client side functionality. | |
413 | * | |
414 | * @return | |
415 | */ | |
416 | public boolean isDisplayInfoMessages() { | |
417 | 0 | return this.displayInfoMessages; |
418 | } | |
419 | ||
420 | public void setDisplayInfoMessages(boolean displayInfoMessages) { | |
421 | 0 | this.displayInfoMessages = displayInfoMessages; |
422 | 0 | } |
423 | ||
424 | public boolean isDisplayLockMessages() { | |
425 | 0 | return this.displayLockMessages; |
426 | } | |
427 | ||
428 | /** | |
429 | * This has no use - needs to be removed(?) | |
430 | * | |
431 | * @param displayLockMessages | |
432 | */ | |
433 | public void setDisplayLockMessages(boolean displayLockMessages) { | |
434 | 0 | this.displayLockMessages = displayLockMessages; |
435 | 0 | } |
436 | ||
437 | /** | |
438 | * If displayWarningMessages is true, warning messages will be displayed, | |
439 | * otherwise they will not. Client side validation has no concept of warning | |
440 | * or info messages, so this will not effect client side functionality. | |
441 | * | |
442 | * @return | |
443 | */ | |
444 | public boolean isDisplayWarningMessages() { | |
445 | 0 | return this.displayWarningMessages; |
446 | } | |
447 | ||
448 | public void setDisplayWarningMessages(boolean displayWarningMessages) { | |
449 | 0 | this.displayWarningMessages = displayWarningMessages; |
450 | 0 | } |
451 | ||
452 | /** | |
453 | * AdditionalKeysToMatch is an additional list of keys outside of the | |
454 | * default keys that will be matched when messages are returned after a form | |
455 | * is submitted. These keys are only used for displaying messages generated | |
456 | * by the server and have no effect on client side validation error display. | |
457 | * | |
458 | * @return the additionalKeysToMatch | |
459 | */ | |
460 | public List<String> getAdditionalKeysToMatch() { | |
461 | 0 | return this.additionalKeysToMatch; |
462 | } | |
463 | ||
464 | /** | |
465 | * Convenience setter for additional keys to match that takes a string argument and | |
466 | * splits on comma to build the list | |
467 | * | |
468 | * @param additionalKeysToMatch String to parse | |
469 | */ | |
470 | public void setAdditionalKeysToMatch(String additionalKeysToMatch) { | |
471 | 0 | if (StringUtils.isNotBlank(additionalKeysToMatch)) { |
472 | 0 | this.additionalKeysToMatch = Arrays.asList(StringUtils.split(additionalKeysToMatch, ",")); |
473 | } | |
474 | 0 | } |
475 | ||
476 | /** | |
477 | * @param additionalKeysToMatch | |
478 | * the additionalKeysToMatch to set | |
479 | */ | |
480 | public void setAdditionalKeysToMatch(List<String> additionalKeysToMatch) { | |
481 | 0 | this.additionalKeysToMatch = additionalKeysToMatch; |
482 | 0 | } |
483 | ||
484 | /** | |
485 | * If true, the errorTitle set on this ErrorsField will be displayed along | |
486 | * with the error messages. Otherwise, the title will not be displayed. | |
487 | * | |
488 | * @return the displayErrorTitle | |
489 | */ | |
490 | public boolean isDisplayErrorTitle() { | |
491 | 0 | return this.displayErrorTitle; |
492 | } | |
493 | ||
494 | /** | |
495 | * @param displayErrorTitle | |
496 | * the displayErrorTitle to set | |
497 | */ | |
498 | public void setDisplayErrorTitle(boolean displayErrorTitle) { | |
499 | 0 | this.displayErrorTitle = displayErrorTitle; |
500 | 0 | } |
501 | ||
502 | /** | |
503 | * If true, the warningTitle set on this ErrorsField will be displayed along | |
504 | * with the warning messages. Otherwise, the title will not be displayed. | |
505 | * | |
506 | * @return the displayWarningTitle | |
507 | */ | |
508 | public boolean isDisplayWarningTitle() { | |
509 | 0 | return this.displayWarningTitle; |
510 | } | |
511 | ||
512 | /** | |
513 | * @param displayWarningTitle | |
514 | * the displayWarningTitle to set | |
515 | */ | |
516 | public void setDisplayWarningTitle(boolean displayWarningTitle) { | |
517 | 0 | this.displayWarningTitle = displayWarningTitle; |
518 | 0 | } |
519 | ||
520 | /** | |
521 | * If true, the infoTitle set on this ErrorsField will be displayed along | |
522 | * with the info messages. Otherwise, the title will not be displayed. | |
523 | * | |
524 | * @return the displayInfoTitle | |
525 | */ | |
526 | public boolean isDisplayInfoTitle() { | |
527 | 0 | return this.displayInfoTitle; |
528 | } | |
529 | ||
530 | /** | |
531 | * @param displayInfoTitle | |
532 | * the displayInfoTitle to set | |
533 | */ | |
534 | public void setDisplayInfoTitle(boolean displayInfoTitle) { | |
535 | 0 | this.displayInfoTitle = displayInfoTitle; |
536 | 0 | } |
537 | ||
538 | /** | |
539 | * If true, the error messages will display the an AttributeField's title | |
540 | * alongside the error, warning, and info messages related to it. This | |
541 | * setting has no effect on messages which do not relate directly to a | |
542 | * single AttributeField. | |
543 | * | |
544 | * @return the displayFieldLabelWithMessages | |
545 | */ | |
546 | public boolean isDisplayFieldLabelWithMessages() { | |
547 | 0 | return this.displayFieldLabelWithMessages; |
548 | } | |
549 | ||
550 | /** | |
551 | * @param displayFieldLabelWithMessages | |
552 | * the displayFieldLabelWithMessages to set | |
553 | */ | |
554 | public void setDisplayFieldLabelWithMessages( | |
555 | boolean displayFieldLabelWithMessages) { | |
556 | 0 | this.displayFieldLabelWithMessages = displayFieldLabelWithMessages; |
557 | 0 | } |
558 | ||
559 | /** | |
560 | * If true, error, warning, and info messages will be displayed (provided | |
561 | * they are also set to display). Otherwise, no messages for this | |
562 | * ErrorsField container will be displayed (including ones set to display). | |
563 | * This is a global display on/off switch for all messages. | |
564 | * | |
565 | * @return the displayMessages | |
566 | */ | |
567 | public boolean isDisplayMessages() { | |
568 | 0 | return this.displayMessages; |
569 | } | |
570 | ||
571 | /** | |
572 | * @param displayMessages | |
573 | * the displayMessages to set | |
574 | */ | |
575 | public void setDisplayMessages(boolean displayMessages) { | |
576 | 0 | this.displayMessages = displayMessages; |
577 | 0 | } |
578 | ||
579 | /** | |
580 | * If true, this ErrorsField will show messages related to the nested | |
581 | * components of its parent component, and not just those related only to | |
582 | * its parent component. Otherwise, it will be up to the individual | |
583 | * components to display their messages, if any, in their ErrorsField. | |
584 | * | |
585 | * @return the displayNestedMessages | |
586 | */ | |
587 | public boolean isDisplayNestedMessages() { | |
588 | 0 | return this.displayNestedMessages; |
589 | } | |
590 | ||
591 | /** | |
592 | * @param displayNestedMessages | |
593 | * the displayNestedMessages to set | |
594 | */ | |
595 | public void setDisplayNestedMessages(boolean displayNestedMessages) { | |
596 | 0 | this.displayNestedMessages = displayNestedMessages; |
597 | 0 | } |
598 | ||
599 | /** | |
600 | * Combines the messages for a single key into one concatenated message per | |
601 | * key being matched, seperated by a comma | |
602 | * | |
603 | * @return the combineMessages | |
604 | */ | |
605 | public boolean isCombineMessages() { | |
606 | 0 | return this.combineMessages; |
607 | } | |
608 | ||
609 | /** | |
610 | * @param combineMessages | |
611 | * the combineMessages to set | |
612 | */ | |
613 | public void setCombineMessages(boolean combineMessages) { | |
614 | 0 | this.combineMessages = combineMessages; |
615 | 0 | } |
616 | ||
617 | /** | |
618 | * If true, when this is set on an ErrorsField whose parentComponent has | |
619 | * nested Containers or AttributeFields, it will allow those fields to also | |
620 | * show their ErrorsField messages. Otherwise, it will turn off the the | |
621 | * display of those messages. This can be used to avoid repeating | |
622 | * information to the user per field, if errors are already being displayed | |
623 | * at the parent's level. This flag has no effect if displayNestedMessages | |
624 | * is false on this ErrorsField. | |
625 | * | |
626 | * @return the allowMessageRepeat | |
627 | */ | |
628 | public boolean isAllowMessageRepeat() { | |
629 | 0 | return this.allowMessageRepeat; |
630 | } | |
631 | ||
632 | /** | |
633 | * | |
634 | * @param allowMessageRepeat | |
635 | * the allowMessageRepeat to set | |
636 | */ | |
637 | public void setAllowMessageRepeat(boolean allowMessageRepeat) { | |
638 | 0 | this.allowMessageRepeat = allowMessageRepeat; |
639 | 0 | } |
640 | ||
641 | /** | |
642 | * displayCounts is true if the counts of errors, warning, and info messages | |
643 | * within this ErrorsField should be displayed (includes count of nested | |
644 | * messages if displayNestedMessages is true). | |
645 | * | |
646 | * @return | |
647 | */ | |
648 | public boolean isDisplayCounts() { | |
649 | 0 | return this.displayCounts; |
650 | } | |
651 | ||
652 | /** | |
653 | * @param displayCounts | |
654 | * the displayCounts to set | |
655 | */ | |
656 | public void setDisplayCounts(boolean displayCounts) { | |
657 | 0 | this.displayCounts = displayCounts; |
658 | 0 | } |
659 | ||
660 | /** | |
661 | * The list of error messages found for the keys that were matched on this | |
662 | * ErrorsField This is generated and cannot be set | |
663 | * | |
664 | * @return the errors | |
665 | */ | |
666 | public List<String> getErrors() { | |
667 | 0 | return this.errors; |
668 | } | |
669 | ||
670 | /** | |
671 | * The list of warning messages found for the keys that were matched on this | |
672 | * ErrorsField This is generated and cannot be set | |
673 | * | |
674 | * @return the warnings | |
675 | */ | |
676 | public List<String> getWarnings() { | |
677 | 0 | return this.warnings; |
678 | } | |
679 | ||
680 | /** | |
681 | * The list of info messages found for the keys that were matched on this | |
682 | * ErrorsField This is generated and cannot be set | |
683 | * | |
684 | * @return the infos | |
685 | */ | |
686 | public List<String> getInfos() { | |
687 | 0 | return this.infos; |
688 | } | |
689 | ||
690 | /** | |
691 | * The count of error messages found for the keys that were matched on this | |
692 | * ErrorsField This is generated and cannot be set | |
693 | * | |
694 | * @return the errorCount | |
695 | */ | |
696 | public int getErrorCount() { | |
697 | 0 | return this.errorCount; |
698 | } | |
699 | ||
700 | /** | |
701 | * The count of warning messages found for the keys that were matched on | |
702 | * this ErrorsField This is generated and cannot be set | |
703 | * | |
704 | * @return the warningCount | |
705 | */ | |
706 | public int getWarningCount() { | |
707 | 0 | return this.warningCount; |
708 | } | |
709 | ||
710 | /** | |
711 | * The count of info messages found for the keys that were matched on this | |
712 | * ErrorsField This is generated and cannot be set | |
713 | * | |
714 | * @return the infoCount | |
715 | */ | |
716 | public int getInfoCount() { | |
717 | 0 | return this.infoCount; |
718 | } | |
719 | ||
720 | /** | |
721 | * If this is true, the display of messages is being handled by another | |
722 | * container. The ErrorsField html generated by the jsp will still be used, | |
723 | * but it will be placed in different location within the page than the | |
724 | * default to accommodate an alternate layout. This flag is used by | |
725 | * BoxLayoutManager. | |
726 | * | |
727 | * This flag only applies to ErrorsFields whose parentComponents are | |
728 | * AttributeFields. | |
729 | * | |
730 | * @return the alternateContainer | |
731 | */ | |
732 | public boolean isAlternateContainer() { | |
733 | 0 | return this.alternateContainer; |
734 | } | |
735 | ||
736 | /** | |
737 | * @param alternateContainer | |
738 | * the alternateContainer to set | |
739 | */ | |
740 | public void setAlternateContainer(boolean alternateContainer) { | |
741 | 0 | this.alternateContainer = alternateContainer; |
742 | 0 | } |
743 | ||
744 | /** | |
745 | * If true, displays an icon next to each field that has an error (default | |
746 | * KNS look). Otherwise, this icon will not be displayed. Note that any icon | |
747 | * set through css for the message containers will still appear and this | |
748 | * only relates to the icon directly to the right of an input field. | |
749 | * | |
750 | * This flag should only be set on AttributeField ErrorsFields. | |
751 | * | |
752 | * @return the displayFieldErrorIcon | |
753 | */ | |
754 | public boolean isDisplayFieldErrorIcon() { | |
755 | 0 | return this.displayFieldErrorIcon; |
756 | } | |
757 | ||
758 | /** | |
759 | * @param displayFieldErrorIcon | |
760 | * the displayFieldErrorIcon to set | |
761 | */ | |
762 | public void setDisplayFieldErrorIcon(boolean displayFieldErrorIcon) { | |
763 | 0 | this.displayFieldErrorIcon = displayFieldErrorIcon; |
764 | 0 | } |
765 | ||
766 | /** | |
767 | * If true, highlights the parentComponent's container when it has an | |
768 | * error/warning/info. Otherwise, this highlighting will not be displayed. | |
769 | * Note that the css can be changed per a type of highlighting, if showing a | |
770 | * different color or no color per type of message is desired. | |
771 | * | |
772 | * @return the highlightOnError | |
773 | */ | |
774 | public void setHighlightOnError(boolean highlightOnError) { | |
775 | 0 | this.highlightOnError = highlightOnError; |
776 | 0 | } |
777 | ||
778 | /** | |
779 | * @return the highlightOnError | |
780 | */ | |
781 | public boolean isHighlightOnError() { | |
782 | 0 | return highlightOnError; |
783 | } | |
784 | ||
785 | } |