Added button to edit name / review account

pull/194/merge
M66B 3 years ago
parent d77c3301c6
commit 07e8b855da

@ -27,9 +27,12 @@ import android.graphics.drawable.Drawable;
import android.net.Uri; import android.net.Uri;
import android.os.Bundle; import android.os.Bundle;
import android.provider.Settings; import android.provider.Settings;
import android.text.TextUtils;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.widget.Button; import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.TextView; import android.widget.TextView;
import androidx.annotation.NonNull; import androidx.annotation.NonNull;
@ -52,6 +55,7 @@ public class FragmentDialogAccount extends FragmentDialogBase {
final View dview = LayoutInflater.from(context).inflate(R.layout.dialog_review_account, null); final View dview = LayoutInflater.from(context).inflate(R.layout.dialog_review_account, null);
final TextView tvName = dview.findViewById(R.id.tvName); final TextView tvName = dview.findViewById(R.id.tvName);
final ImageButton ibEditName = dview.findViewById(R.id.ibEditName);
final TextView tvInbox = dview.findViewById(R.id.tvInbox); final TextView tvInbox = dview.findViewById(R.id.tvInbox);
final TextView tvDrafts = dview.findViewById(R.id.tvDrafts); final TextView tvDrafts = dview.findViewById(R.id.tvDrafts);
final TextView tvSent = dview.findViewById(R.id.tvSent); final TextView tvSent = dview.findViewById(R.id.tvSent);
@ -78,6 +82,7 @@ public class FragmentDialogAccount extends FragmentDialogBase {
tvArchive.setCompoundDrawablesRelative(null, null, null, null); tvArchive.setCompoundDrawablesRelative(null, null, null, null);
tvName.setText(null); tvName.setText(null);
ibEditName.setEnabled(false);
tvLeft.setText(null); tvLeft.setText(null);
tvRight.setText(null); tvRight.setText(null);
@ -87,6 +92,48 @@ public class FragmentDialogAccount extends FragmentDialogBase {
Bundle args = getArguments(); Bundle args = getArguments();
final long account = args.getLong("account"); final long account = args.getLong("account");
ibEditName.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
View e = LayoutInflater.from(context).inflate(R.layout.dialog_edit_name, null);
EditText etName = e.findViewById(R.id.etName);
etName.setText(tvName.getText());
new AlertDialog.Builder(context)
.setView(e)
.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
String name = etName.getText().toString();
if (TextUtils.isEmpty(name))
return;
args.putString("name", name);
new SimpleTask<Void>() {
@Override
protected Void onExecute(Context context, Bundle args) throws Throwable {
long id = args.getLong("account");
String name = args.getString("name");
DB db = DB.getInstance(context);
db.account().setAccountName(id, name);
return null;
}
@Override
protected void onException(Bundle args, Throwable ex) {
// Ignored
}
}.execute(FragmentDialogAccount.this, args, "account:name");
}
})
.setNegativeButton(android.R.string.cancel, null)
.show();
}
});
btnAccount.setOnClickListener(new View.OnClickListener() { btnAccount.setOnClickListener(new View.OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
@ -116,6 +163,7 @@ public class FragmentDialogAccount extends FragmentDialogBase {
@Override @Override
public void onChanged(EntityAccount account) { public void onChanged(EntityAccount account) {
tvName.setText(account.name); tvName.setText(account.name);
ibEditName.setEnabled(true);
btnGmail.setVisibility( btnGmail.setVisibility(
hasGmail && account.auth_type == AUTH_TYPE_GMAIL hasGmail && account.auth_type == AUTH_TYPE_GMAIL
? View.VISIBLE : View.GONE); ? View.VISIBLE : View.GONE);

@ -12,15 +12,30 @@
<eu.faircode.email.FixedTextView <eu.faircode.email.FixedTextView
android:id="@+id/tvName" android:id="@+id/tvName"
android:layout_width="wrap_content" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginEnd="6dp"
android:drawableStart="@drawable/twotone_account_circle_24" android:drawableStart="@drawable/twotone_account_circle_24"
android:drawablePadding="6dp" android:drawablePadding="6dp"
android:minHeight="36dp"
android:text="Name" android:text="Name"
android:textAppearance="@style/TextAppearance.AppCompat.Large" android:textAppearance="@style/TextAppearance.AppCompat.Large"
app:layout_constraintEnd_toStartOf="@id/ibEditName"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
<ImageButton
android:id="@+id/ibEditName"
android:layout_width="36dp"
android:layout_height="36dp"
android:background="?android:attr/selectableItemBackgroundBorderless"
android:contentDescription="@string/title_edit_account_name"
android:tooltipText="@string/title_edit_account_name"
app:layout_constraintBottom_toBottomOf="@+id/tvName"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/tvName"
app:srcCompat="@drawable/twotone_edit_24" />
<eu.faircode.email.FixedTextView <eu.faircode.email.FixedTextView
android:id="@+id/tvSuccess" android:id="@+id/tvSuccess"
android:layout_width="wrap_content" android:layout_width="wrap_content"

Loading…
Cancel
Save