1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
|
/*************************************************************************
*
* $RCSfile: AppController.hxx,v $
*
* $Revision: 1.6 $
*
* last change: $Author: obo $ $Date: 2004-11-16 14:30:18 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc..
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): Ocke Janssen
*
*
************************************************************************/
#ifndef DBAUI_APPCONTROLLER_HXX
#define DBAUI_APPCONTROLLER_HXX
#ifndef DBAUI_GENERICCONTROLLER_HXX
#include "genericcontroller.hxx"
#endif
#ifndef _COM_SUN_STAR_CONTAINER_XCONTAINERLISTENER_HPP_
#include <com/sun/star/container/XContainerListener.hpp>
#endif
#ifndef _SV_TIMER_HXX
#include <vcl/timer.hxx>
#endif
#ifndef _CPPUHELPER_IMPLBASE2_HXX_
#include <cppuhelper/implbase2.hxx>
#endif
#ifndef _COMPHELPER_STLTYPES_HXX_
#include <comphelper/stl_types.hxx>
#endif
#ifndef _COMPHELPER_UNO3_HXX_
#include <comphelper/uno3.hxx>
#endif
#ifndef _TRANSFER_HXX
#include <svtools/transfer.hxx>
#endif
#ifndef _SVX_DATACCESSDESCRIPTOR_HXX_
#include <svx/dataaccessdescriptor.hxx>
#endif
#ifndef DBAUI_APPELEMENTTYPE_HXX
#include "AppElementType.hxx"
#endif
#ifndef _SOT_STORAGE_HXX
#include <sot/storage.hxx>
#endif
#ifndef DBAUI_IAPPELEMENTNOTIFICATION_HXX
#include "IAppElementNotification.hxx"
#endif
#ifndef _COM_SUN_STAR_BEANS_XPROPERTYCHANGELISTENER_HPP_
#include <com/sun/star/beans/XPropertyChangeListener.hpp>
#endif
#ifndef _DBACCESS_UI_CALLBACKS_HXX_
#include "callbacks.hxx"
#endif
#include <memory>
class ListBox;
class SvLBoxEntry;
class SvTreeListBox;
class TransferableHelper;
class TransferableClipboardListener;
class SfxFilter;
FORWARD_DECLARE_INTERFACE(container,XNameContainer)
FORWARD_DECLARE_INTERFACE(container,XContainer)
FORWARD_DECLARE_INTERFACE(util,XNumberFormatter)
FORWARD_DECLARE_INTERFACE(util,XCloseable)
FORWARD_DECLARE_INTERFACE(ucb,XContent)
//........................................................................
namespace dbaui
{
//........................................................................
//====================================================================
//= OApplicationController
//====================================================================
class OApplicationController;
class OApplicationView;
class OLinkedDocumentsAccess;
typedef OGenericUnoController OApplicationController_CBASE;
typedef ::cppu::ImplHelper2 < ::com::sun::star::container::XContainerListener,
::com::sun::star::beans::XPropertyChangeListener
> OApplicationController_Base;
class OApplicationController
:public OApplicationController_CBASE
,public OApplicationController_Base
,public IApplicationElementNotification
,public IControlActionListener
,public IContainerFoundListener
,public IViewChangeListener
{
friend class OConnectionChangeBroadcaster;
public:
typedef ::std::vector< ::com::sun::star::uno::Reference< ::com::sun::star::container::XContainer > > TContainerVector;
typedef ::std::map< ::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent >
, ::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent > > TDocuments;
protected:
// is needed to describe the drop target
struct DropDescriptor
{
::svx::ODataAccessDescriptor aDroppedData;
String aUrl;
SotStorageStreamRef aHtmlRtfStorage;
ElementType nType;
sal_Int8 nAction;
sal_Bool bHtml;
sal_Bool bError;
DropDescriptor() : nType(E_TABLE),nAction(DND_ACTION_NONE) { }
};
private:
DECLARE_STL_USTRINGACCESS_MAP(::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >,TDataSourceConnections);
DropDescriptor m_aAsyncDrop;
TDataSourceConnections m_aDataSourceConnections;
TransferableDataHelper m_aSystemClipboard; // content of the clipboard
::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet > m_xDataSource;
::com::sun::star::uno::Reference< ::com::sun::star::container::XContainer >
m_xCurrentContainer; // the container we listen on at the moment
TContainerVector m_aCurrentSubContainers; // the sub container of our current container
TDocuments m_aDocuments;
TransferableClipboardListener*
m_pClipbordNotifier; // notifier for changes in the clipboard
mutable ::rtl::OUString m_sDatabaseName;
sal_Int32 m_nAsyncDrop;
PreviewMode m_ePreviewMode; // the mode of the preview
ElementType m_eOldType;
sal_Bool m_bPreviewEnabled; // true when the preview should enabled
sal_Bool m_bNeedToReconnect; // true when the settings of the data source were modified and the connection is no longer up to date
sal_Bool m_bSuspended : 1; // is true when the controller was already suspended
OApplicationView* getContainer() const;
/** returns the database name
@return
the database name
*/
inline ::rtl::OUString getDatabaseName() const { return m_sDatabaseName; }
/** returns the stripped database name.
@return
The stripped database name either the registered naem or if it is a file url the last segment.
*/
::rtl::OUString getStrippedDatabaseName() const;
/** opens a new frame with either the table or the query or report or form or view
@param _sName
The name of the object to open
@param _eType
Defines the type to open
@param _bOpenDesignMode
If <TRUE/> the design mode opens for the element
*/
void openElement(const ::rtl::OUString& _sName,ElementType _eType = E_TABLE,sal_Bool _bOpenDesignMode = sal_False);
/** opens a new frame for creation or auto pilot
@param _eType
Defines the type to open
@param _bAutoPilot
If <TRUE/> the auto pilot opens, otherwise not.
@param _bSQLView
If <TRUE/> the query design will be opened in SQL view, otherwise not.
*/
void newElement(ElementType _eType = E_TABLE,sal_Bool _bAutoPilot = sal_False,sal_Bool _bSQLView = sal_False);
/** converts the query to a view
@param _sName
The name of the query.
*/
void convertToView(const ::rtl::OUString& _sName);
/** checks if the selected data source is read only
@return
<TRUE/> if read only, otherwise <FALSE/>
*/
virtual sal_Bool isDataSourceReadOnly() const;
/** checks if the connection for the selected data source is read only. If the connection doesn't exist, <TRUE/> will be returned.
@return
<TRUE/> if read only or doesn't exist, otherwise <FALSE/>
*/
sal_Bool isConnectionReadOnly() const;
/** checks if the database allows the creation of relation
@return
<TRUE/> if read only, otherwise <FALSE/>
*/
sal_Bool isRelationDesignAllowed() const;
/** fills the list with the selected entries.
@param _rNames
*/
void getSelectionElementNames( ::std::vector< ::rtl::OUString>& _rNames );
/// deletes the entries selected.
void deleteEntries();
/// renames the selected entry in the detail page
void renameEntry();
/** deletes queries, forms, or reports
@param _eType
the type of the objects
@param _rList
The names of the elements to delete
@param _bConfirm
determines whether the user must confirm the deletion
*/
void deleteObjects( ElementType _eType,
const ::std::vector< ::rtl::OUString>& _rList,
bool _bConfirm );
/** deletes multiple elements from the given container
@param _rxNames
the object container
@param _rList
The names of the elements to delete
@param _bConfirm
determines whether the user must confirm the deletion
*/
void deleteObjects( const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameContainer>& _rxNames,
const ::std::vector< ::rtl::OUString>& _rList,
bool _bConfirm );
/** deletes tables.
@param _rList
The list of tables.
*/
void deleteTables(const ::std::vector< ::rtl::OUString>& _rList);
/// copies the current object into clipboard
TransferableHelper* copyObject();
/** fills all elements of the wanted type into the list.
@param _eType
The type.
@param _rList
The list to fill.
*/
void getElements(ElementType _eType,::std::vector< ::rtl::OUString>& _rList);
/// returns the nameaccess
::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess > getElements(ElementType _eType);
///
/** returns the document access for the specific type
@param _eType
the type
@return ::std::auto_ptr<OLinkedDocumentsAccess>
*/
::std::auto_ptr<OLinkedDocumentsAccess> getDocumentsAccess(ElementType _eType);
/// returns the query definitions of the active data source.
::com::sun::star::uno::Reference< ::com::sun::star::container::XNameContainer> getQueryDefintions() const;
/** pastes a special format from the system clipboard to the currently selected object types
@param _nFormatId
The format to be copied.
*/
void pasteFormat(sal_uInt32 _nFormatId);
/** pastes a query, form or report into the data source
@param _eType
The type of the object to paste.
@param _rPasteData
The data descriptor.
@param _sParentFolder
The name of the parent folder if it exists.
@param _bMove
if <TRUE/> the name of the content must be inserted without any change, otherwise not.
@return
<TRUE/> if the paste opertions was successfull, otherwise <FALSE/>.
*/
sal_Bool paste( ElementType _eType,const ::svx::ODataAccessDescriptor& _rPasteData ,const String& _sParentFolder = String(),sal_Bool _bMove = sal_False);
/** pastes a table into the data source
@param _rPasteData
The data helper.
*/
void pasteTable( const TransferableDataHelper& _rTransData );
/** pastes a table into the data source
@param _nFormatId
The format which should be copied.
@param _rPasteData
The data helper.
*/
void pasteTable( SotFormatStringId _nFormatId,const TransferableDataHelper& _rTransData );
/** pastes a table into the data source
@param _rPasteData
The data descriptor.
*/
void pasteTable( const ::svx::ODataAccessDescriptor& _rPasteData );
/** insert a table into the data source. The source can eihter be a table or a query
@param _nCommandType
The command type.
@param _xSrcConnection
The connection of the source.
@param _xSrcRs
The ResultSet of the source.
@param _aSelection
The selection of the rows to copy.
@param _bBookmarkSelection
If <TRUE/> the selection is bookmark selection.
@param _sCommand
The name of the query or table.
@param _sSrcDataSourceName
The name of the source data source.
*/
void insertTable( sal_Int32 _nCommandType
,const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection>& _xSrcConnection
,const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSet>& _xSrcRs // the source resultset may be empty
,const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any >& _aSelection
,sal_Bool _bBookmarkSelection
,const ::rtl::OUString& _sCommand
,const ::rtl::OUString& _sSrcDataSourceName);
/** copies a table which was constructed by tags like HTML or RTF
@param _rDesc
The Drop descriptor
@param _bCheck
If set to <TRUE/> than the controller checks only if a copy is possible.
*/
sal_Bool copyTagTable(DropDescriptor& _rDesc, sal_Bool _bCheck);
/// returns the system clipboard.
const TransferableDataHelper& getViewClipboard() const { return m_aSystemClipboard; }
/// returns <TRUE/> if the clipboard supports a table format, otherwise <FALSE/>.
sal_Bool isTableFormat() const;
/** fills the vector with all supported formats
@param _eType
The type for which we need the formats
@param _rFormatIds
The vector to be filled up.
*/
void getSupportedFormats(ElementType _eType,::std::vector<SotFormatStringId>& _rFormatIds) const;
/** crates a number formatter
@param _rxConnection
The connection is needed to create the formatter
*/
::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormatter > getNumberFormatter(const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _rxConnection ) const;
/** adds a listener to the current name access.
@param _xCollection
The collection where we want to listen on.
*/
void addContainerListener(const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess>& _xCollection);
/** opens a uno dialog withthe currently selected data source as initialize argument
@param _sServiceName
The serivce name of the dialog to be executed.
*/
void openDialog(const ::rtl::OUString& _sServiceName);
/** opens the administration dialog for the selected data source
*/
void openDataSourceAdminDialog();
/** opens the table filter dialog for the selected data source
*/
void openTableFilterDialog();
/** opens the DirectSQLDialog to execute hand made sql statements.
*/
void openDirectSQLDialog();
/** when the settings of the data source changed,
it opens a dialog which ask to close all depending documents, then recreate the connection.
The SolarMutex has to be locked before calling this.
*/
void askToReconnect();
/** suspend all open documents.
@return
<TRUE/> if all documents could be suspended, otherwise <FALSE/>.
*/
sal_Bool suspendDocuments(sal_Bool bSuspend);
/** disposes all created connections
*/
void clearConnections();
/** add event listener and remember the document
@param _xDocument
the new document, may be <NULL/>
@param _xDefinition
The defintion object.
*/
void addDocumentListener(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent >& _xDocument,
const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent >& _xDefinition);
/** Inserts a new object into the hierachy given be the type.
@param _eType
Where to insert the new item.
@param _sParentFolder
The name of the parent folder if it exists.
@param _xContent
The content to insert.
@param _bMove
if <TRUE/> the name of the content must be inserted without any change, otherwise not.
@return
<TRUE/> if the insert opertions was successfull, otherwise <FALSE/>.
*/
sal_Bool insertHierachyElement( ElementType _eType
,const String& _sParentFolder
,sal_Bool _bCollection = sal_True
,const ::com::sun::star::uno::Reference< ::com::sun::star::ucb::XContent>& _xContent = ::com::sun::star::uno::Reference< ::com::sun::star::ucb::XContent>()
,sal_Bool _bMove = sal_False);
/** checks if delete command or rename comamnd is allowed
@param _eType
The element type.
@param _bDelete
If <TRUE> then the delete command should be checked.
@return
<TRUE> if the command is allowed
*/
sal_Bool isRenameDeleteAllowed(ElementType _eType,sal_Bool _bDelete) const;
/** all selected entries will be opened, or edited, or converted to a view
@param _nId
The slot which should be executed.
@param _bEdit
If <TRUE/> it was a edit command.
*/
void doAction(sal_uInt16 _nId ,sal_Bool _bEdit);
protected:
// ----------------------------------------------------------------
// initalizing members
/** forces usage of a connection which we do not own
<p>To be used from within XInitialization::initialize only.</p>
*/
void initializeConnection( const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _rxForeignConn );
// 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.
virtual FeatureState GetState(sal_uInt16 nId) const;
// execute a feature
virtual void Execute(sal_uInt16 nId, const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& aArgs);
// IControlActionListener overridables
virtual sal_Bool requestContextMenu( const CommandEvent& _rEvent );
virtual sal_Bool requestQuickHelp( const SvLBoxEntry* _pEntry, String& _rText ) const;
virtual sal_Bool requestDrag( sal_Int8 _nAction, const Point& _rPosPixel );
virtual sal_Int8 queryDrop( const AcceptDropEvent& _rEvt, const DataFlavorExVector& _rFlavors );
virtual sal_Int8 executeDrop( const ExecuteDropEvent& _rEvt );
// OGenericUnoController
virtual void updateTitle( );
virtual void onLoadedMenu( const ::com::sun::star::uno::Reference< drafts::com::sun::star::frame::XLayoutManager >& _xLayoutManager );
virtual void impl_initialize( const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any >& aArguments );
virtual ~OApplicationController();
public:
OApplicationController(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& _rxORB);
DECLARE_XINTERFACE( )
DECLARE_XTYPEPROVIDER( )
// XServiceInfo
virtual ::rtl::OUString SAL_CALL getImplementationName() throw(::com::sun::star::uno::RuntimeException);
virtual ::com::sun::star::uno::Sequence< ::rtl::OUString> SAL_CALL getSupportedServiceNames() throw(::com::sun::star::uno::RuntimeException);
// need by registration
static ::rtl::OUString getImplementationName_Static() throw( ::com::sun::star::uno::RuntimeException );
static ::com::sun::star::uno::Sequence< ::rtl::OUString > getSupportedServiceNames_Static(void) throw( ::com::sun::star::uno::RuntimeException );
static ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >
SAL_CALL Create(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >&);
// ::com::sun::star::frame::XController
virtual sal_Bool SAL_CALL suspend(sal_Bool bSuspend) throw( ::com::sun::star::uno::RuntimeException );
virtual sal_Bool SAL_CALL attachModel(const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel > & xModel) throw( ::com::sun::star::uno::RuntimeException );
virtual ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel > SAL_CALL getModel(void) throw( ::com::sun::star::uno::RuntimeException );
// ::com::sun::star::frame::XFrameActionListener
virtual void SAL_CALL frameAction(const ::com::sun::star::frame::FrameActionEvent& aEvent) throw( ::com::sun::star::uno::RuntimeException );
// ::com::sun::star::container::XContainerListener
virtual void SAL_CALL elementInserted(const ::com::sun::star::container::ContainerEvent& Event) throw( ::com::sun::star::uno::RuntimeException );
virtual void SAL_CALL elementRemoved(const ::com::sun::star::container::ContainerEvent& Event) throw( ::com::sun::star::uno::RuntimeException );
virtual void SAL_CALL elementReplaced(const ::com::sun::star::container::ContainerEvent& Event) throw( ::com::sun::star::uno::RuntimeException );
// XPropertyChangeListener
virtual void SAL_CALL propertyChange( const ::com::sun::star::beans::PropertyChangeEvent& evt ) throw (::com::sun::star::uno::RuntimeException);
/** ensures that a connection for the selected data source exists
@param _xConnection
The new connection
@param _bCreate
If set to <TRUE/> than the connection will be created if it doesn't exist.
*/
void ensureConnection(::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _xConnection,sal_Bool _bCreate = sal_True);
/** returns the connection for the currently active data source
@return
The connection for the currently active data source
*/
::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection > getActiveConnection() const;
/** refreshes the tables
*/
void refreshTables();
/** closes the connection of the select data source
*/
void closeConnection();
/// @see <method>IApplicationElementNotification::onEntryDoubleClick</method>
virtual void onEntryDoubleClick(SvTreeListBox* _pTree);
/// @see <method>IApplicationElementNotification::onCreationClick</method>
virtual void onCreationClick(const ::rtl::OUString& _sCommand);
/// @see <method>IApplicationElementNotification::onContainerSelect</method>
virtual sal_Bool onContainerSelect(ElementType _eType);
/// @see <method>IApplicationElementNotification::onEntrySelect</method>
virtual void onEntrySelect(SvLBoxEntry* _pEntry);
/// @see <method>IApplicationElementNotification::onEntryDeSelect</method>
virtual void onEntryDeSelect(SvTreeListBox* _pTree);
/// @see <method>IApplicationElementNotification::onCutEntry</method>
virtual void onCutEntry(SvLBoxEntry* _pEntry);
/// @see <method>IApplicationElementNotification::onCopyEntry</method>
virtual void onCopyEntry(SvLBoxEntry* _pEntry);
/// @see <method>IApplicationElementNotification::onPasteEntry</method>
virtual void onPasteEntry(SvLBoxEntry* _pEntry);
/// @see <method>IApplicationElementNotification::onDeleteEntry</method>
virtual void onDeleteEntry(SvLBoxEntry* _pEntry);
// time to check the CUT/COPY/PASTE-slot-states
DECL_LINK( OnInvalidateClipboard, void* );
DECL_LINK( OnClipboardChanged, void* );
DECL_LINK( OnAsyncDrop, void* );
// IContainerFoundListener
virtual void containerFound( const ::com::sun::star::uno::Reference< ::com::sun::star::container::XContainer >& _xContainer);
// IViewChangeListener
virtual void previewChanged( sal_Int32 _nMode);
protected:
/** the connection will be disposed and set to NULL
@param _xConnection
the connection to be disposed
*/
virtual void disconnect(::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _xConnection);
// late construction
virtual sal_Bool Construct(Window* pParent);
virtual void describeSupportedFeatures();
protected:
// XEventListener
virtual void SAL_CALL disposing(const ::com::sun::star::lang::EventObject& Source) throw( ::com::sun::star::uno::RuntimeException );
// OComponentHelper
virtual void SAL_CALL disposing();
};
//........................................................................
} // namespace dbaui
//........................................................................
#endif // DBAUI_APPCONTROLLER_HXX
|