2007-03-22 10:30:00 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla 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/MPL/
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2003
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Original Author: Aaron Leventhal (aaronl@netscape.com)
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#ifndef _nsDocAccessible_H_
|
|
|
|
#define _nsDocAccessible_H_
|
|
|
|
|
2007-05-01 10:08:26 -07:00
|
|
|
#include "nsHyperTextAccessibleWrap.h"
|
2007-03-22 10:30:00 -07:00
|
|
|
#include "nsIAccessibleDocument.h"
|
|
|
|
#include "nsIDocument.h"
|
|
|
|
#include "nsIDocumentObserver.h"
|
|
|
|
#include "nsIEditor.h"
|
|
|
|
#include "nsIObserver.h"
|
|
|
|
#include "nsIScrollPositionListener.h"
|
|
|
|
#include "nsITimer.h"
|
|
|
|
#include "nsIWeakReference.h"
|
|
|
|
#include "nsCOMArray.h"
|
|
|
|
#include "nsIDocShellTreeNode.h"
|
|
|
|
|
|
|
|
class nsIScrollableView;
|
|
|
|
|
|
|
|
const PRUint32 kDefaultCacheSize = 256;
|
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
#define NS_DOCACCESSIBLE_IMPL_CID \
|
2009-08-19 23:45:19 -07:00
|
|
|
{ /* 9735bc5f-a4b6-4668-ab73-6f8434c8e750 */ \
|
|
|
|
0x9735bc5f, \
|
|
|
|
0xa4b6, \
|
|
|
|
0x4668, \
|
|
|
|
{ 0xab, 0x73, 0x6f, 0x84, 0x34, 0xc8, 0xe7, 0x50 } \
|
2009-06-24 19:08:53 -07:00
|
|
|
}
|
|
|
|
|
2007-05-01 10:08:26 -07:00
|
|
|
class nsDocAccessible : public nsHyperTextAccessibleWrap,
|
2007-03-22 10:30:00 -07:00
|
|
|
public nsIAccessibleDocument,
|
|
|
|
public nsIDocumentObserver,
|
|
|
|
public nsIObserver,
|
|
|
|
public nsIScrollPositionListener,
|
|
|
|
public nsSupportsWeakReference
|
|
|
|
{
|
|
|
|
NS_DECL_ISUPPORTS_INHERITED
|
2008-08-06 05:19:56 -07:00
|
|
|
NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(nsDocAccessible, nsAccessible)
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
NS_DECL_NSIACCESSIBLEDOCUMENT
|
2009-06-24 19:08:53 -07:00
|
|
|
NS_DECLARE_STATIC_IID_ACCESSOR(NS_DOCACCESSIBLE_IMPL_CID)
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
NS_DECL_NSIOBSERVER
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
public:
|
|
|
|
nsDocAccessible(nsIDOMNode *aNode, nsIWeakReference* aShell);
|
|
|
|
virtual ~nsDocAccessible();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsIAccessible
|
|
|
|
NS_IMETHOD GetName(nsAString& aName);
|
|
|
|
NS_IMETHOD GetDescription(nsAString& aDescription);
|
|
|
|
NS_IMETHOD GetAttributes(nsIPersistentProperties **aAttributes);
|
|
|
|
NS_IMETHOD GetFocusedChild(nsIAccessible **aFocusedChild);
|
|
|
|
NS_IMETHOD GetParent(nsIAccessible **aParent);
|
|
|
|
NS_IMETHOD TakeFocus(void);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsIScrollPositionListener
|
|
|
|
NS_IMETHOD ScrollPositionWillChange(nsIScrollableView *aView,
|
|
|
|
nscoord aX, nscoord aY);
|
2009-07-21 17:45:13 -07:00
|
|
|
virtual void ViewPositionDidChange(nsIScrollableView* aScrollable,
|
|
|
|
nsTArray<nsIWidget::Configuration>* aConfigurations) {}
|
2009-06-24 19:08:53 -07:00
|
|
|
NS_IMETHOD ScrollPositionDidChange(nsIScrollableView *aView,
|
|
|
|
nscoord aX, nscoord aY);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsIDocumentObserver
|
|
|
|
NS_DECL_NSIDOCUMENTOBSERVER
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsAccessNode
|
|
|
|
virtual nsresult Init();
|
|
|
|
virtual nsresult Shutdown();
|
|
|
|
virtual nsIFrame* GetFrame();
|
|
|
|
virtual PRBool IsDefunct();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsAccessible
|
2009-03-07 07:38:58 -08:00
|
|
|
virtual nsresult GetRoleInternal(PRUint32 *aRole);
|
2008-11-03 19:37:46 -08:00
|
|
|
virtual nsresult GetStateInternal(PRUint32 *aState, PRUint32 *aExtraState);
|
2009-06-24 19:12:38 -07:00
|
|
|
virtual nsresult GetARIAState(PRUint32 *aState, PRUint32 *aExtraState);
|
2009-06-18 00:37:38 -07:00
|
|
|
virtual void SetRoleMapEntry(nsRoleMapEntry* aRoleMapEntry);
|
2008-11-03 19:37:46 -08:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsIAccessibleText
|
|
|
|
NS_IMETHOD GetAssociatedEditor(nsIEditor **aEditor);
|
2007-08-14 09:25:24 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
// nsDocAccessible
|
2007-04-16 21:45:42 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
/**
|
|
|
|
* Non-virtual method to fire a delayed event after a 0 length timeout.
|
|
|
|
*
|
2009-09-02 19:01:18 -07:00
|
|
|
* @param aEventType [in] the nsIAccessibleEvent event type
|
2009-06-24 19:08:53 -07:00
|
|
|
* @param aDOMNode [in] DOM node the accesible event should be fired for
|
|
|
|
* @param aAllowDupes [in] rule to process an event (see EEventRule constants)
|
|
|
|
* @param aIsAsynch [in] set to PR_TRUE if this is not being called from
|
|
|
|
* code synchronous with a DOM event
|
|
|
|
*/
|
2009-09-02 19:01:18 -07:00
|
|
|
nsresult FireDelayedAccessibleEvent(PRUint32 aEventType, nsIDOMNode *aDOMNode,
|
|
|
|
nsAccEvent::EEventRule aAllowDupes = nsAccEvent::eRemoveDupes,
|
|
|
|
PRBool aIsAsynch = PR_FALSE);
|
2009-06-24 19:08:53 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fire accessible event after timeout.
|
|
|
|
*
|
|
|
|
* @param aEvent [in] the event to fire
|
|
|
|
*/
|
|
|
|
nsresult FireDelayedAccessibleEvent(nsIAccessibleEvent *aEvent);
|
2007-04-16 21:45:42 -07:00
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
/**
|
|
|
|
* Find the accessible object in the accessibility cache that corresponds to
|
|
|
|
* the given node or the first ancestor of it that has an accessible object
|
|
|
|
* associated with it. Clear that accessible object's parent's cache of
|
|
|
|
* accessible children and remove the accessible object and any descendants
|
|
|
|
* from the accessible cache. Fires proper events. New accessible objects will
|
|
|
|
* be created and cached again on demand.
|
|
|
|
*
|
|
|
|
* @param aContent [in] the child that is changing
|
|
|
|
* @param aEvent [in] the event from nsIAccessibleEvent that caused
|
|
|
|
* the change.
|
|
|
|
*/
|
|
|
|
void InvalidateCacheSubtree(nsIContent *aContent, PRUint32 aEvent);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Cache access node.
|
|
|
|
*
|
|
|
|
* @param aUniquID [in] the unique identifier of accessible
|
|
|
|
* @param aAccessNode [in] accessible to cache
|
|
|
|
*/
|
|
|
|
void CacheAccessNode(void *aUniqueID, nsIAccessNode *aAccessNode);
|
|
|
|
|
2009-08-19 23:45:19 -07:00
|
|
|
/**
|
|
|
|
* Remove the given access node from document cache.
|
|
|
|
*/
|
|
|
|
void RemoveAccessNodeFromCache(nsIAccessNode *aAccessNode);
|
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
/**
|
|
|
|
* Fires pending events.
|
|
|
|
*/
|
|
|
|
void FlushPendingEvents();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fire document load events.
|
|
|
|
*
|
|
|
|
* @param aEventType [in] nsIAccessibleEvent constant
|
|
|
|
*/
|
|
|
|
virtual void FireDocLoadEvents(PRUint32 aEventType);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Process the case when anchor was clicked.
|
|
|
|
*/
|
|
|
|
virtual void FireAnchorJumpEvent();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to flush pending events, called after timeout. See FlushPendingEvents.
|
|
|
|
*/
|
|
|
|
static void FlushEventsCallback(nsITimer *aTimer, void *aClosure);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/**
|
|
|
|
* Iterates through sub documents and shut them down.
|
|
|
|
*/
|
|
|
|
void ShutdownChildDocuments(nsIDocShellTreeItem *aStart);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
virtual void GetBoundsRect(nsRect& aRect, nsIFrame** aRelativeFrame);
|
|
|
|
virtual nsresult AddEventListeners();
|
|
|
|
virtual nsresult RemoveEventListeners();
|
|
|
|
void AddScrollListener();
|
|
|
|
void RemoveScrollListener();
|
2008-02-02 09:02:09 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* For any accessibles in this subtree, invalidate their knowledge of
|
|
|
|
* their children. Only weak refrences are destroyed, not accessibles.
|
|
|
|
* @param aStartNode The root of the subrtee to invalidate accessible child refs in
|
|
|
|
*/
|
|
|
|
void InvalidateChildrenInSubtree(nsIDOMNode *aStartNode);
|
2007-08-10 18:44:44 -07:00
|
|
|
void RefreshNodes(nsIDOMNode *aStartNode);
|
2007-03-22 10:30:00 -07:00
|
|
|
static void ScrollTimerCallback(nsITimer *aTimer, void *aClosure);
|
|
|
|
|
2007-04-16 21:45:42 -07:00
|
|
|
/**
|
2007-09-18 14:36:41 -07:00
|
|
|
* Fires accessible events when attribute is changed.
|
|
|
|
*
|
|
|
|
* @param aContent - node that attribute is changed for
|
|
|
|
* @param aNameSpaceID - namespace of changed attribute
|
|
|
|
* @param aAttribute - changed attribute
|
|
|
|
*/
|
|
|
|
void AttributeChangedImpl(nsIContent* aContent, PRInt32 aNameSpaceID, nsIAtom* aAttribute);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fires accessible events when ARIA attribute is changed.
|
2007-04-16 21:45:42 -07:00
|
|
|
*
|
|
|
|
* @param aContent - node that attribute is changed for
|
|
|
|
* @param aAttribute - changed attribute
|
|
|
|
*/
|
|
|
|
void ARIAAttributeChanged(nsIContent* aContent, nsIAtom* aAttribute);
|
|
|
|
|
2007-07-25 04:54:15 -07:00
|
|
|
/**
|
2007-09-05 01:22:17 -07:00
|
|
|
* Fire text changed event for character data changed. The method is used
|
|
|
|
* from nsIMutationObserver methods.
|
|
|
|
*
|
|
|
|
* @param aContent the text node holding changed data
|
|
|
|
* @param aInfo info structure describing how the data was changed
|
|
|
|
* @param aIsInserted the flag pointed whether removed or inserted
|
|
|
|
* characters should be cause of event
|
2007-07-25 04:54:15 -07:00
|
|
|
*/
|
2007-09-05 01:22:17 -07:00
|
|
|
void FireTextChangeEventForText(nsIContent *aContent,
|
|
|
|
CharacterDataChangeInfo* aInfo,
|
|
|
|
PRBool aIsInserted);
|
2007-07-25 04:54:15 -07:00
|
|
|
|
|
|
|
/**
|
2007-08-28 14:57:53 -07:00
|
|
|
* Create a text change event for a changed node
|
|
|
|
* @param aContainerAccessible, the first accessible in the container
|
|
|
|
* @param aChangeNode, the node that is being inserted or removed, or shown/hidden
|
|
|
|
* @param aAccessibleForChangeNode, the accessible for that node, or nsnull if none exists
|
|
|
|
* @param aIsInserting, is aChangeNode being created or shown (vs. removed or hidden)
|
2007-07-25 04:54:15 -07:00
|
|
|
*/
|
2007-08-28 14:57:53 -07:00
|
|
|
already_AddRefed<nsIAccessibleTextChangeEvent>
|
2007-08-28 15:12:59 -07:00
|
|
|
CreateTextChangeEventForNode(nsIAccessible *aContainerAccessible,
|
|
|
|
nsIDOMNode *aChangeNode,
|
|
|
|
nsIAccessible *aAccessibleForNode,
|
|
|
|
PRBool aIsInserting,
|
|
|
|
PRBool aIsAsynch);
|
2007-07-25 04:54:15 -07:00
|
|
|
|
2007-10-06 09:24:57 -07:00
|
|
|
/**
|
|
|
|
* Fire show/hide events for either the current node if it has an accessible,
|
|
|
|
* or the first-line accessible descendants of the given node.
|
|
|
|
*
|
|
|
|
* @param aDOMNode the given node
|
|
|
|
* @param aEventType event type to fire an event
|
2008-02-08 18:28:01 -08:00
|
|
|
* @param aAvoidOnThisNode Call with PR_TRUE the first time to prevent event firing on root node for change
|
2007-10-06 09:24:57 -07:00
|
|
|
* @param aDelay whether to fire the event on a delay
|
|
|
|
* @param aForceIsFromUserInput the event is known to be from user input
|
|
|
|
*/
|
2008-02-08 18:28:01 -08:00
|
|
|
nsresult FireShowHideEvents(nsIDOMNode *aDOMNode, PRBool aAvoidOnThisNode, PRUint32 aEventType,
|
2007-10-06 09:24:57 -07:00
|
|
|
PRBool aDelay, PRBool aForceIsFromUserInput);
|
|
|
|
|
2008-03-19 18:58:11 -07:00
|
|
|
/**
|
|
|
|
* If the given accessible object is a ROLE_ENTRY, fire a value change event for it
|
|
|
|
*/
|
|
|
|
void FireValueChangeForTextFields(nsIAccessible *aPossibleTextFieldAccessible);
|
|
|
|
|
2007-07-13 20:09:42 -07:00
|
|
|
nsAccessNodeHashtable mAccessNodeCache;
|
2007-03-22 10:30:00 -07:00
|
|
|
void *mWnd;
|
|
|
|
nsCOMPtr<nsIDocument> mDocument;
|
|
|
|
nsCOMPtr<nsITimer> mScrollWatchTimer;
|
|
|
|
nsCOMPtr<nsITimer> mFireEventTimer;
|
|
|
|
PRUint16 mScrollPositionChangedTicks; // Used for tracking scroll events
|
|
|
|
PRPackedBool mIsContentLoaded;
|
2008-02-26 06:19:52 -08:00
|
|
|
PRPackedBool mIsLoadCompleteFired;
|
2007-03-22 10:30:00 -07:00
|
|
|
nsCOMArray<nsIAccessibleEvent> mEventsToFire;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
PRBool mIsAnchor;
|
|
|
|
PRBool mIsAnchorJumped;
|
2008-06-05 02:49:51 -07:00
|
|
|
PRBool mInFlushPendingEvents;
|
2007-09-18 14:36:41 -07:00
|
|
|
static PRUint32 gLastFocusedAccessiblesState;
|
2008-02-08 18:28:01 -08:00
|
|
|
static nsIAtom *gLastFocusedFrameType;
|
2007-03-22 10:30:00 -07:00
|
|
|
};
|
|
|
|
|
2009-06-24 19:08:53 -07:00
|
|
|
NS_DEFINE_STATIC_IID_ACCESSOR(nsDocAccessible,
|
|
|
|
NS_DOCACCESSIBLE_IMPL_CID)
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
#endif
|