1998-06-07 07:55:55 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* The contents of this file are subject to the Netscape Public
|
|
|
|
* License Version 1.1 (the "License"); you may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of
|
|
|
|
* the License at http://www.mozilla.org/NPL/
|
1998-06-07 07:55:55 +00:00
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* Software distributed under the License is distributed on an "AS
|
|
|
|
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
|
|
|
* implied. See the License for the specific language governing
|
|
|
|
* rights and limitations under the License.
|
1998-06-07 07:55:55 +00:00
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
1998-06-07 07:55:55 +00:00
|
|
|
* Communications Corporation. Portions created by Netscape are
|
1999-11-06 03:40:37 +00:00
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
2001-02-12 06:54:31 +00:00
|
|
|
* Steve Clark (buster@netscape.com)
|
1998-06-07 07:55:55 +00:00
|
|
|
*/
|
|
|
|
|
2000-05-05 14:47:37 +00:00
|
|
|
#include "nsCOMPtr.h"
|
1998-06-07 07:55:55 +00:00
|
|
|
#include "nsDOMEvent.h"
|
1998-06-23 21:53:02 +00:00
|
|
|
#include "nsIDOMNode.h"
|
1998-07-23 02:55:33 +00:00
|
|
|
#include "nsIEventStateManager.h"
|
1998-11-18 05:25:26 +00:00
|
|
|
#include "nsIFrame.h"
|
|
|
|
#include "nsIContent.h"
|
1998-10-09 22:57:36 +00:00
|
|
|
#include "nsIRenderingContext.h"
|
1999-06-09 07:38:26 +00:00
|
|
|
#include "nsIWidget.h"
|
1999-06-16 04:39:51 +00:00
|
|
|
#include "nsIPresShell.h"
|
1999-08-06 02:32:13 +00:00
|
|
|
#include "nsPrivateTextRange.h"
|
1999-07-27 20:55:03 +00:00
|
|
|
#include "nsIDocument.h"
|
1999-10-15 13:34:45 +00:00
|
|
|
#include "nsIViewManager.h"
|
1999-08-31 01:20:32 +00:00
|
|
|
#include "nsIPrivateCompositionEvent.h"
|
2000-05-05 14:47:37 +00:00
|
|
|
#include "nsIScrollableView.h"
|
2000-05-16 11:35:12 +00:00
|
|
|
#include "nsIDOMEventTarget.h"
|
|
|
|
#include "nsIInterfaceRequestor.h"
|
2000-09-01 01:54:35 +00:00
|
|
|
#include "nsIDOMWindowInternal.h"
|
2000-05-16 11:35:12 +00:00
|
|
|
#include "nsIDOMAbstractView.h"
|
|
|
|
#include "prmem.h"
|
|
|
|
#include "nsLayoutAtoms.h"
|
2000-11-27 07:55:20 +00:00
|
|
|
#include "nsMutationEvent.h"
|
1998-06-07 07:55:55 +00:00
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
|
|
|
|
static char* mEventNames[] = {
|
1999-04-12 21:17:07 +00:00
|
|
|
"mousedown", "mouseup", "click", "dblclick", "mouseover",
|
2001-03-23 03:34:15 +00:00
|
|
|
"mouseout", "mousemove", "contextmenu", "keydown", "keyup", "keypress",
|
1999-04-12 21:17:07 +00:00
|
|
|
"focus", "blur", "load", "unload", "abort", "error",
|
1999-09-21 23:02:35 +00:00
|
|
|
"submit", "reset", "change", "select", "input", "paint" ,"text",
|
1999-12-01 22:35:33 +00:00
|
|
|
"create", "close", "destroy", "command", "broadcast", "commandupdate",
|
2000-05-17 06:53:58 +00:00
|
|
|
"dragenter", "dragover", "dragexit", "dragdrop", "draggesture", "resize",
|
2000-11-27 07:55:20 +00:00
|
|
|
"scroll","overflow", "underflow", "overflowchanged",
|
|
|
|
"DOMSubtreeModified", "DOMNodeInserted", "DOMNodeRemoved",
|
|
|
|
"DOMNodeRemovedFromDocument", "DOMNodeInsertedIntoDocument",
|
|
|
|
"DOMAttrModified", "DOMCharacterDataModified"
|
1999-09-02 03:51:03 +00:00
|
|
|
};
|
1998-07-17 04:52:12 +00:00
|
|
|
|
2001-02-12 06:54:31 +00:00
|
|
|
/* declare static class data */
|
|
|
|
nsDOMEvent nsDOMEvent::gEventPool;
|
|
|
|
PRBool nsDOMEvent::gEventPoolInUse=PR_FALSE;
|
|
|
|
|
|
|
|
#ifdef NS_DEBUG // metrics for measuring event pool use
|
|
|
|
static PRInt32 numEvents=0;
|
|
|
|
static PRInt32 numNewEvents=0;
|
|
|
|
static PRInt32 numDelEvents=0;
|
|
|
|
static PRInt32 numAllocFromPool=0;
|
|
|
|
//#define NOISY_EVENT_LEAKS // define NOISY_EVENT_LEAKS to get metrics printed to stdout for all nsDOMEvent allocations
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// allocate the memory for the object from the recycler, if possible
|
|
|
|
// otherwise, just grab it from the heap.
|
|
|
|
void*
|
|
|
|
nsDOMEvent::operator new(size_t aSize)
|
|
|
|
{
|
|
|
|
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
numEvents++;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void *result = nsnull;
|
|
|
|
|
|
|
|
if (!gEventPoolInUse) {
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
numAllocFromPool++;
|
|
|
|
#endif
|
|
|
|
result = &gEventPool;
|
|
|
|
gEventPoolInUse = PR_TRUE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
numNewEvents++;
|
|
|
|
#endif
|
|
|
|
result = ::operator new(aSize);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
nsCRT::zero(result, aSize);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Overridden to prevent the global delete from being called on objects from
|
|
|
|
// the recycler. Otherwise, just pass through to the global delete operator.
|
|
|
|
void
|
|
|
|
nsDOMEvent::operator delete(void* aPtr)
|
|
|
|
{
|
|
|
|
if (aPtr==&gEventPool) {
|
|
|
|
gEventPoolInUse = PR_FALSE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
numDelEvents++;
|
|
|
|
#endif
|
|
|
|
::operator delete(aPtr);
|
|
|
|
}
|
|
|
|
#if defined(NS_DEBUG) && defined(NOISY_EVENT_LEAKS)
|
|
|
|
printf("total events =%d, from pool = %d, concurrent live events = %d\n",
|
|
|
|
numEvents, numAllocFromPool, numNewEvents-numDelEvents);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
nsDOMEvent::nsDOMEvent(nsIPresContext* aPresContext, nsEvent* aEvent, const nsAReadableString& aEventType)
|
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
mPresContext = aPresContext;
|
2000-05-01 06:58:53 +00:00
|
|
|
if (mPresContext)
|
|
|
|
NS_ADDREF(mPresContext);
|
2000-05-16 11:35:12 +00:00
|
|
|
if (aEvent) {
|
|
|
|
mEventIsInternal = PR_FALSE;
|
|
|
|
mEvent = aEvent;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
//Allocate internal event
|
2000-08-23 17:27:06 +00:00
|
|
|
nsAutoString eventType(aEventType);
|
|
|
|
if (eventType.EqualsIgnoreCase("MouseEvent")) {
|
2000-05-16 11:35:12 +00:00
|
|
|
mEvent = PR_NEWZAP(nsMouseEvent);
|
|
|
|
mEvent->eventStructType = NS_MOUSE_EVENT;
|
|
|
|
}
|
2000-08-23 17:27:06 +00:00
|
|
|
else if (eventType.EqualsIgnoreCase("KeyEvent")) {
|
2000-05-16 11:35:12 +00:00
|
|
|
mEvent = PR_NEWZAP(nsKeyEvent);
|
|
|
|
mEvent->eventStructType = NS_KEY_EVENT;
|
|
|
|
}
|
2000-08-23 17:27:06 +00:00
|
|
|
else if (eventType.EqualsIgnoreCase("HTMLEvent")) {
|
2000-05-16 11:35:12 +00:00
|
|
|
mEvent = PR_NEWZAP(nsEvent);
|
|
|
|
mEvent->eventStructType = NS_EVENT;
|
|
|
|
}
|
2000-11-27 07:55:20 +00:00
|
|
|
else if (eventType.EqualsIgnoreCase("MutationEvent")) {
|
|
|
|
mEvent = PR_NEWZAP(nsMutationEvent);
|
|
|
|
mEvent->eventStructType = NS_MUTATION_EVENT;
|
|
|
|
}
|
2000-05-16 11:35:12 +00:00
|
|
|
else {
|
|
|
|
mEvent = PR_NEWZAP(nsEvent);
|
|
|
|
mEvent->eventStructType = NS_EVENT;
|
|
|
|
}
|
|
|
|
}
|
1998-11-18 05:25:26 +00:00
|
|
|
mTarget = nsnull;
|
2000-05-16 11:35:12 +00:00
|
|
|
mCurrentTarget = nsnull;
|
2000-09-07 01:07:29 +00:00
|
|
|
mOriginalTarget = nsnull;
|
1999-03-19 23:36:20 +00:00
|
|
|
mText = nsnull;
|
1999-06-29 20:31:22 +00:00
|
|
|
mTextRange = nsnull;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
if (aEvent && aEvent->eventStructType == NS_TEXT_EVENT) {
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// extract the IME composition string
|
|
|
|
//
|
1999-03-19 23:36:20 +00:00
|
|
|
mText = new nsString(((nsTextEvent*)aEvent)->theText);
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// build the range list -- ranges need to be DOM-ified since the IME transaction
|
|
|
|
// will hold a ref, the widget representation isn't persistent
|
|
|
|
//
|
1999-08-06 02:32:13 +00:00
|
|
|
nsIPrivateTextRange** tempTextRangeList = new nsIPrivateTextRange*[((nsTextEvent*)aEvent)->rangeCount];
|
1999-07-14 21:10:55 +00:00
|
|
|
if (tempTextRangeList!=nsnull) {
|
|
|
|
for(PRUint16 i=0;i<((nsTextEvent*)aEvent)->rangeCount;i++) {
|
1999-08-06 02:32:13 +00:00
|
|
|
nsPrivateTextRange* tempPrivateTextRange = new nsPrivateTextRange((((nsTextEvent*)aEvent)->rangeArray[i]).mStartOffset,
|
1999-07-14 21:10:55 +00:00
|
|
|
(((nsTextEvent*)aEvent)->rangeArray[i]).mEndOffset,
|
|
|
|
(((nsTextEvent*)aEvent)->rangeArray[i]).mRangeType);
|
1999-08-06 02:32:13 +00:00
|
|
|
if (tempPrivateTextRange!=nsnull) {
|
|
|
|
tempPrivateTextRange->AddRef();
|
|
|
|
tempTextRangeList[i] = (nsIPrivateTextRange*)tempPrivateTextRange;
|
1999-07-14 21:10:55 +00:00
|
|
|
}
|
|
|
|
}
|
1999-06-29 20:31:22 +00:00
|
|
|
|
1999-07-14 21:10:55 +00:00
|
|
|
}
|
2001-03-12 22:26:58 +00:00
|
|
|
// We need to create mTextRange even rangeCount is 0.
|
|
|
|
// if rangeCount is 0, mac carbon will return 0 for new and tempTextRangeList will be null. but we should still
|
|
|
|
// create mTextRange, otherwise, we will crash it later when some code call GetInputRange and AddRef to the result
|
|
|
|
mTextRange = (nsIPrivateTextRangeList*) new nsPrivateTextRangeList(((nsTextEvent*)aEvent)->rangeCount,tempTextRangeList);
|
|
|
|
if (mTextRange!=nsnull)
|
|
|
|
mTextRange->AddRef();
|
1999-03-19 23:36:20 +00:00
|
|
|
}
|
|
|
|
|
1998-07-23 02:55:33 +00:00
|
|
|
NS_INIT_REFCNT();
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
2001-02-12 06:54:31 +00:00
|
|
|
nsDOMEvent::~nsDOMEvent()
|
|
|
|
{
|
|
|
|
NS_ASSERT_OWNINGTHREAD(nsDOMEvent);
|
|
|
|
|
|
|
|
nsCOMPtr<nsIPresShell> shell;
|
|
|
|
if (mPresContext)
|
|
|
|
{ // we were arena-allocated, prepare to recycle myself
|
|
|
|
mPresContext->GetShell(getter_AddRefs(shell));
|
|
|
|
}
|
2000-05-01 06:58:53 +00:00
|
|
|
NS_IF_RELEASE(mPresContext);
|
1998-11-18 05:25:26 +00:00
|
|
|
NS_IF_RELEASE(mTarget);
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_IF_RELEASE(mCurrentTarget);
|
2000-09-07 01:07:29 +00:00
|
|
|
NS_IF_RELEASE(mOriginalTarget);
|
1999-06-29 20:31:22 +00:00
|
|
|
NS_IF_RELEASE(mTextRange);
|
1999-03-19 23:36:20 +00:00
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
if (mEventIsInternal) {
|
|
|
|
PR_DELETE(mEvent);
|
|
|
|
}
|
|
|
|
|
1999-06-29 20:31:22 +00:00
|
|
|
if (mText!=nsnull)
|
|
|
|
delete mText;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMPL_ADDREF(nsDOMEvent)
|
|
|
|
NS_IMPL_RELEASE(nsDOMEvent)
|
|
|
|
|
1999-12-21 19:28:15 +00:00
|
|
|
NS_INTERFACE_MAP_BEGIN(nsDOMEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIDOMEvent, nsIDOMMouseEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIDOMUIEvent, nsIDOMMouseEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIDOMMouseEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIDOMKeyEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIDOMNSUIEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIPrivateDOMEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIPrivateTextEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY(nsIPrivateCompositionEvent)
|
|
|
|
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIDOMMouseEvent)
|
|
|
|
NS_INTERFACE_MAP_END
|
1998-06-07 07:55:55 +00:00
|
|
|
|
|
|
|
// nsIDOMEventInterface
|
2000-08-23 17:27:06 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetType(nsAWritableString& aType)
|
1998-07-17 04:52:12 +00:00
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
const char* mName = GetEventName(mEvent->message);
|
1998-07-17 04:52:12 +00:00
|
|
|
|
|
|
|
if (nsnull != mName) {
|
2000-08-23 17:27:06 +00:00
|
|
|
aType.Assign(NS_ConvertASCIItoUCS2(mName));
|
1998-07-17 04:52:12 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetTarget(nsIDOMEventTarget** aTarget)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1998-11-18 05:25:26 +00:00
|
|
|
if (nsnull != mTarget) {
|
|
|
|
*aTarget = mTarget;
|
|
|
|
NS_ADDREF(mTarget);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
1998-07-23 02:55:33 +00:00
|
|
|
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
*aTarget = nsnull;
|
|
|
|
|
2001-01-10 20:21:09 +00:00
|
|
|
nsCOMPtr<nsIEventStateManager> manager;
|
|
|
|
nsCOMPtr<nsIContent> targetContent;
|
1998-11-18 05:25:26 +00:00
|
|
|
|
2001-03-12 07:26:46 +00:00
|
|
|
if (mPresContext && NS_OK == mPresContext->GetEventStateManager(getter_AddRefs(manager)) && manager) {
|
2001-01-10 20:21:09 +00:00
|
|
|
manager->GetEventTargetContent(mEvent, getter_AddRefs(targetContent));
|
1998-07-23 02:55:33 +00:00
|
|
|
}
|
|
|
|
|
1999-07-27 20:55:03 +00:00
|
|
|
if (targetContent) {
|
2000-05-16 11:35:12 +00:00
|
|
|
if (NS_OK == targetContent->QueryInterface(NS_GET_IID(nsIDOMEventTarget), (void**)&mTarget)) {
|
1998-11-18 05:25:26 +00:00
|
|
|
*aTarget = mTarget;
|
|
|
|
NS_ADDREF(mTarget);
|
|
|
|
}
|
|
|
|
}
|
1999-07-27 20:55:03 +00:00
|
|
|
else {
|
|
|
|
//Always want a target. Use document if nothing else.
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
nsCOMPtr<nsIDocument> doc;
|
|
|
|
nsCOMPtr<nsIPresShell> presShell;
|
2001-03-12 07:26:46 +00:00
|
|
|
if (mPresContext && NS_SUCCEEDED(mPresContext->GetShell(getter_AddRefs(presShell))) && presShell) {
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
if (NS_SUCCEEDED(presShell->GetDocument(getter_AddRefs(doc))) && doc) {
|
|
|
|
if (NS_SUCCEEDED(doc->QueryInterface(NS_GET_IID(nsIDOMEventTarget), (void**)&mTarget))) {
|
|
|
|
*aTarget = mTarget;
|
|
|
|
NS_ADDREF(mTarget);
|
|
|
|
}
|
|
|
|
}
|
1999-07-27 20:55:03 +00:00
|
|
|
}
|
|
|
|
}
|
1998-11-18 05:25:26 +00:00
|
|
|
|
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_IMETHODIMP
|
2000-05-16 11:35:12 +00:00
|
|
|
nsDOMEvent::GetCurrentTarget(nsIDOMEventTarget** aCurrentTarget)
|
1998-07-17 04:52:12 +00:00
|
|
|
{
|
2000-05-17 00:40:22 +00:00
|
|
|
*aCurrentTarget = mCurrentTarget;
|
|
|
|
NS_IF_ADDREF(*aCurrentTarget);
|
1999-03-15 05:39:04 +00:00
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
2000-09-07 01:07:29 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetOriginalTarget(nsIDOMEventTarget** aOriginalTarget)
|
|
|
|
{
|
2000-09-07 09:20:56 +00:00
|
|
|
if (!mOriginalTarget)
|
|
|
|
return GetTarget(aOriginalTarget);
|
|
|
|
|
2000-09-07 01:07:29 +00:00
|
|
|
*aOriginalTarget = mOriginalTarget;
|
|
|
|
NS_IF_ADDREF(*aOriginalTarget);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-09-07 09:20:56 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::HasOriginalTarget(PRBool* aResult)
|
|
|
|
{
|
|
|
|
*aResult = (mOriginalTarget != nsnull);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetEventPhase(PRUint16* aEventPhase)
|
1998-07-17 04:52:12 +00:00
|
|
|
{
|
1999-07-19 19:54:34 +00:00
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_CAPTURE) {
|
1999-11-03 07:11:45 +00:00
|
|
|
*aEventPhase = nsIDOMMouseEvent::CAPTURING_PHASE;
|
1999-07-19 19:54:34 +00:00
|
|
|
}
|
|
|
|
else if (mEvent->flags & NS_EVENT_FLAG_BUBBLE) {
|
1999-11-03 07:11:45 +00:00
|
|
|
*aEventPhase = nsIDOMMouseEvent::BUBBLING_PHASE;
|
1999-07-19 19:54:34 +00:00
|
|
|
}
|
|
|
|
else if (mEvent->flags & NS_EVENT_FLAG_INIT) {
|
1999-11-03 07:11:45 +00:00
|
|
|
*aEventPhase = nsIDOMMouseEvent::AT_TARGET;
|
1999-07-19 19:54:34 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
*aEventPhase = 0;
|
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
1999-11-03 07:11:45 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetBubbles(PRBool* aBubbles)
|
|
|
|
{
|
2000-09-19 21:47:04 +00:00
|
|
|
*aBubbles = !(mEvent->flags & NS_EVENT_FLAG_CANT_BUBBLE);
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetCancelable(PRBool* aCancelable)
|
|
|
|
{
|
2000-09-19 21:47:04 +00:00
|
|
|
*aCancelable = !(mEvent->flags & NS_EVENT_FLAG_CANT_CANCEL);
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetTimeStamp(PRUint64* aTimeStamp)
|
|
|
|
{
|
2000-05-17 00:40:22 +00:00
|
|
|
LL_UI2L(*aTimeStamp, mEvent->time);
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::StopPropagation()
|
|
|
|
{
|
|
|
|
mEvent->flags |= NS_EVENT_FLAG_STOP_DISPATCH;
|
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::PreventBubble()
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-07-19 19:54:34 +00:00
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_BUBBLE || mEvent->flags & NS_EVENT_FLAG_INIT) {
|
|
|
|
mEvent->flags |= NS_EVENT_FLAG_STOP_DISPATCH;
|
|
|
|
}
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::PreventCapture()
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-07-19 19:54:34 +00:00
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_CAPTURE) {
|
|
|
|
mEvent->flags |= NS_EVENT_FLAG_STOP_DISPATCH;
|
|
|
|
}
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::PreventDefault()
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
if (!(mEvent->flags & NS_EVENT_FLAG_CANT_CANCEL)) {
|
|
|
|
mEvent->flags |= NS_EVENT_FLAG_NO_DEFAULT;
|
|
|
|
}
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
2000-06-20 00:45:47 +00:00
|
|
|
|
1999-11-03 07:11:45 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetView(nsIDOMAbstractView** aView)
|
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_ENSURE_ARG_POINTER(aView);
|
|
|
|
*aView = nsnull;
|
|
|
|
nsresult rv = NS_OK;
|
|
|
|
|
|
|
|
nsCOMPtr<nsISupports> container;
|
|
|
|
rv = mPresContext->GetContainer(getter_AddRefs(container));
|
|
|
|
NS_ENSURE_TRUE(NS_SUCCEEDED(rv) && container, rv);
|
|
|
|
|
|
|
|
nsCOMPtr<nsIInterfaceRequestor> ifrq(do_QueryInterface(container));
|
|
|
|
NS_ENSURE_TRUE(ifrq, NS_OK);
|
|
|
|
|
2000-09-01 01:54:35 +00:00
|
|
|
nsCOMPtr<nsIDOMWindowInternal> window;
|
|
|
|
ifrq->GetInterface(NS_GET_IID(nsIDOMWindowInternal), getter_AddRefs(window));
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_ENSURE_TRUE(window, NS_OK);
|
|
|
|
|
|
|
|
window->QueryInterface(NS_GET_IID(nsIDOMAbstractView), (void **)aView);
|
|
|
|
|
|
|
|
return rv;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetDetail(PRInt32* aDetail)
|
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
//detail is valid for more than just mouseevents but we don't
|
|
|
|
//use it for anything else right now
|
2000-06-23 05:15:04 +00:00
|
|
|
|
|
|
|
if (!mEvent) {
|
2000-05-16 11:35:12 +00:00
|
|
|
*aDetail = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-06-23 05:15:04 +00:00
|
|
|
switch(mEvent->eventStructType)
|
|
|
|
{
|
|
|
|
case NS_SCROLLPORT_EVENT:
|
|
|
|
{
|
|
|
|
nsScrollPortEvent* scrollEvent = (nsScrollPortEvent*)mEvent;
|
|
|
|
*aDetail = (PRInt32)scrollEvent->orient;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
case NS_MOUSE_EVENT:
|
|
|
|
{
|
|
|
|
switch (mEvent->message) {
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_LEFT_CLICK:
|
|
|
|
case NS_MOUSE_LEFT_DOUBLECLICK:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_MIDDLE_CLICK:
|
|
|
|
case NS_MOUSE_MIDDLE_DOUBLECLICK:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_RIGHT_CLICK:
|
|
|
|
case NS_MOUSE_RIGHT_DOUBLECLICK:
|
|
|
|
*aDetail = ((nsMouseEvent*)mEvent)->clickCount;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2000-06-23 22:59:18 +00:00
|
|
|
return NS_OK;
|
2000-06-23 05:15:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
|
|
|
*aDetail = 0;
|
|
|
|
return NS_OK;
|
2000-05-16 11:35:12 +00:00
|
|
|
}
|
2000-06-23 05:15:04 +00:00
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetText(nsString& aText)
|
1998-07-17 04:52:12 +00:00
|
|
|
{
|
1999-05-18 23:51:04 +00:00
|
|
|
if (mEvent->message == NS_TEXT_EVENT) {
|
|
|
|
aText = *mText;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
1999-08-06 02:32:13 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetInputRange(nsIPrivateTextRangeList** aInputRange)
|
1999-05-18 23:51:04 +00:00
|
|
|
{
|
|
|
|
if (mEvent->message == NS_TEXT_EVENT) {
|
1999-06-29 20:31:22 +00:00
|
|
|
*aInputRange = mTextRange;
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
1999-06-29 20:31:22 +00:00
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
1999-08-06 02:32:13 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetEventReply(nsTextEventReply** aReply)
|
1999-06-29 20:31:22 +00:00
|
|
|
{
|
1999-08-06 02:32:13 +00:00
|
|
|
if (mEvent->message==NS_TEXT_EVENT) {
|
|
|
|
*aReply = &(((nsTextEvent*)mEvent)->theReply);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
1999-08-31 01:20:32 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetCompositionReply(nsTextEventReply** aReply)
|
|
|
|
{
|
1999-12-07 01:29:00 +00:00
|
|
|
if((mEvent->message==NS_COMPOSITION_START) ||
|
|
|
|
(mEvent->message==NS_COMPOSITION_QUERY)) {
|
1999-08-31 01:20:32 +00:00
|
|
|
*aReply = &(((nsCompositionEvent*)mEvent)->theReply);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
NS_METHOD
|
|
|
|
nsDOMEvent::GetReconversionReply(nsReconversionEventReply** aReply)
|
|
|
|
{
|
|
|
|
*aReply = &(((nsReconversionEvent*)mEvent)->theReply);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetScreenX(PRInt32* aScreenX)
|
|
|
|
{
|
1999-11-02 01:38:01 +00:00
|
|
|
if (!mEvent ||
|
|
|
|
(mEvent->eventStructType != NS_MOUSE_EVENT && mEvent->eventStructType != NS_DRAGDROP_EVENT) ) {
|
1999-09-22 06:30:01 +00:00
|
|
|
*aScreenX = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!((nsGUIEvent*)mEvent)->widget )
|
1999-07-07 22:40:22 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
|
1999-06-09 07:38:26 +00:00
|
|
|
nsRect bounds, offset;
|
1999-07-07 22:40:22 +00:00
|
|
|
bounds.x = mEvent->refPoint.x;
|
|
|
|
|
|
|
|
((nsGUIEvent*)mEvent)->widget->WidgetToScreen ( bounds, offset );
|
|
|
|
*aScreenX = offset.x;
|
|
|
|
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetScreenY(PRInt32* aScreenY)
|
1998-07-17 04:52:12 +00:00
|
|
|
{
|
1999-11-02 01:38:01 +00:00
|
|
|
if (!mEvent ||
|
|
|
|
(mEvent->eventStructType != NS_MOUSE_EVENT && mEvent->eventStructType != NS_DRAGDROP_EVENT) ) {
|
1999-09-22 06:30:01 +00:00
|
|
|
*aScreenY = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!((nsGUIEvent*)mEvent)->widget )
|
1999-07-07 22:40:22 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
1999-06-09 07:38:26 +00:00
|
|
|
|
1999-07-07 22:40:22 +00:00
|
|
|
nsRect bounds, offset;
|
|
|
|
bounds.y = mEvent->refPoint.y;
|
|
|
|
|
|
|
|
((nsGUIEvent*)mEvent)->widget->WidgetToScreen ( bounds, offset );
|
|
|
|
*aScreenY = offset.y;
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetClientX(PRInt32* aClientX)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-11-02 01:38:01 +00:00
|
|
|
if (!mEvent ||
|
|
|
|
(mEvent->eventStructType != NS_MOUSE_EVENT && mEvent->eventStructType != NS_DRAGDROP_EVENT) ) {
|
1999-09-22 06:30:01 +00:00
|
|
|
*aClientX = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-06-16 04:39:51 +00:00
|
|
|
//My god, man, there *must* be a better way to do this.
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
nsCOMPtr<nsIPresShell> presShell;
|
1999-06-16 04:39:51 +00:00
|
|
|
nsIWidget* rootWidget = nsnull;
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
if (NS_SUCCEEDED(mPresContext->GetShell(getter_AddRefs(presShell))) && presShell) {
|
|
|
|
nsCOMPtr<nsIViewManager> vm;
|
|
|
|
if (NS_SUCCEEDED(presShell->GetViewManager(getter_AddRefs(vm))) && vm) {
|
2000-01-26 23:04:40 +00:00
|
|
|
vm->GetWidget(&rootWidget);
|
1999-06-16 04:39:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
nsRect bounds, offset;
|
|
|
|
offset.x = 0;
|
|
|
|
|
|
|
|
nsIWidget* parent = ((nsGUIEvent*)mEvent)->widget;
|
|
|
|
//Add extra ref since loop will free one.
|
|
|
|
NS_ADDREF(parent);
|
|
|
|
nsIWidget* tmp;
|
1999-09-10 00:57:01 +00:00
|
|
|
while (rootWidget != parent && nsnull != parent) {
|
1999-06-16 04:39:51 +00:00
|
|
|
parent->GetBounds(bounds);
|
|
|
|
offset.x += bounds.x;
|
|
|
|
tmp = parent;
|
|
|
|
parent = tmp->GetParent();
|
|
|
|
NS_RELEASE(tmp);
|
|
|
|
}
|
|
|
|
NS_IF_RELEASE(parent);
|
|
|
|
NS_IF_RELEASE(rootWidget);
|
|
|
|
|
|
|
|
*aClientX = mEvent->refPoint.x + offset.x;
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1999-05-18 23:51:04 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetClientY(PRInt32* aClientY)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-11-02 01:38:01 +00:00
|
|
|
if (!mEvent ||
|
|
|
|
(mEvent->eventStructType != NS_MOUSE_EVENT && mEvent->eventStructType != NS_DRAGDROP_EVENT) ) {
|
1999-09-22 06:30:01 +00:00
|
|
|
*aClientY = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-06-16 04:39:51 +00:00
|
|
|
//My god, man, there *must* be a better way to do this.
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
nsCOMPtr<nsIPresShell> presShell;
|
1999-06-16 04:39:51 +00:00
|
|
|
nsIWidget* rootWidget = nsnull;
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
if (NS_SUCCEEDED(mPresContext->GetShell(getter_AddRefs(presShell))) && presShell) {
|
|
|
|
nsCOMPtr<nsIViewManager> vm;
|
|
|
|
if (NS_SUCCEEDED(presShell->GetViewManager(getter_AddRefs(vm))) && vm) {
|
2000-01-26 23:04:40 +00:00
|
|
|
vm->GetWidget(&rootWidget);
|
1999-06-16 04:39:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
nsRect bounds, offset;
|
|
|
|
offset.y = 0;
|
|
|
|
|
|
|
|
nsIWidget* parent = ((nsGUIEvent*)mEvent)->widget;
|
|
|
|
//Add extra ref since loop will free one.
|
|
|
|
NS_ADDREF(parent);
|
|
|
|
nsIWidget* tmp;
|
1999-09-10 00:57:01 +00:00
|
|
|
while (rootWidget != parent && nsnull != parent) {
|
1999-06-16 04:39:51 +00:00
|
|
|
parent->GetBounds(bounds);
|
|
|
|
offset.y += bounds.y;
|
|
|
|
tmp = parent;
|
|
|
|
parent = tmp->GetParent();
|
|
|
|
NS_RELEASE(tmp);
|
|
|
|
}
|
|
|
|
NS_IF_RELEASE(parent);
|
|
|
|
NS_IF_RELEASE(rootWidget);
|
|
|
|
|
|
|
|
*aClientY = mEvent->refPoint.y + offset.y;
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::GetAltKey(PRBool* aIsDown)
|
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
*aIsDown = ((nsInputEvent*)mEvent)->isAlt;
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetCtrlKey(PRBool* aIsDown)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
*aIsDown = ((nsInputEvent*)mEvent)->isControl;
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetShiftKey(PRBool* aIsDown)
|
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
*aIsDown = ((nsInputEvent*)mEvent)->isShift;
|
1998-06-07 07:55:55 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetMetaKey(PRBool* aIsDown)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
*aIsDown = ((nsInputEvent*)mEvent)->isMeta;
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetCharCode(PRUint32* aCharCode)
|
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
if (!mEvent || mEvent->eventStructType != NS_KEY_EVENT) {
|
|
|
|
*aCharCode = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-03-11 00:07:59 +00:00
|
|
|
switch (mEvent->message) {
|
|
|
|
case NS_KEY_UP:
|
|
|
|
case NS_KEY_DOWN:
|
2000-02-15 05:06:45 +00:00
|
|
|
#if defined(NS_DEBUG) && defined(DEBUG_brade)
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("GetCharCode used for wrong key event; should use onkeypress.\n");
|
1999-08-27 14:16:44 +00:00
|
|
|
#endif
|
|
|
|
*aCharCode = 0;
|
|
|
|
break;
|
|
|
|
case NS_KEY_PRESS:
|
1999-03-11 00:07:59 +00:00
|
|
|
*aCharCode = ((nsKeyEvent*)mEvent)->charCode;
|
|
|
|
break;
|
|
|
|
default:
|
1999-05-18 23:51:04 +00:00
|
|
|
break;
|
1999-03-11 00:07:59 +00:00
|
|
|
}
|
|
|
|
return NS_OK;
|
1998-07-17 04:52:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::GetKeyCode(PRUint32* aKeyCode)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
if (!mEvent || mEvent->eventStructType != NS_KEY_EVENT) {
|
|
|
|
*aKeyCode = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-07-23 02:55:33 +00:00
|
|
|
switch (mEvent->message) {
|
1998-06-23 21:53:02 +00:00
|
|
|
case NS_KEY_UP:
|
1999-03-28 22:22:54 +00:00
|
|
|
case NS_KEY_PRESS:
|
1998-06-23 21:53:02 +00:00
|
|
|
case NS_KEY_DOWN:
|
1998-07-23 02:55:33 +00:00
|
|
|
*aKeyCode = ((nsKeyEvent*)mEvent)->keyCode;
|
1998-06-23 21:53:02 +00:00
|
|
|
break;
|
|
|
|
default:
|
1999-05-18 23:51:04 +00:00
|
|
|
break;
|
1998-06-23 21:53:02 +00:00
|
|
|
}
|
1998-06-07 07:55:55 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-07-19 19:54:34 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetButton(PRUint16* aButton)
|
1998-06-07 07:55:55 +00:00
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
if (!mEvent || mEvent->eventStructType != NS_MOUSE_EVENT) {
|
2001-03-02 03:07:53 +00:00
|
|
|
NS_WARNING("Tried to get mouse button for null or non-mouse event!");
|
|
|
|
*aButton = (PRUint16)-1;
|
1999-09-22 06:30:01 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-07-23 02:55:33 +00:00
|
|
|
switch (mEvent->message) {
|
1998-06-23 21:53:02 +00:00
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_MOUSE_LEFT_CLICK:
|
1998-06-23 21:53:02 +00:00
|
|
|
case NS_MOUSE_LEFT_DOUBLECLICK:
|
2001-03-02 03:07:53 +00:00
|
|
|
*aButton = 0;
|
1998-06-23 21:53:02 +00:00
|
|
|
break;
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_MOUSE_MIDDLE_CLICK:
|
|
|
|
case NS_MOUSE_MIDDLE_DOUBLECLICK:
|
2001-03-02 03:07:53 +00:00
|
|
|
*aButton = 1;
|
1998-06-23 21:53:02 +00:00
|
|
|
break;
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_MOUSE_RIGHT_CLICK:
|
1998-06-23 21:53:02 +00:00
|
|
|
case NS_MOUSE_RIGHT_DOUBLECLICK:
|
2001-03-02 03:07:53 +00:00
|
|
|
*aButton = 2;
|
1998-06-23 21:53:02 +00:00
|
|
|
break;
|
|
|
|
default:
|
1999-05-18 23:51:04 +00:00
|
|
|
break;
|
1998-06-23 21:53:02 +00:00
|
|
|
}
|
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetRelatedTarget(nsIDOMEventTarget** aRelatedTarget)
|
1999-11-03 07:11:45 +00:00
|
|
|
{
|
|
|
|
nsIEventStateManager *manager;
|
2000-01-13 14:53:51 +00:00
|
|
|
nsIContent *relatedContent = nsnull;
|
1999-11-03 07:11:45 +00:00
|
|
|
nsresult ret = NS_OK;
|
|
|
|
|
|
|
|
if (NS_OK == mPresContext->GetEventStateManager(&manager)) {
|
|
|
|
manager->GetEventRelatedContent(&relatedContent);
|
|
|
|
NS_RELEASE(manager);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (relatedContent) {
|
2000-05-16 11:35:12 +00:00
|
|
|
ret = relatedContent->QueryInterface(NS_GET_IID(nsIDOMEventTarget), (void**)aRelatedTarget);
|
1999-11-03 07:11:45 +00:00
|
|
|
NS_RELEASE(relatedContent);
|
|
|
|
}
|
|
|
|
else {
|
2000-05-16 11:35:12 +00:00
|
|
|
*aRelatedTarget = nsnull;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
1998-06-07 07:55:55 +00:00
|
|
|
// nsINSEventInterface
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetLayerX(PRInt32* aLayerX)
|
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
if (!mEvent || mEvent->eventStructType != NS_MOUSE_EVENT) {
|
|
|
|
*aLayerX = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-06-16 04:39:51 +00:00
|
|
|
float t2p;
|
|
|
|
mPresContext->GetTwipsToPixels(&t2p);
|
|
|
|
*aLayerX = NSTwipsToIntPixels(mEvent->point.x, t2p);
|
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetLayerY(PRInt32* aLayerY)
|
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
if (!mEvent || mEvent->eventStructType != NS_MOUSE_EVENT) {
|
|
|
|
*aLayerY = 0;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-06-16 04:39:51 +00:00
|
|
|
float t2p;
|
|
|
|
mPresContext->GetTwipsToPixels(&t2p);
|
|
|
|
*aLayerY = NSTwipsToIntPixels(mEvent->point.y, t2p);
|
|
|
|
return NS_OK;
|
1998-06-07 07:55:55 +00:00
|
|
|
}
|
|
|
|
|
2000-05-05 14:47:37 +00:00
|
|
|
nsresult nsDOMEvent::GetScrollInfo(nsIScrollableView** aScrollableView,
|
|
|
|
float* aP2T, float* aT2P)
|
|
|
|
{
|
|
|
|
mPresContext->GetPixelsToTwips(aP2T);
|
|
|
|
mPresContext->GetTwipsToPixels(aT2P);
|
|
|
|
|
|
|
|
nsCOMPtr<nsIPresShell> presShell;
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
if (NS_SUCCEEDED(mPresContext->GetShell(getter_AddRefs(presShell))) && presShell) {
|
2000-05-05 14:47:37 +00:00
|
|
|
nsCOMPtr<nsIViewManager> vm;
|
|
|
|
presShell->GetViewManager(getter_AddRefs(vm));
|
|
|
|
if(vm) {
|
|
|
|
return vm->GetRootScrollableView(aScrollableView);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-11-19 03:20:21 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetPageX(PRInt32* aPageX)
|
|
|
|
{
|
2000-05-05 14:47:37 +00:00
|
|
|
nsresult ret = NS_OK;
|
|
|
|
PRInt32 scrollX = 0;
|
|
|
|
nsCOMPtr<nsIScrollableView> view;
|
|
|
|
float p2t, t2p;
|
|
|
|
|
|
|
|
GetScrollInfo(getter_AddRefs(view), &p2t, &t2p);
|
|
|
|
if(view) {
|
|
|
|
nscoord xPos, yPos;
|
|
|
|
ret = view->GetScrollPosition(xPos, yPos);
|
|
|
|
scrollX = NSTwipsToIntPixels(xPos, t2p);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NS_SUCCEEDED(ret)) {
|
|
|
|
ret = GetClientX(aPageX);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NS_SUCCEEDED(ret)) {
|
|
|
|
*aPageX += scrollX;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
1998-11-19 03:20:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::GetPageY(PRInt32* aPageY)
|
|
|
|
{
|
2000-05-05 14:47:37 +00:00
|
|
|
nsresult ret = NS_OK;
|
|
|
|
PRInt32 scrollY = 0;
|
|
|
|
nsCOMPtr<nsIScrollableView> view;
|
|
|
|
float p2t, t2p;
|
|
|
|
|
|
|
|
GetScrollInfo(getter_AddRefs(view), &p2t, &t2p);
|
|
|
|
if(view) {
|
|
|
|
nscoord xPos, yPos;
|
|
|
|
ret = view->GetScrollPosition(xPos, yPos);
|
|
|
|
scrollY = NSTwipsToIntPixels(yPos, t2p);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NS_SUCCEEDED(ret)) {
|
|
|
|
ret = GetClientY(aPageY);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NS_SUCCEEDED(ret)) {
|
|
|
|
*aPageY += scrollY;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
1998-11-19 03:20:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::GetWhich(PRUint32* aWhich)
|
|
|
|
{
|
|
|
|
switch (mEvent->eventStructType) {
|
|
|
|
case NS_KEY_EVENT:
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
switch (mEvent->message) {
|
|
|
|
case NS_KEY_UP:
|
|
|
|
case NS_KEY_DOWN:
|
|
|
|
return GetKeyCode(aWhich);
|
|
|
|
case NS_KEY_PRESS:
|
2001-03-13 11:34:07 +00:00
|
|
|
//Special case for 4xp bug 62878. Try to make value of which
|
|
|
|
//more closely mirror the values that 4.x gave for RETURN and BACKSPACE
|
|
|
|
{
|
|
|
|
PRUint32 keyCode = ((nsKeyEvent*)mEvent)->keyCode;
|
|
|
|
if (keyCode == NS_VK_RETURN || keyCode == NS_VK_BACK) {
|
|
|
|
*aWhich = keyCode;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
return GetCharCode(aWhich);
|
|
|
|
}
|
massive landing of joki changes.
Relevant nsbeta3+ bugs 43309, 44503, 2634, 2504,5981, 24698, 25758, 33577,
36062, 36217, 41191, 41491, 42356, 42829, 43016
r=saari (joki code). also been tested by heikki and bryner
2000-08-08 21:31:05 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
1998-11-19 03:20:21 +00:00
|
|
|
case NS_MOUSE_EVENT:
|
1999-07-19 19:54:34 +00:00
|
|
|
{
|
1999-09-22 06:30:01 +00:00
|
|
|
PRUint16 button;
|
|
|
|
(void) GetButton(&button);
|
2001-03-02 03:07:53 +00:00
|
|
|
*aWhich = button + 1;
|
1999-09-22 06:30:01 +00:00
|
|
|
break;
|
1999-07-19 19:54:34 +00:00
|
|
|
}
|
1999-09-22 06:30:01 +00:00
|
|
|
default:
|
|
|
|
*aWhich = 0;
|
|
|
|
break;
|
1998-11-19 03:20:21 +00:00
|
|
|
}
|
1999-05-18 23:51:04 +00:00
|
|
|
return NS_OK;
|
1998-11-19 03:20:21 +00:00
|
|
|
}
|
|
|
|
|
1999-06-08 02:19:26 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetRangeParent(nsIDOMNode** aRangeParent)
|
|
|
|
{
|
|
|
|
nsIFrame* targetFrame;
|
|
|
|
nsIEventStateManager* manager;
|
|
|
|
|
|
|
|
if (NS_OK == mPresContext->GetEventStateManager(&manager)) {
|
|
|
|
manager->GetEventTarget(&targetFrame);
|
|
|
|
NS_RELEASE(manager);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (targetFrame) {
|
|
|
|
nsIContent* parent = nsnull;
|
|
|
|
PRInt32 offset, endOffset;
|
1999-10-13 01:16:09 +00:00
|
|
|
PRBool beginOfContent;
|
1999-11-24 06:03:41 +00:00
|
|
|
if (NS_SUCCEEDED(targetFrame->GetContentAndOffsetsFromPoint(mPresContext,
|
1999-10-13 01:16:09 +00:00
|
|
|
mEvent->point,
|
1999-06-08 02:19:26 +00:00
|
|
|
&parent,
|
|
|
|
offset,
|
1999-10-13 01:16:09 +00:00
|
|
|
endOffset,
|
|
|
|
beginOfContent))) {
|
1999-12-21 19:28:15 +00:00
|
|
|
if (parent && NS_SUCCEEDED(parent->QueryInterface(NS_GET_IID(nsIDOMNode), (void**)aRangeParent))) {
|
1999-06-08 02:19:26 +00:00
|
|
|
NS_RELEASE(parent);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
NS_IF_RELEASE(parent);
|
|
|
|
}
|
|
|
|
}
|
1999-09-22 06:30:01 +00:00
|
|
|
*aRangeParent = nsnull;
|
|
|
|
return NS_OK;
|
1999-06-08 02:19:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::GetRangeOffset(PRInt32* aRangeOffset)
|
|
|
|
{
|
|
|
|
nsIFrame* targetFrame;
|
|
|
|
nsIEventStateManager* manager;
|
|
|
|
|
|
|
|
if (NS_OK == mPresContext->GetEventStateManager(&manager)) {
|
|
|
|
manager->GetEventTarget(&targetFrame);
|
|
|
|
NS_RELEASE(manager);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (targetFrame) {
|
|
|
|
nsIContent* parent = nsnull;
|
1999-06-09 07:51:52 +00:00
|
|
|
PRInt32 endOffset;
|
1999-10-13 01:16:09 +00:00
|
|
|
PRBool beginOfContent;
|
1999-11-24 06:03:41 +00:00
|
|
|
if (NS_SUCCEEDED(targetFrame->GetContentAndOffsetsFromPoint(mPresContext,
|
1999-10-13 01:16:09 +00:00
|
|
|
mEvent->point,
|
1999-06-08 02:19:26 +00:00
|
|
|
&parent,
|
|
|
|
*aRangeOffset,
|
1999-10-13 01:16:09 +00:00
|
|
|
endOffset,
|
|
|
|
beginOfContent))) {
|
1999-06-08 02:19:26 +00:00
|
|
|
NS_IF_RELEASE(parent);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
}
|
1999-09-22 06:30:01 +00:00
|
|
|
*aRangeOffset = 0;
|
|
|
|
return NS_OK;
|
1999-06-08 02:19:26 +00:00
|
|
|
}
|
|
|
|
|
1999-09-21 14:18:52 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetCancelBubble(PRBool* aCancelBubble)
|
|
|
|
{
|
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_BUBBLE || mEvent->flags & NS_EVENT_FLAG_INIT) {
|
|
|
|
*aCancelBubble = (mEvent->flags &= NS_EVENT_FLAG_STOP_DISPATCH) ? PR_TRUE : PR_FALSE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
*aCancelBubble = PR_FALSE;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsDOMEvent::SetCancelBubble(PRBool aCancelBubble)
|
|
|
|
{
|
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_BUBBLE || mEvent->flags & NS_EVENT_FLAG_INIT) {
|
|
|
|
if (aCancelBubble) {
|
|
|
|
mEvent->flags |= NS_EVENT_FLAG_STOP_DISPATCH;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
mEvent->flags &= ~NS_EVENT_FLAG_STOP_DISPATCH;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-11-03 07:11:45 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetIsChar(PRBool* aIsChar)
|
|
|
|
{
|
|
|
|
if (!mEvent) {
|
|
|
|
*aIsChar = PR_FALSE;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
if (mEvent->eventStructType == NS_KEY_EVENT) {
|
|
|
|
*aIsChar = ((nsKeyEvent*)mEvent)->isChar;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
if (mEvent->eventStructType == NS_TEXT_EVENT) {
|
|
|
|
*aIsChar = ((nsTextEvent*)mEvent)->isChar;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
*aIsChar = PR_FALSE;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-02-08 02:05:57 +00:00
|
|
|
NS_METHOD nsDOMEvent::GetPreventDefault(PRBool* aReturn)
|
|
|
|
{
|
|
|
|
if (!mEvent) {
|
|
|
|
*aReturn = PR_FALSE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
*aReturn = (mEvent->flags & NS_EVENT_FLAG_NO_DEFAULT) ? PR_TRUE : PR_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
nsresult
|
2000-08-23 17:27:06 +00:00
|
|
|
nsDOMEvent::SetEventType(const nsAReadableString& aEventTypeArg)
|
2000-05-16 11:35:12 +00:00
|
|
|
{
|
|
|
|
nsAutoString str; str.AssignWithConversion("on");
|
|
|
|
nsIAtom* atom;
|
|
|
|
|
|
|
|
str.Append(aEventTypeArg);
|
|
|
|
atom = NS_NewAtom(str);
|
|
|
|
|
|
|
|
if (atom == nsLayoutAtoms::onmousedown && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_LEFT_BUTTON_DOWN;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onmouseup && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_LEFT_BUTTON_UP;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onclick && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_LEFT_CLICK;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onmouseover && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_ENTER_SYNTH;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onmouseout && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_EXIT_SYNTH;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onmousemove && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_MOUSE_MOVE;
|
|
|
|
}
|
2001-03-30 02:30:17 +00:00
|
|
|
else if (atom == nsLayoutAtoms::oncontextmenu && mEvent->eventStructType == NS_MOUSE_EVENT) {
|
|
|
|
mEvent->message = NS_CONTEXTMENU;
|
|
|
|
}
|
2000-05-16 11:35:12 +00:00
|
|
|
else if (atom == nsLayoutAtoms::onkeydown && mEvent->eventStructType == NS_KEY_EVENT) {
|
|
|
|
mEvent->message = NS_KEY_DOWN;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onkeyup && mEvent->eventStructType == NS_KEY_EVENT) {
|
|
|
|
mEvent->message = NS_KEY_UP;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onkeypress && mEvent->eventStructType == NS_KEY_EVENT) {
|
|
|
|
mEvent->message = NS_KEY_PRESS;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onfocus && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_FOCUS_CONTENT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onblur && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_BLUR_CONTENT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onsubmit && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_FORM_SUBMIT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onreset && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_FORM_RESET;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onchange && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_FORM_CHANGE;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onselect && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_FORM_SELECTED;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onload && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_PAGE_LOAD;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onunload && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_PAGE_UNLOAD;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onabort && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_IMAGE_ABORT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onerror && mEvent->eventStructType == NS_EVENT) {
|
|
|
|
mEvent->message = NS_IMAGE_ERROR;
|
|
|
|
}
|
2001-03-30 02:30:17 +00:00
|
|
|
else if (atom == nsLayoutAtoms::onDOMAttrModified && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_ATTRMODIFIED;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMCharacterDataModified && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_CHARACTERDATAMODIFIED;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMNodeInserted && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_NODEINSERTED;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMNodeRemoved && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_NODEREMOVED;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMNodeInsertedIntoDocument && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_NODEINSERTEDINTODOCUMENT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMNodeRemovedFromDocument && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_NODEREMOVEDFROMDOCUMENT;
|
|
|
|
}
|
|
|
|
else if (atom == nsLayoutAtoms::onDOMSubtreeModified && mEvent->eventStructType == NS_MUTATION_EVENT) {
|
|
|
|
mEvent->message = NS_MUTATION_SUBTREEMODIFIED;
|
|
|
|
}
|
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
else {
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-11-03 07:11:45 +00:00
|
|
|
NS_IMETHODIMP
|
2000-08-23 17:27:06 +00:00
|
|
|
nsDOMEvent::InitEvent(const nsAReadableString& aEventTypeArg, PRBool aCanBubbleArg, PRBool aCancelableArg)
|
1999-11-03 07:11:45 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_ENSURE_SUCCESS(SetEventType(aEventTypeArg), NS_ERROR_FAILURE);
|
|
|
|
mEvent->flags |= aCanBubbleArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_BUBBLE;
|
|
|
|
mEvent->flags |= aCancelableArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_CANCEL;
|
2000-06-20 00:45:47 +00:00
|
|
|
mEvent->internalAppFlags |= NS_APP_EVENT_FLAG_NONE;
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2000-08-23 17:27:06 +00:00
|
|
|
nsDOMEvent::InitUIEvent(const nsAReadableString& aTypeArg, PRBool aCanBubbleArg, PRBool aCancelableArg, nsIDOMAbstractView* aViewArg, PRInt32 aDetailArg)
|
1999-11-03 07:11:45 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2000-08-23 17:27:06 +00:00
|
|
|
nsDOMEvent::InitMouseEvent(const nsAReadableString& aTypeArg, PRBool aCtrlKeyArg, PRBool aAltKeyArg, PRBool aShiftKeyArg, PRBool aMetaKeyArg, PRInt32 aScreenXArg, PRInt32 aScreenYArg, PRInt32 aClientXArg, PRInt32 aClientYArg, PRUint16 aButtonArg, PRUint16 aDetailArg)
|
1999-11-03 07:11:45 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_ENSURE_SUCCESS(SetEventType(aTypeArg), NS_ERROR_FAILURE);
|
|
|
|
//mEvent->flags |= aCanBubbleArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_BUBBLE;
|
|
|
|
//mEvent->flags |= aCancelableArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_CANCEL;
|
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2000-08-23 17:27:06 +00:00
|
|
|
nsDOMEvent::InitKeyEvent(const nsAReadableString& aTypeArg, PRBool aCanBubbleArg, PRBool aCancelableArg, PRBool aCtrlKeyArg, PRBool aAltKeyArg, PRBool aShiftKeyArg, PRBool aMetaKeyArg, PRUint32 aKeyCodeArg, PRUint32 aCharCodeArg, nsIDOMAbstractView* aViewArg)
|
1999-11-03 07:11:45 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_ENSURE_SUCCESS(SetEventType(aTypeArg), NS_ERROR_FAILURE);
|
|
|
|
mEvent->flags |= aCanBubbleArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_BUBBLE;
|
|
|
|
mEvent->flags |= aCancelableArg ? NS_EVENT_FLAG_NONE : NS_EVENT_FLAG_CANT_CANCEL;
|
2000-06-20 00:45:47 +00:00
|
|
|
mEvent->internalAppFlags |= NS_APP_EVENT_FLAG_NONE;
|
2000-05-16 11:35:12 +00:00
|
|
|
return NS_OK;
|
1999-11-03 07:11:45 +00:00
|
|
|
}
|
|
|
|
|
1998-07-23 02:55:33 +00:00
|
|
|
NS_METHOD nsDOMEvent::DuplicatePrivateData()
|
1998-06-23 21:53:02 +00:00
|
|
|
{
|
1998-07-23 02:55:33 +00:00
|
|
|
//XXX Write me!
|
1998-11-18 05:25:26 +00:00
|
|
|
|
|
|
|
//XXX And when you do, make sure to copy over the event target here, too!
|
1998-06-23 21:53:02 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
1998-07-17 04:52:12 +00:00
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::SetTarget(nsIDOMEventTarget* aTarget)
|
1999-05-21 19:27:02 +00:00
|
|
|
{
|
|
|
|
if (mTarget != aTarget) {
|
|
|
|
NS_IF_RELEASE(mTarget);
|
|
|
|
NS_IF_ADDREF(aTarget);
|
|
|
|
mTarget = aTarget;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
NS_METHOD nsDOMEvent::SetCurrentTarget(nsIDOMEventTarget* aCurrentTarget)
|
|
|
|
{
|
|
|
|
if (mCurrentTarget != aCurrentTarget) {
|
|
|
|
NS_IF_RELEASE(mCurrentTarget);
|
|
|
|
NS_IF_ADDREF(aCurrentTarget);
|
|
|
|
mCurrentTarget = aCurrentTarget;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-09-07 01:07:29 +00:00
|
|
|
NS_METHOD nsDOMEvent::SetOriginalTarget(nsIDOMEventTarget* aOriginalTarget)
|
|
|
|
{
|
|
|
|
if (mOriginalTarget != aOriginalTarget) {
|
|
|
|
NS_IF_RELEASE(mOriginalTarget);
|
|
|
|
NS_IF_ADDREF(aOriginalTarget);
|
|
|
|
mOriginalTarget = aOriginalTarget;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-12-15 22:04:43 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::IsDispatchStopped(PRBool* aIsDispatchStopped)
|
|
|
|
{
|
|
|
|
if (mEvent->flags & NS_EVENT_FLAG_STOP_DISPATCH) {
|
|
|
|
*aIsDispatchStopped = PR_TRUE;
|
|
|
|
} else {
|
|
|
|
*aIsDispatchStopped = PR_FALSE;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-06-20 00:45:47 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::IsHandled(PRBool* aIsHandled)
|
|
|
|
{
|
|
|
|
if (mEvent->internalAppFlags | NS_APP_EVENT_FLAG_HANDLED) {
|
|
|
|
*aIsHandled = PR_TRUE;
|
|
|
|
} else {
|
|
|
|
*aIsHandled = PR_FALSE;
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::SetHandled(PRBool aHandled)
|
|
|
|
{
|
|
|
|
if(aHandled)
|
|
|
|
mEvent->internalAppFlags |= NS_APP_EVENT_FLAG_HANDLED;
|
|
|
|
else
|
|
|
|
mEvent->internalAppFlags &= ~NS_APP_EVENT_FLAG_HANDLED;
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-05-17 05:27:22 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsDOMEvent::GetInternalNSEvent(nsEvent** aNSEvent)
|
|
|
|
{
|
|
|
|
*aNSEvent = mEvent;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-07-17 04:52:12 +00:00
|
|
|
const char* nsDOMEvent::GetEventName(PRUint32 aEventType)
|
|
|
|
{
|
|
|
|
switch(aEventType) {
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_mousedown];
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_mouseup];
|
1998-07-24 05:06:44 +00:00
|
|
|
case NS_MOUSE_LEFT_CLICK:
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_MOUSE_MIDDLE_CLICK:
|
1998-07-24 05:06:44 +00:00
|
|
|
case NS_MOUSE_RIGHT_CLICK:
|
|
|
|
return mEventNames[eDOMEvents_click];
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_MOUSE_LEFT_DOUBLECLICK:
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_MOUSE_MIDDLE_DOUBLECLICK:
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_MOUSE_RIGHT_DOUBLECLICK:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_dblclick];
|
2000-04-24 04:41:27 +00:00
|
|
|
case NS_MOUSE_ENTER_SYNTH:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_mouseover];
|
2000-04-24 04:41:27 +00:00
|
|
|
case NS_MOUSE_EXIT_SYNTH:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_mouseout];
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_MOUSE_MOVE:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_mousemove];
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_KEY_UP:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_keyup];
|
1998-07-17 04:52:12 +00:00
|
|
|
case NS_KEY_DOWN:
|
1998-07-23 02:55:33 +00:00
|
|
|
return mEventNames[eDOMEvents_keydown];
|
1998-11-24 07:46:58 +00:00
|
|
|
case NS_KEY_PRESS:
|
|
|
|
return mEventNames[eDOMEvents_keypress];
|
1999-03-28 22:22:54 +00:00
|
|
|
case NS_FOCUS_CONTENT:
|
1998-07-24 05:06:44 +00:00
|
|
|
return mEventNames[eDOMEvents_focus];
|
1999-03-28 22:22:54 +00:00
|
|
|
case NS_BLUR_CONTENT:
|
1998-07-24 05:06:44 +00:00
|
|
|
return mEventNames[eDOMEvents_blur];
|
1999-12-01 22:35:33 +00:00
|
|
|
case NS_XUL_CLOSE:
|
|
|
|
return mEventNames[eDOMEvents_close];
|
1998-07-24 05:06:44 +00:00
|
|
|
case NS_PAGE_LOAD:
|
|
|
|
case NS_IMAGE_LOAD:
|
|
|
|
return mEventNames[eDOMEvents_load];
|
|
|
|
case NS_PAGE_UNLOAD:
|
|
|
|
return mEventNames[eDOMEvents_unload];
|
|
|
|
case NS_IMAGE_ABORT:
|
|
|
|
return mEventNames[eDOMEvents_abort];
|
|
|
|
case NS_IMAGE_ERROR:
|
2000-04-24 04:41:27 +00:00
|
|
|
case NS_SCRIPT_ERROR:
|
1998-07-24 05:06:44 +00:00
|
|
|
return mEventNames[eDOMEvents_error];
|
1998-07-31 22:09:51 +00:00
|
|
|
case NS_FORM_SUBMIT:
|
|
|
|
return mEventNames[eDOMEvents_submit];
|
|
|
|
case NS_FORM_RESET:
|
|
|
|
return mEventNames[eDOMEvents_reset];
|
1998-11-02 23:05:46 +00:00
|
|
|
case NS_FORM_CHANGE:
|
|
|
|
return mEventNames[eDOMEvents_change];
|
1999-08-07 23:18:35 +00:00
|
|
|
case NS_FORM_SELECTED:
|
|
|
|
return mEventNames[eDOMEvents_select];
|
1999-09-21 23:02:35 +00:00
|
|
|
case NS_FORM_INPUT:
|
|
|
|
return mEventNames[eDOMEvents_input];
|
1998-10-06 21:01:59 +00:00
|
|
|
case NS_PAINT:
|
|
|
|
return mEventNames[eDOMEvents_paint];
|
2000-05-17 05:27:22 +00:00
|
|
|
case NS_RESIZE_EVENT:
|
|
|
|
return mEventNames[eDOMEvents_resize];
|
2000-05-17 06:53:58 +00:00
|
|
|
case NS_SCROLL_EVENT:
|
|
|
|
return mEventNames[eDOMEvents_scroll];
|
1999-03-19 23:36:20 +00:00
|
|
|
case NS_TEXT_EVENT:
|
1999-05-18 23:51:04 +00:00
|
|
|
return mEventNames[eDOMEvents_text];
|
1999-07-26 09:18:31 +00:00
|
|
|
case NS_MENU_CREATE:
|
|
|
|
return mEventNames[eDOMEvents_create];
|
|
|
|
case NS_MENU_DESTROY:
|
|
|
|
return mEventNames[eDOMEvents_destroy];
|
|
|
|
case NS_MENU_ACTION:
|
1999-09-21 23:02:35 +00:00
|
|
|
return mEventNames[eDOMEvents_command];
|
|
|
|
case NS_XUL_BROADCAST:
|
|
|
|
return mEventNames[eDOMEvents_broadcast];
|
|
|
|
case NS_XUL_COMMAND_UPDATE:
|
|
|
|
return mEventNames[eDOMEvents_commandupdate];
|
1999-09-02 03:51:03 +00:00
|
|
|
case NS_DRAGDROP_ENTER:
|
|
|
|
return mEventNames[eDOMEvents_dragenter];
|
2000-04-24 04:41:27 +00:00
|
|
|
case NS_DRAGDROP_OVER_SYNTH:
|
1999-09-02 03:51:03 +00:00
|
|
|
return mEventNames[eDOMEvents_dragover];
|
2000-04-24 04:41:27 +00:00
|
|
|
case NS_DRAGDROP_EXIT_SYNTH:
|
1999-09-02 03:51:03 +00:00
|
|
|
return mEventNames[eDOMEvents_dragexit];
|
|
|
|
case NS_DRAGDROP_DROP:
|
|
|
|
return mEventNames[eDOMEvents_dragdrop];
|
|
|
|
case NS_DRAGDROP_GESTURE:
|
|
|
|
return mEventNames[eDOMEvents_draggesture];
|
2000-06-23 05:15:04 +00:00
|
|
|
case NS_SCROLLPORT_OVERFLOW:
|
|
|
|
return mEventNames[eDOMEvents_overflow];
|
|
|
|
case NS_SCROLLPORT_UNDERFLOW:
|
|
|
|
return mEventNames[eDOMEvents_underflow];
|
2000-06-28 00:00:18 +00:00
|
|
|
case NS_SCROLLPORT_OVERFLOWCHANGED:
|
|
|
|
return mEventNames[eDOMEvents_overflowchanged];
|
2000-11-27 07:55:20 +00:00
|
|
|
case NS_MUTATION_SUBTREEMODIFIED:
|
|
|
|
return mEventNames[eDOMEvents_subtreemodified];
|
|
|
|
case NS_MUTATION_NODEINSERTED:
|
|
|
|
return mEventNames[eDOMEvents_nodeinserted];
|
|
|
|
case NS_MUTATION_NODEREMOVED:
|
|
|
|
return mEventNames[eDOMEvents_noderemoved];
|
|
|
|
case NS_MUTATION_NODEREMOVEDFROMDOCUMENT:
|
|
|
|
return mEventNames[eDOMEvents_noderemovedfromdocument];
|
|
|
|
case NS_MUTATION_NODEINSERTEDINTODOCUMENT:
|
|
|
|
return mEventNames[eDOMEvents_nodeinsertedintodocument];
|
|
|
|
case NS_MUTATION_ATTRMODIFIED:
|
|
|
|
return mEventNames[eDOMEvents_attrmodified];
|
|
|
|
case NS_MUTATION_CHARACTERDATAMODIFIED:
|
|
|
|
return mEventNames[eDOMEvents_characterdatamodified];
|
2001-03-30 02:30:17 +00:00
|
|
|
case NS_CONTEXTMENU:
|
|
|
|
return mEventNames[eDOMEvents_contextmenu];
|
1998-07-17 04:52:12 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return nsnull;
|
|
|
|
}
|
1998-07-23 02:55:33 +00:00
|
|
|
|
2000-05-16 11:35:12 +00:00
|
|
|
nsresult NS_NewDOMUIEvent(nsIDOMEvent** aInstancePtrResult,
|
|
|
|
nsIPresContext* aPresContext,
|
2000-08-23 17:27:06 +00:00
|
|
|
const nsAReadableString& aEventType,
|
2000-05-16 11:35:12 +00:00
|
|
|
nsEvent *aEvent)
|
1998-07-23 02:55:33 +00:00
|
|
|
{
|
2000-05-16 11:35:12 +00:00
|
|
|
nsDOMEvent* it = new nsDOMEvent(aPresContext, aEvent, aEventType);
|
2001-02-12 06:54:31 +00:00
|
|
|
|
1998-07-23 02:55:33 +00:00
|
|
|
if (nsnull == it) {
|
|
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
|
|
}
|
|
|
|
|
1999-12-21 19:28:15 +00:00
|
|
|
return it->QueryInterface(NS_GET_IID(nsIDOMEvent), (void **) aInstancePtrResult);
|
1998-07-23 02:55:33 +00:00
|
|
|
}
|
1999-05-18 23:51:04 +00:00
|
|
|
|
1999-11-24 06:03:41 +00:00
|
|
|
nsresult NS_NewDOMEvent(nsIDOMEvent** aInstancePtrResult, nsIPresContext* aPresContext, nsEvent *aEvent)
|
1999-05-18 23:51:04 +00:00
|
|
|
{
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|