summaryrefslogtreecommitdiff
path: root/cui/source/options/optpath.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'cui/source/options/optpath.cxx')
-rw-r--r--cui/source/options/optpath.cxx850
1 files changed, 0 insertions, 850 deletions
diff --git a/cui/source/options/optpath.cxx b/cui/source/options/optpath.cxx
deleted file mode 100644
index ddf4d6170..000000000
--- a/cui/source/options/optpath.cxx
+++ /dev/null
@@ -1,850 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*************************************************************************
- *
- * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
- *
- * Copyright 2000, 2010 Oracle and/or its affiliates.
- *
- * OpenOffice.org - a multi-platform office productivity suite
- *
- * This file is part of OpenOffice.org.
- *
- * OpenOffice.org is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License version 3
- * only, as published by the Free Software Foundation.
- *
- * OpenOffice.org 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 version 3 for more details
- * (a copy is included in the LICENSE file that accompanied this code).
- *
- * You should have received a copy of the GNU Lesser General Public License
- * version 3 along with OpenOffice.org. If not, see
- * <http://www.openoffice.org/license.html>
- * for a copy of the LGPLv3 License.
- *
- ************************************************************************/
-
-// include ---------------------------------------------------------------
-
-#include <svx/svxdlg.hxx>
-#include <tools/shl.hxx>
-#include <vcl/msgbox.hxx>
-#include <sfx2/filedlghelper.hxx>
-#include <sfx2/app.hxx>
-#include <svl/aeitem.hxx>
-#include <svtools/svtabbx.hxx>
-#include <tools/config.hxx>
-#include <tools/urlobj.hxx>
-#include <vcl/svapp.hxx>
-#include <unotools/defaultoptions.hxx>
-#include <unotools/localfilehelper.hxx>
-#include <unotools/pathoptions.hxx>
-#include <unotools/moduleoptions.hxx>
-#include <unotools/viewoptions.hxx>
-
-#define _SVX_OPTPATH_CXX
-
-#include "optpath.hxx"
-#include <dialmgr.hxx>
-#include "optpath.hrc"
-#include <cuires.hrc>
-#include "helpid.hrc"
-#include <comphelper/processfactory.hxx>
-#include <comphelper/configurationhelper.hxx>
-#include <com/sun/star/uno/Exception.hpp>
-#include <com/sun/star/beans/XPropertySet.hpp>
-#include <com/sun/star/beans/PropertyAttribute.hpp>
-#include <com/sun/star/lang/XMultiServiceFactory.hpp>
-#include <com/sun/star/ui/dialogs/ExecutableDialogResults.hpp>
-#include <com/sun/star/ui/dialogs/XAsynchronousExecutableDialog.hpp>
-#include "optHeaderTabListbox.hxx"
-#include <readonlyimage.hxx>
-#include <vcl/help.hxx>
-
-using namespace ::com::sun::star::beans;
-using namespace ::com::sun::star::lang;
-using namespace ::com::sun::star::ui::dialogs;
-using namespace ::com::sun::star::uno;
-using namespace svx;
-
-// define ----------------------------------------------------------------
-
-#define TAB_WIDTH1 80
-#define TAB_WIDTH_MIN 10
-#define TAB_WIDTH2 1000
-#define ITEMID_TYPE 1
-#define ITEMID_PATH 2
-
-#define POSTFIX_INTERNAL String::CreateFromAscii( RTL_CONSTASCII_STRINGPARAM( "_internal" ) )
-#define POSTFIX_USER String::CreateFromAscii( RTL_CONSTASCII_STRINGPARAM( "_user" ) )
-#define POSTFIX_WRITABLE String::CreateFromAscii( RTL_CONSTASCII_STRINGPARAM( "_writable" ) )
-#define POSTFIX_READONLY String::CreateFromAscii( RTL_CONSTASCII_STRINGPARAM( "_readonly" ) )
-#define VAR_ONE String::CreateFromAscii( RTL_CONSTASCII_STRINGPARAM( "%1" ) )
-#define IODLG_CONFIGNAME String(DEFINE_CONST_UNICODE("FilePicker_Save"))
-
-// struct OptPath_Impl ---------------------------------------------------
-
-struct OptPath_Impl
-{
- SvtDefaultOptions m_aDefOpt;
- Image m_aLockImage;
- Image m_aLockImageHC;
- String m_sMultiPathDlg;
- Reference< XPropertySet > m_xPathSettings;
-
- OptPath_Impl(const ResId& rLockRes, const ResId& rLockResHC) :
- m_aLockImage(rLockRes),
- m_aLockImageHC(rLockResHC){}
-};
-
-// struct PathUserData_Impl ----------------------------------------------
-
-struct PathUserData_Impl
-{
- sal_uInt16 nRealId;
- SfxItemState eState;
- String sUserPath;
- String sWritablePath;
-
- PathUserData_Impl( sal_uInt16 nId ) :
- nRealId( nId ), eState( SFX_ITEM_UNKNOWN ) {}
-};
-
-struct Handle2CfgNameMapping_Impl
-{
- sal_uInt16 m_nHandle;
- const char* m_pCfgName;
-};
-
-static Handle2CfgNameMapping_Impl const Hdl2CfgMap_Impl[] =
-{
- { SvtPathOptions::PATH_AUTOCORRECT, "AutoCorrect" },
- { SvtPathOptions::PATH_AUTOTEXT, "AutoText" },
- { SvtPathOptions::PATH_BACKUP, "Backup" },
- { SvtPathOptions::PATH_GALLERY, "Gallery" },
- { SvtPathOptions::PATH_GRAPHIC, "Graphic" },
- { SvtPathOptions::PATH_TEMP, "Temp" },
- { SvtPathOptions::PATH_TEMPLATE, "Template" },
- { SvtPathOptions::PATH_WORK, "Work" },
-#if OSL_DEBUG_LEVEL > 1
- { SvtPathOptions::PATH_LINGUISTIC, "Linguistic" },
- { SvtPathOptions::PATH_DICTIONARY, "Dictionary" },
-#endif
- { USHRT_MAX, NULL }
-};
-
-static String getCfgName_Impl( sal_uInt16 _nHandle )
-{
- String sCfgName;
- sal_uInt16 nIndex = 0;
- while ( Hdl2CfgMap_Impl[ nIndex ].m_nHandle != USHRT_MAX )
- {
- if ( Hdl2CfgMap_Impl[ nIndex ].m_nHandle == _nHandle )
- {
- // config name found
- sCfgName = String::CreateFromAscii( Hdl2CfgMap_Impl[ nIndex ].m_pCfgName );
- break;
- }
- ++nIndex;
- }
-
- return sCfgName;
-}
-
-#define MULTIPATH_DELIMITER ';'
-
-String Convert_Impl( const String& rValue )
-{
- char cDelim = MULTIPATH_DELIMITER;
- sal_uInt16 nCount = rValue.GetTokenCount( cDelim );
- String aReturn;
- for ( sal_uInt16 i=0; i<nCount ; ++i )
- {
- String aValue = rValue.GetToken( i, cDelim );
- INetURLObject aObj( aValue );
- if ( aObj.GetProtocol() == INET_PROT_FILE )
- aReturn += String(aObj.PathToFileName());
- else if ( ::utl::LocalFileHelper::IsFileContent( aValue ) )
- aReturn += String(aObj.GetURLPath( INetURLObject::DECODE_WITH_CHARSET ));
- if ( i+1 < nCount)
- aReturn += MULTIPATH_DELIMITER;
- }
-
- return aReturn;
-}
-
-// class SvxControlFocusHelper ---------------------------------------------
-
-long SvxControlFocusHelper::Notify( NotifyEvent& rNEvt )
-{
- long nRet = Control::Notify( rNEvt );
-
- if ( m_pFocusCtrl && rNEvt.GetWindow() != m_pFocusCtrl && rNEvt.GetType() == EVENT_GETFOCUS )
- m_pFocusCtrl->GrabFocus();
- return nRet;
-}
-
-// functions -------------------------------------------------------------
-
-sal_Bool IsMultiPath_Impl( const sal_uInt16 nIndex )
-{
-#if OSL_DEBUG_LEVEL > 1
- return ( SvtPathOptions::PATH_AUTOCORRECT == nIndex ||
- SvtPathOptions::PATH_AUTOTEXT == nIndex ||
- SvtPathOptions::PATH_BASIC == nIndex ||
- SvtPathOptions::PATH_GALLERY == nIndex ||
- SvtPathOptions::PATH_TEMPLATE == nIndex );
-#else
- return ( SvtPathOptions::PATH_AUTOCORRECT == nIndex ||
- SvtPathOptions::PATH_AUTOTEXT == nIndex ||
- SvtPathOptions::PATH_BASIC == nIndex ||
- SvtPathOptions::PATH_GALLERY == nIndex ||
- SvtPathOptions::PATH_TEMPLATE == nIndex ||
- SvtPathOptions::PATH_LINGUISTIC == nIndex ||
- SvtPathOptions::PATH_DICTIONARY == nIndex );
-#endif
-}
-
-// class SvxPathTabPage --------------------------------------------------
-
-SvxPathTabPage::SvxPathTabPage( Window* pParent, const SfxItemSet& rSet ) :
-
- SfxTabPage( pParent, CUI_RES( RID_SFXPAGE_PATH ), rSet ),
-
- aStdBox ( this, CUI_RES( GB_STD ) ),
- aTypeText ( this, CUI_RES( FT_TYPE ) ),
- aPathText ( this, CUI_RES( FT_PATH ) ),
- aPathCtrl ( this, CUI_RES( LB_PATH ) ),
- aStandardBtn ( this, CUI_RES( BTN_STANDARD ) ),
- aPathBtn ( this, CUI_RES( BTN_PATH ) ),
- pHeaderBar ( NULL ),
- pPathBox ( NULL ),
- pImpl ( new OptPath_Impl( CUI_RES(IMG_LOCK), CUI_RES(IMG_LOCK_HC) ) ),
- xDialogListener ( new ::svt::DialogClosedListener() )
-
-{
- pImpl->m_sMultiPathDlg = String( CUI_RES( STR_MULTIPATHDLG ) );
- aStandardBtn.SetClickHdl( LINK( this, SvxPathTabPage, StandardHdl_Impl ) );
- Link aLink = LINK( this, SvxPathTabPage, PathHdl_Impl );
- aPathBtn.SetClickHdl( aLink );
- Size aBoxSize = aPathCtrl.GetOutputSizePixel();
- pHeaderBar = new HeaderBar( &aPathCtrl, WB_BUTTONSTYLE | WB_BOTTOMBORDER );
- pHeaderBar->SetPosSizePixel( Point( 0, 0 ), Size( aBoxSize.Width(), 16 ) );
- pHeaderBar->SetSelectHdl( LINK( this, SvxPathTabPage, HeaderSelect_Impl ) );
- pHeaderBar->SetEndDragHdl( LINK( this, SvxPathTabPage, HeaderEndDrag_Impl ) );
- Size aSz;
- aSz.Width() = TAB_WIDTH1;
- pHeaderBar->InsertItem( ITEMID_TYPE, aTypeText.GetText(),
- LogicToPixel( aSz, MapMode( MAP_APPFONT ) ).Width(),
- HIB_LEFT | HIB_VCENTER | HIB_CLICKABLE | HIB_UPARROW );
- aSz.Width() = TAB_WIDTH2;
- pHeaderBar->InsertItem( ITEMID_PATH, aPathText.GetText(),
- LogicToPixel( aSz, MapMode( MAP_APPFONT ) ).Width(),
- HIB_LEFT | HIB_VCENTER );
-
- static long nTabs[] = {3, 0, TAB_WIDTH1, TAB_WIDTH1 + TAB_WIDTH2 };
- Size aHeadSize = pHeaderBar->GetSizePixel();
-
- WinBits nBits = WB_SORT | WB_HSCROLL | WB_CLIPCHILDREN | WB_TABSTOP;
- pPathBox = new svx::OptHeaderTabListBox( &aPathCtrl, nBits );
- aPathCtrl.SetFocusControl( pPathBox );
- pPathBox->SetDoubleClickHdl( aLink );
- pPathBox->SetSelectHdl( LINK( this, SvxPathTabPage, PathSelect_Impl ) );
- pPathBox->SetSelectionMode( MULTIPLE_SELECTION );
- pPathBox->SetPosSizePixel( Point( 0, aHeadSize.Height() ),
- Size( aBoxSize.Width(), aBoxSize.Height() - aHeadSize.Height() ) );
- pPathBox->SetTabs( &nTabs[0], MAP_APPFONT );
- pPathBox->InitHeaderBar( pHeaderBar );
- pPathBox->SetHighlightRange();
- pPathBox->SetHelpId( HID_OPTPATH_CTL_PATH );
- pHeaderBar->SetHelpId( HID_OPTPATH_HEADERBAR );
- pPathBox->Show();
- pHeaderBar->Show();
-
- FreeResource();
-
- xDialogListener->SetDialogClosedLink( LINK( this, SvxPathTabPage, DialogClosedHdl ) );
-}
-
-// -----------------------------------------------------------------------
-
-SvxPathTabPage::~SvxPathTabPage()
-{
- // #110603# do not grab focus to a destroyed window !!!
- aPathCtrl.SetFocusControl( NULL );
-
- pHeaderBar->Hide();
- for ( sal_uInt16 i = 0; i < pPathBox->GetEntryCount(); ++i )
- delete (PathUserData_Impl*)pPathBox->GetEntry(i)->GetUserData();
- delete pPathBox;
- delete pHeaderBar;
- delete pImpl;
-}
-
-// -----------------------------------------------------------------------
-
-SfxTabPage* SvxPathTabPage::Create( Window* pParent,
- const SfxItemSet& rAttrSet )
-{
- return ( new SvxPathTabPage( pParent, rAttrSet ) );
-}
-
-// -----------------------------------------------------------------------
-
-sal_Bool SvxPathTabPage::FillItemSet( SfxItemSet& )
-{
- SvtPathOptions aPathOpt;
- for ( sal_uInt16 i = 0; i < pPathBox->GetEntryCount(); ++i )
- {
- PathUserData_Impl* pPathImpl = (PathUserData_Impl*)pPathBox->GetEntry(i)->GetUserData();
- sal_uInt16 nRealId = pPathImpl->nRealId;
- if ( pPathImpl->eState == SFX_ITEM_SET )
- SetPathList( nRealId, pPathImpl->sUserPath, pPathImpl->sWritablePath );
- }
- return sal_True;
-}
-
-// -----------------------------------------------------------------------
-
-void SvxPathTabPage::Reset( const SfxItemSet& )
-{
- pPathBox->Clear();
- SvtPathOptions aPathOpt; //! deprecated
-
- for( sal_uInt16 i = 0; i <= (sal_uInt16)SvtPathOptions::PATH_WORK; ++i )
- {
- // only writer uses autotext
- if ( i == SvtPathOptions::PATH_AUTOTEXT
- && !SvtModuleOptions().IsModuleInstalled( SvtModuleOptions::E_SWRITER ) )
- continue;
-
- switch (i)
- {
- case SvtPathOptions::PATH_AUTOCORRECT:
- case SvtPathOptions::PATH_AUTOTEXT:
- case SvtPathOptions::PATH_BACKUP:
- case SvtPathOptions::PATH_GALLERY:
- case SvtPathOptions::PATH_GRAPHIC:
- case SvtPathOptions::PATH_TEMP:
- case SvtPathOptions::PATH_TEMPLATE:
-#if OSL_DEBUG_LEVEL > 1
- case SvtPathOptions::PATH_LINGUISTIC:
- case SvtPathOptions::PATH_DICTIONARY:
-#endif
- case SvtPathOptions::PATH_WORK:
- {
- String aStr( CUI_RES( RID_SVXSTR_PATH_NAME_START + i ) );
- String sInternal, sUser, sWritable;
- sal_Bool bReadOnly = sal_False;
- GetPathList( i, sInternal, sUser, sWritable, bReadOnly );
- String sTmpPath = sUser;
- if ( sTmpPath.Len() > 0 && sWritable.Len() > 0 )
- sTmpPath += MULTIPATH_DELIMITER;
- sTmpPath += sWritable;
- String aValue( sTmpPath );
- aStr += '\t';
- aStr += Convert_Impl( aValue );
- SvLBoxEntry* pEntry = pPathBox->InsertEntry( aStr );
- if ( bReadOnly )
- {
- pPathBox->SetCollapsedEntryBmp( pEntry, pImpl->m_aLockImage );
- }
- PathUserData_Impl* pPathImpl = new PathUserData_Impl(i);
- pPathImpl->sUserPath = sUser;
- pPathImpl->sWritablePath = sWritable;
- pEntry->SetUserData( pPathImpl );
- }
- }
- }
-
- String aUserData = GetUserData();
- if ( aUserData.Len() )
- {
- // Spaltenbreite restaurieren
- pHeaderBar->SetItemSize( ITEMID_TYPE, aUserData.GetToken(0).ToInt32() );
- HeaderEndDrag_Impl( NULL );
- // Sortierrichtung restaurieren
- sal_Bool bUp = (sal_Bool)(sal_uInt16)aUserData.GetToken(1).ToInt32();
- HeaderBarItemBits nBits = pHeaderBar->GetItemBits(ITEMID_TYPE);
-
- if ( bUp )
- {
- nBits &= ~HIB_UPARROW;
- nBits |= HIB_DOWNARROW;
- }
- else
- {
- nBits &= ~HIB_DOWNARROW;
- nBits |= HIB_UPARROW;
- }
- pHeaderBar->SetItemBits( ITEMID_TYPE, nBits );
- HeaderSelect_Impl( NULL );
- }
- PathSelect_Impl( NULL );
-}
-
-// -----------------------------------------------------------------------
-
-void SvxPathTabPage::FillUserData()
-{
- String aUserData = String::CreateFromInt32( pHeaderBar->GetItemSize( ITEMID_TYPE ) );
- aUserData += ';';
- HeaderBarItemBits nBits = pHeaderBar->GetItemBits( ITEMID_TYPE );
- sal_Bool bUp = ( ( nBits & HIB_UPARROW ) == HIB_UPARROW );
- aUserData += bUp ? '1' : '0';
- SetUserData( aUserData );
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, PathSelect_Impl, svx::OptHeaderTabListBox *, EMPTYARG )
-{
- sal_uInt16 nSelCount = 0;
- SvLBoxEntry* pEntry = pPathBox->FirstSelected();
-
- //the entry image indicates whether the path is write protected
- Image aEntryImage;
- if(pEntry)
- aEntryImage = pPathBox->GetCollapsedEntryBmp( pEntry );
- sal_Bool bEnable = !aEntryImage;
- while ( pEntry && ( nSelCount < 2 ) )
- {
- nSelCount++;
- pEntry = pPathBox->NextSelected( pEntry );
- }
-
- aPathBtn.Enable( 1 == nSelCount && bEnable);
- aStandardBtn.Enable( nSelCount > 0 && bEnable);
- return 0;
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, StandardHdl_Impl, PushButton *, EMPTYARG )
-{
- SvLBoxEntry* pEntry = pPathBox->FirstSelected();
- while ( pEntry )
- {
- PathUserData_Impl* pPathImpl = (PathUserData_Impl*)pEntry->GetUserData();
- String aOldPath = pImpl->m_aDefOpt.GetDefaultPath( pPathImpl->nRealId );
-
- if ( aOldPath.Len() )
- {
- String sInternal, sUser, sWritable, sTemp;
- sal_Bool bReadOnly = sal_False;
- GetPathList( pPathImpl->nRealId, sInternal, sUser, sWritable, bReadOnly );
-
- sal_uInt16 i;
- sal_uInt16 nOldCount = aOldPath.GetTokenCount( MULTIPATH_DELIMITER );
- sal_uInt16 nIntCount = sInternal.GetTokenCount( MULTIPATH_DELIMITER );
- for ( i = 0; i < nOldCount; ++i )
- {
- bool bFound = false;
- String sOnePath = aOldPath.GetToken( i, MULTIPATH_DELIMITER );
- for ( sal_uInt16 j = 0; !bFound && j < nIntCount; ++j )
- {
- if ( sInternal.GetToken( i, MULTIPATH_DELIMITER ) == sOnePath )
- bFound = true;
- }
- if ( !bFound )
- {
- if ( sTemp.Len() > 0 )
- sTemp += MULTIPATH_DELIMITER;
- sTemp += sOnePath;
- }
- }
-
- String sUserPath, sWritablePath;
- nOldCount = sTemp.GetTokenCount( MULTIPATH_DELIMITER );
- for ( i = 0; nOldCount > 0 && i < nOldCount - 1; ++i )
- {
- if ( sUserPath.Len() > 0 )
- sUserPath += MULTIPATH_DELIMITER;
- sUserPath += sTemp.GetToken( i, MULTIPATH_DELIMITER );
- }
- sWritablePath = sTemp.GetToken( nOldCount - 1, MULTIPATH_DELIMITER );
-
- pPathBox->SetEntryText( Convert_Impl( sTemp ), pEntry, 1 );
- pPathImpl->eState = SFX_ITEM_SET;
- pPathImpl->sUserPath = sUserPath;
- pPathImpl->sWritablePath = sWritablePath;
- }
- pEntry = pPathBox->NextSelected( pEntry );
- }
- return 0;
-}
-
-// -----------------------------------------------------------------------
-
-void SvxPathTabPage::ChangeCurrentEntry( const String& _rFolder )
-{
- SvLBoxEntry* pEntry = pPathBox->GetCurEntry();
- if ( !pEntry )
- {
- DBG_ERRORFILE( "SvxPathTabPage::ChangeCurrentEntry(): no entry" );
- return;
- }
-
- String sInternal, sUser, sWritable;
- PathUserData_Impl* pPathImpl = (PathUserData_Impl*)pEntry->GetUserData();
- sal_Bool bReadOnly = sal_False;
- GetPathList( pPathImpl->nRealId, sInternal, sUser, sWritable, bReadOnly );
- sUser = pPathImpl->sUserPath;
- sWritable = pPathImpl->sWritablePath;
- sal_uInt16 nPos = pPathImpl->nRealId;
-
- // old path is an URL?
- INetURLObject aObj( sWritable );
- bool bURL = ( aObj.GetProtocol() != INET_PROT_NOT_VALID );
- rtl::OUString aPathStr( _rFolder );
- INetURLObject aNewObj( aPathStr );
- aNewObj.removeFinalSlash();
-
- // then the new path also an URL else system path
- String sNewPathStr = bURL ? aPathStr : aNewObj.getFSysPath( INetURLObject::FSYS_DETECT );
-
- bool bChanged =
-#ifdef UNX
-// Unix is case sensitive
- ( sNewPathStr != sWritable );
-#else
- ( sNewPathStr.CompareIgnoreCaseToAscii( sWritable ) != COMPARE_EQUAL );
-#endif
-
- if ( bChanged )
- {
- pPathBox->SetEntryText( Convert_Impl( sNewPathStr ), pEntry, 1 );
- nPos = (sal_uInt16)pPathBox->GetModel()->GetAbsPos( pEntry );
- pPathImpl = (PathUserData_Impl*)pPathBox->GetEntry(nPos)->GetUserData();
- pPathImpl->eState = SFX_ITEM_SET;
- pPathImpl->sWritablePath = sNewPathStr;
- if ( SvtPathOptions::PATH_WORK == pPathImpl->nRealId )
- {
- // Remove view options entry so the new work path
- // will be used for the next open dialog.
- SvtViewOptions aDlgOpt( E_DIALOG, IODLG_CONFIGNAME );
- aDlgOpt.Delete();
- // Reset also last used dir in the sfx application instance
- SfxApplication *pSfxApp = SFX_APP();
- pSfxApp->ResetLastDir();
-
- // Set configuration flag to notify file picker that it's necessary
- // to take over the path provided.
- Reference < XMultiServiceFactory > xFactory( ::comphelper::getProcessServiceFactory() );
- ::comphelper::ConfigurationHelper::writeDirectKey(xFactory,
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("org.openoffice.Office.Common/")),
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("Path/Info")),
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("WorkPathChanged")),
- ::com::sun::star::uno::makeAny(true),
- ::comphelper::ConfigurationHelper::E_STANDARD);
- }
- }
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, PathHdl_Impl, PushButton *, EMPTYARG )
-{
- SvLBoxEntry* pEntry = pPathBox->GetCurEntry();
- sal_uInt16 nPos = ( pEntry != NULL ) ? ( (PathUserData_Impl*)pEntry->GetUserData() )->nRealId : 0;
- String sInternal, sUser, sWritable;
- if ( pEntry )
- {
- PathUserData_Impl* pPathImpl = (PathUserData_Impl*)pEntry->GetUserData();
- sal_Bool bReadOnly = sal_False;
- GetPathList( pPathImpl->nRealId, sInternal, sUser, sWritable, bReadOnly );
- sUser = pPathImpl->sUserPath;
- sWritable = pPathImpl->sWritablePath;
- }
-
- if(pEntry && !(!((OptHeaderTabListBox*)pPathBox)->GetCollapsedEntryBmp(pEntry)))
- return 0;
-
- if ( IsMultiPath_Impl( nPos ) )
- {
- SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
- if ( pFact )
- {
- AbstractSvxMultiPathDialog* pMultiDlg =
- pFact->CreateSvxMultiPathDialog( this );
- DBG_ASSERT( pMultiDlg, "Dialogdiet fail!" );
- pMultiDlg->EnableRadioButtonMode();
-
- String sPath( sUser );
- if ( sPath.Len() > 0 )
- sPath += MULTIPATH_DELIMITER;
- sPath += sWritable;
- pMultiDlg->SetPath( sPath );
-
- String sPathName = pPathBox->GetEntryText( pEntry, 0 );
- String sNewTitle( pImpl->m_sMultiPathDlg );
- sNewTitle.SearchAndReplace( VAR_ONE, sPathName );
- pMultiDlg->SetTitle( sNewTitle );
-
- if ( pMultiDlg->Execute() == RET_OK && pEntry )
- {
- sUser.Erase();
- sWritable.Erase();
- String sFullPath;
- String sNewPath = pMultiDlg->GetPath();
- char cDelim = MULTIPATH_DELIMITER;
- sal_uInt16 nCount = sNewPath.GetTokenCount( cDelim );
- if ( nCount > 0 )
- {
- sal_uInt16 i = 0;
- for ( ; i < nCount - 1; ++i )
- {
- if ( sUser.Len() > 0 )
- sUser += cDelim;
- sUser += sNewPath.GetToken( i, cDelim );
- }
- if ( sFullPath.Len() > 0 )
- sFullPath += cDelim;
- sFullPath += sUser;
- sWritable += sNewPath.GetToken( i, cDelim );
- if ( sFullPath.Len() > 0 )
- sFullPath += cDelim;
- sFullPath += sWritable;
- }
-
- pPathBox->SetEntryText( Convert_Impl( sFullPath ), pEntry, 1 );
- // save modified flag
- PathUserData_Impl* pPathImpl = (PathUserData_Impl*)pEntry->GetUserData();
- pPathImpl->eState = SFX_ITEM_SET;
- pPathImpl->sUserPath = sUser;
- pPathImpl->sWritablePath = sWritable;
- }
- delete pMultiDlg;
- }
- }
- else if ( pEntry )
- {
- try
- {
- rtl::OUString aService( RTL_CONSTASCII_USTRINGPARAM( FOLDER_PICKER_SERVICE_NAME ) );
- Reference < XMultiServiceFactory > xFactory( ::comphelper::getProcessServiceFactory() );
- xFolderPicker = ::com::sun::star::uno::Reference< XFolderPicker >(
- xFactory->createInstance( aService ), UNO_QUERY );
-
- INetURLObject aURL( sWritable, INET_PROT_FILE );
- xFolderPicker->setDisplayDirectory( aURL.GetMainURL( INetURLObject::NO_DECODE ) );
-
- Reference< XAsynchronousExecutableDialog > xAsyncDlg( xFolderPicker, UNO_QUERY );
- if ( xAsyncDlg.is() )
- xAsyncDlg->startExecuteModal( xDialogListener.get() );
- else
- {
- short nRet = xFolderPicker->execute();
- if ( ExecutableDialogResults::OK != nRet )
- return 0;
-
- String sFolder( xFolderPicker->getDirectory() );
- ChangeCurrentEntry( sFolder );
- }
- }
- catch( Exception& )
- {
- DBG_ERRORFILE( "SvxPathTabPage::PathHdl_Impl: exception from folder picker" );
- }
- }
- return 0;
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, HeaderSelect_Impl, HeaderBar*, pBar )
-{
- if ( pBar && pBar->GetCurItemId() != ITEMID_TYPE )
- return 0;
-
- HeaderBarItemBits nBits = pHeaderBar->GetItemBits(ITEMID_TYPE);
- sal_Bool bUp = ( ( nBits & HIB_UPARROW ) == HIB_UPARROW );
- SvSortMode eMode = SortAscending;
-
- if ( bUp )
- {
- nBits &= ~HIB_UPARROW;
- nBits |= HIB_DOWNARROW;
- eMode = SortDescending;
- }
- else
- {
- nBits &= ~HIB_DOWNARROW;
- nBits |= HIB_UPARROW;
- }
- pHeaderBar->SetItemBits( ITEMID_TYPE, nBits );
- SvTreeList* pModel = pPathBox->GetModel();
- pModel->SetSortMode( eMode );
- pModel->Resort();
- return 1;
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, HeaderEndDrag_Impl, HeaderBar*, pBar )
-{
- if ( pBar && !pBar->GetCurItemId() )
- return 0;
-
- if ( !pHeaderBar->IsItemMode() )
- {
- Size aSz;
- sal_uInt16 nTabs = pHeaderBar->GetItemCount();
- long nTmpSz = 0;
- long nWidth = pHeaderBar->GetItemSize(ITEMID_TYPE);
- long nBarWidth = pHeaderBar->GetSizePixel().Width();
-
- if(nWidth < TAB_WIDTH_MIN)
- pHeaderBar->SetItemSize( ITEMID_TYPE, TAB_WIDTH_MIN);
- else if ( ( nBarWidth - nWidth ) < TAB_WIDTH_MIN )
- pHeaderBar->SetItemSize( ITEMID_TYPE, nBarWidth - TAB_WIDTH_MIN );
-
- for ( sal_uInt16 i = 1; i <= nTabs; ++i )
- {
- long _nWidth = pHeaderBar->GetItemSize(i);
- aSz.Width() = _nWidth + nTmpSz;
- nTmpSz += _nWidth;
- pPathBox->SetTab( i, PixelToLogic( aSz, MapMode(MAP_APPFONT) ).Width(), MAP_APPFONT );
- }
- }
- return 1;
-}
-
-// -----------------------------------------------------------------------
-
-IMPL_LINK( SvxPathTabPage, DialogClosedHdl, DialogClosedEvent*, pEvt )
-{
- if ( RET_OK == pEvt->DialogResult )
- {
- DBG_ASSERT( xFolderPicker.is() == sal_True, "SvxPathTabPage::DialogClosedHdl(): no folder picker" );
-
- String sURL = String( xFolderPicker->getDirectory() );
- ChangeCurrentEntry( sURL );
- }
- return 0L;
-}
-
-// -----------------------------------------------------------------------
-
-void SvxPathTabPage::GetPathList(
- sal_uInt16 _nPathHandle, String& _rInternalPath,
- String& _rUserPath, String& _rWritablePath, sal_Bool& _rReadOnly )
-{
- String sCfgName = getCfgName_Impl( _nPathHandle );
-
- // load PathSettings service if necessary
- if ( !pImpl->m_xPathSettings.is() )
- {
- Reference< XMultiServiceFactory > xSMgr = comphelper::getProcessServiceFactory();
- pImpl->m_xPathSettings = Reference< XPropertySet >( xSMgr->createInstance(
- rtl::OUString( RTL_CONSTASCII_USTRINGPARAM(
- "com.sun.star.util.PathSettings") ) ), UNO_QUERY );
- }
-
- try
- {
- if ( pImpl->m_xPathSettings.is() )
- {
- // load internal paths
- String sProp( sCfgName );
- sProp = sCfgName;
- sProp += POSTFIX_INTERNAL;
- Any aAny = pImpl->m_xPathSettings->getPropertyValue( sProp );
- Sequence< ::rtl::OUString > aPathSeq;
- if ( aAny >>= aPathSeq )
- {
- long i, nCount = aPathSeq.getLength();
- const ::rtl::OUString* pPaths = aPathSeq.getConstArray();
-
- for ( i = 0; i < nCount; ++i )
- {
- if ( _rInternalPath.Len() > 0 )
- _rInternalPath += ';';
- _rInternalPath += String( pPaths[i] );
- }
- }
- // load user paths
- sProp = sCfgName;
- sProp += POSTFIX_USER;
- aAny = pImpl->m_xPathSettings->getPropertyValue( sProp );
- if ( aAny >>= aPathSeq )
- {
- long i, nCount = aPathSeq.getLength();
- const ::rtl::OUString* pPaths = aPathSeq.getConstArray();
-
- for ( i = 0; i < nCount; ++i )
- {
- if ( _rUserPath.Len() > 0 )
- _rUserPath += ';';
- _rUserPath += String( pPaths[i] );
- }
- }
- // then the writable path
- sProp = sCfgName;
- sProp += POSTFIX_WRITABLE;
- aAny = pImpl->m_xPathSettings->getPropertyValue( sProp );
- ::rtl::OUString sWritablePath;
- if ( aAny >>= sWritablePath )
- _rWritablePath = String( sWritablePath );
-
- // and the readonly flag
- sProp = sCfgName;
- Reference< XPropertySetInfo > xInfo = pImpl->m_xPathSettings->getPropertySetInfo();
- Property aProp = xInfo->getPropertyByName( sProp );
- _rReadOnly = ( ( aProp.Attributes & PropertyAttribute::READONLY ) == PropertyAttribute::READONLY );
- }
- }
- catch( const Exception& )
- {
- OSL_FAIL( "SvxPathTabPage::GetPathList(): caught an exception!" );
- }
-}
-
-// -----------------------------------------------------------------------
-
-void SvxPathTabPage::SetPathList(
- sal_uInt16 _nPathHandle, const String& _rUserPath, const String& _rWritablePath )
-{
- String sCfgName = getCfgName_Impl( _nPathHandle );
-
- // load PathSettings service if necessary
- if ( !pImpl->m_xPathSettings.is() )
- {
- Reference< XMultiServiceFactory > xSMgr = comphelper::getProcessServiceFactory();
- pImpl->m_xPathSettings = Reference< XPropertySet >( xSMgr->createInstance(
- rtl::OUString( RTL_CONSTASCII_USTRINGPARAM(
- "com.sun.star.util.PathSettings") ) ), UNO_QUERY );
- }
-
- try
- {
- if ( pImpl->m_xPathSettings.is() )
- {
- // save user paths
- char cDelim = MULTIPATH_DELIMITER;
- sal_uInt16 nCount = _rUserPath.GetTokenCount( cDelim );
- Sequence< ::rtl::OUString > aPathSeq( nCount );
- ::rtl::OUString* pArray = aPathSeq.getArray();
- for ( sal_uInt16 i = 0; i < nCount; ++i )
- pArray[i] = ::rtl::OUString( _rUserPath.GetToken( i, cDelim ) );
- String sProp( sCfgName );
- sProp += POSTFIX_USER;
- Any aValue = makeAny( aPathSeq );
- pImpl->m_xPathSettings->setPropertyValue( sProp, aValue );
-
- // then the writable path
- aValue = makeAny( ::rtl::OUString( _rWritablePath ) );
- sProp = sCfgName;
- sProp += POSTFIX_WRITABLE;
- pImpl->m_xPathSettings->setPropertyValue( sProp, aValue );
- }
- }
- catch( const Exception& )
- {
- OSL_FAIL( "SvxPathTabPage::SetPathList(): caught an exception!" );
- }
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */