1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org. If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
26 ************************************************************************/
28 #ifndef EXTENSIONS_SOURCE_PROPCTRLR_EFORMSHELPER_HXX
29 #define EXTENSIONS_SOURCE_PROPCTRLR_EFORMSHELPER_HXX
31 #include "pcrcommon.hxx"
33 /** === begin UNO includes === **/
34 #include <com/sun/star/frame/XModel.hpp>
35 #include <com/sun/star/beans/XPropertySet.hpp>
36 #include <com/sun/star/xforms/XModel.hpp>
37 #include <com/sun/star/xforms/XFormsSupplier.hpp>
38 #include <com/sun/star/form/binding/XBindableValue.hpp>
39 #include <com/sun/star/form/binding/XListEntrySource.hpp>
40 /** === end UNO includes === **/
41 #include <osl/mutex.hxx>
42 #include <tools/string.hxx>
43 #include <comphelper/listenernotification.hxx>
49 //........................................................................
52 //........................................................................
54 typedef ::std::map
< ::rtl::OUString
, ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>, ::std::less
< ::rtl::OUString
> >
55 MapStringToPropertySet
;
57 //====================================================================
59 //====================================================================
63 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>
65 ::com::sun::star::uno::Reference
< ::com::sun::star::form::binding::XBindableValue
>
67 ::com::sun::star::uno::Reference
< ::com::sun::star::xforms::XFormsSupplier
>
69 PropertyChangeListeners
71 MapStringToPropertySet
72 m_aSubmissionUINames
; // only filled upon request
73 MapStringToPropertySet
74 m_aBindingUINames
; // only filled upon request
78 ::osl::Mutex
& _rMutex
,
79 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& _rxControlModel
,
80 const ::com::sun::star::uno::Reference
< ::com::sun::star::frame::XModel
>& _rxContextDocument
83 /** determines whether the given document is an eForm
85 If this method returns <FALSE/>, you cannot instantiate a EFormsHelper with
86 this document, since then no of it's functionality will be available.
90 const ::com::sun::star::uno::Reference
< ::com::sun::star::frame::XModel
>& _rxContextDocument
93 /** registers a listener to be notified when any aspect of the binding changes.
95 The listener will be registered at the current binding of the control model. If the binding
96 changes (see <method>setBinding</method>), the listener will be revoked from the old binding,
97 registered at the new binding, and for all properties which differ between both bindings,
98 the listener will be notified.
99 @see revokeBindingListener
101 void registerBindingListener(
102 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertyChangeListener
>& _rxBindingListener
105 /** revokes the binding listener which has previously been registered
106 @see registerBindingListener
108 void revokeBindingListener(
109 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertyChangeListener
>& _rxBindingListener
112 /** checks whether it's possible to bind the control model to a given XSD data type
115 the data type which should be bound. If this is -1, <TRUE/> is returned if the control model
116 can be bound to <em>any</em> data type.
118 bool canBindToDataType( sal_Int32 _nDataType
= -1 ) const SAL_THROW(());
120 /** checks whether the control model cna be bound to any XSD data type
122 bool canBindToAnyDataType() const SAL_THROW(()) { return canBindToDataType( -1 ); }
124 /** checks whether the control model is a source for list entries, as supplied by XML data bindings
126 bool isListEntrySink() const SAL_THROW(());
128 /** retrieves the names of all XForms models in the document the control lives in
130 void getFormModelNames( ::std::vector
< ::rtl::OUString
>& /* [out] */ _rModelNames
) const SAL_THROW(());
132 /** retrieves the names of all bindings for a given model
133 @see getFormModelNames
135 void getBindingNames( const ::rtl::OUString
& _rModelName
, ::std::vector
< ::rtl::OUString
>& /* [out] */ _rBindingNames
) const SAL_THROW(());
137 /// retrieves the XForms model (within the control model's document) with the given name
138 ::com::sun::star::uno::Reference
< ::com::sun::star::xforms::XModel
>
139 getFormModelByName( const ::rtl::OUString
& _rModelName
) const SAL_THROW(());
141 /** retrieves the model which the active binding of the control model belongs to
143 ::com::sun::star::uno::Reference
< ::com::sun::star::xforms::XModel
>
144 getCurrentFormModel() const SAL_THROW(());
146 /** retrieves the name of the model which the active binding of the control model belongs to
149 getCurrentFormModelName() const SAL_THROW(());
151 /** retrieves the binding instance which is currently attached to the control model
153 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>
154 getCurrentBinding() const SAL_THROW(());
156 /** retrieves the name of the binding instance which is currently attached to the control model
159 getCurrentBindingName() const SAL_THROW(());
161 /** sets a new binding at the control model
163 void setBinding( const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& _rxBinding
) SAL_THROW(());
165 /** retrieves the binding instance which is currently used as list source for the control model
168 ::com::sun::star::uno::Reference
< ::com::sun::star::form::binding::XListEntrySource
>
169 getCurrentListSourceBinding() const SAL_THROW(());
171 /** sets a new list source at the control model
174 void setListSourceBinding( const ::com::sun::star::uno::Reference
< ::com::sun::star::form::binding::XListEntrySource
>& _rxListSource
) SAL_THROW(());
176 /** retrieves a given binding for a given model, or creates a new one
179 the name of the model to create a binding for. Must not be empty
181 the name of the binding to retrieve. If the model denoted by <arg>_rTargetModel</arg> does not
182 have a binding with this name, a new binding is created and returned.
184 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>
185 getOrCreateBindingForModel( const ::rtl::OUString
& _rTargetModel
, const ::rtl::OUString
& _rBindingName
) const SAL_THROW(());
187 /** types of sub-elements of a model
189 enum ModelElementType
195 /** retrieves the name of a model's sub-element, as to be shown in the UI
196 @see getModelElementFromUIName
197 @see getAllElementUINames
200 getModelElementUIName(
201 const ModelElementType _eType
,
202 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& _rxElement
203 ) const SAL_THROW(());
205 /** retrieves the submission object for an UI name
207 Note that <member>getAllElementUINames</member> must have been called before, for the given element type
209 @see getModelElementUIName
210 @see getAllElementUINames
212 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>
213 getModelElementFromUIName(
214 const ModelElementType _eType
,
215 const ::rtl::OUString
& _rUIName
216 ) const SAL_THROW(());
218 /** retrieves the UI names of all elements of all models in our document
220 the type of elements for which the names should be retrieved
221 @param _rElementNames
222 the array of element names
223 @see getModelElementUIName
224 @see getModelElementFromUIName
226 void getAllElementUINames(
227 const ModelElementType _eType
,
228 ::std::vector
< ::rtl::OUString
>& /* [out] */ _rElementNames
,
229 bool _bPrepentEmptyEntry
233 void firePropertyChanges(
234 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& _rxOldProps
,
235 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& _rxNewProps
,
236 ::std::set
< ::rtl::OUString
>& _rFilter
239 /** fires a change in a single property, if the property value changed, and if we have a listener
240 interested in property changes
242 void firePropertyChange(
243 const ::rtl::OUString
& _rName
,
244 const ::com::sun::star::uno::Any
& _rOldValue
,
245 const ::com::sun::star::uno::Any
& _rNewValue
249 void impl_switchBindingListening_throw( bool _bDoListening
, const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertyChangeListener
>& _rxListener
);
251 /// implementation for both <member>getOrCreateBindingForModel</member>
252 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>
253 implGetOrCreateBinding( const ::rtl::OUString
& _rTargetModel
, const ::rtl::OUString
& _rBindingName
) const SAL_THROW(());
256 impl_toggleBindingPropertyListening_throw( bool _bDoListen
, const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertyChangeListener
>& _rxConcreteListenerOrNull
);
259 EFormsHelper(); // never implemented
260 EFormsHelper( const EFormsHelper
& ); // never implemented
261 EFormsHelper
& operator=( const EFormsHelper
& ); // never implemented
264 //........................................................................
266 //........................................................................
268 #endif // EXTENSIONS_SOURCE_PROPCTRLR_EFORMSHELPER_HXX