summaryrefslogtreecommitdiffstats
path: root/offapi/com/sun/star/report/XSection.idl
blob: 76452db23d6414060939c7acc383ee7516821d0c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 .
 */

 module com {  module sun {  module star {  module report {
 interface XGroup;

/** identifies a XSection inside a report.

    <p>A section acts like a container of report components. This generic
    construction allows the definition of hierarchies of reports and their
    dependent subreports.</p>

    @see XReportDefinition
    @see XGroup
 */
interface XSection
{
    /** allows to navigate to group or report definition.
    */
    interface com::sun::star::container::XChild;
    /** allows to register listeners to be notified of changes in the container.
    */
    interface com::sun::star::container::XContainer;

    /** gives access to the elements by index.
    */
    interface com::sun::star::drawing::XShapes;

    /** creates an enumeration of the elements.
    */
    interface com::sun::star::container::XEnumerationAccess;

    /** provides generic access to the instance properties
    */
    interface com::sun::star::beans::XPropertySet;

    /** allows life-time control of sections.
     */
    interface com::sun::star::lang::XComponent;


    /** Defines if the section should be visible in report.
    */
    [attribute,bound] boolean Visible;

    /** Defines the name of the section.
    */
    [attribute,bound] string Name;

    /** Defines the height of the section.
    */
    [attribute,bound] unsigned long Height;

    /** Defines the background color of the section.
    */
    [attribute,bound] com::sun::star::util::Color BackColor;

    /** determines if the background color is set to transparent.
     */
    [attribute,bound] boolean BackTransparent;

    /** Defines the expression which is executed before printing the section.
        If the return value of the expression is `TRUE` then the section will be printed.
    */
    [attribute,bound] string ConditionalPrintExpression;

    /** Specifies whether the section is printed on a separate page.
        <p>Not valid for page header or page footer.</p>
        @see ForceNewPage
    */
    [attribute,bound] short ForceNewPage
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

    /** Specifies whether the section is printed in a new row or column within a multi column report.
        <p>Not valid for page header or page footer.</p>
        @see ForceNewPage
    */
    [attribute,bound] short NewRowOrCol
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

    /** Specifies that the section is printed on one page.
    <p>Not valid for page header or page footer.</p>
    */
    [attribute,bound] boolean KeepTogether
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

    /** Specifies that elements with dynamic state will be expanded vertically when then content of the element is larger than it's container.
        If this property is disabled the content will be truncated when its size is larger than the container.
    */
    [attribute,bound] boolean CanGrow
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

/**
  <p>Represents ...</p>

 */
    [attribute,bound] boolean CanShrink
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

    /** Defines that the group header should be repeated on the next page when a group spans more than one page.
        It only applies to group headers.
    */
    [attribute,bound] boolean RepeatSection
    {
        set raises ( com::sun::star::lang::IllegalArgumentException,com::sun::star::beans::UnknownPropertyException );
        get raises ( com::sun::star::beans::UnknownPropertyException );
    };

    /** Specifies the parent of the section if it is a group header or group footer.
    */
    [attribute,readonly] com::sun::star::report::XGroup Group;

    /** Specifies the parent of the section if it is a page header or page footer.
    */
    [attribute,readonly] com::sun::star::report::XReportDefinition ReportDefinition;
};


}; }; }; };

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */