diff options
Diffstat (limited to 'uui')
-rw-r--r-- | uui/source/logindlg.cxx | 51 |
1 files changed, 22 insertions, 29 deletions
diff --git a/uui/source/logindlg.cxx b/uui/source/logindlg.cxx index f4e6fa990e50..aa25574c4873 100644 --- a/uui/source/logindlg.cxx +++ b/uui/source/logindlg.cxx @@ -18,23 +18,24 @@ */ #include <comphelper/string.hxx> -#include <svtools/filedlg.hxx> #include <vcl/msgbox.hxx> #include "logindlg.hxx" #include "logindlg.hrc" #include "ids.hrc" #include <tools/resid.hxx> +#include <osl/file.hxx> #ifdef UNX #include <limits.h> #define _MAX_PATH PATH_MAX #endif -// LoginDialog ------------------------------------------------------- +#include <com/sun/star/ui/dialogs/ExecutableDialogResults.hpp> +#include <com/sun/star/ui/dialogs/FolderPicker.hpp> +#include <comphelper/processfactory.hxx> -//............................................................................ -//............................................................................ +using namespace com::sun::star; static void lcl_Move( Window &rWin, long nOffset ) { @@ -184,7 +185,6 @@ void LoginDialog::HideControls_Impl( sal_uInt16 nFlags ) } }; -// ----------------------------------------------------------------------- void LoginDialog::EnableUseSysCredsControls_Impl( sal_Bool bUseSysCredsEnabled ) { aErrorInfo.Enable( !bUseSysCredsEnabled ); @@ -201,8 +201,6 @@ void LoginDialog::EnableUseSysCredsControls_Impl( sal_Bool bUseSysCredsEnabled ) aAccountED.Enable( !bUseSysCredsEnabled ); } -// ----------------------------------------------------------------------- - IMPL_LINK_NOARG(LoginDialog, OKHdl_Impl) { // trim the strings @@ -212,30 +210,36 @@ IMPL_LINK_NOARG(LoginDialog, OKHdl_Impl) return 1; } -// ----------------------------------------------------------------------- - IMPL_LINK_NOARG(LoginDialog, PathHdl_Impl) { - PathDialog* pDlg = new PathDialog( this, WB_3DLOOK ); - pDlg->SetPath( aPathED.GetText() ); + try + { + uno::Reference<ui::dialogs::XFolderPicker2> xFolderPicker = ui::dialogs::FolderPicker::create(comphelper::getProcessComponentContext()); + + OUString aPath( aPathED.GetText() ); + osl::FileBase::getFileURLFromSystemPath( aPath, aPath ); + xFolderPicker->setDisplayDirectory( aPath ); - if ( pDlg->Execute() == RET_OK ) - aPathED.SetText( pDlg->GetPath() ); + if (xFolderPicker->execute() == ui::dialogs::ExecutableDialogResults::OK) + { + osl::FileBase::getSystemPathFromFileURL( xFolderPicker->getDirectory(), aPath ); + aPathED.SetText( aPath ); + } + } + catch (uno::Exception & e) + { + SAL_WARN("uui", "LoginDialog::PathHdl_Impl: caught UNO exception: " << e.Message); + } - delete pDlg; return 1; } -// ----------------------------------------------------------------------- - IMPL_LINK_NOARG(LoginDialog, UseSysCredsHdl_Impl) { EnableUseSysCredsControls_Impl( aUseSysCredsCB.IsChecked() ); return 1; } -// ----------------------------------------------------------------------- - LoginDialog::LoginDialog ( Window* pParent, @@ -296,14 +300,10 @@ LoginDialog::LoginDialog HideControls_Impl( nFlags ); }; -// ----------------------------------------------------------------------- - LoginDialog::~LoginDialog() { } -// ----------------------------------------------------------------------- - void LoginDialog::SetUseSystemCredentials( sal_Bool bUse ) { if ( aUseSysCredsCB.IsVisible() ) @@ -313,8 +313,6 @@ void LoginDialog::SetUseSystemCredentials( sal_Bool bUse ) } } -// ----------------------------------------------------------------------- - void LoginDialog::ClearPassword() { aPasswordED.SetText( String() ); @@ -325,15 +323,10 @@ void LoginDialog::ClearPassword() aPasswordED.GrabFocus(); }; -// ----------------------------------------------------------------------- - void LoginDialog::ClearAccount() { aAccountED.SetText( String() ); aAccountED.GrabFocus(); }; -//............................................................................ -//............................................................................ - /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |