xref: /AOO41X/main/offapi/com/sun/star/text/TextTable.idl (revision d1766043198e81d0bcfc626e12893e7b4d7e31ca)
1/**************************************************************
2 *
3 * Licensed to the Apache Software Foundation (ASF) under one
4 * or more contributor license agreements.  See the NOTICE file
5 * distributed with this work for additional information
6 * regarding copyright ownership.  The ASF licenses this file
7 * to you under the Apache License, Version 2.0 (the
8 * "License"); you may not use this file except in compliance
9 * with the License.  You may obtain a copy of the License at
10 *
11 *   http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing,
14 * software distributed under the License is distributed on an
15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16 * KIND, either express or implied.  See the License for the
17 * specific language governing permissions and limitations
18 * under the License.
19 *
20 *************************************************************/
21
22
23#ifndef __com_sun_star_text_TextTable_idl__
24#define __com_sun_star_text_TextTable_idl__
25
26#ifndef __com_sun_star_text_TextContent_idl__
27#include <com/sun/star/text/TextContent.idl>
28#endif
29
30#ifndef __com_sun_star_util_Color_idl__
31#include <com/sun/star/util/Color.idl>
32#endif
33
34#ifndef __com_sun_star_text_XTextTable_idl__
35#include <com/sun/star/text/XTextTable.idl>
36#endif
37#ifndef __com_sun_star_text_TableColumnSeparator_idl__
38#include <com/sun/star/text/TableColumnSeparator.idl>
39#endif
40
41#ifndef __com_sun_star_container_XNamed_idl__
42#include <com/sun/star/container/XNamed.idl>
43#endif
44
45#ifndef __com_sun_star_beans_XPropertySet_idl__
46#include <com/sun/star/beans/XPropertySet.idl>
47#endif
48
49#ifndef __com_sun_star_style_GraphicLocation_idl__
50#include <com/sun/star/style/GraphicLocation.idl>
51#endif
52#ifndef __com_sun_star_style_BreakType_idl__
53#include <com/sun/star/style/BreakType.idl>
54#endif
55#ifndef __com_sun_star_table_ShadowFormat_idl__
56#include <com/sun/star/table/ShadowFormat.idl>
57#endif
58#ifndef __com_sun_star_table_TableBorder_idl__
59#include <com/sun/star/table/TableBorder.idl>
60#endif
61#ifndef __com_sun_star_table_XCellRange_idl__
62#include <com/sun/star/table/XCellRange.idl>
63#endif
64#ifndef __com_sun_star_table_XAutoFormattable_idl__
65#include <com/sun/star/table/XAutoFormattable.idl>
66#endif
67#ifndef __com_sun_star_chart_XChartDataArray_idl__
68#include <com/sun/star/chart/XChartDataArray.idl>
69#endif
70#ifndef __com_sun_star_util_XSortable_idl__
71#include <com/sun/star/util/XSortable.idl>
72#endif
73#ifndef __com_sun_star_sheet_XCellRangeData_idl__
74#include <com/sun/star/sheet/XCellRangeData.idl>
75#endif
76#ifndef _com_sun_star_xml_UserDefinedAttributesSupplier_idl_
77#include <com/sun/star/xml/UserDefinedAttributesSupplier.idl>
78#endif
79
80
81//=============================================================================
82
83 module com {  module sun {  module star {  module text {
84
85//=============================================================================
86
87/** is a table of text cells which is anchored to a surrounding text.
88
89    <p>Note: The anchor of the actual implementation for text tables
90    does not have a position in the text. Thus that anchor can not be
91    used for some operation like <member>XTextContent::attach</member> or
92    <member>XText::insertTextContent</member>
93    or other function that require the object to have a position in the text.</p>
94
95    <p>The reason why a text table still needs an anchor is that for example
96    tables should be insertable via <member>XText::insertTextContent</member>
97    and that interface uses a parameter of that type.</p>
98
99    @example
100
101    <p>Create and insert a TextTable:</p>
102
103    <listing>
104    xTable = xTextDoc.createInstance( "com.sun.star.text.TextTable" )
105    xTable.initialize(5, 8)
106    xTable.HoriOrient = 0 'com::sun::star::text::HoriOrientation::NONE
107    xTable.LeftMargin = 2000
108    xTable.RightMargin = 1500
109    xTextDoc.getText.insertTextContent( xTextRange, xTable, false )
110    </listing>
111
112    @see    com::sun::star::text::Cell
113    @see    com::sun::star::text::CellRange
114    @see    com::sun::star::text::TableColumns
115    @see    com::sun::star::text::TableRows
116    @see    com::sun::star::text::TextTableCursor
117 */
118published service TextTable
119{
120    service com::sun::star::text::TextContent;
121
122    [optional] service com::sun::star::xml::UserDefinedAttributesSupplier;
123
124    interface com::sun::star::text::XTextTable;
125
126    interface com::sun::star::container::XNamed;
127
128    interface com::sun::star::table::XCellRange;
129
130    interface com::sun::star::chart::XChartDataArray;
131
132    interface com::sun::star::table::XAutoFormattable;
133
134    interface com::sun::star::util::XSortable;
135
136    [optional] interface com::sun::star::sheet::XCellRangeData;
137
138    /** determins the type of break that is applied at the beginning of the table.@see com.sun.star.style.BreakType
139     */
140    [property] com::sun::star::style::BreakType BreakType;
141    //-------------------------------------------------------------------------
142
143    /** contains the left margin of the table.
144     */
145    [property] long LeftMargin;
146    //-------------------------------------------------------------------------
147
148    /** contains the right margin of the table.
149     */
150    [property] long RightMargin;
151    //-------------------------------------------------------------------------
152
153    /** contains the horizontal orientation.@see com.sun.star.text.HoriOrientation
154     */
155    [property] short HoriOrient;
156    //-------------------------------------------------------------------------
157
158    /** Setting this property to TRUE prevents page or column
159        breaks between this table and the following paragraph or text table.
160     */
161    [property] boolean KeepTogether;
162    //-------------------------------------------------------------------------
163
164    /** Setting this property to FALSE prevents the table from
165        getting spread on two pages.
166     */
167    [property] boolean Split;
168    //-------------------------------------------------------------------------
169
170    /** If a page break property is set at the table,
171        this property contains the new value for the page number.
172     */
173    [property] short PageNumberOffset;
174    //-------------------------------------------------------------------------
175
176    /** If this property is set, it creates a page break before the
177        table and assigns the value as the name of the new page style sheet to use.
178     */
179    [property] string PageDescName;
180    //-------------------------------------------------------------------------
181
182    /** determins the width of the table relative to its environment.
183     */
184    [property] short RelativeWidth;
185    //-------------------------------------------------------------------------
186    /** determins if the value of the relative width is valid.
187     */
188    [property] boolean IsWidthRelative;
189    //-------------------------------------------------------------------------
190
191    /** determins if the first row of the table is repeated on every new page.
192     */
193    [property] boolean RepeatHeadline;
194        //-------------------------------------------------------------------------
195        /** determins the number of rows of the table repeated on every new page.
196         */
197        [optional, property] long HeaderRowCount;
198        //-------------------------------------------------------------------------
199
200    /** determins the type, color and size of the shadow.@see com.sun.star.table.ShadowFormat
201     */
202    [property] com::sun::star::table::ShadowFormat ShadowFormat;
203    //-------------------------------------------------------------------------
204
205    /** determins the top margin.
206     */
207    [property] long TopMargin;
208    //-------------------------------------------------------------------------
209
210    /** determins the bottom margin.
211     */
212    [property] long BottomMargin;
213    //-------------------------------------------------------------------------
214
215    /** determins if the background color is transparent.
216     */
217    [property] boolean BackTransparent;
218    //-------------------------------------------------------------------------
219
220    /** contains the absolute table width.
221
222        <p>As this is only a describing property the value of the actual table may vary depending on the
223        environment the table is located in and the settings of LeftMargin,
224        RightMargin and HoriOrient. </p>
225     */
226    [property] long Width;
227    //-------------------------------------------------------------------------
228
229    /** determins if the first row of the table should be treated as
230        axis labels when a chart is to be created.
231     */
232    [property] boolean ChartRowAsLabel;
233    //-------------------------------------------------------------------------
234
235    /** determins if the first column of the table should be treated as
236        axis labels when a chart is to be created.
237     */
238    [property] boolean ChartColumnAsLabel;
239    //-------------------------------------------------------------------------
240
241    /** contains the description of the table borders.@see com.sun.star.table.TableBorder
242     */
243    [property] com::sun::star::table::TableBorder TableBorder;
244    //-------------------------------------------------------------------------
245
246    /** contains the column description of the table.
247             @see com.sun.star.text.TableColumnSeparator
248     */
249    [property] sequence<com::sun::star::text::TableColumnSeparator> TableColumnSeparators;
250    //-------------------------------------------------------------------------
251
252    /** contains the sum of the column width values used in TableColumnSeparators.
253     */
254    [property] short TableColumnRelativeSum;
255    //-------------------------------------------------------------------------
256
257    /** contains the color of the background.
258     */
259    [property] com::sun::star::util::Color BackColor;
260    //-------------------------------------------------------------------------
261
262    /** contains the URL for the background graphic.
263     */
264    [property] string BackGraphicURL;
265
266    //-------------------------------------------------------------------------
267
268    /** contains the name of the file filter for the background graphic.
269     */
270    [property] string BackGraphicFilter;
271
272    //-------------------------------------------------------------------------
273
274    /** determines the position of the background graphic.@see GraphicLocation
275     */
276    [property] com::sun::star::style::GraphicLocation BackGraphicLocation;
277
278    //-------------------------------------------------------------------------
279
280    /** determines whether borders of neighbouring table cells are
281     * collapsed into one
282     */
283    [optional, property] boolean CollapsingBorders;
284
285};
286
287//=============================================================================
288
289}; }; }; };
290
291#endif
292