gecko-dev/dom/xul/XULMenuElement.h
Emilio Cobos Álvarez 4f1f5e7314 Bug 1805414 - Remove nsMenuFrame and nsMenuParent. r=smaug,Jamie,desktop-theme-reviewers,settings-reviewers,dao
Move most the event handling stuff to the DOM. I've left nsMenuBarFrame
for now, but I will be removing that in the future.

The basic set up is:

  * nsMenuParent becomes XULMenuParentElement (menubar or popup, manages
    the current active menu item)

  * nsMenuFrame -> XULButtonElements that return true for IsMenu().
    Can't use XULMenuElement because of <button type=menu>, which
    behaves like a, well, menu.

This makes the a11y events for menus (DOMMenuItem{Active,Inactive}) make
sense (before that we were firing duplicate Inactive events etc, and the
event order was rather suspicious).

Differential Revision: https://phabricator.services.mozilla.com/D164210
2023-01-04 19:01:13 +00:00

38 lines
1.1 KiB
C++

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* 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/. */
#ifndef mozilla_dom_XULMenuElement_h
#define mozilla_dom_XULMenuElement_h
#include "XULButtonElement.h"
#include "nsINode.h"
#include "nsXULElement.h"
namespace mozilla::dom {
class KeyboardEvent;
class XULMenuElement final : public XULButtonElement {
public:
explicit XULMenuElement(already_AddRefed<mozilla::dom::NodeInfo>&& aNodeInfo)
: XULButtonElement(std::move(aNodeInfo)) {}
MOZ_CAN_RUN_SCRIPT void SetActiveMenuChild(Element*);
Element* GetActiveMenuChild();
NS_IMPL_FROMNODE_HELPER(XULMenuElement,
IsAnyOfXULElements(nsGkAtoms::menu,
nsGkAtoms::menulist));
private:
virtual ~XULMenuElement() = default;
JSObject* WrapNode(JSContext* aCx, JS::Handle<JSObject*> aGivenProto) final;
};
} // namespace mozilla::dom
#endif // XULMenuElement_h