import java.text.NumberFormat;
import java.util.ArrayList;
+import java.util.Collections;
import javax.swing.table.AbstractTableModel;
import tim.prune.I18nManager;
import tim.prune.config.Config;
-import tim.prune.data.Distance;
+import tim.prune.data.Unit;
+import tim.prune.function.search.SearchResult;
/**
* Model for list of tracks from gpsies.com
public class TrackListModel extends AbstractTableModel
{
/** List of tracks */
- private ArrayList<GpsiesTrack> _trackList = null;
+ private ArrayList<SearchResult> _trackList = null;
/** Column heading for track name */
private String _nameColLabel = null;
/** Column heading for length */
return _trackList.size();
}
+ /** @return true if there are no rows */
+ public boolean isEmpty()
+ {
+ return getRowCount() == 0;
+ }
+
/**
* @param inColNum column number
* @return column label for given column
*/
public Object getValueAt(int inRowNum, int inColNum)
{
- GpsiesTrack track = _trackList.get(inRowNum);
+ SearchResult track = _trackList.get(inRowNum);
if (inColNum == 0) {return track.getTrackName();}
double lengthM = track.getLength();
- if (Config.getConfigBoolean(Config.KEY_METRIC_UNITS)) {
- return _distanceFormatter.format(lengthM / 1000.0) + " " + I18nManager.getText("units.kilometres.short");
- }
- // must be imperial
- return _distanceFormatter.format(Distance.convertMetresToMiles(lengthM))
- + " " + I18nManager.getText("units.miles.short");
+ // convert to current distance units
+ Unit distUnit = Config.getUnitSet().getDistanceUnit();
+ double length = lengthM * distUnit.getMultFactorFromStd();
+ // Make text
+ return _distanceFormatter.format(length) + " " + I18nManager.getText(distUnit.getShortnameKey());
}
/**
* Add a list of tracks to this model
* @param inList list of tracks to add
*/
- public void addTracks(ArrayList<GpsiesTrack> inList)
+ public void addTracks(ArrayList<SearchResult> inList)
+ {
+ addTracks(inList, false);
+ }
+
+ /**
+ * Add a list of tracks to this model and optionally sort them
+ * @param inList list of tracks to add
+ * @param inSort true to sort results after adding
+ */
+ public void addTracks(ArrayList<SearchResult> inList, boolean inSort)
{
- if (_trackList == null) {_trackList = new ArrayList<GpsiesTrack>();}
- if (inList != null && inList.size() > 0) {
+ if (_trackList == null) {_trackList = new ArrayList<SearchResult>();}
+ final int prevCount = _trackList.size();
+ if (inList != null && inList.size() > 0)
+ {
_trackList.addAll(inList);
+ if (inSort) {
+ Collections.sort(_trackList);
+ }
}
- fireTableDataChanged();
+ final int updatedCount = _trackList.size();
+ if (prevCount <= 0)
+ fireTableDataChanged();
+ else
+ fireTableRowsInserted(prevCount, updatedCount-1);
}
/**
* @param inRowNum row number from 0
* @return track object for this row
*/
- public GpsiesTrack getTrack(int inRowNum)
+ public SearchResult getTrack(int inRowNum)
{
return _trackList.get(inRowNum);
}