All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jidesoft.grouper.ObjectGrouper Maven / Gradle / Ivy

package com.jidesoft.grouper;

import com.jidesoft.comparator.ComparatorContext;
import com.jidesoft.converter.ConverterContext;

/**
 * An interface that can convert a object to a group so that the objects that has the same group can be grouped
 * together. We suggest you extends {@link com.jidesoft.grouper.AbstractObjectGrouper} if you want to create your own
 * ObjectGrouper in case we add new methods to this interface due to requirement changes.
 */
public interface ObjectGrouper {
    /**
     * Gets the group value after this value is grouped. If two objects return the same value in this getGroupValue
     * method, the two objects are considered as one group. We assume all values returned from this method are of the
     * same type which is returned in {@link #getType()}.
     *
     * @param value the value
     * @return the value after grouped.
     */
    Object getValue(Object value);

    /**
     * Gets the group value type. It should be the type of the value that is returned from the getGroupValue.
     *
     * @return the group value type.
     */
    Class getType();

    /**
     * Gets the name of this object grouper.
     *
     * @return the name of this grouper.
     */
    String getName();

    /**
     * Gets the converter context for the value returned from this object grouper. This converter context will be used
     * to find the ObjectConverter that will convert the value returned from {@link #getValue(Object)} method to String
     * so that it can be displayed somewhere.
     *
     * @return the converter context.
     */
    ConverterContext getConverterContext();

    /**
     * Gets the comparator context for the value returned from this object grouper. This comparator context will be used
     * to find the ObjectComparator that will sort the values return from {@link #getValue(Object)} method whenever
     * sorting is needed.
     *
     * @return the converter context.
     */
    ComparatorContext getComparatorContext();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy