Observe favorites loading

This commit is contained in:
Alex Sytnyk 2018-10-11 16:16:35 +03:00
parent ec12ec3b45
commit 74c8040de5
5 changed files with 110 additions and 15 deletions

View file

@ -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<FavoritesListener> 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;
context.runInUIThread(new Runnable() {
@Override
public void run() {
for (FavoritesListener listener : listeners) {
listener.onFavoritesLoaded();
}
private void favouritesUpdated() {
}
});
}
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<String, FavouritePoint> source, Map<String, FavouritePoint> destination) {
boolean changed = false;
for (String ks : source.keySet()) {

View file

@ -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<String, OsmandSettings.OsmandPreference<Boolean>> 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();
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() {

View file

@ -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() {
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() {

View file

@ -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<FavouritePoint> favouritePoints;
private List<FavouritePoint> 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

View file

@ -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());
}