From 259a0ae1400bf5bb4874fe2cb04572c2fb823e65 Mon Sep 17 00:00:00 2001 From: FineFindus Date: Wed, 14 Aug 2024 18:50:58 +0200 Subject: [PATCH 1/2] feat: use mute row Partially 6c519b3cb9d036e3da43e7bb0a6b86f81e5c9dff to use the full row again, but keep the selection in a dialog. This improves the UI, as the secondary button is confusing, and feels out-of-place. --- .../android/ui/sheets/MuteAccountConfirmationSheet.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java b/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java index efc4c242ed..7cb31d23a1 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java +++ b/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java @@ -44,10 +44,11 @@ public MuteAccountConfirmationSheet(@NonNull Context context, Account user, Atom addRow(R.drawable.ic_fluent_alert_off_24_regular, R.string.mo_mute_notifications, m3Switch); // add mute duration (Moshidon) - secondaryBtn.setVisibility(View.VISIBLE); - secondaryBtn.setOnClickListener(v->getMuteDurationDialog(context, muteDuration, secondaryBtn).show()); - secondaryBtn.setText(R.string.sk_duration_indefinite); - secondaryBtn.setTypeface(null, Typeface.BOLD_ITALIC); + Button muteDurationBtn=new Button(getContext()); + muteDurationBtn.setOnClickListener(v->getMuteDurationDialog(context, muteDuration, muteDurationBtn).show()); + muteDurationBtn.setText(R.string.sk_duration_indefinite); + + addRow(R.drawable.ic_fluent_clock_20_regular, R.string.sk_mute_label, muteDurationBtn); } @NonNull From 49cf100d37f190d14b407a25c6195239e8f04bba Mon Sep 17 00:00:00 2001 From: FineFindus Date: Wed, 14 Aug 2024 19:06:12 +0200 Subject: [PATCH 2/2] fix(MuteAccountSheet): set selected mute time --- .../sheets/MuteAccountConfirmationSheet.java | 46 ++++++------------- 1 file changed, 14 insertions(+), 32 deletions(-) diff --git a/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java b/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java index 7cb31d23a1..6a1172e13f 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java +++ b/mastodon/src/main/java/org/joinmastodon/android/ui/sheets/MuteAccountConfirmationSheet.java @@ -2,14 +2,8 @@ import android.app.AlertDialog; import android.content.Context; -import android.content.DialogInterface; -import android.graphics.Typeface; -import android.view.Gravity; import android.view.View; import android.widget.Button; -import android.widget.PopupMenu; -import android.widget.TextView; -import android.widget.Toast; import org.joinmastodon.android.R; import org.joinmastodon.android.model.Account; @@ -17,6 +11,7 @@ import org.joinmastodon.android.ui.views.M3Switch; import java.time.Duration; +import java.util.List; import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicReference; @@ -47,7 +42,6 @@ public MuteAccountConfirmationSheet(@NonNull Context context, Account user, Atom Button muteDurationBtn=new Button(getContext()); muteDurationBtn.setOnClickListener(v->getMuteDurationDialog(context, muteDuration, muteDurationBtn).show()); muteDurationBtn.setText(R.string.sk_duration_indefinite); - addRow(R.drawable.ic_fluent_clock_20_regular, R.string.sk_mute_label, muteDurationBtn); } @@ -56,6 +50,15 @@ private M3AlertDialogBuilder getMuteDurationDialog(@NonNull Context context, Ato M3AlertDialogBuilder builder=new M3AlertDialogBuilder(context); builder.setTitle(R.string.sk_mute_label); builder.setIcon(R.drawable.ic_fluent_clock_20_regular); + List durations =List.of(Duration.ZERO, + Duration.ofMinutes(5), + Duration.ofMinutes(30), + Duration.ofHours(1), + Duration.ofHours(6), + Duration.ofDays(1), + Duration.ofDays(3), + Duration.ofDays(7), + Duration.ofDays(7)); String[] choices = {context.getString(R.string.sk_duration_indefinite), context.getString(R.string.sk_duration_minutes_5), @@ -66,35 +69,14 @@ private M3AlertDialogBuilder getMuteDurationDialog(@NonNull Context context, Ato context.getString(R.string.sk_duration_days_3), context.getString(R.string.sk_duration_days_7)}; - builder.setSingleChoiceItems(choices, 0, (dialog, which) -> {}); + builder.setSingleChoiceItems(choices, durations.indexOf(muteDuration.get()), (dialog, which) -> {}); builder.setPositiveButton(R.string.ok, (dialog, which)->{ int selected = ((AlertDialog) dialog).getListView().getCheckedItemPosition(); - if(selected==0){ - muteDuration.set(Duration.ZERO); - }else if(selected==1){ - muteDuration.set(Duration.ofMinutes(5)); - }else if(selected==2){ - muteDuration.set(Duration.ofMinutes(30)); - }else if(selected==3){ - muteDuration.set(Duration.ofHours(1)); - }else if(selected==4){ - muteDuration.set(Duration.ofHours(6)); - }else if(selected==5){ - muteDuration.set(Duration.ofDays(1)); - }else if(selected==6){ - muteDuration.set(Duration.ofDays(3)); - }else if(selected==7){ - muteDuration.set(Duration.ofDays(7)); - } - if(selected >= 0 && selected <= 7){ - button.setText(choices[selected]); - } else { - Toast.makeText(context, "" + selected, Toast.LENGTH_SHORT).show(); - } + muteDuration.set(durations.get(selected)); + button.setText(choices[selected]); }); - - builder.setNegativeButton(R.string.cancel, ((dialogInterface, i) -> {})); + builder.setNegativeButton(R.string.cancel, null); return builder; }