From 74c8040de56c9d9b6cbf2f010b80e08aea0894ff Mon Sep 17 00:00:00 2001 From: Alex Sytnyk Date: Thu, 11 Oct 2018 16:16:35 +0300 Subject: [PATCH] Observe favorites loading --- .../net/osmand/plus/FavouritesDbHelper.java | 26 ++++++++++---- .../activities/FavoritesTreeFragment.java | 19 ++++++++-- .../plus/dashboard/DashFavoritesFragment.java | 24 ++++++++++++- .../FavouritesBottomSheetMenuFragment.java | 35 ++++++++++++++++--- ...ouritesGroupBottomSheetDialogFragment.java | 21 +++++++++++ 5 files changed, 110 insertions(+), 15 deletions(-) diff --git a/OsmAnd/src/net/osmand/plus/FavouritesDbHelper.java b/OsmAnd/src/net/osmand/plus/FavouritesDbHelper.java index 4038ce7b73..a4090ef951 100644 --- a/OsmAnd/src/net/osmand/plus/FavouritesDbHelper.java +++ b/OsmAnd/src/net/osmand/plus/FavouritesDbHelper.java @@ -31,11 +31,10 @@ import java.util.Set; public class FavouritesDbHelper { - public interface FavoritesUpdatedListener { - void updateFavourites(); + public interface FavoritesListener { + void onFavoritesLoaded(); } - private static final org.apache.commons.logging.Log log = PlatformUtil.getLog(FavouritesDbHelper.class); public static final String FILE_TO_SAVE = "favourites.gpx"; //$NON-NLS-1$ @@ -50,6 +49,7 @@ public class FavouritesDbHelper { protected static final String HIDDEN = "HIDDEN"; private static final String DELIMETER = "__"; + private Set listeners = new HashSet<>(); private boolean favoritesLoaded; public FavouritesDbHelper(OsmandApplication context) { @@ -91,17 +91,29 @@ public class FavouritesDbHelper { if (changed || !getExternalFile().exists()) { saveCurrentPointsIntoFile(); } - favouritesUpdated(); favoritesLoaded = true; - } - - private void favouritesUpdated() { + context.runInUIThread(new Runnable() { + @Override + public void run() { + for (FavoritesListener listener : listeners) { + listener.onFavoritesLoaded(); + } + } + }); } public boolean isFavoritesLoaded() { return favoritesLoaded; } + public void addListener(FavoritesListener listener) { + listeners.add(listener); + } + + public void removeListener(FavoritesListener listener) { + listeners.remove(listener); + } + private boolean merge(Map source, Map destination) { boolean changed = false; for (String ks : source.keySet()) { diff --git a/OsmAnd/src/net/osmand/plus/activities/FavoritesTreeFragment.java b/OsmAnd/src/net/osmand/plus/activities/FavoritesTreeFragment.java index e72fbee1c5..276af19e10 100644 --- a/OsmAnd/src/net/osmand/plus/activities/FavoritesTreeFragment.java +++ b/OsmAnd/src/net/osmand/plus/activities/FavoritesTreeFragment.java @@ -37,8 +37,8 @@ import net.osmand.data.LatLon; import net.osmand.data.PointDescription; import net.osmand.plus.FavouritesDbHelper; import net.osmand.plus.FavouritesDbHelper.FavoriteGroup; +import net.osmand.plus.FavouritesDbHelper.FavoritesListener; import net.osmand.plus.MapMarkersHelper; -import net.osmand.plus.MapMarkersHelper.MapMarkersGroup; import net.osmand.plus.OsmAndFormatter; import net.osmand.plus.OsmandApplication; import net.osmand.plus.OsmandSettings; @@ -90,13 +90,24 @@ public class FavoritesTreeFragment extends OsmandExpandableListFragment { private HashMap> preferenceCache = new HashMap<>(); private View footerView; + private FavoritesListener favoritesListener; + @Override public void onAttach(Context context) { super.onAttach(context); this.app = (OsmandApplication) getActivity().getApplication(); helper = getMyApplication().getFavorites(); - favouritesAdapter.synchronizeGroups(); + if (helper.isFavoritesLoaded()) { + favouritesAdapter.synchronizeGroups(); + } else { + helper.addListener(favoritesListener = new FavoritesListener() { + @Override + public void onFavoritesLoaded() { + favouritesAdapter.synchronizeGroups(); + } + }); + } setAdapter(favouritesAdapter); boolean light = getMyApplication().getSettings().isLightContent(); @@ -233,6 +244,10 @@ public class FavoritesTreeFragment extends OsmandExpandableListFragment { if (actionMode != null) { actionMode.finish(); } + if (favoritesListener != null) { + helper.removeListener(favoritesListener); + favoritesListener = null; + } } private int getSelectedFavoritesCount() { diff --git a/OsmAnd/src/net/osmand/plus/dashboard/DashFavoritesFragment.java b/OsmAnd/src/net/osmand/plus/dashboard/DashFavoritesFragment.java index 2ddc7319c1..12c1a44bf3 100644 --- a/OsmAnd/src/net/osmand/plus/dashboard/DashFavoritesFragment.java +++ b/OsmAnd/src/net/osmand/plus/dashboard/DashFavoritesFragment.java @@ -14,6 +14,7 @@ import net.osmand.data.FavouritePoint; import net.osmand.data.LatLon; import net.osmand.data.PointDescription; import net.osmand.plus.FavouritesDbHelper; +import net.osmand.plus.FavouritesDbHelper.FavoritesListener; import net.osmand.plus.R; import net.osmand.plus.activities.MapActivity; import net.osmand.plus.base.FavoriteImageDrawable; @@ -47,6 +48,8 @@ public class DashFavoritesFragment extends DashLocationFragment { public static final DashFragmentData FRAGMENT_DATA = new DashFragmentData(TAG, DashFavoritesFragment.class, SHOULD_SHOW_FUNCTION, 90, ROW_NUMBER_TAG); + private FavoritesListener favoritesListener; + @Override public View initView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = getActivity().getLayoutInflater().inflate(R.layout.dash_common_fragment, container, false); @@ -62,7 +65,26 @@ public class DashFavoritesFragment extends DashLocationFragment { @Override public void onOpenDash() { - setupFavorites(); + FavouritesDbHelper helper = getMyApplication().getFavorites(); + if (helper.isFavoritesLoaded()) { + setupFavorites(); + } else { + helper.addListener(favoritesListener = new FavoritesListener() { + @Override + public void onFavoritesLoaded() { + setupFavorites(); + } + }); + } + } + + @Override + public void onCloseDash() { + super.onCloseDash(); + if (favoritesListener != null) { + getMyApplication().getFavorites().removeListener(favoritesListener); + favoritesListener = null; + } } public void setupFavorites() { diff --git a/OsmAnd/src/net/osmand/plus/mapcontextmenu/other/FavouritesBottomSheetMenuFragment.java b/OsmAnd/src/net/osmand/plus/mapcontextmenu/other/FavouritesBottomSheetMenuFragment.java index b68f2cc6af..f6a9023cd6 100644 --- a/OsmAnd/src/net/osmand/plus/mapcontextmenu/other/FavouritesBottomSheetMenuFragment.java +++ b/OsmAnd/src/net/osmand/plus/mapcontextmenu/other/FavouritesBottomSheetMenuFragment.java @@ -12,6 +12,8 @@ import net.osmand.AndroidUtils; import net.osmand.Location; import net.osmand.data.FavouritePoint; import net.osmand.data.LatLon; +import net.osmand.plus.FavouritesDbHelper; +import net.osmand.plus.FavouritesDbHelper.FavoritesListener; import net.osmand.plus.OsmAndLocationProvider; import net.osmand.plus.OsmandApplication; import net.osmand.plus.R; @@ -23,6 +25,7 @@ import net.osmand.plus.base.bottomsheetmenu.BottomSheetItemTitleWithDescrAndButt import net.osmand.util.MapUtils; import java.text.Collator; +import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; @@ -36,7 +39,7 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag private static final String IS_SORTED = "sorted"; private static final String SORTED_BY_TYPE = "sortedByType"; - private List favouritePoints; + private List favouritePoints = new ArrayList<>(); private FavouritesAdapter adapter; private RecyclerView recyclerView; private boolean sortByDist = true; @@ -47,6 +50,8 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag private boolean intermediate; private float lastHeading; + private FavoritesListener favoritesListener; + @Override public void createMenuItems(final Bundle savedInstanceState) { Bundle args = getArguments(); @@ -57,16 +62,24 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag if (savedInstanceState != null && savedInstanceState.getBoolean(IS_SORTED)) { sortByDist = savedInstanceState.getBoolean(SORTED_BY_TYPE); } - favouritePoints = getMyApplication().getFavorites().getVisibleFavouritePoints(); - if (favouritePoints.isEmpty()) { - favouritePoints = getMyApplication().getFavorites().getFavouritePoints(); + adapter = new FavouritesAdapter(getMyApplication(), favouritePoints); + FavouritesDbHelper helper = getMyApplication().getFavorites(); + if (helper.isFavoritesLoaded()) { + loadFavorites(); + } else { + helper.addListener(favoritesListener = new FavoritesListener() { + @Override + public void onFavoritesLoaded() { + loadFavorites(); + adapter.notifyDataSetChanged(); + } + }); } recyclerView = new RecyclerView(getContext()); final int themeRes = nightMode ? R.style.OsmandDarkTheme : R.style.OsmandLightTheme; recyclerView = (RecyclerView) View.inflate(new ContextThemeWrapper(getContext(), themeRes), R.layout.recyclerview, null); recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); - adapter = new FavouritesAdapter(getMyApplication(), favouritePoints); sortFavourites(); final BottomSheetItemTitleWithDescrAndButton[] title = new BottomSheetItemTitleWithDescrAndButton[1]; title[0] = (BottomSheetItemTitleWithDescrAndButton) new BottomSheetItemTitleWithDescrAndButton.Builder() @@ -110,6 +123,14 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag .create()); } + private void loadFavorites() { + favouritePoints.clear(); + favouritePoints.addAll(getMyApplication().getFavorites().getVisibleFavouritePoints()); + if (favouritePoints.isEmpty()) { + favouritePoints.addAll(getMyApplication().getFavorites().getFavouritePoints()); + } + } + private Drawable getIconForButton() { return getIcon(sortByDist ? R.drawable.ic_action_list_sort : R.drawable.ic_action_sort_by_name, nightMode ? R.color.multi_selection_menu_close_btn_dark : R.color.multi_selection_menu_close_btn_light); @@ -170,6 +191,10 @@ public class FavouritesBottomSheetMenuFragment extends MenuBottomSheetDialogFrag super.onPause(); stopLocationUpdate(); setupMapRouteInfoMenuSpinners(getMapRouteInfoMenu()); + if (favoritesListener != null) { + getMyApplication().getFavorites().removeListener(favoritesListener); + favoritesListener = null; + } } @Override diff --git a/OsmAnd/src/net/osmand/plus/mapmarkers/AddFavouritesGroupBottomSheetDialogFragment.java b/OsmAnd/src/net/osmand/plus/mapmarkers/AddFavouritesGroupBottomSheetDialogFragment.java index 20434f4995..3ffd755741 100644 --- a/OsmAnd/src/net/osmand/plus/mapmarkers/AddFavouritesGroupBottomSheetDialogFragment.java +++ b/OsmAnd/src/net/osmand/plus/mapmarkers/AddFavouritesGroupBottomSheetDialogFragment.java @@ -4,12 +4,14 @@ import android.os.Bundle; import net.osmand.plus.FavouritesDbHelper; import net.osmand.plus.FavouritesDbHelper.FavoriteGroup; +import net.osmand.plus.FavouritesDbHelper.FavoritesListener; import net.osmand.plus.mapmarkers.adapters.FavouritesGroupsAdapter; import net.osmand.plus.mapmarkers.adapters.GroupsAdapter; public class AddFavouritesGroupBottomSheetDialogFragment extends AddGroupBottomSheetDialogFragment { private FavouritesDbHelper favouritesDbHelper; + private FavoritesListener favoritesListener; @Override public void onCreate(Bundle savedInstanceState) { @@ -17,8 +19,27 @@ public class AddFavouritesGroupBottomSheetDialogFragment extends AddGroupBottomS favouritesDbHelper = getMyApplication().getFavorites(); } + @Override + public void onPause() { + super.onPause(); + if (favoritesListener != null) { + favouritesDbHelper.removeListener(favoritesListener); + favoritesListener = null; + } + } + @Override public GroupsAdapter createAdapter() { + if (!favouritesDbHelper.isFavoritesLoaded()) { + favouritesDbHelper.addListener(favoritesListener = new FavoritesListener() { + @Override + public void onFavoritesLoaded() { + if (adapter != null) { + adapter.notifyDataSetChanged(); + } + } + }); + } return new FavouritesGroupsAdapter(getContext(), favouritesDbHelper.getFavoriteGroups()); }