summaryrefslogtreecommitdiff
path: root/vdrmanager/src/de
diff options
context:
space:
mode:
Diffstat (limited to 'vdrmanager/src/de')
-rw-r--r--vdrmanager/src/de/bjusystems/vdrmanager/gui/EventAdapter.java47
1 files changed, 47 insertions, 0 deletions
diff --git a/vdrmanager/src/de/bjusystems/vdrmanager/gui/EventAdapter.java b/vdrmanager/src/de/bjusystems/vdrmanager/gui/EventAdapter.java
index 8b77fa6..052192f 100644
--- a/vdrmanager/src/de/bjusystems/vdrmanager/gui/EventAdapter.java
+++ b/vdrmanager/src/de/bjusystems/vdrmanager/gui/EventAdapter.java
@@ -1,6 +1,8 @@
package de.bjusystems.vdrmanager.gui;
import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
import java.util.List;
import android.content.Context;
@@ -61,6 +63,51 @@ abstract class EventAdapter extends ArrayAdapter<EventListItem> implements
items.add(object);
super.add(object);
}
+
+
+ void sort(int sortBy){
+
+ ArrayList<EventListItem> events = new ArrayList<EventListItem>(items);
+
+ if(sortBy == BaseEventListActivity.MENU_GROUP_ALPHABET){
+
+ Collections.sort(events, new Comparator<EventListItem>() {
+ @Override
+ public int compare(EventListItem lhs, EventListItem rhs) {
+ if(lhs == null || lhs.getTitle() == null){
+ return 1;
+ }
+ if(rhs == null || rhs.getTitle() == null){
+ return 0;
+ }
+ return lhs.getTitle().compareTo(rhs.getTitle());
+ }
+ });
+
+ } else if(sortBy == BaseEventListActivity.MENU_GROUP_TIME) {
+
+ Collections.sort(events, new Comparator<EventListItem>() {
+ @Override
+ public int compare(EventListItem lhs, EventListItem rhs) {
+ if(lhs == null || lhs.getStart() == null){
+ return 1;
+ }
+ if(rhs == null || rhs.getStart() == null){
+ return 0;
+ }
+ return lhs.getStart().compareTo(rhs.getStart());
+ }
+ });
+
+ }
+
+ clear();
+ for(EventListItem eli : events){
+ add(eli);
+ }
+
+ notifyDataSetChanged();
+ }
@Override
public int getItemViewType(int position) {