1*cdf0e10cSrcweir/*************************************************************************
2*cdf0e10cSrcweir *
3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir *
5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir *
7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir *
9*cdf0e10cSrcweir * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir *
11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir *
15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir *
21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir *
26*cdf0e10cSrcweir ************************************************************************/
27*cdf0e10cSrcweir#ifndef __com_sun_star_awt_grid_XGridColumnModel_idl__
28*cdf0e10cSrcweir#define __com_sun_star_awt_grid_XGridColumnModel_idl__
29*cdf0e10cSrcweir
30*cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl>
31*cdf0e10cSrcweir#include <com/sun/star/lang/XComponent.idl>
32*cdf0e10cSrcweir#include <com/sun/star/util/XCloneable.idl>
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir#include <com/sun/star/awt/grid/XGridColumn.idl>
35*cdf0e10cSrcweir#include <com/sun/star/container/XContainer.idl>
36*cdf0e10cSrcweir#include <com/sun/star/lang/IndexOutOfBoundsException.idl>
37*cdf0e10cSrcweir#include <com/sun/star/lang/IllegalArgumentException.idl>
38*cdf0e10cSrcweir
39*cdf0e10cSrcweir//=============================================================================
40*cdf0e10cSrcweir
41*cdf0e10cSrcweirmodule com {  module sun {  module star {  module awt { module grid {
42*cdf0e10cSrcweir
43*cdf0e10cSrcweir//=============================================================================
44*cdf0e10cSrcweir
45*cdf0e10cSrcweir/** An instance of this interface is used by the <type>UnoControlGrid</type> to
46*cdf0e10cSrcweir    retrieve the column structure that is displayed in the actual control.
47*cdf0e10cSrcweir
48*cdf0e10cSrcweir    If you do not need your own model implementation, you can also use the <type>DefaultGridColumnModel</type>.
49*cdf0e10cSrcweir
50*cdf0e10cSrcweir    @since OOo 3.3
51*cdf0e10cSrcweir*/
52*cdf0e10cSrcweirpublished interface XGridColumnModel
53*cdf0e10cSrcweir{
54*cdf0e10cSrcweir    /** implements life time control for the component
55*cdf0e10cSrcweir    */
56*cdf0e10cSrcweir    interface ::com::sun::star::lang::XComponent;
57*cdf0e10cSrcweir
58*cdf0e10cSrcweir    /** allows to register listeners to be notified when columns are inserted or removed
59*cdf0e10cSrcweir    */
60*cdf0e10cSrcweir    interface ::com::sun::star::container::XContainer;
61*cdf0e10cSrcweir
62*cdf0e10cSrcweir    /** allows cloning the complete column model
63*cdf0e10cSrcweir    */
64*cdf0e10cSrcweir    interface ::com::sun::star::util::XCloneable;
65*cdf0e10cSrcweir
66*cdf0e10cSrcweir    /** Returns the number of columns.
67*cdf0e10cSrcweir
68*cdf0e10cSrcweir        @returns
69*cdf0e10cSrcweir                the number of columns.
70*cdf0e10cSrcweir    */
71*cdf0e10cSrcweir    long getColumnCount();
72*cdf0e10cSrcweir
73*cdf0e10cSrcweir    /** creates a new column for use with the column model.
74*cdf0e10cSrcweir
75*cdf0e10cSrcweir        <p>The newly created column is not yet inserted into the column container, you need to call <member>addColumn</member>
76*cdf0e10cSrcweir        after you initialized the column object.</p>
77*cdf0e10cSrcweir    */
78*cdf0e10cSrcweir    XGridColumn
79*cdf0e10cSrcweir        createColumn();
80*cdf0e10cSrcweir
81*cdf0e10cSrcweir    /** Adds a column to the model.
82*cdf0e10cSrcweir
83*cdf0e10cSrcweir        <p>You should use the <member>createColumn</member> member to create a new column. This gives
84*cdf0e10cSrcweir        implementations of the <code>XGridColumnModel</code> interface the possibility to provide own column
85*cdf0e10cSrcweir        implementations which extend the basic <type>GridColumn</type> type.</p>
86*cdf0e10cSrcweir
87*cdf0e10cSrcweir        <p>As soon as the column has been inserted into the model, the model takes ownership of it. This means when the
88*cdf0e10cSrcweir        column is removed, or when the column model is disposed, the grid column is disposed as well.</p>
89*cdf0e10cSrcweir
90*cdf0e10cSrcweir        @param column
91*cdf0e10cSrcweir            the column to add to the model.
92*cdf0e10cSrcweir        @returns
93*cdf0e10cSrcweir            the index of new created column.
94*cdf0e10cSrcweir
95*cdf0e10cSrcweir        @throws ::com::sun::star::lang::IllegalArgumentException
96*cdf0e10cSrcweir            if the given column is not a valid element for the column container, or if it is <NULL/>.
97*cdf0e10cSrcweir    */
98*cdf0e10cSrcweir    long addColumn( [in] XGridColumn column )
99*cdf0e10cSrcweir        raises ( ::com::sun::star::lang::IllegalArgumentException );
100*cdf0e10cSrcweir
101*cdf0e10cSrcweir    /** removes a column from the model
102*cdf0e10cSrcweir
103*cdf0e10cSrcweir        <p>The column object will be disposed upon removal.</p>
104*cdf0e10cSrcweir
105*cdf0e10cSrcweir        @param ColumnIndex
106*cdf0e10cSrcweir            denotes the index of the column to remove
107*cdf0e10cSrcweir        @throws ::com::sun::star::lang::IndexOutOfBoundsException
108*cdf0e10cSrcweir            if <code>ColumnIndex</code> does not denote a valid column index.
109*cdf0e10cSrcweir    */
110*cdf0e10cSrcweir    void removeColumn( [in] long ColumnIndex )
111*cdf0e10cSrcweir        raises ( ::com::sun::star::lang::IndexOutOfBoundsException );
112*cdf0e10cSrcweir
113*cdf0e10cSrcweir    /** Returns all columns of the model.
114*cdf0e10cSrcweir        @returns
115*cdf0e10cSrcweir                 all columns associated with the model in a sequence of <type>XGridColumn</type>.
116*cdf0e10cSrcweir    */
117*cdf0e10cSrcweir    sequence<XGridColumn> getColumns();
118*cdf0e10cSrcweir
119*cdf0e10cSrcweir    /** Returns a specific column.
120*cdf0e10cSrcweir        @param index
121*cdf0e10cSrcweir                the position of the requested column.
122*cdf0e10cSrcweir        @returns
123*cdf0e10cSrcweir                 the requested column.
124*cdf0e10cSrcweir    */
125*cdf0e10cSrcweir    XGridColumn getColumn( [in] long index)
126*cdf0e10cSrcweir        raises ( ::com::sun::star::lang::IndexOutOfBoundsException );
127*cdf0e10cSrcweir
128*cdf0e10cSrcweir    /** Fills the model with the given number of default columns
129*cdf0e10cSrcweir
130*cdf0e10cSrcweir        <p>Existing columns will be removed before adding new columns. Listeners at the column model will
131*cdf0e10cSrcweir        be notified one <member scope="com::sun::star::container">XContainerListener::elementRemoved</member> event
132*cdf0e10cSrcweir        for each removed column, and one <member scope="com::sun::star::container">XContainerListener::elementInserted</member>
133*cdf0e10cSrcweir        event for each insertion.</p>
134*cdf0e10cSrcweir
135*cdf0e10cSrcweir        @param elements
136*cdf0e10cSrcweir            the number of default columns that should be set.
137*cdf0e10cSrcweir    */
138*cdf0e10cSrcweir    void setDefaultColumns([in] long elements);
139*cdf0e10cSrcweir};
140*cdf0e10cSrcweir
141*cdf0e10cSrcweir//=============================================================================
142*cdf0e10cSrcweir
143*cdf0e10cSrcweir}; }; }; }; };
144*cdf0e10cSrcweir
145*cdf0e10cSrcweir#endif
146