summaryrefslogtreecommitdiff
path: root/app/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/main/java')
-rw-r--r--app/src/main/java/com/zeapo/pwdstore/utils/PasswordRecyclerAdapter.java88
1 files changed, 73 insertions, 15 deletions
diff --git a/app/src/main/java/com/zeapo/pwdstore/utils/PasswordRecyclerAdapter.java b/app/src/main/java/com/zeapo/pwdstore/utils/PasswordRecyclerAdapter.java
index 2bcfd7ef..e72b9e07 100644
--- a/app/src/main/java/com/zeapo/pwdstore/utils/PasswordRecyclerAdapter.java
+++ b/app/src/main/java/com/zeapo/pwdstore/utils/PasswordRecyclerAdapter.java
@@ -1,10 +1,14 @@
package com.zeapo.pwdstore.utils;
import android.graphics.Color;
+import android.support.v7.app.AppCompatActivity;
+import android.support.v7.view.ActionMode;
import android.support.v7.widget.PopupMenu;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
+import android.util.SparseBooleanArray;
import android.view.LayoutInflater;
+import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
@@ -20,6 +24,8 @@ public class PasswordRecyclerAdapter extends RecyclerView.Adapter<PasswordRecycl
private final PasswordStore activity;
private final ArrayList<PasswordItem> values;
private final PasswordFragment.OnFragmentInteractionListener listener;
+ private final SparseBooleanArray selectedItems;
+ private ActionMode mActionMode;
// Provide a reference to the views for each data item
// Complex data items may need more than one view per item, and
@@ -44,6 +50,7 @@ public class PasswordRecyclerAdapter extends RecyclerView.Adapter<PasswordRecycl
this.values = values;
this.activity = activity;
this.listener = listener;
+ selectedItems = new SparseBooleanArray();
}
// Create new views (invoked by the layout manager)
@@ -89,33 +96,74 @@ public class PasswordRecyclerAdapter extends RecyclerView.Adapter<PasswordRecycl
holder.view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
- listener.onFragmentInteraction(pass);
+ if (mActionMode != null) {
+ toggleSelection(holder.position);
+ } else {
+ listener.onFragmentInteraction(pass);
+ }
}
});
holder.view.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
- PopupMenu p = new PopupMenu(activity, v);
- p.getMenuInflater().inflate(
- R.menu.context_pass, p.getMenu());
- p.show();
- p.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem menuItem) {
- if (menuItem.getItemId() == R.id.menu_delete_password) {
- activity.deletePassword(PasswordRecyclerAdapter.this, holder.position);
- }
- return false;
- }
- });
- return false;
+ if (mActionMode != null) {
+ return false;
+ }
+ toggleSelection(holder.position);
+ // Start the CAB using the ActionMode.Callback defined above
+ mActionMode = activity.startSupportActionMode(mActionModeCallback);
+ return true;
}
});
+ holder.view.setSelected(selectedItems.get(position));
}
+ private ActionMode.Callback mActionModeCallback = new ActionMode.Callback() {
+
+ // Called when the action mode is created; startActionMode() was called
+ @Override
+ public boolean onCreateActionMode(ActionMode mode, Menu menu) {
+ // Inflate a menu resource providing context menu items
+ mode.getMenuInflater().inflate(R.menu.context_pass, menu);
+ return true;
+ }
+
+ // Called each time the action mode is shown. Always called after onCreateActionMode, but
+ // may be called multiple times if the mode is invalidated.
+ @Override
+ public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
+ return false; // Return false if nothing is done
+ }
+
+ // Called when the user selects a contextual menu item
+ @Override
+ public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
+ switch (item.getItemId()) {
+ case R.id.menu_delete_password:
+ for (int i = 0; i < selectedItems.size(); i++) {
+ if (selectedItems.valueAt(i)) {
+ activity.deletePassword(PasswordRecyclerAdapter.this, selectedItems.keyAt(i));
+ }
+ }
+ mode.finish(); // Action picked, so close the CAB
+ return true;
+ default:
+ return false;
+ }
+ }
+
+ // Called when the user exits the action mode
+ @Override
+ public void onDestroyActionMode(ActionMode mode) {
+ selectedItems.clear();
+ mActionMode = null;
+ notifyDataSetChanged();
+ }
+ };
+
// Return the size of your dataset (invoked by the layout manager)
@Override
public int getItemCount() {
@@ -146,4 +194,14 @@ public class PasswordRecyclerAdapter extends RecyclerView.Adapter<PasswordRecycl
this.notifyItemRemoved(position);
}
+ public void toggleSelection(int pos) {
+ if (selectedItems.get(pos, false)) {
+ selectedItems.delete(pos);
+ }
+ else {
+ selectedItems.put(pos, true);
+ }
+ notifyItemChanged(pos);
+ }
+
} \ No newline at end of file