summaryrefslogtreecommitdiff
path: root/offapi/com/sun/star/form/component/DatabaseListBox.idl
blob: 486c445d39c156d8e0ad895553ca1cc13e44df73 (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
153
154
155
156
157
158
159
160
161
162
/*************************************************************************
 *
 * 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: DatabaseListBox.idl,v $
 * $Revision: 1.10 $
 *
 * 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
 * <http://www.openoffice.org/license.html>
 * for a copy of the LGPLv3 License.
 *
 ************************************************************************/
#ifndef __com_sun_star_form_component_DatabaseListBox_idl__
#define __com_sun_star_form_component_DatabaseListBox_idl__

#ifndef __com_sun_star_form_component_ListBox_idl__
#include <com/sun/star/form/component/ListBox.idl>
#endif

#ifndef __com_sun_star_form_DataAwareControlModel_idl__
#include <com/sun/star/form/DataAwareControlModel.idl>
#endif

#ifndef __com_sun_star_form_ListSourceType_idl__
#include <com/sun/star/form/ListSourceType.idl>
#endif


//=============================================================================

 module com {  module sun {  module star {  module form {  module component {

//=============================================================================

/** This service specifies a data-aware list box control model.

    <p>The base service for list boxes (<type>ListBox</type>) offers only
    one possibility to specify the list entries: the <member>ListBox::ListSource</member>
    property, which contains all the strings to be displayed.</p>

    <p>This service here extends this mimic. It allows to fill the list from a data source.
    This means that a second result set is opened, which works on the same connection as the
    form which the list box belongs to, but can be based on an arbitrary table or SQL statement.</p>

    <p>For instance, you may have a form which is bound to a table <em>invoice</em>, and you use it
    to enter invoices for your customers. Probably, you will have a second table (say <em>customer</em>),
    which (amonst other data) contains a unique key for identifying customers. In your invoice table, you will
    have a foreign key referring to these customers.<br/>
    Now, besides the result set the form is based on (all your invoices), the list box can be caused
    to open a second result set, this time for the <em>customer</em> table, and fill it's list with entries
    from this result set.<br/>
    Additionally, it allows to model the relation between the two tables: When the user selects a customer from
    the list, this customer has the unique id we just talked about (which is not necessarily visible to the
    user in any way). The list box then automatically transfers this id into the foreign key column of
    <em>invoice</em>, thus allowing the user to transparently work with human-readable strings instead of
    pure numbers.<br/>
    Let's call this result set the list is filled from the <em>list result set</em> here ...</p>

 */
published service DatabaseListBox
{
    service com::sun::star::form::component::ListBox;

    service com::sun::star::form::DataAwareControlModel;

    //-------------------------------------------------------------------------

    /** specifies which column of the list result set should be used for data exchange.

        <p>When you make a selection from a list box, the "BoundColumn"
        property reflects which column value of a result set should
        be used as the value of the component. If the control is bound
        to a database field, the column value is stored in the
        database field identified by the property
        <member scope="com::sun::star::form">DataAwareControlModel::DataField</member>.

        <dl>
            <dt>0</dt>
            <dd>The selected (displayed) list box string is stored in
            the current database field.</dd>

            <dt>1 or greater</dt>
            <dd>The column value of the result set at the position is
            stored in the current database field.</dd>
        </dl></p>

        <p>The bound column property is only used if a list source is defined
        and the list source matches with the types
        <member scope="com::sun::star::form">ListSourceType::TABLE</member>,
        <member scope="com::sun::star::form">ListSourceType::QUERY</member>,
        <member scope="com::sun::star::form">ListSourceType::SQL</member> or
        <member scope="com::sun::star::form">ListSourceType::SQLPASSTHROUGH</member>.
        Otherwise the property is ignored, as there is no result set from which to
        get the column values.</p>
    */
    [property] short BoundColumn;

    //-------------------------------------------------------------------------

    /** describes the kind of list source used.

        <p>Depending on the value of this property, the way the value of <member>ListBox::ListSource</member>
        is evaluated varies.
            <dl>
                <dt><member scope="com::sun::star::form">ListSourceType::VALUELIST</member></dt>
                <dd>The elements in the string sequence in <member>ListBox::ListSource</member>
                build up the entry list.</dd>

                <dt><member scope="com::sun::star::form">ListSourceType::TABLE</member></dt>
                <dd>The first element of the string sequence in <member>ListBox::ListSource</member>
                determines the table which the list result set should be based on.</dd>

                <dt><member scope="com::sun::star::form">ListSourceType::QUERY</member></dt>
                <dd>The first element of the string sequence in <member>ListBox::ListSource</member>
                determines the query which the list result set should be based on.<br/>
                For retrieving the query, the connection which the data form is working with
                (<member scope="com::sun::star::sdb">RowSet::ActiveConnection</member>) is queried for
                the <type scope="com::sun::star::sdb">XQueriesSupplier</type> interface.</dd>

                <dt><member scope="com::sun::star::form">ListSourceType::SQL</member></dt>
                <dd>The first element of the string sequence in <member>ListBox::ListSource</member>
                contains the SQL statement which the list result set should be based on.</p>

                <dt><member scope="com::sun::star::form">ListSourceType::SQLPASSTHROUGH</member></dt>
                <dd>The first element of the string sequence in <member>ListBox::ListSource</member>
                contains the SQL statement which the list result set should be based on.<br/>
                The statement is not analyzed by the parser. This means that you can use database specific
                SQL features here, but, on the other hand, loose features like parameter value substitution.</dd>

                <dt><member scope="com::sun::star::form">ListSourceType::TABLEFIELDS</member></dt>
                <dd>The first element of the string sequence in <member>ListBox::ListSource</member>
                determines the table which's column names should fill the list.</dd>
            </dl>
        </p>

     */
    [property] com::sun::star::form::ListSourceType ListSourceType;

};

//=============================================================================

}; }; }; }; };

#endif