/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include "logindlg.hxx" #include #include #ifdef UNX #include #define _MAX_PATH PATH_MAX #endif #include #include using namespace com::sun::star; LoginDialog::~LoginDialog() { } void LoginDialog::SetPassword( const OUString& rNew ) { m_xPasswordED->set_text( rNew ); SetRequest(); } void LoginDialog::HideControls_Impl( LoginFlags nFlags ) { if ( nFlags & LoginFlags::UsernameReadonly ) { m_xNameED->set_sensitive( false ); } if ( nFlags & LoginFlags::NoSavePassword ) m_xSavePasswdBtn->hide(); if ( nFlags & LoginFlags::NoErrorText ) { m_xErrorInfo->hide(); m_xErrorFT->hide(); } if ( nFlags & LoginFlags::NoAccount ) { m_xAccountFT->hide(); m_xAccountED->hide(); } if ( nFlags & LoginFlags::NoUseSysCreds ) { m_xUseSysCredsCB->hide(); } } void LoginDialog::EnableUseSysCredsControls_Impl( bool bUseSysCredsset_sensitived ) { m_xErrorInfo->set_sensitive( !bUseSysCredsset_sensitived ); m_xErrorFT->set_sensitive( !bUseSysCredsset_sensitived ); m_xRequestInfo->set_sensitive( !bUseSysCredsset_sensitived ); m_xNameFT->set_sensitive( !bUseSysCredsset_sensitived ); m_xNameED->set_sensitive( !bUseSysCredsset_sensitived ); m_xPasswordFT->set_sensitive( !bUseSysCredsset_sensitived ); m_xPasswordED->set_sensitive( !bUseSysCredsset_sensitived ); m_xAccountFT->set_sensitive( !bUseSysCredsset_sensitived ); m_xAccountED->set_sensitive( !bUseSysCredsset_sensitived ); } void LoginDialog::SetRequest() { bool oldPwd = !m_xPasswordED->get_text().isEmpty(); OUString aRequest; if (m_xAccountFT->get_visible() && !m_realm.isEmpty()) { std::unique_ptr xText(m_xBuilder->weld_label(oldPwd ? "wrongloginrealm" : "loginrealm")); aRequest = xText->get_label(); aRequest = aRequest.replaceAll("%2", m_realm); } else { std::unique_ptr xText(m_xBuilder->weld_label(oldPwd ? "wrongrequestinfo" : "requestinfo")); aRequest = xText->get_label(); } aRequest = aRequest.replaceAll("%1", m_server); m_xRequestInfo->set_label(aRequest); } IMPL_LINK_NOARG(LoginDialog, OKHdl_Impl, weld::Button&, void) { // trim the strings m_xNameED->set_text(comphelper::string::strip(m_xNameED->get_text(), ' ')); m_xPasswordED->set_text(comphelper::string::strip(m_xPasswordED->get_text(), ' ')); m_xDialog->response(RET_OK); } IMPL_LINK_NOARG(LoginDialog, UseSysCredsHdl_Impl, weld::Button&, void) { EnableUseSysCredsControls_Impl( m_xUseSysCredsCB->get_active() ); } LoginDialog::LoginDialog(weld::Window* pParent, LoginFlags nFlags, const OUString& rServer, const OUString& rRealm) : GenericDialogController(pParent, "uui/ui/logindialog.ui", "LoginDialog") , m_xErrorFT(m_xBuilder->weld_label("errorft")) , m_xErrorInfo(m_xBuilder->weld_label("errorinfo")) , m_xRequestInfo(m_xBuilder->weld_label("requestinfo")) , m_xNameFT(m_xBuilder->weld_label("nameft")) , m_xNameED(m_xBuilder->weld_entry("nameed")) , m_xPasswordFT(m_xBuilder->weld_label("passwordft")) , m_xPasswordED(m_xBuilder->weld_entry("passworded")) , m_xAccountFT(m_xBuilder->weld_label("accountft")) , m_xAccountED(m_xBuilder->weld_entry("accounted")) , m_xSavePasswdBtn(m_xBuilder->weld_check_button("remember")) , m_xUseSysCredsCB(m_xBuilder->weld_check_button("syscreds")) , m_xOKBtn(m_xBuilder->weld_button("ok")) , m_server(rServer), m_realm(rRealm) { if ( !( nFlags & LoginFlags::NoUseSysCreds ) ) EnableUseSysCredsControls_Impl( m_xUseSysCredsCB->get_active() ); SetRequest(); m_xNameED->set_max_length( _MAX_PATH ); m_xOKBtn->connect_clicked( LINK( this, LoginDialog, OKHdl_Impl ) ); m_xUseSysCredsCB->connect_clicked( LINK( this, LoginDialog, UseSysCredsHdl_Impl ) ); HideControls_Impl( nFlags ); } void LoginDialog::SetUseSystemCredentials( bool bUse ) { if ( m_xUseSysCredsCB->get_visible() ) { m_xUseSysCredsCB->set_active( bUse ); EnableUseSysCredsControls_Impl( bUse ); } } void LoginDialog::ClearPassword() { m_xPasswordED->set_text( OUString() ); if ( m_xNameED->get_text().isEmpty() ) m_xNameED->grab_focus(); else m_xPasswordED->grab_focus(); } void LoginDialog::ClearAccount() { m_xAccountED->set_text( OUString() ); m_xAccountED->grab_focus(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */