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.datadictionary.state; 17 18 import org.kuali.rice.krad.datadictionary.validator.ValidationTrace; 19 20 import java.util.List; 21 import java.util.Map; 22 23 /** 24 * StateMapping defines the methods necessary to allow for state validation to apply to a state object 25 * 26 * @author Kuali Rice Team (rice.collab@kuali.org) 27 * @since 2.2 28 */ 29 public interface StateMapping { 30 31 /** 32 * Gets the currentState by looking at the statePropertyName on the stateObject passed in 33 * 34 * @param stateObject the object containing the state information 35 * @return the currentState of the object 36 */ 37 public String getCurrentState(Object stateObject); 38 39 /** 40 * Gets the nextState of the object passed in by looking at the statePropertyName and using the states list 41 * to determine the next state in order. Returns the currentState if there is no next state. 42 * 43 * @param stateObject the object containing the state information 44 * @return the next state of the object, or current state if no next state exists 45 */ 46 public String getNextState(Object stateObject); 47 48 /** 49 * Returns the human readable message determined by the key set for the state passed in 50 * against the stateNameMessageKeyMap. If the state cannot be found in the states list or the state passed in is 51 * blank, this method will return null. If the key found does not match a message, this method will return the 52 * state 53 * passed in. 54 * 55 * @param state state to get the message for 56 * @return state message, or the state passed in (if a valid state in states). Otherwise, returns null. 57 */ 58 public String getStateNameMessage(String state); 59 60 /** 61 * Map used by getStateNameMessage to determine the key to use when retrieving the message for the state specified. 62 * The map should be defined as state:messageKeyForState. 63 * 64 * @return map of states and their messageKeys 65 */ 66 public Map<String, String> getStateNameMessageKeyMap(); 67 68 /** 69 * Set the stateNameMessageKeyMap 70 * 71 * @param stateNameMessageKeyMap map of states and their messageKeys 72 */ 73 public void setStateNameMessageKeyMap(Map<String, String> stateNameMessageKeyMap); 74 75 /** 76 * The states of this stateMapping. IMPORTANT: This must be ALL states for this mapping IN ORDER. 77 * 78 * @return list of states, in the order in which they are applied. If states were never set, returns an empty 79 * list. 80 */ 81 public List<String> getStates(); 82 83 /** 84 * Set the states of this stateMapping, in order 85 * 86 * @param states list of states, in the order in which they are applied. 87 */ 88 public void setStates(List<String> states); 89 90 /** 91 * The property name/path to be used when trying to find state String information on the object. This is used by 92 * getCurrentState(Object object) 93 * and getNextState(Object object); 94 * 95 * @return the property name/path representing where state information can be found on the object 96 */ 97 public String getStatePropertyName(); 98 99 /** 100 * Set the property name/path 101 * 102 * @param name the property name/path that points to the string representation of the object's tate 103 */ 104 public void setStatePropertyName(String name); 105 106 /** 107 * This ONLY applies to client side validations as the controller has full control over what validations to apply 108 * on the server. This setting determines for what states, if any, the client side validation needs to use for 109 * its validation instead of the default (by default if state validation is setup, the client side validation 110 * will use n+1 as its validation, ie whatever the NEXT state is). 111 * 112 * <p>The map must be defined as such: (state of the object, state to use for validation on the 113 * client when in that state).<br> 114 * Example:<br> 115 * key="INITIAL" value="SUBMIT"<br> 116 * key="SAVE" value="SUBMIT"<br> 117 * In this example, when the object is in the "INITIAL" or the "SAVE" states, validation on the client will 118 * be against the "SUBMIT" state</p> 119 * 120 * @return map representing the state of the object and state to use for validation on the 121 * client when in that state 122 */ 123 public Map<String, String> getCustomClientSideValidationStates(); 124 125 /** 126 * Set the custom client side validation behavior map. This only applies for client-side validation. 127 * 128 * @param customClientSideValidationStates map representing the state of the object and state to use for validation 129 * on the 130 * client when in that state 131 */ 132 public void setCustomClientSideValidationStates(Map<String, String> customClientSideValidationStates); 133 134 /** 135 * Validates different requirements of component compiling a series of reports detailing information on errors 136 * found in the component. Used by the RiceDictionaryValidator. 137 * 138 * @param tracer Record of component's location 139 */ 140 public void completeValidation(ValidationTrace tracer); 141 142 }