Coverage Report - org.kuali.rice.kns.uif.util.ViewModelUtils
 
Classes in this File Line Coverage Branch Coverage Complexity
ViewModelUtils
0%
0/53
0%
0/40
5.6
 
 1  
 /*
 2  
  * Copyright 2007 The Kuali Foundation Licensed under the Educational Community
 3  
  * License, Version 1.0 (the "License"); you may not use this file except in
 4  
  * compliance with the License. You may obtain a copy of the License at
 5  
  * http://www.opensource.org/licenses/ecl1.php Unless required by applicable law
 6  
  * or agreed to in writing, software distributed under the License is
 7  
  * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 8  
  * KIND, either express or implied. See the License for the specific language
 9  
  * governing permissions and limitations under the License.
 10  
  */
 11  
 package org.kuali.rice.kns.uif.util;
 12  
 
 13  
 import java.util.Collection;
 14  
 import java.util.Map;
 15  
 
 16  
 import org.apache.commons.lang.StringUtils;
 17  
 import org.kuali.rice.kns.uif.container.View;
 18  
 import org.kuali.rice.kns.uif.core.Component;
 19  
 import org.kuali.rice.kns.uif.core.BindingInfo;
 20  
 import org.kuali.rice.kns.uif.field.AttributeField;
 21  
 
 22  
 /**
 23  
  * Provides methods for getting property values, types, and paths within the
 24  
  * context of a <code>View</code>
 25  
  * 
 26  
  * <p>
 27  
  * The view provides a special map named 'abstractTypeClasses' that indicates
 28  
  * concrete classes that should be used in place of abstract property types that
 29  
  * are encountered on the object graph. This classes takes into account that map
 30  
  * while dealing with properties. e.g. suppose we have propertyPath
 31  
  * 'document.name' on the form, with the type of the document property set to
 32  
  * the interface Document. Using class introspection we would get back the
 33  
  * interface type for document and this would not be able to get the property
 34  
  * type for name. Using the view map, we can replace document with a concrete
 35  
  * class and then use it to get the name property
 36  
  * </p>
 37  
  * 
 38  
  * @author Kuali Rice Team (rice.collab@kuali.org)
 39  
  */
 40  0
 public class ViewModelUtils {
 41  
 
 42  
     public static Class<?> getPropertyType(View view, String propertyPath) {
 43  0
         Class<?> propertyType = null;
 44  
 
 45  0
         if (StringUtils.isBlank(propertyPath)) {
 46  0
             return propertyType;
 47  
         }
 48  
 
 49  
         // in case of partial match, holds the class that matched and the
 50  
         // property so we can get by reflection
 51  0
         Class<?> modelClass = view.getFormClass();
 52  0
         String modelProperty = propertyPath;
 53  
 
 54  0
         int bestMatchLength = 0;
 55  
 
 56  
         // removed collection indexes from path for matching
 57  0
         String flattenedPropertyPath = propertyPath.replaceAll("\\[.+\\]", "");
 58  
 
 59  
         // check if property path matches one of the modelClass entries
 60  0
         Map<String, Class<?>> modelClasses = view.getAbstractTypeClasses();
 61  0
         for (String path : modelClasses.keySet()) {
 62  
             // full match
 63  0
             if (StringUtils.equals(path, flattenedPropertyPath)) {
 64  0
                 propertyType = modelClasses.get(path);
 65  0
                 break;
 66  
             }
 67  
 
 68  
             // partial match
 69  0
             if (flattenedPropertyPath.startsWith(path) && (path.length() > bestMatchLength)) {
 70  0
                 bestMatchLength = path.length();
 71  
 
 72  0
                 modelClass = modelClasses.get(path);
 73  0
                 modelProperty = StringUtils.removeStart(flattenedPropertyPath, path);
 74  0
                 modelProperty = StringUtils.removeStart(modelProperty, ".");
 75  
             }
 76  
         }
 77  
 
 78  
         // if full match not found, get type based on reflection
 79  0
         if (propertyType == null) {
 80  0
             propertyType = ObjectPropertyUtils.getPropertyType(modelClass, modelProperty);
 81  
         }
 82  
 
 83  0
         return propertyType;
 84  
     }
 85  
 
 86  
     public static String getParentObjectPath(AttributeField field) {
 87  0
         String parentObjectPath = "";
 88  
 
 89  0
         String objectPath = field.getBindingInfo().getBindingObjectPath();
 90  0
         String propertyPrefix = field.getBindingInfo().getBindByNamePrefix();
 91  
 
 92  0
         if (!field.getBindingInfo().isBindToForm() && StringUtils.isNotBlank(objectPath)) {
 93  0
             parentObjectPath = objectPath;
 94  
         }
 95  
 
 96  0
         if (StringUtils.isNotBlank(propertyPrefix)) {
 97  0
             if (StringUtils.isNotBlank(parentObjectPath)) {
 98  0
                 parentObjectPath += ".";
 99  
             }
 100  
 
 101  0
             parentObjectPath += propertyPrefix;
 102  
         }
 103  
 
 104  0
         return parentObjectPath;
 105  
     }
 106  
 
 107  
     public static Class<?> getParentObjectClassForMetadata(View view, AttributeField field) {
 108  0
         String parentObjectPath = getParentObjectPath(field);
 109  
 
 110  0
         return getPropertyType(view, parentObjectPath);
 111  
     }
 112  
 
 113  
     public static Object getParentObjectForMetadata(View view, Object model, AttributeField field) {
 114  
         // default to model as parent
 115  0
         Object parentObject = model;
 116  
 
 117  0
         String parentObjectPath = getParentObjectPath(field);
 118  0
         if (StringUtils.isNotBlank(parentObjectPath)) {
 119  0
             parentObject = ObjectPropertyUtils.getPropertyValue(model, parentObjectPath);
 120  
 
 121  
             // attempt to create new instance if parent is null or is a
 122  
             // collection or map
 123  0
             if ((parentObject == null) || Collection.class.isAssignableFrom(parentObject.getClass())
 124  
                     || Map.class.isAssignableFrom(parentObject.getClass())) {
 125  
                 try {
 126  0
                     Class<?> parentObjectClass = getPropertyType(view, parentObjectPath);
 127  0
                     parentObject = parentObjectClass.newInstance();
 128  
                 }
 129  0
                 catch (InstantiationException e) {
 130  
                     // swallow exception and let null be returned
 131  
                 }
 132  0
                 catch (IllegalAccessException e) {
 133  
                     // swallow exception and let null be returned
 134  0
                 }
 135  
             }
 136  
         }
 137  
 
 138  0
         return parentObject;
 139  
     }
 140  
     
 141  
     public static Object getValue(View view, Object model, String propertyName, BindingInfo bindingInfo){
 142  0
         Object value = null;
 143  0
         if(bindingInfo == null && StringUtils.isNotBlank(propertyName)){
 144  0
             if(StringUtils.isNotBlank(view.getDefaultBindingObjectPath())){
 145  0
                 value = ObjectPropertyUtils.getPropertyValue(model, view.getDefaultBindingObjectPath() + "." + propertyName);
 146  
             }
 147  
             else{
 148  0
                 value = ObjectPropertyUtils.getPropertyValue(model, propertyName);
 149  
             }
 150  
             
 151  
         }
 152  0
         else if(bindingInfo != null){
 153  0
             if(StringUtils.isNotBlank(bindingInfo.getBindingPath()) && !bindingInfo.getBindingPath().equals("null")){
 154  0
                 value = ObjectPropertyUtils.getPropertyValue(model, bindingInfo.getBindingPath());
 155  
             }
 156  
         }
 157  0
         return value;
 158  
     }
 159  
 
 160  
 }