Files
libreoffice/dbaccess/source/ui/querydesign/JoinController.cxx

486 lines
18 KiB
C++
Raw Normal View History

2001-02-28 09:16:07 +00:00
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
2001-02-28 09:16:07 +00:00
*
* $RCSfile: JoinController.cxx,v $
2001-02-28 09:16:07 +00:00
*
* $Revision: 1.35 $
2001-02-28 09:16:07 +00:00
*
* last change: $Author: hr $ $Date: 2005-09-23 12:41:49 $
2001-02-28 09:16:07 +00:00
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
2001-02-28 09:16:07 +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
2001-02-28 09:16:07 +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.
2001-02-28 09:16:07 +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.
2001-02-28 09:16:07 +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
2001-02-28 09:16:07 +00:00
*
************************************************************************/
#ifndef _SFXSIDS_HRC
#include <sfx2/sfxsids.hrc>
#endif
2002-08-19 07:01:32 +00:00
#ifndef _DBU_QRY_HRC_
#include "dbu_qry.hrc"
2001-02-28 09:16:07 +00:00
#endif
#ifndef DBACCESS_UI_BROWSER_ID_HXX
#include "browserids.hxx"
#endif
#ifndef _COMPHELPER_TYPES_HXX_
#include <comphelper/types.hxx>
#endif
#ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
#include "dbustrings.hrc"
#endif
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
#include <connectivity/dbtools.hxx>
#endif
#ifndef _COM_SUN_STAR_FRAME_FRAMESEARCHFLAG_HPP_
#include <com/sun/star/frame/FrameSearchFlag.hpp>
#endif
#ifndef _COMPHELPER_EXTRACT_HXX_
#include <comphelper/extract.hxx>
2001-02-28 09:16:07 +00:00
#endif
#ifndef _COM_SUN_STAR_CONTAINER_XCHILD_HPP_
#include <com/sun/star/container/XChild.hpp>
#endif
#ifndef _COM_SUN_STAR_CONTAINER_XNAMECONTAINER_HPP_
#include <com/sun/star/container/XNameContainer.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XDATADESCRIPTORFACTORY_HPP_
#include <com/sun/star/sdbcx/XDataDescriptorFactory.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XTABLESSUPPLIER_HPP_
#include <com/sun/star/sdbcx/XTablesSupplier.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_KEYTYPE_HPP_
#include <com/sun/star/sdbcx/KeyType.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XDROP_HPP_
#include <com/sun/star/sdbcx/XDrop.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XALTERTABLE_HPP_
#include <com/sun/star/sdbcx/XAlterTable.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBCX_XAPPEND_HPP_
#include <com/sun/star/sdbcx/XAppend.hpp>
#endif
#ifndef _COM_SUN_STAR_SDB_SQLCONTEXT_HPP_
#include <com/sun/star/sdb/SQLContext.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_SQLWARNING_HPP_
#include <com/sun/star/sdbc/SQLWarning.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_COLUMNVALUE_HPP_
#include <com/sun/star/sdbc/ColumnValue.hpp>
#endif
#ifndef _COM_SUN_STAR_SDBC_XROW_HPP_
#include <com/sun/star/sdbc/XRow.hpp>
#endif
#ifndef _DBHELPER_DBEXCEPTION_HXX_
#include <connectivity/dbexception.hxx>
#endif
#ifndef _COM_SUN_STAR_UI_DIALOGS_XEXECUTABLEDIALOG_HPP_
#include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
2001-02-28 09:16:07 +00:00
#endif
#ifndef _COMPHELPER_STREAMSECTION_HXX_
#include <comphelper/streamsection.hxx>
#endif
#ifndef _COMPHELPER_BASIC_IO_HXX_
#include <comphelper/basicio.hxx>
#endif
#ifndef _COMPHELPER_SEQSTREAM_HXX
#include <comphelper/seqstream.hxx>
#endif
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASOURCE_HPP_
#include <com/sun/star/io/XActiveDataSource.hpp>
#endif
#ifndef _COM_SUN_STAR_IO_XACTIVEDATASINK_HPP_
#include <com/sun/star/io/XActiveDataSink.hpp>
#endif
#ifndef _DBAUI_SQLMESSAGE_HXX_
#include "sqlmessage.hxx"
#endif
#ifndef DBAUI_JOINCONTROLLER_HXX
#include "JoinController.hxx"
#endif
#ifndef _SV_MSGBOX_HXX
#include <vcl/msgbox.hxx>
#endif
#ifndef DBAUI_TABLEWINDOWDATA_HXX
#include "TableWindowData.hxx"
#endif
#ifndef DBAUI_TABLEWINDOW_HXX
#include "TableWindow.hxx"
#endif
#ifndef DBAUI_TABLECONNECTIONDATA_HXX
#include "TableConnectionData.hxx"
#endif
#ifndef DBAUI_QYDLGTAB_HXX
#include "adtabdlg.hxx"
#endif
#ifndef _SV_WAITOBJ_HXX
#include <vcl/waitobj.hxx>
#endif
2002-07-11 11:05:41 +00:00
#ifndef DBAUI_TOOLS_HXX
#include "UITools.hxx"
#endif
2001-02-28 09:16:07 +00:00
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::io;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::frame;
using namespace ::com::sun::star::util;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::sdbcx;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::sdb;
using namespace ::com::sun::star::ui::dialogs;
2001-02-28 09:16:07 +00:00
using namespace ::dbtools;
using namespace ::dbaui;
using namespace ::comphelper;
DBG_NAME(OJoinController);
2001-02-28 09:16:07 +00:00
// -----------------------------------------------------------------------------
OJoinController::OJoinController(const Reference< XMultiServiceFactory >& _rM) : OJoinController_BASE(_rM)
,m_bViewsAllowed(sal_True)
2001-02-28 09:16:07 +00:00
,m_pAddTabDlg(NULL)
{
DBG_CTOR(OJoinController,NULL);
2001-02-28 09:16:07 +00:00
}
// -----------------------------------------------------------------------------
OJoinController::~OJoinController()
{
DBG_DTOR(OJoinController,NULL);
2001-02-28 09:16:07 +00:00
}
// -----------------------------------------------------------------------------
void SAL_CALL OJoinController::disposing( const EventObject& _rSource ) throw(RuntimeException)
{
OJoinController_BASE::disposing( _rSource );
}
// -----------------------------------------------------------------------------
OJoinDesignView* OJoinController::getJoinView()
{
return static_cast< OJoinDesignView* >( getView() );
}
2001-02-28 09:16:07 +00:00
// -----------------------------------------------------------------------------
2001-03-01 14:17:55 +00:00
void OJoinController::disposing()
2001-02-28 09:16:07 +00:00
{
OJoinController_BASE::disposing();
2002-08-19 07:01:32 +00:00
2001-02-28 09:16:07 +00:00
m_pAddTabDlg = NULL;
m_pView = NULL;
2001-02-28 09:16:07 +00:00
{
::std::vector< OTableConnectionData*>::iterator aIter = m_vTableConnectionData.begin();
for(;aIter != m_vTableConnectionData.end();++aIter)
delete *aIter;
m_vTableConnectionData.clear();
}
{
::std::vector< OTableWindowData*>::iterator aIter = m_vTableData.begin();
for(;aIter != m_vTableData.end();++aIter)
delete *aIter;
m_vTableData.clear();
}
}
// -----------------------------------------------------------------------------
void OJoinController::setModified(sal_Bool _bModified)
{
2002-08-19 07:01:32 +00:00
OJoinController_BASE::setModified(_bModified);
InvalidateFeature(SID_RELATION_ADD_RELATION);
2001-02-28 09:16:07 +00:00
}
// -----------------------------------------------------------------------------
void OJoinController::SaveTabWinPosSize(OTableWindow* pTabWin, long nOffsetX, long nOffsetY)
{
// die Daten zum Fenster
OTableWindowData* pData = pTabWin->GetData();
OSL_ENSURE(pData != NULL, "SaveTabWinPosSize : TabWin hat keine Daten !");
// Position & Size der Daten neu setzen (aus den aktuellen Fenster-Parametern)
Point aPos = pTabWin->GetPosPixel();
aPos.X() += nOffsetX;
aPos.Y() += nOffsetY;
pData->SetPosition(aPos);
pData->SetSize(pTabWin->GetSizePixel());
}
// -----------------------------------------------------------------------------
FeatureState OJoinController::GetState(sal_uInt16 _nId) const
2001-02-28 09:16:07 +00:00
{
FeatureState aReturn;
// (disabled automatically)
aReturn.bEnabled = sal_True;
switch (_nId)
{
case ID_BROWSER_EDITDOC:
2002-08-19 07:01:32 +00:00
aReturn.aState = ::cppu::bool2any(isEditable());
2001-02-28 09:16:07 +00:00
break;
case ID_BROWSER_SAVEDOC:
2002-08-19 07:01:32 +00:00
aReturn.bEnabled = isConnected() && isModified();
2001-02-28 09:16:07 +00:00
break;
case ID_BROWSER_ADDTABLE:
if (aReturn.bEnabled = getView() && const_cast< OJoinController* >( this )->getJoinView()->getTableView()->IsAddAllowed())
2001-02-28 09:16:07 +00:00
aReturn.aState = ::cppu::bool2any(m_pAddTabDlg && m_pAddTabDlg->IsVisible());
else
aReturn.aState = ::cppu::bool2any(sal_False);
break;
2002-08-19 07:01:32 +00:00
default:
aReturn = OJoinController_BASE::GetState(_nId);
2001-02-28 09:16:07 +00:00
}
return aReturn;
}
// -----------------------------------------------------------------------------
void OJoinController::Execute(sal_uInt16 _nId, const Sequence< PropertyValue >& aArgs)
2001-02-28 09:16:07 +00:00
{
switch(_nId)
{
case ID_BROWSER_EDITDOC:
2002-08-19 07:01:32 +00:00
if(isEditable())
2001-10-23 11:30:27 +00:00
{ // the state should be changed to not editable
switch (saveModified())
{
case RET_CANCEL:
// don't change anything here so return
return;
break;
case RET_NO:
reset();
setModified(sal_False); // and we are not modified yet
break;
default:
break;
}
}
2002-08-19 07:01:32 +00:00
setEditable(!isEditable());
getJoinView()->setReadOnly(!isEditable());
2001-10-23 11:30:27 +00:00
InvalidateAll();
return;
2001-02-28 09:16:07 +00:00
break;
case ID_BROWSER_ADDTABLE:
if(!m_pAddTabDlg)
m_pAddTabDlg = getJoinView()->getAddTableDialog();
2001-02-28 09:16:07 +00:00
if(m_pAddTabDlg->IsVisible())
2001-03-20 07:15:49 +00:00
{
// ::dbaui::notifySystemWindow(getView(),m_pAddTabDlg,::comphelper::mem_fun(&TaskPaneList::RemoveWindow));
2001-02-28 09:16:07 +00:00
m_pAddTabDlg->Show(!m_pAddTabDlg->IsVisible());
2001-03-20 07:15:49 +00:00
m_pView->GrabFocus();
}
else if(getJoinView()->getTableView()->IsAddAllowed())
{
{
WaitObject aWaitCursor(getView());
m_pAddTabDlg->Update();
}
2001-02-28 09:16:07 +00:00
m_pAddTabDlg->Show(!m_pAddTabDlg->IsVisible());
2002-07-11 11:05:41 +00:00
::dbaui::notifySystemWindow(getView(),m_pAddTabDlg,::comphelper::mem_fun(&TaskPaneList::AddWindow));
}
2001-02-28 09:16:07 +00:00
break;
2002-08-19 07:01:32 +00:00
default:
OJoinController_BASE::Execute(_nId,aArgs);
2001-02-28 09:16:07 +00:00
}
2001-04-18 06:02:22 +00:00
InvalidateFeature(_nId);
2001-02-28 09:16:07 +00:00
}
// -----------------------------------------------------------------------------
void OJoinController::SaveTabWinsPosSize( OJoinTableView::OTableWindowMap* pTabWinList, long nOffsetX, long nOffsetY )
{
// Das Loeschen und Neuanlegen der alten Implementation ist unter dem aktuellen Modell nicht mehr richtig : Die TabWins
// habe einen Zeiger auf ihre Daten, verwaltet werden sie aber von mir. Wenn ich die alten loesche, haben die TabWins
// ploetzlich Zeiger auf nicht mehr existente Objekte.
// Wenn die TabWins ein SetData haetten, koennte ich mir das sparen ... haben sie aber nicht, ausserdem muesste ich dann immer
// noch Informationen, die sich eigentlich nicht geaendert haben, auch neu setzen.
// Also loesche ich die TabWinDatas nicht, sondern aktualisiere sie nur.
DBG_ASSERT(m_vTableData.size() == pTabWinList->size(),
"OJoinController::SaveTabWinsPosSize : inkonsistenter Zustand : sollte genausviel TabWinDatas haben wie TabWins !");
OJoinTableView::OTableWindowMap::iterator aIter = pTabWinList->begin();
for(;aIter != pTabWinList->end();++aIter)
SaveTabWinPosSize(aIter->second, nOffsetX, nOffsetY);
}
// -----------------------------------------------------------------------------
2002-02-19 13:16:17 +00:00
void OJoinController::removeConnectionData(OTableConnectionData* _pData)
2001-02-28 09:16:07 +00:00
{
m_vTableConnectionData.erase( ::std::remove(m_vTableConnectionData.begin(),m_vTableConnectionData.end(),_pData),m_vTableConnectionData.end());
2001-02-28 09:16:07 +00:00
}
// -----------------------------------------------------------------------------
void OJoinController::describeSupportedFeatures()
2001-04-24 13:28:56 +00:00
{
OJoinController_BASE::describeSupportedFeatures();
implDescribeSupportedFeature( ".uno:Redo", ID_BROWSER_REDO, CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:Save", ID_BROWSER_SAVEDOC, CommandGroup::DOCUMENT );
implDescribeSupportedFeature( ".uno:Undo", ID_BROWSER_UNDO, CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:AddTable", ID_BROWSER_ADDTABLE,CommandGroup::EDIT );
implDescribeSupportedFeature( ".uno:EditDoc", ID_BROWSER_EDITDOC, CommandGroup::EDIT );
2001-04-24 13:28:56 +00:00
}
// -----------------------------------------------------------------------------
sal_Bool SAL_CALL OJoinController::suspend(sal_Bool _bSuspend) throw( RuntimeException )
2001-10-23 11:30:27 +00:00
{
if ( getBroadcastHelper().bInDispose || getBroadcastHelper().bDisposed )
return sal_True;
sal_Bool bCheck = sal_True;
if ( _bSuspend )
{
bCheck = saveModified() != RET_CANCEL;
if ( bCheck )
OSingleDocumentController::suspend(_bSuspend);
}
return bCheck;
2001-10-23 11:30:27 +00:00
}
// -----------------------------------------------------------------------------
void OJoinController::loadTableWindows(const Sequence<PropertyValue>& aViewProps)
{
::std::vector< OTableWindowData*>::iterator aIter = m_vTableData.begin();
for(;aIter != m_vTableData.end();++aIter)
delete *aIter;
m_vTableData.clear();
2001-02-28 09:16:07 +00:00
const PropertyValue *pIter = aViewProps.getConstArray();
const PropertyValue *pEnd = pIter + aViewProps.getLength();
for (; pIter != pEnd; ++pIter)
{
if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "Tables" ) ) )
{
Sequence<PropertyValue> aWindow;
pIter->Value >>= aWindow;
const PropertyValue *pTablesIter = aWindow.getConstArray();
const PropertyValue *pTablesEnd = pTablesIter + aWindow.getLength();
for (; pTablesIter != pTablesEnd; ++pTablesIter)
{
Sequence<PropertyValue> aTable;
pTablesIter->Value >>= aTable;
loadTableWindow(aTable);
}
}
}
}
// -----------------------------------------------------------------------------
void OJoinController::loadTableWindow(const Sequence<PropertyValue>& _rTable)
{
OTableWindowData* pData = createTableWindowData();
2001-02-28 09:16:07 +00:00
sal_Int32 nX = -1, nY = -1, nHeight = -1, nWidth = -1;
2001-02-28 09:16:07 +00:00
const PropertyValue *pIter = _rTable.getConstArray();
const PropertyValue *pEnd = pIter + _rTable.getLength();
for (; pIter != pEnd; ++pIter)
{
if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "ComposedName" ) ) )
{
::rtl::OUString sName;
pIter->Value >>= sName;
pData->SetComposedName(sName);
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "TableName" ) ) )
{
::rtl::OUString sName;
pIter->Value >>= sName;
pData->SetTableName(sName);
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "WindowName" ) ) )
{
::rtl::OUString sName;
pIter->Value >>= sName;
pData->SetWinName(sName);
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "WindowTop" ) ) )
{
pIter->Value >>= nY;
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "WindowLeft" ) ) )
{
pIter->Value >>= nX;
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "WindowWidth" ) ) )
{
pIter->Value >>= nWidth;
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "WindowHeight" ) ) )
{
pIter->Value >>= nHeight;
}
else if ( pIter->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM ( "ShowAll" ) ) )
{
sal_Bool bShowAll;
pIter->Value >>= bShowAll;
pData->ShowAll(bShowAll);
}
}
pData->SetPosition(Point(nX,nY));
pData->SetSize(Size(nHeight, nWidth));
m_vTableData.push_back(pData);
}
// -----------------------------------------------------------------------------
void OJoinController::saveTableWindows(Sequence<PropertyValue>& _rViewProps)
{
if ( !m_vTableData.empty() )
{
PropertyValue *pViewIter = _rViewProps.getArray();
PropertyValue *pEnd = pViewIter + _rViewProps.getLength();
const static ::rtl::OUString s_sTables(RTL_CONSTASCII_USTRINGPARAM("Tables"));
for (; pViewIter != pEnd && pViewIter->Name != s_sTables; ++pViewIter)
;
2001-02-28 09:16:07 +00:00
if ( pViewIter == pEnd )
{
sal_Int32 nLen = _rViewProps.getLength();
_rViewProps.realloc( nLen + 1 );
pViewIter = _rViewProps.getArray() + nLen;
pViewIter->Name = s_sTables;
}
2001-02-28 09:16:07 +00:00
Sequence<PropertyValue> aTables(m_vTableData.size());
PropertyValue *pIter = aTables.getArray();
2001-02-28 09:16:07 +00:00
Sequence<PropertyValue> aWindow(8);
2001-02-28 09:16:07 +00:00
::std::vector< OTableWindowData*>::iterator aIter = m_vTableData.begin();
::std::vector< OTableWindowData*>::iterator aEnd = m_vTableData.end();
for(sal_Int32 i = 1;aIter != aEnd;++aIter,++pIter,++i)
{
pIter->Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Table")) + ::rtl::OUString::valueOf(i);
2001-02-28 09:16:07 +00:00
sal_Int32 nPos = 0;
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ComposedName"));
aWindow[nPos++].Value <<= (*aIter)->GetComposedName();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("TableName"));
aWindow[nPos++].Value <<= (*aIter)->GetTableName();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("WindowName"));
aWindow[nPos++].Value <<= (*aIter)->GetWinName();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("WindowTop"));
aWindow[nPos++].Value <<= (*aIter)->GetPosition().Y();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("WindowLeft"));
aWindow[nPos++].Value <<= (*aIter)->GetPosition().X();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("WindowWidth"));
aWindow[nPos++].Value <<= (*aIter)->GetSize().Width();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("WindowHeight"));
aWindow[nPos++].Value <<= (*aIter)->GetSize().Height();
aWindow[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ShowAll"));
aWindow[nPos++].Value <<= (*aIter)->IsShowAll();
2001-02-28 09:16:07 +00:00
pIter->Value <<= aWindow;
}
pViewIter->Value <<= aTables;
}
}
// -----------------------------------------------------------------------------