|
|
@ -247,12 +247,13 @@ public class FragmentQuickSetup extends FragmentBase {
|
|
|
|
btnManual.setOnClickListener(new View.OnClickListener() {
|
|
|
|
btnManual.setOnClickListener(new View.OnClickListener() {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void onClick(View v) {
|
|
|
|
public void onClick(View v) {
|
|
|
|
FragmentBase fragment = new FragmentAccount();
|
|
|
|
finish();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
FragmentAccount fragment = new FragmentAccount();
|
|
|
|
fragment.setArguments(new Bundle());
|
|
|
|
fragment.setArguments(new Bundle());
|
|
|
|
FragmentTransaction fragmentTransaction = getParentFragmentManager().beginTransaction();
|
|
|
|
FragmentTransaction fragmentTransaction = getParentFragmentManager().beginTransaction();
|
|
|
|
fragmentTransaction.replace(R.id.content_frame, fragment).addToBackStack("account");
|
|
|
|
fragmentTransaction.replace(R.id.content_frame, fragment).addToBackStack("account");
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
finish();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
@ -294,10 +295,43 @@ public class FragmentQuickSetup extends FragmentBase {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void onSave(boolean check) {
|
|
|
|
private void onSave(boolean check) {
|
|
|
|
|
|
|
|
String name = etName.getText().toString().trim();
|
|
|
|
|
|
|
|
String email = etEmail.getText().toString().trim();
|
|
|
|
|
|
|
|
String password = tilPassword.getEditText().getText().toString();
|
|
|
|
|
|
|
|
String warning = null;
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(name))
|
|
|
|
|
|
|
|
warning = getString(R.string.title_no_name);
|
|
|
|
|
|
|
|
else if (TextUtils.isEmpty(email))
|
|
|
|
|
|
|
|
warning = getString(R.string.title_no_email);
|
|
|
|
|
|
|
|
else if (!Helper.EMAIL_ADDRESS.matcher(email).matches())
|
|
|
|
|
|
|
|
warning = getString(R.string.title_email_invalid, email);
|
|
|
|
|
|
|
|
else if (TextUtils.isEmpty(password))
|
|
|
|
|
|
|
|
warning = getString(R.string.title_no_password);
|
|
|
|
|
|
|
|
else {
|
|
|
|
|
|
|
|
ConnectivityManager cm = Helper.getSystemService(getContext(), ConnectivityManager.class);
|
|
|
|
|
|
|
|
NetworkInfo ani = (cm == null ? null : cm.getActiveNetworkInfo());
|
|
|
|
|
|
|
|
if (ani == null || !ani.isConnected())
|
|
|
|
|
|
|
|
warning = getString(R.string.title_no_internet);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (warning != null) {
|
|
|
|
|
|
|
|
tvArgument.setText(warning);
|
|
|
|
|
|
|
|
tvArgument.setVisibility(View.VISIBLE);
|
|
|
|
|
|
|
|
getMainHandler().post(new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
if (!getLifecycle().getCurrentState().isAtLeast(Lifecycle.State.STARTED))
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
scroll.smoothScrollTo(0, tvArgument.getBottom());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
Bundle args = new Bundle();
|
|
|
|
args.putString("name", etName.getText().toString().trim());
|
|
|
|
args.putString("name", name);
|
|
|
|
args.putString("email", etEmail.getText().toString().trim());
|
|
|
|
args.putString("email", email);
|
|
|
|
args.putString("password", tilPassword.getEditText().getText().toString());
|
|
|
|
args.putString("password", password);
|
|
|
|
args.putBoolean("update", cbUpdate.isChecked());
|
|
|
|
args.putBoolean("update", cbUpdate.isChecked());
|
|
|
|
args.putBoolean("check", check);
|
|
|
|
args.putBoolean("check", check);
|
|
|
|
args.putParcelable("best", bestProvider);
|
|
|
|
args.putParcelable("best", bestProvider);
|
|
|
@ -340,23 +374,9 @@ public class FragmentQuickSetup extends FragmentBase {
|
|
|
|
boolean check = args.getBoolean("check");
|
|
|
|
boolean check = args.getBoolean("check");
|
|
|
|
EmailProvider best = args.getParcelable("best");
|
|
|
|
EmailProvider best = args.getParcelable("best");
|
|
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(name))
|
|
|
|
|
|
|
|
throw new ArgumentException(context.getString(R.string.title_no_name));
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(email))
|
|
|
|
|
|
|
|
throw new ArgumentException(context.getString(R.string.title_no_email));
|
|
|
|
|
|
|
|
if (!Helper.EMAIL_ADDRESS.matcher(email).matches())
|
|
|
|
|
|
|
|
throw new ArgumentException(context.getString(R.string.title_email_invalid, email));
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(password))
|
|
|
|
|
|
|
|
throw new ArgumentException(context.getString(R.string.title_no_password));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int at = email.indexOf('@');
|
|
|
|
int at = email.indexOf('@');
|
|
|
|
String username = email.substring(0, at);
|
|
|
|
String username = email.substring(0, at);
|
|
|
|
|
|
|
|
|
|
|
|
ConnectivityManager cm = Helper.getSystemService(context, ConnectivityManager.class);
|
|
|
|
|
|
|
|
NetworkInfo ani = (cm == null ? null : cm.getActiveNetworkInfo());
|
|
|
|
|
|
|
|
if (ani == null || !ani.isConnected())
|
|
|
|
|
|
|
|
throw new ArgumentException(context.getString(R.string.title_no_internet));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Throwable fail = null;
|
|
|
|
Throwable fail = null;
|
|
|
|
List<EmailProvider> providers;
|
|
|
|
List<EmailProvider> providers;
|
|
|
|
if (best == null)
|
|
|
|
if (best == null)
|
|
|
@ -695,24 +715,12 @@ public class FragmentQuickSetup extends FragmentBase {
|
|
|
|
etEmail.clearFocus();
|
|
|
|
etEmail.clearFocus();
|
|
|
|
Helper.hideKeyboard(view);
|
|
|
|
Helper.hideKeyboard(view);
|
|
|
|
|
|
|
|
|
|
|
|
if (ex instanceof ArgumentException) {
|
|
|
|
|
|
|
|
tvArgument.setText(ex.getMessage());
|
|
|
|
|
|
|
|
tvArgument.setVisibility(View.VISIBLE);
|
|
|
|
|
|
|
|
getMainHandler().post(new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
if (!getLifecycle().getCurrentState().isAtLeast(Lifecycle.State.STARTED))
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
scroll.smoothScrollTo(0, tvArgument.getBottom());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (ex instanceof AuthenticationFailedException) {
|
|
|
|
if (ex instanceof AuthenticationFailedException) {
|
|
|
|
String message = getString(R.string.title_setup_no_auth_hint);
|
|
|
|
String message = getString(R.string.title_setup_no_auth_hint);
|
|
|
|
if (provider != null && provider.appPassword)
|
|
|
|
if (provider != null && provider.appPassword)
|
|
|
|
message += "\n\n" + getString(R.string.title_setup_app_password_hint);
|
|
|
|
message += "\n\n" + getString(R.string.title_setup_app_password_hint);
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
btnManual.setVisibility(View.VISIBLE);
|
|
|
|
tvErrorHint.setText(message);
|
|
|
|
tvErrorHint.setText(message);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
tvErrorHint.setText(R.string.title_setup_no_settings_hint);
|
|
|
|
tvErrorHint.setText(R.string.title_setup_no_settings_hint);
|
|
|
@ -838,10 +846,4 @@ public class FragmentQuickSetup extends FragmentBase {
|
|
|
|
Log.e(ex);
|
|
|
|
Log.e(ex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static class ArgumentException extends IllegalArgumentException {
|
|
|
|
|
|
|
|
public ArgumentException(String text) {
|
|
|
|
|
|
|
|
super(text);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|