001 /** 002 * Copyright 2005-2012 The Kuali Foundation 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 package org.kuali.rice.kns.maintenance; 017 018 import org.kuali.rice.kns.document.authorization.MaintenanceDocumentRestrictions; 019 import org.kuali.rice.krad.bo.BusinessObject; 020 import org.kuali.rice.krad.bo.PersistableBusinessObject; 021 import org.kuali.rice.kns.document.MaintenanceDocument; 022 import org.kuali.rice.krad.lookup.SelectiveReferenceRefresher; 023 024 import java.util.Collection; 025 import java.util.List; 026 import java.util.Map; 027 028 /** 029 * Defines basic methods that all maintainable objects must provide 030 */ 031 @Deprecated 032 public interface Maintainable extends org.kuali.rice.krad.maintenance.Maintainable, SelectiveReferenceRefresher { 033 034 public String getDocumentTitle(MaintenanceDocument document); 035 036 /** 037 * Returns instance of the business object that is being maintained. 038 */ 039 @Deprecated 040 public PersistableBusinessObject getBusinessObject(); 041 042 /** 043 * Called from a lookup return by the maintenance action. 044 */ 045 @Deprecated 046 public void refresh(String refreshCaller, Map fieldValues, MaintenanceDocument document); 047 048 /** 049 * Sets an instance of a business object to be maintained. 050 */ 051 @Deprecated 052 public void setBusinessObject(PersistableBusinessObject object); 053 054 @Deprecated 055 public Class getBoClass(); 056 057 @Deprecated 058 public void setBoClass(Class boClass); 059 060 /** 061 * This method will cause the Maintainable implementation to save/store the 062 * relevant business object(s). This typically is called only after the 063 * maint document has gone through state to final. 064 */ 065 @Deprecated 066 public void saveBusinessObject(); 067 068 @Deprecated 069 public void addMultipleValueLookupResults(MaintenanceDocument document, String collectionName, 070 Collection<PersistableBusinessObject> rawValues, boolean needsBlank, PersistableBusinessObject bo); 071 072 @Deprecated 073 public List<String> getDuplicateIdentifierFieldsFromDataDictionary(String docTypeName, String collectionName); 074 075 @Deprecated 076 public List<String> getMultiValueIdentifierList(Collection maintCollection, List<String> duplicateIdentifierFields); 077 078 @Deprecated 079 public boolean hasBusinessObjectExisted(BusinessObject bo, List<String> existingIdentifierList, 080 List<String> duplicateIdentifierFields); 081 082 /** 083 * Blanks out or sets the default of any value specified as restricted 084 * within the {@link MaintenanceDocumentRestrictions} instance. 085 * 086 * This method should only be called if this maintainable represents the new 087 * maintainable of the maintenance document. 088 * 089 * @param maintenanceDocumentRestrictions 090 */ 091 @Deprecated 092 public void clearBusinessObjectOfRestrictedValues(MaintenanceDocumentRestrictions maintenanceDocumentRestrictions); 093 094 public boolean isBoNotesEnabled(); 095 096 /** 097 * Gives chance to a maintainable object to prepare and return a 098 * maintainable object which might be external to the system 099 * 100 * @return 101 */ 102 @Deprecated 103 public void prepareBusinessObject(BusinessObject businessObject); 104 105 // 3070 106 @Deprecated 107 public void deleteBusinessObject(); 108 109 @Deprecated 110 boolean isOldBusinessObjectInDocument(); 111 112 /** 113 * Indicates whether inactive records for the given collection should be 114 * display. 115 * 116 * @param collectionName - name of the collection (or sub-collection) to check inactive 117 * record display setting 118 * @return true if inactive records should be displayed, false otherwise 119 */ 120 @Deprecated 121 public boolean getShowInactiveRecords(String collectionName); 122 123 /** 124 * Returns the Map used to control the state of inactive record collection 125 * display. Exposed for setting from the maintenance jsp. 126 */ 127 @Deprecated 128 public Map<String, Boolean> getInactiveRecordDisplay(); 129 130 /** 131 * Indicates to maintainble whether or not inactive records should be 132 * displayed for the given collection name. 133 * 134 * @param collectionName - name of the collection (or sub-collection) to set inactive 135 * record display setting 136 * @param showInactive - true to display inactive, false to not display inactive 137 * records 138 */ 139 @Deprecated 140 public void setShowInactiveRecords(String collectionName, boolean showInactive); 141 142 /** 143 * Populates the new collection lines based on key/value pairs. 144 * 145 * @param fieldValues 146 * @return 147 */ 148 @Deprecated 149 public Map<String, String> populateNewCollectionLines(Map<String, String> fieldValues, 150 MaintenanceDocument maintenanceDocument, String methodToCall); 151 152 /** 153 * Gets the holder for the "add line" for a collection on the business 154 * object 155 * 156 * @param collectionName 157 * @return 158 */ 159 @Deprecated 160 public PersistableBusinessObject getNewCollectionLine(String collectionName); 161 162 /** 163 * Adds the new line for the given collection to the business object's 164 * collection. 165 * 166 * @param collectionName 167 */ 168 @Deprecated 169 public void addNewLineToCollection(String collectionName); 170 171 /** 172 * KULRICE-4264 - a hook to change the state of the business object, which 173 * is the "new line" of a collection, before it is validated 174 * 175 * @param colName 176 * @param colClass 177 * @param addBO 178 */ 179 @Deprecated 180 public void processBeforeAddLine(String colName, Class colClass, BusinessObject addBO); 181 182 /** 183 * Set default values. 184 * 185 * @param docTypeName 186 */ 187 @Deprecated 188 public void setGenerateDefaultValues(String docTypeName); 189 190 /** 191 * Set default values for blank required fields. 192 * 193 * @param docTypeName 194 */ 195 @Deprecated 196 public void setGenerateBlankRequiredValues(String docTypeName); 197 198 /** 199 * Returns a list of Section objects that specify how to render the view for 200 * the maintenance object. 201 * 202 * @param oldMaintainable - If this is the new maintainable, the old is passed in for 203 * reference. If it is the old maintainable, then null will be 204 * passed in 205 * @return 206 */ 207 @Deprecated 208 public List getSections(MaintenanceDocument maintenanceDocument, Maintainable oldMaintainable); 209 210 /** 211 * This method populates the business object based on key/value pairs. 212 * 213 * @param fieldValues 214 * @param maintenanceDocument 215 * @return 216 */ 217 @Deprecated 218 public Map populateBusinessObject(Map<String, String> fieldValues, MaintenanceDocument maintenanceDocument, 219 String methodToCall); 220 221 /** 222 * Returns a string that will be displayed as title on the maintenance 223 * screen. 224 */ 225 @Deprecated 226 public String getMaintainableTitle(); 227 228 public void setupNewFromExisting(MaintenanceDocument document, 229 Map<String, String[]> parameters); 230 231 public void processAfterCopy(MaintenanceDocument document, 232 Map<String, String[]> requestParameters); 233 234 public void processAfterEdit(MaintenanceDocument document, 235 Map<String, String[]> requestParameters); 236 237 public void processAfterNew(MaintenanceDocument document, 238 Map<String, String[]> requestParameters); 239 240 public void processAfterPost(MaintenanceDocument document, 241 Map<String, String[]> requestParameters); 242 }