aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main/java
diff options
context:
space:
mode:
authorDominik Schürmann <dominik@dominikschuermann.de>2014-10-08 14:42:56 +0200
committerDominik Schürmann <dominik@dominikschuermann.de>2014-10-08 14:42:56 +0200
commitadcc07ca653db0c8a392a8dd7d75d254bd4cdbc1 (patch)
tree4a19e1cc7560ae84a074fb716a81240bacf956c4 /OpenKeychain/src/main/java
parent678265483a9ec7457dd75bfdaba02bf8e981b6a5 (diff)
downloadopen-keychain-adcc07ca653db0c8a392a8dd7d75d254bd4cdbc1.tar.gz
open-keychain-adcc07ca653db0c8a392a8dd7d75d254bd4cdbc1.tar.bz2
open-keychain-adcc07ca653db0c8a392a8dd7d75d254bd4cdbc1.zip
Filter key list by certified keys
Diffstat (limited to 'OpenKeychain/src/main/java')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java51
1 files changed, 51 insertions, 0 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java
index 8c4278835..4024ee7fe 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java
@@ -49,9 +49,11 @@ import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AbsListView.MultiChoiceModeListener;
import android.widget.AdapterView;
+import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.ListView;
+import android.widget.Spinner;
import android.widget.TextView;
import org.sufficientlysecure.keychain.Constants;
@@ -68,8 +70,10 @@ import org.sufficientlysecure.keychain.ui.util.Highlighter;
import org.sufficientlysecure.keychain.util.Log;
import org.sufficientlysecure.keychain.ui.util.Notify;
+import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
+import java.util.List;
import se.emilsjolander.stickylistheaders.StickyListHeadersAdapter;
import se.emilsjolander.stickylistheaders.StickyListHeadersListView;
@@ -85,10 +89,13 @@ public class KeyListFragment extends LoaderFragment
private KeyListAdapter mAdapter;
private StickyListHeadersListView mStickyList;
private ListAwareSwipeRefreshLayout mSwipeRefreshLayout;
+ private Spinner mFilterSpinner;
// saves the mode object for multiselect, needed for reset at some point
private ActionMode mActionMode = null;
+ private boolean mShowAllKeys = false;
+
private String mQuery;
private SearchView mSearchView;
// empty list layout
@@ -213,6 +220,42 @@ public class KeyListFragment extends LoaderFragment
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
+ mFilterSpinner = (Spinner) getActivity().findViewById(R.id.key_list_filter_spinner);
+ List<String> list = new ArrayList<String>();
+ list.add(getString(R.string.key_list_filter_show_certified));
+ list.add(getString(R.string.key_list_filter_show_all));
+
+ ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>
+ (getActivity(), android.R.layout.simple_spinner_item, list);
+
+ dataAdapter.setDropDownViewResource
+ (android.R.layout.simple_spinner_dropdown_item);
+
+ mFilterSpinner.setAdapter(dataAdapter);
+
+ mFilterSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
+ @Override
+ public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
+ switch (position) {
+ case 0: {
+ mShowAllKeys = false;
+ getLoaderManager().restartLoader(0, null, KeyListFragment.this);
+ break;
+ }
+ case 1: {
+ mShowAllKeys = true;
+ getLoaderManager().restartLoader(0, null, KeyListFragment.this);
+ break;
+ }
+ }
+ }
+
+ @Override
+ public void onNothingSelected(AdapterView<?> parent) {
+
+ }
+ });
+
mStickyList.setOnItemClickListener(this);
mStickyList.setAreHeadersSticky(true);
mStickyList.setDrawingListUnderStickyHeader(false);
@@ -355,6 +398,14 @@ public class KeyListFragment extends LoaderFragment
whereArgs[i] = "%" + words[i] + "%";
}
}
+ if (!mShowAllKeys) {
+ if (where == null) {
+ where = "";
+ } else {
+ where += " AND ";
+ }
+ where += KeyRings.VERIFIED + " != 0";
+ }
// Now create and return a CursorLoader that will take care of
// creating a Cursor for the data being displayed.