/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: XMutableTreeNode.idl,v $ * $Revision: 1.4 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef __com_sun_star_awt_tree_XMutableTreeNode_idl__ #define __com_sun_star_awt_tree_XMutableTreeNode_idl__ #ifndef __com_sun_star_awt_tree_XTreeNode_idl__ #include #endif #ifndef __com_sun_star_lang_IllegalArgumentException_idl__ #include #endif #ifndef __com_sun_star_lang_IndexOutOfBoundsException_idl__ #include #endif //============================================================================= module com { module sun { module star { module awt { module tree { //============================================================================= /** Represents a mutable tree node as used by the MutableTreeDataModel */ interface XMutableTreeNode : XTreeNode { /** appends ChildNode to this instance. @throws ::com::sun::star::lang::IllegalArgumentException if ChildNode is not a valid node of the corresponding XTreeDataModel. */ void appendChild( [in] XMutableTreeNode ChildNode ) raises( com::sun::star::lang::IllegalArgumentException ); /** inserts ChildNode to this instance at the given index. @param Index the index where the node will be inserted to this instance. @throws ::com::sun::star::lang::IllegalArgumentException if ChildNode is not a valid node of the corresponding XTreeDataModel. @throws ::com::sun::star::lang::IndexOutOfBoundsException if Index is less than 0 or greater then XTreeNode::getChildCount(). */ void insertChildByIndex( [in] long Index, [in] XMutableTreeNode ChildNode ) raises( com::sun::star::lang::IllegalArgumentException, com::sun::star::lang::IndexOutOfBoundsException ); /** removes the node from this instance at the specified index. @param Index the index of the node to be removed from this instance. @throws ::com::sun::star::lang::IndexOutOfBoundsException if Index is less than 0 or greater then XTreeNode::getChildCount(). */ void removeChildByIndex( [in] long Index ) raises( com::sun::star::lang::IndexOutOfBoundsException ); /** Changes if the children of this node are created on demand. @see XTreeNode::hasChildrenOnDemand() */ void setHasChildrenOnDemand( [in] boolean ChildrenOnDemand ); /** sets the display value of this node */ void setDisplayValue( [in] any Value ); /** Stores an implementation dependend value.

You can use this attribute to store data for this node that is independend of the display value

*/ [attribute] any DataValue; /** The URL for a graphic that is rendered before the text part of this node.

If this URL is empty, no graphic is rendered. */ void setNodeGraphicURL( [in] string URL ); /** The URL for a graphic that is rendered to visualize expanded non leaf nodes.

If URL is empty, XTreeControl::DefaultExpandedGraphicURL is used. */ void setExpandedGraphicURL( [in] string URL ); /** The URL for a graphic that is rendered to visualize collapsed non leaf nodes.

If URL is empty, XTreeControl::DefaultCollapsedGraphicURL is used. */ void setCollapsedGraphicURL( [in] string URL ); }; //============================================================================= }; }; }; }; }; #endif