1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135
|
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/ash/accessibility/service/automation_client_impl.h"
#include "chrome/browser/ui/aura/accessibility/automation_manager_aura.h"
#include "extensions/browser/api/automation_internal/automation_event_router.h"
#include "extensions/browser/api/automation_internal/automation_internal_api.h"
#include "mojo/public/cpp/bindings/pending_associated_remote.h"
#include "ui/accessibility/ax_location_and_scroll_updates.h"
namespace ash {
AutomationClientImpl::AutomationClientImpl() = default;
AutomationClientImpl::~AutomationClientImpl() {
if (!bound_)
return;
extensions::AutomationEventRouter::GetInstance()->RegisterRemoteRouter(
nullptr);
}
void AutomationClientImpl::BindAutomation(
mojo::PendingAssociatedRemote<ax::mojom::Automation> automation) {
// Launches the service if it wasn't running yet.
// Development note (crbug.com/1355633): Using the remote router means
// extensions don't get a11y events when AutomationClientImpl is bound, so
// accessibility features built as component extensions are broken when the
// service is running.
if (!bound_) {
bound_ = true;
extensions::AutomationEventRouter::GetInstance()->RegisterRemoteRouter(
this);
}
automation_remotes_.Add(std::move(automation));
}
void AutomationClientImpl::BindAutomationClient(
mojo::PendingReceiver<ax::mojom::AutomationClient> automation_client) {
automation_client_receivers_.Add(this, std::move(automation_client));
}
void AutomationClientImpl::DispatchAccessibilityEvents(
const ui::AXTreeID& tree_id,
const std::vector<ui::AXTreeUpdate>& updates,
const gfx::Point& mouse_location,
const std::vector<ui::AXEvent>& events) {
DCHECK(tree_id != ui::AXTreeIDUnknown());
if (tree_id == ui::AXTreeIDUnknown())
return;
for (auto& remote : automation_remotes_) {
remote->DispatchAccessibilityEvents(tree_id, updates, mouse_location,
events);
}
}
void AutomationClientImpl::DispatchAccessibilityLocationChange(
const ui::AXTreeID& tree_id,
const ui::AXLocationChange& details) {
if (tree_id == ui::AXTreeIDUnknown())
return;
for (auto& remote : automation_remotes_) {
remote->DispatchAccessibilityLocationChange(tree_id, details.id,
details.new_location);
}
}
void AutomationClientImpl::DispatchAccessibilityScrollChange(
const ui::AXTreeID& tree_id,
const ui::AXScrollChange& details) {
if (tree_id == ui::AXTreeIDUnknown()) {
return;
}
for (auto& remote : automation_remotes_) {
remote->DispatchAccessibilityScrollChange(
tree_id, details.id, details.scroll_x, details.scroll_y);
}
}
void AutomationClientImpl::DispatchTreeDestroyedEvent(ui::AXTreeID tree_id) {
if (tree_id == ui::AXTreeIDUnknown())
return;
// TODO(crbug.com/1355633): Send to AccessibilityService.
// for (auto& remote : automation_remotes_) {
// remote->DispatchTreeDestroyedEvent(tree_id);
// }
}
void AutomationClientImpl::DispatchActionResult(
const ui::AXActionData& data,
bool result,
content::BrowserContext* browser_context) {
// TODO(crbug.com/1355633): Send to AccessibilityService.
// for (auto& remote : automation_remotes_) {
// remote->DispatchActionResult(data, result);
// }
}
void AutomationClientImpl::DispatchGetTextLocationDataResult(
const ui::AXActionData& data,
const std::optional<gfx::Rect>& rect) {
// TODO(crbug.com/1355633): Send to AccessibilityService.
// for (auto& remote : automation_remotes_) {
// remote->DispatchGetTextLocationDataResult(data, rect);
// }
}
void AutomationClientImpl::Enable(EnableCallback callback) {
// Enable automation for all of Desktop.
AutomationManagerAura::GetInstance()->Enable();
std::move(callback).Run(AutomationManagerAura::GetInstance()->ax_tree_id());
}
void AutomationClientImpl::Disable() {
// Disable automation.
AutomationManagerAura::GetInstance()->Disable();
}
void AutomationClientImpl::EnableChildTree(const ui::AXTreeID& tree_id) {
// TODO(crbug.com/1355633): Refactor logic from extensions namespace to a
// common location.
extensions::AutomationInternalEnableTreeFunction::EnableTree(
tree_id, /*extension_id=*/"");
}
void AutomationClientImpl::PerformAction(const ui::AXActionData& data) {
// TODO(crbug.com/1355633): Refactor logic from extensions namespace to a
// common location.
extensions::AutomationInternalPerformActionFunction::PerformAction(
data, /*extension=*/nullptr, /*automation_info=*/nullptr);
}
} // namespace ash
|