1*d1766043SAndrew Rist/**************************************************************
2cdf0e10cSrcweir *
3*d1766043SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
4*d1766043SAndrew Rist * or more contributor license agreements.  See the NOTICE file
5*d1766043SAndrew Rist * distributed with this work for additional information
6*d1766043SAndrew Rist * regarding copyright ownership.  The ASF licenses this file
7*d1766043SAndrew Rist * to you under the Apache License, Version 2.0 (the
8*d1766043SAndrew Rist * "License"); you may not use this file except in compliance
9*d1766043SAndrew Rist * with the License.  You may obtain a copy of the License at
10*d1766043SAndrew Rist *
11*d1766043SAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
12*d1766043SAndrew Rist *
13*d1766043SAndrew Rist * Unless required by applicable law or agreed to in writing,
14*d1766043SAndrew Rist * software distributed under the License is distributed on an
15*d1766043SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*d1766043SAndrew Rist * KIND, either express or implied.  See the License for the
17*d1766043SAndrew Rist * specific language governing permissions and limitations
18*d1766043SAndrew Rist * under the License.
19*d1766043SAndrew Rist *
20*d1766043SAndrew Rist *************************************************************/
21*d1766043SAndrew Rist
22*d1766043SAndrew Rist
23cdf0e10cSrcweir#ifndef com_sun_star_chart2_data_XDataReceiver_idl
24cdf0e10cSrcweir#define com_sun_star_chart2_data_XDataReceiver_idl
25cdf0e10cSrcweir
26cdf0e10cSrcweir#ifndef __com_sun_star_uno_XInterface_idl__
27cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl>
28cdf0e10cSrcweir#endif
29cdf0e10cSrcweir#ifndef __com_sun_star_lang_IllegalArgumentException_idl__
30cdf0e10cSrcweir#include <com/sun/star/lang/IllegalArgumentException.idl>
31cdf0e10cSrcweir#endif
32cdf0e10cSrcweir
33cdf0e10cSrcweir#ifndef com_sun_star_chart2_data_XDataProvider_idl
34cdf0e10cSrcweir#include <com/sun/star/chart2/data/XDataProvider.idl>
35cdf0e10cSrcweir#endif
36cdf0e10cSrcweir
37cdf0e10cSrcweir#ifndef com_sun_star_chart2_data_XRangeHighlighter_idl
38cdf0e10cSrcweir#include <com/sun/star/chart2/data/XRangeHighlighter.idl>
39cdf0e10cSrcweir#endif
40cdf0e10cSrcweir
41cdf0e10cSrcweir#ifndef com_sun_star_beans_PropertyValue_idl
42cdf0e10cSrcweir#include <com/sun/star/beans/PropertyValue.idl>
43cdf0e10cSrcweir#endif
44cdf0e10cSrcweir
45cdf0e10cSrcweir#ifndef __com_sun_star_util_XNumberFormatsSupplier_idl__
46cdf0e10cSrcweir#include <com/sun/star/util/XNumberFormatsSupplier.idl>
47cdf0e10cSrcweir#endif
48cdf0e10cSrcweir
49cdf0e10cSrcweirmodule com
50cdf0e10cSrcweir{
51cdf0e10cSrcweirmodule sun
52cdf0e10cSrcweir{
53cdf0e10cSrcweirmodule star
54cdf0e10cSrcweir{
55cdf0e10cSrcweirmodule chart2
56cdf0e10cSrcweir{
57cdf0e10cSrcweirmodule data
58cdf0e10cSrcweir{
59cdf0e10cSrcweir
60cdf0e10cSrcweirinterface XDataReceiver : ::com::sun::star::uno::XInterface
61cdf0e10cSrcweir{
62cdf0e10cSrcweir    /** attaches a component that provides data for the document.
63cdf0e10cSrcweir
64cdf0e10cSrcweir        <p>The previously set data provider will be released.</p>
65cdf0e10cSrcweir
66cdf0e10cSrcweir        @param xProvider
67cdf0e10cSrcweir              The new DataProvider.  If it is an empty reference, the
68cdf0e10cSrcweir              ChartDocument will have no data.
69cdf0e10cSrcweir     */
70cdf0e10cSrcweir    void attachDataProvider( [in] XDataProvider xProvider );
71cdf0e10cSrcweir
72cdf0e10cSrcweir    void setArguments( [in] sequence< com::sun::star::beans::PropertyValue > aArguments )
73cdf0e10cSrcweir        raises( com::sun::star::lang::IllegalArgumentException );
74cdf0e10cSrcweir
75cdf0e10cSrcweir    /** returns a list of all range strings for which data has been
76cdf0e10cSrcweir        requested by the most recently attached data provider, and
77cdf0e10cSrcweir        which is still used.
78cdf0e10cSrcweir
79cdf0e10cSrcweir        <p>This list may be used by the data provider to swap charts
80cdf0e10cSrcweir        out of memory, but still get informed by changes of ranges
81cdf0e10cSrcweir        while the chart is not loaded.</p>
82cdf0e10cSrcweir        @return a list of used range strings.
83cdf0e10cSrcweir     */
84cdf0e10cSrcweir    sequence< string > getUsedRangeRepresentations();
85cdf0e10cSrcweir
86cdf0e10cSrcweir    /** Returns the data requested by the most recently attached data
87cdf0e10cSrcweir        provider, that is still used.
88cdf0e10cSrcweir     */
89cdf0e10cSrcweir    XDataSource getUsedData();
90cdf0e10cSrcweir
91cdf0e10cSrcweir    /** attaches an <type>XNumberFormatsSupplier</type> to this
92cdf0e10cSrcweir		<type>XDataReceiver</type>.
93cdf0e10cSrcweir
94cdf0e10cSrcweir		<p>The given number formats will be used for display purposes.</p>
95cdf0e10cSrcweir	 */
96cdf0e10cSrcweir    void attachNumberFormatsSupplier( [in] com::sun::star::util::XNumberFormatsSupplier xSupplier );
97cdf0e10cSrcweir
98cdf0e10cSrcweir    /** Returns a component at which a view representing the data of
99cdf0e10cSrcweir        the attached data provider may listen for highlighting the
100cdf0e10cSrcweir        data ranges used by the currently selected objects in the data
101cdf0e10cSrcweir        receiver component.
102cdf0e10cSrcweir
103cdf0e10cSrcweir        <p>This is typically used by a spreadsheet to hightlight the
104cdf0e10cSrcweir        ranges used by the currently selected object in a chart.</p>
105cdf0e10cSrcweir
106cdf0e10cSrcweir        <p>The range hightlighter is optional, i.e., this method may
107cdf0e10cSrcweir        return an empty object.</p>
108cdf0e10cSrcweir     */
109cdf0e10cSrcweir    XRangeHighlighter getRangeHighlighter();
110cdf0e10cSrcweir};
111cdf0e10cSrcweir
112cdf0e10cSrcweir} ; // data
113cdf0e10cSrcweir} ; // chart2
114cdf0e10cSrcweir} ; // com
115cdf0e10cSrcweir} ; // sun
116cdf0e10cSrcweir} ; // star
117cdf0e10cSrcweir
118cdf0e10cSrcweir#endif
119