Skip to content
This repository has been archived by the owner on Jul 22, 2024. It is now read-only.

Commit

Permalink
Update the navigation bar bookmarked flag when bookmarks are updated
Browse files Browse the repository at this point in the history
  • Loading branch information
keianhzo authored and bluemarvin committed Feb 21, 2020
1 parent 6e949a2 commit 9620b99
Showing 1 changed file with 36 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@
import org.mozilla.vrbrowser.R;
import org.mozilla.vrbrowser.VRBrowserActivity;
import org.mozilla.vrbrowser.VRBrowserApplication;
import org.mozilla.vrbrowser.browser.BookmarksStore;
import org.mozilla.vrbrowser.browser.Media;
import org.mozilla.vrbrowser.browser.PromptDelegate;
import org.mozilla.vrbrowser.browser.SessionChangeListener;
Expand Down Expand Up @@ -173,11 +174,13 @@ private void initialize(Context aContext) {
setupListeners(mSession);

mBookmarksView = new BookmarksView(aContext);
mBookmarksView.addBookmarksListener(mBookmarksListener);
mBookmarksView.addBookmarksListener(mBookmarksViewListener);

mHistoryView = new HistoryView(aContext);
mHistoryView.addHistoryListener(mHistoryListener);

SessionStore.get().getBookmarkStore().addListener(mBookmarksListener);

mHandle = ((WidgetManagerDelegate)aContext).newWidgetHandle();
mWidgetPlacement = new WidgetPlacement(aContext);
mPlacementBeforeFullscreen = new WidgetPlacement(aContext);
Expand Down Expand Up @@ -626,6 +629,8 @@ public void setActiveWindow(boolean active) {

} else {
mWidgetManager.getNavigationBar().removeNavigationBarListener(mNavigationBarListener);
updateBookmarked();

}

hideContextMenus();
Expand Down Expand Up @@ -917,9 +922,10 @@ public void releaseWidget() {
mTexture.release();
mTexture = null;
}
mBookmarksView.removeBookmarksListener(mBookmarksListener);
mBookmarksView.removeBookmarksListener(mBookmarksViewListener);
mHistoryView.removeHistoryListener(mHistoryListener);
mWidgetManager.getNavigationBar().removeNavigationBarListener(mNavigationBarListener);
SessionStore.get().getBookmarkStore().removeListener(mBookmarksListener);
mPromptDelegate.detachFromWindow();
super.releaseWidget();
}
Expand Down Expand Up @@ -1348,7 +1354,7 @@ public void onRemoveFromBookmarks(LibraryMenuWidget.LibraryContextMenuItem item)
});
}

private BookmarksCallback mBookmarksListener = new BookmarksCallback() {
private BookmarksCallback mBookmarksViewListener = new BookmarksCallback() {
@Override
public void onShowContextMenu(@NonNull View view, @NonNull Bookmark item, boolean isLastVisibleItem) {
showLibraryItemContextMenu(
Expand Down Expand Up @@ -1447,6 +1453,33 @@ public void onHome() {
}
};

private BookmarksStore.BookmarkListener mBookmarksListener = new BookmarksStore.BookmarkListener() {
@Override
public void onBookmarksUpdated() {
updateBookmarked();
}

@Override
public void onBookmarkAdded() {
updateBookmarked();
}
};

private void updateBookmarked() {
SessionStore.get().getBookmarkStore().isBookmarked(mViewModel.getUrl().getValue().toString()).thenAcceptAsync(bookmarked -> {
if (bookmarked) {
mViewModel.setIsBookmarked(true);

} else {
mViewModel.setIsBookmarked(false);
}
}, mUIThreadExecutor).exceptionally(throwable -> {
Log.d(LOGTAG, "Error checking bookmark: " + throwable.getLocalizedMessage());
throwable.printStackTrace();
return null;
});
}

private void hideContextMenus() {
if (mContextMenu != null) {
if (!mContextMenu.isReleased()) {
Expand Down

0 comments on commit 9620b99

Please sign in to comment.