diff --git a/mastodon/src/main/java/org/joinmastodon/android/api/requests/statuses/CreateStatus.java b/mastodon/src/main/java/org/joinmastodon/android/api/requests/statuses/CreateStatus.java index a0ae62006..52b93809b 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/api/requests/statuses/CreateStatus.java +++ b/mastodon/src/main/java/org/joinmastodon/android/api/requests/statuses/CreateStatus.java @@ -11,13 +11,11 @@ import java.util.ArrayList; import java.util.List; public class CreateStatus extends MastodonAPIRequest{ - public static final Instant DRAFTS_AFTER_INSTANT = Instant.ofEpochMilli(253370764799999L) /* end of 9998 */; - private static final float draftFactor = 31536000000f /* one year */ / 253370764799999f /* end of 9998 */; + public static long EPOCH_OF_THE_YEAR_FIVE_THOUSAND=95617584000000L; + public static final Instant DRAFTS_AFTER_INSTANT=Instant.ofEpochMilli(EPOCH_OF_THE_YEAR_FIVE_THOUSAND - 1) /* end of 4999 */; public static Instant getDraftInstant() { - // returns an instant between 9999-01-01 00:00:00 and 9999-12-31 23:59:59 - // yes, this is a weird implementation for something that hardly matters - return DRAFTS_AFTER_INSTANT.plusMillis(1 + (long) (System.currentTimeMillis() * draftFactor)); + return DRAFTS_AFTER_INSTANT.plusMillis(System.currentTimeMillis()); } public CreateStatus(CreateStatus.Request req, String uuid){ diff --git a/mastodon/src/main/java/org/joinmastodon/android/api/session/AccountLocalPreferences.java b/mastodon/src/main/java/org/joinmastodon/android/api/session/AccountLocalPreferences.java index 32b4eb162..ae0c685d8 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/api/session/AccountLocalPreferences.java +++ b/mastodon/src/main/java/org/joinmastodon/android/api/session/AccountLocalPreferences.java @@ -42,7 +42,7 @@ public class AccountLocalPreferences{ public boolean keepOnlyLatestNotification; public boolean emojiReactionsEnabled; - public boolean showEmojiReactionsInLists; + public boolean emojiReactionsInTimelines; private final static Type recentLanguagesType = new TypeToken>() {}.getType(); private final static Type timelinesType = new TypeToken>() {}.getType(); @@ -73,7 +73,7 @@ public class AccountLocalPreferences{ timelineReplyVisibility=prefs.getString("timelineReplyVisibility", null); keepOnlyLatestNotification=prefs.getBoolean("keepOnlyLatestNotification", false); emojiReactionsEnabled=prefs.getBoolean("emojiReactionsEnabled", session.getInstance().isPresent() && session.getInstance().get().isAkkoma()); - showEmojiReactionsInLists=prefs.getBoolean("showEmojiReactionsInLists", false); + emojiReactionsInTimelines=prefs.getBoolean("emojiReactionsInTimelines", true); // MOSHIDON recentEmojis=fromJson(prefs.getString("recentEmojis", "{}"), recentEmojisType, new HashMap<>()); @@ -109,7 +109,7 @@ public class AccountLocalPreferences{ .putString("timelineReplyVisibility", timelineReplyVisibility) .putBoolean("keepOnlyLatestNotification", keepOnlyLatestNotification) .putBoolean("emojiReactionsEnabled", emojiReactionsEnabled) - .putBoolean("showEmojiReactionsInLists", showEmojiReactionsInLists) + .putBoolean("emojiReactionsInTimelines", emojiReactionsInTimelines) // MOSHIDON .putString("recentEmojis", gson.toJson(recentEmojis)) diff --git a/mastodon/src/main/java/org/joinmastodon/android/events/EmojiReactionsUpdatedEvent.java b/mastodon/src/main/java/org/joinmastodon/android/events/EmojiReactionsUpdatedEvent.java new file mode 100644 index 000000000..2e0ce6467 --- /dev/null +++ b/mastodon/src/main/java/org/joinmastodon/android/events/EmojiReactionsUpdatedEvent.java @@ -0,0 +1,19 @@ +package org.joinmastodon.android.events; + +import androidx.recyclerview.widget.RecyclerView; +import org.joinmastodon.android.model.EmojiReaction; +import java.util.List; + +public class EmojiReactionsUpdatedEvent{ + public final String id; + public final List reactions; + public final boolean updateTextPadding; + public RecyclerView.ViewHolder viewHolder; + + public EmojiReactionsUpdatedEvent(String id, List reactions, boolean updateTextPadding, RecyclerView.ViewHolder viewHolder){ + this.id=id; + this.reactions=reactions; + this.updateTextPadding=updateTextPadding; + this.viewHolder=viewHolder; + } +} diff --git a/mastodon/src/main/java/org/joinmastodon/android/events/StatusCountersUpdatedEvent.java b/mastodon/src/main/java/org/joinmastodon/android/events/StatusCountersUpdatedEvent.java index 3027a3809..cdcf37104 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/events/StatusCountersUpdatedEvent.java +++ b/mastodon/src/main/java/org/joinmastodon/android/events/StatusCountersUpdatedEvent.java @@ -1,27 +1,14 @@ package org.joinmastodon.android.events; -import androidx.recyclerview.widget.RecyclerView; - -import org.joinmastodon.android.api.CacheController; -import org.joinmastodon.android.model.EmojiReaction; import org.joinmastodon.android.model.Status; -import java.util.ArrayList; -import java.util.List; - public class StatusCountersUpdatedEvent{ public String id; public long favorites, reblogs, replies; public boolean favorited, reblogged, bookmarked, pinned; - public List reactions; public Status status; - public RecyclerView.ViewHolder viewHolder; public StatusCountersUpdatedEvent(Status s){ - this(s, null); - } - - public StatusCountersUpdatedEvent(Status s, RecyclerView.ViewHolder vh){ id=s.id; status=s; favorites=s.favouritesCount; @@ -31,7 +18,5 @@ public class StatusCountersUpdatedEvent{ reblogged=s.reblogged; bookmarked=s.bookmarked; pinned=s.pinned; - reactions=new ArrayList<>(s.reactions); - viewHolder=vh; } } diff --git a/mastodon/src/main/java/org/joinmastodon/android/fragments/NotificationsListFragment.java b/mastodon/src/main/java/org/joinmastodon/android/fragments/NotificationsListFragment.java index 92171e380..02fb2cf07 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/fragments/NotificationsListFragment.java +++ b/mastodon/src/main/java/org/joinmastodon/android/fragments/NotificationsListFragment.java @@ -15,6 +15,7 @@ import org.joinmastodon.android.E; import org.joinmastodon.android.GlobalUserPreferences; import org.joinmastodon.android.R; import org.joinmastodon.android.api.session.AccountSessionManager; +import org.joinmastodon.android.events.EmojiReactionsUpdatedEvent; import org.joinmastodon.android.events.PollUpdatedEvent; import org.joinmastodon.android.events.RemoveAccountPostsEvent; import org.joinmastodon.android.events.StatusCountersUpdatedEvent; @@ -27,6 +28,7 @@ import org.joinmastodon.android.ui.displayitems.ExtendedFooterStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.FooterStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.NotificationHeaderStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.StatusDisplayItem; +import org.joinmastodon.android.ui.displayitems.TextStatusDisplayItem; import org.joinmastodon.android.ui.utils.DiscoverInfoBannerHelper; import org.joinmastodon.android.ui.utils.InsetStatusItemDecoration; import org.joinmastodon.android.ui.utils.UiUtils; @@ -43,7 +45,6 @@ import androidx.annotation.NonNull; import androidx.recyclerview.widget.RecyclerView; import me.grishka.appkit.api.SimpleCallback; import me.grishka.appkit.utils.MergeRecyclerAdapter; -import me.grishka.appkit.views.FragmentRootLinearLayout; public class NotificationsListFragment extends BaseStatusListFragment { private boolean onlyMentions; @@ -102,8 +103,6 @@ public class NotificationsListFragment extends BaseStatusListFragment items=StatusDisplayItem.buildItems(this, n.status, accountID, n, knownAccounts, null, flags); if(titleItem!=null) items.add(0, titleItem); @@ -258,8 +257,6 @@ public class NotificationsListFragment extends BaseStatusListFragment buildDisplayItems(ScheduledStatus s) { - return StatusDisplayItem.buildItems(this, s.toStatus(), accountID, s, knownAccounts, false, false, false, true, null); + return StatusDisplayItem.buildItems(this, s.toStatus(), accountID, s, knownAccounts, null, + StatusDisplayItem.FLAG_NO_EMOJI_REACTIONS | + StatusDisplayItem.FLAG_NO_FOOTER | + StatusDisplayItem.FLAG_NO_TRANSLATE); } @Override diff --git a/mastodon/src/main/java/org/joinmastodon/android/fragments/StatusListFragment.java b/mastodon/src/main/java/org/joinmastodon/android/fragments/StatusListFragment.java index fcb3890c5..7e9f7bc72 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/fragments/StatusListFragment.java +++ b/mastodon/src/main/java/org/joinmastodon/android/fragments/StatusListFragment.java @@ -8,6 +8,7 @@ import com.squareup.otto.Subscribe; import org.joinmastodon.android.E; import org.joinmastodon.android.GlobalUserPreferences; import org.joinmastodon.android.api.session.AccountSessionManager; +import org.joinmastodon.android.events.EmojiReactionsUpdatedEvent; import org.joinmastodon.android.MainActivity; import org.joinmastodon.android.events.PollUpdatedEvent; import org.joinmastodon.android.events.RemoveAccountPostsEvent; @@ -21,6 +22,7 @@ import org.joinmastodon.android.ui.displayitems.EmojiReactionsStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.ExtendedFooterStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.FooterStatusDisplayItem; import org.joinmastodon.android.ui.displayitems.StatusDisplayItem; +import org.joinmastodon.android.ui.displayitems.TextStatusDisplayItem; import org.joinmastodon.android.ui.utils.UiUtils; import org.parceler.Parcels; @@ -40,7 +42,7 @@ public abstract class StatusListFragment extends BaseStatusListFragment int flags = 0; if (GlobalUserPreferences.spectatorMode) flags |= StatusDisplayItem.FLAG_NO_FOOTER; - if (!getLocalPrefs().showEmojiReactionsInLists) + if (!getLocalPrefs().emojiReactionsInTimelines) flags |= StatusDisplayItem.FLAG_NO_EMOJI_REACTIONS; return StatusDisplayItem.buildItems(this, s, accountID, s, knownAccounts, getFilterContext(), isMainThreadStatus ? 0 : flags); } @@ -237,8 +239,30 @@ public abstract class StatusListFragment extends BaseStatusListFragment footer.rebind(); }else if(holder instanceof ExtendedFooterStatusDisplayItem.Holder footer && footer.getItem().status==s.getContentStatus()){ footer.rebind(); - }else if(holder instanceof EmojiReactionsStatusDisplayItem.Holder reactions && reactions.getItem().status==s.getContentStatus() && ev.viewHolder!=holder){ + } + } + } + } + for(Status s:preloadedData){ + if(s.getContentStatus().id.equals(ev.id)){ + s.getContentStatus().update(ev); + AccountSessionManager.get(accountID).getCacheController().updateStatus(s); + } + } + } + + @Subscribe + public void onEmojiReactionsChanged(EmojiReactionsUpdatedEvent ev){ + for(Status s:data){ + if(s.getContentStatus().id.equals(ev.id)){ + s.getContentStatus().update(ev); + AccountSessionManager.get(accountID).getCacheController().updateStatus(s); + for(int i=0;i{ return switch(s.type){ case ACCOUNT -> Collections.singletonList(new AccountStatusDisplayItem(s.id, this, s.account)); case HASHTAG -> Collections.singletonList(new HashtagStatusDisplayItem(s.id, this, s.hashtag)); - case STATUS -> StatusDisplayItem.buildItems(this, s.status, accountID, s, knownAccounts, FilterContext.PUBLIC, !getLocalPrefs().showEmojiReactionsInLists ? StatusDisplayItem.FLAG_NO_EMOJI_REACTIONS : 0); + case STATUS -> StatusDisplayItem.buildItems(this, s.status, accountID, s, knownAccounts, FilterContext.PUBLIC, 0); }; } diff --git a/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsInstanceFragment.java b/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsInstanceFragment.java index 6d6bdd5d2..e7b28d398 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsInstanceFragment.java +++ b/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsInstanceFragment.java @@ -19,7 +19,7 @@ import java.util.List; import me.grishka.appkit.Nav; public class SettingsInstanceFragment extends BaseSettingsFragment implements HasAccountID{ - private CheckableListItem contentTypesItem, emojiReactionsItem, emojiReactionsInListsItem, localOnlyItem, glitchModeItem; + private CheckableListItem contentTypesItem, emojiReactionsItem, emojiReactionsInTimelinesItem, localOnlyItem, glitchModeItem; private ListItem defaultContentTypeItem; private AccountLocalPreferences lp; @@ -35,16 +35,16 @@ public class SettingsInstanceFragment extends BaseSettingsFragment impleme new ListItem<>(R.string.sk_settings_posting, 0, R.drawable.ic_fluent_open_24_regular, ()->UiUtils.launchWebBrowser(getActivity(), "https://"+s.domain+"/settings/preferences/other")), new ListItem<>(R.string.sk_settings_auth, 0, R.drawable.ic_fluent_open_24_regular, ()->UiUtils.launchWebBrowser(getActivity(), "https://"+s.domain+"/auth/edit"), 0, true), contentTypesItem=new CheckableListItem<>(R.string.sk_settings_content_types, R.string.sk_settings_content_types_explanation, CheckableListItem.Style.SWITCH, lp.contentTypesEnabled, R.drawable.ic_fluent_text_edit_style_24_regular, this::onContentTypeClick), - defaultContentTypeItem=new ListItem<>(R.string.sk_settings_default_content_type, lp.defaultContentType.getName(), R.drawable.ic_fluent_text_bold_24_regular, this::onDefaultContentTypeClick), + defaultContentTypeItem=new ListItem<>(R.string.sk_settings_default_content_type, lp.defaultContentType.getName(), R.drawable.ic_fluent_text_bold_24_regular, this::onDefaultContentTypeClick, 0, true), emojiReactionsItem=new CheckableListItem<>(R.string.sk_settings_emoji_reactions, R.string.sk_settings_emoji_reactions_explanation, CheckableListItem.Style.SWITCH, lp.emojiReactionsEnabled, R.drawable.ic_fluent_emoji_laugh_24_regular, this::onEmojiReactionsClick), - emojiReactionsInListsItem=new CheckableListItem<>(R.string.sk_settings_emoji_reactions_in_lists, R.string.sk_settings_emoji_reactions_in_lists_explanation, CheckableListItem.Style.SWITCH, lp.showEmojiReactionsInLists, R.drawable.ic_fluent_emoji_24_regular, ()->toggleCheckableItem(emojiReactionsInListsItem)), + emojiReactionsInTimelinesItem=new CheckableListItem<>(R.string.sk_settings_emoji_reactions_in_lists, R.string.sk_settings_emoji_reactions_in_lists_explanation, CheckableListItem.Style.SWITCH, lp.emojiReactionsInTimelines, R.drawable.ic_fluent_emoji_24_regular, ()->toggleCheckableItem(emojiReactionsInTimelinesItem), true), localOnlyItem=new CheckableListItem<>(R.string.sk_settings_support_local_only, R.string.sk_settings_local_only_explanation, CheckableListItem.Style.SWITCH, lp.localOnlySupported, R.drawable.ic_fluent_eye_24_regular, this::onLocalOnlyClick), glitchModeItem=new CheckableListItem<>(R.string.sk_settings_glitch_instance, R.string.sk_settings_glitch_mode_explanation, CheckableListItem.Style.SWITCH, lp.glitchInstance, R.drawable.ic_fluent_eye_24_filled, ()->toggleCheckableItem(glitchModeItem)) )); contentTypesItem.checkedChangeListener=checked->onContentTypeClick(); defaultContentTypeItem.isEnabled=contentTypesItem.checked; emojiReactionsItem.checkedChangeListener=checked->onEmojiReactionsClick(); - emojiReactionsInListsItem.isEnabled=emojiReactionsItem.checked; + emojiReactionsInTimelinesItem.isEnabled=emojiReactionsItem.checked; localOnlyItem.checkedChangeListener=checked->onLocalOnlyClick(); glitchModeItem.isEnabled=localOnlyItem.checked; } @@ -57,7 +57,7 @@ public class SettingsInstanceFragment extends BaseSettingsFragment impleme super.onHidden(); lp.contentTypesEnabled=contentTypesItem.checked; lp.emojiReactionsEnabled=emojiReactionsItem.checked; - lp.showEmojiReactionsInLists=emojiReactionsInListsItem.checked; + lp.emojiReactionsInTimelines=emojiReactionsInTimelinesItem.checked; lp.localOnlySupported=localOnlyItem.checked; lp.glitchInstance=glitchModeItem.checked; lp.save(); @@ -109,9 +109,8 @@ public class SettingsInstanceFragment extends BaseSettingsFragment impleme private void onEmojiReactionsClick(){ toggleCheckableItem(emojiReactionsItem); - emojiReactionsInListsItem.checked=false; - emojiReactionsInListsItem.isEnabled=emojiReactionsItem.checked; - rebindItem(emojiReactionsInListsItem); + emojiReactionsInTimelinesItem.checked=emojiReactionsInTimelinesItem.isEnabled=emojiReactionsItem.checked; + rebindItem(emojiReactionsInTimelinesItem); } private void onLocalOnlyClick(){ diff --git a/mastodon/src/main/java/org/joinmastodon/android/model/Status.java b/mastodon/src/main/java/org/joinmastodon/android/model/Status.java index 7cb25a548..2b0f50402 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/model/Status.java +++ b/mastodon/src/main/java/org/joinmastodon/android/model/Status.java @@ -15,10 +15,10 @@ import com.google.gson.JsonElement; import com.google.gson.JsonObject; import com.google.gson.JsonParseException; -import org.joinmastodon.android.GlobalUserPreferences; import org.joinmastodon.android.api.ObjectValidationException; import org.joinmastodon.android.api.RequiredField; import org.joinmastodon.android.api.session.AccountSessionManager; +import org.joinmastodon.android.events.EmojiReactionsUpdatedEvent; import org.joinmastodon.android.events.StatusCountersUpdatedEvent; import org.joinmastodon.android.ui.text.HtmlParser; import org.parceler.Parcel; @@ -181,6 +181,9 @@ public class Status extends BaseModel implements DisplayItemsParent, Searchable{ reblogged=ev.reblogged; bookmarked=ev.bookmarked; pinned=ev.pinned; + } + + public void update(EmojiReactionsUpdatedEvent ev){ reactions=ev.reactions; } diff --git a/mastodon/src/main/java/org/joinmastodon/android/ui/displayitems/EmojiReactionsStatusDisplayItem.java b/mastodon/src/main/java/org/joinmastodon/android/ui/displayitems/EmojiReactionsStatusDisplayItem.java index 109678a7d..bce5e4461 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/ui/displayitems/EmojiReactionsStatusDisplayItem.java +++ b/mastodon/src/main/java/org/joinmastodon/android/ui/displayitems/EmojiReactionsStatusDisplayItem.java @@ -31,11 +31,10 @@ import org.joinmastodon.android.api.requests.statuses.PleromaAddStatusReaction; import org.joinmastodon.android.api.requests.statuses.PleromaDeleteStatusReaction; import org.joinmastodon.android.api.session.AccountSession; import org.joinmastodon.android.api.session.AccountSessionManager; -import org.joinmastodon.android.events.StatusCountersUpdatedEvent; +import org.joinmastodon.android.events.EmojiReactionsUpdatedEvent; import org.joinmastodon.android.fragments.BaseStatusListFragment; import org.joinmastodon.android.fragments.account_list.StatusEmojiReactionsListFragment; import org.joinmastodon.android.model.Account; -import org.joinmastodon.android.model.Announcement; import org.joinmastodon.android.model.Emoji; import org.joinmastodon.android.model.EmojiReaction; import org.joinmastodon.android.model.Status; @@ -44,8 +43,6 @@ import org.joinmastodon.android.ui.utils.TextDrawable; import org.joinmastodon.android.ui.utils.UiUtils; import org.joinmastodon.android.ui.views.ProgressBarButton; -import java.util.Optional; - import me.grishka.appkit.Nav; import me.grishka.appkit.api.Callback; import me.grishka.appkit.api.ErrorResponse; @@ -62,20 +59,18 @@ import me.grishka.appkit.views.UsableRecyclerView; public class EmojiReactionsStatusDisplayItem extends StatusDisplayItem { public final Status status; private final Drawable placeholder; - private final boolean hideAdd, forAnnouncement; + private final boolean hideEmpty, forAnnouncement; private final String accountID; - private boolean hidden; private static final float ALPHA_DISABLED=0.55f; - public EmojiReactionsStatusDisplayItem(String parentID, BaseStatusListFragment parentFragment, Status status, String accountID, boolean hideAdd, boolean forAnnouncement) { + public EmojiReactionsStatusDisplayItem(String parentID, BaseStatusListFragment parentFragment, Status status, String accountID, boolean hideEmpty, boolean forAnnouncement) { super(parentID, parentFragment); this.status=status; - this.hideAdd=hideAdd; + this.hideEmpty=hideEmpty; this.forAnnouncement=forAnnouncement; this.accountID=accountID; placeholder=parentFragment.getContext().getDrawable(R.drawable.image_placeholder).mutate(); placeholder.setBounds(0, 0, V.sp(24), V.sp(24)); - updateHidden(); } @Override @@ -94,11 +89,7 @@ public class EmojiReactionsStatusDisplayItem extends StatusDisplayItem { } public boolean isHidden(){ - return hidden; - } - - private void updateHidden(){ - hidden=status.reactions.isEmpty() && hideAdd; + return status.reactions.isEmpty() && hideEmpty; } // borrowed from ProfileFragment @@ -187,12 +178,12 @@ public class EmojiReactionsStatusDisplayItem extends StatusDisplayItem { emojiKeyboard.setListener(this); space.setVisibility(View.GONE); root.addView(emojiKeyboard.getView()); - item.updateHidden(); - root.setVisibility(item.hidden ? View.GONE : View.VISIBLE); - line.setVisibility(item.hidden ? View.GONE : View.VISIBLE); + boolean hidden=item.isHidden(); + root.setVisibility(hidden ? View.GONE : View.VISIBLE); + line.setVisibility(hidden ? View.GONE : View.VISIBLE); line.setPadding( list.getPaddingLeft(), - item.hidden ? 0 : V.dp(8), + hidden ? 0 : V.dp(8), list.getPaddingRight(), item.forAnnouncement ? V.dp(8) : 0 ); @@ -219,6 +210,7 @@ public class EmojiReactionsStatusDisplayItem extends StatusDisplayItem { } private void addEmojiReaction(String emoji, Emoji info) { + int countBefore=item.status.reactions.size(); for(int i=0; i buildItems(BaseStatusListFragment fragment, Status status, String accountID, DisplayItemsParent parentObject, Map knownAccounts, boolean inset, boolean showReactions, boolean addFooter, boolean disableTranslate, FilterContext filterContext) { - int flags=0; - if(inset) - flags|=FLAG_INSET; - if(!addFooter) - flags|=FLAG_NO_FOOTER; - if (disableTranslate) - flags|=FLAG_NO_TRANSLATE; - if (!showReactions) - flags|=FLAG_NO_EMOJI_REACTIONS; - return buildItems(fragment, status, accountID, parentObject, knownAccounts, filterContext, flags); - } - public static ReblogOrReplyLineStatusDisplayItem buildReplyLine(BaseStatusListFragment fragment, Status status, String accountID, DisplayItemsParent parent, Account account, boolean threadReply) { String parentID = parent.getID(); String text = threadReply ? fragment.getString(R.string.sk_show_thread) @@ -293,8 +280,8 @@ public abstract class StatusDisplayItem{ if(contentItems!=items && statusForContent.spoilerRevealed){ items.addAll(contentItems); } - if((flags & FLAG_NO_EMOJI_REACTIONS)==0 - && AccountSessionManager.get(accountID).getLocalPreferences().emojiReactionsEnabled){ + if((flags & FLAG_NO_EMOJI_REACTIONS)==0 && fragment.getLocalPrefs().emojiReactionsEnabled && + (fragment.getLocalPrefs().emojiReactionsInTimelines || fragment instanceof ThreadFragment)){ boolean isMainStatus=fragment instanceof ThreadFragment t && t.getMainStatus().id.equals(statusForContent.id); items.add(new EmojiReactionsStatusDisplayItem(parentID, fragment, statusForContent, accountID, !isMainStatus, false)); } @@ -401,15 +388,7 @@ public abstract class StatusDisplayItem{ } return Optional.empty(); } -// int nextNextPos=getAbsoluteAdapterPosition() + 2; -// if(next.map(n->n instanceof EmojiReactionsStatusDisplayItem e && e.isHidden()).orElse(false)){ -// List displayItems=item.parentFragment.getDisplayItems(); -// return displayItems.size() > nextNextPos -// ? Optional.of(displayItems.get(nextNextPos)) -// : Optional.empty(); -// }else{ -// return next; -// } + public Optional getNextDisplayItem(){ return getDisplayItemOffset(1); }