2020-07-16 17:14:54 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Shelley Vohr <shelley.vohr@gmail.com>
|
|
|
|
Date: Mon, 6 Jul 2020 13:46:06 -0700
|
2024-04-23 15:30:47 +00:00
|
|
|
Subject: Adjust accessibility_ui for Electron
|
2020-07-16 17:14:54 +00:00
|
|
|
|
|
|
|
This tweaks Chrome's Accessibility support at chrome://accessibility
|
2024-04-23 15:30:47 +00:00
|
|
|
to make it usable from Electron by replacing use of the Profile PrefService
|
|
|
|
with Electron's own PrefService in ElectronBrowserContext. It also removes
|
|
|
|
usage of BrowserList and Browser as we subclass related methods and use our
|
|
|
|
WindowList.
|
2020-07-16 17:14:54 +00:00
|
|
|
|
2024-01-31 23:04:13 +00:00
|
|
|
diff --git a/chrome/browser/ui/webui/accessibility/accessibility_ui.cc b/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
|
2024-04-23 15:30:47 +00:00
|
|
|
index 45b085ebb5096b2cdd083337371539a249c7a0a8..9a0a6cb8b37c60641c2c51aa489fbf22cdb123cb 100644
|
2024-01-31 23:04:13 +00:00
|
|
|
--- a/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
|
|
|
|
+++ b/chrome/browser/ui/webui/accessibility/accessibility_ui.cc
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -44,6 +44,7 @@
|
|
|
|
#include "content/public/browser/web_contents.h"
|
|
|
|
#include "content/public/browser/web_contents_delegate.h"
|
|
|
|
#include "content/public/browser/web_ui_data_source.h"
|
|
|
|
+#include "electron/shell/browser/electron_browser_context.h"
|
|
|
|
#include "ui/accessibility/accessibility_features.h"
|
|
|
|
#include "ui/accessibility/platform/ax_platform_node.h"
|
|
|
|
#include "ui/accessibility/platform/ax_platform_node_delegate.h"
|
|
|
|
@@ -169,7 +170,7 @@ base::Value::Dict BuildTargetDescriptor(content::RenderViewHost* rvh) {
|
2020-07-16 17:14:54 +00:00
|
|
|
accessibility_mode);
|
|
|
|
}
|
|
|
|
|
2022-02-10 02:58:52 +00:00
|
|
|
-#if !BUILDFLAG(IS_ANDROID)
|
2020-07-16 17:14:54 +00:00
|
|
|
+#if 0
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::Dict BuildTargetDescriptor(Browser* browser) {
|
|
|
|
base::Value::Dict target_data;
|
|
|
|
target_data.Set(kSessionIdField, browser->session_id().id());
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -203,7 +204,7 @@ void HandleAccessibilityRequestCallback(
|
2020-07-16 17:14:54 +00:00
|
|
|
DCHECK(ShouldHandleAccessibilityRequestCallback(path));
|
|
|
|
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::Dict data;
|
2024-04-23 15:30:47 +00:00
|
|
|
- PrefService* pref = Profile::FromBrowserContext(current_context)->GetPrefs();
|
|
|
|
+ PrefService* pref = static_cast<electron::ElectronBrowserContext*>(current_context)->prefs();
|
2020-07-16 17:14:54 +00:00
|
|
|
ui::AXMode mode =
|
|
|
|
content::BrowserAccessibilityState::GetInstance()->GetAccessibilityMode();
|
|
|
|
bool is_native_enabled = content::BrowserAccessibilityState::GetInstance()
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -236,7 +237,7 @@ void HandleAccessibilityRequestCallback(
|
2022-09-07 07:46:37 +00:00
|
|
|
data.Set(kViewsAccessibility, features::IsAccessibilityTreeForViewsEnabled());
|
2020-07-16 17:14:54 +00:00
|
|
|
|
2024-04-23 15:30:47 +00:00
|
|
|
std::string pref_api_type =
|
2024-04-15 22:10:32 +00:00
|
|
|
- pref->GetString(prefs::kShownAccessibilityApiType);
|
2024-04-23 15:30:47 +00:00
|
|
|
+ std::string(pref->GetString(prefs::kShownAccessibilityApiType));
|
2024-04-15 22:10:32 +00:00
|
|
|
bool pref_api_type_supported = false;
|
2020-07-16 17:14:54 +00:00
|
|
|
|
2024-04-15 22:10:32 +00:00
|
|
|
std::vector<ui::AXApiType::Type> supported_api_types =
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -303,11 +304,11 @@ void HandleAccessibilityRequestCallback(
|
2022-07-13 21:26:16 +00:00
|
|
|
data.Set(kPagesField, std::move(page_list));
|
2020-07-16 17:14:54 +00:00
|
|
|
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::List browser_list;
|
2022-02-10 02:58:52 +00:00
|
|
|
-#if !BUILDFLAG(IS_ANDROID)
|
2020-07-16 17:14:54 +00:00
|
|
|
+#if 0
|
|
|
|
for (Browser* browser : *BrowserList::GetInstance()) {
|
2022-09-07 07:46:37 +00:00
|
|
|
browser_list.Append(BuildTargetDescriptor(browser));
|
2020-07-16 17:14:54 +00:00
|
|
|
}
|
2022-02-10 02:58:52 +00:00
|
|
|
-#endif // !BUILDFLAG(IS_ANDROID)
|
2024-04-23 15:30:47 +00:00
|
|
|
+#endif
|
2020-07-16 17:14:54 +00:00
|
|
|
data.Set(kBrowsersField, std::move(browser_list));
|
|
|
|
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::List widgets_list;
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -647,7 +648,8 @@ void AccessibilityUIMessageHandler::SetGlobalString(
|
2024-04-15 22:10:32 +00:00
|
|
|
const std::string value = CheckJSValue(data.FindString(kValueField));
|
2020-07-16 17:14:54 +00:00
|
|
|
|
2024-04-15 22:10:32 +00:00
|
|
|
if (string_name == kApiTypeField) {
|
2024-04-23 15:30:47 +00:00
|
|
|
- PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
|
|
|
|
+ PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
|
|
|
|
+ web_ui()->GetWebContents()->GetBrowserContext())->prefs();
|
2024-04-15 22:10:32 +00:00
|
|
|
pref->SetString(prefs::kShownAccessibilityApiType, value);
|
|
|
|
}
|
|
|
|
}
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -700,7 +702,8 @@ void AccessibilityUIMessageHandler::RequestWebContentsTree(
|
2020-10-16 01:30:41 +00:00
|
|
|
AXPropertyFilter::ALLOW_EMPTY);
|
|
|
|
AddPropertyFilters(property_filters, deny, AXPropertyFilter::DENY);
|
|
|
|
|
2024-04-23 15:30:47 +00:00
|
|
|
- PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
|
|
|
|
+ PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
|
|
|
|
+ web_contents->GetBrowserContext())->prefs();
|
2024-04-15 22:10:32 +00:00
|
|
|
ui::AXApiType::Type api_type =
|
|
|
|
ui::AXApiType::From(pref->GetString(prefs::kShownAccessibilityApiType));
|
2020-09-21 08:00:36 +00:00
|
|
|
std::string accessibility_contents =
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -727,6 +730,7 @@ void AccessibilityUIMessageHandler::RequestNativeUITree(
|
2020-10-16 01:30:41 +00:00
|
|
|
AXPropertyFilter::ALLOW_EMPTY);
|
|
|
|
AddPropertyFilters(property_filters, deny, AXPropertyFilter::DENY);
|
|
|
|
|
2020-07-16 17:14:54 +00:00
|
|
|
+#if 0
|
|
|
|
for (Browser* browser : *BrowserList::GetInstance()) {
|
|
|
|
if (browser->session_id().id() == session_id) {
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::Dict result = BuildTargetDescriptor(browser);
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -739,6 +743,7 @@ void AccessibilityUIMessageHandler::RequestNativeUITree(
|
2020-10-16 01:30:41 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
+#endif
|
2022-02-10 02:58:52 +00:00
|
|
|
#endif // !BUILDFLAG(IS_ANDROID)
|
2020-10-16 01:30:41 +00:00
|
|
|
// No browser with the specified |session_id| was found.
|
2022-09-07 07:46:37 +00:00
|
|
|
base::Value::Dict result;
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -807,11 +812,13 @@ void AccessibilityUIMessageHandler::StopRecording(
|
2024-04-15 22:10:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ui::AXApiType::Type AccessibilityUIMessageHandler::GetRecordingApiType() {
|
2024-04-23 15:30:47 +00:00
|
|
|
- PrefService* pref = Profile::FromWebUI(web_ui())->GetPrefs();
|
2024-04-15 22:10:32 +00:00
|
|
|
- const std::vector<ui::AXApiType::Type> supported_types =
|
|
|
|
- content::AXInspectFactory::SupportedApis();
|
2024-04-23 15:30:47 +00:00
|
|
|
+ PrefService* pref = static_cast<electron::ElectronBrowserContext*>(
|
|
|
|
+ web_ui()->GetWebContents()->GetBrowserContext())->prefs();
|
2024-04-15 22:10:32 +00:00
|
|
|
ui::AXApiType::Type api_type =
|
|
|
|
ui::AXApiType::From(pref->GetString(prefs::kShownAccessibilityApiType));
|
2024-04-23 15:30:47 +00:00
|
|
|
+
|
2024-04-15 22:10:32 +00:00
|
|
|
+ const std::vector<ui::AXApiType::Type> supported_types =
|
|
|
|
+ content::AXInspectFactory::SupportedApis();
|
|
|
|
// Check to see if it is in the supported types list.
|
|
|
|
if (std::find(supported_types.begin(), supported_types.end(), api_type) ==
|
|
|
|
supported_types.end()) {
|
2024-04-23 15:30:47 +00:00
|
|
|
@@ -881,8 +888,11 @@ void AccessibilityUIMessageHandler::RequestAccessibilityEvents(
|
2020-07-16 17:14:54 +00:00
|
|
|
// static
|
|
|
|
void AccessibilityUIMessageHandler::RegisterProfilePrefs(
|
|
|
|
user_prefs::PrefRegistrySyncable* registry) {
|
|
|
|
+#if 0
|
2024-04-15 22:10:32 +00:00
|
|
|
const std::string_view default_api_type =
|
|
|
|
std::string_view(ui::AXApiType::Type(ui::AXApiType::kBlink));
|
|
|
|
registry->RegisterStringPref(prefs::kShownAccessibilityApiType,
|
|
|
|
std::string(default_api_type));
|
|
|
|
+ registry->RegisterBooleanPref(prefs::kShowInternalAccessibilityTree, false);
|
2020-07-16 17:14:54 +00:00
|
|
|
+#endif
|
|
|
|
}
|
2024-01-31 23:04:13 +00:00
|
|
|
diff --git a/chrome/browser/ui/webui/accessibility/accessibility_ui.h b/chrome/browser/ui/webui/accessibility/accessibility_ui.h
|
2024-04-15 22:10:32 +00:00
|
|
|
index b62ebe504451d7dcd057a3fb6fa64ecd8897c26f..b0e54b76fa9a42df789b12f2e7e6d1ebd41b6aed 100644
|
2024-01-31 23:04:13 +00:00
|
|
|
--- a/chrome/browser/ui/webui/accessibility/accessibility_ui.h
|
|
|
|
+++ b/chrome/browser/ui/webui/accessibility/accessibility_ui.h
|
2024-04-15 22:10:32 +00:00
|
|
|
@@ -27,6 +27,8 @@ class ScopedAccessibilityMode;
|
2020-07-16 17:14:54 +00:00
|
|
|
class WebContents;
|
|
|
|
} // namespace content
|
|
|
|
|
|
|
|
+class ElectronAccessibilityUIMessageHandler;
|
|
|
|
+
|
|
|
|
namespace user_prefs {
|
|
|
|
class PrefRegistrySyncable;
|
|
|
|
} // namespace user_prefs
|
2024-04-15 22:10:32 +00:00
|
|
|
@@ -79,6 +81,8 @@ class AccessibilityUIMessageHandler : public content::WebUIMessageHandler {
|
2020-07-16 17:14:54 +00:00
|
|
|
static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
|
|
|
|
|
|
|
|
private:
|
|
|
|
+ friend class ElectronAccessibilityUIMessageHandler;
|
|
|
|
+
|
2024-01-31 23:04:13 +00:00
|
|
|
// Applies `mode` to `web_contents` for the lifetime of the accessibility
|
|
|
|
// UI page.
|
|
|
|
void SetAccessibilityModeForWebContents(content::WebContents* web_contents,
|