aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog
diff options
context:
space:
mode:
authorgogowitczak <gogowitczak@gmail.com>2014-04-08 23:59:41 +0200
committergogowitczak <gogowitczak@gmail.com>2014-04-08 23:59:41 +0200
commit19cab919afd26c14d4df214f51ae05c49432e1d1 (patch)
tree5447ca46d265814df53ee20b48d731d22f38c977 /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog
parent946c1e115cbf35cc7f4eae7c2480501892e86c0a (diff)
downloadopen-keychain-19cab919afd26c14d4df214f51ae05c49432e1d1.tar.gz
open-keychain-19cab919afd26c14d4df214f51ae05c49432e1d1.tar.bz2
open-keychain-19cab919afd26c14d4df214f51ae05c49432e1d1.zip
Modified Spinner values for CreateKeyDialog. Added info for user about custom key length restrictions.
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/CreateKeyDialogFragment.java121
1 files changed, 84 insertions, 37 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/CreateKeyDialogFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/CreateKeyDialogFragment.java
index 78223379b..183f569f1 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/CreateKeyDialogFragment.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/CreateKeyDialogFragment.java
@@ -20,6 +20,7 @@ package org.sufficientlysecure.keychain.ui.dialog;
import android.app.AlertDialog;
import android.app.Dialog;
import android.content.DialogInterface;
+import android.os.Build;
import android.os.Bundle;
import android.support.v4.app.DialogFragment;
import android.support.v4.app.FragmentActivity;
@@ -37,6 +38,7 @@ import org.sufficientlysecure.keychain.R;
import org.sufficientlysecure.keychain.util.Choice;
import java.util.ArrayList;
+import java.util.Arrays;
public class CreateKeyDialogFragment extends DialogFragment {
@@ -53,6 +55,7 @@ public class CreateKeyDialogFragment extends DialogFragment {
private Spinner mKeySizeSpinner;
private TextView mCustomKeyTextView;
private EditText mCustomKeyEditText;
+ private TextView mCustomKeyInfoTextView;
public void setOnAlgorithmSelectedListener(OnAlgorithmSelectedListener listener) {
mAlgorithmSelectedListener = listener;
@@ -110,32 +113,16 @@ public class CreateKeyDialogFragment extends DialogFragment {
}
mKeySizeSpinner = (Spinner) view.findViewById(R.id.create_key_size);
- ArrayAdapter<CharSequence> keySizeAdapter = ArrayAdapter.createFromResource(
- context, R.array.key_size_spinner_values,
- android.R.layout.simple_spinner_item);
- keySizeAdapter
- .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
+ // dynamic ArrayAdapter must be created (instead of ArrayAdapter.getFromResource), because it's content may change
+ ArrayAdapter<CharSequence> keySizeAdapter = new ArrayAdapter<CharSequence>(context, android.R.layout.simple_spinner_item,
+ new ArrayList<CharSequence>(Arrays.asList(getResources().getStringArray(R.array.rsa_key_size_spinner_values))));
+ keySizeAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
mKeySizeSpinner.setAdapter(keySizeAdapter);
- mKeySizeSpinner.setSelection(3); // Default to 4096 for the key length
+ mKeySizeSpinner.setSelection(1); // Default to 4096 for the key length
mCustomKeyTextView = (TextView) view.findViewById(R.id.custom_key_size_label);
mCustomKeyEditText = (EditText) view.findViewById(R.id.custom_key_size_input);
-
- final AdapterView.OnItemSelectedListener customKeySelectedLisener = new AdapterView.OnItemSelectedListener() {
- @Override
- public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
- final String selectedItemString = (String) parent.getSelectedItem();
- final String customLengthString = getResources().getString(R.string.key_size_custom);
- final boolean customSelected = customLengthString.equals(selectedItemString);
- final int visibility = customSelected ? View.VISIBLE : View.GONE;
- mCustomKeyEditText.setVisibility(visibility);
- mCustomKeyTextView.setVisibility(visibility);
- }
-
- @Override
- public void onNothingSelected(AdapterView<?> parent) {
- }
- };
+ mCustomKeyInfoTextView = (TextView) view.findViewById(R.id.custom_key_size_info);
dialog.setPositiveButton(android.R.string.ok,
new DialogInterface.OnClickListener() {
@@ -158,37 +145,46 @@ public class CreateKeyDialogFragment extends DialogFragment {
final AlertDialog alertDialog = dialog.create();
- final AdapterView.OnItemSelectedListener weakRsaListener = new AdapterView.OnItemSelectedListener() {
+ mCustomKeyEditText.addTextChangedListener(new TextWatcher() {
@Override
- public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
- if (mKeySizeSpinner == parent) {
- customKeySelectedLisener.onItemSelected(parent, view, position, id);
- }
- setOkButtonAvailability(alertDialog);
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
- public void onNothingSelected(AdapterView<?> parent) {
+ public void onTextChanged(CharSequence s, int start, int before, int count) {
}
- };
- mCustomKeyEditText.addTextChangedListener(new TextWatcher() {
@Override
- public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+ public void afterTextChanged(Editable s) {
+ setOkButtonAvailability(alertDialog);
}
+ });
+ mKeySizeSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
- public void onTextChanged(CharSequence s, int start, int before, int count) {
+ public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
+ setCustomKeyVisibility();
+ setOkButtonAvailability(alertDialog);
}
@Override
- public void afterTextChanged(Editable s) {
- setOkButtonAvailability(alertDialog);
+ public void onNothingSelected(AdapterView<?> parent) {
}
});
- mKeySizeSpinner.setOnItemSelectedListener(weakRsaListener);
- mAlgorithmSpinner.setOnItemSelectedListener(weakRsaListener);
+ mAlgorithmSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
+ @Override
+ public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
+ setKeyLengthSpinnerValuesForAlgorithm(((Choice) parent.getSelectedItem()).getId());
+
+ setCustomKeyVisibility();
+ setOkButtonAvailability(alertDialog);
+ }
+
+ @Override
+ public void onNothingSelected(AdapterView<?> parent) {
+ }
+ });
return alertDialog;
}
@@ -263,4 +259,55 @@ public class CreateKeyDialogFragment extends DialogFragment {
alertDialog.getButton(AlertDialog.BUTTON_POSITIVE).setEnabled(properKeyLength > 0);
}
+ private void setCustomKeyVisibility() {
+ final String selectedItemString = (String) mKeySizeSpinner.getSelectedItem();
+ final String customLengthString = getResources().getString(R.string.key_size_custom);
+ final boolean customSelected = customLengthString.equals(selectedItemString);
+ final int visibility = customSelected ? View.VISIBLE : View.GONE;
+
+ mCustomKeyEditText.setVisibility(visibility);
+ mCustomKeyTextView.setVisibility(visibility);
+ mCustomKeyInfoTextView.setVisibility(visibility);
+ }
+
+ private void setKeyLengthSpinnerValuesForAlgorithm(int algorithmId) {
+ final ArrayAdapter<CharSequence> keySizeAdapter = (ArrayAdapter<CharSequence>) mKeySizeSpinner.getAdapter();
+ final Object selectedItem = mKeySizeSpinner.getSelectedItem();
+ keySizeAdapter.clear();
+ switch (algorithmId) {
+ case Id.choice.algorithm.rsa:
+ replaceArrayAdapterContent(keySizeAdapter, R.array.rsa_key_size_spinner_values);
+ mCustomKeyInfoTextView.setText(getResources().getString(R.string.key_size_custom_info_rsa));
+ break;
+ case Id.choice.algorithm.elgamal:
+ replaceArrayAdapterContent(keySizeAdapter, R.array.elgamal_key_size_spinner_values);
+ mCustomKeyInfoTextView.setText(""); // ElGamal does not support custom key length
+ break;
+ case Id.choice.algorithm.dsa:
+ replaceArrayAdapterContent(keySizeAdapter, R.array.dsa_key_size_spinner_values);
+ mCustomKeyInfoTextView.setText(getResources().getString(R.string.key_size_custom_info_dsa));
+ break;
+ }
+ keySizeAdapter.notifyDataSetChanged();
+
+ // when switching algorithm, try to select same key length as before
+ for (int i = 0; i < keySizeAdapter.getCount(); i++) {
+ if (selectedItem.equals(keySizeAdapter.getItem(i))) {
+ mKeySizeSpinner.setSelection(i);
+ break;
+ }
+ }
+ }
+
+ private void replaceArrayAdapterContent(ArrayAdapter<CharSequence> arrayAdapter, int stringArrayResourceId) {
+ final String[] spinnerValuesStringArray = getResources().getStringArray(stringArrayResourceId);
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
+ arrayAdapter.addAll(spinnerValuesStringArray);
+ } else {
+ for (final String value : spinnerValuesStringArray) {
+ arrayAdapter.add(value);
+ }
+ }
+ }
+
}