From 8a23f3b84c283d9519d3dc1a2c89b5657b59bdb1 Mon Sep 17 00:00:00 2001 From: Konrad Pozniak Date: Sat, 18 Apr 2020 13:45:07 +0200 Subject: [PATCH] fix content warning in notifications when alwaysShowSpoiler is on (#1757) --- .../tusky/adapter/NotificationsAdapter.java | 11 +++++------ .../tusky/fragment/NotificationsFragment.java | 16 +++++++--------- .../keylesspalace/tusky/util/ViewDataUtils.java | 2 +- .../tusky/viewdata/NotificationViewData.java | 14 +++----------- 4 files changed, 16 insertions(+), 27 deletions(-) diff --git a/app/src/main/java/com/keylesspalace/tusky/adapter/NotificationsAdapter.java b/app/src/main/java/com/keylesspalace/tusky/adapter/NotificationsAdapter.java index ee746891..8d4b4227 100644 --- a/app/src/main/java/com/keylesspalace/tusky/adapter/NotificationsAdapter.java +++ b/app/src/main/java/com/keylesspalace/tusky/adapter/NotificationsAdapter.java @@ -545,7 +545,7 @@ public class NotificationsAdapter extends RecyclerView.Adapter { statusContent.setVisibility(statusViewData.isExpanded() ? View.GONE : View.VISIBLE); }); - setupContentAndSpoiler(notificationViewData, listener); + setupContentAndSpoiler(listener); } } @@ -587,9 +587,8 @@ public class NotificationsAdapter extends RecyclerView.Adapter { } } - private void setupContentAndSpoiler(NotificationViewData.Concrete notificationViewData, final LinkListener listener) { - - boolean shouldShowContentIfSpoiler = notificationViewData.isExpanded(); + private void setupContentAndSpoiler(final LinkListener listener) { + boolean shouldShowContentIfSpoiler = statusViewData.isExpanded(); boolean hasSpoiler = !TextUtils.isEmpty(statusViewData.getSpoilerText()); if (!shouldShowContentIfSpoiler && hasSpoiler) { statusContent.setVisibility(View.GONE); @@ -599,8 +598,8 @@ public class NotificationsAdapter extends RecyclerView.Adapter { Spanned content = statusViewData.getContent(); List emojis = statusViewData.getStatusEmojis(); - - if (statusViewData.isCollapsible() && (notificationViewData.isExpanded() || !hasSpoiler)) { + + if (statusViewData.isCollapsible() && (statusViewData.isExpanded() || !hasSpoiler)) { contentCollapseButton.setOnClickListener(view -> { int position = getAdapterPosition(); if (position != RecyclerView.NO_POSITION && notificationActionListener != null) { diff --git a/app/src/main/java/com/keylesspalace/tusky/fragment/NotificationsFragment.java b/app/src/main/java/com/keylesspalace/tusky/fragment/NotificationsFragment.java index 9259f4a6..5fd94799 100644 --- a/app/src/main/java/com/keylesspalace/tusky/fragment/NotificationsFragment.java +++ b/app/src/main/java/com/keylesspalace/tusky/fragment/NotificationsFragment.java @@ -469,8 +469,7 @@ public class NotificationsFragment extends SFragment implements NotificationViewData.Concrete newViewData = new NotificationViewData.Concrete( viewdata.getType(), viewdata.getId(), viewdata.getAccount(), - viewDataBuilder.createStatusViewData(), viewdata.isExpanded(), viewdata.getEmoji()); - + viewDataBuilder.createStatusViewData(), viewdata.getEmoji()); notifications.setPairedItem(position, newViewData); updateAdapter(); } @@ -504,7 +503,7 @@ public class NotificationsFragment extends SFragment implements NotificationViewData.Concrete newViewData = new NotificationViewData.Concrete( viewdata.getType(), viewdata.getId(), viewdata.getAccount(), - viewDataBuilder.createStatusViewData(), viewdata.isExpanded(), viewdata.getEmoji()); + viewDataBuilder.createStatusViewData(), viewdata.getEmoji()); notifications.setPairedItem(position, newViewData); updateAdapter(); @@ -539,7 +538,7 @@ public class NotificationsFragment extends SFragment implements NotificationViewData.Concrete newViewData = new NotificationViewData.Concrete( viewdata.getType(), viewdata.getId(), viewdata.getAccount(), - viewDataBuilder.createStatusViewData(), viewdata.isExpanded(), viewdata.getEmoji()); + viewDataBuilder.createStatusViewData(), viewdata.getEmoji()); notifications.setPairedItem(position, newViewData); updateAdapter(); @@ -568,7 +567,7 @@ public class NotificationsFragment extends SFragment implements NotificationViewData.Concrete newViewData = new NotificationViewData.Concrete( viewdata.getType(), viewdata.getId(), viewdata.getAccount(), - viewDataBuilder.createStatusViewData(), viewdata.isExpanded(), viewdata.getEmoji()); + viewDataBuilder.createStatusViewData(), viewdata.getEmoji()); notifications.setPairedItem(position, newViewData); updateAdapter(); @@ -608,7 +607,7 @@ public class NotificationsFragment extends SFragment implements .setIsExpanded(expanded) .createStatusViewData(); NotificationViewData notificationViewData = new NotificationViewData.Concrete(old.getType(), - old.getId(), old.getAccount(), statusViewData, expanded, old.getEmoji()); + old.getId(), old.getAccount(), statusViewData, old.getEmoji()); notifications.setPairedItem(position, notificationViewData); updateAdapter(); } @@ -622,7 +621,7 @@ public class NotificationsFragment extends SFragment implements .setIsShowingSensitiveContent(isShowing) .createStatusViewData(); NotificationViewData notificationViewData = new NotificationViewData.Concrete(old.getType(), - old.getId(), old.getAccount(), statusViewData, old.isExpanded(), old.getEmoji()); + old.getId(), old.getAccount(), statusViewData, old.getEmoji()); notifications.setPairedItem(position, notificationViewData); updateAdapter(); } @@ -636,7 +635,7 @@ public class NotificationsFragment extends SFragment implements .setMuted(isMuted) .createStatusViewData(); NotificationViewData notificationViewData = new NotificationViewData.Concrete(old.getType(), - old.getId(), old.getAccount(), statusViewData, old.isExpanded(), old.getEmoji()); + old.getId(), old.getAccount(), statusViewData, old.getEmoji()); notifications.setPairedItem(position, notificationViewData); updateAdapter(); } @@ -708,7 +707,6 @@ public class NotificationsFragment extends SFragment implements concreteNotification.getId(), concreteNotification.getAccount(), updatedStatus, - concreteNotification.isExpanded(), concreteNotification.getEmoji() ); notifications.setPairedItem(position, updatedNotification); diff --git a/app/src/main/java/com/keylesspalace/tusky/util/ViewDataUtils.java b/app/src/main/java/com/keylesspalace/tusky/util/ViewDataUtils.java index 12ff0639..174c874a 100644 --- a/app/src/main/java/com/keylesspalace/tusky/util/ViewDataUtils.java +++ b/app/src/main/java/com/keylesspalace/tusky/util/ViewDataUtils.java @@ -85,8 +85,8 @@ public final class ViewDataUtils { alwaysShowSensitiveData, alwaysOpenSpoiler ), - false, notification.getEmoji() + ) ); } } diff --git a/app/src/main/java/com/keylesspalace/tusky/viewdata/NotificationViewData.java b/app/src/main/java/com/keylesspalace/tusky/viewdata/NotificationViewData.java index c1cb2304..6d36b02d 100644 --- a/app/src/main/java/com/keylesspalace/tusky/viewdata/NotificationViewData.java +++ b/app/src/main/java/com/keylesspalace/tusky/viewdata/NotificationViewData.java @@ -47,18 +47,15 @@ public abstract class NotificationViewData { private final Account account; @Nullable private final StatusViewData.Concrete statusViewData; - private final boolean isExpanded; - @Nullable private final String emoji; public Concrete(Notification.Type type, String id, Account account, - @Nullable StatusViewData.Concrete statusViewData, boolean isExpanded, + @Nullable StatusViewData.Concrete statusViewData, @Nullable String emoji) { this.type = type; this.id = id; this.account = account; this.statusViewData = statusViewData; - this.isExpanded = isExpanded; this.emoji = emoji; } @@ -79,10 +76,6 @@ public abstract class NotificationViewData { return statusViewData; } - public boolean isExpanded() { - return isExpanded; - } - @Nullable public String getEmoji() { return emoji; @@ -98,8 +91,7 @@ public abstract class NotificationViewData { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Concrete concrete = (Concrete) o; - return isExpanded == concrete.isExpanded && - type == concrete.type && + return type == concrete.type && Objects.equals(id, concrete.id) && account.getId().equals(concrete.account.getId()) && (emoji != null && concrete.emoji != null && emoji.equals(concrete.emoji)) && @@ -111,7 +103,7 @@ public abstract class NotificationViewData { @Override public int hashCode() { - return Objects.hash(type, id, account, statusViewData, isExpanded); + return Objects.hash(type, id, account, statusViewData); } }