mirror of
https://codeberg.org/tom79/Fedilab.git
synced 2025-01-05 15:40:08 +02:00
Delay loading of other timelines + display when available
This commit is contained in:
parent
3d4f075c9c
commit
382a198572
3 changed files with 94 additions and 10 deletions
|
@ -164,6 +164,7 @@ public abstract class BaseMainActivity extends BaseActivity implements NetworkSt
|
||||||
public static String regex_home, regex_local, regex_public;
|
public static String regex_home, regex_local, regex_public;
|
||||||
public static BaseAccount currentAccount;
|
public static BaseAccount currentAccount;
|
||||||
Fragment currentFragment;
|
Fragment currentFragment;
|
||||||
|
public static String slugOfFirstFragment;
|
||||||
private AppBarConfiguration mAppBarConfiguration;
|
private AppBarConfiguration mAppBarConfiguration;
|
||||||
private ActivityMainBinding binding;
|
private ActivityMainBinding binding;
|
||||||
private final BroadcastReceiver broadcast_error_message = new BroadcastReceiver() {
|
private final BroadcastReceiver broadcast_error_message = new BroadcastReceiver() {
|
||||||
|
@ -894,6 +895,8 @@ public abstract class BaseMainActivity extends BaseActivity implements NetworkSt
|
||||||
new ViewModelProvider(BaseMainActivity.this).get(TopBarVM.class).getDBPinned()
|
new ViewModelProvider(BaseMainActivity.this).get(TopBarVM.class).getDBPinned()
|
||||||
.observe(this, pinned -> {
|
.observe(this, pinned -> {
|
||||||
this.pinned = pinned;
|
this.pinned = pinned;
|
||||||
|
//Initialize the slug of the first fragment
|
||||||
|
slugOfFirstFragment = PinnedTimelineHelper.firstTimelineSlug(BaseMainActivity.this, pinned, bottomMenu);
|
||||||
//First it's taken from db (last stored values)
|
//First it's taken from db (last stored values)
|
||||||
PinnedTimelineHelper.redrawTopBarPinned(BaseMainActivity.this, binding, pinned, bottomMenu, null);
|
PinnedTimelineHelper.redrawTopBarPinned(BaseMainActivity.this, binding, pinned, bottomMenu, null);
|
||||||
//Fetch remote lists for the authenticated account and update them
|
//Fetch remote lists for the authenticated account and update them
|
||||||
|
|
|
@ -22,6 +22,7 @@ import static app.fedilab.android.BaseMainActivity.show_replies;
|
||||||
import static app.fedilab.android.ui.pageadapter.FedilabPageAdapter.BOTTOM_TIMELINE_COUNT;
|
import static app.fedilab.android.ui.pageadapter.FedilabPageAdapter.BOTTOM_TIMELINE_COUNT;
|
||||||
|
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.text.Editable;
|
import android.text.Editable;
|
||||||
|
@ -91,6 +92,59 @@ public class PinnedTimelineHelper {
|
||||||
Collections.sort(menuItemList, (obj1, obj2) -> Integer.compare(obj1.position, obj2.position));
|
Collections.sort(menuItemList, (obj1, obj2) -> Integer.compare(obj1.position, obj2.position));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the slug of the first loaded fragment
|
||||||
|
*
|
||||||
|
* @param context - Context
|
||||||
|
* @param pinned - {@link Pinned}
|
||||||
|
* @param bottomMenu - {@link BottomMenu}
|
||||||
|
* @return String - slug
|
||||||
|
*/
|
||||||
|
public static String firstTimelineSlug(Context context, Pinned pinned, BottomMenu bottomMenu) {
|
||||||
|
String slug = null;
|
||||||
|
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
|
||||||
|
boolean singleBar = sharedpreferences.getBoolean(context.getString(R.string.SET_USE_SINGLE_TOPBAR), false);
|
||||||
|
PinnedTimeline pinnedTimelineMin = null;
|
||||||
|
if (singleBar) {
|
||||||
|
for (PinnedTimeline pinnedTimeline : pinned.pinnedTimelines) {
|
||||||
|
if (pinnedTimeline.displayed) {
|
||||||
|
if (pinnedTimelineMin == null) {
|
||||||
|
pinnedTimelineMin = pinnedTimeline;
|
||||||
|
} else if (pinnedTimelineMin.position > pinnedTimeline.position) {
|
||||||
|
pinnedTimelineMin = pinnedTimeline;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (bottomMenu != null && bottomMenu.bottom_menu != null && bottomMenu.bottom_menu.size() > 0) {
|
||||||
|
BottomMenu.MenuItem menuItem = bottomMenu.bottom_menu.get(0);
|
||||||
|
return menuItem.item_menu_type.getValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
String ident = null;
|
||||||
|
if (pinnedTimelineMin != null) {
|
||||||
|
if (pinnedTimelineMin.tagTimeline != null) {
|
||||||
|
ident = "@T@" + pinnedTimelineMin.tagTimeline.name;
|
||||||
|
if (pinnedTimelineMin.tagTimeline.isART) {
|
||||||
|
pinnedTimelineMin.type = Timeline.TimeLineEnum.ART;
|
||||||
|
}
|
||||||
|
} else if (pinnedTimelineMin.mastodonList != null) {
|
||||||
|
ident = "@l@" + pinnedTimelineMin.mastodonList.id;
|
||||||
|
} else if (pinnedTimelineMin.remoteInstance != null) {
|
||||||
|
if (pinnedTimelineMin.remoteInstance.type == RemoteInstance.InstanceType.NITTER) {
|
||||||
|
String remoteInstance = sharedpreferences.getString(context.getString(R.string.SET_NITTER_HOST), context.getString(R.string.DEFAULT_NITTER_HOST)).toLowerCase();
|
||||||
|
ident = "@R@" + remoteInstance;
|
||||||
|
} else {
|
||||||
|
ident = "@R@" + pinnedTimelineMin.remoteInstance.host;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
slug = pinnedTimelineMin.type.getValue() + (ident != null ? "|" + ident : "");
|
||||||
|
}
|
||||||
|
return slug;
|
||||||
|
}
|
||||||
|
|
||||||
public synchronized static void redrawTopBarPinned(BaseMainActivity activity, ActivityMainBinding activityMainBinding, Pinned pinned, BottomMenu bottomMenu, List<MastodonList> mastodonLists) {
|
public synchronized static void redrawTopBarPinned(BaseMainActivity activity, ActivityMainBinding activityMainBinding, Pinned pinned, BottomMenu bottomMenu, List<MastodonList> mastodonLists) {
|
||||||
//Values must be initialized if there is no records in db
|
//Values must be initialized if there is no records in db
|
||||||
if (pinned == null) {
|
if (pinned == null) {
|
||||||
|
|
|
@ -16,6 +16,7 @@ package app.fedilab.android.ui.fragment.timeline;
|
||||||
|
|
||||||
|
|
||||||
import static app.fedilab.android.BaseMainActivity.networkAvailable;
|
import static app.fedilab.android.BaseMainActivity.networkAvailable;
|
||||||
|
import static app.fedilab.android.BaseMainActivity.slugOfFirstFragment;
|
||||||
|
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
@ -78,14 +79,8 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
private Timeline.TimeLineEnum timelineType;
|
private Timeline.TimeLineEnum timelineType;
|
||||||
private List<Status> timelineStatuses;
|
private List<Status> timelineStatuses;
|
||||||
public UpdateCounters update;
|
public UpdateCounters update;
|
||||||
|
private boolean isViewInitialized;
|
||||||
@Override
|
private Statuses initialStatuses;
|
||||||
public void onResume() {
|
|
||||||
super.onResume();
|
|
||||||
if (timelineStatuses != null && timelineStatuses.size() > 0) {
|
|
||||||
route(DIRECTION.FETCH_NEW, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//Handle actions that can be done in other fragments
|
//Handle actions that can be done in other fragments
|
||||||
private final BroadcastReceiver receive_action = new BroadcastReceiver() {
|
private final BroadcastReceiver receive_action = new BroadcastReceiver() {
|
||||||
|
@ -147,6 +142,18 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
private TimelinesVM.TimelineParams timelineParams;
|
private TimelinesVM.TimelineParams timelineParams;
|
||||||
private boolean canBeFederated;
|
private boolean canBeFederated;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
if (slug.compareTo(slugOfFirstFragment) != 0 && !isViewInitialized) {
|
||||||
|
isViewInitialized = true;
|
||||||
|
initializeStatusesCommonView(initialStatuses);
|
||||||
|
}
|
||||||
|
if (timelineStatuses != null && timelineStatuses.size() > 0) {
|
||||||
|
route(DIRECTION.FETCH_NEW, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the position of the status in the ArrayList
|
* Return the position of the status in the ArrayList
|
||||||
*
|
*
|
||||||
|
@ -196,6 +203,7 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
ViewGroup container, Bundle savedInstanceState) {
|
ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
|
||||||
timelineType = Timeline.TimeLineEnum.HOME;
|
timelineType = Timeline.TimeLineEnum.HOME;
|
||||||
|
|
||||||
canBeFederated = true;
|
canBeFederated = true;
|
||||||
if (getArguments() != null) {
|
if (getArguments() != null) {
|
||||||
timelineType = (Timeline.TimeLineEnum) getArguments().get(Helper.ARG_TIMELINE_TYPE);
|
timelineType = (Timeline.TimeLineEnum) getArguments().get(Helper.ARG_TIMELINE_TYPE);
|
||||||
|
@ -244,6 +252,8 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
if (timelineType != null) {
|
if (timelineType != null) {
|
||||||
slug = timelineType.getValue() + (ident != null ? "|" + ident : "");
|
slug = timelineType.getValue() + (ident != null ? "|" + ident : "");
|
||||||
}
|
}
|
||||||
|
//Only the first fragment will initialize its view
|
||||||
|
isViewInitialized = slug.compareTo(slugOfFirstFragment) == 0;
|
||||||
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(requireActivity());
|
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(requireActivity());
|
||||||
//Retrieve the max_id to keep position
|
//Retrieve the max_id to keep position
|
||||||
|
|
||||||
|
@ -357,6 +367,9 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
*/
|
*/
|
||||||
private void initializeStatusesCommonView(final Statuses statuses) {
|
private void initializeStatusesCommonView(final Statuses statuses) {
|
||||||
flagLoading = false;
|
flagLoading = false;
|
||||||
|
if (!isViewInitialized) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (binding == null || !isAdded() || getActivity() == null) {
|
if (binding == null || !isAdded() || getActivity() == null) {
|
||||||
if (binding != null) {
|
if (binding != null) {
|
||||||
binding.loader.setVisibility(View.GONE);
|
binding.loader.setVisibility(View.GONE);
|
||||||
|
@ -528,6 +541,9 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
* @param direction - DIRECTION null if first call, then is set to TOP or BOTTOM depending of scroll
|
* @param direction - DIRECTION null if first call, then is set to TOP or BOTTOM depending of scroll
|
||||||
*/
|
*/
|
||||||
private void routeCommon(DIRECTION direction, boolean fetchingMissing, Status status) {
|
private void routeCommon(DIRECTION direction, boolean fetchingMissing, Status status) {
|
||||||
|
if (direction == null) {
|
||||||
|
isViewInitialized = slug.compareTo(slugOfFirstFragment) == 0;
|
||||||
|
}
|
||||||
if (binding == null || getActivity() == null || !isAdded()) {
|
if (binding == null || getActivity() == null || !isAdded()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -584,13 +600,17 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
|
|
||||||
Handler handler = new Handler();
|
Handler handler = new Handler();
|
||||||
//The action for fetching new messages is delayed for other timelines than HOME
|
//The action for fetching new messages is delayed for other timelines than HOME
|
||||||
|
if (slugOfFirstFragment == null) {
|
||||||
|
slugOfFirstFragment = slug;
|
||||||
|
}
|
||||||
|
|
||||||
handler.postDelayed(() -> {
|
handler.postDelayed(() -> {
|
||||||
if (useCache && direction != DIRECTION.SCROLL_TOP && direction != DIRECTION.FETCH_NEW) {
|
if (useCache && direction != DIRECTION.SCROLL_TOP && direction != DIRECTION.FETCH_NEW) {
|
||||||
getCachedStatus(direction, fetchingMissing, timelineParams);
|
getCachedStatus(direction, fetchingMissing, timelineParams);
|
||||||
} else {
|
} else {
|
||||||
getLiveStatus(direction, fetchingMissing, timelineParams, status);
|
getLiveStatus(direction, fetchingMissing, timelineParams, status);
|
||||||
}
|
}
|
||||||
}, timelineType == Timeline.TimeLineEnum.HOME ? 0 : 1000);
|
}, slug.compareTo(slugOfFirstFragment) == 0 ? 0 : 1000);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -652,6 +672,7 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
if (direction == null) {
|
if (direction == null) {
|
||||||
timelinesVM.getTimelineCache(timelineStatuses, timelineParams)
|
timelinesVM.getTimelineCache(timelineStatuses, timelineParams)
|
||||||
.observe(getViewLifecycleOwner(), statusesCached -> {
|
.observe(getViewLifecycleOwner(), statusesCached -> {
|
||||||
|
initialStatuses = statusesCached;
|
||||||
if (statusesCached == null || statusesCached.statuses == null || statusesCached.statuses.size() == 0) {
|
if (statusesCached == null || statusesCached.statuses == null || statusesCached.statuses.size() == 0) {
|
||||||
getLiveStatus(null, fetchingMissing, timelineParams, null);
|
getLiveStatus(null, fetchingMissing, timelineParams, null);
|
||||||
} else {
|
} else {
|
||||||
|
@ -694,9 +715,15 @@ public class FragmentMastodonTimeline extends Fragment implements StatusAdapter.
|
||||||
}
|
}
|
||||||
|
|
||||||
private void getLiveStatus(DIRECTION direction, boolean fetchingMissing, TimelinesVM.TimelineParams timelineParams, Status status) {
|
private void getLiveStatus(DIRECTION direction, boolean fetchingMissing, TimelinesVM.TimelineParams timelineParams, Status status) {
|
||||||
|
if (getView() == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (direction == null) {
|
if (direction == null) {
|
||||||
timelinesVM.getTimeline(timelineStatuses, timelineParams)
|
timelinesVM.getTimeline(timelineStatuses, timelineParams)
|
||||||
.observe(getViewLifecycleOwner(), this::initializeStatusesCommonView);
|
.observe(getViewLifecycleOwner(), statuses -> {
|
||||||
|
initialStatuses = statuses;
|
||||||
|
initializeStatusesCommonView(statuses);
|
||||||
|
});
|
||||||
} else if (direction == DIRECTION.BOTTOM) {
|
} else if (direction == DIRECTION.BOTTOM) {
|
||||||
timelinesVM.getTimeline(timelineStatuses, timelineParams)
|
timelinesVM.getTimeline(timelineStatuses, timelineParams)
|
||||||
.observe(getViewLifecycleOwner(), statusesBottom -> dealWithPagination(statusesBottom, DIRECTION.BOTTOM, fetchingMissing, status));
|
.observe(getViewLifecycleOwner(), statusesBottom -> dealWithPagination(statusesBottom, DIRECTION.BOTTOM, fetchingMissing, status));
|
||||||
|
|
Loading…
Reference in a new issue