package com.boardgamegeek.filterer;
import android.content.Context;
import android.support.annotation.NonNull;
import com.boardgamegeek.R;
import com.boardgamegeek.provider.BggContract.Collection;
import com.boardgamegeek.util.MathUtils;
import com.boardgamegeek.util.StringUtils;
public class PlayCountFilterer extends CollectionFilterer {
public static final int MIN_RANGE = 0;
public static final int MAX_RANGE = 25;
private int min;
private int max;
public PlayCountFilterer(Context context) {
super(context);
}
public PlayCountFilterer(@NonNull Context context, int min, int max) {
super(context);
this.min = min;
this.max = max;
}
@Override
public void setData(@NonNull String data) {
String[] d = data.split(DELIMITER);
min = d.length > 0 ? MathUtils.constrain(StringUtils.parseInt(d[0], MIN_RANGE), MIN_RANGE, MAX_RANGE) : MIN_RANGE;
max = d.length > 1 ? MathUtils.constrain(StringUtils.parseInt(d[1], MAX_RANGE), MIN_RANGE, MAX_RANGE) : MAX_RANGE;
}
@Override
public int getTypeResourceId() {
return R.string.collection_filter_type_play_count;
}
@NonNull
@Override
public String flatten() {
return String.valueOf(min) + DELIMITER + String.valueOf(max);
}
public int getMax() {
return max;
}
public int getMin() {
return min;
}
@Override
public String getDisplayText() {
String text;
if (max >= MAX_RANGE) {
text = min + "+";
} else if (min == max) {
text = String.valueOf(max);
} else {
text = min + "-" + max;
}
return text + " " + context.getString(R.string.plays);
}
@Override
public String getSelection() {
String selection;
if (max >= MAX_RANGE) {
selection = Collection.NUM_PLAYS + ">=?";
} else {
selection = "(" + Collection.NUM_PLAYS + ">=? AND " + Collection.NUM_PLAYS + "<=?)";
}
return selection;
}
@Override
public String[] getSelectionArgs() {
if (max >= MAX_RANGE) {
return new String[] { String.valueOf(min) };
} else {
return new String[] { String.valueOf(min), String.valueOf(max) };
}
}
}