2003-04-02 00:39:57 +04: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.
|
|
|
|
*
|
|
|
|
* Original Author: Aaron Leventhal (aaronl@netscape.com)
|
2003-07-09 11:01:46 +04:00
|
|
|
* Contributor(s):
|
2003-04-02 00:39:57 +04:00
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either 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 ***** */
|
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
2007-03-23 02:01:14 +03:00
|
|
|
|
2003-06-19 22:12:52 +04:00
|
|
|
interface nsIDOMNode;
|
|
|
|
interface nsIAccessibleDocument;
|
2003-04-02 00:39:57 +04:00
|
|
|
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* An interface used by in-process accessibility clients
|
|
|
|
* to get style, window, markup and other information about
|
|
|
|
* a DOM node. When accessibility is active in Gecko,
|
|
|
|
* every DOM node can have one nsIAccessNode for each
|
|
|
|
* pres shell the DOM node is rendered in.
|
|
|
|
* The nsIAccessNode implementations are instantiated lazily.
|
|
|
|
* The nsIAccessNode tree for a given dom window
|
|
|
|
* has a one to one relationship to the DOM tree.
|
|
|
|
* If the DOM node for this access node is "accessible",
|
|
|
|
* then a QueryInterface to nsIAccessible will succeed.
|
|
|
|
*
|
|
|
|
* @status UNDER_REVIEW
|
|
|
|
*/
|
2007-04-12 20:54:09 +04:00
|
|
|
[scriptable, uuid(11c0007f-531c-43b7-be63-a3060a13d8d2)]
|
2003-04-02 00:39:57 +04:00
|
|
|
interface nsIAccessNode : nsISupports
|
|
|
|
{
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* The DOM node this nsIAccessNode is associated with.
|
|
|
|
*/
|
2003-06-19 22:12:52 +04:00
|
|
|
readonly attribute nsIDOMNode DOMNode;
|
|
|
|
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* The number of DOM children for the DOM node, which
|
|
|
|
* matches the number of nsIAccessNode children for this
|
|
|
|
* nsIAccessNode.
|
|
|
|
*/
|
2003-06-19 22:12:52 +04:00
|
|
|
readonly attribute long numChildren;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the nth child of this node
|
|
|
|
* @param childNum Zero-based child index
|
|
|
|
* @return The nth nsIAccessNode child
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
nsIAccessNode getChildNodeAt(in long childNum);
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The parent nsIAccessNode
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
readonly attribute nsIAccessNode parentNode;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The first nsIAccessNode child
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
readonly attribute nsIAccessNode firstChildNode;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The last nsIAccessNode child
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
readonly attribute nsIAccessNode lastChildNode;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The previous nsIAccessNode sibling
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
readonly attribute nsIAccessNode previousSiblingNode;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The next nsIAccessNode sibling
|
|
|
|
*/
|
2003-07-31 12:09:39 +04:00
|
|
|
readonly attribute nsIAccessNode nextSiblingNode;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The nsIAccessibleDocument that this nsIAccessNode
|
|
|
|
* resides in.
|
|
|
|
*/
|
2003-06-19 22:12:52 +04:00
|
|
|
readonly attribute nsIAccessibleDocument accessibleDocument;
|
|
|
|
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* The innerHTML for the DOM node
|
|
|
|
* This is a text string of all the markup inside the DOM
|
|
|
|
* node, not including the start and end tag for the node.
|
|
|
|
*/
|
2003-06-19 22:12:52 +04:00
|
|
|
readonly attribute DOMString innerHTML;
|
|
|
|
|
2007-02-28 17:21:41 +03:00
|
|
|
/**
|
|
|
|
* Makes an object visible on screen.
|
|
|
|
*
|
2007-04-12 20:54:09 +04:00
|
|
|
* @param scrollType - defines where the object should be placed on
|
|
|
|
* the screen (see nsIAccessibleScrollType for
|
|
|
|
* available constants).
|
2007-02-28 17:21:41 +03:00
|
|
|
*/
|
2007-04-12 20:54:09 +04:00
|
|
|
void scrollTo(in unsigned long aScrollType);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Moves the top left of an object to a specified location.
|
|
|
|
*
|
|
|
|
* @param coordinateType - specifies whether the coordinates are relative to
|
|
|
|
* the screen or the parent object (for available
|
|
|
|
* constants refer to nsIAccessibleCoordinateType)
|
|
|
|
* @param aX - defines the x coordinate
|
|
|
|
* @param aY - defines the y coordinate
|
|
|
|
*/
|
|
|
|
void scrollToPoint(in unsigned long aCoordinateType, in long aX, in long aY);
|
2007-02-28 17:21:41 +03:00
|
|
|
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* The OS window handle for the window this node
|
|
|
|
* is being displayed in.
|
|
|
|
*/
|
2003-04-02 00:39:57 +04:00
|
|
|
[noscript] readonly attribute voidPtr ownerWindow;
|
2003-07-22 18:55:22 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A unique ID calculated for this DOM node, for the
|
|
|
|
* purposes of caching and referencing this object.
|
|
|
|
*/
|
2003-04-15 12:45:55 +04:00
|
|
|
[noscript] readonly attribute voidPtr uniqueID;
|
2003-06-19 22:12:52 +04:00
|
|
|
|
2003-07-22 18:55:22 +04:00
|
|
|
/**
|
|
|
|
* Retrieve the computed style value for this DOM node, if it is a DOM element.
|
|
|
|
* Note: the meanings of width, height and other size measurements depend
|
|
|
|
* on the version of CSS being used. Therefore, for bounds information,
|
|
|
|
* it is better to use nsIAccessible::accGetBounds.
|
|
|
|
* @param pseudoElt The pseudo element to retrieve style for, or NULL
|
|
|
|
* for general computed style information for this node.
|
|
|
|
* @param propertyName Retrieve the computed style value for this property name,
|
|
|
|
* for example "border-bottom".
|
|
|
|
*/
|
2003-06-19 22:12:52 +04:00
|
|
|
DOMString getComputedStyleValue(in DOMString pseudoElt, in DOMString propertyName);
|
2003-04-02 00:39:57 +04:00
|
|
|
};
|