Files
libreoffice/sd/source/ui/dlg/sdtreelb.cxx

919 lines
28 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* $RCSfile: sdtreelb.cxx,v $
*
2001-10-18 13:42:07 +00:00
* $Revision: 1.7 $
2000-09-18 16:07:07 +00:00
*
2001-10-18 13:42:07 +00:00
* last change: $Author: thb $ $Date: 2001-10-18 14:42:07 $
2000-09-18 16:07:07 +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 EXPRESSED 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): _______________________________________
*
*
************************************************************************/
#pragma hdrstop
#include <tools/urlobj.hxx>
#ifndef SVTOOLS_URIHELPER_HXX
#include <svtools/urihelper.hxx>
#endif
#ifndef _SV_MSGBOX_HXX //autogen
#include <vcl/msgbox.hxx>
#endif
#ifndef _SVDITER_HXX //autogen
#include <svx/svditer.hxx>
#endif
#ifndef _SVSTOR_HXX //autogen
#include <so3/svstor.hxx>
#endif
#ifndef _SFXDOCFILE_HXX //autogen
#include <sfx2/docfile.hxx>
#endif
#ifndef _SOT_FORMATS_HXX //autogen
#include <sot/formats.hxx>
#endif
#include "strmname.h"
#include "sdtreelb.hxx"
#include "viewshel.hxx"
#include "docshell.hxx"
#include "drawdoc.hxx"
#include "sdpage.hxx"
#include "sdview.hxx"
#include "sdresid.hxx"
#include "navichld.hxx"
#include "navigatr.hxx"
#include "strings.hrc"
#include "res_bmp.hrc"
BOOL SdPageObjsTLB::bIsInDrag = FALSE;
// -----------------------------------------
// - SdPageObjsTLB::SdPageObjsTransferable -
// -----------------------------------------
SdPageObjsTLB::SdPageObjsTransferable::~SdPageObjsTransferable()
{
}
// -----------------------------------------------------------------------------
void SdPageObjsTLB::SdPageObjsTransferable::AddSupportedFormats()
{
AddFormat( SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK );
}
// -----------------------------------------------------------------------------
sal_Bool SdPageObjsTLB::SdPageObjsTransferable::GetData( const ::com::sun::star::datatransfer::DataFlavor& rFlavor )
{
SetINetBookmark( maBookmark, rFlavor );
return sal_True;
}
// -----------------------------------------------------------------------------
void SdPageObjsTLB::SdPageObjsTransferable::DragFinished( sal_Int8 nDropAction )
{
mrParent.DragFinished( nDropAction );
}
2000-09-18 16:07:07 +00:00
/*************************************************************************
|*
|* Ctor1 SdPageObjsTLB
|*
\************************************************************************/
SdPageObjsTLB::SdPageObjsTLB( Window* pParentWin, const SdResId& rSdResId,
BOOL bEnableDrop ) :
SvTreeListBox ( pParentWin, rSdResId ),
pParent ( pParentWin ),
pDoc ( NULL ),
pBookmarkDoc ( NULL ),
pMedium ( NULL ),
pOwnMedium ( NULL ),
aColor ( COL_WHITE ),
aImgOle ( Bitmap( SdResId( BMP_OLE ) ), aColor ),
aImgGraphic ( Bitmap( SdResId( BMP_GRAPHIC ) ), aColor ),
pDropNavWin ( NULL ),
2000-09-18 16:07:07 +00:00
bOleSelected ( FALSE ),
bGraphicSelected( FALSE )
{
// Tree-ListBox mit Linien versehen
SetWindowBits( WinBits( WB_TABSTOP | WB_BORDER | WB_HASLINES |
WB_HASBUTTONS | // WB_HASLINESATROOT |
WB_HSCROLL | // #31562#
WB_HASBUTTONSATROOT ) );
SetNodeBitmaps( Bitmap( SdResId( BMP_EXPAND ) ),
Bitmap( SdResId( BMP_COLLAPSE ) ) );
}
/*************************************************************************
|*
|* Dtor SdPageObjsTLB
|*
\************************************************************************/
SdPageObjsTLB::~SdPageObjsTLB()
{
CloseBookmarkDoc();
}
/*************************************************************************
|*
|* In TreeLB Eintrag selektieren
|*
\************************************************************************/
BOOL SdPageObjsTLB::SelectEntry( const String& rName )
{
BOOL bFound = FALSE;
if( rName.Len() )
{
SvLBoxEntry* pEntry = NULL;
String aTmp;
for( pEntry = First(); pEntry && !bFound; pEntry = Next( pEntry ) )
{
aTmp = GetEntryText( pEntry );
if( aTmp == rName )
{
bFound = TRUE;
SetCurEntry( pEntry );
}
}
}
return( bFound );
}
/*************************************************************************
|*
|* Gibt zurueck, ob Childs des uebergebenen Strings selektiert sind
|*
\************************************************************************/
BOOL SdPageObjsTLB::HasSelectedChilds( const String& rName )
{
BOOL bFound = FALSE;
BOOL bChilds = FALSE;
if( rName.Len() )
{
SvLBoxEntry* pEntry = NULL;
String aTmp;
for( pEntry = First(); pEntry && !bFound; pEntry = Next( pEntry ) )
{
aTmp = GetEntryText( pEntry );
if( aTmp == rName )
{
bFound = TRUE;
BOOL bExpanded = IsExpanded( pEntry );
long nCount = GetChildSelectionCount( pEntry );
#if SUPD < 335
nCount++;
#endif
if( bExpanded && nCount > 0 )
bChilds = TRUE;
}
}
}
return( bChilds );
}
/*************************************************************************
|*
|* TreeLB mit Seiten und Objekten fuellen
|*
\************************************************************************/
void SdPageObjsTLB::Fill( const SdDrawDocument* pInDoc, BOOL bAllPages,
const String& rDocName)
{
String aSelection;
if( GetSelectionCount() > 0 )
{
aSelection = GetSelectEntry();
Clear();
}
pDoc = pInDoc;
aDocName = rDocName;
SdrObject* pObj = NULL;
SdPage* pPage = NULL;
SvLBoxEntry* pEntry = NULL;
Bitmap aBmpPage( SdResId( BMP_PAGE ) );
Image aImgPage( aBmpPage, aColor );
Bitmap aBmpPageExcluded( SdResId( BMP_PAGE_EXCLUDED ) );
Image aImgPageExcl( aBmpPageExcluded, aColor );
Bitmap aBmpPageObjsExcluded( SdResId( BMP_PAGEOBJS_EXCLUDED ) );
Image aImgPageObjsExcl( aBmpPageObjsExcluded, aColor );
Bitmap aBmpPageObjs( SdResId( BMP_PAGEOBJS ) );
Image aImgPageObjs( aBmpPageObjs, aColor );
Bitmap aBmpObjects( SdResId( BMP_OBJECTS ) );
Image aImgObjects( aBmpObjects, aColor );
// Zuerst alle Pages incl. Objekte einfuegen
USHORT nPage = 0;
const USHORT nMaxPages = pDoc->GetPageCount();
while( nPage < nMaxPages )
{
pPage = (SdPage*) pDoc->GetPage( nPage );
if( bAllPages || pPage->GetPageKind() == PK_STANDARD )
{
BOOL bPageExluded = pPage->IsExcluded();
pEntry = InsertEntry( pPage->GetName(),
bPageExluded ? aImgPageExcl : aImgPage,
bPageExluded ? aImgPageExcl : aImgPage );
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
while( aIter.IsMore() )
{
pObj = aIter.Next();
String aStr( pObj->GetName() );
if( aStr.Len() )
{
if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_OLE2 )
InsertEntry( aStr, aImgOle, aImgOle, pEntry ); // pEntry entspr. Parent
else if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_GRAF )
InsertEntry( aStr, aImgGraphic, aImgGraphic, pEntry ); // pEntry entspr. Parent
else
InsertEntry( aStr, aImgObjects, aImgObjects, pEntry );
}
}
if( pEntry->HasChilds() )
{
SetExpandedEntryBmp( pEntry, bPageExluded ? aImgPageObjsExcl : aImgPageObjs );
SetCollapsedEntryBmp( pEntry, bPageExluded ? aImgPageObjsExcl : aImgPageObjs );
}
}
nPage++;
}
// dann alle MasterPages incl. Objekte einfuegen
if( bAllPages )
{
nPage = 0;
const USHORT nMaxMasterPages = pDoc->GetMasterPageCount();
while( nPage < nMaxMasterPages )
{
pPage = (SdPage*) pDoc->GetMasterPage( nPage );
pEntry = InsertEntry( pPage->GetName(), aImgPage, aImgPage );
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
while( aIter.IsMore() )
{
pObj = aIter.Next();
String aStr( pObj->GetName() );
if( aStr.Len() )
{
if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_OLE2 )
InsertEntry( aStr, aImgOle, aImgOle, pEntry ); // pEntry entspr. Parent
else if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_GRAF )
InsertEntry( aStr, aImgGraphic, aImgGraphic, pEntry ); // pEntry entspr. Parent
else
InsertEntry( aStr, aImgObjects, aImgObjects, pEntry );
}
}
if( pEntry->HasChilds() )
{
SetExpandedEntryBmp( pEntry, aImgPageObjs );
SetCollapsedEntryBmp( pEntry, aImgPageObjs );
}
nPage++;
}
}
if( aSelection.Len() )
SelectEntry( aSelection );
}
/*************************************************************************
|*
|* Es wird nur der erste Eintrag eingefuegt. Childs werden OnDemand erzeugt
|*
\************************************************************************/
void SdPageObjsTLB::Fill( const SdDrawDocument* pInDoc, SfxMedium* pInMedium,
const String& rDocName )
{
pDoc = pInDoc;
pMedium = pInMedium;
aDocName = rDocName;
SdrObject* pObj = NULL;
SdPage* pPage = NULL;
SvLBoxEntry* pFileEntry = NULL;
SvLBoxEntry* pPageEntry = NULL;
Bitmap aBmpDocOpen( SdResId( BMP_DOC_OPEN ) );
Image aImgDocOpen( aBmpDocOpen, aColor );
Bitmap aBmpDocClosed( SdResId( BMP_DOC_CLOSED ) );
Image aImgDocClosed( aBmpDocClosed, aColor );
// Dokumentnamen einfuegen
pFileEntry = InsertEntry( aDocName, aImgDocOpen, aImgDocClosed,
NULL, TRUE ); // ChildsOnDemand
}
/*************************************************************************
|*
|* Prueft, ob die Seiten (PK_STANDARD) und die darauf befindlichen Objekte
|* des Docs und der TreeLB identisch sind.
|* Wird ein Doc uebergeben, wird dieses zum aktuellem Doc (Wichtig bei
|* mehreren Documenten).
|*
\************************************************************************/
BOOL SdPageObjsTLB::IsEqualToDoc( const SdDrawDocument* pInDoc )
{
if( pInDoc )
pDoc = pInDoc;
if( !pDoc )
return( FALSE );
SdrObject* pObj = NULL;
SdPage* pPage = NULL;
SvLBoxEntry* pEntry = First();
String aName;
// Alle Pages incl. Objekte vergleichen
USHORT nPage = 0;
const USHORT nMaxPages = pDoc->GetPageCount();
while( nPage < nMaxPages )
{
pPage = (SdPage*) pDoc->GetPage( nPage );
if( pPage->GetPageKind() == PK_STANDARD )
{
if( !pEntry )
return( FALSE );
aName = GetEntryText( pEntry );
if( pPage->GetName() != aName )
return( FALSE );
pEntry = Next( pEntry );
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
while( aIter.IsMore() )
{
pObj = aIter.Next();
if( pObj->GetName().Len() )
{
if( !pEntry )
return( FALSE );
aName = GetEntryText( pEntry );
if( pObj->GetName() != aName )
return( FALSE );
pEntry = Next( pEntry );
}
}
}
nPage++;
}
// Wenn noch Eintraege in der Listbox vorhanden sind, wurden
// Objekte (mit Namen) oder Seiten geloescht
return( !pEntry );
}
/*************************************************************************
|*
|* Selectierten String zurueckgeben
|*
\************************************************************************/
String SdPageObjsTLB::GetSelectEntry()
{
return( GetEntryText( GetCurEntry() ) );
}
/*************************************************************************
|*
|* Selektierte Eintrage zurueckgeben
|* nDepth == 0 -> Seiten
|* nDepth == 1 -> Objekte
|*
\************************************************************************/
List* SdPageObjsTLB::GetSelectEntryList( USHORT nDepth )
{
List* pList = NULL;
SvLBoxEntry* pEntry = FirstSelected();
while( pEntry )
{
USHORT nListDepth = GetModel()->GetDepth( pEntry );
if( nListDepth == nDepth )
{
if( !pList )
pList = new List();
pList->Insert( new String( GetEntryText( pEntry ) ), LIST_APPEND );
}
pEntry = NextSelected( pEntry );
}
return( pList );
}
/*************************************************************************
|*
|* Alle Pages (und Objekte) des Docs zurueckgeben
|* nType == 0 -> Seiten
|* nType == 1 -> Objekte
|*
\************************************************************************/
List* SdPageObjsTLB::GetBookmarkList( USHORT nType )
{
List* pList = NULL;
if( GetBookmarkDoc() )
{
SdPage* pPage = NULL;
String* pName = NULL;
USHORT nPage = 0;
const USHORT nMaxPages = pBookmarkDoc->GetSdPageCount( PK_STANDARD );
while( nPage < nMaxPages )
{
pPage = pBookmarkDoc->GetSdPage( nPage, PK_STANDARD );
if( nType == 0 ) // Seitennamen einfuegen
{
if( !pList )
pList = new List();
pName = new String( pPage->GetRealName() );
pList->Insert( pName, LIST_APPEND );
}
else // Objektnamen einfuegen
{
// Ueber Objekte der Seite iterieren
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
while( aIter.IsMore() )
{
SdrObject* pObj = aIter.Next();
String aStr( pObj->GetName() );
if( aStr.Len() )
{
if( !pList )
pList = new List();
pName = new String( aStr );
pList->Insert( pName, LIST_APPEND );
}
}
}
nPage++;
}
}
return( pList );
}
/*************************************************************************
|*
|* Eintraege werden erst auf Anforderung (Doppelklick) eingefuegt
|*
\************************************************************************/
void __EXPORT SdPageObjsTLB::RequestingChilds( SvLBoxEntry* pFileEntry )
{
if( !pFileEntry->HasChilds() )
{
if( GetBookmarkDoc() )
{
SdrObject* pObj = NULL;
SdPage* pPage = NULL;
SvLBoxEntry* pPageEntry = NULL;
Bitmap aBmpPage( SdResId( BMP_PAGE ) );
Image aImgPage( aBmpPage, aColor );
Bitmap aBmpPageObjs( SdResId( BMP_PAGEOBJS ) );
Image aImgPageObjs( aBmpPageObjs, aColor );
Bitmap aBmpObjects( SdResId( BMP_OBJECTS ) );
Image aImgObjects( aBmpObjects, aColor );
// Dokumentname ist schon eingefuegt
// Nur alle "normalen" Pages mit Objekten einfuegen
USHORT nPage = 0;
const USHORT nMaxPages = pBookmarkDoc->GetPageCount();
while( nPage < nMaxPages )
{
pPage = (SdPage*) pBookmarkDoc->GetPage( nPage );
if( pPage->GetPageKind() == PK_STANDARD )
{
pPageEntry = InsertEntry( pPage->GetName(), aImgPage, aImgPage, pFileEntry );
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
while( aIter.IsMore() )
{
pObj = aIter.Next();
String aStr( pObj->GetName() );
if( aStr.Len() )
{
if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_OLE2 )
InsertEntry( aStr, aImgOle, aImgOle, pPageEntry );
else if( pObj->GetObjInventor() == SdrInventor &&
pObj->GetObjIdentifier() == OBJ_GRAF )
InsertEntry( aStr, aImgGraphic, aImgGraphic, pPageEntry ); // pEntry entspr. Parent
else
InsertEntry( aStr, aImgObjects, aImgObjects, pPageEntry );
}
}
if( pPageEntry->HasChilds() )
{
SetExpandedEntryBmp( pPageEntry, aImgPageObjs );
SetCollapsedEntryBmp( pPageEntry, aImgPageObjs );
}
}
nPage++;
}
}
}
else
SvTreeListBox::RequestingChilds( pFileEntry );
}
/*************************************************************************
|*
|* Prueft, ob es sich um eine Draw-Datei handelt und oeffnet anhand des
|* uebergebenen Docs das BookmarkDoc
|*
\************************************************************************/
SdDrawDocument* SdPageObjsTLB::GetBookmarkDoc(SfxMedium* pMed)
{
if (!pBookmarkDoc ||
pMed && (!pOwnMedium || pOwnMedium->GetName() != pMed->GetName()))
{
if (pOwnMedium != pMed)
{
CloseBookmarkDoc();
}
SfxMedium* pWorkMedium = NULL;
if (pMed)
{
// Dieses Medium gehoert nun SdPageObjsTLB
pOwnMedium = pMed;
pWorkMedium = pOwnMedium;
}
else
{
delete pOwnMedium;
pOwnMedium = NULL;
pWorkMedium = pMedium;
// Das Medium muss mit READ/WRITE geoeffnet werden, da es ev.
// OLE-Objekte enthaelt, welche geclont werden
// (innerhalb dieses Mediums)
// #70116#: OpenMode is set only to STREAM_READ
pWorkMedium->SetOpenMode(STREAM_READ /*WRITE | STREAM_SHARE_DENYWRITE | STREAM_NOCREATE */,
FALSE);
pWorkMedium->ReOpen();
}
SvStorage* pStorage;
if( !pWorkMedium->IsStorage() )
{
// Nun wird eine Kopie angelegt. In diese Kopie darf
// geschrieben werden
pWorkMedium = new SfxMedium(*pWorkMedium, TRUE);
pStorage = ( pWorkMedium->IsStorage() ? pWorkMedium->GetStorage() : NULL );
}
else
pStorage = pWorkMedium->GetStorage();
// ist es eine Draw-Datei?
if( pStorage &&
( pStorage->IsStream( pStarDrawDoc ) ||
pStorage->IsStream( pStarDrawDoc3 ) ||
pStorage->IsStream( pStarDrawXMLContent ) ||
pStorage->IsStream( pStarDrawOldXMLContent ) ) )
2000-09-18 16:07:07 +00:00
{
if( pMed )
2000-09-18 16:07:07 +00:00
{
// Da das Medium der SdTreeLb gehoert, gehoert auch die
// nun zu erzeugende DocShell der SdTreeLb
xBookmarkDocShRef = new SdDrawDocShell(SFX_CREATE_MODE_STANDARD, TRUE);
2000-09-18 16:07:07 +00:00
if (xBookmarkDocShRef->DoLoad(pMed))
pBookmarkDoc = xBookmarkDocShRef->GetDoc();
else
pBookmarkDoc = NULL;
}
else
pBookmarkDoc = ((SdDrawDocument*) pDoc)->OpenBookmarkDoc(*pWorkMedium);
}
else // unbekanntes Storage-Format
{
ErrorBox aErrorBox( this, WB_OK, String( SdResId( STR_READ_DATA_ERROR ) ) );
2000-09-18 16:07:07 +00:00
aErrorBox.Execute();
}
}
return( pBookmarkDoc );
}
/*************************************************************************
|*
|* Bookmark-Dokument schlie<EFBFBD>en und loeschen
|*
\************************************************************************/
void SdPageObjsTLB::CloseBookmarkDoc()
{
if (xBookmarkDocShRef.Is())
{
xBookmarkDocShRef->DoClose();
}
else
{
if (pBookmarkDoc && pDoc)
((SdDrawDocument*) pDoc)->CloseBookmarkDoc();
}
xBookmarkDocShRef.Clear();
pBookmarkDoc = NULL;
// delete pOwnMedium;
pOwnMedium = NULL;
}
/*************************************************************************
|*
|* Setzt das Flag bOleSelected, entspr. ob ein OLE-Objekt selektiert ist
|*
\************************************************************************/
void SdPageObjsTLB::SelectHdl()
{
SvLBoxEntry* pEntry = NULL;
bOleSelected = FALSE;
bGraphicSelected = FALSE;
pEntry = FirstSelected();
while( pEntry && ( !bOleSelected || !bGraphicSelected ) )
{
if( aImgOle == GetExpandedEntryBmp( pEntry ) )
bOleSelected = TRUE;
if( aImgGraphic == GetExpandedEntryBmp( pEntry ) )
bGraphicSelected = TRUE;
pEntry = NextSelected( pEntry );
}
SvTreeListBox::SelectHdl();
}
/*************************************************************************
|*
|* Ueberlaedt RETURN mit der Funktionsweise von DoubleClick
|*
\************************************************************************/
void SdPageObjsTLB::KeyInput( const KeyEvent& rKEvt )
{
if( rKEvt.GetKeyCode().GetCode() == KEY_RETURN )
{
// Auskommentierter Code aus svtools/source/contnr/svimpbox.cxx
SvLBoxEntry* pCursor = GetCurEntry();
if( pCursor->HasChilds() || pCursor->HasChildsOnDemand() )
{
if( IsExpanded( pCursor ) )
Collapse( pCursor );
else
Expand( pCursor );
}
DoubleClickHdl();
}
else
SvTreeListBox::KeyInput( rKEvt );
}
/*************************************************************************
|*
|* StartDrag-Request
2000-09-18 16:07:07 +00:00
|*
\************************************************************************/
void SdPageObjsTLB::StartDrag( sal_Int8 nAction, const Point& rPosPixel )
2000-09-18 16:07:07 +00:00
{
SdNavigatorWin* pNavWin = NULL;
if( pFrame->HasChildWindow( SID_NAVIGATOR ) )
pNavWin = (SdNavigatorWin*) ( pFrame->GetChildWindow( SID_NAVIGATOR )->GetContextWindow( SD_MOD() ) );
2000-09-18 16:07:07 +00:00
if( pNavWin && pNavWin == pParent && pNavWin->GetNavigatorDragType() != NAVIGATOR_DRAGTYPE_NONE )
2000-09-18 16:07:07 +00:00
{
// Aus dem ExecuteDrag heraus kann der Navigator geloescht werden
// (beim Umschalten auf einen anderen Dokument-Typ), das wuerde aber
// den StarView MouseMove-Handler, der Command() aufruft, umbringen.
// Deshalb Drag&Drop asynchron:
Application::PostUserEvent( STATIC_LINK( this, SdPageObjsTLB, ExecDragHdl ) );
2000-09-18 16:07:07 +00:00
}
}
/*************************************************************************
|*
|* Begin drag
2000-09-18 16:07:07 +00:00
|*
\************************************************************************/
void SdPageObjsTLB::DoDrag()
2000-09-18 16:07:07 +00:00
{
pDropNavWin = ( pFrame->HasChildWindow( SID_NAVIGATOR ) ) ?
(SdNavigatorWin*)( pFrame->GetChildWindow( SID_NAVIGATOR )->GetContextWindow( SD_MOD() ) ) :
NULL;
2000-09-18 16:07:07 +00:00
if( pDropNavWin )
2000-09-18 16:07:07 +00:00
{
SdDrawDocShell* pDocShell = ( (SdDrawDocument*) pDoc )->GetDocSh();
String aURL( pDocShell->GetMedium()->GetPhysicalName() );
NavigatorDragType eDragType = pDropNavWin->GetNavigatorDragType();
2000-09-18 16:07:07 +00:00
aURL = ::URIHelper::SmartRelToAbs( aURL, FALSE, INetURLObject::WAS_ENCODED, INetURLObject::DECODE_UNAMBIGUOUS );
aURL.Append( '#' );
aURL.Append( GetSelectEntry() );
2000-09-18 16:07:07 +00:00
INetBookmark aBookmark( aURL, GetSelectEntry() );
sal_Int8 nDNDActions = DND_ACTION_COPY;
2000-09-18 16:07:07 +00:00
if( eDragType == NAVIGATOR_DRAGTYPE_LINK )
2001-10-18 13:42:07 +00:00
nDNDActions = DND_ACTION_LINK; // #93240# Either COPY *or* LINK, never both!
SvTreeListBox::ReleaseMouse();
bIsInDrag = TRUE;
SD_MOD()->SetCurrentNavigatorDragDocShell( pDocShell );
SD_MOD()->SetCurrentNavigatorDragType( eDragType );
2000-09-18 16:07:07 +00:00
// object is destroyed by internal reference mechanism
( new SdPageObjsTLB::SdPageObjsTransferable( *this, aBookmark ) )->StartDrag( this, nDNDActions );
}
}
2000-09-18 16:07:07 +00:00
/*************************************************************************
|*
|* Drag finished
2000-09-18 16:07:07 +00:00
|*
\************************************************************************/
void SdPageObjsTLB::DragFinished( sal_uInt8 nDropAction )
2000-09-18 16:07:07 +00:00
{
if( pFrame->HasChildWindow( SID_NAVIGATOR ) )
2000-09-18 16:07:07 +00:00
{
SdNavigatorWin* pNewNavWin = (SdNavigatorWin*) ( pFrame->GetChildWindow( SID_NAVIGATOR )->GetContextWindow( SD_MOD() ) );
if( pDropNavWin == pNewNavWin)
{
MouseEvent aMEvt( pDropNavWin->GetPointerPosPixel() );
SvTreeListBox::MouseButtonUp( aMEvt );
}
2000-09-18 16:07:07 +00:00
}
pDropNavWin = NULL;
SD_MOD()->SetCurrentNavigatorDragType( NAVIGATOR_DRAGTYPE_NONE );
SD_MOD()->SetCurrentNavigatorDragDocShell( NULL );
bIsInDrag = FALSE;
}
2000-09-18 16:07:07 +00:00
/*************************************************************************
|*
|* AcceptDrop-Event
2000-09-18 16:07:07 +00:00
|*
\************************************************************************/
sal_Int8 SdPageObjsTLB::AcceptDrop( const AcceptDropEvent& rEvt )
2000-09-18 16:07:07 +00:00
{
return( ( !bIsInDrag && IsDropFormatSupported( FORMAT_FILE ) ) ? rEvt.mnAction : DND_ACTION_NONE );
}
2000-09-18 16:07:07 +00:00
/*************************************************************************
|*
|* ExecuteDrop-Event
|*
\************************************************************************/
2000-09-18 16:07:07 +00:00
sal_Int8 SdPageObjsTLB::ExecuteDrop( const ExecuteDropEvent& rEvt )
{
sal_Int8 nRet = DND_ACTION_NONE;
2000-09-18 16:07:07 +00:00
if( !bIsInDrag )
{
SdNavigatorWin* pNavWin = NULL;
USHORT nId = SID_NAVIGATOR;
2000-09-18 16:07:07 +00:00
if( pFrame->HasChildWindow( nId ) )
pNavWin = (SdNavigatorWin*)( pFrame->GetChildWindow( nId )->GetContextWindow( SD_MOD() ) );
2000-09-18 16:07:07 +00:00
if( pNavWin && ( pNavWin == pParent ) )
2000-09-18 16:07:07 +00:00
{
TransferableDataHelper aDataHelper( rEvt.maDropEvent.Transferable );
String aFile;
2000-09-18 16:07:07 +00:00
if( aDataHelper.GetString( FORMAT_FILE, aFile ) &&
( (SdNavigatorWin*) pParent)->InsertFile( aFile ) )
{
nRet = rEvt.mnAction;
}
2000-09-18 16:07:07 +00:00
}
}
return nRet;
}
2000-09-18 16:07:07 +00:00
/*************************************************************************
|*
|* Handler fuers Dragging
|*
\************************************************************************/
IMPL_STATIC_LINK(SdPageObjsTLB, ExecDragHdl, void*, EMPTYARG)
{
// als Link, damit asynchron ohne ImpMouseMoveMsg auf dem Stack auch der
// Navigator geloescht werden darf
pThis->DoDrag();
return 0;
}