summaryrefslogtreecommitdiffstats
path: root/accessible/xul/XULAlertAccessible.cpp
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; }