diff options
| author | mar-v-in <github@rvin.mooo.com> | 2014-08-14 12:22:02 +0200 | 
|---|---|---|
| committer | mar-v-in <github@rvin.mooo.com> | 2014-08-14 16:02:27 +0200 | 
| commit | ef2449917e53e312ebc2eb4bea7e3149ba9db137 (patch) | |
| tree | 58aff860c8c176b5191ae0863f38c60eb22f5878 /OpenKeychain | |
| parent | 62f7bf62150b460ee2dfa14f2c45f6df40d55cc9 (diff) | |
| download | open-keychain-ef2449917e53e312ebc2eb4bea7e3149ba9db137.tar.gz open-keychain-ef2449917e53e312ebc2eb4bea7e3149ba9db137.tar.bz2 open-keychain-ef2449917e53e312ebc2eb4bea7e3149ba9db137.zip | |
factor KeySpinner out
Diffstat (limited to 'OpenKeychain')
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java | 142 | ||||
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java | 4 | ||||
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java | 171 | ||||
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java | 48 | ||||
| -rw-r--r-- | OpenKeychain/src/main/res/layout/encrypt_asymmetric_fragment.xml | 2 | ||||
| -rw-r--r-- | OpenKeychain/src/main/res/layout/keyspinner_key.xml (renamed from OpenKeychain/src/main/res/layout/encrypt_asymmetric_signkey.xml) | 0 | 
6 files changed, 230 insertions, 137 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java index a402b6f68..41566cffc 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java @@ -47,6 +47,7 @@ import org.sufficientlysecure.keychain.provider.CachedPublicKeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.ui.widget.EncryptKeyCompletionView; +import org.sufficientlysecure.keychain.ui.widget.KeySpinner;  import org.sufficientlysecure.keychain.util.Log;  import java.util.ArrayList; @@ -54,22 +55,20 @@ import java.util.Iterator;  import java.util.List;  public class EncryptAsymmetricFragment extends Fragment implements EncryptActivityInterface.UpdateListener { -    public static final String ARG_SIGNATURE_KEY_ID = "signature_key_id"; -    public static final String ARG_ENCRYPTION_KEY_IDS = "encryption_key_ids"; -      ProviderHelper mProviderHelper;      // view -    private Spinner mSign; +    private KeySpinner mSign;      private EncryptKeyCompletionView mEncryptKeyView; -    private SelectSignKeyCursorAdapter mSignAdapter = new SelectSignKeyCursorAdapter();      // model      private EncryptActivityInterface mEncryptInterface;      @Override      public void onNotifyUpdate() { - +        if (mSign != null) { +            mSign.setSelectedKeyId(mEncryptInterface.getSignatureKey()); +        }      }      @Override @@ -101,8 +100,7 @@ public class EncryptAsymmetricFragment extends Fragment implements EncryptActivi      public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {          View view = inflater.inflate(R.layout.encrypt_asymmetric_fragment, container, false); -        mSign = (Spinner) view.findViewById(R.id.sign); -        mSign.setAdapter(mSignAdapter); +        mSign = (KeySpinner) view.findViewById(R.id.sign);          mSign.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {              @Override              public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { @@ -128,42 +126,6 @@ public class EncryptAsymmetricFragment extends Fragment implements EncryptActivi          // preselect keys given          preselectKeys(); -        getLoaderManager().initLoader(1, null, new LoaderManager.LoaderCallbacks<Cursor>() { -            @Override -            public Loader<Cursor> onCreateLoader(int id, Bundle args) { -                // This is called when a new Loader needs to be created. This -                // sample only has one Loader, so we don't care about the ID. -                Uri baseUri = KeyRings.buildUnifiedKeyRingsUri(); - -                // These are the rows that we will retrieve. -                String[] projection = new String[]{ -                        KeyRings._ID, -                        KeyRings.MASTER_KEY_ID, -                        KeyRings.KEY_ID, -                        KeyRings.USER_ID, -                        KeyRings.IS_EXPIRED, -                        KeyRings.HAS_SIGN, -                        KeyRings.HAS_ANY_SECRET -                }; - -                String where = KeyRings.HAS_ANY_SECRET + " = 1 AND " + KeyRings.HAS_SIGN + " NOT NULL AND " -                        + KeyRings.IS_REVOKED + " = 0 AND " + KeyRings.IS_EXPIRED + " = 0"; - -                // Now create and return a CursorLoader that will take care of -                // creating a Cursor for the data being displayed. -                return new CursorLoader(getActivity(), baseUri, projection, where, null, null); -            } - -            @Override -            public void onLoadFinished(Loader<Cursor> loader, Cursor data) { -                mSignAdapter.swapCursor(data); -            } - -            @Override -            public void onLoaderReset(Loader<Cursor> loader) { -                mSignAdapter.swapCursor(null); -            } -        });          mEncryptKeyView.setTokenListener(new TokenCompleteTextView.TokenListener() {              @Override              public void onTokenAdded(Object token) { @@ -194,6 +156,7 @@ public class EncryptAsymmetricFragment extends Fragment implements EncryptActivi                          KeyRings.buildUnifiedKeyRingUri(signatureKey));                  if(keyring.hasAnySecret()) {                      setSignatureKeyId(keyring.getMasterKeyId()); +                    mSign.setSelectedKeyId(mEncryptInterface.getSignatureKey());                  }              } catch (PgpGeneralException e) {                  Log.e(Constants.TAG, "key not found!", e); @@ -233,95 +196,4 @@ public class EncryptAsymmetricFragment extends Fragment implements EncryptActivi          setEncryptionKeyIds(keyIdsArr);          setEncryptionUserIds(userIds.toArray(new String[userIds.size()]));      } - -    private class SelectSignKeyCursorAdapter extends BaseAdapter implements SpinnerAdapter { -        private CursorAdapter inner; -        private int mIndexUserId; -        private int mIndexKeyId; -        private int mIndexMasterKeyId; - -        public SelectSignKeyCursorAdapter() { -            inner = new CursorAdapter(null, null, 0) { -                @Override -                public View newView(Context context, Cursor cursor, ViewGroup parent) { -                    return getActivity().getLayoutInflater().inflate(R.layout.encrypt_asymmetric_signkey, null); -                } - -                @Override -                public void bindView(View view, Context context, Cursor cursor) { -                    String[] userId = KeyRing.splitUserId(cursor.getString(mIndexUserId)); -                    ((TextView) view.findViewById(android.R.id.title)).setText(userId[2] == null ? userId[0] : (userId[0] + " (" + userId[2] + ")")); -                    ((TextView) view.findViewById(android.R.id.text1)).setText(userId[1]); -                    ((TextView) view.findViewById(android.R.id.text2)).setText(PgpKeyHelper.convertKeyIdToHex(cursor.getLong(mIndexKeyId))); -                } - -                @Override -                public long getItemId(int position) { -                    mCursor.moveToPosition(position); -                    return mCursor.getLong(mIndexMasterKeyId); -                } -            }; -        } - -        public Cursor swapCursor(Cursor newCursor) { -            if (newCursor == null) return inner.swapCursor(null); - -            mIndexKeyId = newCursor.getColumnIndex(KeyRings.KEY_ID); -            mIndexUserId = newCursor.getColumnIndex(KeyRings.USER_ID); -            mIndexMasterKeyId = newCursor.getColumnIndex(KeyRings.MASTER_KEY_ID); -            if (newCursor.moveToFirst()) { -                do { -                    if (newCursor.getLong(mIndexMasterKeyId) == mEncryptInterface.getSignatureKey()) { -                        mSign.setSelection(newCursor.getPosition() + 1); -                    } -                } while (newCursor.moveToNext()); -            } -            return inner.swapCursor(newCursor); -        } - -        @Override -        public int getCount() { -            return inner.getCount() + 1; -        } - -        @Override -        public Object getItem(int position) { -            if (position == 0) return null; -            return inner.getItem(position - 1); -        } - -        @Override -        public long getItemId(int position) { -            if (position == 0) return Constants.key.none; -            return inner.getItemId(position - 1); -        } - -        @Override -        public View getView(int position, View convertView, ViewGroup parent) { -            View v = getDropDownView(position, convertView, parent); -            v.findViewById(android.R.id.text1).setVisibility(View.GONE); -            return v; -        } - -        @Override -        public View getDropDownView(int position, View convertView, ViewGroup parent) { -            View v; -            if (position == 0) { -                if (convertView == null) { -                    v = inner.newView(null, null, parent); -                } else { -                    v = convertView; -                } -                ((TextView) v.findViewById(android.R.id.title)).setText("None"); -                v.findViewById(android.R.id.text1).setVisibility(View.GONE); -                v.findViewById(android.R.id.text2).setVisibility(View.GONE); -            } else { -                v = inner.getView(position - 1, convertView, parent); -                v.findViewById(android.R.id.text1).setVisibility(View.VISIBLE); -                v.findViewById(android.R.id.text2).setVisibility(View.VISIBLE); -            } -            return v; -        } -    } -  } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java index 20b9570bb..ceb3f665f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java @@ -111,7 +111,7 @@ public class EncryptKeyCompletionView extends TokenCompleteTextView {      protected void onAttachedToWindow() {          super.onAttachedToWindow();          if (getContext() instanceof FragmentActivity) { -            ((FragmentActivity) getContext()).getSupportLoaderManager().initLoader(0, null, new LoaderManager.LoaderCallbacks<Cursor>() { +            ((FragmentActivity) getContext()).getSupportLoaderManager().initLoader(hashCode(), null, new LoaderManager.LoaderCallbacks<Cursor>() {                  @Override                  public Loader<Cursor> onCreateLoader(int id, Bundle args) {                      // These are the rows that we will retrieve. @@ -143,6 +143,8 @@ public class EncryptKeyCompletionView extends TokenCompleteTextView {                      swapCursor(null);                  }              }); +        } else { +            Log.e(Constants.TAG, "EncryptKeyCompletionView must be attached to a FragmentActivity, this is " + getContext().getClass());          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java new file mode 100644 index 000000000..b8d83311a --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java @@ -0,0 +1,171 @@ +package org.sufficientlysecure.keychain.ui.widget; + +import android.content.Context; +import android.database.Cursor; +import android.os.Bundle; +import android.support.v4.app.FragmentActivity; +import android.support.v4.app.LoaderManager; +import android.support.v4.content.Loader; +import android.support.v4.widget.CursorAdapter; +import android.util.AttributeSet; +import android.view.View; +import android.view.ViewGroup; +import android.widget.BaseAdapter; +import android.widget.Spinner; +import android.widget.SpinnerAdapter; +import android.widget.TextView; + +import org.sufficientlysecure.keychain.Constants; +import org.sufficientlysecure.keychain.R; +import org.sufficientlysecure.keychain.pgp.KeyRing; +import org.sufficientlysecure.keychain.pgp.PgpKeyHelper; +import org.sufficientlysecure.keychain.provider.KeychainContract; +import org.sufficientlysecure.keychain.util.Log; + +public abstract class KeySpinner extends Spinner { +    private long mSelectedKeyId; +    private SelectKeyAdapter mAdapter = new SelectKeyAdapter(); + +    public KeySpinner(Context context) { +        super(context); +    } + +    public KeySpinner(Context context, AttributeSet attrs) { +        super(context, attrs); +    } + +    public KeySpinner(Context context, AttributeSet attrs, int defStyle) { +        super(context, attrs, defStyle); +    } + +    public abstract Loader<Cursor> onCreateLoader(); + +    @Override +    protected void onAttachedToWindow() { +        super.onAttachedToWindow(); +        setAdapter(mAdapter); +        if (getContext() instanceof FragmentActivity) { +            ((FragmentActivity) getContext()).getSupportLoaderManager().initLoader(hashCode(), null, new LoaderManager.LoaderCallbacks<Cursor>() { +                @Override +                public Loader<Cursor> onCreateLoader(int id, Bundle args) { +                    return KeySpinner.this.onCreateLoader(); +                } + +                @Override +                public void onLoadFinished(Loader<Cursor> loader, Cursor data) { +                    mAdapter.swapCursor(data); +                } + +                @Override +                public void onLoaderReset(Loader<Cursor> loader) { +                    mAdapter.swapCursor(null); +                } +            }); +        } else { +            Log.e(Constants.TAG, "KeySpinner must be attached to FragmentActivity, this is " + getContext().getClass()); +        } +    } + +    public long getSelectedKeyId() { +        return mSelectedKeyId; +    } + +    public void setSelectedKeyId(long selectedKeyId) { +        this.mSelectedKeyId = selectedKeyId; +    } + +    private class SelectKeyAdapter extends BaseAdapter implements SpinnerAdapter { +        private CursorAdapter inner; +        private int mIndexUserId; +        private int mIndexKeyId; +        private int mIndexMasterKeyId; + +        public SelectKeyAdapter() { +            inner = new CursorAdapter(null, null, 0) { +                @Override +                public View newView(Context context, Cursor cursor, ViewGroup parent) { +                    return View.inflate(getContext(), R.layout.keyspinner_key, null); +                } + +                @Override +                public void bindView(View view, Context context, Cursor cursor) { +                    String[] userId = KeyRing.splitUserId(cursor.getString(mIndexUserId)); +                    ((TextView) view.findViewById(android.R.id.title)).setText(userId[2] == null ? userId[0] : (userId[0] + " (" + userId[2] + ")")); +                    ((TextView) view.findViewById(android.R.id.text1)).setText(userId[1]); +                    ((TextView) view.findViewById(android.R.id.text2)).setText(PgpKeyHelper.convertKeyIdToHex(cursor.getLong(mIndexKeyId))); +                } + +                @Override +                public long getItemId(int position) { +                    mCursor.moveToPosition(position); +                    return mCursor.getLong(mIndexMasterKeyId); +                } +            }; +        } + +        public Cursor swapCursor(Cursor newCursor) { +            if (newCursor == null) return inner.swapCursor(null); + +            mIndexKeyId = newCursor.getColumnIndex(KeychainContract.KeyRings.KEY_ID); +            mIndexUserId = newCursor.getColumnIndex(KeychainContract.KeyRings.USER_ID); +            mIndexMasterKeyId = newCursor.getColumnIndex(KeychainContract.KeyRings.MASTER_KEY_ID); +            if (newCursor.moveToFirst()) { +                do { +                    if (newCursor.getLong(mIndexMasterKeyId) == mSelectedKeyId) { +                        setSelection(newCursor.getPosition() + 1); +                    } +                } while (newCursor.moveToNext()); +            } +            return inner.swapCursor(newCursor); +        } + +        @Override +        public int getCount() { +            return inner.getCount() + 1; +        } + +        @Override +        public Object getItem(int position) { +            if (position == 0) return null; +            return inner.getItem(position - 1); +        } + +        @Override +        public long getItemId(int position) { +            if (position == 0) return Constants.key.none; +            return inner.getItemId(position - 1); +        } + +        @Override +        public View getView(int position, View convertView, ViewGroup parent) { +            try { +                View v = getDropDownView(position, convertView, parent); +                v.findViewById(android.R.id.text1).setVisibility(View.GONE); +                return v; +            } catch (NullPointerException e) { +                // This is for the preview... +                return View.inflate(getContext(), android.R.layout.simple_list_item_1, null); +            } +        } + +        @Override +        public View getDropDownView(int position, View convertView, ViewGroup parent) { +            View v; +            if (position == 0) { +                if (convertView == null) { +                    v = inner.newView(null, null, parent); +                } else { +                    v = convertView; +                } +                ((TextView) v.findViewById(android.R.id.title)).setText("None"); +                v.findViewById(android.R.id.text1).setVisibility(View.GONE); +                v.findViewById(android.R.id.text2).setVisibility(View.GONE); +            } else { +                v = inner.getView(position - 1, convertView, parent); +                v.findViewById(android.R.id.text1).setVisibility(View.VISIBLE); +                v.findViewById(android.R.id.text2).setVisibility(View.VISIBLE); +            } +            return v; +        } +    } +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java new file mode 100644 index 000000000..cbec7f920 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java @@ -0,0 +1,48 @@ +package org.sufficientlysecure.keychain.ui.widget; + +import android.content.Context; +import android.database.Cursor; +import android.net.Uri; +import android.support.v4.content.CursorLoader; +import android.support.v4.content.Loader; +import android.util.AttributeSet; +import org.sufficientlysecure.keychain.provider.KeychainContract; + +public class SignKeySpinner extends KeySpinner { +    public SignKeySpinner(Context context) { +        super(context); +    } + +    public SignKeySpinner(Context context, AttributeSet attrs) { +        super(context, attrs); +    } + +    public SignKeySpinner(Context context, AttributeSet attrs, int defStyle) { +        super(context, attrs, defStyle); +    } + +    @Override +    public Loader<Cursor> onCreateLoader() { +        // This is called when a new Loader needs to be created. This +        // sample only has one Loader, so we don't care about the ID. +        Uri baseUri = KeychainContract.KeyRings.buildUnifiedKeyRingsUri(); + +        // These are the rows that we will retrieve. +        String[] projection = new String[]{ +                KeychainContract.KeyRings._ID, +                KeychainContract.KeyRings.MASTER_KEY_ID, +                KeychainContract.KeyRings.KEY_ID, +                KeychainContract.KeyRings.USER_ID, +                KeychainContract.KeyRings.IS_EXPIRED, +                KeychainContract.KeyRings.HAS_SIGN, +                KeychainContract.KeyRings.HAS_ANY_SECRET +        }; + +        String where = KeychainContract.KeyRings.HAS_ANY_SECRET + " = 1 AND " + KeychainContract.KeyRings.HAS_SIGN + " NOT NULL AND " +                + KeychainContract.KeyRings.IS_REVOKED + " = 0 AND " + KeychainContract.KeyRings.IS_EXPIRED + " = 0"; + +        // Now create and return a CursorLoader that will take care of +        // creating a Cursor for the data being displayed. +        return new CursorLoader(getContext(), baseUri, projection, where, null, null); +    } +} diff --git a/OpenKeychain/src/main/res/layout/encrypt_asymmetric_fragment.xml b/OpenKeychain/src/main/res/layout/encrypt_asymmetric_fragment.xml index 4d82477bc..2189a1f34 100644 --- a/OpenKeychain/src/main/res/layout/encrypt_asymmetric_fragment.xml +++ b/OpenKeychain/src/main/res/layout/encrypt_asymmetric_fragment.xml @@ -24,7 +24,7 @@              android:textAppearance="?android:attr/textAppearanceMedium"              android:text="@string/label_asymmetric_from" /> -        <Spinner +        <org.sufficientlysecure.keychain.ui.widget.SignKeySpinner              android:id="@+id/sign"              android:layout_width="match_parent"              android:layout_height="wrap_content" diff --git a/OpenKeychain/src/main/res/layout/encrypt_asymmetric_signkey.xml b/OpenKeychain/src/main/res/layout/keyspinner_key.xml index 703f9133b..703f9133b 100644 --- a/OpenKeychain/src/main/res/layout/encrypt_asymmetric_signkey.xml +++ b/OpenKeychain/src/main/res/layout/keyspinner_key.xml | 
