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 _SBA_BWRCTRLR_HXX
21 #define _SBA_BWRCTRLR_HXX
23 #include <dbaccess/genericcontroller.hxx>
24 #include "moduledbu.hxx"
25 #include "brwview.hxx"
26 #include "sbagrid.hxx"
28 #include <com/sun/star/form/XLoadable.hpp>
29 #include <com/sun/star/container/XContainerListener.hpp>
30 #include <com/sun/star/sdb/XSQLErrorListener.hpp>
31 #include <com/sun/star/sdbc/XRowSet.hpp>
32 #include <com/sun/star/form/XResetListener.hpp>
33 #include <com/sun/star/form/XDatabaseParameterListener.hpp>
34 #include <com/sun/star/form/XConfirmDeleteListener.hpp>
35 #include <com/sun/star/form/XFormComponent.hpp>
36 #include <com/sun/star/awt/XFocusListener.hpp>
37 #include <com/sun/star/sdbcx/XColumnsSupplier.hpp>
38 #include <com/sun/star/sdb/XSingleSelectQueryComposer.hpp>
39 #include <com/sun/star/beans/XPropertyChangeListener.hpp>
40 #include <com/sun/star/frame/XModule.hpp>
42 #include <vcl/timer.hxx>
43 #include <svtools/transfer.hxx>
44 #include <osl/mutex.hxx>
45 #include <osl/thread.hxx>
46 #include <cppuhelper/implbase9.hxx>
47 #include <svtools/cliplistener.hxx>
49 struct FmFoundRecordInformation
;
50 struct FmSearchContext
;
54 class SQLExceptionInfo
;
59 // =========================================================================
61 typedef ::cppu::ImplInheritanceHelper9
< OGenericUnoController
62 , ::com::sun::star::sdb::XSQLErrorListener
63 , ::com::sun::star::form::XDatabaseParameterListener
64 , ::com::sun::star::form::XConfirmDeleteListener
65 , ::com::sun::star::form::XLoadListener
66 , ::com::sun::star::form::XResetListener
67 , ::com::sun::star::awt::XFocusListener
68 , ::com::sun::star::container::XContainerListener
69 , ::com::sun::star::beans::XPropertyChangeListener
70 , ::com::sun::star::frame::XModule
71 > SbaXDataBrowserController_Base
;
73 class SbaXDataBrowserController
:public SbaXDataBrowserController_Base
74 ,public SbaGridListener
79 // for implementing the XFormController
80 class FormControllerImpl
;
81 friend class FormControllerImpl
;
82 OModuleClient m_aModuleClient
;
84 ::com::sun::star::uno::Reference
< ::com::sun::star::sdbc::XRowSet
> m_xRowSet
; // our rowset
85 ::com::sun::star::uno::Reference
< ::com::sun::star::sdbcx::XColumnsSupplier
> m_xColumnsSupplier
; // queried from the rowset member
86 ::com::sun::star::uno::Reference
< ::com::sun::star::form::XLoadable
> m_xLoadable
; // queried from the rowset member as well
87 ::com::sun::star::uno::Reference
< ::com::sun::star::form::XFormComponent
> m_xGridModel
; // the model of our grid
88 ::com::sun::star::uno::Reference
< ::com::sun::star::util::XNumberFormatter
> m_xFormatter
; // a number formatter working with the connection's NumberFormatsSupplier
89 ::com::sun::star::uno::Reference
< ::com::sun::star::uno::XAggregation
> m_xFormControllerImpl
;
90 mutable ::com::sun::star::uno::Reference
< ::com::sun::star::sdb::XSingleSelectQueryComposer
>
91 m_xParser
; // for sorting 'n filtering
93 sal_Int32 m_nRowSetPrivileges
; // cached Privileges property of m_xRowSet
95 AutoTimer m_aInvalidateClipboard
; // for testing the state of the CUT/COPY/PASTE-slots
97 TransferableDataHelper m_aSystemClipboard
; // content of the clipboard
98 TransferableClipboardListener
*
99 m_pClipbordNotifier
; // notifier for changes in the clipboard
101 ::osl::Mutex m_aAsyncLoadSafety
; // for multi-thread access to our members
103 OAsyncronousLink m_aAsyncGetCellFocus
;
104 OAsyncronousLink m_aAsyncDisplayError
;
105 ::dbtools::SQLExceptionInfo m_aCurrentError
;
107 OUString m_sStateSaveRecord
;
108 OUString m_sStateUndoRecord
;
109 OUString m_sModuleIdentifier
;
111 // members for asynchronous load operations
112 FormControllerImpl
* m_pFormControllerImpl
; // implementing the XFormController
114 sal_uInt16 m_nFormActionNestingLevel
; // see enter-/leaveFormAction
116 sal_Bool m_bLoadCanceled
: 1; // the load was canceled somehow
117 bool m_bCannotSelectUnfiltered
: 1; // received an DATA_CANNOT_SELECT_UNFILTERED error
120 class FormErrorHelper
122 SbaXDataBrowserController
* m_pOwner
;
124 FormErrorHelper(SbaXDataBrowserController
* pOwner
) : m_pOwner(pOwner
) { m_pOwner
->enterFormAction(); }
125 virtual ~FormErrorHelper() { m_pOwner
->leaveFormAction(); }
127 friend class FormErrorHelper
;
132 ::com::sun::star::uno::Reference
< ::com::sun::star::sdbc::XRowSet
> getRowSet() const { return m_xRowSet
; }
133 ::com::sun::star::uno::Reference
< ::com::sun::star::sdbcx::XColumnsSupplier
> getColumnsSupplier()const { return m_xColumnsSupplier
; }
134 ::com::sun::star::uno::Reference
< ::com::sun::star::form::XLoadable
> getLoadable() const { return m_xLoadable
; }
136 ::com::sun::star::uno::Reference
< ::com::sun::star::form::XFormComponent
> getFormComponent() const { return m_xGridModel
; }
137 ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControlModel
> getControlModel() const { return ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControlModel
> (m_xGridModel
, ::com::sun::star::uno::UNO_QUERY
); }
138 ::com::sun::star::uno::Reference
< ::com::sun::star::util::XNumberFormatter
> getNumberFormatter()const { return m_xFormatter
; }
140 sal_Bool
isValid() const { return m_xRowSet
.is() && m_xGridModel
.is(); }
141 sal_Bool
isValidCursor() const; // checks the ::com::sun::star::data::XDatabaseCursor-interface of m_xRowSet
142 sal_Bool
isLoaded() const;
143 sal_Bool
loadingCancelled() const { return m_bLoadCanceled
; }
144 void onStartLoading( const ::com::sun::star::uno::Reference
< ::com::sun::star::form::XLoadable
>& _rxLoadable
);
145 void setLoadingCancelled() { m_bLoadCanceled
= sal_True
; }
147 const TransferableDataHelper
&
148 getViewClipboard() const { return m_aSystemClipboard
; }
151 SbaXDataBrowserController(const ::com::sun::star::uno::Reference
< ::com::sun::star::uno::XComponentContext
>& _rM
);
153 UnoDataBrowserView
* getBrowserView() const { return static_cast< UnoDataBrowserView
*>(getView()); }
155 virtual sal_Bool
Construct(Window
* pParent
);
158 virtual ::com::sun::star::uno::Any SAL_CALL
queryInterface(const ::com::sun::star::uno::Type
& _rType
) throw (::com::sun::star::uno::RuntimeException
);
161 virtual ::com::sun::star::uno::Sequence
< ::com::sun::star::uno::Type
> SAL_CALL
getTypes( ) throw (::com::sun::star::uno::RuntimeException
);
162 virtual ::com::sun::star::uno::Sequence
< sal_Int8
> SAL_CALL
getImplementationId( ) throw (::com::sun::star::uno::RuntimeException
);
164 // ::com::sun::star::lang::XEventListener
165 virtual void SAL_CALL
disposing(const ::com::sun::star::lang::EventObject
& Source
) throw( ::com::sun::star::uno::RuntimeException
);
167 // ::com::sun::star::util::XModifyListener
168 virtual void SAL_CALL
modified(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
170 // ::com::sun::star::container::XContainerListener
171 virtual void SAL_CALL
elementInserted(const ::com::sun::star::container::ContainerEvent
& Event
) throw( ::com::sun::star::uno::RuntimeException
);
172 virtual void SAL_CALL
elementRemoved(const ::com::sun::star::container::ContainerEvent
& Event
) throw( ::com::sun::star::uno::RuntimeException
);
173 virtual void SAL_CALL
elementReplaced(const ::com::sun::star::container::ContainerEvent
& Event
) throw( ::com::sun::star::uno::RuntimeException
);
175 // XPropertyChangeListener
176 virtual void SAL_CALL
propertyChange( const ::com::sun::star::beans::PropertyChangeEvent
& evt
) throw (::com::sun::star::uno::RuntimeException
);
179 virtual void SAL_CALL
setIdentifier( const OUString
& Identifier
) throw (::com::sun::star::uno::RuntimeException
);
180 virtual OUString SAL_CALL
getIdentifier( ) throw (::com::sun::star::uno::RuntimeException
);
182 // ::com::sun::star::awt::XFocusListener
183 virtual void SAL_CALL
focusGained(const ::com::sun::star::awt::FocusEvent
& e
) throw( ::com::sun::star::uno::RuntimeException
);
184 virtual void SAL_CALL
focusLost(const ::com::sun::star::awt::FocusEvent
& e
) throw( ::com::sun::star::uno::RuntimeException
);
186 // ::com::sun::star::frame::XController
187 virtual sal_Bool SAL_CALL
suspend(sal_Bool bSuspend
) throw( ::com::sun::star::uno::RuntimeException
);
189 // ::com::sun::star::lang::XComponent
190 virtual void SAL_CALL
disposing();
192 // ::com::sun::star::frame::XFrameActionListener
193 virtual void SAL_CALL
frameAction(const ::com::sun::star::frame::FrameActionEvent
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
195 // ::com::sun::star::sdb::XSQLErrorListener
196 virtual void SAL_CALL
errorOccured(const ::com::sun::star::sdb::SQLErrorEvent
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
198 // ::com::sun::star::form::XDatabaseParameterListener
199 virtual sal_Bool SAL_CALL
approveParameter(const ::com::sun::star::form::DatabaseParameterEvent
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
201 // ::com::sun::star::form::XConfirmDeleteListener
202 virtual sal_Bool SAL_CALL
confirmDelete(const ::com::sun::star::sdb::RowChangeEvent
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
204 // ::com::sun::star::form::XLoadListener
205 virtual void SAL_CALL
loaded(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
206 virtual void SAL_CALL
unloading(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
207 virtual void SAL_CALL
unloaded(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
208 virtual void SAL_CALL
reloading(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
209 virtual void SAL_CALL
reloaded(const ::com::sun::star::lang::EventObject
& aEvent
) throw( ::com::sun::star::uno::RuntimeException
);
211 // ::com::sun::star::form::XResetListener
212 virtual sal_Bool SAL_CALL
approveReset(const ::com::sun::star::lang::EventObject
& rEvent
) throw( ::com::sun::star::uno::RuntimeException
);
213 virtual void SAL_CALL
resetted(const ::com::sun::star::lang::EventObject
& rEvent
) throw( ::com::sun::star::uno::RuntimeException
);
216 virtual void RowChanged();
217 virtual void ColumnChanged();
218 virtual void SelectionChanged();
219 virtual void CellActivated();
220 virtual void CellDeactivated();
221 virtual void BeforeDrop();
222 virtual void AfterDrop();
227 virtual ~SbaXDataBrowserController();
229 // all the features which should be handled by this class
230 virtual void describeSupportedFeatures();
231 // state of a feature. 'feature' may be the handle of a ::com::sun::star::util::URL somebody requested a dispatch interface for OR a toolbar slot.
232 virtual FeatureState
GetState(sal_uInt16 nId
) const;
234 virtual void Execute(sal_uInt16 nId
, const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::PropertyValue
>& aArgs
);
236 virtual void startFrameListening( const ::com::sun::star::uno::Reference
< ::com::sun::star::frame::XFrame
>& _rxFrame
);
237 virtual void stopFrameListening( const ::com::sun::star::uno::Reference
< ::com::sun::star::frame::XFrame
>& _rxFrame
);
239 virtual ::com::sun::star::uno::Reference
< ::com::sun::star::sdbc::XRowSet
> CreateForm();
240 // our default implementation simply instantiates a stardiv.one.form.component.Form service
241 // (probably this needs not to be overloaded, but you may return anything you want as long as it
242 // supports the ::com::sun::star::form::DatabaseForm service. For instance you may want to create an adapter here which
243 // is synchronized with a foreign ::com::sun::star::form::DatabaseForm you got elsewhere)
244 virtual sal_Bool
InitializeForm(
245 const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
>& i_formProperties
) = 0;
246 // called immediately after a successful CreateForm
247 // do any initialization (data source etc.) here. the form should be fully functional after that.
248 // return sal_False if you didn't succeed (don't throw exceptions, they won't be caught)
250 virtual sal_Bool
InitializeGridModel(const ::com::sun::star::uno::Reference
< ::com::sun::star::form::XFormComponent
> & xGrid
);
253 virtual ::com::sun::star::uno::Reference
< ::com::sun::star::form::XFormComponent
> CreateGridModel();
254 // our default implementation simply instantiates a stardiv.one.form.component.Grid service
255 // you most probably don't want to override this behaviuor
257 // the default implementation of disposing distributes the events to the following disposingXXX functions
258 virtual void disposingGridControl(const ::com::sun::star::lang::EventObject
& Source
); // calls removeControlListeners
259 virtual void disposingGridModel(const ::com::sun::star::lang::EventObject
& Source
); // calls removeModelListeners
260 virtual void disposingFormModel(const ::com::sun::star::lang::EventObject
& Source
);
261 virtual void disposingColumnModel(const ::com::sun::star::lang::EventObject
& Source
);
263 // want to be a listener to the grid control ? use this !
264 virtual void addControlListeners(const ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControl
> & _xGridControl
);
265 virtual void removeControlListeners(const ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControl
> & _xGridControl
);
267 // want to be a listener to the grid model ? use this !
268 virtual void addModelListeners(const ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControlModel
> & _xGridControlModel
);
269 virtual void removeModelListeners(const ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControlModel
> & _xGridControlModel
);
271 // want to be a listener grid columns ? use this !
272 virtual void AddColumnListener(const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
> & xCol
);
273 virtual void RemoveColumnListener(const ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
> & xCol
);
276 // call after "major changes" (e.g. the completion of the async load).
277 // invalidates all toolbox slots and all supported features.
279 virtual sal_Bool
LoadForm();
281 // the default implementation does an direct load or starts a load thread, depending on the multithread capabilities
282 // of the data source.
283 // the default implementation also calls LoadFinished after a syncronous load, so be sure to do the same if you override
284 // this metod and don't call the base class' method
286 virtual void LoadFinished(sal_Bool bWasSynch
);
287 // called if the loading (the _complete_ loading process) is done (no matter if synchron or asynchron).
289 virtual void criticalFail();
290 // called whenever a reload operation on the rowset failed
291 // (a "operation" is not only a simple reload: If the user sets a filter, an reloading the form
292 // after setting this filter fails, the filter is reset and the form is reloaded, again. Only the
293 // whole process (_both_ XLoadable::reload calls _together_) form the "reload operation"
295 // --------------------
297 // empty the frame where our view resides
298 virtual sal_Bool
CommitCurrent();
299 // commit the current column (i.e. cell)
300 virtual sal_Bool
SaveModified(sal_Bool bAskFor
= sal_True
);
301 // save the modified record
303 ::com::sun::star::uno::Reference
< ::com::sun::star::beans::XPropertySet
> getBoundField(sal_uInt16 nViewPos
= (sal_uInt16
)-1) const;
304 // a PropertySet corresponding to the cursor field a column is bound to
305 // if nViewPos is (sal_uInt16)-1 (the default) then the field for the current column will be retrieved
307 void enterFormAction();
308 void leaveFormAction();
310 // init the formatter if form changes
311 void initFormatter();
313 /// loads or reloads the form
314 virtual sal_Bool
reloadForm(const ::com::sun::star::uno::Reference
< ::com::sun::star::form::XLoadable
>& _rxLoadable
);
316 virtual sal_Bool
preReloadForm(){ return sal_False
; }
317 virtual void postReloadForm(){}
319 ::com::sun::star::uno::Reference
< ::com::sun::star::sdb::XSingleSelectQueryComposer
>
320 createParser_nothrow();
323 void setCurrentModified( sal_Bool _bSet
);
325 // execute the filter or sort slot
326 void ExecuteFilterSortCrit(sal_Bool bFilter
);
328 // execute the search slot
329 void ExecuteSearch();
331 void initializeParser() const; // changes the mutable member m_xParser
332 void applyParserFilter(const OUString
& _rOldFilter
, sal_Bool _bOldFilterApplied
,const ::OUString
& _sOldHaving
,const ::com::sun::star::uno::Reference
< ::com::sun::star::sdb::XSingleSelectQueryComposer
>& _xParser
);
333 void applyParserOrder(const OUString
& _rOldOrder
,const ::com::sun::star::uno::Reference
< ::com::sun::star::sdb::XSingleSelectQueryComposer
>& _xParser
);
335 sal_Int16
getCurrentColumnPosition();
336 void setCurrentColumnPosition( sal_Int16 _nPos
);
337 void addColumnListeners(const ::com::sun::star::uno::Reference
< ::com::sun::star::awt::XControlModel
> & _xGridControlModel
);
339 void impl_checkForCannotSelectUnfiltered( const ::dbtools::SQLExceptionInfo
& _rError
);
341 // time to check the CUT/COPY/PASTE-slot-states
342 DECL_LINK( OnInvalidateClipboard
, AutoTimer
* );
343 DECL_LINK( OnClipboardChanged
, void* );
346 DECL_LINK(OnSearchContextRequest
, FmSearchContext
*);
347 DECL_LINK(OnFoundData
, FmFoundRecordInformation
*);
348 DECL_LINK(OnCanceledNotFound
, FmFoundRecordInformation
*);
350 DECL_LINK(OnAsyncGetCellFocus
, void*);
352 DECL_LINK( OnAsyncDisplayError
, void* );
356 #endif // _SBA_BWRCTRLR_HXX
358 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */