1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef EXTENSIONS_SOURCE_PROPCTRLR_COMPOSEDUIUPDATE_HXX
21 #define EXTENSIONS_SOURCE_PROPCTRLR_COMPOSEDUIUPDATE_HXX
23 #include "propertyhandler.hxx"
25 #include <com/sun/star/inspection/XObjectInspectorUI.hpp>
31 //........................................................................
34 //........................................................................
36 //====================================================================
38 //====================================================================
40 struct MapHandlerToUI
;
42 /** callback for an ComposedPropertyUIUpdate checking a given property for existence
44 class SAL_NO_VTABLE IPropertyExistenceCheck
47 virtual ::sal_Bool SAL_CALL
hasPropertyByName( const OUString
& _rName
) throw (::com::sun::star::uno::RuntimeException
) = 0;
50 ~IPropertyExistenceCheck() {}
53 //====================================================================
54 //= ComposedPropertyUIUpdate
55 //====================================================================
56 /** helper class composing requests to a ->XObjectInspectorUI interface, coming
59 Usually, a handler tells the browser UI to enable to disable, or show or hide, certain
60 elements. Now when multiple handlers do this, their instructions must be combined:
61 If one handler disables a certain element, but others enable it, it must in the
62 result still be disabled. Similar for showing/hiding elements.
64 ->ComposedPropertyUIUpdate implements this combination. It does so by providing a dedicated
65 ->XObjectInspectorUI instance for every participating handler, and remembering the UI
66 state on a per-handler basis. Upon request (->fire), the combined UI state is
67 forwarded to another ->XObjectInspectorUI instance, the so-called delegator UI.
69 class ComposedPropertyUIUpdate
72 ::std::auto_ptr
< MapHandlerToUI
> m_pCollectedUIs
;
73 ::com::sun::star::uno::Reference
< ::com::sun::star::inspection::XObjectInspectorUI
>
75 oslInterlockedCount m_nSuspendCounter
;
76 IPropertyExistenceCheck
* m_pPropertyCheck
;
79 /** constructs a ->ComposedPropertyUIUpdate instance
81 a ->XObjectInspectorUI instance to which composed UI requests should be forwarded. Must
83 @param _pPropertyCheck
84 an instance checking properties for existence. If this is not <NULL/>, it will be invoked
85 whenever one of the ->XObjectInspectorUI methods is called, to check the passed property
87 Beware of lifetime issues. The instance pointed to by <arg>_pPropertyCheck</arg> must
88 live at least as long as the ->ComposedPropertyUIUpdate instance you're going to create.
89 @throws ::com::sun::star::lang::NullPointerException
90 if ->_rxDelegatorUI is <NULL/>
92 ComposedPropertyUIUpdate(
93 const ::com::sun::star::uno::Reference
< ::com::sun::star::inspection::XObjectInspectorUI
>& _rxDelegatorUI
,
94 IPropertyExistenceCheck
* _pPropertyCheck
);
95 ~ComposedPropertyUIUpdate();
97 /** returns the delegator UI
98 @throw ::com::sun::star::lang::DisposedException
100 ::com::sun::star::uno::Reference
< ::com::sun::star::inspection::XObjectInspectorUI
> getDelegatorUI() const;
102 /** returns a ->XObjectInspectorUI instance belonging to a given property handler
104 In every call to an ->XPropertyHandler method which requires a ->XObjectInspectorUI,
105 the same UI instance should be used. The instance here will cache all requests passed
106 to it, and ->ComposedPropertyUIUpdate::fire will use the combination of all
107 cached UI states of all handlers to update the delegator UI.
109 ::com::sun::star::uno::Reference
< ::com::sun::star::inspection::XObjectInspectorUI
>
110 getUIForPropertyHandler( const ::com::sun::star::uno::Reference
< ::com::sun::star::inspection::XPropertyHandler
>& _rxHandler
);
112 /** Suspends automatic firing of UI changes
114 normally, as soon as any of the property handlers does a request for an
115 arbitrary UI change, the set of collected UI changes is evaluated, and the combined
116 UI state is fired to the delegator UI.
118 You can disable this automatic firing by calling ->suspendAutoFire. As longs as auto
119 firing is suspended, only explicit ->fire calls trigger the notification to the
122 Note that calls to ->suspendAutoFire are culmulative, that is, if you make multiple calls
123 they must be accompanied by an equal number of calls to ->resumeAutoFire, to enable
126 @seealso resumeAutoFire
128 void SAL_CALL
suspendAutoFire();
130 /** Suspends automatic firing of UI changes
132 @seealso suspendAutoFire
134 void SAL_CALL
resumeAutoFire();
136 /** disposes the instance, so it becomes non-functional.
138 All cached handlers and cached ->XObjectInspectorUI instances will be released,
139 the latter will also be disposed, so that if anybody still holds a reference to them
140 and tries to operate them will get a DisposedException.
142 void SAL_CALL
dispose();
144 /** invokes m_pPropertyCheck to check whether a given property should be handled
146 bool shouldContinuePropertyHandling( const OUString
& _rName
) const;
149 /// determines whether the instance is already disposed
150 inline bool impl_isDisposed() const { return m_pCollectedUIs
.get() == NULL
; }
152 /// throws an exception if the component is already disposed
153 void impl_checkDisposed() const;
155 /** fires the collected UI changes to our delegator UI
157 All operations for any elements are forwarded:
158 <ul><li>If an element has been hidden at least once, it's also hidden at the delegator UI.</li>
159 <li>If an element has been shown at least once, and never been hidden, it's also
160 shown at the delegator UI.</li>
161 <li>If an element has never been shown or hidden, it's also not touched at the delegator UI.</li>
162 <li>The same holds if you replace "hidden" in the last three items with "disabled",
163 and "shown" with "enabled".</li>
164 <li>If an element should have been rebuilt (->XObjectInspectorUI::rebuiltPropertyUI)
165 at least once, it's rebuilt at the delegator UI, too.<br/>
166 After that, the request to rebuild the UI for this property is cleared, so subsequent
167 calls to ->fire will not trigger an new rebuilt request.
171 instance is not disposed
173 void impl_fireAll_throw();
175 /// fires the combination of ->XObjectInspectorUI::enablePropertyUI calls
176 void impl_fireEnablePropertyUI_throw();
178 /// fires the combination of ->XObjectInspectorUI::enablePropertyUIElements calls
179 void impl_fireEnablePropertyUIElements_throw();
181 /// fires the combination of ->XObjectInspectorUI::rebuildPropertyUI calls
182 void impl_fireRebuildPropertyUI_throw();
184 /// fires the combination of ->XObjectInspectorUI::showPropertyUI and ->XObjectInspectorUI::hidePropertyUI calls
185 void impl_fireShowHidePropertyUI_throw();
187 /// fires the combination of ->XObjectInspectorUI::showCategory calls
188 void impl_fireShowCategory_throw();
190 /** callback for when a single property handler requested any change in the inspector UI
192 void callback_inspectorUIChanged_throw();
195 ComposedPropertyUIUpdate(); // never implemented
196 ComposedPropertyUIUpdate( const ComposedPropertyUIUpdate
& ); // never implemented
197 ComposedPropertyUIUpdate
& operator=( const ComposedPropertyUIUpdate
& ); // never implemented
200 //====================================================================
201 //= ComposedUIAutoFireGuard
202 //====================================================================
203 class ComposedUIAutoFireGuard
206 ComposedPropertyUIUpdate
& m_rUIUpdate
;
208 ComposedUIAutoFireGuard( ComposedPropertyUIUpdate
& _rUIUpdate
)
209 :m_rUIUpdate( _rUIUpdate
)
211 m_rUIUpdate
.suspendAutoFire();
213 ~ComposedUIAutoFireGuard()
215 m_rUIUpdate
.resumeAutoFire();
219 //........................................................................
221 //........................................................................
223 #endif // EXTENSIONS_SOURCE_PROPCTRLR_COMPOSEDUIUPDATE_HXX
225 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */