2001-03-23 09:59:09 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: dsbrowserDnD.cxx,v $
|
|
|
|
*
|
2005-01-21 16:08:45 +00:00
|
|
|
* $Revision: 1.68 $
|
2001-03-23 09:59:09 +00:00
|
|
|
*
|
2005-01-21 16:08:45 +00:00
|
|
|
* last change: $Author: kz $ $Date: 2005-01-21 17:08:45 $
|
2001-03-23 09:59:09 +00:00
|
|
|
*
|
|
|
|
* 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): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _SBA_UNODATBR_HXX_
|
|
|
|
#include "unodatbr.hxx"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_COMMANDTYPE_HPP_
|
|
|
|
#include <com/sun/star/sdb/CommandType.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XCONNECTION_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XConnection.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef DBAUI_DBTREEMODEL_HXX
|
|
|
|
#include "dbtreemodel.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBACCESS_UI_DBTREEVIEW_HXX
|
|
|
|
#include "dbtreeview.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
|
|
|
|
#include "dbustrings.hrc"
|
|
|
|
#endif
|
2002-08-19 06:32:53 +00:00
|
|
|
#ifndef _DBU_BRW_HRC_
|
|
|
|
#include "dbu_brw.hrc"
|
2001-03-23 09:59:09 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _DBAUI_MODULE_DBU_HXX_
|
|
|
|
#include "moduledbu.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBHELPER_DBEXCEPTION_HXX_
|
|
|
|
#include <connectivity/dbexception.hxx>
|
|
|
|
#endif
|
2001-06-01 10:23:46 +00:00
|
|
|
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
|
|
|
|
#include <connectivity/dbtools.hxx>
|
|
|
|
#endif
|
2001-03-23 09:59:09 +00:00
|
|
|
#ifndef DBAUI_DBEXCHANGE_HXX
|
|
|
|
#include "dbexchange.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBAUI_ENUMTYPES_HXX
|
|
|
|
#include "QEnumTypes.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBAUI_TOOLS_HXX
|
|
|
|
#include "UITools.hxx"
|
|
|
|
#endif
|
2001-04-11 11:58:38 +00:00
|
|
|
#ifndef _SVX_DATACCESSDESCRIPTOR_HXX_
|
|
|
|
#include <svx/dataaccessdescriptor.hxx>
|
|
|
|
#endif
|
2004-08-02 14:33:59 +00:00
|
|
|
#ifndef DBAUI_DBTREELISTBOX_HXX
|
|
|
|
#include "dbtreelistbox.hxx"
|
2002-10-31 11:48:33 +00:00
|
|
|
#endif
|
2005-01-21 16:08:45 +00:00
|
|
|
#ifndef _COM_SUN_STAR_FRAME_XSTORABLE_HPP_
|
|
|
|
#include <com/sun/star/frame/XStorable.hpp>
|
|
|
|
#endif
|
2004-09-08 15:28:51 +00:00
|
|
|
#include <functional>
|
2001-03-23 09:59:09 +00:00
|
|
|
// .........................................................................
|
|
|
|
namespace dbaui
|
|
|
|
{
|
|
|
|
// .........................................................................
|
|
|
|
|
|
|
|
using namespace ::com::sun::star::uno;
|
|
|
|
using namespace ::com::sun::star::sdb;
|
|
|
|
using namespace ::com::sun::star::sdbc;
|
|
|
|
using namespace ::com::sun::star::sdbcx;
|
|
|
|
using namespace ::com::sun::star::beans;
|
|
|
|
using namespace ::com::sun::star::util;
|
|
|
|
using namespace ::com::sun::star::frame;
|
|
|
|
using namespace ::com::sun::star::container;
|
|
|
|
using namespace ::com::sun::star::lang;
|
|
|
|
using namespace ::com::sun::star::form;
|
|
|
|
using namespace ::com::sun::star::io;
|
|
|
|
using namespace ::com::sun::star::i18n;
|
2001-06-22 09:58:46 +00:00
|
|
|
using namespace ::com::sun::star::task;
|
2001-03-23 09:59:09 +00:00
|
|
|
using namespace ::com::sun::star::datatransfer;
|
|
|
|
using namespace ::dbtools;
|
2001-04-11 11:58:38 +00:00
|
|
|
using namespace ::svx;
|
2001-03-23 09:59:09 +00:00
|
|
|
|
2002-03-27 07:18:45 +00:00
|
|
|
// -----------------------------------------------------------------------------
|
2001-03-23 09:59:09 +00:00
|
|
|
TransferableHelper* SbaTableQueryBrowser::implCopyObject( SvLBoxEntry* _pApplyTo, sal_Int32 _nCommandType, sal_Bool _bAllowConnection )
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard(m_aEntryMutex);
|
|
|
|
|
2001-04-26 10:36:16 +00:00
|
|
|
::rtl::OUString aName = GetEntryText( _pApplyTo );
|
2004-10-22 11:03:31 +00:00
|
|
|
::rtl::OUString aDSName = getDataSourceAcessor( m_pTreeView->getListBox()->GetRootLevelParent( _pApplyTo ) );
|
2001-03-23 09:59:09 +00:00
|
|
|
|
2002-11-05 07:33:33 +00:00
|
|
|
ODataClipboard* pData = NULL;
|
|
|
|
Reference<XConnection> xConnection; // supports the service sdb::connection
|
|
|
|
if ( CommandType::QUERY != _nCommandType )
|
|
|
|
{
|
|
|
|
if (_bAllowConnection && !ensureConnection(_pApplyTo, xConnection))
|
|
|
|
return NULL;
|
|
|
|
pData = new ODataClipboard(aDSName, _nCommandType, aName, xConnection, getNumberFormatter(), getORB());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
pData = new ODataClipboard(aDSName, _nCommandType, aName, getNumberFormatter(), getORB());
|
|
|
|
|
|
|
|
// the owner ship goes to ODataClipboards
|
2001-03-23 09:59:09 +00:00
|
|
|
return pData;
|
|
|
|
}
|
|
|
|
catch(SQLException& e)
|
|
|
|
{
|
|
|
|
showError(SQLExceptionInfo(e));
|
|
|
|
}
|
|
|
|
catch(Exception&)
|
|
|
|
{
|
|
|
|
DBG_ERROR("SbaTableQueryBrowser::implCopyObject: caught a generic exception!");
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
sal_Int8 SbaTableQueryBrowser::queryDrop( const AcceptDropEvent& _rEvt, const DataFlavorExVector& _rFlavors )
|
|
|
|
{
|
2005-01-21 16:08:45 +00:00
|
|
|
// check if we're a table or query container
|
|
|
|
SvLBoxEntry* pHitEntry = m_pTreeView->getListBox()->GetEntry( _rEvt.maPosPixel );
|
|
|
|
|
|
|
|
if ( pHitEntry ) // no drop if no entry was hit ....
|
|
|
|
{
|
|
|
|
// it must be a container
|
|
|
|
EntryType eEntryType = getEntryType( pHitEntry );
|
|
|
|
Reference<XConnection> xConnection;
|
|
|
|
if ( eEntryType == etTableContainer && ensureConnection(pHitEntry,xConnection) && xConnection.is() )
|
|
|
|
{
|
|
|
|
Reference<XChild> xChild(xConnection,UNO_QUERY);
|
|
|
|
Reference<XStorable> xStore(xChild.is() ? xChild->getParent() : Reference<XInterface>(),UNO_QUERY);
|
|
|
|
// check for the concrete type
|
|
|
|
if ( xStore.is() && !xStore->isReadonly() && ::std::find_if(_rFlavors.begin(),_rFlavors.end(),TAppSupportedSotFunctor(E_TABLE,sal_True)) != _rFlavors.end())
|
|
|
|
return DND_ACTION_COPY;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-03-23 09:59:09 +00:00
|
|
|
return DND_ACTION_NONE;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
sal_Int8 SbaTableQueryBrowser::executeDrop( const ExecuteDropEvent& _rEvt )
|
|
|
|
{
|
2005-01-21 16:08:45 +00:00
|
|
|
SvLBoxEntry* pHitEntry = m_pTreeView->getListBox()->GetEntry( _rEvt.maPosPixel );
|
|
|
|
EntryType eEntryType = getEntryType( pHitEntry );
|
|
|
|
if (!isContainer(eEntryType))
|
|
|
|
{
|
|
|
|
DBG_ERROR("SbaTableQueryBrowser::executeDrop: what the hell did queryDrop do?");
|
|
|
|
// queryDrop shoud not have allowed us to reach this situation ....
|
|
|
|
return DND_ACTION_NONE;
|
|
|
|
}
|
|
|
|
// a TransferableDataHelper for accessing the dropped data
|
|
|
|
TransferableDataHelper aDroppedData(_rEvt.maDropEvent.Transferable);
|
|
|
|
|
|
|
|
|
|
|
|
// reset the data of the previous async drop (if any)
|
|
|
|
if ( m_nAsyncDrop )
|
|
|
|
Application::RemoveUserEvent(m_nAsyncDrop);
|
|
|
|
|
|
|
|
|
|
|
|
m_nAsyncDrop = 0;
|
|
|
|
m_aAsyncDrop.aDroppedData.clear();
|
|
|
|
m_aAsyncDrop.nType = E_TABLE;
|
|
|
|
m_aAsyncDrop.nAction = _rEvt.mnAction;
|
|
|
|
m_aAsyncDrop.bError = sal_False;
|
|
|
|
m_aAsyncDrop.bHtml = sal_False;
|
|
|
|
m_aAsyncDrop.pDroppedAt = NULL;
|
|
|
|
m_aAsyncDrop.aUrl = ::rtl::OUString();
|
|
|
|
|
|
|
|
|
|
|
|
// loop through the available formats and see what we can do ...
|
|
|
|
// first we have to check if it is our own format, if not we have to copy the stream :-(
|
|
|
|
if ( ODataAccessObjectTransferable::canExtractObjectDescriptor(aDroppedData.GetDataFlavorExVector()) )
|
|
|
|
{
|
|
|
|
m_aAsyncDrop.aDroppedData = ODataAccessObjectTransferable::extractObjectDescriptor(aDroppedData);
|
|
|
|
m_aAsyncDrop.pDroppedAt = pHitEntry;
|
|
|
|
|
|
|
|
// asyncron because we some dialogs and we aren't allowed to show them while in D&D
|
|
|
|
m_nAsyncDrop = Application::PostUserEvent(LINK(this, SbaTableQueryBrowser, OnAsyncDrop));
|
|
|
|
return DND_ACTION_COPY;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Reference<XConnection> xDestConnection; // supports the service sdb::connection
|
|
|
|
if ( ensureConnection(pHitEntry, xDestConnection) && xDestConnection.is() && m_aTableCopyHelper.copyTagTable(aDroppedData,m_aAsyncDrop,xDestConnection) )
|
|
|
|
{
|
|
|
|
m_aAsyncDrop.pDroppedAt = pHitEntry;
|
|
|
|
|
|
|
|
// asyncron because we some dialogs and we aren't allowed to show them while in D&D
|
|
|
|
m_nAsyncDrop = Application::PostUserEvent(LINK(this, SbaTableQueryBrowser, OnAsyncDrop));
|
|
|
|
return DND_ACTION_COPY;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-03-23 09:59:09 +00:00
|
|
|
return DND_ACTION_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
sal_Bool SbaTableQueryBrowser::requestDrag( sal_Int8 _nAction, const Point& _rPosPixel )
|
|
|
|
{
|
|
|
|
// get the affected list entry
|
|
|
|
// ensure that the entry which the user clicked at is selected
|
|
|
|
SvLBoxEntry* pHitEntry = m_pTreeView->getListBox()->GetEntry( _rPosPixel );
|
|
|
|
if (!pHitEntry)
|
|
|
|
// no drag of no entry was hit ....
|
|
|
|
return sal_False;
|
|
|
|
|
|
|
|
// it must be a query/table
|
|
|
|
EntryType eEntryType = getEntryType( pHitEntry );
|
|
|
|
if (!isObject(eEntryType))
|
|
|
|
return DND_ACTION_NONE;
|
|
|
|
|
2001-05-14 10:59:28 +00:00
|
|
|
TransferableHelper* pTransfer = implCopyObject( pHitEntry, (etTable == eEntryType || etView == eEntryType) ? CommandType::TABLE : CommandType::QUERY);
|
2001-03-23 09:59:09 +00:00
|
|
|
Reference< XTransferable> xEnsureDelete = pTransfer;
|
|
|
|
|
|
|
|
if (pTransfer)
|
|
|
|
pTransfer->StartDrag( m_pTreeView->getListBox(), DND_ACTION_COPY );
|
|
|
|
|
|
|
|
return NULL != pTransfer;
|
|
|
|
}
|
2001-04-06 12:48:34 +00:00
|
|
|
// -----------------------------------------------------------------------------
|
2001-07-18 10:34:19 +00:00
|
|
|
IMPL_LINK(SbaTableQueryBrowser, OnCopyEntry, SvLBoxEntry*, _pEntry)
|
|
|
|
{
|
2002-03-21 06:22:52 +00:00
|
|
|
if( isEntryCopyAllowed(_pEntry) )
|
2001-07-18 10:34:19 +00:00
|
|
|
copyEntry(_pEntry);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2002-04-16 16:01:04 +00:00
|
|
|
sal_Bool SbaTableQueryBrowser::isEntryCutAllowed(SvLBoxEntry* _pEntry) const
|
2001-07-18 10:34:19 +00:00
|
|
|
{
|
|
|
|
// at the momoent this isn't allowed
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2002-04-16 16:01:04 +00:00
|
|
|
sal_Bool SbaTableQueryBrowser::isEntryCopyAllowed(SvLBoxEntry* _pEntry) const
|
2001-07-18 10:34:19 +00:00
|
|
|
{
|
|
|
|
EntryType eType = getEntryType(_pEntry);
|
|
|
|
return (eType == etTable || eType == etQuery || eType == etView);
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2002-04-16 16:01:04 +00:00
|
|
|
sal_Bool SbaTableQueryBrowser::isEntryPasteAllowed(SvLBoxEntry* _pEntry) const
|
2001-07-18 10:34:19 +00:00
|
|
|
{
|
2004-08-02 14:33:59 +00:00
|
|
|
return sal_False;
|
2001-07-18 10:34:19 +00:00
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
void SbaTableQueryBrowser::copyEntry(SvLBoxEntry* _pEntry)
|
|
|
|
{
|
|
|
|
TransferableHelper* pTransfer = NULL;
|
|
|
|
Reference< XTransferable> aEnsureDelete;
|
|
|
|
EntryType eType = getEntryType(_pEntry);
|
|
|
|
pTransfer = implCopyObject( _pEntry, eType == etQuery ? CommandType::QUERY : CommandType::TABLE);
|
|
|
|
aEnsureDelete = pTransfer;
|
|
|
|
if (pTransfer)
|
|
|
|
pTransfer->CopyToClipboard(getView());
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2005-01-21 16:08:45 +00:00
|
|
|
sal_Bool SbaTableQueryBrowser::copyTagTable(OTableCopyHelper::DropDescriptor& _rDesc, sal_Bool _bCheck)
|
|
|
|
{
|
|
|
|
// first get the dest connection
|
|
|
|
::osl::MutexGuard aGuard(m_aMutex);
|
|
|
|
|
|
|
|
Reference<XConnection> xDestConnection; // supports the service sdb::connection
|
|
|
|
if (!ensureConnection(_rDesc.pDroppedAt, xDestConnection) )
|
|
|
|
return sal_False;
|
|
|
|
|
|
|
|
return m_aTableCopyHelper.copyTagTable(_rDesc, _bCheck,xDestConnection);
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
IMPL_LINK( SbaTableQueryBrowser, OnAsyncDrop, void*, NOTINTERESTEDIN )
|
|
|
|
{
|
|
|
|
m_nAsyncDrop = 0;
|
|
|
|
::vos::OGuard aSolarGuard( Application::GetSolarMutex() );
|
|
|
|
::osl::MutexGuard aGuard(m_aMutex);
|
|
|
|
|
|
|
|
|
|
|
|
if ( m_aAsyncDrop.nType == E_TABLE )
|
|
|
|
{
|
|
|
|
Reference<XConnection> xDestConnection; // supports the service sdb::connection
|
|
|
|
if ( ensureConnection(m_aAsyncDrop.pDroppedAt, xDestConnection) && xDestConnection.is() )
|
|
|
|
{
|
|
|
|
SvLBoxEntry* pDataSourceEntry = m_pTreeView->getListBox()->GetRootLevelParent(m_aAsyncDrop.pDroppedAt);
|
|
|
|
m_aTableCopyHelper.asyncCopyTagTable(m_aAsyncDrop,getDataSourceAcessor( pDataSourceEntry ),xDestConnection);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
m_aAsyncDrop.aDroppedData.clear();
|
|
|
|
|
|
|
|
return 0L;
|
|
|
|
}
|
|
|
|
// -----------------------------------------------------------------------------
|
2005-01-05 11:33:32 +00:00
|
|
|
void SbaTableQueryBrowser::clearTreeModel()
|
|
|
|
{
|
|
|
|
if (m_pTreeModel)
|
|
|
|
{
|
|
|
|
// clear the user data of the tree model
|
|
|
|
SvLBoxEntry* pEntryLoop = m_pTreeModel->First();
|
|
|
|
while (pEntryLoop)
|
|
|
|
{
|
|
|
|
DBTreeListModel::DBTreeListUserData* pData = static_cast<DBTreeListModel::DBTreeListUserData*>(pEntryLoop->GetUserData());
|
|
|
|
if(pData)
|
|
|
|
{
|
|
|
|
pEntryLoop->SetUserData(NULL);
|
|
|
|
Reference< XContainer > xContainer(pData->xObject, UNO_QUERY);
|
|
|
|
if (xContainer.is())
|
|
|
|
xContainer->removeContainerListener(this);
|
|
|
|
|
|
|
|
Reference<XConnection> xCon(pData->xObject,UNO_QUERY);
|
|
|
|
if(xCon.is())
|
|
|
|
{
|
|
|
|
Reference< XComponent > xComponent(xCon, UNO_QUERY);
|
|
|
|
if (xComponent.is())
|
|
|
|
{
|
|
|
|
Reference< ::com::sun::star::lang::XEventListener> xEvtL((::cppu::OWeakObject*)this,UNO_QUERY);
|
|
|
|
xComponent->removeEventListener(xEvtL);
|
|
|
|
}
|
|
|
|
::comphelper::disposeComponent(pData->xObject);
|
|
|
|
}
|
|
|
|
|
|
|
|
pData->xObject.clear();
|
|
|
|
delete pData;
|
|
|
|
}
|
|
|
|
pEntryLoop = m_pTreeModel->Next(pEntryLoop);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
m_pCurrentlyDisplayed = NULL;
|
|
|
|
}
|
2001-03-23 09:59:09 +00:00
|
|
|
// .........................................................................
|
|
|
|
} // namespace dbaui
|
|
|
|
// .........................................................................
|
|
|
|
|