|
Packit |
f0b94e |
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
Packit |
f0b94e |
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
Packit |
f0b94e |
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
Packit |
f0b94e |
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
Packit |
f0b94e |
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
#ifndef nsXBLWindowKeyHandler_h__
|
|
Packit |
f0b94e |
#define nsXBLWindowKeyHandler_h__
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
#include "mozilla/EventForwards.h"
|
|
Packit |
f0b94e |
#include "mozilla/layers/KeyboardMap.h"
|
|
Packit |
f0b94e |
#include "nsWeakPtr.h"
|
|
Packit |
f0b94e |
#include "nsIDOMEventListener.h"
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
class nsAtom;
|
|
Packit |
f0b94e |
class nsIDOMElement;
|
|
Packit |
f0b94e |
class nsXBLPrototypeHandler;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
namespace mozilla {
|
|
Packit |
f0b94e |
class EventListenerManager;
|
|
Packit |
f0b94e |
class WidgetKeyboardEvent;
|
|
Packit |
f0b94e |
struct IgnoreModifierState;
|
|
Packit |
f0b94e |
namespace dom {
|
|
Packit |
f0b94e |
class Element;
|
|
Packit |
f0b94e |
class EventTarget;
|
|
Packit |
f0b94e |
class KeyboardEvent;
|
|
Packit |
f0b94e |
} // namespace dom
|
|
Packit |
f0b94e |
} // namespace mozilla
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
class nsXBLWindowKeyHandler : public nsIDOMEventListener {
|
|
Packit |
f0b94e |
typedef mozilla::EventListenerManager EventListenerManager;
|
|
Packit |
f0b94e |
typedef mozilla::IgnoreModifierState IgnoreModifierState;
|
|
Packit |
f0b94e |
typedef mozilla::layers::KeyboardMap KeyboardMap;
|
|
Packit |
f0b94e |
typedef mozilla::dom::KeyboardEvent KeyboardEvent;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
public:
|
|
Packit |
f0b94e |
nsXBLWindowKeyHandler(nsIDOMElement* aElement,
|
|
Packit |
f0b94e |
mozilla::dom::EventTarget* aTarget);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void InstallKeyboardEventListenersTo(
|
|
Packit |
f0b94e |
EventListenerManager* aEventListenerManager);
|
|
Packit |
f0b94e |
void RemoveKeyboardEventListenersFrom(
|
|
Packit |
f0b94e |
EventListenerManager* aEventListenerManager);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
static KeyboardMap CollectKeyboardShortcuts();
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_DECL_ISUPPORTS
|
|
Packit |
f0b94e |
NS_DECL_NSIDOMEVENTLISTENER
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
protected:
|
|
Packit |
f0b94e |
virtual ~nsXBLWindowKeyHandler();
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
nsresult WalkHandlers(KeyboardEvent* aKeyEvent, nsAtom* aEventType);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// walk the handlers, looking for one to handle the event
|
|
Packit |
f0b94e |
bool WalkHandlersInternal(KeyboardEvent* aKeyEvent, nsAtom* aEventType,
|
|
Packit |
f0b94e |
nsXBLPrototypeHandler* aHandler, bool aExecute,
|
|
Packit |
f0b94e |
bool* aOutReservedForChrome = nullptr);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// walk the handlers for aEvent, aCharCode and aIgnoreModifierState. Execute
|
|
Packit |
f0b94e |
// it if aExecute = true.
|
|
Packit |
f0b94e |
bool WalkHandlersAndExecute(KeyboardEvent* aKeyEvent, nsAtom* aEventType,
|
|
Packit |
f0b94e |
nsXBLPrototypeHandler* aHandler,
|
|
Packit |
f0b94e |
uint32_t aCharCode,
|
|
Packit |
f0b94e |
const IgnoreModifierState& aIgnoreModifierState,
|
|
Packit |
f0b94e |
bool aExecute,
|
|
Packit |
f0b94e |
bool* aOutReservedForChrome = nullptr);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// HandleEvent function for the capturing phase in the default event group.
|
|
Packit |
f0b94e |
void HandleEventOnCaptureInDefaultEventGroup(KeyboardEvent* aEvent);
|
|
Packit |
f0b94e |
// HandleEvent function for the capturing phase in the system event group.
|
|
Packit |
f0b94e |
void HandleEventOnCaptureInSystemEventGroup(KeyboardEvent* aEvent);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Check if any handler would handle the given event. Optionally returns
|
|
Packit |
f0b94e |
// whether the command handler for the event is marked with the "reserved"
|
|
Packit |
f0b94e |
// attribute.
|
|
Packit |
f0b94e |
bool HasHandlerForEvent(KeyboardEvent* aEvent,
|
|
Packit |
f0b94e |
bool* aOutReservedForChrome = nullptr);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Returns true if the key would be reserved for the given handler. A reserved
|
|
Packit |
f0b94e |
// key is not sent to a content process or single-process equivalent.
|
|
Packit |
f0b94e |
bool IsReservedKey(mozilla::WidgetKeyboardEvent* aKeyEvent,
|
|
Packit |
f0b94e |
nsXBLPrototypeHandler* aHandler);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Returns event type for matching between aWidgetKeyboardEvent and
|
|
Packit |
f0b94e |
// shortcut key handlers. This is used for calling WalkHandlers(),
|
|
Packit |
f0b94e |
// WalkHandlersInternal() and WalkHandlersAndExecute().
|
|
Packit |
f0b94e |
nsAtom* ConvertEventToDOMEventType(
|
|
Packit |
f0b94e |
const mozilla::WidgetKeyboardEvent& aWidgetKeyboardEvent) const;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// lazily load the special doc info for loading handlers
|
|
Packit |
f0b94e |
static void EnsureSpecialDocInfo();
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// lazily load the handlers. Overridden to handle being attached
|
|
Packit |
f0b94e |
// to a particular element rather than the document
|
|
Packit |
f0b94e |
nsresult EnsureHandlers();
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Is an HTML editable element focused
|
|
Packit |
f0b94e |
bool IsHTMLEditableFieldFocused();
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Returns the element which was passed as a parameter to the constructor,
|
|
Packit |
f0b94e |
// unless the element has been removed from the document. Optionally returns
|
|
Packit |
f0b94e |
// whether the disabled attribute is set on the element (assuming the element
|
|
Packit |
f0b94e |
// is non-null).
|
|
Packit |
f0b94e |
already_AddRefed<mozilla::dom::Element> GetElement(
|
|
Packit |
f0b94e |
bool* aIsDisabled = nullptr);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
/**
|
|
Packit |
f0b94e |
* GetElementForHandler() retrieves an element for the handler. The element
|
|
Packit |
f0b94e |
* may be a command element or a key element.
|
|
Packit |
f0b94e |
*
|
|
Packit |
f0b94e |
* @param aHandler The handler.
|
|
Packit |
f0b94e |
* @param aElementForHandler Must not be nullptr. The element is returned to
|
|
Packit |
f0b94e |
* this.
|
|
Packit |
f0b94e |
* @return true if the handler is valid. Otherwise, false.
|
|
Packit |
f0b94e |
*/
|
|
Packit |
f0b94e |
bool GetElementForHandler(nsXBLPrototypeHandler* aHandler,
|
|
Packit |
f0b94e |
mozilla::dom::Element** aElementForHandler);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
/**
|
|
Packit |
f0b94e |
* IsExecutableElement() returns true if aElement is executable.
|
|
Packit |
f0b94e |
* Otherwise, false. aElement should be a command element or a key element.
|
|
Packit |
f0b94e |
*/
|
|
Packit |
f0b94e |
bool IsExecutableElement(mozilla::dom::Element* aElement) const;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Using weak pointer to the DOM Element.
|
|
Packit |
f0b94e |
nsWeakPtr mWeakPtrForElement;
|
|
Packit |
f0b94e |
mozilla::dom::EventTarget* mTarget; // weak ref
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// these are not owning references; the prototype handlers are owned
|
|
Packit |
f0b94e |
// by the prototype bindings which are owned by the docinfo.
|
|
Packit |
f0b94e |
nsXBLPrototypeHandler* mHandler; // platform bindings
|
|
Packit |
f0b94e |
nsXBLPrototypeHandler* mUserHandler; // user-specific bindings
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// holds reference count to document info about bindings
|
|
Packit |
f0b94e |
static uint32_t sRefCnt;
|
|
Packit |
f0b94e |
};
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
already_AddRefed<nsXBLWindowKeyHandler> NS_NewXBLWindowKeyHandler(
|
|
Packit |
f0b94e |
nsIDOMElement* aElement, mozilla::dom::EventTarget* aTarget);
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
#endif
|