Add-menu-item-to-view-source.patch 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. From: csagan5 <32685696+csagan5@users.noreply.github.com>
  2. Date: Mon, 13 Jul 2020 00:37:06 +0200
  3. Subject: Add menu item to view source
  4. ---
  5. chrome/android/java/res/menu/custom_tabs_menu.xml | 3 +++
  6. chrome/android/java/res/menu/main_menu.xml | 2 ++
  7. chrome/android/java/res/menu/main_menu_regroup.xml | 3 +++
  8. .../chrome/browser/ChromeTabbedActivity.java | 2 ++
  9. .../chrome/browser/app/ChromeActivity.java | 2 ++
  10. .../app/appmenu/AppMenuPropertiesDelegateImpl.java | 14 ++++++++++++++
  11. .../CustomTabAppMenuPropertiesDelegate.java | 1 +
  12. .../ui/android/strings/android_chrome_strings.grd | 3 +++
  13. 8 files changed, 30 insertions(+)
  14. diff --git a/chrome/android/java/res/menu/custom_tabs_menu.xml b/chrome/android/java/res/menu/custom_tabs_menu.xml
  15. --- a/chrome/android/java/res/menu/custom_tabs_menu.xml
  16. +++ b/chrome/android/java/res/menu/custom_tabs_menu.xml
  17. @@ -46,6 +46,9 @@
  18. <item android:id="@+id/add_to_homescreen_id"
  19. android:title="@string/menu_add_to_homescreen"
  20. android:orderInCategory="2" />
  21. + <item android:id="@+id/view_source_id"
  22. + android:title="@string/view_source"
  23. + android:orderInCategory="2" />
  24. <item android:id="@+id/open_webapk_id"
  25. android:title="@string/menu_open_webapk"
  26. android:orderInCategory="2" />
  27. diff --git a/chrome/android/java/res/menu/main_menu.xml b/chrome/android/java/res/menu/main_menu.xml
  28. --- a/chrome/android/java/res/menu/main_menu.xml
  29. +++ b/chrome/android/java/res/menu/main_menu.xml
  30. @@ -88,6 +88,8 @@
  31. <item android:id="@+id/add_to_homescreen_id"
  32. android:title="@string/menu_add_to_homescreen"
  33. android:icon="@drawable/ic_add_to_home_screen" />
  34. + <item android:id="@+id/view_source_id"
  35. + android:title="@string/view_source" />
  36. <item android:id="@+id/open_webapk_id"
  37. android:title="@string/menu_open_webapk"
  38. android:icon="@drawable/ic_add_to_home_screen" />
  39. diff --git a/chrome/android/java/res/menu/main_menu_regroup.xml b/chrome/android/java/res/menu/main_menu_regroup.xml
  40. --- a/chrome/android/java/res/menu/main_menu_regroup.xml
  41. +++ b/chrome/android/java/res/menu/main_menu_regroup.xml
  42. @@ -97,6 +97,9 @@
  43. <item android:id="@+id/add_to_homescreen_id"
  44. android:title="@string/menu_add_to_homescreen"
  45. android:icon="@drawable/ic_add_to_home_screen" />
  46. + <item android:id="@+id/view_source_id"
  47. + android:title="@string/view_source"
  48. + android:icon="@drawable/ic_drive_document_24dp" />
  49. <item android:id="@+id/open_webapk_id"
  50. android:title="@string/menu_open_webapk"
  51. android:icon="@drawable/ic_add_to_home_screen" />
  52. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/ChromeTabbedActivity.java b/chrome/android/java/src/org/chromium/chrome/browser/ChromeTabbedActivity.java
  53. --- a/chrome/android/java/src/org/chromium/chrome/browser/ChromeTabbedActivity.java
  54. +++ b/chrome/android/java/src/org/chromium/chrome/browser/ChromeTabbedActivity.java
  55. @@ -1747,6 +1747,8 @@ public class ChromeTabbedActivity extends ChromeActivity<ChromeActivityComponent
  56. NewTabPageUma.recordAction(NewTabPageUma.ACTION_OPENED_DOWNLOADS_MANAGER);
  57. }
  58. RecordUserAction.record("MobileMenuDownloadManager");
  59. + } else if (id == R.id.view_source_id) {
  60. + currentTab.getWebContents().getNavigationController().loadUrl(new LoadUrlParams("view-source:"+currentTab.getUrlString()));
  61. } else if (id == R.id.open_recently_closed_tab) {
  62. TabModel currentModel = mTabModelSelectorImpl.getCurrentModel();
  63. if (!currentModel.isIncognito()) currentModel.openMostRecentlyClosedTab();
  64. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java b/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
  65. --- a/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
  66. +++ b/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
  67. @@ -1969,6 +1969,8 @@ public abstract class ChromeActivity<C extends ChromeActivityComponent>
  68. } catch (ActivityNotFoundException e) {
  69. Toast.makeText(context, R.string.open_webapk_failed, Toast.LENGTH_SHORT).show();
  70. }
  71. + } else if (id == R.id.view_source_id) {
  72. + currentTab.getWebContents().getNavigationController().loadUrl(new LoadUrlParams("view-source:"+currentTab.getUrlString()));
  73. } else if (id == R.id.request_desktop_site_id || id == R.id.request_desktop_site_check_id) {
  74. final boolean reloadOnChange = !currentTab.isNativePage();
  75. final boolean usingDesktopUserAgent =
  76. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/app/appmenu/AppMenuPropertiesDelegateImpl.java b/chrome/android/java/src/org/chromium/chrome/browser/app/appmenu/AppMenuPropertiesDelegateImpl.java
  77. --- a/chrome/android/java/src/org/chromium/chrome/browser/app/appmenu/AppMenuPropertiesDelegateImpl.java
  78. +++ b/chrome/android/java/src/org/chromium/chrome/browser/app/appmenu/AppMenuPropertiesDelegateImpl.java
  79. @@ -334,6 +334,7 @@ public class AppMenuPropertiesDelegateImpl implements AppMenuPropertiesDelegate
  80. isChromeScheme, isFileScheme, isContentScheme, isIncognito, url));
  81. updateRequestDesktopSiteMenuItem(menu, currentTab, true /* can show */);
  82. + updateViewSourceMenuItem(menu, currentTab);
  83. // Only display reader mode settings menu option if the current page is in reader mode.
  84. menu.findItem(R.id.reader_mode_prefs_id).setVisible(shouldShowReaderModePrefs(currentTab));
  85. @@ -703,6 +704,19 @@ public class AppMenuPropertiesDelegateImpl implements AppMenuPropertiesDelegate
  86. }
  87. }
  88. + /**
  89. + * Updates the view source menu item's state.
  90. + *
  91. + * @param menu {@link Menu} for view source.
  92. + * @param currentTab Current tab being displayed.
  93. + */
  94. + protected void updateViewSourceMenuItem(
  95. + Menu menu, Tab currentTab) {
  96. + MenuItem viewSourceMenuItem = menu.findItem(R.id.view_source_id);
  97. + String url = currentTab.getUrlString();
  98. + viewSourceMenuItem.setVisible(!url.isEmpty() && !url.startsWith("view-source:"));
  99. + }
  100. +
  101. /**
  102. * Updates the request desktop site item's state.
  103. *
  104. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/customtabs/CustomTabAppMenuPropertiesDelegate.java b/chrome/android/java/src/org/chromium/chrome/browser/customtabs/CustomTabAppMenuPropertiesDelegate.java
  105. --- a/chrome/android/java/src/org/chromium/chrome/browser/customtabs/CustomTabAppMenuPropertiesDelegate.java
  106. +++ b/chrome/android/java/src/org/chromium/chrome/browser/customtabs/CustomTabAppMenuPropertiesDelegate.java
  107. @@ -222,6 +222,7 @@ public class CustomTabAppMenuPropertiesDelegate extends AppMenuPropertiesDelegat
  108. }
  109. updateRequestDesktopSiteMenuItem(menu, currentTab, requestDesktopSiteVisible);
  110. + updateViewSourceMenuItem(menu, currentTab);
  111. prepareAddToHomescreenMenuItem(menu, currentTab, addToHomeScreenVisible);
  112. }
  113. }
  114. diff --git a/chrome/browser/ui/android/strings/android_chrome_strings.grd b/chrome/browser/ui/android/strings/android_chrome_strings.grd
  115. --- a/chrome/browser/ui/android/strings/android_chrome_strings.grd
  116. +++ b/chrome/browser/ui/android/strings/android_chrome_strings.grd
  117. @@ -326,6 +326,9 @@ CHAR-LIMIT guidelines:
  118. <message name="IDS_SERVICES_CATEGORY_TITLE" desc="Title for the group of preferences that control non-personalized Google services. This group contains preferences for data that is not tied to user's Google Account.">
  119. Other Google services
  120. </message>
  121. + <message name="IDS_VIEW_SOURCE" desc="Title for the menu command to view the source of the current page. [CHAR-LIMIT=40]">
  122. + View source
  123. + </message>
  124. <message name="IDS_PREFS_GOOGLE_SERVICES" desc="Title for the group of preferences that control non-personalized Google services. This group contains preferences for data that is not tied to user's Google Account. [CHAR-LIMIT=40]">
  125. Google services
  126. </message>
  127. --
  128. 2.17.1