blob: 187df3c471fcd22c9daaa9c109ff8eb11f534116 [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_PUBLIC_BROWSER_BROWSER_ACCESSIBILITY_STATE_H_
#define CONTENT_PUBLIC_BROWSER_BROWSER_ACCESSIBILITY_STATE_H_
#include "base/callback_list.h"
#include "base/functional/callback_forward.h"
#include "content/common/content_export.h"
#include "ui/accessibility/ax_mode.h"
namespace ui {
enum class AssistiveTech;
}
namespace content {
class BrowserContext;
struct FocusedNodeDetails;
class ScopedAccessibilityMode;
class WebContents;
// The BrowserAccessibilityState class is used to determine if the browser
// should be customized for users with assistive technology, such as screen
// readers.
class CONTENT_EXPORT BrowserAccessibilityState {
public:
virtual ~BrowserAccessibilityState() = default;
// Returns the singleton instance.
static BrowserAccessibilityState* GetInstance();
// Returns the effective accessibility mode for the process. Individual
// WebContentses may have an effective mode that is a superset of this as a
// result of any live ScopedAccessibilityMode instances targeting them
// directly or targeting their BrowserContext.
virtual ui::AXMode GetAccessibilityMode() = 0;
// Returns the accessibility mode for `browser_context`, which is the union of
// all mode flags applied to the process and to `browser_context` itself.
virtual ui::AXMode GetAccessibilityModeForBrowserContext(
BrowserContext* browser_context) = 0;
// The following methods apply `mode` throughout the lifetime of the returned
// scoper to a) the process, b) a specific BrowserContext, or c) a specific
// WebContents (colloquially referred to as the "target" of the scoper).
// Creation and deletion of a scoper will each result in recomputation of the
// effective accessibility mode for its target. If the effective mode changes,
// WebContentses associated with the target will be notified. Calls that are
// made in response to signals from the platform accessibility integration
// (e.g., enabling accessibility when VoiceOver is detected) must include the
// `AXMode::kFromPlatform` flag in addition to other flags.
virtual std::unique_ptr<ScopedAccessibilityMode> CreateScopedModeForProcess(
ui::AXMode mode) = 0;
virtual std::unique_ptr<ScopedAccessibilityMode>
CreateScopedModeForBrowserContext(BrowserContext* browser_context,
ui::AXMode mode) = 0;
virtual std::unique_ptr<ScopedAccessibilityMode>
CreateScopedModeForWebContents(WebContents* web_contents,
ui::AXMode mode) = 0;
// Return the last active assistive technology. If multiple ATs are
// running concurrently (rare case), the result will prefer a screen reader.
// This will use the last known value, so it is possible for it to be out of
// date for a short period of time. Use
// AXModeObserver::OnAssistiveTechChanged() to get notifications for changes
// to this state.
virtual ui::AssistiveTech ActiveAssistiveTech() const = 0;
// Update BrowserAccessibilityState with the current status of performance
// filtering.
virtual void SetPerformanceFilteringAllowed(bool allowed) = 0;
// Returns whether performance filtering is allowed.
virtual bool IsPerformanceFilteringAllowed() = 0;
// Allows or disallows changes to the AXMode. This is useful for tests that
// want to ensure that the AXMode is not changed after a certain point.
virtual void SetAXModeChangeAllowed(bool allow) = 0;
virtual bool IsAXModeChangeAllowed() const = 0;
// Enables or disables activation of accessibility from interactions with the
// platform's accessibility integration. Such activations are disabled by
// default in tests; specifically, mode changes via calls to
// `CreateScopedModeForProcess()` are ignored when the `AXMode` contains the
// `AXMode::kFromPlatform` flag.
virtual void SetActivationFromPlatformEnabled(bool enabled) = 0;
virtual bool IsActivationFromPlatformEnabled() = 0;
// Returns true if the current AXMode was set as part of the accessibility
// performance measurement experiment.
virtual bool IsAccessibilityPerformanceMeasurementExperimentActive()
const = 0;
// Notifies web contents that preferences have changed.
virtual void NotifyWebContentsPreferencesChanged() const = 0;
using FocusChangedCallback =
base::RepeatingCallback<void(const FocusedNodeDetails&)>;
// Registers a callback method that is called whenever the focused element
// has changed inside a WebContents.
virtual base::CallbackListSubscription RegisterFocusChangedCallback(
FocusChangedCallback callback) = 0;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_BROWSER_ACCESSIBILITY_STATE_H_