2007-03-22 10:30:00 -07:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* 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/. */
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
#include "domstubs.idl"
|
|
|
|
|
|
|
|
interface nsIDOMEventTarget;
|
|
|
|
|
2012-06-10 11:14:30 -07:00
|
|
|
[ptr] native nsEventPtr(nsEvent);
|
|
|
|
[ptr] native IPCMessagePtr(IPC::Message);
|
|
|
|
[ptr] native ConstIPCMessagePtr(const IPC::Message);
|
|
|
|
%{C++
|
|
|
|
class nsEvent;
|
|
|
|
class nsCommandEvent;
|
|
|
|
class nsPresContext;
|
|
|
|
class nsInvalidateRequestList;
|
|
|
|
namespace IPC {
|
|
|
|
class Message;
|
|
|
|
}
|
|
|
|
%}
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
/**
|
|
|
|
* The nsIDOMEvent interface is the primary datatype for all events in
|
|
|
|
* the Document Object Model.
|
|
|
|
*
|
|
|
|
* For more information on this interface please see
|
2012-05-03 03:59:51 -07:00
|
|
|
* http://dev.w3.org/2006/webapi/DOM-Level-3-Events/html/DOM3-Events.html and
|
|
|
|
* http://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html
|
2007-03-22 10:30:00 -07:00
|
|
|
*/
|
|
|
|
|
2012-06-10 11:14:30 -07:00
|
|
|
[scriptable, builtinclass, uuid(a7dc0284-5832-4034-a8a5-d860ce0f21d3)]
|
2007-03-22 10:30:00 -07:00
|
|
|
interface nsIDOMEvent : nsISupports
|
|
|
|
{
|
|
|
|
// PhaseType
|
2012-05-03 03:59:51 -07:00
|
|
|
/**
|
|
|
|
* The event isn't being dispatched.
|
|
|
|
*/
|
|
|
|
const unsigned short NONE = 0;
|
2007-03-22 10:30:00 -07:00
|
|
|
/**
|
|
|
|
* The current event phase is the capturing phase.
|
|
|
|
*/
|
|
|
|
const unsigned short CAPTURING_PHASE = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The event is currently being evaluated at the target EventTarget.
|
|
|
|
*/
|
|
|
|
const unsigned short AT_TARGET = 2;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The current event phase is the bubbling phase.
|
|
|
|
*/
|
|
|
|
const unsigned short BUBBLING_PHASE = 3;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The name of the event (case-insensitive). The name must be an XML
|
|
|
|
* name.
|
|
|
|
*/
|
|
|
|
readonly attribute DOMString type;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate the EventTarget to which the event was originally
|
|
|
|
* dispatched.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIDOMEventTarget target;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate the EventTarget whose EventListeners are currently
|
|
|
|
* being processed. This is particularly useful during capturing and
|
|
|
|
* bubbling.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIDOMEventTarget currentTarget;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate which phase of event flow is currently being
|
|
|
|
* evaluated.
|
|
|
|
*/
|
|
|
|
readonly attribute unsigned short eventPhase;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate whether or not an event is a bubbling event. If the
|
|
|
|
* event can bubble the value is true, else the value is false.
|
|
|
|
*/
|
|
|
|
readonly attribute boolean bubbles;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate whether or not an event can have its default action
|
|
|
|
* prevented. If the default action can be prevented the value is true,
|
|
|
|
* else the value is false.
|
|
|
|
*/
|
|
|
|
readonly attribute boolean cancelable;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to specify the time (in milliseconds relative to the epoch) at
|
|
|
|
* which the event was created. Due to the fact that some systems may
|
|
|
|
* not provide this information the value of timeStamp may be not
|
|
|
|
* available for all events. When not available, a value of 0 will be
|
|
|
|
* returned. Examples of epoch time are the time of the system start or
|
|
|
|
* 0:0:0 UTC 1st January 1970.
|
|
|
|
*/
|
|
|
|
readonly attribute DOMTimeStamp timeStamp;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The stopPropagation method is used prevent further propagation of an
|
|
|
|
* event during event flow. If this method is called by any
|
|
|
|
* EventListener the event will cease propagating through the tree. The
|
|
|
|
* event will complete dispatch to all listeners on the current
|
|
|
|
* EventTarget before event flow stops. This method may be used during
|
|
|
|
* any stage of event flow.
|
|
|
|
*/
|
|
|
|
void stopPropagation();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If an event is cancelable, the preventDefault method is used to
|
|
|
|
* signify that the event is to be canceled, meaning any default action
|
|
|
|
* normally taken by the implementation as a result of the event will
|
|
|
|
* not occur. If, during any stage of event flow, the preventDefault
|
|
|
|
* method is called the event is canceled. Any default action associated
|
|
|
|
* with the event will not occur. Calling this method for a
|
|
|
|
* non-cancelable event has no effect. Once preventDefault has been
|
|
|
|
* called it will remain in effect throughout the remainder of the
|
|
|
|
* event's propagation. This method may be used during any stage of
|
|
|
|
* event flow.
|
|
|
|
*/
|
|
|
|
void preventDefault();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The initEvent method is used to initialize the value of an Event
|
|
|
|
* created through the DocumentEvent interface. This method may only be
|
|
|
|
* called before the Event has been dispatched via the dispatchEvent
|
|
|
|
* method, though it may be called multiple times during that phase if
|
|
|
|
* necessary. If called multiple times the final invocation takes
|
|
|
|
* precedence. If called from a subclass of Event interface only the
|
|
|
|
* values specified in the initEvent method are modified, all other
|
|
|
|
* attributes are left unchanged.
|
|
|
|
*
|
|
|
|
* @param eventTypeArg Specifies the event type. This type may be
|
|
|
|
* any event type currently defined in this
|
|
|
|
* specification or a new event type.. The string
|
|
|
|
* must be an XML name.
|
|
|
|
* Any new event type must not begin with any
|
|
|
|
* upper, lower, or mixed case version of the
|
|
|
|
* string "DOM". This prefix is reserved for
|
|
|
|
* future DOM event sets. It is also strongly
|
|
|
|
* recommended that third parties adding their
|
|
|
|
* own events use their own prefix to avoid
|
|
|
|
* confusion and lessen the probability of
|
|
|
|
* conflicts with other new events.
|
|
|
|
* @param canBubbleArg Specifies whether or not the event can bubble.
|
|
|
|
* @param cancelableArg Specifies whether or not the event's default
|
|
|
|
* action can be prevented.
|
|
|
|
*/
|
|
|
|
void initEvent(in DOMString eventTypeArg,
|
|
|
|
in boolean canBubbleArg,
|
|
|
|
in boolean cancelableArg);
|
2011-05-13 13:44:35 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to indicate whether preventDefault() has been called for this event.
|
|
|
|
*/
|
|
|
|
readonly attribute boolean defaultPrevented;
|
2011-11-04 10:17:19 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Prevents other event listeners from being triggered and,
|
|
|
|
* unlike Event.stopPropagation() its effect is immediate.
|
|
|
|
*/
|
|
|
|
void stopImmediatePropagation();
|
2012-06-10 11:14:30 -07:00
|
|
|
|
|
|
|
[noscript] void duplicatePrivateData();
|
|
|
|
[noscript] void setTarget(in nsIDOMEventTarget aTarget);
|
|
|
|
[notxpcom] boolean IsDispatchStopped();
|
|
|
|
[notxpcom] nsEventPtr GetInternalNSEvent();
|
|
|
|
[noscript] void SetTrusted(in boolean aTrusted);
|
|
|
|
[notxpcom] void Serialize(in IPCMessagePtr aMsg,
|
|
|
|
in boolean aSerializeInterfaceType);
|
|
|
|
[notxpcom] boolean Deserialize(in ConstIPCMessagePtr aMsg, out voidPtr aIter);
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
};
|
2011-12-14 11:53:48 -08:00
|
|
|
|
2012-03-12 21:44:48 -07:00
|
|
|
dictionary EventInit
|
2011-12-14 11:53:48 -08:00
|
|
|
{
|
2012-03-12 21:44:48 -07:00
|
|
|
boolean bubbles;
|
|
|
|
boolean cancelable;
|
2011-12-14 11:53:48 -08:00
|
|
|
};
|
2012-06-10 11:14:30 -07:00
|
|
|
|
|
|
|
%{C++
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMDataContainerEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMUIEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsGUIEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMouseEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsInputEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMouseScrollEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsInputEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMDragEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsDragEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMKeyboardEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsKeyEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMCompositionEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsCompositionEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMutationEvent(nsIDOMEvent** aResult NS_OUTPARAM, nsPresContext* aPresContext, class nsMutationEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMPopupBlockedEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMDeviceOrientationEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMDeviceLightEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMDeviceMotionEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMTextEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, class nsTextEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMBeforeUnloadEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMPageTransitionEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMSVGEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, class nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMSVGZoomEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, class nsGUIEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMTimeEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, class nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMXULCommandEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext, class nsInputEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMCommandEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsCommandEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMessageEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMProgressEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsEvent* aEvent);
|
|
|
|
// This empties aInvalidateRequests.
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMNotifyPaintEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext,
|
|
|
|
nsEvent* aEvent,
|
|
|
|
PRUint32 aEventType = 0,
|
|
|
|
nsInvalidateRequestList* aInvalidateRequests = nsnull);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMAudioAvailableEvent(nsIDOMEvent** aResult, nsPresContext* aPresContext,
|
|
|
|
nsEvent* aEvent,
|
|
|
|
PRUint32 aEventType = 0,
|
|
|
|
float* aFrameBuffer = nsnull,
|
|
|
|
PRUint32 aFrameBufferLength = 0,
|
|
|
|
float aTime = 0);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMSimpleGestureEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsSimpleGestureEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMScrollAreaEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsScrollAreaEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMTransitionEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsTransitionEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMAnimationEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsAnimationEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMCloseEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMozTouchEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsMozTouchEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMTouchEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, class nsTouchEvent *aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMSmsEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMozSettingsEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
2012-06-14 10:13:12 -07:00
|
|
|
NS_NewDOMMozContactChangeEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
2012-06-16 11:14:12 -07:00
|
|
|
NS_NewDOMMozWifiStatusChangeEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMMozWifiConnectionInfoEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
2012-06-10 11:14:30 -07:00
|
|
|
NS_NewDOMPopStateEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
|
|
|
nsresult
|
|
|
|
NS_NewDOMHashChangeEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
2012-06-14 16:03:55 -07:00
|
|
|
nsresult
|
|
|
|
NS_NewDOMMozApplicationEvent(nsIDOMEvent** aInstancePtrResult, nsPresContext* aPresContext, nsEvent* aEvent);
|
2012-06-10 11:14:30 -07:00
|
|
|
%}
|