2004-08-02 14:28:20 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* $RCSfile: AppController.hxx,v $
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* $Revision: 1.11 $
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* last change: $Author: rt $ $Date: 2005-09-08 14:19:02 $
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* The Contents of this file are made available subject to
|
|
|
|
* the terms of GNU Lesser General Public License Version 2.1.
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2005 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* 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.
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* 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.
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
2005-09-08 13:19:02 +00:00
|
|
|
* 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
|
2004-08-02 14:28:20 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#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
|
2004-11-17 13:45:54 +00:00
|
|
|
#ifndef _DBAUI_DSNTYPES_HXX_
|
|
|
|
#include "dsntypes.hxx"
|
|
|
|
#endif
|
2005-01-21 16:05:23 +00:00
|
|
|
#ifndef DBUI_TABLECOPYHELPER_HXX
|
|
|
|
#include "TableCopyHelper.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBAUI_LINKEDDOCUMENTS_HXX_
|
|
|
|
#include "linkeddocuments.hxx"
|
|
|
|
#endif
|
2004-11-17 13:45:54 +00:00
|
|
|
|
2004-08-02 14:28:20 +00:00
|
|
|
#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;
|
|
|
|
private:
|
|
|
|
|
|
|
|
DECLARE_STL_USTRINGACCESS_MAP(::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >,TDataSourceConnections);
|
|
|
|
|
2005-01-21 16:05:23 +00:00
|
|
|
OTableCopyHelper::DropDescriptor m_aAsyncDrop;
|
2004-08-02 14:28:20 +00:00
|
|
|
TDataSourceConnections m_aDataSourceConnections;
|
|
|
|
TransferableDataHelper m_aSystemClipboard; // content of the clipboard
|
2005-03-10 15:43:32 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet > m_xDataSource;
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel > m_xModel;
|
2005-01-21 16:05:23 +00:00
|
|
|
TContainerVector m_aCurrentContainers; // the containers where we are listener on
|
2004-08-02 14:28:20 +00:00
|
|
|
TDocuments m_aDocuments;
|
2004-11-17 13:45:54 +00:00
|
|
|
ODsnTypeCollection m_aTypeCollection;
|
2005-01-21 16:05:23 +00:00
|
|
|
OTableCopyHelper m_aTableCopyHelper;
|
2004-08-02 14:28:20 +00:00
|
|
|
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
|
2004-09-09 08:38:40 +00:00
|
|
|
ElementType m_eOldType;
|
2004-08-02 14:28:20 +00:00
|
|
|
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;
|
|
|
|
|
2005-01-21 16:05:23 +00:00
|
|
|
/** return the element type for given container
|
|
|
|
@param _xContainer The container where the element type has to be found
|
|
|
|
@return the element type coressponding to the given container
|
|
|
|
*/
|
|
|
|
ElementType getElementType(const ::com::sun::star::uno::Reference< ::com::sun::star::container::XContainer >& _xContainer) const;
|
|
|
|
|
2004-08-02 14:28:20 +00:00
|
|
|
/** 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
|
2005-01-21 16:05:23 +00:00
|
|
|
@return the form or report model will only be returned, otherwise <NULL/>
|
2004-08-02 14:28:20 +00:00
|
|
|
*/
|
2005-01-21 16:05:23 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::lang::XComponent > openElement(const ::rtl::OUString& _sName,ElementType _eType = E_TABLE,OLinkedDocumentsAccess::EOpenMode _eOpenMode = OLinkedDocumentsAccess::OPEN_NORMAL);
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/** opens a new frame for creation or auto pilot
|
|
|
|
@param _eType
|
|
|
|
Defines the type to open
|
|
|
|
@param _bSQLView
|
|
|
|
If <TRUE/> the query design will be opened in SQL view, otherwise not.
|
|
|
|
*/
|
2005-01-21 16:05:23 +00:00
|
|
|
void newElement( ElementType _eType , sal_Bool _bSQLView );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
2005-01-21 16:05:23 +00:00
|
|
|
/** creates a new database object, using an auto pilot
|
|
|
|
@param _eType
|
|
|
|
Defines the type of the object to create
|
|
|
|
@precond
|
|
|
|
Our mutex must not be locked.
|
|
|
|
@since #i39203#
|
|
|
|
*/
|
|
|
|
void newElementWithPilot( ElementType _eType );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/** 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
|
|
|
|
*/
|
2004-10-22 10:59:25 +00:00
|
|
|
void getSelectionElementNames( ::std::vector< ::rtl::OUString>& _rNames );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/// deletes the entries selected.
|
|
|
|
void deleteEntries();
|
|
|
|
|
|
|
|
/// renames the selected entry in the detail page
|
|
|
|
void renameEntry();
|
|
|
|
|
2004-10-22 10:59:25 +00:00
|
|
|
/** deletes queries, forms, or reports
|
2004-08-02 14:28:20 +00:00
|
|
|
@param _eType
|
|
|
|
the type of the objects
|
|
|
|
@param _rList
|
2004-10-22 10:59:25 +00:00
|
|
|
The names of the elements to delete
|
|
|
|
@param _bConfirm
|
|
|
|
determines whether the user must confirm the deletion
|
2004-08-02 14:28:20 +00:00
|
|
|
*/
|
2004-10-22 10:59:25 +00:00
|
|
|
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 );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
/** 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);
|
|
|
|
|
2005-01-21 16:05:23 +00:00
|
|
|
/// returns the system clipboard.
|
|
|
|
const TransferableDataHelper& getViewClipboard() const { return m_aSystemClipboard; }
|
2004-08-02 14:28:20 +00:00
|
|
|
|
2005-01-21 16:05:23 +00:00
|
|
|
/// returns <TRUE/> if the clipboard supports a table format, otherwise <FALSE/>.
|
|
|
|
sal_Bool isTableFormat() const;
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/** 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.
|
|
|
|
*/
|
2005-01-21 16:05:23 +00:00
|
|
|
sal_Bool copyTagTable( OTableCopyHelper::DropDescriptor& _rDesc
|
|
|
|
, sal_Bool _bCheck);
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/** 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;
|
|
|
|
|
|
|
|
/** 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();
|
|
|
|
|
2005-03-10 15:43:32 +00:00
|
|
|
/** suspend one document.
|
|
|
|
@return
|
|
|
|
<TRUE/> if the document could be suspended, otherwise <FALSE/>.
|
|
|
|
*/
|
|
|
|
sal_Bool suspendDocument(const TDocuments::key_type& _xComponent,sal_Bool _bSuspend);
|
|
|
|
|
2004-08-02 14:28:20 +00:00
|
|
|
/** 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);
|
2004-09-09 08:38:40 +00:00
|
|
|
/** 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.
|
2005-01-21 16:05:23 +00:00
|
|
|
@param _eOpenMode
|
|
|
|
Defines the mode of opening. @see OLinkedDocumentsAccess::EOpenMode
|
2004-09-09 08:38:40 +00:00
|
|
|
*/
|
2005-01-21 16:05:23 +00:00
|
|
|
void doAction(sal_uInt16 _nId ,OLinkedDocumentsAccess::EOpenMode _eOpenMode);
|
2004-08-02 14:28:20 +00:00
|
|
|
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
|
2004-09-09 08:38:40 +00:00
|
|
|
virtual void Execute(sal_uInt16 nId, const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& aArgs);
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
// IControlActionListener overridables
|
|
|
|
virtual sal_Bool requestContextMenu( const CommandEvent& _rEvent );
|
2004-10-22 10:59:25 +00:00
|
|
|
virtual sal_Bool requestQuickHelp( const SvLBoxEntry* _pEntry, String& _rText ) const;
|
2004-08-02 14:28:20 +00:00
|
|
|
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( );
|
2005-03-01 18:14:41 +00:00
|
|
|
virtual void onLoadedMenu( const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XLayoutManager >& _xLayoutManager );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
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.
|
2005-01-21 16:05:23 +00:00
|
|
|
@return
|
|
|
|
<TRUE/> if and only if the conneciton could be established
|
2004-08-02 14:28:20 +00:00
|
|
|
*/
|
2005-01-21 16:05:23 +00:00
|
|
|
bool ensureConnection(::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _xConnection,sal_Bool _bCreate = sal_True);
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
/** 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>
|
2004-09-09 08:38:40 +00:00
|
|
|
virtual void onCreationClick(const ::rtl::OUString& _sCommand);
|
2004-08-02 14:28:20 +00:00
|
|
|
/// @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);
|
|
|
|
|
|
|
|
DECL_LINK( OnInvalidateClipboard, void* );
|
|
|
|
DECL_LINK( OnClipboardChanged, void* );
|
|
|
|
DECL_LINK( OnAsyncDrop, void* );
|
2005-01-21 16:05:23 +00:00
|
|
|
DECL_LINK( OnCreateWithPilot, void* );
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
// 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);
|
2004-11-16 13:30:18 +00:00
|
|
|
virtual void describeSupportedFeatures();
|
2004-08-02 14:28:20 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
|