diff options
author | Michael Kolb <kolby@google.com> | 2011-07-14 14:25:38 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-07-14 14:25:38 -0700 |
commit | ef85204bf5eab3e4fd2ca4d36e838bdaaa48f68a (patch) | |
tree | c613e9e9aa7607e0c73e048028ef0fee60b47007 | |
parent | e1dbb956d762c3f07033f247c05270a9882a79a7 (diff) | |
parent | 4bf7971ed99aa273dc8ea9cf610cd6fa168c5dcb (diff) | |
download | packages_apps_browser-ef85204bf5eab3e4fd2ca4d36e838bdaaa48f68a.zip packages_apps_browser-ef85204bf5eab3e4fd2ca4d36e838bdaaa48f68a.tar.gz packages_apps_browser-ef85204bf5eab3e4fd2ca4d36e838bdaaa48f68a.tar.bz2 |
Merge "add navigation to menu again"
-rw-r--r-- | res/menu/browser.xml | 10 | ||||
-rw-r--r-- | src/com/android/browser/Controller.java | 90 | ||||
-rw-r--r-- | src/com/android/browser/NavScreen.java | 2 | ||||
-rw-r--r-- | src/com/android/browser/NavigationBarPhone.java | 2 | ||||
-rw-r--r-- | src/com/android/browser/UiController.java | 7 |
5 files changed, 54 insertions, 57 deletions
diff --git a/res/menu/browser.xml b/res/menu/browser.xml index b5d80c5..0b46db6 100644 --- a/res/menu/browser.xml +++ b/res/menu/browser.xml @@ -20,16 +20,6 @@ <group android:id="@+id/NAV_MENU"> <item - android:id="@+id/new_tab_menu_id" - android:title="@string/new_tab" - android:icon="@drawable/ic_menu_new_window" - android:alphabeticShortcut="n" /> - <item - android:id="@+id/bookmarks_menu_id" - android:title="@string/bookmarks" - android:alphabeticShortcut="b" - android:icon="@drawable/ic_bookmarks_holo_dark" /> - <item android:id="@+id/stop_reload_menu_id" android:alphabeticShortcut="r" /> <item diff --git a/src/com/android/browser/Controller.java b/src/com/android/browser/Controller.java index b495cc0..83c4d61 100644 --- a/src/com/android/browser/Controller.java +++ b/src/com/android/browser/Controller.java @@ -67,7 +67,6 @@ import android.view.View; import android.webkit.CookieManager; import android.webkit.CookieSyncManager; import android.webkit.HttpAuthHandler; -import android.webkit.SearchBox; import android.webkit.SslErrorHandler; import android.webkit.ValueCallback; import android.webkit.WebChromeClient; @@ -1458,54 +1457,59 @@ public class Controller menu.setGroupEnabled(R.id.MAIN_MENU, true); menu.setGroupEnabled(R.id.MAIN_SHORTCUT_MENU, true); } - final Tab t = getCurrentTab(); - boolean canGoBack = false; - boolean canGoForward = false; - boolean isHome = false; - if (t != null) { - canGoBack = t.canGoBack(); - canGoForward = t.canGoForward(); - isHome = mSettings.getHomePage().equals(t.getUrl()); - } - final MenuItem back = menu.findItem(R.id.back_menu_id); - back.setEnabled(canGoBack); - - final MenuItem home = menu.findItem(R.id.homepage_menu_id); - home.setEnabled(!isHome); - - final MenuItem forward = menu.findItem(R.id.forward_menu_id); - forward.setEnabled(canGoForward); - - // decide whether to show the share link option - PackageManager pm = mActivity.getPackageManager(); - Intent send = new Intent(Intent.ACTION_SEND); - send.setType("text/plain"); - ResolveInfo ri = pm.resolveActivity(send, - PackageManager.MATCH_DEFAULT_ONLY); - menu.findItem(R.id.share_page_menu_id).setVisible(ri != null); - - boolean isNavDump = mSettings.enableNavDump(); - final MenuItem nav = menu.findItem(R.id.dump_nav_menu_id); - nav.setVisible(isNavDump); - nav.setEnabled(isNavDump); - - boolean showDebugSettings = mSettings.isDebugEnabled(); - final MenuItem counter = menu.findItem(R.id.dump_counters_menu_id); - counter.setVisible(showDebugSettings); - counter.setEnabled(showDebugSettings); - - final MenuItem newtab = menu.findItem(R.id.new_tab_menu_id); - newtab.setEnabled(getTabControl().canCreateNewTab()); - - MenuItem saveSnapshot = menu.findItem(R.id.save_snapshot_menu_id); - Tab tab = getCurrentTab(); - saveSnapshot.setVisible(tab != null && !tab.isSnapshot()); + updateMenuState(getCurrentTab(), menu); break; } mCurrentMenuState = mMenuState; return mUi.onPrepareOptionsMenu(menu); } + @Override + public void updateMenuState(Tab tab, Menu menu) { + boolean canGoBack = false; + boolean canGoForward = false; + boolean isHome = false; + if (tab != null) { + canGoBack = tab.canGoBack(); + canGoForward = tab.canGoForward(); + isHome = mSettings.getHomePage().equals(tab.getUrl()); + } + final MenuItem back = menu.findItem(R.id.back_menu_id); + back.setEnabled(canGoBack); + + final MenuItem home = menu.findItem(R.id.homepage_menu_id); + home.setEnabled(!isHome); + + final MenuItem forward = menu.findItem(R.id.forward_menu_id); + forward.setEnabled(canGoForward); + + final MenuItem source = menu.findItem(mInLoad ? R.id.stop_menu_id : R.id.reload_menu_id); + final MenuItem dest = menu.findItem(R.id.stop_reload_menu_id); + dest.setTitle(source.getTitle()); + dest.setIcon(source.getIcon()); + + // decide whether to show the share link option + PackageManager pm = mActivity.getPackageManager(); + Intent send = new Intent(Intent.ACTION_SEND); + send.setType("text/plain"); + ResolveInfo ri = pm.resolveActivity(send, + PackageManager.MATCH_DEFAULT_ONLY); + menu.findItem(R.id.share_page_menu_id).setVisible(ri != null); + + boolean isNavDump = mSettings.enableNavDump(); + final MenuItem nav = menu.findItem(R.id.dump_nav_menu_id); + nav.setVisible(isNavDump); + nav.setEnabled(isNavDump); + + boolean showDebugSettings = mSettings.isDebugEnabled(); + final MenuItem counter = menu.findItem(R.id.dump_counters_menu_id); + counter.setVisible(showDebugSettings); + counter.setEnabled(showDebugSettings); + + MenuItem saveSnapshot = menu.findItem(R.id.save_snapshot_menu_id); + saveSnapshot.setVisible(tab != null && !tab.isSnapshot()); + } + public boolean onOptionsItemSelected(MenuItem item) { if (mOptionsMenuHandler != null && mOptionsMenuHandler.onOptionsItemSelected(item)) { diff --git a/src/com/android/browser/NavScreen.java b/src/com/android/browser/NavScreen.java index 6a51e87..d03da6b 100644 --- a/src/com/android/browser/NavScreen.java +++ b/src/com/android/browser/NavScreen.java @@ -77,7 +77,7 @@ public class NavScreen extends RelativeLayout PopupMenu popup = new PopupMenu(mContext, mMore); Menu menu = popup.getMenu(); popup.getMenuInflater().inflate(R.menu.browser, menu); - menu.setGroupVisible(R.id.NAV_MENU, false); + mUiController.updateMenuState(mScroller.getSelectedItem(), menu); popup.setOnMenuItemClickListener(this); popup.show(); } diff --git a/src/com/android/browser/NavigationBarPhone.java b/src/com/android/browser/NavigationBarPhone.java index 7dcf7b5..684f986 100644 --- a/src/com/android/browser/NavigationBarPhone.java +++ b/src/com/android/browser/NavigationBarPhone.java @@ -171,7 +171,7 @@ public class NavigationBarPhone extends NavigationBarBase implements PopupMenu popup = new PopupMenu(mContext, anchor); Menu menu = popup.getMenu(); popup.getMenuInflater().inflate(R.menu.browser, menu); - menu.setGroupVisible(R.id.NAV_MENU, false); + mUiController.updateMenuState(mBaseUi.getActiveTab(), menu); popup.setOnMenuItemClickListener(this); popup.setOnDismissListener(this); popup.show(); diff --git a/src/com/android/browser/UiController.java b/src/com/android/browser/UiController.java index 421dc14..10821cd 100644 --- a/src/com/android/browser/UiController.java +++ b/src/com/android/browser/UiController.java @@ -16,12 +16,13 @@ package com.android.browser; -import com.android.browser.UI.DropdownChangeListener; - import android.content.Intent; +import android.view.Menu; import android.view.MenuItem; import android.webkit.WebView; +import com.android.browser.UI.DropdownChangeListener; + import java.util.List; @@ -93,6 +94,8 @@ public interface UiController extends BookmarksHistoryCallbacks { void unregisterOptionsMenuHandler(OptionsMenuHandler handler); + void updateMenuState(Tab tab, Menu menu); + void registerDropdownChangeListener(DropdownChangeListener d); boolean onOptionsItemSelected(MenuItem item); |