1 /** 2 * Copyright 2005-2016 The Kuali Foundation 3 * 4 * Licensed under the Educational Community License, Version 2.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/ecl2.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.krad.uif.component; 17 18 import org.kuali.rice.krad.datadictionary.uif.UifDictionaryBean; 19 import org.kuali.rice.krad.datadictionary.validator.ValidationTrace; 20 import org.kuali.rice.krad.uif.layout.CssGridSizes; 21 import org.kuali.rice.krad.uif.lifecycle.RunComponentModifiersTask; 22 import org.kuali.rice.krad.uif.lifecycle.ViewLifecycleUtils; 23 import org.kuali.rice.krad.uif.modifier.ComponentModifier; 24 import org.kuali.rice.krad.uif.util.LifecycleElement; 25 import org.kuali.rice.krad.uif.widget.Tooltip; 26 27 import java.io.Serializable; 28 import java.util.List; 29 import java.util.Map; 30 31 /** 32 * Component defines basic properties and methods that all rendering element implement 33 * 34 * <p> 35 * All classes of the UIF that are used as a rendering element implement the 36 * component interface. All components within the framework have the 37 * following structure: 38 * <ul> 39 * <li>Dictionary Configuration/Composition</li> 40 * <li>Java Class (the Component implementation</li> 41 * <li>>JSP Template Renderer</li> 42 * </ul> 43 * </p> 44 * <p> 45 * There are three basic types of components: 46 * <ul> 47 * <li>Container Components: {@code View}, {@code Group}</li> 48 * <li>Field Components: {@code Field}</li> 49 * <li>Widget Components: {@code Widget}</li> 50 * </ul> 51 * </p> 52 * 53 * @author Kuali Rice Team (rice.collab@kuali.org) 54 * @see org.kuali.rice.krad.uif.container.Container 55 * @see org.kuali.rice.krad.uif.field.Field 56 * @see org.kuali.rice.krad.uif.widget.Widget 57 */ 58 public interface Component extends UifDictionaryBean, LifecycleElement, Serializable, Ordered, ScriptEventSupport { 59 60 /** 61 * The name for the component type 62 * 63 * <p> 64 * This is used within the rendering layer to pass the component instance into the template. The component instance 65 * is exported under the name given by this method. 66 * </p> 67 * 68 * @return String type name 69 */ 70 String getComponentTypeName(); 71 72 /** 73 * Indicates whether the component has been fully rendered. 74 * 75 * @return True if the component has fully rendered, false if not. 76 */ 77 boolean isRendered(); 78 79 /** 80 * Invoked by the view lifecycle after expressions are evaluated at the apply model phase. 81 * 82 * <p> 83 * In general, this method is preferred to {@link #performApplyModel(Object, LifecycleElement)} 84 * for populating model data via code, since it is called before client-side state is synchronize. 85 * </p> 86 */ 87 void afterEvaluateExpression(); 88 89 /** 90 * Set the view lifecycle processing status for this component, explicitly. 91 * 92 * @param status The view status for this component. 93 */ 94 void setViewStatus(String status); 95 96 /** 97 * The path to the JSP file that should be called to render the component 98 * 99 * <p> 100 * The path should be relative to the web root. An attribute will be available to the component to use under the 101 * name given by the method {@code getComponentTypeName}. Based on the component type, additional attributes could 102 * be available for use. See the component documentation for more information on such attributes. 103 * </p> 104 * 105 * <p> 106 * e.g. '/krad/WEB-INF/jsp/tiles/component.jsp' 107 * </p> 108 * 109 * @return String representing the template path 110 */ 111 String getTemplate(); 112 113 /** 114 * Setter for the components template 115 * 116 * @param template 117 */ 118 void setTemplate(String template); 119 120 /** 121 * Gets additional templates that will be required during the rendering of this component. 122 * 123 * <p> 124 * If a parent or sibling component is referred to by this component's template, 125 * include that component's template here to ensure that it has been compiled already during 126 * bottom-up inline rendering. 127 * </p> 128 * 129 * @return additional templates required during rendering 130 */ 131 List<String> getAdditionalTemplates(); 132 133 /** 134 * The name for which the template can be invoked by 135 * 136 * <p> 137 * Whether the template name is needed depends on the underlying rendering engine being used. In the example of 138 * Freemarker, the template points to the actual source file, which then loads a macro. From then on the macro is 139 * simply invoked to execute the template 140 * </p> 141 * 142 * <p> 143 * e.g. 'uif_text' 144 * </p> 145 * 146 * @return template name 147 */ 148 public String getTemplateName(); 149 150 /** 151 * Setter for the name of the template (a name which can be used to invoke) 152 * 153 * @param templateName 154 */ 155 public void setTemplateName(String templateName); 156 157 /** 158 * The component title 159 * 160 * <p> 161 * Depending on the component can be used in various ways. For example with a Container component the title is 162 * used to set the header text. For components like controls other other components that render an HTML element it 163 * is used to set the HTML title attribute. 164 * </p> 165 * 166 * @return String title for component 167 */ 168 String getTitle(); 169 170 /** 171 * Setter for the component's title 172 * 173 * @param title 174 */ 175 void setTitle(String title); 176 177 /** 178 * List of components that are contained within the List of {@code PropertyReplacer} in component 179 * 180 * <p> 181 * Used to get all the nested components in the property replacers. 182 * </p> 183 * 184 * @return List<Component> {@code PropertyReplacer} child components 185 */ 186 List<Component> getPropertyReplacerComponents(); 187 188 /** 189 * {@code ComponentModifier} instances that should be invoked to 190 * initialize the component 191 * 192 * <p> 193 * These provide dynamic initialization behavior for the component and are 194 * configured through the components definition. Each initializer will get 195 * invoked by the initialize method. 196 * </p> 197 * 198 * @return List of component modifiers 199 * @see RunComponentModifiersTask 200 */ 201 List<ComponentModifier> getComponentModifiers(); 202 203 /** 204 * Setter for the components List of {@code ComponentModifier} 205 * instances 206 * 207 * @param componentModifiers 208 */ 209 void setComponentModifiers(List<ComponentModifier> componentModifiers); 210 211 /** 212 * When true, this component will render as a placeholder component instead of rendering normally because the 213 * content will be later retrieved through manually ajax retrieval calls in the js 214 * 215 * <p>This flag does not imply any automation, there must be a js call invoked for the content to be retrieved 216 * by the server, but this does mark it with a placeholder component which KRAD js uses during these calls. 217 * This placeholder component is used for ajax retrievals. In particular, this flag is useful for use in 218 * combination with the <b>showLightboxComponent</b> js function which will automatically retrieve the 219 * real content of a component through ajax if a placeholder component is detected. This allows for the full 220 * content to only be retrieved when the lightbox is first opened. 221 * When this flag is set to true, the forceSessionPersistence 222 * flag is set to true AUTOMATICALLY because it is implied that this component will be retrieved by an ajax call 223 * in the future. This may also be useful for direct custom calls to <b>retrieveComponent</b> function, 224 * as well, which also relies on the placeholder being present.</p> 225 * 226 * @return true if this component is being rendered as a placeholder for use in replacement during and ajax call, 227 * false otherwise 228 */ 229 public boolean isRetrieveViaAjax(); 230 231 /** 232 * When true, this component will render as a placeholder component instead of rendering normally because the 233 * content will be later retrieved through manually ajax retrieval calls in the js 234 * 235 * @param useAjaxCallForContent 236 */ 237 public void setRetrieveViaAjax(boolean useAjaxCallForContent); 238 239 /** 240 * Indicates whether the component should be hidden in the UI 241 * 242 * <p> 243 * How the hidden data is maintained depends on the views persistence mode. 244 * If the mode is request, the corresponding data will be rendered to the UI 245 * but not visible. If the mode is session, the data will not be rendered to 246 * the UI but maintained server side. 247 * </p> 248 * 249 * <p> 250 * For a {@code Container} component, the hidden setting will apply to 251 * all contained components (making a section hidden makes all fields within 252 * the section hidden) 253 * </p> 254 * 255 * @return boolean true if the component should be hidden, false if it 256 * should be visible 257 */ 258 boolean isHidden(); 259 260 /** 261 * Setter for the hidden indicator 262 * 263 * @param hidden 264 */ 265 void setHidden(boolean hidden); 266 267 /** 268 * Indicates whether the component can be edited 269 * 270 * <p> 271 * When readOnly the controls and widgets of {@code Field} components 272 * will not be rendered. If the Field has an underlying value it will be 273 * displayed readOnly to the user. 274 * </p> 275 * 276 * <p> 277 * For a {@code Container} component, the readOnly setting will apply 278 * to all contained components (making a section readOnly makes all fields 279 * within the section readOnly). 280 * </p> 281 * 282 * @return boolean true if the component should be readOnly, false if is 283 * allows editing 284 */ 285 Boolean getReadOnly(); 286 287 /** 288 * Setter for the read only indicator 289 * 290 * @param readOnly 291 */ 292 void setReadOnly(Boolean readOnly); 293 294 /** 295 * Indicates whether the component should be cleared on copy 296 * 297 * <p> 298 * By default this property is false. ReadOnly components are cleared on a copy operation. 299 * If set this prevents the component from being cleared. 300 * </p> 301 * @return 302 */ 303 Boolean getCanCopyOnReadOnly(); 304 305 /** 306 * Setter for the canCopyOnReadOnly indicator 307 * 308 * @param canCopyOnReadOnly 309 */ 310 void setCanCopyOnReadOnly(Boolean canCopyOnReadOnly); 311 /** 312 * Indicates whether the component is required 313 * 314 * <p> 315 * At the general component level required means there is some action the 316 * user needs to take within the component. For example, within a section it 317 * might mean the fields within the section should be completed. At a field 318 * level, it means the field should be completed. This provides the ability 319 * for the renderers to indicate the required action. 320 * </p> 321 * 322 * @return boolean true if the component is required, false if it is not 323 * required 324 */ 325 Boolean getRequired(); 326 327 /** 328 * Setter for the required indicator 329 * 330 * @param required 331 */ 332 void setRequired(Boolean required); 333 334 /** 335 * Horizontal alignment of the component within its container 336 * 337 * <p> 338 * All components belong to a <code>Container</code> and are placed using a 339 * <code>LayoutManager</code>. This property specifies how the component 340 * should be aligned horizontally within the container. During the finalize 341 * phase the CSS text-align style will be created for the align setting. 342 * </p> 343 * 344 * @return String horizontal align 345 * @see org.kuali.rice.krad.uif.CssConstants.TextAligns 346 */ 347 public String getAlign(); 348 349 /** 350 * Sets the components horizontal alignment 351 * 352 * @param align 353 */ 354 public void setAlign(String align); 355 356 /** 357 * Vertical alignment of the component within its container 358 * 359 * <p> 360 * All components belong to a <code>Container</code> and are placed using a 361 * <code>LayoutManager</code>. This property specifies how the component 362 * should be aligned vertically within the container. During the finalize 363 * phase the CSS vertical-align style will be created for the valign 364 * setting. 365 * </p> 366 * 367 * @return String vertical align 368 * @see org.kuali.rice.krad.uif.CssConstants.VerticalAligns 369 */ 370 public String getValign(); 371 372 /** 373 * Setter for the component's vertical align 374 * 375 * @param valign 376 */ 377 public void setValign(String valign); 378 379 /** 380 * Width the component should take up in the container 381 * 382 * <p> 383 * All components belong to a <code>Container</code> and are placed using a 384 * <code>LayoutManager</code>. This property specifies a width the component 385 * should take up in the Container. This is not applicable for all layout 386 * managers. During the finalize phase the CSS width style will be created 387 * for the width setting. 388 * </p> 389 * 390 * <p> 391 * e.g. '30%', '55px' 392 * </p> 393 * 394 * @return String width string 395 */ 396 public String getWidth(); 397 398 /** 399 * Setter for the components width 400 * 401 * @param width 402 */ 403 public void setWidth(String width); 404 405 /** 406 * CSS style string to be applied to the component 407 * 408 * <p> 409 * Any style override or additions can be specified with this attribute. 410 * This is used by the renderer to set the style attribute on the 411 * corresponding element. 412 * </p> 413 * 414 * <p> 415 * e.g. 'color: #000000;text-decoration: underline;' 416 * </p> 417 * 418 * @return String css style string 419 */ 420 String getStyle(); 421 422 /** 423 * Setter for the components style 424 * 425 * @param style 426 */ 427 void setStyle(String style); 428 429 public List<String> getLibraryCssClasses(); 430 431 public void setLibraryCssClasses(List<String> libraryCssClasses); 432 433 /** 434 * CSS style class(s) to be applied to the component 435 * 436 * <p> 437 * Declares style classes for the component. Multiple classes are specified 438 * with a space delimiter. This is used by the renderer to set the class 439 * attribute on the corresponding element. The class(s) declared must be 440 * available in the common style sheets or the style sheets specified for 441 * the view 442 * </p> 443 * 444 * @return List<String> css style classes to appear on the 'class' attribute 445 */ 446 List<String> getCssClasses(); 447 448 /** 449 * Setter for the components style classes 450 * 451 * @param styleClasses 452 */ 453 void setCssClasses(List<String> styleClasses); 454 455 /** 456 * Convenience property for adding css class names to the end of the list of cssClasses that may already exist on 457 * this Component (this is to avoid explicitly having to set list merge in the bean definition) 458 * 459 * @return the additionalCssClasses 460 */ 461 List<String> getAdditionalCssClasses(); 462 463 /** 464 * Set the additionalCssClasses 465 * 466 * @param styleClasses 467 */ 468 void setAdditionalCssClasses(List<String> styleClasses); 469 470 /** 471 * Adds a single style to the list of styles on this component 472 * 473 * @param styleClass 474 */ 475 void addStyleClass(String styleClass); 476 477 /** 478 * Appends to the inline style set on a component 479 * 480 * @param itemStyle 481 */ 482 void appendToStyle(String itemStyle); 483 484 /** 485 * Number of places the component should take up horizontally in the 486 * container; when using a CssGridLayoutManager this is converted to the appropriate medium size. 487 * 488 * <p> 489 * All components belong to a {@code Container} and are placed using a 490 * {@code LayoutManager}. This property specifies how many places 491 * horizontally the component should take up within the container. This is 492 * only applicable for table based layout managers. Default is 1 493 * </p> 494 * 495 * TODO: this should not be on component interface since it only applies if 496 * the layout manager supports it, need some sort of layoutOptions map for 497 * field level options that depend on the manager 498 * 499 * @return int number of columns to span 500 */ 501 int getColSpan(); 502 503 /** 504 * Setter for the components column span 505 * 506 * @param colSpan 507 */ 508 void setColSpan(int colSpan); 509 510 /** 511 * Number of places the component should take up vertically in the container 512 * 513 * <p> 514 * All components belong to a {@code Container} and are placed using a 515 * {@code LayoutManager}. This property specifies how many places 516 * vertically the component should take up within the container. This is 517 * only applicable for table based layout managers. Default is 1 518 * </p> 519 * 520 * TODO: this should not be on component interface since it only applies if 521 * the layout manager supports it, need some sort of layoutOptions map for 522 * field level options that depend on the manager 523 * 524 * @return int number of rows to span 525 */ 526 int getRowSpan(); 527 528 /** 529 * Setter for the component row span 530 * 531 * @param rowSpan 532 */ 533 void setRowSpan(int rowSpan); 534 535 /** 536 * The cellCssClasses property defines the classes that will be placed on the corresponding td (or th) elements 537 * relating to this component when used in a table backed layout. This property has no effect on other layouts. 538 * 539 * @return the css classes to apply to the wrapping td (or th) element for this component 540 */ 541 public List<String> getWrapperCssClasses(); 542 543 /** 544 * Set the cellCssClasses property which defines the classes that will be placed on the corresponding td (or th) 545 * relating to this component when used in a table backed layout. This property has no effect on other layouts. 546 * 547 * @param cellCssClasses 548 */ 549 public void setWrapperCssClasses(List<String> cellCssClasses); 550 551 /** 552 * Add a cell css class to the cell classes list 553 * 554 * @param cssClass the name of the class to add 555 */ 556 public void addWrapperCssClass(String cssClass); 557 558 /** 559 * CSS style string to be applied to the cell containing the component (only applies within 560 * table based layouts) 561 * 562 * <p> 563 * e.g. 'align: right;' 564 * </p> 565 * 566 * @return String css style string 567 */ 568 public String getWrapperStyle(); 569 570 /** 571 * Setter for the cell style attribute 572 * 573 * @param cellStyle 574 */ 575 public void setWrapperStyle(String cellStyle); 576 577 /** 578 * Width setting for the cell containing the component (only applies within table based 579 * layouts) 580 * 581 * @return String width ('25%', '155px') 582 */ 583 public String getCellWidth(); 584 585 /** 586 * Setter for the containing cell width 587 * 588 * @param cellWidth 589 */ 590 public void setCellWidth(String cellWidth); 591 592 /** 593 * CssGridSizes represent the size (width) the content's div "cell" will take up in the "row" at each screen 594 * size (extra small, small, medium, large) when using a group backed by a CssGridLayoutManager. 595 * 596 * <p> 597 * This object is NOT used by other layouts. 598 * For specifics of how css grids work, refer to the krad guide and bootstrap css grid documentation. 599 * </p> 600 * 601 * @return 602 */ 603 public CssGridSizes getCssGridSizes(); 604 605 /** 606 * @see org.kuali.rice.krad.uif.component.Component#getCssGridSizes() 607 */ 608 public void setCssGridSizes(CssGridSizes cssGridSizes); 609 610 /** 611 * Context map for the component 612 * 613 * <p> 614 * Any el statements configured for the components properties (e.g. 615 * title="@{foo.property}") are evaluated using the el context map. This map 616 * will get populated with default objects like the model, view, and request 617 * from the {@code ViewHelperService}. Other components can push 618 * further objects into the context so that they are available for use with 619 * that component. For example, {@code Field} instances that are part 620 * of a collection line as receive the current line instance 621 * </p> 622 * 623 * <p> 624 * Context map also provides objects to methods that are invoked for 625 * {@code GeneratedField} instances 626 * </p> 627 * 628 * <p> 629 * The Map key gives the name of the variable that can be used within 630 * expressions, and the Map value gives the object instance for which 631 * expressions containing the variable should evaluate against 632 * </p> 633 * 634 * <p> 635 * NOTE: Calling getContext().putAll() will skip updating any configured property replacers for the 636 * component. Instead you should call #pushAllToContextDeep 637 * </p> 638 * 639 * @return Map<String, Object> context 640 */ 641 Map<String, Object> getContext(); 642 643 /** 644 * Setter for the context Map 645 * 646 * @param context 647 */ 648 void setContext(Map<String, Object> context); 649 650 /** 651 * gets a list of {@code PropertyReplacer} instances 652 * 653 * <p>They will be evaluated 654 * during the view lifecycle to conditionally set properties on the 655 * {@code Component} based on expression evaluations</p> 656 * 657 * @return List<PropertyReplacer> replacers to evaluate 658 */ 659 List<PropertyReplacer> getPropertyReplacers(); 660 661 /** 662 * Setter for the components property substitutions 663 * 664 * @param propertyReplacers 665 */ 666 void setPropertyReplacers(List<PropertyReplacer> propertyReplacers); 667 668 /** 669 * The options that are passed through to the Component renderer 670 * 671 * <p> 672 * The Map key is the option name, with the Map value as the option value. See 673 * documentation on the particular widget render for available options. 674 * </p> 675 * 676 * @return Map<String, String> options 677 */ 678 Map<String, String> getTemplateOptions(); 679 680 /** 681 * Setter for the template's options 682 * 683 * @param templateOptions 684 */ 685 void setTemplateOptions(Map<String, String> templateOptions); 686 687 /** 688 * Builds a string from the underlying <code>Map</code> of template options that will export that options as a 689 * JavaScript Map for use in js and jQuery plugins 690 * 691 * <p> 692 * See documentation on the particular component render for available options. 693 * </p> 694 * 695 * @return String options 696 */ 697 String getTemplateOptionsJSString(); 698 699 /** 700 * Setter for the template's options 701 * 702 * @param templateOptionsJSString 703 */ 704 void setTemplateOptionsJSString(String templateOptionsJSString); 705 706 /** 707 * Order of a component within a List of other components 708 * 709 * <p>Lower numbers are placed higher up in the list, while higher numbers are placed 710 * lower in the list</p> 711 * 712 * @return int ordering number 713 * @see org.springframework.core.Ordered#getOrder() 714 */ 715 int getOrder(); 716 717 /** 718 * Setter for the component's order 719 * 720 * @param order 721 */ 722 void setOrder(int order); 723 724 /** 725 * The Tooltip widget that renders a tooltip with additional information about the element on 726 * specified trigger event 727 * 728 * @return Tooltip 729 */ 730 Tooltip getToolTip(); 731 732 /** 733 * Setter for the component tooltip widget instance 734 * 735 * @param toolTip 736 */ 737 void setToolTip(Tooltip toolTip); 738 739 /** 740 * String containing JavaScript code for registering event handlers for this component 741 * (blur, focus, click, etc.) 742 * 743 * @return JS event handler script 744 */ 745 public String getEventHandlerScript(); 746 747 /** 748 * The name of the method that should be invoked for finalizing the component 749 * configuration (full method name, without parameters or return type) 750 * 751 * <p> 752 * Note the method can also be set with the finalizeMethodInvoker 753 * targetMethod property. If the method is on the configured 754 * {@code ViewHelperService}, only this property needs to be configured 755 * </p> 756 * 757 * <p> 758 * The model backing the view will be passed as the first argument method and then 759 * the {@code Component} instance as the second argument. If any additional method 760 * arguments are declared with the finalizeMethodAdditionalArguments, they will then 761 * be passed in the order declared in the list 762 * </p> 763 * 764 * <p> 765 * If the component is selfRendered, the finalize method can return a string which 766 * will be set as the component's renderOutput. The selfRendered indicator will also 767 * be set to true on the component. 768 * </p> 769 * 770 * @return String method name 771 */ 772 String getFinalizeMethodToCall(); 773 774 /** 775 * The List of Object instances that should be passed as arguments to the finalize method 776 * 777 * <p> 778 * These arguments are passed to the finalize method after the standard model and component 779 * arguments. They are passed in the order declared in the list 780 * </p> 781 * 782 * @return List<Object> additional method arguments 783 */ 784 List<Object> getFinalizeMethodAdditionalArguments(); 785 786 /** 787 * {@code MethodInvokerConfig} instance for the method that should be invoked 788 * for finalizing the component configuration 789 * 790 * <p> 791 * MethodInvoker can be configured to specify the class or object the method 792 * should be called on. For static method invocations, the targetClass 793 * property can be configured. For object invocations, that targetObject 794 * property can be configured 795 * </p> 796 * 797 * <p> 798 * If the component is selfRendered, the finalize method can return a string which 799 * will be set as the component's renderOutput. The selfRendered indicator will also 800 * be set to true on the component. 801 * </p> 802 * 803 * @return MethodInvokerConfig instance 804 */ 805 MethodInvokerConfig getFinalizeMethodInvoker(); 806 807 /** 808 * Indicates whether the component contains its own render output (through 809 * the renderOutput property) 810 * 811 * <p> 812 * If self rendered is true, the corresponding template for the component 813 * will not be invoked and the renderOutput String will be written to the 814 * response as is. 815 * </p> 816 * 817 * @return boolean true if component is self rendered, false if not (renders 818 * through template) 819 */ 820 boolean isSelfRendered(); 821 822 /** 823 * Setter for the self render indicator 824 * 825 * @param selfRendered 826 */ 827 void setSelfRendered(boolean selfRendered); 828 829 /** 830 * Rendering output for the component that will be sent as part of the 831 * response (can contain static text and HTML) 832 * 833 * @return String render output 834 */ 835 String getRenderedHtmlOutput(); 836 837 /** 838 * Setter for the component's render output 839 * 840 * @param renderOutput 841 */ 842 void setRenderedHtmlOutput(String renderOutput); 843 844 /** 845 * Disables the storage of the component in session (when the framework determines it needs to be due to a 846 * refresh condition) 847 * 848 * <p> 849 * When the framework determines there is a condition on the component that requires it to keep around between 850 * posts, it will store the component instance in session. This flag can be set to disable this behavior (which 851 * would require custom application logic to support behavior such as refresh) 852 * </p> 853 * 854 * @return boolean true if the component should not be stored in session, false if session storage is allowed 855 */ 856 boolean isDisableSessionPersistence(); 857 858 /** 859 * Setter for disabling storage of the component in session 860 * 861 * @param disableSessionPersistence 862 */ 863 void setDisableSessionPersistence(boolean disableSessionPersistence); 864 865 /** 866 * Indicates whether the component should be stored with the session view regardless of configuration 867 * 868 * <p> 869 * By default the framework nulls out any components that do not have a refresh condition or are needed for 870 * collection processing. This can be a problem if custom application code is written to refresh a component 871 * without setting the corresponding component flag. In this case this property can be set to true to force the 872 * framework to keep the component in session. Defaults to false 873 * </p> 874 * 875 * @return boolean true if the component should be stored in session, false if not 876 */ 877 boolean isForceSessionPersistence(); 878 879 /** 880 * Setter for the indicator to force persistence of the component in session 881 * 882 * @param persistInSession 883 */ 884 void setForceSessionPersistence(boolean persistInSession); 885 886 /** 887 * Security object that indicates what authorization (permissions) exist for the component 888 * 889 * @return ComponentSecurity instance 890 */ 891 ComponentSecurity getComponentSecurity(); 892 893 /** 894 * Setter for the components security object 895 * 896 * @param componentSecurity 897 */ 898 void setComponentSecurity(ComponentSecurity componentSecurity); 899 900 /** 901 * Spring EL expression, which when evaluates to true, makes this component visible 902 * 903 * @return the SpEl expression string 904 */ 905 String getProgressiveRender(); 906 907 /** 908 * Setter for progressiveRender Spring EL expression 909 * 910 * @param progressiveRender the progressiveRender to set 911 */ 912 void setProgressiveRender(String progressiveRender); 913 914 /** 915 * Spring EL expression, which when evaluates to true, causes this component to be refreshed 916 * 917 * @return the SpEl expression string 918 */ 919 String getConditionalRefresh(); 920 921 /** 922 * Setter for conditionalRefresh Spring EL expression 923 * 924 * @param conditionalRefresh the conditionalRefresh to set 925 */ 926 void setConditionalRefresh(String conditionalRefresh); 927 928 /** 929 * List of control names (ids) extracted from {@link #getProgressiveRender()} 930 * 931 * @return the list of control names 932 */ 933 List<String> getProgressiveDisclosureControlNames(); 934 935 /** 936 * A JavaScript expression constructed from {@link #getConditionalRefresh()} 937 * 938 * <p>The script can be executed on the client to determine if the original exp was satisfied before 939 * interacting with the server.</p> 940 * 941 * @return the JS script 942 */ 943 String getProgressiveDisclosureConditionJs(); 944 945 /** 946 * A JavaScript expression constructed from {@link #getProgressiveRender()} 947 * 948 * <p>The script can be executed on the client to determine if the original exp was satisfied before 949 * interacting with the server.</p> 950 * 951 * @return the JS script 952 */ 953 String getConditionalRefreshConditionJs(); 954 955 /** 956 * The list of control names (ids) extracted from {@link #getConditionalRefresh()} 957 * 958 * @return the list of control names 959 */ 960 List<String> getConditionalRefreshControlNames(); 961 962 /** 963 * Indicates whether the component will be stored on the client, but hidden, after the first retrieval 964 * 965 * <p> 966 * The component will not be rendered hidden after first retrieval if this flag is set to true. The component will 967 * then be fetched via an ajax call when it should be rendered. 968 * </p> 969 * 970 * @return the progressiveRenderViaAJAX 971 */ 972 boolean isProgressiveRenderViaAJAX(); 973 974 /** 975 * Setter for the progressiveRenderViaAJAX flag 976 * 977 * @param progressiveRenderViaAJAX the progressiveRenderViaAJAX to set 978 */ 979 void setProgressiveRenderViaAJAX(boolean progressiveRenderViaAJAX); 980 981 /** 982 * Determines whether the component will always be retrieved from the server and shown 983 * 984 * <p> 985 * If true, when the progressiveRender condition is satisfied, the component 986 * will always be retrieved from the server and shown(as opposed to being 987 * stored on the client, but hidden, after the first retrieval as is the 988 * case with the progressiveRenderViaAJAX option). <b>By default, this is 989 * false, so components with progressive render capabilities will always be 990 * already within the client html and toggled to be hidden or visible.</b> </p> 991 * 992 * @return the progressiveRenderAndRefresh 993 */ 994 boolean isProgressiveRenderAndRefresh(); 995 996 /** 997 * Setter for the progressiveRenderAndRefresh flag 998 * 999 * @param progressiveRenderAndRefresh the progressiveRenderAndRefresh to set 1000 */ 1001 void setProgressiveRenderAndRefresh(boolean progressiveRenderAndRefresh); 1002 1003 /** 1004 * Specifies a property by name that when its value changes will automatically perform 1005 * a refresh on this component 1006 * 1007 * <p> 1008 * This can be a comma 1009 * separated list of multiple properties that require this component to be 1010 * refreshed when any of them change. <Br>DO NOT use with progressiveRender 1011 * unless it is know that progressiveRender condition will always be 1012 * satisfied before one of these fields can be changed. 1013 * </p> 1014 * 1015 * @return List property names that should trigger a refresh when their values change 1016 */ 1017 List<String> getRefreshWhenChangedPropertyNames(); 1018 1019 /** 1020 * Setter for the list of property names that trigger a refresh 1021 * 1022 * @param refreshWhenChangedPropertyNames 1023 */ 1024 void setRefreshWhenChangedPropertyNames(List<String> refreshWhenChangedPropertyNames); 1025 1026 /** 1027 * Returns a list of componentIds which will be also be refreshed when this component is refreshed 1028 * 1029 * <p> 1030 * This will be a comma separated list of componentIds that need to be refreshed when a refresh 1031 * condition has been set on this component. 1032 * </p> 1033 * 1034 * @return List<String> 1035 */ 1036 public List<String> getAdditionalComponentsToRefresh(); 1037 1038 /** 1039 * Setter for alsoRefreshComponents 1040 * 1041 * @param additionalComponentsToRefresh 1042 */ 1043 public void setAdditionalComponentsToRefresh(List<String> additionalComponentsToRefresh); 1044 1045 /** 1046 * Returns a string for representing the list of additional components to be refreshed as 1047 * a JavaScript value 1048 * 1049 * @return String representation of the list of componentIds for the components that need to be refreshed 1050 */ 1051 public String getAdditionalComponentsToRefreshJs(); 1052 1053 /** 1054 * Indicates the component can be refreshed by an action 1055 * 1056 * <p> 1057 * This is set by the framework for configured ajax action buttons, should not be set in 1058 * configuration 1059 * </p> 1060 * 1061 * @return boolean true if the component is refreshed by an action, false if not 1062 */ 1063 boolean isRefreshedByAction(); 1064 1065 /** 1066 * Setter for the refreshed by action indicator 1067 * 1068 * <p> 1069 * This is set by the framework for configured ajax action buttons, should not be set in 1070 * configuration 1071 * </p> 1072 * 1073 * @param refreshedByAction 1074 */ 1075 void setRefreshedByAction(boolean refreshedByAction); 1076 1077 /** 1078 * If true if this component is disclosed by an action in js, a placeholder will be put in this components place 1079 * if render is also false. 1080 * 1081 * @return true if this component is disclosed by an action 1082 */ 1083 public boolean isDisclosedByAction(); 1084 1085 /** 1086 * Set if this component is disclosed by some outside action 1087 * 1088 * @param disclosedByAction 1089 */ 1090 public void setDisclosedByAction(boolean disclosedByAction); 1091 1092 /** 1093 * Indicates whether data contained within the component should be reset (set to default) when the 1094 * component is refreshed 1095 * 1096 * @return boolean true if data should be refreshed, false if data should remain as is 1097 */ 1098 boolean isResetDataOnRefresh(); 1099 1100 /** 1101 * Setter for the reset data on refresh indicator 1102 * 1103 * @param resetDataOnRefresh 1104 */ 1105 void setResetDataOnRefresh(boolean resetDataOnRefresh); 1106 1107 /** 1108 * Time in seconds after which the component is automatically refreshed 1109 * 1110 * @return time in seconds 1111 */ 1112 int getRefreshTimer(); 1113 1114 /** 1115 * Setter for refreshTimer 1116 * 1117 * @param refreshTimer 1118 */ 1119 void setRefreshTimer(int refreshTimer); 1120 1121 /** 1122 * The DataAttributes that will be written to the html element for this component as data- 1123 * 1124 * <p>They can be access through .data() call in jQuery.</p> 1125 * 1126 * @return map of data attributes, where key is data attribute name and the map value is the data 1127 * attribute value 1128 */ 1129 Map<String, String> getDataAttributes(); 1130 1131 /** 1132 * Setter for data attributes to include for the component 1133 * 1134 * @param dataAttributes 1135 */ 1136 void setDataAttributes(Map<String, String> dataAttributes); 1137 1138 /** 1139 * Setter for script data attributes to include for the component 1140 * 1141 * @param dataAttributes 1142 */ 1143 void setScriptDataAttributes(Map<String, String> dataAttributes); 1144 1145 /** 1146 * The DataAttributes that will be written to the html as a script call to data for this component (these cannot be 1147 * used for jQuery selection directly) 1148 * 1149 * <p>They can be accessed through .data() call in jQuery.</p> 1150 * 1151 * @return map of data attributes, where key is data attribute name and the map value is the data 1152 * attribute value 1153 */ 1154 Map<String, String> getScriptDataAttributes(); 1155 1156 /** 1157 * Add a data attribute to the dataAttributes map 1158 * 1159 * @param key 1160 * @param value 1161 */ 1162 void addDataAttribute(String key, String value); 1163 1164 /** 1165 * Add a script data attribute to the scriptDataAttributes map 1166 * 1167 * @param key 1168 * @param value 1169 */ 1170 void addScriptDataAttribute(String key, String value); 1171 1172 /** 1173 * The string that can be put into a the tag of a component to add data attributes inline 1174 * 1175 * @return html string for data attributes as html formatted element attributes 1176 */ 1177 String getSimpleDataAttributes(); 1178 1179 /** 1180 * Returns a js string that can be used to right js data attributes to for the component 1181 * 1182 * @return html string for the js required to add the script data attributes 1183 */ 1184 String getScriptDataAttributesJs(); 1185 1186 /** 1187 * The role attribute of this component, use to define aria roles 1188 * 1189 * @return the role attribute 1190 */ 1191 String getRole(); 1192 1193 /** 1194 * @see Component#getRole() 1195 */ 1196 void setRole(String role); 1197 1198 /** 1199 * The aria attributes of this component and their values 1200 * (without "aria-", this is automatically appended during rendering) 1201 * 1202 * @return the aria attributes of this component 1203 */ 1204 Map<String, String> getAriaAttributes(); 1205 1206 /** 1207 * @see org.kuali.rice.krad.uif.component.Component#getAriaAttributes() 1208 */ 1209 void setAriaAttributes(Map<String, String> ariaAttributes); 1210 1211 /** 1212 * Add an aria attribute to the ariaAttributes list 1213 * 1214 * @param key the attribute (no "aria-" prefix) 1215 * @param value the attribute's value 1216 */ 1217 void addAriaAttribute(String key, String value); 1218 1219 /** 1220 * Get the aria attributes as a String that can be used during template output 1221 * 1222 * @return the aria attributes as a string 1223 */ 1224 String getAriaAttributesAsString(); 1225 1226 /** 1227 * Validates different requirements of component compiling a series of reports detailing information on errors 1228 * found in the component. Used by the RiceDictionaryValidator. 1229 * 1230 * @param tracer Record of component's location 1231 */ 1232 void completeValidation(ValidationTrace tracer); 1233 1234 /** 1235 * Raw html or string content to render before this component renders 1236 * 1237 * @return the preRenderContent string 1238 */ 1239 public String getPreRenderContent(); 1240 1241 /** 1242 * Set the preRenderContent 1243 * 1244 * @param preRenderContent 1245 */ 1246 public void setPreRenderContent(String preRenderContent); 1247 1248 /** 1249 * Raw html or string content to render after this component renders 1250 * 1251 * @return the postRenderContent string 1252 */ 1253 public String getPostRenderContent(); 1254 1255 /** 1256 * Set the postRenderContent 1257 * 1258 * @param postRenderContent 1259 */ 1260 public void setPostRenderContent(String postRenderContent); 1261 1262 /** 1263 * Gets the method to call on refresh. 1264 * 1265 * @return method to call 1266 */ 1267 String getMethodToCallOnRefresh(); 1268 1269 /** 1270 * Limits the field data to send on a refresh methodToCall server call to the names/group id/field id 1271 * specified in this list. 1272 * 1273 * <p>The names in the list should be the propertyNames of the fields sent with this request. A wildcard("*") 1274 * can be used at the END of a name to specify all fields with names that begin with the string 1275 * before the wildcard. If the array contains 1 item with the keyword "NONE", then no form fields are sent. 1276 * In addition, a group id or field id with the "#" id selector prefix can be used to send all input data which 1277 * are nested within them. Note that this only limits the fields which exist on the form and data required 1278 * by the KRAD framework is still sent (eg, methodToCall, formKey, sessionId, etc.)</p> 1279 * 1280 * @return the only input fields to send by name with the action request 1281 */ 1282 public List<String> getFieldsToSendOnRefresh(); 1283 1284 /** 1285 * @see org.kuali.rice.krad.uif.component.Component#getFieldsToSendOnRefresh() 1286 */ 1287 public void setFieldsToSendOnRefresh(List<String> fieldsToSendOnRefresh); 1288 1289 /** 1290 * Gets a string representing all CSS style classes. 1291 * 1292 * @return string representation of CSS classes 1293 */ 1294 String getStyleClassesAsString(); 1295 1296 /** 1297 * Names a model property path, which if set and resolves to true, indicates that this component 1298 * should be excluded from the lifecycle at the initialize phase. 1299 * 1300 * <p> 1301 * If prefixed with the '#' character, this path will be relative to the view's "pre-model" 1302 * context rather than the model. 1303 * </p> 1304 * 1305 * <p> 1306 * This property is superseded by {@link #getExcludeUnless()}; when both resolve to true, the 1307 * component will be included. When neither property is set, the component is unconditionally 1308 * included. 1309 * </p> 1310 * 1311 * @return model property path 1312 * @see ViewLifecycleUtils#isExcluded(Component) 1313 */ 1314 String getExcludeIf(); 1315 1316 /** 1317 * Names a model property path, which if set and resolves to null or false, indicates that this 1318 * component should be excluded from the lifecycle at the initialize phase. 1319 * 1320 * <p> 1321 * If prefixed with the '#' character, this path will be relative to the view's "pre-model" 1322 * context rather than the model. 1323 * </p> 1324 * 1325 * <p> 1326 * This property supersedes {@link #getExcludeIf()}; when both resolve to true, the component 1327 * will be included. When neither property is set, the component is unconditionally included. 1328 * </p> 1329 * 1330 * @return model property path 1331 * @see ViewLifecycleUtils#isExcluded(Component) 1332 */ 1333 String getExcludeUnless(); 1334 1335 /** 1336 * Whether to omit fields from form post unless they are explicitly specified by the 1337 * {@link org.kuali.rice.krad.uif.element.Action#fieldsToSend} property. 1338 * 1339 * @return whether fields will be omitted from form post 1340 */ 1341 boolean isOmitFromFormPost(); 1342 1343 /** 1344 * @see #isOmitFromFormPost() 1345 */ 1346 void setOmitFromFormPost(boolean omitFromFormPost); 1347 1348 1349 }