diff options
author | Raj Yengisetty <rajesh@cyngn.com> | 2015-03-11 18:04:08 -0700 |
---|---|---|
committer | Steve Kondik <steve@cyngn.com> | 2015-10-18 13:52:55 -0700 |
commit | 89002ba2ece50c3d1dde3a5e67184384960f8a5c (patch) | |
tree | 2d0ae6954070e3581d48ff72a87fafc6e80751b8 /src | |
parent | 4d1090788f07fc0a17a2d6de0d95e3fd11706ba5 (diff) | |
download | android_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.java | 20 |
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; } }; |