summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorRaj Yengisetty <rajesh@cyngn.com>2015-03-11 18:04:08 -0700
committerSteve Kondik <steve@cyngn.com>2015-10-18 13:52:55 -0700
commit89002ba2ece50c3d1dde3a5e67184384960f8a5c (patch)
tree2d0ae6954070e3581d48ff72a87fafc6e80751b8 /src
parent4d1090788f07fc0a17a2d6de0d95e3fd11706ba5 (diff)
downloadandroid_packages_apps_Calendar-89002ba2ece50c3d1dde3a5e67184384960f8a5c.tar.gz
android_packages_apps_Calendar-89002ba2ece50c3d1dde3a5e67184384960f8a5c.tar.bz2
android_packages_apps_Calendar-89002ba2ece50c3d1dde3a5e67184384960f8a5c.zip
Calendar: add feature to select/deselect all events in delete view
Change-Id: I1301d921474d848d6c877eb904bd7a00df13c48a
Diffstat (limited to 'src')
-rw-r--r--src/com/android/calendar/DeleteEventsActivity.java20
1 files changed, 19 insertions, 1 deletions
diff --git a/src/com/android/calendar/DeleteEventsActivity.java b/src/com/android/calendar/DeleteEventsActivity.java
index da2b6bc5..fbab524d 100644
--- a/src/com/android/calendar/DeleteEventsActivity.java
+++ b/src/com/android/calendar/DeleteEventsActivity.java
@@ -108,6 +108,8 @@ public class DeleteEventsActivity extends ListActivity
private AsyncQueryService mService;
private TextView mHeaderTextView;
+ private boolean mIgnoreSelections = false;
+
private Map<Long, Long> mSelectedMap = new HashMap<Long, Long>();
private Map<Long, String> mCalendarsMap = new HashMap<Long, String>();
private List<Long> mEventList = new ArrayList<Long>();
@@ -255,6 +257,10 @@ public class DeleteEventsActivity extends ListActivity
@Override
public void onItemCheckedStateChanged(ActionMode mode, int position,
long id, boolean checked) {
+ // We're updating selections manually ignore changes
+ if (mIgnoreSelections) {
+ return;
+ }
int firstVisiblePosition = mListView.getFirstVisiblePosition();
int actualPosition = position - firstVisiblePosition;
@@ -301,6 +307,16 @@ public class DeleteEventsActivity extends ListActivity
: R.string.no_events, Toast.LENGTH_SHORT).show();
}
return true;
+ case R.id.select_all_check:
+ mIgnoreSelections = true;
+ if (item.isChecked()) {
+ selectNone();
+ } else {
+ selectAll();
+ }
+ mIgnoreSelections = false;
+ invalidateOptionsMenu();
+ return true;
}
return false;
}
@@ -316,7 +332,9 @@ public class DeleteEventsActivity extends ListActivity
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
// Here you can perform updates to the CAB due to
// an invalidate() request
- return false;
+ MenuItem selectAllItem = menu.findItem(R.id.select_all_check);
+ selectAllItem.setChecked(mSelectedMap.size() == mEventList.size());
+ return true;
}
};