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.view; 17 18 import org.kuali.rice.krad.file.FileMetaBlob; 19 import org.kuali.rice.krad.uif.UifConstants.ViewType; 20 import org.kuali.rice.krad.uif.component.Component; 21 import org.kuali.rice.krad.uif.lifecycle.ViewPostMetadata; 22 import org.kuali.rice.krad.uif.service.ViewHelperService; 23 import org.kuali.rice.krad.web.form.DialogResponse; 24 25 import javax.servlet.http.HttpServletRequest; 26 import java.io.Serializable; 27 import java.util.List; 28 import java.util.Map; 29 import java.util.Set; 30 31 /** 32 * Interface that must be implemented for classes the provide the backing data (model) for a 33 * {@link org.kuali.rice.krad.uif.view.View}. 34 * 35 * <p>Since the View relies on helper properties from the model it is necessary the backing object implement the 36 * ViewModel interface. Note model objects can extend {@link org.kuali.rice.krad.web.form.UifFormBase} which implements 37 * the ViewModel interface.</p> 38 * 39 * @author Kuali Rice Team (rice.collab@kuali.org) 40 */ 41 public interface ViewModel extends Serializable { 42 43 /** 44 * Called before Spring binds the request to the form to allow for pre-processing before setting values. 45 * 46 * @param request request object containing the query parameters 47 */ 48 void preBind(HttpServletRequest request); 49 50 /** 51 * Called after Spring binds the request to the form and before the controller method is invoked 52 * 53 * @param request request object containing the query parameters 54 */ 55 void postBind(HttpServletRequest request); 56 57 /** 58 * Called after the controller has finished executing, but before rendering occurs. 59 * 60 * @param request request object containing the query parameters 61 */ 62 void preRender(HttpServletRequest request); 63 64 /** 65 * Unique Id for the <code>View</code> instance. This is specified for a 66 * view in its definition by setting the 'id' property. 67 * 68 * @return String view id 69 */ 70 public String getViewId(); 71 72 /** 73 * Setter for the unique view id 74 * 75 * @param viewId 76 */ 77 public void setViewId(String viewId); 78 79 /** 80 * Name for the <code>View</code> instance. This is specified for a view in 81 * its definition by setting the 'id' property. The name is not necessary 82 * unique and cannot be used by itself to retrieve a view. Typically it is 83 * used with other parameters to identify a view with a certain type (view 84 * type) 85 * 86 * @return String view name 87 */ 88 public String getViewName(); 89 90 /** 91 * Setter for the view name 92 * 93 * @param viewName 94 */ 95 public void setViewName(String viewName); 96 97 /** 98 * Name for the type of view being requested. This can be used to find 99 * <code>View</code> instances by request parameters (not necessary the 100 * unique id) 101 * 102 * @return String view type name 103 */ 104 public ViewType getViewTypeName(); 105 106 /** 107 * Setter for the view type name 108 * 109 * @param viewTypeName 110 */ 111 public void setViewTypeName(ViewType viewTypeName); 112 113 /** 114 * View instance associated with the model. Used to render the user interface 115 * 116 * @return View 117 */ 118 public View getView(); 119 120 /** 121 * Setter for the view instance 122 * 123 * @param view 124 */ 125 public void setView(View view); 126 127 /** 128 * Returns the view helper service instance that was configured for the current view. 129 * 130 * @return instance of view helper service, null if view is null 131 */ 132 public ViewHelperService getViewHelperService() throws IllegalAccessException, InstantiationException; 133 134 /** 135 * Gets the {@link org.kuali.rice.krad.uif.lifecycle.ViewPostMetadata} that has been built up from processing 136 * of a view. 137 * 138 * <p>The view post metadata is used to read information about the view that was rendered when a post occurs. For 139 * example, you might need to check whether a particular flag was enabled for the rendered view when processing 140 * the post logic</p> 141 * 142 * @return ViewPostMetadata instance for the previously processed view 143 */ 144 public ViewPostMetadata getViewPostMetadata(); 145 146 /** 147 * @see ViewModel#getViewPostMetadata() 148 */ 149 public void setViewPostMetadata(ViewPostMetadata viewPostMetadata); 150 151 /** 152 * Id for the current page being displayed within the view 153 * 154 * @return String page id 155 */ 156 public String getPageId(); 157 158 /** 159 * Setter for the current page id 160 * 161 * @param pageId 162 */ 163 public void setPageId(String pageId); 164 165 /** 166 * URL the form generated for the view should post to 167 * 168 * @return String form post URL 169 */ 170 public String getFormPostUrl(); 171 172 /** 173 * Setter for the form post URL 174 * 175 * @param formPostUrl 176 */ 177 public void setFormPostUrl(String formPostUrl); 178 179 /** 180 * Map of parameters that was used to configured the <code>View</code>. 181 * Maintained on the form to rebuild the view on posts and session timeout 182 * 183 * @return Map<String, String> view parameters 184 * @see org.kuali.rice.krad.uif.view.View.getViewRequestParameters() 185 */ 186 public Map<String, String> getViewRequestParameters(); 187 188 /** 189 * Setter for the view's request parameter map 190 * 191 * @param viewRequestParameters map of request parameters 192 */ 193 public void setViewRequestParameters(Map<String, String> viewRequestParameters); 194 195 /** 196 * List of fields that should be read only on the view 197 * 198 * <p> 199 * If the view being rendered supports request setting of read-only fields, the readOnlyFields request parameter 200 * can be sent to mark fields as read only that might not have been otherwise 201 * </p> 202 * 203 * <p> 204 * Note the paths specified should be the simple property names (not the full binding path). Therefore if the 205 * property name appears multiple times in the view, all instances will be set as read only 206 * </p> 207 * 208 * @return List<String> read only property names 209 * @see View#isSupportsRequestOverrideOfReadOnlyFields() 210 */ 211 public List<String> getReadOnlyFieldsList(); 212 213 /** 214 * Setter for the list of read only fields 215 * 216 * @param readOnlyFieldsList 217 */ 218 public void setReadOnlyFieldsList(List<String> readOnlyFieldsList); 219 220 /** 221 * Holds instances for collection add lines. The key of the Map gives the 222 * collection name the line instance applies to, the Map value is an 223 * instance of the collection object class that holds the new line data 224 * 225 * @return Map<String, Object> new collection lines 226 */ 227 public Map<String, Object> getNewCollectionLines(); 228 229 /** 230 * Setter for the new collection lines Map 231 * 232 * @param newCollectionLines 233 */ 234 public void setNewCollectionLines(Map<String, Object> newCollectionLines); 235 236 /** 237 * When the request has been triggered by an action component, gives the id for the action. 238 * 239 * @return String action id, or null if request was not triggered by an action component 240 */ 241 String getTriggerActionId(); 242 243 /** 244 * @see ViewModel#getTriggerActionId() 245 */ 246 void setTriggerActionId(String triggerActionId); 247 248 /** 249 * Map of parameters sent for the invoked action 250 * 251 * <p> 252 * Many times besides just setting the method to call actions need to send 253 * additional parameters. For instance the method being called might do a 254 * redirect, in which case the action needs to send parameters for the 255 * redirect URL. An example of this is redirecting to a <code>Lookup</code> 256 * view. In some cases the parameters that need to be sent conflict with 257 * properties already on the form, and putting all the action parameters as 258 * form properties would grow massive (in addition to adds an additional 259 * step from the XML config). So this general map solves those issues. 260 * </p> 261 * 262 * @return Map<String, String> action parameters 263 */ 264 public Map<String, String> getActionParameters(); 265 266 /** 267 * Setter for the action parameters map 268 * 269 * @param actionParameters 270 */ 271 public void setActionParameters(Map<String, String> actionParameters); 272 273 /** 274 * Map that is populated from the component state maintained on the client 275 * 276 * <p> 277 * Used when a request is made that refreshes part of the view. The current state for components (which 278 * have state that can be changed on the client), is populated into this map which is then used by the 279 * <code>ViewHelperService</code> to update the components so that the state is maintained when they render. 280 * </p> 281 * 282 * @return Map<String, Object> map where key is name of property or component id, and value is the property 283 * value or another map of component key/value pairs 284 */ 285 public Map<String, Object> getClientStateForSyncing(); 286 287 /** 288 * Holds Set of String identifiers for lines that were selected in a collection from a single page. 289 * selectedCollectionLines are request level values and get reset with every page request 290 * 291 * <p> 292 * When the select field is enabled for a <code>CollectionGroup</code>, the framework will be 293 * default bind the selected identifier strings to this property. The key of the map uniquely identifies the 294 * collection by the full binding path to the collection, and the value is a set of Strings for the checked 295 * lines. 296 * </p> 297 * 298 * @return Map<String, Set<String>> map of collections and their selected lines 299 * @see org.kuali.rice.krad.service.LegacyDataAdapter#getDataObjectIdentifierString(java.lang.Object) 300 */ 301 public Map<String, Set<String>> getSelectedCollectionLines(); 302 303 /** 304 * Setter for the map that holds selected collection lines 305 * 306 * @param selectedCollectionLines 307 */ 308 public void setSelectedCollectionLines(Map<String, Set<String>> selectedCollectionLines); 309 310 /** 311 * Indicates whether default values should be applied. 312 * 313 * <p> 314 * Default field values of a view need to be applied after the view life cycle completes. Otherwise, 315 * they risk getting over written. 316 * </p> 317 * 318 * @return boolean true if the request was an ajax call, false if not 319 */ 320 boolean isApplyDefaultValues(); 321 322 /** 323 * Set whether default values should be applied to the view 324 * 325 * @param applyDefaultValues 326 */ 327 void setApplyDefaultValues(boolean applyDefaultValues); 328 329 /** 330 * Determines whether edit modes and action flags should be evaluated. 331 * 332 * <p>Initially this will be true causing edit modes and action flags to be evaluated on the initial 333 * request to a view. If these need to be reevaluated at some point (for a particular view instance), this 334 * flag can be set to true and causing the authorization to be reevaluated during the lifecycle.</p> 335 * 336 * @return boolean true if flags and modes should be evaluate during the view lifecycle, false if not 337 */ 338 boolean isEvaluateFlagsAndModes(); 339 340 /** 341 * @see ViewModel#isEvaluateFlagsAndModes() 342 */ 343 void setEvaluateFlagsAndModes(boolean evaluateFlagsAndModes); 344 345 /** 346 * Copy of the edit view flag to be used by subsequent requests (so they don't need to be 347 * evaluated on each request). 348 * 349 * <p>If null, edit check will be performed</p> 350 * 351 * @see org.kuali.rice.krad.uif.component.ComponentBase#setReadOnly(java.lang.Boolean) 352 */ 353 Boolean isCanEditView(); 354 355 /** 356 * @see ViewModel#isCanEditView() 357 */ 358 void setCanEditView(Boolean canEditView); 359 360 /** 361 * Copy of the action flags on the view to be used by subsequent requests (so they don't need to be 362 * evaluated on each request). 363 * 364 * @see ViewModel#isEvaluateFlagsAndModes() 365 * @see org.kuali.rice.krad.uif.view.View#getActionFlags() 366 */ 367 Map<String, Boolean> getActionFlags(); 368 369 /** 370 * @see ViewModel#getActionFlags() 371 */ 372 void setActionFlags(Map<String, Boolean> actionFlags); 373 374 /** 375 * Copy of the edit modes on the view to be used by subsequent requests (so they don't need to be 376 * evaluated on each request). 377 * 378 * @see ViewModel#isEvaluateFlagsAndModes() 379 * @see org.kuali.rice.krad.uif.view.View#getEditModes()() 380 */ 381 Map<String, Boolean> getEditModes(); 382 383 /** 384 * @see ViewModel#getEditModes() 385 */ 386 void setEditModes(Map<String, Boolean> editModes); 387 388 /** 389 * Script that will run on render (view or component) for generating growl messages 390 * 391 * @return String JS growl script 392 */ 393 public String getGrowlScript(); 394 395 /** 396 * Setter for the script that generates growls on render 397 * 398 * @param growlScript 399 */ 400 public void setGrowlScript(String growlScript); 401 402 /** 403 * Gets the state. This is the default location for state on KRAD forms. 404 * 405 * @return the state 406 */ 407 public String getState(); 408 409 /** 410 * Set the state 411 * 412 * @param state 413 */ 414 public void setState(String state); 415 416 /** 417 * Id for the component that should be updated for a component refresh process 418 * 419 * @return String component id 420 */ 421 public String getUpdateComponentId(); 422 423 /** 424 * Setter for the component id that should be refreshed 425 * 426 * @param updateComponentId 427 */ 428 public void setUpdateComponentId(String updateComponentId); 429 430 /** 431 * Component instance that been built for a refresh/disclosure request. 432 * 433 * <p>This is generally set by org.kuali.rice.krad.uif.lifecycle.ViewLifecycle#performComponentLifecycle(org.kuali.rice.krad.uif.view.View, 434 * java.lang.Object, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, 435 * org.kuali.rice.krad.uif.lifecycle.ViewPostMetadata, java.lang.String) after processing the lifecycle. The form 436 * property provides access to the rendering layer.</p> 437 * 438 * @return component instance for updating 439 */ 440 public Component getUpdateComponent(); 441 442 /** 443 * @see ViewModel#getUpdateComponent() 444 */ 445 public void setUpdateComponent(Component updateComponent); 446 447 /** 448 * Indicates whether the request was made by an ajax call 449 * 450 * <p> 451 * Depending on whether the request was made via ajax (versus standard browser submit) the response 452 * will be handled different. For example with an ajax request we can send back partial page updates, which 453 * cannot be done with standard submits 454 * </p> 455 * 456 * <p> 457 * If this indicator is true, {@link #getAjaxReturnType()} will be used to determine how to handling 458 * the ajax return 459 * </p> 460 * 461 * @return boolean true if the request was an ajax call, false if not 462 */ 463 boolean isAjaxRequest(); 464 465 /** 466 * Set the ajaxRequest 467 * 468 * @param ajaxRequest 469 */ 470 void setAjaxRequest(boolean ajaxRequest); 471 472 /** 473 * Gets the return type for the ajax call 474 * 475 * <p> 476 * The ajax return type indicates how the response content will be handled in the client. Typical 477 * examples include updating a component, the page, or doing a redirect. 478 * </p> 479 * 480 * @return String return type 481 * @see org.kuali.rice.krad.uif.UifConstants.AjaxReturnTypes 482 */ 483 String getAjaxReturnType(); 484 485 /** 486 * Setter for the type of ajax return 487 * 488 * @param ajaxReturnType 489 */ 490 void setAjaxReturnType(String ajaxReturnType); 491 492 /** 493 * Indicates whether the request is to update a component (only applicable for ajax requests) 494 * 495 * @return boolean true if the request is for update component, false if not 496 */ 497 boolean isUpdateComponentRequest(); 498 499 /** 500 * Indicates whether the request is to update a page (only applicable for ajax requests) 501 * 502 * @return boolean true if the request is for update page, false if not 503 */ 504 boolean isUpdatePageRequest(); 505 506 /** 507 * Indicates whether the request is to update a dialog (only applicable for ajax requests) 508 * 509 * @return boolean true if the request is for update dialog, false if not 510 */ 511 boolean isUpdateDialogRequest(); 512 513 /** 514 * Indicates whether the request is for a non-update of the view (only applicable for ajax requests) 515 * 516 * <p> 517 * Examples of requests that do not update the view are ajax queries or requests that download a file 518 * </p> 519 * 520 * @return boolean true if the request is for non-update, false if not 521 */ 522 boolean isUpdateNoneRequest(); 523 524 /** 525 * Indicates whether the request should return a JSON string 526 * 527 * <p> 528 * When this indicator is true, the rendering process will invoke the template 529 * given by {@link #getRequestJsonTemplate()} which should return a JSON string 530 * </p> 531 * 532 * <p> 533 * For JSON requests the view is not built, however a component can be retrieved and 534 * exported in the request by setting {@link #getUpdateComponentId()} 535 * </p> 536 * 537 * @return boolean true if request is for JSON, false if not 538 */ 539 boolean isJsonRequest(); 540 541 /** 542 * Template the will be invoked to return a JSON string 543 * 544 * <p> 545 * Certain templates can be rendered to build JSON for a JSON request. The template 546 * set here (by a controller) will be rendered 547 * </p> 548 * 549 * @return path to template 550 */ 551 String getRequestJsonTemplate(); 552 553 /** 554 * Setter for the template to render for the request 555 * 556 * @param requestJsonTemplate 557 */ 558 void setRequestJsonTemplate(String requestJsonTemplate); 559 560 /** 561 * Indicates whether the request is for paging a collection (or sorting). 562 * 563 * @return boolean true if a paging request is present, false if not 564 */ 565 boolean isCollectionPagingRequest(); 566 567 /** 568 * @see ViewModel#isCollectionPagingRequest() 569 */ 570 void setCollectionPagingRequest(boolean collectionPagingRequest); 571 572 /** 573 * Contains values for dialog explanation fields present on the page. 574 * 575 * <p>Since multiple dialogs can be present on the same page using the generic explanation field, the values 576 * are maintained in this map using the dialog id as the key. Values are cleared on each request.</p> 577 * 578 * @return map of dialog explanations, where key is the dialog id and map value is the explanation 579 */ 580 Map<String, String> getDialogExplanations(); 581 582 /** 583 * @see ViewModel#getDialogExplanations() 584 */ 585 void setDialogExplanations(Map<String, String> dialogExplanations); 586 587 /** 588 * Map containing dialog responses for a request 'conversation'. 589 * 590 * <p>When a controller methods requests a dialog, the response is collected on the return call and placed 591 * into this map. The key to the map is the id for the dialog. Since a single controller method can spawn multiple 592 * dialogs in a single conversation (these are actually multiple requests/responses, but part of the same action 593 * request), the responses are collected in this map. Whenever a request is encountered that is not a return, the 594 * map is cleared. This means the responses will be cleared in case the action is triggered action.</p> 595 * 596 * @return map of dialog responses, where map key is the dialog id and the map value is the dialog response 597 * object 598 */ 599 Map<String, DialogResponse> getDialogResponses(); 600 601 /** 602 * Helper method to get a dialog response for the given dialog id. 603 * 604 * @param dialogId id of the dialog to get response for 605 * @return dialog response object, or null if response does not exist 606 * @see ViewModel#getDialogResponses() 607 */ 608 DialogResponse getDialogResponse(String dialogId); 609 610 /** 611 * @see ViewModel#getDialogResponses() 612 */ 613 void setDialogResponses(Map<String, DialogResponse> dialogResponses); 614 615 /** 616 * A generic map for framework pieces (such as component modifiers) that need to dynamically store 617 * data to the form 618 * 619 * @return Map<String, Object> 620 */ 621 public Map<String, Object> getExtensionData(); 622 623 /** 624 * Setter for the generic extension data map 625 * 626 * @param extensionData 627 */ 628 public void setExtensionData(Map<String, Object> extensionData); 629 630 }