Quick setup review account

pull/162/head
M66B 6 years ago
parent 5b670a61bc
commit 984800c191

@ -47,6 +47,7 @@ import androidx.annotation.NonNull;
import androidx.annotation.Nullable; import androidx.annotation.Nullable;
import androidx.appcompat.app.AlertDialog; import androidx.appcompat.app.AlertDialog;
import androidx.constraintlayout.widget.Group; import androidx.constraintlayout.widget.Group;
import androidx.localbroadcastmanager.content.LocalBroadcastManager;
import com.google.android.material.textfield.TextInputLayout; import com.google.android.material.textfield.TextInputLayout;
@ -309,6 +310,7 @@ public class FragmentQuickSetup extends FragmentBase {
account.last_connected = account.created; account.last_connected = account.created;
account.id = db.account().insertAccount(account); account.id = db.account().insertAccount(account);
args.putLong("account", account.id);
EntityLog.log(context, "Quick added account=" + account.name); EntityLog.log(context, "Quick added account=" + account.name);
// Create folders // Create folders
@ -343,6 +345,7 @@ public class FragmentQuickSetup extends FragmentBase {
identity.primary = true; identity.primary = true;
identity.id = db.identity().insertIdentity(identity); identity.id = db.identity().insertIdentity(identity);
args.putLong("identity", identity.id);
EntityLog.log(context, "Quick added identity=" + identity.name + " email=" + identity.email); EntityLog.log(context, "Quick added identity=" + identity.name + " email=" + identity.email);
db.setTransactionSuccessful(); db.setTransactionSuccessful();
@ -366,6 +369,7 @@ public class FragmentQuickSetup extends FragmentBase {
grpSetup.setVisibility(result == null ? View.GONE : View.VISIBLE); grpSetup.setVisibility(result == null ? View.GONE : View.VISIBLE);
} else { } else {
FragmentDialogDone fragment = new FragmentDialogDone(); FragmentDialogDone fragment = new FragmentDialogDone();
fragment.setArguments(args);
fragment.setTargetFragment(FragmentQuickSetup.this, REQUEST_DONE); fragment.setTargetFragment(FragmentQuickSetup.this, REQUEST_DONE);
fragment.show(getFragmentManager(), "quick:done"); fragment.show(getFragmentManager(), "quick:done");
} }
@ -429,9 +433,18 @@ public class FragmentQuickSetup extends FragmentBase {
public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) { public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
return new AlertDialog.Builder(getContext()) return new AlertDialog.Builder(getContext())
.setMessage(R.string.title_setup_quick_success) .setMessage(R.string.title_setup_quick_success)
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() { .setPositiveButton(R.string.title_review, new DialogInterface.OnClickListener() {
@Override @Override
public void onClick(DialogInterface dialogInterface, int i) { public void onClick(DialogInterface dialogInterface, int i) {
Bundle args = getArguments();
long account = args.getLong("account");
LocalBroadcastManager lbm = LocalBroadcastManager.getInstance(getContext());
lbm.sendBroadcast(
new Intent(ActivitySetup.ACTION_EDIT_ACCOUNT)
.putExtra("id", account)
.putExtra("pop", false));
sendResult(RESULT_OK); sendResult(RESULT_OK);
} }
}) })

@ -64,6 +64,7 @@ import androidx.preference.PreferenceManager;
import com.google.android.material.snackbar.Snackbar; import com.google.android.material.snackbar.Snackbar;
import java.io.IOException; import java.io.IOException;
import java.net.UnknownHostException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -551,12 +552,11 @@ public class FragmentSetup extends FragmentBase {
String password = args.getString("password"); String password = args.getString("password");
if (!user.contains("@")) if (!user.contains("@"))
throw new IllegalArgumentException(user); throw new IllegalArgumentException(
context.getString(R.string.title_email_invalid, user));
String domain = user.split("@")[1]; String domain = user.split("@")[1];
EmailProvider provider = EmailProvider.fromDomain(context, domain, EmailProvider.Discover.ALL); EmailProvider provider = EmailProvider.fromDomain(context, domain, EmailProvider.Discover.ALL);
if (provider == null)
throw new IllegalArgumentException(user);
List<EntityFolder> folders; List<EntityFolder> folders;
@ -567,7 +567,8 @@ public class FragmentSetup extends FragmentBase {
folders = iservice.getFolders(); folders = iservice.getFolders();
if (folders == null) if (folders == null)
throw new IllegalArgumentException(domain); throw new IllegalArgumentException(
context.getString(R.string.title_setup_no_settings, domain));
} }
String iprotocol = provider.smtp.starttls ? "smtp" : "smtps"; String iprotocol = provider.smtp.starttls ? "smtp" : "smtps";
@ -600,6 +601,7 @@ public class FragmentSetup extends FragmentBase {
account.last_connected = account.created; account.last_connected = account.created;
account.id = db.account().insertAccount(account); account.id = db.account().insertAccount(account);
args.putLong("account", account.id);
EntityLog.log(context, "Gmail account=" + account.name); EntityLog.log(context, "Gmail account=" + account.name);
// Create folders // Create folders
@ -646,6 +648,7 @@ public class FragmentSetup extends FragmentBase {
identity.primary = true; identity.primary = true;
identity.id = db.identity().insertIdentity(identity); identity.id = db.identity().insertIdentity(identity);
args.putLong("identity", identity.id);
EntityLog.log(context, "Gmail identity=" + identity.name + " email=" + identity.email); EntityLog.log(context, "Gmail identity=" + identity.name + " email=" + identity.email);
db.setTransactionSuccessful(); db.setTransactionSuccessful();
@ -661,12 +664,16 @@ public class FragmentSetup extends FragmentBase {
@Override @Override
protected void onExecuted(Bundle args, Void data) { protected void onExecuted(Bundle args, Void data) {
FragmentQuickSetup.FragmentDialogDone fragment = new FragmentQuickSetup.FragmentDialogDone(); FragmentQuickSetup.FragmentDialogDone fragment = new FragmentQuickSetup.FragmentDialogDone();
fragment.setArguments(args);
fragment.show(getFragmentManager(), "gmail:done"); fragment.show(getFragmentManager(), "gmail:done");
} }
@Override @Override
protected void onException(Bundle args, Throwable ex) { protected void onException(Bundle args, Throwable ex) {
Helper.unexpectedError(getFragmentManager(), ex); if (ex instanceof IllegalArgumentException || ex instanceof UnknownHostException)
Snackbar.make(view, ex.getMessage(), Snackbar.LENGTH_LONG).show();
else
Snackbar.make(view, Helper.formatThrowable(ex, false), Snackbar.LENGTH_LONG).show();
} }
}.execute(this, args, "setup:gmail"); }.execute(this, args, "setup:gmail");
} }

@ -420,6 +420,7 @@
<string name="title_oauth_support">OAuth is not supported</string> <string name="title_oauth_support">OAuth is not supported</string>
<string name="title_authorize">Authorize</string> <string name="title_authorize">Authorize</string>
<string name="title_authorizing">Authorizing &#8230;</string> <string name="title_authorizing">Authorizing &#8230;</string>
<string name="title_review">Review</string>
<string name="title_synchronize_now">Synchronize now</string> <string name="title_synchronize_now">Synchronize now</string>
<string name="title_synchronize_all">Synchronize all messages</string> <string name="title_synchronize_all">Synchronize all messages</string>

Loading…
Cancel
Save