summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVladimir Glazounov <vg@openoffice.org>2006-11-22 09:15:23 +0000
committerVladimir Glazounov <vg@openoffice.org>2006-11-22 09:15:23 +0000
commited6173be9bb8f61bd925b4b68b94a9865c25508a (patch)
tree93c654e573a926c86de27d17b868a38ab3a72047
parentcb9cf468b849107a6fd736b644dc1c115376c485 (diff)
INTEGRATION: CWS asyncdialogs (1.3.28); FILE MERGED
2006/10/31 13:30:06 pb 1.3.28.9: RESYNC: (1.12-1.14); FILE MERGED 2006/09/20 10:49:10 pb 1.3.28.8: RESYNC: (1.11-1.12); FILE MERGED 2006/08/30 06:53:25 pb 1.3.28.7: RESYNC: (1.9-1.11); FILE MERGED 2006/07/14 10:46:35 pb 1.3.28.6: fix: #i57125# warning free code 2006/07/12 14:13:46 pb 1.3.28.5: RESYNC: (1.8-1.9); FILE MERGED 2006/05/31 09:03:05 pb 1.3.28.4: RESYNC: (1.7-1.8); FILE MERGED 2006/02/14 05:58:59 pb 1.3.28.3: RESYNC: (1.5-1.7); FILE MERGED 2005/12/01 13:00:10 kso 1.3.28.2: RESYNC: (1.3-1.5); FILE MERGED 2005/11/01 14:24:44 kso 1.3.28.1: #i57125# - dialog adaptions for Threading Framework.
-rw-r--r--fpicker/source/office/iodlg.cxx286
1 files changed, 157 insertions, 129 deletions
diff --git a/fpicker/source/office/iodlg.cxx b/fpicker/source/office/iodlg.cxx
index 0dd7b5dde2cc..8dfe19445faf 100644
--- a/fpicker/source/office/iodlg.cxx
+++ b/fpicker/source/office/iodlg.cxx
@@ -4,9 +4,9 @@
*
* $RCSfile: iodlg.cxx,v $
*
- * $Revision: 1.14 $
+ * $Revision: 1.15 $
*
- * last change: $Author: obo $ $Date: 2006-10-13 09:41:22 $
+ * last change: $Author: vg $ $Date: 2006-11-22 10:15:23 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -1457,6 +1457,13 @@ IMPL_STATIC_LINK( SvtFileDialog, OpenHdl_Impl, void*, pVoid )
//*****************************************************************************
+void SvtFileDialog::EnableAutocompletion( BOOL _bEnable )
+{
+ _pImp->_pEdFileName->EnableAutocompletion( _bEnable );
+}
+
+//*****************************************************************************
+
IMPL_STATIC_LINK( SvtFileDialog, FilterSelectHdl_Impl, ListBox*, pBox )
{
DBG_ASSERT( pBox, "SvtFileDialog:keine Instanz" );
@@ -2033,6 +2040,153 @@ String SvtFileDialog::implGetInitialURL( const String& _rPath, const String& _rF
//---------------------------------------------------------------------
short SvtFileDialog::Execute()
{
+ if ( !PrepareExecute() )
+ return 0;
+
+ // Start des Dialogs.
+ _bIsInExecute = TRUE;
+ short nResult = ModalDialog::Execute();
+ _bIsInExecute = FALSE;
+
+ DBG_ASSERT( !m_pCurrentAsyncAction.is(), "SvtFilePicker::Execute: still running an async action!" );
+ // the dialog should not be cancellable while an async action is running - firs, the action
+ // needs to be cancelled
+
+ // letztes Verzeichnis merken
+ if ( RET_OK == nResult )
+ {
+ INetURLObject aURL( _aPath );
+ if ( aURL.GetProtocol() == INET_PROT_FILE )
+ {
+ // nur bei File-URL's und nicht bei virtuelle Folder
+ // das ausgew"ahlte Verzeichnis merken
+ sal_Int32 nLevel = aURL.getSegmentCount();
+ // #97148# & #102204# ------
+ sal_Bool bDir = m_aContent.isFolder( aURL.GetMainURL( INetURLObject::NO_DECODE ) );
+ // BOOL bClassPath = ( ( _pImp->_nStyle & SFXWB_CLASSPATH ) == SFXWB_CLASSPATH );
+ if ( nLevel > 1 && ( FILEDLG_TYPE_FILEDLG == _pImp->_eDlgType || !bDir ) )
+ aURL.removeSegment();
+ }
+ }
+
+ return nResult;
+}
+
+//---------------------------------------------------------------------
+void SvtFileDialog::StartExecuteModal( const Link& rEndDialogHdl )
+{
+ PrepareExecute();
+
+ // Start des Dialogs.
+// _bIsInExecute = TRUE;
+ ModalDialog::StartExecuteModal( rEndDialogHdl );
+}
+
+//-----------------------------------------------------------------------------
+void SvtFileDialog::onAsyncOperationStarted()
+{
+ EnableUI( FALSE );
+ // the cancel button must be always enabled
+ _pImp->_pBtnCancel->Enable( TRUE );
+ _pImp->_pBtnCancel->GrabFocus();
+}
+
+//-----------------------------------------------------------------------------
+void SvtFileDialog::onAsyncOperationFinished()
+{
+ EnableUI( TRUE );
+ m_pCurrentAsyncAction = NULL;
+ if ( !m_bInExecuteAsync )
+ _pImp->_pEdFileName->GrabFocus();
+ // (if m_bInExecuteAsync is true, then the operation was finished within the minium wait time,
+ // and to the user, the operation appears to be synchronous)
+}
+
+//-------------------------------------------------------------------------
+void SvtFileDialog::displayIOException( const String& _rURL, ::com::sun::star::ucb::IOErrorCode _eCode )
+{
+ try
+ {
+ // create make a human-readable string from the URL
+ String sDisplayPath( _rURL );
+ ::utl::LocalFileHelper::ConvertURLToSystemPath( _rURL, sDisplayPath );
+
+ // build an own exception which tells "access denied"
+ ::com::sun::star::ucb::InteractiveAugmentedIOException aException;
+ aException.Arguments.realloc( 2 );
+ aException.Arguments[ 0 ] <<= ::rtl::OUString( sDisplayPath );
+ aException.Arguments[ 1 ] <<= PropertyValue(
+ ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Uri" ) ),
+ -1, aException.Arguments[ 0 ], PropertyState_DIRECT_VALUE
+ );
+ // (formerly, it was sufficient to put the URL first parameter. Nowadays,
+ // the services expects the URL in a PropertyValue named "Uri" ...)
+ aException.Code = _eCode;
+ aException.Classification = InteractionClassification_ERROR;
+
+ // let and interaction handler handle this exception
+ ::comphelper::OInteractionRequest* pRequest = NULL;
+ Reference< ::com::sun::star::task::XInteractionRequest > xRequest = pRequest =
+ new ::comphelper::OInteractionRequest( makeAny( aException ) );
+ pRequest->addContinuation( new ::comphelper::OInteractionAbort( ) );
+
+ Reference< XInteractionHandler > xHandler(
+ ::comphelper::getProcessServiceFactory()->createInstance(
+ ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.task.InteractionHandler") )
+ ),
+ UNO_QUERY
+ );
+ if ( xHandler.is() )
+ xHandler->handle( xRequest );
+ }
+ catch( const Exception& )
+ {
+ DBG_ERROR( "iodlg::displayIOException: caught an exception!" );
+ }
+}
+
+//-----------------------------------------------------------------------------
+void SvtFileDialog::EnableUI( BOOL _bEnable )
+{
+ Enable( _bEnable );
+
+ if ( _bEnable )
+ {
+ for ( ::std::set< Control* >::iterator aLoop = m_aDisabledControls.begin();
+ aLoop != m_aDisabledControls.end();
+ ++aLoop
+ )
+ {
+ (*aLoop)->Enable( FALSE );
+ }
+ }
+}
+
+//-----------------------------------------------------------------------------
+void SvtFileDialog::EnableControl( Control* _pControl, BOOL _bEnable )
+{
+ if ( !_pControl )
+ {
+ DBG_ERRORFILE( "SvtFileDialog::EnableControl: invalid control!" );
+ return;
+ }
+
+ _pControl->Enable( _bEnable );
+
+ if ( _bEnable )
+ {
+ ::std::set< Control* >::iterator aPos = m_aDisabledControls.find( _pControl );
+ if ( m_aDisabledControls.end() != aPos )
+ m_aDisabledControls.erase( aPos );
+ }
+ else
+ m_aDisabledControls.insert( _pControl );
+}
+
+//----------------------------------------------------------------------------
+
+short SvtFileDialog::PrepareExecute()
+{
rtl::OUString aEnvValue;
if ( getEnvironmentValue( "WorkDirMustContainRemovableMedia", aEnvValue ) &&
aEnvValue.equalsAscii( "1" ) )
@@ -2236,133 +2390,7 @@ short SvtFileDialog::Execute()
// ggf. Gr"osse aus Ini lesen und setzen
InitSize();
- // Start des Dialogs.
- _bIsInExecute = TRUE;
- short nResult = ModalDialog::Execute();
- _bIsInExecute = FALSE;
-
- DBG_ASSERT( !m_pCurrentAsyncAction.is(), "SvtFilePicker::Execute: still running an async action!" );
- // the dialog should not be cancellable while an async action is running - firs, the action
- // needs to be cancelled
-
- // letztes Verzeichnis merken
- if ( RET_OK == nResult )
- {
- INetURLObject aURL( _aPath );
- if ( aURL.GetProtocol() == INET_PROT_FILE )
- {
- // nur bei File-URL's und nicht bei virtuelle Folder
- // das ausgew"ahlte Verzeichnis merken
- sal_Int32 nLevel = aURL.getSegmentCount();
- // #97148# & #102204# ------
- sal_Bool bDir = m_aContent.isFolder( aURL.GetMainURL( INetURLObject::NO_DECODE ) );
- if ( nLevel > 1 && ( FILEDLG_TYPE_FILEDLG == _pImp->_eDlgType || !bDir ) )
- aURL.removeSegment();
- }
- }
-
- return nResult;
-}
-
-//-----------------------------------------------------------------------------
-void SvtFileDialog::onAsyncOperationStarted()
-{
- EnableUI( FALSE );
- // the cancel button must be always enabled
- _pImp->_pBtnCancel->Enable( TRUE );
- _pImp->_pBtnCancel->GrabFocus();
-}
-
-//-----------------------------------------------------------------------------
-void SvtFileDialog::onAsyncOperationFinished()
-{
- EnableUI( TRUE );
- m_pCurrentAsyncAction = NULL;
- if ( !m_bInExecuteAsync )
- _pImp->_pEdFileName->GrabFocus();
- // (if m_bInExecuteAsync is true, then the operation was finished within the minium wait time,
- // and to the user, the operation appears to be synchronous)
-}
-
-//-------------------------------------------------------------------------
-void SvtFileDialog::displayIOException( const String& _rURL, ::com::sun::star::ucb::IOErrorCode _eCode )
-{
- try
- {
- // create make a human-readable string from the URL
- String sDisplayPath( _rURL );
- ::utl::LocalFileHelper::ConvertURLToSystemPath( _rURL, sDisplayPath );
-
- // build an own exception which tells "access denied"
- ::com::sun::star::ucb::InteractiveAugmentedIOException aException;
- aException.Arguments.realloc( 2 );
- aException.Arguments[ 0 ] <<= ::rtl::OUString( sDisplayPath );
- aException.Arguments[ 1 ] <<= PropertyValue(
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Uri" ) ),
- -1, aException.Arguments[ 0 ], PropertyState_DIRECT_VALUE
- );
- // (formerly, it was sufficient to put the URL first parameter. Nowadays,
- // the services expects the URL in a PropertyValue named "Uri" ...)
- aException.Code = _eCode;
- aException.Classification = InteractionClassification_ERROR;
-
- // let and interaction handler handle this exception
- ::comphelper::OInteractionRequest* pRequest = NULL;
- Reference< ::com::sun::star::task::XInteractionRequest > xRequest = pRequest =
- new ::comphelper::OInteractionRequest( makeAny( aException ) );
- pRequest->addContinuation( new ::comphelper::OInteractionAbort( ) );
-
- Reference< XInteractionHandler > xHandler(
- ::comphelper::getProcessServiceFactory()->createInstance(
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.task.InteractionHandler") )
- ),
- UNO_QUERY
- );
- if ( xHandler.is() )
- xHandler->handle( xRequest );
- }
- catch( const Exception& )
- {
- DBG_ERROR( "iodlg::displayIOException: caught an exception!" );
- }
-}
-
-//-----------------------------------------------------------------------------
-void SvtFileDialog::EnableUI( BOOL _bEnable )
-{
- Enable( _bEnable );
-
- if ( _bEnable )
- {
- for ( ::std::set< Control* >::iterator aLoop = m_aDisabledControls.begin();
- aLoop != m_aDisabledControls.end();
- ++aLoop
- )
- {
- (*aLoop)->Enable( FALSE );
- }
- }
-}
-
-//-----------------------------------------------------------------------------
-void SvtFileDialog::EnableControl( Control* _pControl, BOOL _bEnable )
-{
- if ( !_pControl )
- {
- DBG_ERRORFILE( "SvtFileDialog::EnableControl: invalid control!" );
- return;
- }
-
- _pControl->Enable( _bEnable );
-
- if ( _bEnable )
- {
- ::std::set< Control* >::iterator aPos = m_aDisabledControls.find( _pControl );
- if ( m_aDisabledControls.end() != aPos )
- m_aDisabledControls.erase( aPos );
- }
- else
- m_aDisabledControls.insert( _pControl );
+ return 1;
}
//-----------------------------------------------------------------------------