/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: docvor.cxx,v $ * * $Revision: 1.53 $ * * last change: $Author: ihi $ $Date: 2007-07-11 13:12:19 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 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 * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sfx2.hxx" #ifndef _COM_SUN_STAR_EMBED_XSTORAGE_HPP_ #include #endif #ifndef _COM_SUN_STAR_EMBED_ELEMENTMODES_HPP_ #include #endif #ifndef _COM_SUN_STAR_BEANS_XPROPERTYSET_HPP_ #include #endif #include "com/sun/star/ui/dialogs/TemplateDescription.hpp" #include #ifndef _SV_PRNSETUP_HXX //autogen #include #endif #ifndef _VCL_CMDEVT_HXX //autogen #include #endif #ifndef _SV_MENUBTN_HXX //autogen #include #endif #ifndef _SV_MSGBOX_HXX //autogen #include #endif #ifndef _SV_PRINT_HXX //autogen #include #endif #ifndef _SFXSTYLE_HXX //autogen #include #endif #ifndef _SFXSTRITEM_HXX //autogen #include #endif #ifndef _SFXENUMITEM_HXX #include #endif #ifndef _SFXECODE_HXX #include #endif #ifndef _EHDL_HXX #include #endif #ifndef _SVTOOLS_IMAGEMGR_HXX #include #endif #ifndef _SV_WAITOBJ_HXX #include #endif #include #include #include #include #include #include #include "helpid.hrc" #include "docvor.hxx" #include #include "orgmgr.hxx" #include #include #include "sfxtypes.hxx" #include #include #include "sfxresid.hxx" #include "doc.hrc" #include #include "docvor.hrc" #include #include #include #include #ifndef _SVTOOLS_LOCALRESACCESS_HXX_ #include #endif #ifndef _SVT_DOC_ADDRESSTEMPLATE_HXX_ #include #endif #ifndef _COMPHELPER_PROCESSFACTORY_HXX_ #include #endif #define _SVSTDARR_STRINGSDTOR #include static const char cDelim = ':'; BOOL SfxOrganizeListBox_Impl::bDropMoveOk = TRUE; using namespace ::com::sun::star; //========================================================================= class SuspendAccel { public: Accelerator* pAccel; SuspendAccel( Accelerator* pA ) { pAccel=pA; GetpApp()->RemoveAccel( pAccel ); } ~SuspendAccel() { GetpApp()->InsertAccel( pAccel ); } }; //========================================================================= inline void SfxOrganizeListBox_Impl::SetBitmaps( const Image &rOFolder, const Image &rCFolder, const Image &rODoc, const Image &rCDoc, const Image &rOFolderHC, const Image &rCFolderHC, const Image &rODocHC, const Image &rCDocHC ) { aOpenedFolderBmp = rOFolder; aClosedFolderBmp = rCFolder; aOpenedDocBmp = rODoc; aClosedDocBmp = rCDoc; aOpenedFolderBmpHC = rOFolderHC; aClosedFolderBmpHC = rCFolderHC; aOpenedDocBmpHC = rODocHC; aClosedDocBmpHC = rCDocHC; } //========================================================================= #define NO_DROP_ACTION ((sal_Int8)-1) class SfxOrganizeDlg_Impl { friend class SfxTemplateOrganizeDlg; friend class SfxOrganizeListBox_Impl; SuspendAccel* pSuspend; SfxTemplateOrganizeDlg* pDialog; SfxOrganizeListBox_Impl* pFocusBox; Printer* pPrt; // save pointer for asynchronous D&D SvLBox* pSourceView; SvLBoxEntry* pTargetEntry; SfxOrganizeListBox_Impl* pFinishedBox; sal_Int8 nDropAction; bool bExecDropFinished; // save some variables for the asynchronous file dialog USHORT m_nRegion; USHORT m_nIndex; String m_sExtension4Save; SfxOrganizeListBox_Impl aLeftLb; ListBox aLeftTypLb; SfxOrganizeListBox_Impl aRightLb; ListBox aRightTypLb; OKButton aOkBtn; MenuButton aEditBtn; HelpButton aHelpBtn; PushButton aAddressTemplateBtn; PushButton aFilesBtn; Accelerator aEditAcc; String aLastDir; SfxOrganizeMgr aMgr; sfx2::FileDialogHelper* pFileDlg; SvStringsDtor* GetAllFactoryURLs_Impl() const; sal_Bool GetServiceName_Impl( String& rFactoryURL, String& rFileURL ) const; long Dispatch_Impl( USHORT nId, Menu* _pMenu ); String GetPath_Impl( BOOL bOpen, const String& rFileName ); ::com::sun::star::uno::Sequence< ::rtl::OUString > GetPaths_Impl( const String& rFileName ); void InitBitmaps( void ); DECL_LINK( GetFocus_Impl, SfxOrganizeListBox_Impl * ); DECL_LINK( LeftListBoxSelect_Impl, ListBox * ); DECL_LINK( RightListBoxSelect_Impl, ListBox * ); DECL_LINK( AccelSelect_Impl, Accelerator * ); DECL_LINK( MenuSelect_Impl, Menu * ); DECL_LINK( MenuActivate_Impl, Menu * ); DECL_LINK( AddFiles_Impl, Button * ); DECL_LINK( OnAddressTemplateClicked, Button * ); DECL_LINK( ImportHdl, sfx2::FileDialogHelper* ); DECL_LINK( ExportHdl, sfx2::FileDialogHelper* ); DECL_LINK( AddFilesHdl, sfx2::FileDialogHelper* ); BOOL DontDelete_Impl( SvLBoxEntry* pEntry ); void OkHdl( Button* ); public: SfxOrganizeDlg_Impl( SfxTemplateOrganizeDlg* pParent, SfxDocumentTemplates* pTempl ); ~SfxOrganizeDlg_Impl(); }; //------------------------------------------------------------------------- SfxOrganizeDlg_Impl::SfxOrganizeDlg_Impl( SfxTemplateOrganizeDlg* pParent, SfxDocumentTemplates* pTempl ) : pSuspend ( NULL ), pDialog ( pParent ), pFocusBox ( NULL ), pPrt ( NULL ), pSourceView ( NULL ), pTargetEntry ( NULL ), pFinishedBox ( NULL ), nDropAction ( NO_DROP_ACTION ), bExecDropFinished ( true ), aLeftLb ( this, pParent, WB_BORDER | WB_TABSTOP | WB_HSCROLL, SfxOrganizeListBox_Impl::VIEW_TEMPLATES ), aLeftTypLb ( pParent, SfxResId( LB_LEFT_TYP ) ), aRightLb ( this, pParent, WB_BORDER | WB_TABSTOP | WB_HSCROLL, SfxOrganizeListBox_Impl::VIEW_FILES ), aRightTypLb ( pParent, SfxResId( LB_RIGHT_TYP ) ), aOkBtn ( pParent, SfxResId( BTN_OK ) ), aEditBtn ( pParent, SfxResId( BTN_EDIT ) ), aHelpBtn ( pParent, SfxResId( BTN_HELP ) ), aAddressTemplateBtn ( pParent, SfxResId( BTN_ADDRESSTEMPLATE ) ), aFilesBtn ( pParent, SfxResId( BTN_FILES ) ), aEditAcc ( SfxResId( ACC_EDIT ) ), aMgr ( &aLeftLb, &aRightLb, pTempl ), pFileDlg ( NULL ) { // update the SfxDocumentTemplates the manager works with if ( aMgr.GetTemplates() ) // should never fail, but who knows .... { // for this, show a wait cursor (it may take a while) Window* pWaitObjectRange = pDialog ? pDialog->GetParent() : NULL; if ( !pWaitObjectRange ) pWaitObjectRange = pDialog; WaitObject aWaitCursor( pWaitObjectRange ); const_cast< SfxDocumentTemplates* >( aMgr.GetTemplates() )->Update( sal_True /* be smart */ ); // this const_cast is a hack - but the alternative would be to // * have a method which returns the templates non-const // * use a new SfxDocumentTemplates instance for the update (knowing that they all share the same // implementation class) // * always work with an own instance, even if we get only NULL in this ctor } aLeftLb.SetHelpId( HID_CTL_ORGANIZER_LEFT ); aRightLb.SetHelpId( HID_CTL_ORGANIZER_RIGHT ); String aWorkPath = SvtPathOptions().GetWorkPath(); if ( aWorkPath.Len() ) { INetURLObject aObj( aWorkPath ); DBG_ASSERT( aObj.GetProtocol() != INET_PROT_NOT_VALID, "Illegal URL !" ); aObj.setFinalSlash(); aLastDir = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); } else { // fallback String aProgURL = SvtPathOptions().SubstituteVariable( String::CreateFromAscii("$(PROGURL)") ); INetURLObject aObj( aProgURL ); DBG_ASSERT( aObj.GetProtocol() != INET_PROT_NOT_VALID, "Illegal URL !" ); aLastDir = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); } InitBitmaps(); aEditBtn.GetPopupMenu()->SetSelectHdl( LINK( this, SfxOrganizeDlg_Impl, MenuSelect_Impl ) ); aEditBtn.GetPopupMenu()->SetActivateHdl( LINK( this, SfxOrganizeDlg_Impl, MenuActivate_Impl ) ); aEditAcc.SetSelectHdl( LINK( this, SfxOrganizeDlg_Impl, AccelSelect_Impl ) ); GetpApp()->InsertAccel( &aEditAcc ); aFilesBtn.SetClickHdl( LINK(this,SfxOrganizeDlg_Impl, AddFiles_Impl)); aAddressTemplateBtn.SetClickHdl( LINK(this,SfxOrganizeDlg_Impl, OnAddressTemplateClicked)); aLeftTypLb.SetSelectHdl( LINK(this, SfxOrganizeDlg_Impl, LeftListBoxSelect_Impl)); aRightTypLb.SetSelectHdl( LINK(this, SfxOrganizeDlg_Impl, RightListBoxSelect_Impl)); aLeftLb.SetGetFocusHdl( LINK(this, SfxOrganizeDlg_Impl, GetFocus_Impl)); aRightLb.SetGetFocusHdl( LINK(this, SfxOrganizeDlg_Impl, GetFocus_Impl)); aLeftLb.SetPosSizePixel(pParent->LogicToPixel(Point(3, 6), MAP_APPFONT), pParent->LogicToPixel(Size(94, 132), MAP_APPFONT)); aRightLb.SetPosSizePixel(pParent->LogicToPixel(Point(103, 6), MAP_APPFONT), pParent->LogicToPixel(Size(94, 132), MAP_APPFONT)); if ( !SvtModuleOptions().IsModuleInstalled(SvtModuleOptions::E_SDATABASE) ) aAddressTemplateBtn.Hide(); Font aFont(aLeftLb.GetFont()); aFont.SetWeight(WEIGHT_NORMAL); aLeftLb.SetFont(aFont); aRightLb.SetFont(aFont); const long nIndent = aLeftLb.GetIndent() / 2; aLeftLb.SetIndent( (short)nIndent ); aRightLb.SetIndent( (short)nIndent ); aLeftLb.SetMgr(&aMgr); aRightLb.SetMgr(&aMgr); aLeftLb.Reset(); aRightLb.Reset();//SetModel(aLeftLb.GetModel()); aLeftLb.Show(); aRightLb.Show(); aLeftLb.SelectAll( FALSE ); aRightLb.SelectAll( FALSE ); aRightLb.GrabFocus(); } //------------------------------------------------------------------------- SfxOrganizeDlg_Impl::~SfxOrganizeDlg_Impl() { delete pFileDlg; } //------------------------------------------------------------------------- void SfxOrganizeDlg_Impl::InitBitmaps( void ) { Image aOpenedFolderBmp( SfxResId( IMG_OPENED_FOLDER ) ); Image aClosedFolderBmp( SfxResId( IMG_CLOSED_FOLDER ) ); Image aOpenedDocBmp( SfxResId( IMG_OPENED_DOC ) ); Image aClosedDocBmp( SfxResId( IMG_CLOSED_DOC ) ); Image aOpenedFolderBmpHC( SfxResId( IMG_OPENED_FOLDER_HC ) ); Image aClosedFolderBmpHC( SfxResId( IMG_CLOSED_FOLDER_HC ) ); Image aOpenedDocBmpHC( SfxResId( IMG_OPENED_DOC_HC ) ); Image aClosedDocBmpHC( SfxResId( IMG_CLOSED_DOC_HC ) ); aLeftLb.SetBitmaps( aOpenedFolderBmp, aClosedFolderBmp, aOpenedDocBmp, aClosedDocBmp, aOpenedFolderBmpHC, aClosedFolderBmpHC, aOpenedDocBmpHC, aClosedDocBmpHC ); aRightLb.SetBitmaps( aOpenedFolderBmp, aClosedFolderBmp, aOpenedDocBmp, aClosedDocBmp, aOpenedFolderBmpHC, aClosedFolderBmpHC, aOpenedDocBmpHC, aClosedDocBmpHC ); } //========================================================================= BOOL QueryDelete_Impl(Window *pParent, // Parent der QueryBox USHORT nId, // Resource Id const String &rTemplateName) // Name der zu l"oschenden Vorlage /* [Beschreibung] "oschabfrage */ { SfxResId aResId( nId ); String aEntryText( aResId ); aEntryText.SearchAndReplaceAscii( "$1", rTemplateName ); QueryBox aBox( pParent, WB_YES_NO | WB_DEF_NO, aEntryText ); return RET_NO != aBox.Execute(); } //------------------------------------------------------------------------- void ErrorDelete_Impl(Window *pParent, const String &rName, sal_Bool bFolder = sal_False ) /* [Beschreibung] Benutzerinformation, da"s die Vorlage rName nicht gel"oscht werden konnte */ { if ( bFolder ) { String aText( SfxResId( STR_ERROR_DELETE_TEMPLATE_DIR ) ); ErrorBox( pParent, WB_OK, aText ).Execute(); } else { String aText( SfxResId( STR_ERROR_DELETE_TEMPLATE ) ); aText.SearchAndReplaceAscii( "$1", rName ); ErrorBox( pParent, WB_OK, aText ).Execute(); } } //========================================================================= /* [Beschreibung] Implementierungsklasse; Referenzklasse f"ur USHORT-Array */ struct ImpPath_Impl { SvUShorts aUS; USHORT nRef; ImpPath_Impl(); ImpPath_Impl( const ImpPath_Impl& rCopy ); }; //------------------------------------------------------------------------- ImpPath_Impl::ImpPath_Impl() : aUS(5), nRef(1) { } //------------------------------------------------------------------------- ImpPath_Impl::ImpPath_Impl( const ImpPath_Impl& rCopy ) : aUS ( (BYTE)rCopy.aUS.Count() ), nRef( 1 ) { const USHORT nCount = rCopy.aUS.Count(); for ( USHORT i = 0; i < nCount; ++i ) aUS.Insert( rCopy.aUS[i], i ); } //========================================================================== /* [Beschreibung] Implementierungsklasse; Darstellung einer Position in der Outline- Listbox als USHORT-Array; dieses beschreibt die Position jeweil als relative Postion zum "ubergeordneten Eintrag */ class Path { ImpPath_Impl *pData; void NewImp(); public: Path(SvLBox *pBox, SvLBoxEntry *pEntry); Path(const Path &rPath): pData(rPath.pData) { ++pData->nRef; } const Path &operator=(const Path &rPath) { if(&rPath != this) { if(!--pData->nRef) delete pData; pData = rPath.pData; pData->nRef++; } return *this; } ~Path() { if(!--pData->nRef) delete pData; } USHORT Count() const { return pData->aUS.Count(); } USHORT operator[]( USHORT i ) const { return i < Count()? pData->aUS[i]: INDEX_IGNORE; } }; //------------------------------------------------------------------------- Path::Path(SvLBox *pBox, SvLBoxEntry *pEntry) : pData(new ImpPath_Impl) { DBG_ASSERT(pEntry != 0, "EntryPtr ist NULL"); if(!pEntry) return; SvLBoxEntry *pParent = pBox->GetParent(pEntry); do { pData->aUS.Insert((USHORT)pBox->GetModel()->GetRelPos(pEntry), 0); if(0 == pParent) break; pEntry = pParent; pParent = pBox->GetParent(pEntry); } while(1); } //------------------------------------------------------------------------- void Path::NewImp() { if(pData->nRef != 1) { pData->nRef--; pData = new ImpPath_Impl(*pData); } } //------------------------------------------------------------------------- SvLBoxEntry *GetIndices_Impl(SvLBox *pBox, SvLBoxEntry *pEntry, USHORT &rRegion, USHORT &rOffset) /* [Beschreibung] Bereich und Position innerhalb eines Bereiches f"ur eine Dokumentvorlage wird ermittelt. [Parameter] SvLBox *pBox Listbox, an der das Ereignis auftrat SvLBoxEntry *pEntry Eintrag, dessen Position ermittelt werden soll USHORT &rRegion der Bereich innerhalb der Bereiche der Dokumentvorlagen (Out-Parameter) USHORT &rOffset die Position innerhalb des Bereiches Dokumentvorlagen (Out-Parameter) [Querverweise] (unter Umst"anden kann auf diese Funktion zugunsten von Path verzichtet werden.) */ { if(!pEntry) { rRegion = rOffset = 0; return pEntry; } if(0 == pBox->GetModel()->GetDepth(pEntry)) { rRegion = (USHORT)pBox->GetModel()->GetRelPos(pEntry); rOffset = USHRT_MAX; return pEntry; } SvLBoxEntry *pParent = pBox->GetParent(pEntry); rRegion = (USHORT)pBox->GetModel()->GetRelPos(pParent); rOffset = (USHORT)pBox->GetModel()->GetRelPos(pEntry); return pEntry; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::Select( SvLBoxEntry* pEntry, BOOL bSelect ) { if(!bSelect) return SvTreeListBox::Select(pEntry,bSelect); USHORT nLevel = GetDocLevel(); if(GetModel()->GetDepth(pEntry)+nLevel<3) return SvTreeListBox::Select(pEntry,bSelect); Path aPath(this, pEntry); GetObjectShell(aPath)->TriggerHelpPI( aPath[nLevel+1], aPath[nLevel+2], aPath[nLevel+3]); return SvTreeListBox::Select(pEntry,bSelect); } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::MoveOrCopyTemplates(SvLBox *pSourceBox, SvLBoxEntry *pSource, SvLBoxEntry* pTarget, SvLBoxEntry *&pNewParent, ULONG &rIdx, BOOL bCopy) /* [Beschreibung] Verschieben oder Kopieren von Dokumentvorlagen [Parameter] SvLBox *pSourceBox Quell-Listbox, an der das Ereignis auftrat SvLBoxEntry *pSource Quell-Eintrag, der kopiert / verschoben werden soll SvLBoxEntry* pTarget Ziel-Eintrag, auf den verschoben werden soll SvLBoxEntry *&pNewParent der Parent der an der Zielposition erzeugten Eintrags (Out-Parameter) ULONG &rIdx Index des Zieleintrags BOOL bCopy Flag f"ur Kopieren / Verschieben [Returnwert] BOOL: Erfolg oder Mi"serfolg [Querverweise] */ { BOOL bOk = FALSE; if(pSource) { USHORT nTargetRegion = 0, nTargetIndex = 0; GetIndices_Impl(this, pTarget, nTargetRegion, nTargetIndex); USHORT nSourceRegion = 0, nSourceIndex = 0; GetIndices_Impl(pSourceBox, pSource, nSourceRegion, nSourceIndex); bOk = bCopy ? pMgr->Copy(nTargetRegion, nTargetIndex+1, nSourceRegion, nSourceIndex): pMgr->Move(nTargetRegion, nTargetIndex+1, nSourceRegion, nSourceIndex); if(bOk) { if(pSourceBox->GetModel()->GetDepth(pSource) == GetModel()->GetDepth(pTarget)) { pNewParent = GetParent(pTarget); rIdx = GetModel()->GetRelPos(pTarget)+1; } else { if(nTargetIndex == USHRT_MAX) { pNewParent = pTarget; rIdx = 0; } else SvLBox::NotifyCopying( pTarget, pSource, pNewParent, rIdx); } } else if ( bCopy ) { // the template organizer always tries copy after the move, so no error is required for move case String aText( SfxResId( bCopy ? STR_ERROR_COPY_TEMPLATE : STR_ERROR_MOVE_TEMPLATE ) ); aText.SearchAndReplaceAscii( "$1", ( (SvTreeListBox *)pSourceBox )->GetEntryText( pSource ) ); ErrorBox( this, WB_OK, aText ).Execute(); } } return bOk; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::MoveOrCopyContents(SvLBox *pSourceBox, SvLBoxEntry *pSource, SvLBoxEntry* pTarget, SvLBoxEntry *&pNewParent, ULONG &rIdx, BOOL bCopy) /* [Beschreibung] Verschieben oder Kopieren von Dokumentinhalten [Parameter] SvLBox *pSourceBox Quell-Listbox, an der das Ereignis auftrat SvLBoxEntry *pSource Quell-Eintrag, der kopiert / verschoben werden soll SvLBoxEntry* pTarget Ziel-Eintrag, auf den verschoben werden soll SvLBoxEntry *&pNewParent der Parent der an der Zielposition erzeugten Eintrags (Out-Parameter) ULONG &rIdx Index des Zieleintrags BOOL bCopy Flag f"ur Kopieren / Verschieben [Returnwert] BOOL: Erfolg oder Mi"serfolg [Querverweise] */ { SfxErrorContext aEc( ERRCTX_SFX_MOVEORCOPYCONTENTS, this); BOOL bOk = FALSE, bKeepExpansion = FALSE; BOOL bRemovedFromSource = FALSE; Path aSource(pSourceBox, pSource); Path aTarget(this, pTarget); SfxObjectShellRef aSourceDoc = ((SfxOrganizeListBox_Impl *)pSourceBox)->GetObjectShell(aSource); SfxObjectShellRef aTargetDoc = GetObjectShell(aTarget); const USHORT nSLevel = ((SfxOrganizeListBox_Impl *)pSourceBox)->GetDocLevel(); const USHORT nTLevel = GetDocLevel(); if(aSourceDoc.Is() && aTargetDoc.Is()) { if (aSourceDoc->GetStyleSheetPool()) aSourceDoc->GetStyleSheetPool()->SetSearchMask( SFX_STYLE_FAMILY_ALL, SFXSTYLEBIT_USERDEF | SFXSTYLEBIT_USED); if (aTargetDoc->GetStyleSheetPool()) aTargetDoc->GetStyleSheetPool()->SetSearchMask( SFX_STYLE_FAMILY_ALL, SFXSTYLEBIT_USERDEF | SFXSTYLEBIT_USED); USHORT p[3]; USHORT nIdxDeleted = INDEX_IGNORE; p[0]=aTarget[nTLevel+1]; p[1]=aTarget[nTLevel+2]; if(p[1]!=INDEX_IGNORE)p[1]++; p[2]=aTarget[nTLevel+3]; bOk = aTargetDoc->Insert( *aSourceDoc, aSource[nSLevel+1], aSource[nSLevel+2], aSource[nSLevel+3], p[0], p[1], p[2], nIdxDeleted); // Positionskorrektur auswerten // a = Dokumentinhalt // b = Position Sub-Inhalt 1 // c = Position Sub-Inhalt 2 // doppelte Eintraege loeschen if(bOk) { SvLBoxEntry *pParentIter = pTarget; // bis auf die DokumentEbene nach oben als // allgemeiner Bezugspunkt while(GetModel()->GetDepth(pParentIter) != nTLevel) pParentIter = GetParent(pParentIter); if(pParentIter->HasChildsOnDemand() && !GetModel()->HasChilds(pParentIter)) RequestingChilds(pParentIter); SvLBoxEntry *pChildIter = 0; USHORT i = 0; while(i < 2 && p[i+1] != INDEX_IGNORE) { pChildIter = FirstChild(pParentIter); // bis zum Index der aktuellen Ebene for(USHORT j = 0; j < p[i]; ++j) pChildIter = NextSibling(pChildIter); // gfs Fuellen bei Items onDemand ++i; if(p[i+1] != INDEX_IGNORE && pChildIter->HasChildsOnDemand() && !GetModel()->HasChilds(pChildIter)) RequestingChilds(pChildIter); pParentIter = pChildIter; } rIdx = p[i]; pNewParent = pParentIter; if(!IsExpanded(pNewParent) && pNewParent->HasChildsOnDemand() && !GetModel()->HasChilds(pNewParent)) { bOk = FALSE; if(!bCopy) pSourceBox->GetModel()->Remove(pSource); } // Geloeschte Eintraege entfernen // (kann durch Ueberschreiben geschehen) if(nIdxDeleted != INDEX_IGNORE) { pChildIter = FirstChild(pParentIter); for(USHORT j = 0; j < nIdxDeleted; ++j) pChildIter = NextSibling(pChildIter); if( pChildIter && pChildIter != pSource ) { bKeepExpansion = IsExpanded(pParentIter); GetModel()->Remove(pChildIter); } else bOk = FALSE; } if(!bCopy && &aSourceDoc != &aTargetDoc) { //#109566# pool styles that are moved produce //an rIdx == INDEX_IGNORE //the method has to return true to keep the box content consistent bRemovedFromSource = aSourceDoc->Remove(aSource[nSLevel+1], aSource[nSLevel+2], aSource[nSLevel+3]); } } } // rIdx++; return (((rIdx != INDEX_IGNORE)|| bRemovedFromSource) && bOk ) ? bKeepExpansion? (BOOL)2: TRUE: FALSE; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::NotifyMoving(SvLBoxEntry *pTarget, SvLBoxEntry* pSource, SvLBoxEntry *&pNewParent, ULONG &rIdx) /* [Beschreibung] Benachrichtigung, da"s ein Eintrag verschoben werden soll (SV-Handler) [Parameter] SvLBoxEntry* pTarget Ziel-Eintrag, auf den verschoben werden soll SvLBoxEntry *pSource Quell-Eintrag, der verschoben werden soll SvLBoxEntry *&pNewParent der Parent der an der Zielposition erzeugten Eintrags (Out-Parameter) ULONG &rIdx Index des Zieleintrags [Returnwert] BOOL: Erfolg oder Mi"serfolg [Querverweise] */ { BOOL bOk = FALSE; SvLBox* pSourceBox = GetSourceView(); if ( !pSourceBox ) pSourceBox = pDlg->pSourceView; DBG_ASSERT( pSourceBox, "no source view" ); if ( !pTarget ) pTarget = pDlg->pTargetEntry; if ( pSourceBox->GetModel()->GetDepth( pSource ) <= GetDocLevel() && GetModel()->GetDepth( pTarget ) <= GetDocLevel() ) bOk = MoveOrCopyTemplates( pSourceBox, pSource, pTarget, pNewParent, rIdx, FALSE ); else bOk = MoveOrCopyContents(pSourceBox, pSource, pTarget, pNewParent, rIdx, FALSE ); return bOk; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::NotifyCopying(SvLBoxEntry *pTarget, SvLBoxEntry* pSource, SvLBoxEntry *&pNewParent, ULONG &rIdx) /* [Beschreibung] Benachrichtigung, da"s ein Eintrag kopiert werden soll (SV-Handler) [Parameter] SvLBoxEntry* pTarget Ziel-Eintrag, auf den kopiert werden soll SvLBoxEntry *pSource Quell-Eintrag, der kopiert werden soll SvLBoxEntry *&pNewParent der Parent der an der Zielposition erzeugten Eintrags (Out-Parameter) ULONG &rIdx Index des Zieleintrags [Returnwert] BOOL: Erfolg oder Mi"serfolg [Querverweise] */ { BOOL bOk = FALSE; SvLBox* pSourceBox = GetSourceView(); if ( !pSourceBox ) pSourceBox = pDlg->pSourceView; DBG_ASSERT( pSourceBox, "no source view" ); if ( !pTarget ) pTarget = pDlg->pTargetEntry; if ( pSourceBox->GetModel()->GetDepth( pSource ) <= GetDocLevel() && GetModel()->GetDepth( pTarget ) <= GetDocLevel() ) bOk = MoveOrCopyTemplates( pSourceBox, pSource, pTarget, pNewParent, rIdx, TRUE ); else bOk = MoveOrCopyContents( pSourceBox, pSource, pTarget, pNewParent, rIdx, TRUE ); return bOk; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::EditingEntry( SvLBoxEntry* pEntry, Selection& ) /* [Beschreibung] Nachfrage, ob ein Eintrag editierbar ist (SV-Handler) [Querverweise] */ { if( VIEW_TEMPLATES == eViewType && GetModel()->GetDepth(pEntry) < 2 ) { pDlg->pSuspend = new SuspendAccel( &pDlg->aEditAcc ); return TRUE; } return FALSE; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::EditedEntry(SvLBoxEntry* pEntry, const String& rText) /* [Beschreibung] Der Name eines Eintrags wurde bearbeitet; ist der eingegebene Name ein g"ultiger Name ("ange > 0), wird das Model aktualisiert. (SV-Handler) [Returnwert] BOOL TRUE: der Name soll in der Anzeige ge"andert werden FALSE:der Name soll nicht ge"andert werden [Querverweise] */ { DBG_ASSERT(pEntry, "kein Entry selektiert"); delete pDlg->pSuspend; pDlg->pSuspend = NULL; SvLBoxEntry* pParent = GetParent(pEntry); if( !rText.Len() ) { ErrorBox aBox( this, SfxResId( MSG_ERROR_EMPTY_NAME ) ); aBox.GrabFocus(); aBox.Execute(); return FALSE; } if ( !IsUniqName_Impl( rText, pParent, pEntry ) ) { ErrorBox aBox( this, SfxResId( MSG_ERROR_UNIQ_NAME ) ); aBox.GrabFocus(); aBox.Execute(); return FALSE; } USHORT nRegion = 0, nIndex = 0; GetIndices_Impl( this, pEntry, nRegion, nIndex ); String aOldName; if ( USHRT_MAX != nIndex ) aOldName = pMgr->GetTemplates()->GetName( nRegion, nIndex ); else aOldName = pMgr->GetTemplates()->GetRegionName( nRegion ); if ( !pMgr->SetName( rText, nRegion, nIndex ) ) { SfxResId aResId( USHRT_MAX != nIndex ? MSG_ERROR_RENAME_TEMPLATE : MSG_ERROR_RENAME_TEMPLATE_REGION ); ErrorBox( this, aResId ).Execute(); return FALSE; } /* else { SfxTemplateOrganizeDlg* pDlg = (SfxTemplateOrganizeDlg*)Window::GetParent(); } */ return TRUE; } //------------------------------------------------------------------------- DragDropMode SfxOrganizeListBox_Impl::NotifyStartDrag( TransferDataContainer&, SvLBoxEntry* pEntry ) { USHORT nSourceLevel = GetModel()->GetDepth( pEntry ); if ( VIEW_FILES == GetViewType() ) ++nSourceLevel; if ( nSourceLevel >= 2 ) bDropMoveOk = FALSE; else bDropMoveOk = TRUE; return GetDragDropMode(); } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::NotifyAcceptDrop( SvLBoxEntry* pEntry ) { if(!pEntry) return FALSE; SvLBox *pSource = GetSourceView(); SvLBoxEntry *pSourceEntry = pSource->FirstSelected(); if(pEntry == pSourceEntry) return FALSE; USHORT nSourceLevel = pSource->GetModel()->GetDepth(pSourceEntry); if(VIEW_FILES == ((SfxOrganizeListBox_Impl *)pSource)->GetViewType()) ++nSourceLevel; USHORT nTargetLevel = GetModel()->GetDepth(pEntry); if(VIEW_FILES == GetViewType()) ++nTargetLevel; Path aSource(pSource, pSourceEntry); Path aTarget(this, pEntry); const USHORT SL = ((SfxOrganizeListBox_Impl *)pSource)->GetDocLevel(); const USHORT TL = GetDocLevel(); return( (nSourceLevel == 1 && nTargetLevel == 0 && VIEW_TEMPLATES == ((SfxOrganizeListBox_Impl *)pSource)->GetViewType()) || (nSourceLevel == 1 && nTargetLevel == 1 && VIEW_TEMPLATES == ((SfxOrganizeListBox_Impl *)pSource)->GetViewType() && VIEW_TEMPLATES == GetViewType()) || (nSourceLevel == 3 && nTargetLevel == 1) || (nSourceLevel == 3 && nTargetLevel == 2 && aSource[1+SL] == aTarget[1+TL]) || (nSourceLevel == 3 && nTargetLevel == 3 && aSource[1+SL] == aTarget[1+TL]) || (nSourceLevel == 4 && nTargetLevel == 3 && aSource[1+SL] == aTarget[1+TL] && aSource[2+SL] == aTarget[2+TL]) || (nSourceLevel == 4 && nTargetLevel == 4 && aSource[1+SL] == aTarget[1+TL] && aSource[2+SL] == aTarget[2+TL])); } //------------------------------------------------------------------------- sal_Int8 SfxOrganizeListBox_Impl::AcceptDrop( const AcceptDropEvent& rEvt ) { sal_Bool bAccept = ( eViewType == VIEW_FILES && IsDropFormatSupported( SOT_FORMAT_FILE ) ); if ( bAccept ) return rEvt.mnAction; else return SvTreeListBox::AcceptDrop( rEvt ); } //------------------------------------------------------------------------- sal_Int8 SfxOrganizeListBox_Impl::ExecuteDrop( const ExecuteDropEvent& rEvt ) { TransferableDataHelper aHelper( rEvt.maDropEvent.Transferable ); sal_uInt32 nFormatCount = aHelper.GetFormatCount(); BOOL bSuccess = FALSE; for ( sal_uInt32 i = 0; i < nFormatCount; ++i ) { String aFileName; SotFormatStringId nId = aHelper.GetFormat(i); if ( SOT_FORMAT_FILE == nId && aHelper.GetString( nId, aFileName ) ) { INetURLObject aObj( aFileName, INET_PROT_FILE ); bSuccess |= pMgr->InsertFile( this, aObj.GetMainURL(INetURLObject::DECODE_TO_IURI) ); } } bDropMoveOk = TRUE; sal_Int8 nRet = rEvt.mnAction; if ( !bSuccess ) { // asynchronous, because of MessBoxes pDlg->pSourceView = GetSourceView(); pDlg->pTargetEntry = pTargetEntry; pDlg->pFinishedBox = NULL; pDlg->nDropAction = NO_DROP_ACTION; PostUserEvent( LINK( this, SfxOrganizeListBox_Impl, OnAsyncExecuteDrop ), new ExecuteDropEvent( rEvt ) ); } return nRet; } //------------------------------------------------------------------------- void SfxOrganizeListBox_Impl::DragFinished( sal_Int8 nDropAction ) { if ( pDlg->bExecDropFinished ) { if ( pDlg->nDropAction != NO_DROP_ACTION ) nDropAction = pDlg->nDropAction; SvTreeListBox::DragFinished( nDropAction ); pDlg->nDropAction = NO_DROP_ACTION; } else pDlg->pFinishedBox = this; } //------------------------------------------------------------------------- inline USHORT SfxOrganizeListBox_Impl::GetDocLevel() const /* [Beschreibung] Ermittelt, auf welche Ebene sich Dokumente befinden (unterschiedlich in der Dokumentvorlagensicht und der Dokumentensicht) [Returnwert] USHORT Die Ebene der Dokumente */ { return eViewType == VIEW_FILES? 0: 1; } //------------------------------------------------------------------------- SfxObjectShellRef SfxOrganizeListBox_Impl::GetObjectShell(const Path &rPath) /* [Beschreibung] Zugriff auf die ObjectShell, die dem aktuellen Eintrag zugeordnet ist. [Parameter] const Path &rPath Beschreibung des aktuellen Eintrags [Returnwert] SfxObjectShellRef Referenz auf die ObjectShell [Querverweise] */ { SfxObjectShellRef aDoc; if(eViewType == VIEW_FILES) aDoc = pMgr->CreateObjectShell(rPath[0]); else aDoc = pMgr->CreateObjectShell(rPath[0], rPath[1]); return aDoc; } //------------------------------------------------------------------------- void SfxOrganizeListBox_Impl::RequestingChilds( SvLBoxEntry* pEntry ) /* [Beschreibung] Aufforderung, der Childs eines Eintrags einzuf"ugen ist. (SV-Handler) [Parameter] SvLBoxEntry* pEntry der Eintrag, dessen Childs erfragt werden */ { // wenn keine Childs vorhanden sind, gfs. Childs // einfuegen BmpColorMode eColorMode = BMP_COLOR_NORMAL; if ( GetDisplayBackground().GetColor().IsDark() ) eColorMode = BMP_COLOR_HIGHCONTRAST; if ( !GetModel()->HasChilds( pEntry ) ) { WaitObject aWaitCursor( this ); // Choose the correct mask color dependent from eColorMode. This must be adopted if // we change the mask color for normal images, too! Color aMaskColor( COL_LIGHTMAGENTA ); // hier sind alle initial eingefuegt SfxErrorContext aEc(ERRCTX_SFX_CREATEOBJSH, pDlg->pDialog); if(VIEW_TEMPLATES == GetViewType() && 0 == GetModel()->GetDepth(pEntry)) { USHORT i = (USHORT)GetModel()->GetRelPos(pEntry); const USHORT nEntryCount = pMgr->GetTemplates()->GetCount(i); for(USHORT j = 0; j < nEntryCount; ++j) InsertEntryByBmpType( pMgr->GetTemplates()->GetName( i, j ), BMPTYPE_DOC, pEntry, TRUE ); } else { const USHORT nDocLevel = GetDocLevel(); Path aPath(this, pEntry); SfxObjectShellRef aRef = GetObjectShell(aPath); if(aRef.Is()) { const USHORT nCount = aRef->GetContentCount( aPath[nDocLevel+1], aPath[nDocLevel+2]); String aText; Bitmap aClosedBmp, aOpenedBmp; const BOOL bCanHaveChilds = aRef->CanHaveChilds(aPath[nDocLevel+1], aPath[nDocLevel+2]); for(USHORT i = 0; i < nCount; ++i) { BOOL bDeletable; aRef->GetContent( aText, aClosedBmp, aOpenedBmp, eColorMode, bDeletable, i, aPath[nDocLevel+1], aPath[nDocLevel+2]); // Create image with the correct mask color Image aClosedImage( aClosedBmp, aMaskColor ); Image aOpenedImage( aOpenedBmp, aMaskColor ); SvLBoxEntry *pNew = SvTreeListBox::InsertEntry( aText, aOpenedImage, aClosedImage, pEntry, bCanHaveChilds); pNew->SetUserData(bDeletable ? &bDeletable : 0); } } } } } //------------------------------------------------------------------------- long SfxOrganizeListBox_Impl::ExpandingHdl() /* [Beschreibung] SV-Handler, der nach dem und vor dem Aufklappen eines Eintrags gerufen wird. Wird verwendet, um gfs. die ObjectShell wieder zu schlie"sen; die Eintr"age mit den Inhalten dieser Shell werden ebenfalls entfernt. */ { if ( !(nImpFlags & SVLBOX_IS_EXPANDING) ) { SvLBoxEntry* pEntry = GetHdlEntry(); const USHORT nLevel = GetModel()->GetDepth(pEntry); if((eViewType == VIEW_FILES && nLevel == 0) || (eViewType == VIEW_TEMPLATES && nLevel == 1)) { Path aPath(this, pEntry); // Beim Schliessen des Files die ObjectShell freigeben if(eViewType == VIEW_FILES && nLevel == 0) pMgr->DeleteObjectShell(aPath[0]); else pMgr->DeleteObjectShell(aPath[0], aPath[1]); // alle SubEntries loeschen SvLBoxEntry *pToDel = SvLBox::GetEntry(pEntry, 0); while(pToDel) { GetModel()->Remove(pToDel); pToDel = SvLBox::GetEntry(pEntry, 0); } } } return TRUE; } //------------------------------------------------------------------------- BOOL SfxOrganizeListBox_Impl::IsUniqName_Impl(const String &rText, SvLBoxEntry* pParent, SvLBoxEntry *pEntry) const /* [Beschreibung] Pr"uft, ob eine Name auf seiner Ebene eindeutig ist. [Parameter] const String & Name des zu suchenden Eintrags SvLBoxEntry* pSibling Geschwister (bezeichnet die Ebene) [Returnwert] BOOL TRUE, wenn der Name eindeutig ist, sonst FALSE */ { SvLBoxEntry* pChild = FirstChild(pParent); while(pChild) { const String aEntryText(GetEntryText(pChild)); if(COMPARE_EQUAL == aEntryText.CompareIgnoreCaseToAscii(rText)&&(!pEntry || pEntry!=pChild)) return FALSE; pChild = NextSibling(pChild); } return TRUE; } //------------------------------------------------------------------------- USHORT SfxOrganizeListBox_Impl::GetLevelCount_Impl(SvLBoxEntry* pParent) const { SvLBoxEntry* pChild = FirstChild(pParent); USHORT nCount = 0; while(pChild) { pChild = NextSibling(pChild); ++nCount; } return nCount; } //------------------------------------------------------------------------- SvLBoxEntry* SfxOrganizeListBox_Impl::InsertEntryByBmpType( const XubString& rText, BMPTYPE eBmpType, SvLBoxEntry* pParent, BOOL bChildsOnDemand, ULONG nPos, void* pUserData ) { SvLBoxEntry* pEntry = NULL; const Image* pExp = NULL; const Image* pCol = NULL; const Image* pExpHC = NULL; const Image* pColHC = NULL; switch( eBmpType ) { case BMPTYPE_FOLDER: pExp = &aOpenedFolderBmp; pCol = &aClosedFolderBmp; pExpHC = &aOpenedFolderBmpHC; pColHC = &aClosedFolderBmpHC; break; default: DBG_ERROR( "SfxOrganizeListBox_Impl::InsertEntryByBmpType(): something forgotten?!" ); case BMPTYPE_DOC: pExp = &aOpenedDocBmp; pCol = &aClosedDocBmp; pExpHC = &aOpenedDocBmpHC; pColHC = &aClosedDocBmpHC; break; } pEntry = SvTreeListBox::InsertEntry( rText, *pExp, *pCol, pParent, bChildsOnDemand, nPos, pUserData ); SetExpandedEntryBmp( pEntry, *pExpHC, BMP_COLOR_HIGHCONTRAST ); SetCollapsedEntryBmp( pEntry, *pColHC, BMP_COLOR_HIGHCONTRAST ); return pEntry; } //------------------------------------------------------------------------- SfxOrganizeListBox_Impl::SfxOrganizeListBox_Impl ( SfxOrganizeDlg_Impl* pArgDlg, Window* pParent, WinBits nBits, DataEnum eType ) : SvTreeListBox( pParent, nBits ), pMgr ( NULL ), pDlg ( pArgDlg ), eViewType ( eType ) /* [Beschreibung] Konstruktor SfxOrganizeListBox */ { SetDragDropMode( SV_DRAGDROP_CTRL_MOVE | SV_DRAGDROP_CTRL_COPY | SV_DRAGDROP_APP_MOVE | SV_DRAGDROP_APP_COPY | SV_DRAGDROP_APP_DROP ); SetEntryHeight( 16 ); SetSelectionMode( SINGLE_SELECTION ); GetModel()->SetSortMode( SortNone ); EnableContextMenuHandling(); } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeListBox_Impl, OnAsyncExecuteDrop, ExecuteDropEvent*, pEvent ) { DBG_ASSERT( pEvent, "invalid DropEvent" ); if ( pEvent ) { SvLBox* pSourceView = GetSourceView(); if ( !pSourceView ) pSourceView = pDlg->pSourceView; pDlg->bExecDropFinished = false; // if a template can not be moved it should be copied if ( pEvent->mnAction == DND_ACTION_MOVE ) pEvent->mnAction = DND_ACTION_COPYMOVE; pDlg->nDropAction = SvTreeListBox::ExecuteDrop( *pEvent, pSourceView ); delete pEvent; pDlg->pSourceView = NULL; pDlg->pTargetEntry = NULL; pDlg->bExecDropFinished = true; if ( pDlg->pFinishedBox ) { pDlg->pFinishedBox->DragFinished( pDlg->nDropAction ); pDlg->pFinishedBox = NULL; } } return 0; } //------------------------------------------------------------------------- void SfxOrganizeListBox_Impl::Reset() /* [Beschreibung] Einf"ugen der Elemente in die ListBox */ { DBG_ASSERT( pMgr != 0, "kein Manager" ); // Inhalte l"oschen SetUpdateMode(FALSE); Clear(); if ( VIEW_TEMPLATES == eViewType ) { const USHORT nCount = pMgr->GetTemplates()->GetRegionCount(); for ( USHORT i = 0; i < nCount; ++i ) InsertEntryByBmpType( pMgr->GetTemplates()->GetFullRegionName(i), BMPTYPE_FOLDER, 0, TRUE ); } else { const SfxObjectList& rList = pMgr->GetObjectList(); const USHORT nCount = rList.Count(); for ( USHORT i = 0; i < nCount; ++i ) InsertEntryByBmpType( rList.GetBaseName(i), BMPTYPE_DOC, 0, TRUE ); } SetUpdateMode(TRUE); Invalidate(); Update(); } //------------------------------------------------------------------------- const Image &SfxOrganizeListBox_Impl::GetClosedBmp(USHORT nLevel) const /* [Beschreibung] Zugriff auf die Bitmap f"ur einen geschlossenen Eintrag der jeweiligen Ebene [Parameter] USHORT nLevel Angabe der Ebene, 2 Ebenen sind erlaubt [Returnwert] const Image & das Image auf der Ebenen nLevel */ { BOOL bHC = GetBackground().GetColor().IsDark(); const Image* pRet = NULL; switch( nLevel ) { default: DBG_ERROR( "Bitmaps ueberindiziert" ); case 0: pRet = bHC? &aClosedFolderBmpHC : &aClosedFolderBmp; break; case 1: pRet = bHC? &aClosedDocBmpHC : &aClosedDocBmp; break; } return *pRet; } //------------------------------------------------------------------------- const Image &SfxOrganizeListBox_Impl::GetOpenedBmp(USHORT nLevel) const /* [Beschreibung] Zugriff auf die Bitmap f"ur einen ge"offneten Eintrag der jeweiligen Ebene [Parameter] USHORT nLevel Angabe der Ebene, 2 Ebenen sind erlaubt [Returnwert] const Image & das Image auf der Ebenen nLevel */ { BOOL bHC = GetBackground().GetColor().IsDark(); const Image* pRet = NULL; switch( nLevel ) { case 0: pRet = bHC ? &aOpenedFolderBmpHC : &aOpenedFolderBmp; break; case 1: pRet = bHC ? &aOpenedDocBmpHC : &aOpenedDocBmp; break; default: pRet = bHC ? &aClosedFolderBmpHC : &aClosedFolderBmp; break; } return *pRet; } //------------------------------------------------------------------------- PopupMenu* SfxOrganizeListBox_Impl::CreateContextMenu() { return new PopupMenu( *( pDlg->aEditBtn.GetPopupMenu() ) ); } //------------------------------------------------------------------------- String SfxOrganizeDlg_Impl::GetPath_Impl( BOOL bOpen, const String& rFileName ) /* [Beschreibung] Pfad per FileDialog erfragen, f"ur Import / Export von Dokumentvorlagen [Parameter] BOOL bOpen Flag: "Offnen / Speichern const String& rFileName aktueller Dateiname als Vorschlag [R"uckgabewert] Dateiname mit Pfad oder Leerstring, wenn der Benutzer 'Abbrechen' gedr"uckt hat */ { String aPath; m_sExtension4Save = DEFINE_CONST_UNICODE( "vor" ); sal_Int16 nDialogType = bOpen ? com::sun::star::ui::dialogs::TemplateDescription::FILEOPEN_SIMPLE : com::sun::star::ui::dialogs::TemplateDescription::FILESAVE_SIMPLE; if ( pFileDlg ) delete pFileDlg; pFileDlg = new sfx2::FileDialogHelper( nDialogType, 0L ); // add "All" filter pFileDlg->AddFilter( String( SfxResId( STR_SFX_FILTERNAME_ALL ) ), DEFINE_CONST_UNICODE( FILEDIALOG_FILTER_ALL ) ); // add template filter String sFilterName( SfxResId( STR_TEMPLATE_FILTER ) ); String sFilterExt; // add filters of modules which are installed SvtModuleOptions aModuleOpt; if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SWRITER ) ) sFilterExt += DEFINE_CONST_UNICODE( "*.ott;*.stw;*.oth" ); if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SCALC ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.ots;*.stc" ); } if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SIMPRESS ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.otp;*.sti" ); } if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SDRAW ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.otg;*.std" ); } if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.vor" ); sFilterName += DEFINE_CONST_UNICODE( " (" ); sFilterName += sFilterExt; sFilterName += ')'; pFileDlg->AddFilter( sFilterName, sFilterExt ); pFileDlg->SetCurrentFilter( sFilterName ); if ( aLastDir.Len() || rFileName.Len() ) { INetURLObject aObj; if ( aLastDir.Len() ) { aObj.SetURL( aLastDir ); if ( rFileName.Len() ) aObj.insertName( rFileName ); } else aObj.SetURL( rFileName ); if ( aObj.hasExtension() ) { m_sExtension4Save = aObj.getExtension( INetURLObject::LAST_SEGMENT, true, INetURLObject::DECODE_WITH_CHARSET ); aObj.removeExtension(); } DBG_ASSERT( aObj.GetProtocol() != INET_PROT_NOT_VALID, "Invalid URL!" ); pFileDlg->SetDisplayDirectory( aObj.GetMainURL( INetURLObject::NO_DECODE ) ); } pFileDlg->StartExecuteModal( LINK( this, SfxOrganizeDlg_Impl, ImportHdl ) ); return aPath; } //------------------------------------------------------------------------- ::com::sun::star::uno::Sequence< ::rtl::OUString > SfxOrganizeDlg_Impl::GetPaths_Impl( const String& rFileName ) /* [Description] Query plural paths by FileDialog, for Import / Export from document templates [Parameter] const String& rFileName The default file name when dialog executes [Return value] Empty sequence when users have clicked 'Cancel', a sequence just containing one file name with path when they have choosed one file or a sequence containing path and file names without path */ { ::com::sun::star::uno::Sequence< ::rtl::OUString > aPaths; m_sExtension4Save = DEFINE_CONST_UNICODE( "vor" ); if ( pFileDlg ) delete pFileDlg; pFileDlg = new sfx2::FileDialogHelper( com::sun::star::ui::dialogs::TemplateDescription::FILEOPEN_SIMPLE, SFXWB_MULTISELECTION ); // add "All" filter pFileDlg->AddFilter( String( SfxResId( STR_SFX_FILTERNAME_ALL ) ), DEFINE_CONST_UNICODE( FILEDIALOG_FILTER_ALL ) ); // add template filter String sFilterName( SfxResId( STR_TEMPLATE_FILTER ) ); String sFilterExt; // add filters of modules which are installed SvtModuleOptions aModuleOpt; if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SWRITER ) ) sFilterExt += DEFINE_CONST_UNICODE( "*.ott;*.stw;*.oth" ); if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SCALC ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.ots;*.stc" ); } if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SIMPRESS ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.otp;*.sti" ); } if ( aModuleOpt.IsModuleInstalled( SvtModuleOptions::E_SDRAW ) ) { if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.otg;*.std" ); } if ( sFilterExt.Len() > 0 ) sFilterExt += ';'; sFilterExt += DEFINE_CONST_UNICODE( "*.vor" ); sFilterName += DEFINE_CONST_UNICODE( " (" ); sFilterName += sFilterExt; sFilterName += ')'; pFileDlg->AddFilter( sFilterName, sFilterExt ); pFileDlg->SetCurrentFilter( sFilterName ); if ( aLastDir.Len() || rFileName.Len() ) { INetURLObject aObj; if ( aLastDir.Len() ) { aObj.SetURL( aLastDir ); if ( rFileName.Len() ) aObj.insertName( rFileName ); } else aObj.SetURL( rFileName ); if ( aObj.hasExtension() ) { m_sExtension4Save = aObj.getExtension( INetURLObject::LAST_SEGMENT, true, INetURLObject::DECODE_WITH_CHARSET ); aObj.removeExtension(); } DBG_ASSERT( aObj.GetProtocol() != INET_PROT_NOT_VALID, "Invalid URL!" ); pFileDlg->SetDisplayDirectory( aObj.GetMainURL( INetURLObject::NO_DECODE ) ); } pFileDlg->StartExecuteModal( LINK( this, SfxOrganizeDlg_Impl, ExportHdl ) ); return aPaths; } //------------------------------------------------------------------------- BOOL SfxOrganizeDlg_Impl::DontDelete_Impl( SvLBoxEntry* pEntry ) { USHORT nDepth = pFocusBox->GetModel()->GetDepth(pEntry); if(SfxOrganizeListBox_Impl::VIEW_FILES == pFocusBox->GetViewType()) nDepth++; if( nDepth > 2 && !pEntry->GetUserData() || //Delete ueber GetContent verboten nDepth==2 || //Vorlage / Konfigurtionsrubrik nicht loeshcen (nDepth==1 && SfxOrganizeListBox_Impl::VIEW_FILES == pFocusBox->GetViewType()) || //Files nicht loeschen (0 == nDepth && pFocusBox->GetLevelCount_Impl(0) < 2)) //Mindestens eine Vorlage behalten { return TRUE; } USHORT nRegion = 0, nIndex = 0; GetIndices_Impl( pFocusBox, pEntry, nRegion, nIndex ); const SfxDocumentTemplates* pTemplates = aMgr.GetTemplates(); if ( !pTemplates || !pTemplates->HasUserContents( nRegion, nIndex ) ) return TRUE; return FALSE; } SvStringsDtor* SfxOrganizeDlg_Impl::GetAllFactoryURLs_Impl( ) const { SvtModuleOptions aModOpt; const ::com::sun::star::uno::Sequence < ::rtl::OUString >& aServiceNames = aModOpt.GetAllServiceNames() ; SvStringsDtor* pList = new SvStringsDtor; sal_Int32 nCount = aServiceNames.getLength(); for( sal_Int32 i=0; i 0 ) { SvtModuleOptions::EFactory eFac = SvtModuleOptions::E_WRITER; SvtModuleOptions::ClassifyFactoryByName( aServiceNames[i], eFac ); String* pURL = new String( aModOpt.GetFactoryEmptyDocumentURL( eFac ) ); pList->Insert( pURL, pList->Count() ); } } return pList; } sal_Bool SfxOrganizeDlg_Impl::GetServiceName_Impl( String& rName, String& rFileURL ) const { sal_Bool bRet = sal_False; const SfxDocumentTemplates* pTemplates = aMgr.GetTemplates(); SvLBoxEntry* pEntry = pFocusBox ? pFocusBox->FirstSelected() : NULL; USHORT nRegion = 0, nIndex = 0; GetIndices_Impl( pFocusBox, pEntry, nRegion, nIndex ); rFileURL = pTemplates->GetPath( nRegion, nIndex ); if ( rFileURL.Len() > 0 ) { try { uno::Reference< embed::XStorage > xStorage = ::comphelper::OStorageHelper::GetStorageFromURL( rFileURL, embed::ElementModes::READ ); ULONG nFormat = SotStorage::GetFormatID( xStorage ); const SfxFilter* pFilter = SFX_APP()->GetFilterMatcher().GetFilter4ClipBoardId( nFormat ); if ( pFilter ) { rName = pFilter->GetServiceName(); bRet = TRUE; } } catch( uno::Exception& ) {} } return bRet; } long SfxOrganizeDlg_Impl::Dispatch_Impl( USHORT nId, Menu* _pMenu ) /* [Beschreibung] Verarbeiten der Events aus MenuButton oder Accelerator [Parameter] USHORT nId ID des Events [R"uckgabewert] 1: Event wurde verarbeitet, 0: Event wurde nicht verarbeitet (SV-Menu) */ { SuspendAccel aTmp(&aEditAcc); SvLBoxEntry *pEntry = pFocusBox? pFocusBox->FirstSelected(): 0; sal_Bool bHandled = sal_True; switch(nId) { case ID_NEW: { if(!pEntry) return 1; if(pFocusBox->GetViewType() == SfxOrganizeListBox_Impl::VIEW_TEMPLATES) { if(0 == pFocusBox->GetModel()->GetDepth(pEntry)) { const String aNoName( SfxResId(STR_NONAME) ); SvLBoxEntry* pParent = pFocusBox->GetParent(pEntry); String aName(aNoName); USHORT n = 1; while(!pFocusBox->IsUniqName_Impl(aName, pParent)) { aName = aNoName; aName += String::CreateFromInt32( n++ ); } aMgr.InsertDir( pFocusBox, aName, (USHORT)pFocusBox->GetModel()->GetRelPos(pEntry)+1); } } break; } case ID_DELETE: { if(!pEntry || DontDelete_Impl(pEntry)) return 1; const USHORT nDepth = pFocusBox->GetModel()->GetDepth(pEntry); if(nDepth < 2) { if(0 == nDepth && pFocusBox->GetLevelCount_Impl(0) < 2) return 1; if(SfxOrganizeListBox_Impl::VIEW_TEMPLATES == pFocusBox->GetViewType()) { USHORT nResId = nDepth? STR_DELETE_TEMPLATE : STR_DELETE_REGION; if( !QueryDelete_Impl( pDialog, nResId, pFocusBox->GetEntryText(pEntry))) return 1; if ( STR_DELETE_REGION == nResId && pFocusBox->GetChildCount(pEntry)) { QueryBox aQBox(pDialog, SfxResId(MSG_REGION_NOTEMPTY)); if(RET_NO == aQBox.Execute()) return 1; } USHORT nRegion = 0, nIndex = 0; GetIndices_Impl(pFocusBox, pEntry, nRegion, nIndex); USHORT nDeleteInd = ( STR_DELETE_REGION == nResId? USHRT_MAX: nIndex ); if ( !aMgr.Delete( pFocusBox, nRegion, nDeleteInd ) ) ErrorDelete_Impl( pDialog, pFocusBox->GetEntryText(pEntry), ( nDeleteInd == USHRT_MAX && pFocusBox->GetChildCount(pEntry) ) ); } } // Inhaltsformen else if(nDepth + pFocusBox->GetDocLevel() >= 2) { if(!QueryDelete_Impl(pDialog, STR_DELETE_TEMPLATE, pFocusBox->GetEntryText(pEntry))) return 1; Path aPath(pFocusBox, pEntry); SfxObjectShellRef aRef = pFocusBox->GetObjectShell(aPath); if(aRef.Is() && aRef->Remove(aPath[1+pFocusBox->GetDocLevel()], aPath[2+pFocusBox->GetDocLevel()], aPath[3+pFocusBox->GetDocLevel()])) pFocusBox->GetModel()->Remove(pEntry); else ErrorDelete_Impl(pDialog, pFocusBox->GetEntryText(pEntry), sal_False ); } break; } case ID_EDIT: { if(!pEntry) return 1; USHORT nRegion = 0, nIndex = 0; GetIndices_Impl( pFocusBox, pEntry, nRegion, nIndex ); const SfxStringItem aName( SID_FILE_NAME, aMgr.GetTemplates()->GetPath( nRegion, nIndex ) ); const SfxStringItem aLongName( SID_FILE_LONGNAME, pFocusBox->GetEntryText( pEntry ) ); const SfxStringItem aReferer( SID_REFERER, DEFINE_CONST_UNICODE( "private:user" ) ); const SfxStringItem aTargetName( SID_TARGETNAME, DEFINE_CONST_UNICODE( "_default" ) ); const SfxBoolItem aTemplateIndicator( SID_TEMPLATE, sal_False ); SFX_APP()->GetAppDispatcher_Impl()->Execute( SID_OPENTEMPLATE, SFX_CALLMODE_ASYNCHRON | SFX_CALLMODE_RECORD, &aName, &aLongName, &aReferer, &aTargetName, &aTemplateIndicator, 0L ); pDialog->EndDialog( RET_EDIT_STYLE ); break; } case ID_COPY_FROM: { if ( !pEntry ) return 1; m_nRegion = 0; m_nIndex = 0; GetIndices_Impl( pFocusBox, pEntry, m_nRegion, m_nIndex ); GetPaths_Impl( String() ); break; } case ID_COPY_TO: { if ( !pEntry ) return 1; m_nRegion = 0; m_nIndex = 0; GetIndices_Impl( pFocusBox, pEntry, m_nRegion, m_nIndex ); GetPath_Impl( FALSE, aMgr.GetTemplates()->GetFileName( m_nRegion, m_nIndex ) ); break; } case ID_RESCAN: if ( !aMgr.Rescan() ) ErrorBox( pDialog, SfxResId( MSG_ERROR_RESCAN ) ).Execute(); if ( SfxOrganizeListBox_Impl::VIEW_TEMPLATES == aLeftLb.GetViewType() ) aLeftLb.Reset(); if ( SfxOrganizeListBox_Impl::VIEW_TEMPLATES == aRightLb.GetViewType() ) aRightLb.Reset(); break; case ID_PRINT: { if ( !pEntry ) return 1; Path aPath( pFocusBox, pEntry ); SfxObjectShellRef aRef = pFocusBox->GetObjectShell( aPath ); if ( aRef.Is() ) { const USHORT nDocLevel = pFocusBox->GetDocLevel(); if ( !pPrt ) pPrt = new Printer; SvLBoxEntry *pDocEntry = pEntry; while ( pFocusBox->GetModel()->GetDepth( pDocEntry ) > nDocLevel ) pDocEntry = pFocusBox->GetParent( pDocEntry ); const String aName(pFocusBox->GetEntryText(pDocEntry)); if ( !aRef->Print( *pPrt, aPath[1+nDocLevel], aPath[2+nDocLevel], aPath[3+nDocLevel], &aName ) ) ErrorBox( pDialog, SfxResId( MSG_PRINT_ERROR ) ).Execute(); } break; } case ID_PRINTER_SETUP: { PrinterSetupDialog* pDlg = new PrinterSetupDialog( pDialog ); if ( !pPrt ) pPrt = new Printer; pDlg->SetPrinter( pPrt ); pDlg->Execute(); delete pDlg; break; } case ID_DEFAULT_TEMPLATE: { String aServiceName, aFileURL; if ( GetServiceName_Impl( aServiceName, aFileURL ) ) SfxObjectFactory::SetStandardTemplate( aServiceName, aFileURL ); break; } default: bHandled = sal_False; } if ( !bHandled && ( nId > ID_RESET_DEFAULT_TEMPLATE || nId <= ID_RESET_DEFAULT_TEMPLATE_END ) ) { Menu* pSubMenu = _pMenu ? _pMenu : aEditBtn.GetPopupMenu()->GetPopupMenu( ID_RESET_DEFAULT_TEMPLATE ); if ( pSubMenu ) { String aServiceName = SfxObjectShell::GetServiceNameFromFactory( pSubMenu->GetItemCommand( nId ) ); SfxObjectFactory::SetStandardTemplate( aServiceName, String() ); bHandled = sal_True; } } return bHandled ? 1 : 0; } //------------------------------------------------------------------------- IMPL_LINK_INLINE_START( SfxOrganizeDlg_Impl, MenuSelect_Impl, Menu *, pMenu ) /* [Beschreibung] SelectHandler des Men"us des Men"ubuttons (SV) [Parameter] MenuButton *pBtn der das Event ausl"osende Button [R"uckgabewert] 1: Event wurde verarbeitet, 0: Event wurde nicht verarbeitet (SV-Menu) */ { return Dispatch_Impl( pMenu->GetCurItemId(), pMenu ); } IMPL_LINK_INLINE_END( SfxOrganizeDlg_Impl, MenuSelect_Impl, Menu *, pMenu ) //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, AccelSelect_Impl, Accelerator *, pAccel ) /* [Beschreibung] SelectHandler des Accelerators (SV) [Parameter] Accelerator *pAccel der das Event ausl"osende Accelerator [R"uckgabewert] 1: Event wurde verarbeitet, 0: Event wurde nicht verarbeitet (SV) */ { SvLBoxEntry* pEntry = pFocusBox && pFocusBox->GetSelectionCount() ? pFocusBox->FirstSelected() : NULL ; return pEntry && ( pAccel->GetCurItemId() == ID_NEW || !DontDelete_Impl( pEntry ) ) ? Dispatch_Impl( pAccel->GetCurItemId(), NULL ) : 0; } //------------------------------------------------------------------------- void SfxOrganizeDlg_Impl::OkHdl(Button *pButton) { if(pFocusBox && pFocusBox->IsEditingActive()) pFocusBox->EndEditing(FALSE); pButton->Click(); } IMPL_LINK( SfxOrganizeDlg_Impl, MenuActivate_Impl, Menu *, pMenu ) /* [Beschreibung] ActivateHandler des Men"us des Men"ubuttons (SV) [Parameter] Menu *pMenu das das Event ausl"osende Men"u [R"uckgabewert] 1: Event wurde verarbeitet, 0: Event wurde nicht verarbeitet (SV-Menu) */ { if ( pFocusBox && pFocusBox->IsEditingActive() ) pFocusBox->EndEditing( FALSE ); BOOL bEnable = ( pFocusBox && pFocusBox->GetSelectionCount() ); SvLBoxEntry* pEntry = bEnable ? pFocusBox->FirstSelected() : NULL; const USHORT nDepth = ( bEnable && pFocusBox->GetSelectionCount() ) ? pFocusBox->GetModel()->GetDepth( pEntry ) : 0; const USHORT nDocLevel = bEnable ? pFocusBox->GetDocLevel() : 0; int eVT = pFocusBox ? pFocusBox->GetViewType() : 0; // nur Vorlagen anlegen pMenu->EnableItem( ID_NEW, bEnable && 0 == nDepth && SfxOrganizeListBox_Impl::VIEW_TEMPLATES == eVT ); // Vorlagen: Loeschen Ebene 0,1,3ff // ein Bereich mu"s mindestens erhalten bleiben // Dateien : Loeschen Ebene > 2 pMenu->EnableItem( ID_DELETE, bEnable && !DontDelete_Impl( pEntry ) ); pMenu->EnableItem( ID_EDIT, bEnable && eVT == SfxOrganizeListBox_Impl::VIEW_TEMPLATES && nDepth == nDocLevel && !DontDelete_Impl( pEntry ) ); pMenu->EnableItem( ID_COPY_FROM, bEnable && eVT == SfxOrganizeListBox_Impl::VIEW_TEMPLATES && ( nDepth == nDocLevel || nDepth == nDocLevel - 1 ) ); pMenu->EnableItem( ID_COPY_TO, bEnable && eVT == SfxOrganizeListBox_Impl::VIEW_TEMPLATES && nDepth == nDocLevel ); pMenu->EnableItem( ID_RESCAN, SfxOrganizeListBox_Impl::VIEW_TEMPLATES == aRightLb.GetViewType() || SfxOrganizeListBox_Impl::VIEW_TEMPLATES == aLeftLb.GetViewType() ); BOOL bPrint = bEnable && nDepth > pFocusBox->GetDocLevel(); if ( bPrint && pPrt ) bPrint = !pPrt->IsPrinting() && !pPrt->IsJobActive(); if ( bPrint && bEnable ) { // only styles printable Path aPath( pFocusBox, pFocusBox->FirstSelected() ); USHORT nIndex = aPath[ nDocLevel + 1 ]; bPrint = ( nIndex == CONTENT_STYLE ); } pMenu->EnableItem( ID_PRINT, bPrint ); if ( bEnable && eVT == SfxOrganizeListBox_Impl::VIEW_TEMPLATES && nDepth == nDocLevel ) { String aFactoryURL, aFileURL; bEnable = GetServiceName_Impl( aFactoryURL, aFileURL ); } else if ( bEnable ) bEnable = FALSE; pMenu->EnableItem( ID_DEFAULT_TEMPLATE, bEnable ); bEnable = sal_True; SvStringsDtor* pList = GetAllFactoryURLs_Impl(); USHORT nCount = pList->Count(); if ( nCount > 0 ) { PopupMenu* pSubMenu = new PopupMenu; USHORT nItemId = ID_RESET_DEFAULT_TEMPLATE + 1; for ( USHORT i = 0; i < nCount; ++i ) { String aObjFacURL( *pList->GetObject(i) ); String aTitle = SvFileInformationManager::GetDescription( INetURLObject(aObjFacURL) ); pSubMenu->InsertItem( nItemId, aTitle, SvFileInformationManager::GetImage(INetURLObject(aObjFacURL)) ); pSubMenu->SetItemCommand( nItemId++, aObjFacURL ); DBG_ASSERT( nItemId <= ID_RESET_DEFAULT_TEMPLATE_END, "menu item id overflow" ); } pMenu->SetPopupMenu( ID_RESET_DEFAULT_TEMPLATE, pSubMenu ); } else bEnable = sal_False; delete pList; pMenu->EnableItem( ID_RESET_DEFAULT_TEMPLATE, bEnable ); return 1; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, GetFocus_Impl, SfxOrganizeListBox_Impl *, pBox ) /* [Beschreibung] GetFocus-Handler, wird aus den Select-Handler der Listboxen gerufen. Wird verwendet, im die Listbox, die den Focus besitzt sowie deren Zustand zu ermitteln. [Parameter] SfxOrganizeListBox *pBox die rufende Box */ { if(pFocusBox && pFocusBox != pBox) pFocusBox->SelectAll(FALSE); pFocusBox = pBox; aFilesBtn.Enable( SfxOrganizeListBox_Impl::VIEW_FILES == pFocusBox->GetViewType() ); return 0; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, LeftListBoxSelect_Impl, ListBox *, pBox ) /* [Beschreibung] Select-Handler, wird aus den Select-Handler der Listboxen gerufen. Wenn sich der Modus der Boxen (Dokumentsicht, Dokumentvorlagensicht) unterscheiden, werden die Models getrennt; andernfalls zusammengefa"st. [Parameter] ListBox *pBox die rufende Box */ { const SfxOrganizeListBox_Impl::DataEnum eViewType = pBox->GetSelectEntryPos() == 0 ? SfxOrganizeListBox_Impl::VIEW_TEMPLATES : SfxOrganizeListBox_Impl::VIEW_FILES; if(eViewType!= aLeftLb.GetViewType()) { aLeftLb.SetViewType(eViewType); if(aRightLb.GetViewType() == eViewType) aLeftLb.SetModel(aRightLb.GetModel()); else { // Models trennen aLeftLb.DisconnectFromModel(); aLeftLb.Reset(); } } GetFocus_Impl(&aLeftLb); return 0; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, RightListBoxSelect_Impl, ListBox *, pBox ) /* [Beschreibung] Select-Handler, wird aus den Select-Handler der Listboxen gerufen. Wenn sich der Modus der Boxen (Dokumentsicht, Dokumentvorlagensicht) unterscheiden, werden die Models getrennt; andernfalls zusammengefa"st. [Parameter] ListBox *pBox die rufende Box */ { const SfxOrganizeListBox_Impl::DataEnum eViewType = pBox->GetSelectEntryPos() == 0 ? SfxOrganizeListBox_Impl::VIEW_TEMPLATES : SfxOrganizeListBox_Impl::VIEW_FILES; if(eViewType!= aRightLb.GetViewType()) { aRightLb.SetViewType(eViewType); if(aLeftLb.GetViewType() == eViewType) aRightLb.SetModel(aLeftLb.GetModel()); else { // Models trennen aRightLb.DisconnectFromModel(); aRightLb.Reset(); } } aRightLb.GrabFocus(); GetFocus_Impl(&aRightLb); return 0; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, OnAddressTemplateClicked, Button *, pButton ) { (void)pButton; //unused svt::AddressBookSourceDialog aDialog(pDialog, ::comphelper::getProcessServiceFactory()); aDialog.Execute(); return 0L; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, AddFiles_Impl, Button *, pButton ) /* [Beschreibung] Handler des Buttons f"ur das Hinzuf"ugen von Dateien per Dialog. [Parameter] Button * der Button, der dieses Events ausgel"ost hat. */ { (void)pButton; //unused if ( pFileDlg ) delete pFileDlg; pFileDlg = new sfx2::FileDialogHelper( WB_OPEN, String() ); // add config and basic filter static String sOpenBracket( DEFINE_CONST_UNICODE( " (" ) ); static String sCloseBracket( DEFINE_CONST_UNICODE( ")" ) ); static String sConfigExt( DEFINE_CONST_UNICODE( "*.cfg" ) ); static String sBasicExt( DEFINE_CONST_UNICODE( "*.sbl" ) ); String sFilterName( SfxResId( RID_STR_FILTCONFIG ) ); sFilterName += sOpenBracket; sFilterName += sConfigExt; sFilterName += sCloseBracket; pFileDlg->AddFilter( sFilterName, sConfigExt ); sFilterName = String( SfxResId( RID_STR_FILTBASIC ) ); sFilterName += sOpenBracket; sFilterName += sBasicExt; sFilterName += sCloseBracket; pFileDlg->AddFilter( sFilterName, sBasicExt ); // set "All" filter as current pFileDlg->SetCurrentFilter( String( SfxResId( STR_SFX_FILTERNAME_ALL ) ) ); if ( aLastDir.Len() ) pFileDlg->SetDisplayDirectory( aLastDir ); pFileDlg->StartExecuteModal( LINK( this, SfxOrganizeDlg_Impl, AddFilesHdl ) ); return 0; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, ImportHdl, sfx2::FileDialogHelper *, EMPTYARG ) { DBG_ASSERT( pFileDlg, "SfxOrganizeDlg_Impl::ImportHdl(): no file dialog" ); if ( ERRCODE_NONE == pFileDlg->GetError() ) { String aPath = pFileDlg->GetPath(); INetURLObject aObj( aPath ); // we want to keep the original extension when exporting, the file open dialog // always sets the extension to *.vor if ( pFileDlg->GetDialogType() == com::sun::star::ui::dialogs::TemplateDescription::FILESAVE_SIMPLE ) { if ( aObj.hasExtension() ) aObj.removeExtension(); aObj.setExtension( m_sExtension4Save ); aPath = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); } aObj.removeSegment(); aLastDir = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); if ( aPath.Len() && !aMgr.CopyTo( m_nRegion, m_nIndex, aPath ) ) { String aText( SfxResId( STR_ERROR_COPY_TEMPLATE ) ); aText.SearchAndReplaceAscii( "$1", aPath ); ErrorBox( pDialog, WB_OK, aText ).Execute(); } } return 0L; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, ExportHdl, sfx2::FileDialogHelper *, EMPTYARG ) { DBG_ASSERT( pFileDlg, "SfxOrganizeDlg_Impl::ImportHdl(): no file dialog" ); ::com::sun::star::uno::Sequence< ::rtl::OUString > aPaths; if ( ERRCODE_NONE == pFileDlg->GetError() ) { aPaths = pFileDlg->GetMPath(); sal_Int32 lastCount = aPaths.getLength() - 1; INetURLObject aObj( aPaths.getArray()[ lastCount ] ); aObj.removeSegment(); aLastDir = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); } sal_Int32 nCount = aPaths.getLength(); if ( 1 == nCount ) { String aPath = String( aPaths.getArray()[0] ); if ( aPath.Len() && !aMgr.CopyFrom( pFocusBox, m_nRegion, m_nIndex, aPath ) ) { String aText( SfxResId( STR_ERROR_COPY_TEMPLATE ) ); aText.SearchAndReplaceAscii( "$1", aPath ); ErrorBox( pDialog, WB_OK, aText ).Execute(); } } else if ( nCount > 1 ) { INetURLObject aPathObj( aPaths[0] ); aPathObj.setFinalSlash(); for ( USHORT i = 1; i < nCount; ++i ) { if ( 1 == i ) aPathObj.Append( aPaths[i] ); else aPathObj.setName( aPaths[i] ); String aPath = aPathObj.GetMainURL( INetURLObject::NO_DECODE ); if ( aPath.Len() && !aMgr.CopyFrom( pFocusBox, m_nRegion, m_nIndex, aPath ) ) { String aText( SfxResId( STR_ERROR_COPY_TEMPLATE ) ); aText.SearchAndReplaceAscii( "$1", aPath ); ErrorBox( pDialog, WB_OK, aText ).Execute(); } } } return 0L; } //------------------------------------------------------------------------- IMPL_LINK( SfxOrganizeDlg_Impl, AddFilesHdl, sfx2::FileDialogHelper *, EMPTYARG ) { if ( ERRCODE_NONE == pFileDlg->GetError() ) { String aPath = pFileDlg->GetPath(); aMgr.InsertFile( pFocusBox, aPath ); INetURLObject aObj( aPath ); aObj.removeSegment(); aObj.setFinalSlash(); aLastDir = aObj.GetMainURL( INetURLObject::DECODE_TO_IURI ); } return 0L; } //------------------------------------------------------------------------- short SfxTemplateOrganizeDlg::Execute() /* [Beschreibung] "Uberladene Execute- Methode; speichert gfs. "Anderungen an den Dokumentvorlagen (SV-Methode) */ { const short nRet = ModalDialog::Execute(); if(RET_CANCEL != nRet) { pImp->aMgr.SaveAll(this); SfxTemplateDialog* pTemplDlg = SFX_APP()->GetTemplateDialog(); if(pTemplDlg) pTemplDlg->Update(); } return nRet; } //------------------------------------------------------------------------- SfxTemplateOrganizeDlg::SfxTemplateOrganizeDlg(Window * pParent, SfxDocumentTemplates *pTempl) : ModalDialog( pParent, SfxResId(DLG_ORGANIZE)), pImp( new SfxOrganizeDlg_Impl(this, pTempl) ) /* [Beschreibung] Konstruktor */ { FreeResource(); } //------------------------------------------------------------------------- SfxTemplateOrganizeDlg::~SfxTemplateOrganizeDlg() { GetpApp()->RemoveAccel(&pImp->aEditAcc); delete pImp->pPrt; delete pImp; }