1d1766043SAndrew Rist/**************************************************************
2d1766043SAndrew Rist *
3d1766043SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
4d1766043SAndrew Rist * or more contributor license agreements.  See the NOTICE file
5d1766043SAndrew Rist * distributed with this work for additional information
6d1766043SAndrew Rist * regarding copyright ownership.  The ASF licenses this file
7d1766043SAndrew Rist * to you under the Apache License, Version 2.0 (the
8d1766043SAndrew Rist * "License"); you may not use this file except in compliance
9d1766043SAndrew Rist * with the License.  You may obtain a copy of the License at
10d1766043SAndrew Rist *
11d1766043SAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
12d1766043SAndrew Rist *
13d1766043SAndrew Rist * Unless required by applicable law or agreed to in writing,
14d1766043SAndrew Rist * software distributed under the License is distributed on an
15d1766043SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16d1766043SAndrew Rist * KIND, either express or implied.  See the License for the
17d1766043SAndrew Rist * specific language governing permissions and limitations
18d1766043SAndrew Rist * under the License.
19d1766043SAndrew Rist *
20d1766043SAndrew Rist *************************************************************/
21d1766043SAndrew Rist
22d1766043SAndrew Rist
23cdf0e10cSrcweir
24cdf0e10cSrcweir#ifndef __com_sun_star_ui_XUIConfiguration_idl__
25cdf0e10cSrcweir#define __com_sun_star_ui_XUIConfiguration_idl__
26cdf0e10cSrcweir
27cdf0e10cSrcweir#ifndef __com_sun_star_ui_XUIConfigurationListener_idl__
28cdf0e10cSrcweir#include <com/sun/star/ui/XUIConfigurationListener.idl>
29cdf0e10cSrcweir#endif
30cdf0e10cSrcweir
31cdf0e10cSrcweirmodule com { module sun { module star { module ui {
32cdf0e10cSrcweir
33cdf0e10cSrcweir/** supports to notify other implementations about changes of a user
34cdf0e10cSrcweir    interface configuration manager.
35cdf0e10cSrcweir
36cdf0e10cSrcweir    <p>
37cdf0e10cSrcweir    The <type>XUIConfiguration</type> interface is provided for user
38cdf0e10cSrcweir    interface configuration managers which need to broadcast changes
39cdf0e10cSrcweir    within the container; that means the actions of adding, replacing
40cdf0e10cSrcweir    and removing elements are broadcast to listeners.
41cdf0e10cSrcweir    </p>
42cdf0e10cSrcweir
43cdf0e10cSrcweir    <p>This can be useful for UI to enable/disable some functions without
44cdf0e10cSrcweir    actually accessing the data.</p>
45cdf0e10cSrcweir
46*f431c806SJürgen Schmidt    @since OpenOffice 2.0
47cdf0e10cSrcweir*/
48cdf0e10cSrcweir
49cdf0e10cSrcweirpublished interface XUIConfiguration : ::com::sun::star::uno::XInterface
50cdf0e10cSrcweir{
51cdf0e10cSrcweir    /** adds the specified listener to receive events when elements are
52cdf0e10cSrcweir        changed, inserted or removed.
53cdf0e10cSrcweir
54cdf0e10cSrcweir        <p>
55cdf0e10cSrcweir        It is suggested to allow multiple registration of the same
56cdf0e10cSrcweir        listener, thus for each time a listener is added, it has to be
57cdf0e10cSrcweir        removed.
58cdf0e10cSrcweir
59cdf0e10cSrcweir        @see XUIConfigurationListener
60cdf0e10cSrcweir        </p>
61cdf0e10cSrcweir    */
62cdf0e10cSrcweir    void addConfigurationListener( [in] ::com::sun::star::ui::XUIConfigurationListener Listener );
63cdf0e10cSrcweir
64cdf0e10cSrcweir    /** removes the specified listener so it does not receive any events
65cdf0e10cSrcweir        from this user interface configuration manager.
66cdf0e10cSrcweir
67cdf0e10cSrcweir        <p>It is suggested to allow multiple registration of the same
68cdf0e10cSrcweir        listener, thus for each time a listener is added, it has to be
69cdf0e10cSrcweir        removed.
70cdf0e10cSrcweir
71cdf0e10cSrcweir        @see XUIConfigurationListener
72cdf0e10cSrcweir        </p>
73cdf0e10cSrcweir     */
74cdf0e10cSrcweir    void removeConfigurationListener( [in] ::com::sun::star::ui::XUIConfigurationListener Listener );
75cdf0e10cSrcweir};
76cdf0e10cSrcweir
77cdf0e10cSrcweir//=============================================================================
78cdf0e10cSrcweir
79cdf0e10cSrcweir}; }; }; };
80cdf0e10cSrcweir
81cdf0e10cSrcweir#endif
82