// ImportDuplicateComparator
package org.javamoney.examples.ez.money.gui.table.comparator;
import static org.javamoney.examples.ez.money.gui.table.ImportDuplicateTable.AMOUNT_COLUMN;
import static org.javamoney.examples.ez.money.gui.table.ImportDuplicateTable.CHECK_NUMBER_COLUMN;
import static org.javamoney.examples.ez.money.gui.table.ImportDuplicateTable.DATE_COLUMN;
import static org.javamoney.examples.ez.money.utility.TransactionCompareHelper.compareAmounts;
import static org.javamoney.examples.ez.money.utility.TransactionCompareHelper.compareCheckNumbers;
import static org.javamoney.examples.ez.money.utility.TransactionCompareHelper.compareDates;
import static org.javamoney.examples.ez.money.utility.TransactionCompareHelper.comparePayees;
import org.javamoney.examples.ez.money.model.persisted.transaction.Transaction;
import org.javamoney.examples.ez.common.gui.table.DataTableComparator;
/**
* This class facilitates comparing transactions in a table.
*/
public
final
class
ImportDuplicateComparator
extends DataTableComparator<Transaction>
{
/**
* Constructs a new comparator.
*/
public
ImportDuplicateComparator()
{
super(DATE_COLUMN);
}
/**
* This method compares two transactions.
*
* @param trans1 A transaction to compare.
* @param trans2 A transaction to compare.
*
* @return The result of comparing two transactions.
*/
@Override
public
int
compare(Transaction trans1, Transaction trans2)
{
int result = 0;
if(getColumn() == CHECK_NUMBER_COLUMN)
{
result = compareCheckNumbers(trans1, trans2, invertSort());
}
else if(getColumn() == DATE_COLUMN)
{
result = compareDates(trans1, trans2, invertSort());
}
else if(getColumn() == AMOUNT_COLUMN)
{
result = compareAmounts(trans1, trans2, invertSort());
}
else
{
result = comparePayees(trans1, trans2, invertSort());
}
return result;
}
}