org.kuali.rice.krad.uif.modifier
Class CompareFieldCreateModifier

java.lang.Object
  extended by org.kuali.rice.krad.uif.component.ConfigurableBase
      extended by org.kuali.rice.krad.uif.modifier.ComponentModifierBase
          extended by org.kuali.rice.krad.uif.modifier.CompareFieldCreateModifier
All Implemented Interfaces:
Serializable, Configurable, ComponentModifier, org.springframework.core.Ordered

public class CompareFieldCreateModifier
extends ComponentModifierBase

Generates Field instances to produce a comparison view among objects of the same type

Modifier is initialized with a List of ComparableInfo instances. For each comparable info, a copy of the configured group field is made and adjusted to the binding object path for the comparable. The comparison fields are ordered based on the configured order property of the comparable. In addition, a HeaderField can be generated to label each group of comparison fields.

Author:
Kuali Rice Team (rice.collab@kuali.org)
See Also:
Serialized Form

Field Summary
 
Fields inherited from interface org.kuali.rice.krad.uif.component.Ordered
INITIAL_ORDER_VALUE
 
Fields inherited from interface org.springframework.core.Ordered
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
 
Constructor Summary
CompareFieldCreateModifier()
           
 
Method Summary
 List<ComparableInfo> getComparables()
          List of ComparableInfo instances the compare fields should be generated for
 List<Component> getComponentPrototypes()
          List of components that are maintained by the modifier as prototypes for creating other component instances
 int getDefaultOrderSequence()
          Indicates the starting integer sequence value to use for ComparableInfo instances that do not have the order property set
 HeaderField getHeaderFieldPrototype()
          Prototype instance to use for creating the HeaderField for each group of comparison fields (if generateCompareHeaders is true)
protected  String getIdSuffix(ComparableInfo comparable, int index)
          Generates an id suffix for the comparable item
 Set<Class<? extends Component>> getSupportedComponents()
          Set of Component classes that may be sent to the modifier
 boolean isGenerateCompareHeaders()
          Indicates whether a HeaderField should be created for each group of comparison fields
 void performInitialization(View view, Object model, Component component)
          Calls ViewHelperService to initialize the header field prototype
 void performModification(View view, Object model, Component component)
          Generates the comparison fields
protected  void performValueComparison(Group group, Component compareItem, Object model, String compareValueObjectBindingPath)
          For each attribute field in the compare item, retrieves the field value and compares against the value for the main comparable.
 void setComparables(List<ComparableInfo> comparables)
          Setter for the list of comparable info instances
 void setDefaultOrderSequence(int defaultOrderSequence)
          Setter for the default sequence starting value
 void setGenerateCompareHeaders(boolean generateCompareHeaders)
          Setter for the generate comparison headers indicator
 void setHeaderFieldPrototype(HeaderField headerFieldPrototype)
          Setter for the header field prototype
 
Methods inherited from class org.kuali.rice.krad.uif.modifier.ComponentModifierBase
getOrder, getRunCondition, getRunPhase, setOrder, setRunCondition, setRunPhase
 
Methods inherited from class org.kuali.rice.krad.uif.component.ConfigurableBase
getPropertyExpression, getPropertyExpressions, setPropertyExpressions
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface org.kuali.rice.krad.uif.component.Configurable
getPropertyExpression, getPropertyExpressions, setPropertyExpressions
 

Constructor Detail

CompareFieldCreateModifier

public CompareFieldCreateModifier()
Method Detail

performInitialization

public void performInitialization(View view,
                                  Object model,
                                  Component component)
Calls ViewHelperService to initialize the header field prototype

Specified by:
performInitialization in interface ComponentModifier
Overrides:
performInitialization in class ComponentModifierBase
Parameters:
view - - View instance the component modifier is a part of
component - - Component the modifier is configured on
See Also:
ComponentModifier.performInitialization(org.kuali.rice.krad.uif.view.View, java.lang.Object, org.kuali.rice.krad.uif.component.Component)

performModification

public void performModification(View view,
                                Object model,
                                Component component)
Generates the comparison fields

First the configured List of ComparableInfo instances are sorted based on their order property. Then if generateCompareHeaders is set to true, a HeaderField is created for each comparable using the headerFieldPrototype and the headerText given by the comparable. Finally for each field configured on the Group, a corresponding comparison field is generated for each comparable and adjusted to the binding object path given by the comparable in addition to suffixing the id and setting the readOnly property

Parameters:
view - - the view instance to which the component belongs
model - - top level object containing the view data
component - - the component instance to modify
See Also:
ComponentModifier.performModification(org.kuali.rice.krad.uif.view.View, java.lang.Object, org.kuali.rice.krad.uif.component.Component)

performValueComparison

protected void performValueComparison(Group group,
                                      Component compareItem,
                                      Object model,
                                      String compareValueObjectBindingPath)
For each attribute field in the compare item, retrieves the field value and compares against the value for the main comparable. If the value is different, adds script to the field on ready event to add the change icon to the field and the containing group header

Parameters:
group - - group that contains the item and whose header will be highlighted for changes
compareItem - - the compare item being generated and to pull attribute fields from
model - - object containing the data
compareValueObjectBindingPath - - object path for the comparison item

getIdSuffix

protected String getIdSuffix(ComparableInfo comparable,
                             int index)
Generates an id suffix for the comparable item

If the idSuffix to use if configured on the ComparableInfo it will be used, else the given integer index will be used with an underscore

Parameters:
comparable - - comparable info to check for id suffix
index - - sequence integer
Returns:
String id suffix
See Also:
org.kuali.rice.krad.uif.modifier.ComparableInfo.getIdSuffix()

getSupportedComponents

public Set<Class<? extends Component>> getSupportedComponents()
Description copied from interface: ComponentModifier
Set of Component classes that may be sent to the modifier

If an empty or null list is returned, it is assumed the modifier supports all components. The returned set will be used by the dictionary validation

Returns:
Set component classes
See Also:
ComponentModifier.getSupportedComponents()

getComponentPrototypes

public List<Component> getComponentPrototypes()
Description copied from interface: ComponentModifier
List of components that are maintained by the modifier as prototypes for creating other component instances

Prototypes are held for configuring how a component should be created during the lifecycle. An example of this are the fields in a collection group that are created for each collection record. They only participate in the initialize phase.

Specified by:
getComponentPrototypes in interface ComponentModifier
Overrides:
getComponentPrototypes in class ComponentModifierBase
Returns:
List child component prototypes
See Also:
ComponentModifierBase.getComponentPrototypes()

getDefaultOrderSequence

public int getDefaultOrderSequence()
Indicates the starting integer sequence value to use for ComparableInfo instances that do not have the order property set

Returns:
int default sequence starting value

setDefaultOrderSequence

public void setDefaultOrderSequence(int defaultOrderSequence)
Setter for the default sequence starting value

Parameters:
defaultOrderSequence -

isGenerateCompareHeaders

public boolean isGenerateCompareHeaders()
Indicates whether a HeaderField should be created for each group of comparison fields

If set to true, for each group of comparison fields a header field will be created using the headerFieldPrototype configured on the modifier with the headerText property of the comparable

Returns:
boolean true if the headers should be created, false if no headers should be created

setGenerateCompareHeaders

public void setGenerateCompareHeaders(boolean generateCompareHeaders)
Setter for the generate comparison headers indicator

Parameters:
generateCompareHeaders -

getHeaderFieldPrototype

public HeaderField getHeaderFieldPrototype()
Prototype instance to use for creating the HeaderField for each group of comparison fields (if generateCompareHeaders is true)

Returns:
HeaderField header field prototype

setHeaderFieldPrototype

public void setHeaderFieldPrototype(HeaderField headerFieldPrototype)
Setter for the header field prototype

Parameters:
headerFieldPrototype -

getComparables

public List<ComparableInfo> getComparables()
List of ComparableInfo instances the compare fields should be generated for

For each comparable, a copy of the fields configured for the Group will be created for the comparison view

Returns:
List comparables to generate fields for

setComparables

public void setComparables(List<ComparableInfo> comparables)
Setter for the list of comparable info instances

Parameters:
comparables -


Copyright © 2005-2012 The Kuali Foundation. All Rights Reserved.