|
|
|
@ -27,8 +27,10 @@ import android.graphics.drawable.GradientDrawable;
|
|
|
|
|
import android.os.Bundle;
|
|
|
|
|
import android.os.Handler;
|
|
|
|
|
import android.preference.PreferenceManager;
|
|
|
|
|
import android.text.Editable;
|
|
|
|
|
import android.text.Html;
|
|
|
|
|
import android.text.TextUtils;
|
|
|
|
|
import android.text.TextWatcher;
|
|
|
|
|
import android.util.Patterns;
|
|
|
|
|
import android.view.LayoutInflater;
|
|
|
|
|
import android.view.Menu;
|
|
|
|
@ -47,6 +49,7 @@ import android.widget.ImageView;
|
|
|
|
|
import android.widget.ProgressBar;
|
|
|
|
|
import android.widget.ScrollView;
|
|
|
|
|
import android.widget.Spinner;
|
|
|
|
|
import android.widget.TextView;
|
|
|
|
|
|
|
|
|
|
import com.android.colorpicker.ColorPickerDialog;
|
|
|
|
|
import com.android.colorpicker.ColorPickerSwatch;
|
|
|
|
@ -73,15 +76,21 @@ import androidx.fragment.app.FragmentTransaction;
|
|
|
|
|
|
|
|
|
|
public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
private ViewGroup view;
|
|
|
|
|
|
|
|
|
|
private EditText etName;
|
|
|
|
|
private EditText etEmail;
|
|
|
|
|
private EditText etDisplay;
|
|
|
|
|
|
|
|
|
|
private Spinner spAccount;
|
|
|
|
|
|
|
|
|
|
private EditText etDisplay;
|
|
|
|
|
private Button btnColor;
|
|
|
|
|
private View vwColor;
|
|
|
|
|
private ImageView ibColorDefault;
|
|
|
|
|
private EditText etSignature;
|
|
|
|
|
private ImageButton ibPro;
|
|
|
|
|
|
|
|
|
|
private Button btnAdvanced;
|
|
|
|
|
private EditText etReplyTo;
|
|
|
|
|
private EditText etBcc;
|
|
|
|
|
private CheckBox cbDeliveryReceipt;
|
|
|
|
|
private CheckBox cbReadReceipt;
|
|
|
|
|
private TextView tvProvider;
|
|
|
|
|
private Spinner spProvider;
|
|
|
|
|
private EditText etDomain;
|
|
|
|
|
private Button btnAutoConfig;
|
|
|
|
@ -92,19 +101,19 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
private EditText etUser;
|
|
|
|
|
private TextInputLayout tilPassword;
|
|
|
|
|
|
|
|
|
|
private Button btnColor;
|
|
|
|
|
private View vwColor;
|
|
|
|
|
private ImageView ibColorDefault;
|
|
|
|
|
private EditText etSignature;
|
|
|
|
|
private ImageButton ibPro;
|
|
|
|
|
|
|
|
|
|
private CheckBox cbSynchronize;
|
|
|
|
|
private CheckBox cbPrimary;
|
|
|
|
|
|
|
|
|
|
private EditText etReplyTo;
|
|
|
|
|
private EditText etBcc;
|
|
|
|
|
private CheckBox cbDeliveryReceipt;
|
|
|
|
|
private CheckBox cbReadReceipt;
|
|
|
|
|
private Spinner spSent;
|
|
|
|
|
|
|
|
|
|
private Button btnSave;
|
|
|
|
|
private ProgressBar pbSave;
|
|
|
|
|
private ProgressBar pbWait;
|
|
|
|
|
|
|
|
|
|
private Group grpAdvanced;
|
|
|
|
|
|
|
|
|
|
private long id = -1;
|
|
|
|
@ -135,19 +144,18 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
etName = view.findViewById(R.id.etName);
|
|
|
|
|
etEmail = view.findViewById(R.id.etEmail);
|
|
|
|
|
spAccount = view.findViewById(R.id.spAccount);
|
|
|
|
|
|
|
|
|
|
btnAdvanced = view.findViewById(R.id.btnAdvanced);
|
|
|
|
|
etDisplay = view.findViewById(R.id.etDisplay);
|
|
|
|
|
etReplyTo = view.findViewById(R.id.etReplyTo);
|
|
|
|
|
etBcc = view.findViewById(R.id.etBcc);
|
|
|
|
|
cbDeliveryReceipt = view.findViewById(R.id.cbDeliveryReceipt);
|
|
|
|
|
cbReadReceipt = view.findViewById(R.id.cbReadReceipt);
|
|
|
|
|
btnColor = view.findViewById(R.id.btnColor);
|
|
|
|
|
vwColor = view.findViewById(R.id.vwColor);
|
|
|
|
|
ibColorDefault = view.findViewById(R.id.ibColorDefault);
|
|
|
|
|
etSignature = view.findViewById(R.id.etSignature);
|
|
|
|
|
ibPro = view.findViewById(R.id.ibPro);
|
|
|
|
|
|
|
|
|
|
btnAdvanced = view.findViewById(R.id.btnAdvanced);
|
|
|
|
|
tvProvider = view.findViewById(R.id.tvProvider);
|
|
|
|
|
spProvider = view.findViewById(R.id.spProvider);
|
|
|
|
|
|
|
|
|
|
etDomain = view.findViewById(R.id.etDomain);
|
|
|
|
|
btnAutoConfig = view.findViewById(R.id.btnAutoConfig);
|
|
|
|
|
|
|
|
|
|
etHost = view.findViewById(R.id.etHost);
|
|
|
|
|
cbStartTls = view.findViewById(R.id.cbStartTls);
|
|
|
|
|
cbInsecure = view.findViewById(R.id.cbInsecure);
|
|
|
|
@ -155,19 +163,19 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
etUser = view.findViewById(R.id.etUser);
|
|
|
|
|
tilPassword = view.findViewById(R.id.tilPassword);
|
|
|
|
|
|
|
|
|
|
btnColor = view.findViewById(R.id.btnColor);
|
|
|
|
|
vwColor = view.findViewById(R.id.vwColor);
|
|
|
|
|
ibColorDefault = view.findViewById(R.id.ibColorDefault);
|
|
|
|
|
etSignature = view.findViewById(R.id.etSignature);
|
|
|
|
|
ibPro = view.findViewById(R.id.ibPro);
|
|
|
|
|
|
|
|
|
|
cbSynchronize = view.findViewById(R.id.cbSynchronize);
|
|
|
|
|
cbPrimary = view.findViewById(R.id.cbPrimary);
|
|
|
|
|
|
|
|
|
|
etReplyTo = view.findViewById(R.id.etReplyTo);
|
|
|
|
|
etBcc = view.findViewById(R.id.etBcc);
|
|
|
|
|
cbDeliveryReceipt = view.findViewById(R.id.cbDeliveryReceipt);
|
|
|
|
|
cbReadReceipt = view.findViewById(R.id.cbReadReceipt);
|
|
|
|
|
spSent = view.findViewById(R.id.spSent);
|
|
|
|
|
|
|
|
|
|
btnSave = view.findViewById(R.id.btnSave);
|
|
|
|
|
pbSave = view.findViewById(R.id.pbSave);
|
|
|
|
|
pbWait = view.findViewById(R.id.pbWait);
|
|
|
|
|
|
|
|
|
|
grpAdvanced = view.findViewById(R.id.grpAdvanced);
|
|
|
|
|
|
|
|
|
|
// Wire controls
|
|
|
|
@ -229,6 +237,63 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
vwColor.setBackgroundColor(color);
|
|
|
|
|
btnColor.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
if (Helper.isPro(getContext())) {
|
|
|
|
|
int[] colors = getContext().getResources().getIntArray(R.array.colorPicker);
|
|
|
|
|
ColorPickerDialog colorPickerDialog = new ColorPickerDialog();
|
|
|
|
|
colorPickerDialog.initialize(R.string.title_account_color, colors, color, 4, colors.length);
|
|
|
|
|
colorPickerDialog.setOnColorSelectedListener(new ColorPickerSwatch.OnColorSelectedListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onColorSelected(int color) {
|
|
|
|
|
setColor(color);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
colorPickerDialog.show(getFragmentManager(), "colorpicker");
|
|
|
|
|
} else {
|
|
|
|
|
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
|
|
|
|
|
fragmentTransaction.hide(FragmentIdentity.this);
|
|
|
|
|
fragmentTransaction.add(R.id.content_frame, new FragmentPro()).addToBackStack("pro");
|
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ibColorDefault.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
setColor(Color.TRANSPARENT);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ibPro.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
|
|
|
|
|
fragmentTransaction.hide(FragmentIdentity.this);
|
|
|
|
|
fragmentTransaction.add(R.id.content_frame, new FragmentPro()).addToBackStack("pro");
|
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
btnAdvanced.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
int visibility = (grpAdvanced.getVisibility() == View.VISIBLE ? View.GONE : View.VISIBLE);
|
|
|
|
|
grpAdvanced.setVisibility(visibility);
|
|
|
|
|
cbInsecure.setVisibility(insecure ? visibility : View.GONE);
|
|
|
|
|
if (visibility == View.VISIBLE)
|
|
|
|
|
new Handler().post(new Runnable() {
|
|
|
|
|
@Override
|
|
|
|
|
public void run() {
|
|
|
|
|
((ScrollView) view).smoothScrollTo(0, tvProvider.getTop());
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
spProvider.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onItemSelected(AdapterView<?> adapterView, View view, int position, long id) {
|
|
|
|
@ -250,6 +315,23 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
etDomain.addTextChangedListener(new TextWatcher() {
|
|
|
|
|
@Override
|
|
|
|
|
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onTextChanged(CharSequence text, int start, int before, int count) {
|
|
|
|
|
btnAutoConfig.setEnabled(text.length() > 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void afterTextChanged(Editable s) {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
btnAutoConfig.setEnabled(false);
|
|
|
|
|
|
|
|
|
|
btnAutoConfig.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
@ -262,8 +344,10 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
new SimpleTask<SRVRecord>() {
|
|
|
|
|
@Override
|
|
|
|
|
protected SRVRecord onLoad(Context context, Bundle args) throws Throwable {
|
|
|
|
|
String domain = args.getString("domain");
|
|
|
|
|
Record[] records = new Lookup("_submission._tcp." + domain, Type.SRV).run();
|
|
|
|
|
String dns = "_submission._tcp." + args.getString("domain");
|
|
|
|
|
Log.i("Lookup dns=" + dns);
|
|
|
|
|
Record[] records = new Lookup(dns, Type.SRV).run();
|
|
|
|
|
Log.i("Found dns=" + (records == null ? -1 : records.length));
|
|
|
|
|
if (records != null)
|
|
|
|
|
for (int i = 0; i < records.length; i++) {
|
|
|
|
|
SRVRecord srv = (SRVRecord) records[i];
|
|
|
|
@ -298,22 +382,6 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
btnAdvanced.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
int visibility = (grpAdvanced.getVisibility() == View.VISIBLE ? View.GONE : View.VISIBLE);
|
|
|
|
|
grpAdvanced.setVisibility(visibility);
|
|
|
|
|
cbInsecure.setVisibility(insecure ? visibility : View.GONE);
|
|
|
|
|
if (visibility == View.VISIBLE)
|
|
|
|
|
new Handler().post(new Runnable() {
|
|
|
|
|
@Override
|
|
|
|
|
public void run() {
|
|
|
|
|
((ScrollView) view).smoothScrollTo(0, etDisplay.getTop());
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
cbStartTls.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
|
|
|
|
@ -321,47 +389,6 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
vwColor.setBackgroundColor(color);
|
|
|
|
|
btnColor.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
if (Helper.isPro(getContext())) {
|
|
|
|
|
int[] colors = getContext().getResources().getIntArray(R.array.colorPicker);
|
|
|
|
|
ColorPickerDialog colorPickerDialog = new ColorPickerDialog();
|
|
|
|
|
colorPickerDialog.initialize(R.string.title_account_color, colors, color, 4, colors.length);
|
|
|
|
|
colorPickerDialog.setOnColorSelectedListener(new ColorPickerSwatch.OnColorSelectedListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onColorSelected(int color) {
|
|
|
|
|
setColor(color);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
colorPickerDialog.show(getFragmentManager(), "colorpicker");
|
|
|
|
|
} else {
|
|
|
|
|
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
|
|
|
|
|
fragmentTransaction.hide(FragmentIdentity.this);
|
|
|
|
|
fragmentTransaction.add(R.id.content_frame, new FragmentPro()).addToBackStack("pro");
|
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ibColorDefault.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
setColor(Color.TRANSPARENT);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ibPro.setOnClickListener(new View.OnClickListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onClick(View v) {
|
|
|
|
|
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
|
|
|
|
|
fragmentTransaction.hide(FragmentIdentity.this);
|
|
|
|
|
fragmentTransaction.add(R.id.content_frame, new FragmentPro()).addToBackStack("pro");
|
|
|
|
|
fragmentTransaction.commit();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
cbSynchronize.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
|
|
|
|
@Override
|
|
|
|
|
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
|
|
|
|
@ -406,24 +433,27 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
protected Void onLoad(Context context, Bundle args) throws Throwable {
|
|
|
|
|
long id = args.getLong("id");
|
|
|
|
|
String name = args.getString("name");
|
|
|
|
|
String email = args.getString("email");
|
|
|
|
|
long account = args.getLong("account");
|
|
|
|
|
|
|
|
|
|
String display = args.getString("display");
|
|
|
|
|
String email = args.getString("email");
|
|
|
|
|
String replyto = args.getString("replyto");
|
|
|
|
|
String bcc = args.getString("bcc");
|
|
|
|
|
boolean delivery_receipt = args.getBoolean("delivery_receipt");
|
|
|
|
|
boolean read_receipt = args.getBoolean("read_receipt");
|
|
|
|
|
Integer color = args.getInt("color");
|
|
|
|
|
String signature = args.getString("signature");
|
|
|
|
|
|
|
|
|
|
int auth_type = args.getInt("auth_type");
|
|
|
|
|
String host = args.getString("host");
|
|
|
|
|
boolean starttls = args.getBoolean("starttls");
|
|
|
|
|
boolean insecure = args.getBoolean("insecure");
|
|
|
|
|
String port = args.getString("port");
|
|
|
|
|
String user = args.getString("user");
|
|
|
|
|
String password = args.getString("password");
|
|
|
|
|
Integer color = args.getInt("color");
|
|
|
|
|
String signature = args.getString("signature");
|
|
|
|
|
int auth_type = args.getInt("auth_type");
|
|
|
|
|
boolean synchronize = args.getBoolean("synchronize");
|
|
|
|
|
boolean primary = args.getBoolean("primary");
|
|
|
|
|
|
|
|
|
|
String replyto = args.getString("replyto");
|
|
|
|
|
String bcc = args.getString("bcc");
|
|
|
|
|
boolean delivery_receipt = args.getBoolean("delivery_receipt");
|
|
|
|
|
boolean read_receipt = args.getBoolean("read_receipt");
|
|
|
|
|
EntityFolder sent = (EntityFolder) args.getSerializable("sent");
|
|
|
|
|
|
|
|
|
|
if (TextUtils.isEmpty(name))
|
|
|
|
@ -495,24 +525,26 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
if (identity == null)
|
|
|
|
|
identity = new EntityIdentity();
|
|
|
|
|
identity.name = name;
|
|
|
|
|
identity.email = email;
|
|
|
|
|
identity.account = account;
|
|
|
|
|
identity.display = display;
|
|
|
|
|
identity.email = email;
|
|
|
|
|
identity.replyto = replyto;
|
|
|
|
|
identity.bcc = bcc;
|
|
|
|
|
identity.delivery_receipt = delivery_receipt;
|
|
|
|
|
identity.read_receipt = read_receipt;
|
|
|
|
|
identity.color = color;
|
|
|
|
|
identity.signature = signature;
|
|
|
|
|
|
|
|
|
|
identity.auth_type = auth_type;
|
|
|
|
|
identity.host = host;
|
|
|
|
|
identity.starttls = starttls;
|
|
|
|
|
identity.insecure = insecure;
|
|
|
|
|
identity.port = Integer.parseInt(port);
|
|
|
|
|
identity.user = user;
|
|
|
|
|
identity.password = password;
|
|
|
|
|
identity.color = color;
|
|
|
|
|
identity.signature = signature;
|
|
|
|
|
identity.auth_type = auth_type;
|
|
|
|
|
identity.synchronize = synchronize;
|
|
|
|
|
identity.primary = (identity.synchronize && primary);
|
|
|
|
|
|
|
|
|
|
identity.replyto = replyto;
|
|
|
|
|
identity.bcc = bcc;
|
|
|
|
|
identity.delivery_receipt = delivery_receipt;
|
|
|
|
|
identity.read_receipt = read_receipt;
|
|
|
|
|
identity.store_sent = false;
|
|
|
|
|
identity.sent_folder = (sent == null ? null : sent.id);
|
|
|
|
|
identity.error = null;
|
|
|
|
@ -602,21 +634,24 @@ public class FragmentIdentity extends FragmentEx {
|
|
|
|
|
if (savedInstanceState == null) {
|
|
|
|
|
etName.setText(identity == null ? null : identity.name);
|
|
|
|
|
etEmail.setText(identity == null ? null : identity.email);
|
|
|
|
|
|
|
|
|
|
etDisplay.setText(identity == null ? null : identity.display);
|
|
|
|
|
etReplyTo.setText(identity == null ? null : identity.replyto);
|
|
|
|
|
etBcc.setText(identity == null ? null : identity.bcc);
|
|
|
|
|
cbDeliveryReceipt.setChecked(identity == null ? false : identity.delivery_receipt);
|
|
|
|
|
cbReadReceipt.setChecked(identity == null ? false : identity.read_receipt);
|
|
|
|
|
etSignature.setText(identity == null || identity.signature == null ? null : Html.fromHtml(identity.signature));
|
|
|
|
|
|
|
|
|
|
etHost.setText(identity == null ? null : identity.host);
|
|
|
|
|
cbStartTls.setChecked(identity == null ? false : identity.starttls);
|
|
|
|
|
cbInsecure.setChecked(identity == null ? false : identity.insecure);
|
|
|
|
|
etPort.setText(identity == null ? null : Long.toString(identity.port));
|
|
|
|
|
etUser.setText(identity == null ? null : identity.user);
|
|
|
|
|
tilPassword.getEditText().setText(identity == null ? null : identity.password);
|
|
|
|
|
etSignature.setText(identity == null || identity.signature == null ? null : Html.fromHtml(identity.signature));
|
|
|
|
|
cbSynchronize.setChecked(identity == null ? true : identity.synchronize);
|
|
|
|
|
cbPrimary.setChecked(identity == null ? true : identity.primary);
|
|
|
|
|
|
|
|
|
|
etReplyTo.setText(identity == null ? null : identity.replyto);
|
|
|
|
|
etBcc.setText(identity == null ? null : identity.bcc);
|
|
|
|
|
cbDeliveryReceipt.setChecked(identity == null ? false : identity.delivery_receipt);
|
|
|
|
|
cbReadReceipt.setChecked(identity == null ? false : identity.read_receipt);
|
|
|
|
|
|
|
|
|
|
color = (identity == null || identity.color == null ? Color.TRANSPARENT : identity.color);
|
|
|
|
|
|
|
|
|
|
etName.requestFocus();
|
|
|
|
|