aboutsummaryrefslogtreecommitdiffstats
path: root/main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java
diff options
context:
space:
mode:
authorBananeweizen <bananeweizen@gmx.de>2013-12-16 15:07:55 +0100
committerBananeweizen <bananeweizen@gmx.de>2013-12-16 15:07:55 +0100
commit755c21382c08953db22dc7ed958f72eff6760632 (patch)
treecaef20ceaec163e5b1f255db005e504b30d6cb93 /main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java
parent4e22020a306bbb0e3695eb2a7f4386df113dae34 (diff)
downloadcgeo-755c21382c08953db22dc7ed958f72eff6760632.zip
cgeo-755c21382c08953db22dc7ed958f72eff6760632.tar.gz
cgeo-755c21382c08953db22dc7ed958f72eff6760632.tar.bz2
refactoring: remove duplicated preferences
Diffstat (limited to 'main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java')
-rw-r--r--main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java105
1 files changed, 11 insertions, 94 deletions
diff --git a/main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java b/main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java
index 724ab80..434f7d7 100644
--- a/main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java
+++ b/main/src/cgeo/geocaching/settings/CheckGcCredentialsPreference.java
@@ -1,28 +1,14 @@
package cgeo.geocaching.settings;
-import cgeo.geocaching.R;
-import cgeo.geocaching.activity.ActivityMixin;
import cgeo.geocaching.connector.gc.Login;
import cgeo.geocaching.enumerations.StatusCode;
-import cgeo.geocaching.network.Cookies;
-import cgeo.geocaching.utils.Log;
-import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.tuple.ImmutablePair;
-import android.annotation.SuppressLint;
-import android.app.ProgressDialog;
import android.content.Context;
-import android.content.res.Resources;
-import android.graphics.drawable.Drawable;
-import android.os.Handler;
-import android.os.Message;
-import android.preference.Preference;
import android.util.AttributeSet;
-import android.view.View;
-import android.view.ViewGroup;
-public class CheckGcCredentialsPreference extends Preference {
+public class CheckGcCredentialsPreference extends AbstractCheckCredentialsPreference {
public CheckGcCredentialsPreference(Context context) {
super(context);
@@ -37,87 +23,18 @@ public class CheckGcCredentialsPreference extends Preference {
}
@Override
- protected View onCreateView(ViewGroup parent) {
- setOnPreferenceClickListener(GC_LOGIN_CHECK);
- return super.onCreateView(parent);
+ protected ImmutablePair<String, String> getCredentials() {
+ return Settings.getGcLogin();
}
- private final GcLoginCheck GC_LOGIN_CHECK = new GcLoginCheck();
-
- private class GcLoginCheck implements OnPreferenceClickListener {
- private Resources res;
- private SettingsActivity activity;
-
- private ProgressDialog loginDialog;
- @SuppressLint("HandlerLeak")
- private Handler logInHandler = new Handler() {
- @Override
- public void handleMessage(Message msg) {
- try {
- if (loginDialog != null && loginDialog.isShowing()) {
- loginDialog.dismiss();
- }
-
- if (msg.obj == null || (msg.obj instanceof Drawable)) {
- ActivityMixin.helpDialog(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_ok),
- (Drawable) msg.obj);
- } else {
- ActivityMixin.helpDialog(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_failed_reason)
- + " "
- + ((StatusCode) msg.obj).getErrorString(res)
- + ".");
- }
- } catch (Exception e) {
- ActivityMixin.showToast(activity, R.string.err_login_failed);
- Log.e("SettingsActivity.logInHandler", e);
- } finally {
- if (loginDialog != null && loginDialog.isShowing()) {
- loginDialog.dismiss();
- }
- // enable/disable basic member preferences
- activity.initBasicMemberPreferences();
- }
- }
- };
-
- @Override
- public boolean onPreferenceClick(Preference preference) {
- this.activity = (SettingsActivity) CheckGcCredentialsPreference.this.getContext();
- this.res = activity.getResources();
-
- ImmutablePair<String, String> credentials = Settings.getGcLogin();
-
- // check credentials for validity
- if (StringUtils.isBlank(credentials.getLeft())
- || StringUtils.isBlank(credentials.getRight())) {
- ActivityMixin.showToast(activity, R.string.err_missing_auth);
- return false;
- }
-
- loginDialog = ProgressDialog.show(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_working), true);
- loginDialog.setCancelable(false);
- Cookies.clearCookies();
-
- (new Thread() {
- @Override
- public void run() {
- final StatusCode loginResult = Login.login();
- Object payload = loginResult;
- if (loginResult == StatusCode.NO_ERROR) {
- Login.detectGcCustomDate();
- payload = Login.downloadAvatarAndGetMemberStatus();
- }
- logInHandler.obtainMessage(0, payload).sendToTarget();
- }
- }).start();
-
- return false; // no shared preference has to be changed
+ @Override
+ protected Object login() {
+ final StatusCode loginResult = Login.login();
+ Object payload = loginResult;
+ if (loginResult == StatusCode.NO_ERROR) {
+ Login.detectGcCustomDate();
+ payload = Login.downloadAvatarAndGetMemberStatus();
}
+ return payload;
}
}