blob: 64c1fe7aa02d08e8c3b387c72b186a4fdcc9deaf (
plain)
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
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "XULAlertAccessible.h"
#include "LocalAccessible-inl.h"
#include "mozilla/a11y/Role.h"
#include "States.h"
using namespace mozilla::a11y;
////////////////////////////////////////////////////////////////////////////////
// XULAlertAccessible
////////////////////////////////////////////////////////////////////////////////
XULAlertAccessible::XULAlertAccessible(nsIContent* aContent,
DocAccessible* aDoc)
: AccessibleWrap(aContent, aDoc) {
mGenericTypes |= eAlert;
}
XULAlertAccessible::~XULAlertAccessible() {}
role XULAlertAccessible::NativeRole() const { return roles::ALERT; }
uint64_t XULAlertAccessible::NativeState() const {
return LocalAccessible::NativeState() | states::ALERT;
}
ENameValueFlag XULAlertAccessible::Name(nsString& aName) const {
// Screen readers need to read contents of alert, not the accessible name.
// If we have both some screen readers will read the alert twice.
aName.Truncate();
return eNameOK;
}
////////////////////////////////////////////////////////////////////////////////
// Widgets
bool XULAlertAccessible::IsWidget() const { return true; }
LocalAccessible* XULAlertAccessible::ContainerWidget() const { return nullptr; }
|