diff options
author | Mathias Bauer <mba@openoffice.org> | 2009-10-31 00:36:06 +0100 |
---|---|---|
committer | Mathias Bauer <mba@openoffice.org> | 2009-10-31 00:36:06 +0100 |
commit | d32b3a714fe55892bdead03502c5a9b0e77fa61d (patch) | |
tree | 05a682f7a6b9210ddeb38b2afb05c7886caaf4cf /cui/source/options/optinet2.cxx | |
parent | 7176bc595f46ef90375de21314f86e02249b69f8 (diff) |
#i106421#: move svx/source/cui to cui
Diffstat (limited to 'cui/source/options/optinet2.cxx')
-rw-r--r-- | cui/source/options/optinet2.cxx | 2338 |
1 files changed, 2338 insertions, 0 deletions
diff --git a/cui/source/options/optinet2.cxx b/cui/source/options/optinet2.cxx new file mode 100644 index 000000000000..94f850eb1d32 --- /dev/null +++ b/cui/source/options/optinet2.cxx @@ -0,0 +1,2338 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2008 by Sun Microsystems, Inc. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: optinet2.cxx,v $ + * $Revision: 1.31 $ + * + * 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. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_cui.hxx" + +// include --------------------------------------------------------------- +#include <tools/shl.hxx> +#include <tools/config.hxx> +#include <vcl/msgbox.hxx> +#include <svl/intitem.hxx> +#include <svl/stritem.hxx> +#include <svl/eitem.hxx> +#include <svl/slstitm.hxx> +#include <sfx2/fcontnr.hxx> +#include <sfx2/dispatch.hxx> +#include <sfx2/docfilt.hxx> +#include <sfx2/viewsh.hxx> +#include <sfx2/sfxsids.hrc> +#include <sfx2/filedlghelper.hxx> +#include <tools/inetdef.hxx> +#include <svl/urihelper.hxx> +#include <svl/cntwids.hrc> +#include <unotools/inetoptions.hxx> +#include <sfx2/app.hxx> +#include <sfx2/objsh.hxx> +#include <unotools/bootstrap.hxx> +#include <vcl/help.hxx> +#include <sfx2/viewfrm.hxx> +#include <tools/urlobj.hxx> +#include <unotools/pathoptions.hxx> +#include <unotools/securityoptions.hxx> +#include <unotools/javaoptions.hxx> +#include <unotools/localfilehelper.hxx> +#include <unotools/extendedsecurityoptions.hxx> +#include <com/sun/star/uno/Sequence.hxx> +#define _SVX_OPTINET2_CXX +#include <svx/dialmgr.hxx> +#include "optinet2.hxx" +#include <svx/svxdlg.hxx> //CHINA001 +#include <svx/dialogs.hrc> +#include "optinet2.hrc" +#include "helpid.hrc" +#include <svx/ofaitem.hxx> +#include <svx/htmlmode.hxx> + +// for security TP +#include <comphelper/processfactory.hxx> +#include <com/sun/star/security/XDocumentDigitalSignatures.hpp> + +#ifdef UNX +#include <sys/types.h> +#include <sys/stat.h> +#include <unistd.h> +#include <fcntl.h> +#include <pwd.h> +#include <sys/types.h> +#include <string.h> +#include <rtl/textenc.h> +#include <rtl/locale.h> +#include <osl/nlsupport.h> +#endif +#include <sal/types.h> +#include <rtl/ustring.hxx> +#include <osl/file.hxx> +#include <osl/process.h> +#include <com/sun/star/container/XNameReplace.hpp> +#include <com/sun/star/container/XNameAccess.hpp> +#include <com/sun/star/beans/PropertyValue.hpp> +#include <com/sun/star/beans/XPropertySet.hpp> +#include <com/sun/star/beans/XPropertyState.hpp> +#include <com/sun/star/util/XChangesBatch.hpp> +#include <comphelper/processfactory.hxx> + +#include "com/sun/star/ui/dialogs/TemplateDescription.hpp" +#include "com/sun/star/task/XMasterPasswordHandling2.hpp" +#include "com/sun/star/task/XPasswordContainer.hpp" +#include "securityoptions.hxx" +#include "webconninfo.hxx" + +using namespace ::com::sun::star; +using namespace ::com::sun::star::uno; +using namespace ::sfx2; +using ::rtl::OUString; + +//CHINA001 copy from multipat.hxx begin +// define ---------------------------------------------------------------- + +// different delimiter for Unix (:) and Windows (;) + +#ifdef UNX +#define CLASSPATH_DELIMITER ':' +#else +#define CLASSPATH_DELIMITER ';' +#endif +//CHINA001 copy from multipat.hxx end +// static ---------------------------------------------------------------- + +#define C2U(cChar) OUString::createFromAscii(cChar) + +#define INET_SEARCH_TOKEN '"' +#define RET_ALL ((short)200) +#define CFG_READONLY_DEFAULT FALSE + +#include <sal/config.h> + +SV_IMPL_PTRARR( SfxFilterPtrArr, SfxFilterPtr ) + +const char* SEARCHENGINE_INI = "srcheng.ini"; +const char* SEARCHENGINE_GROUP = "SearchEngines-$(vlang)"; + +// ----------------------------------------------------------------------- + +String lcl_MakeTabEntry(const SfxFilter* pFilter) +{ + String sEntry(pFilter->GetMimeType()); + sEntry += '\t'; + sEntry += pFilter->GetWildcard().GetWildCard(); + sEntry += '\t'; + sEntry += pFilter->GetName(); +#if defined(OS2) + sEntry += '\t'; + sEntry += pFilter->GetTypeName(); +#endif + return sEntry; +} + +// ----------------------------------------------------------------------- + +BOOL IsJavaInstalled_Impl( /*!!!SfxIniManager* pIniMgr*/ ) +{ + BOOL bRet = FALSE; +/*!!! (pb) needs new implementation + String aIniEntry; + String aFullName = Config::GetConfigName( pIniMgr->Get( SFX_KEY_USERCONFIG_PATH ), + String::CreateFromAscii("java") ); + INetURLObject aIniFileObj( aFullName, INET_PROT_FILE ); + String aIniPath = aIniFileObj.getName(); + if ( pIniMgr->SearchFile( aIniPath ) ) + { + Config aJavaCfg( aIniPath ); + aJavaCfg.SetGroup( "Java" ); + ByteString sTemp = aJavaCfg.ReadKey( ByteString(::rtl::OUStringToOString(pIniMgr->GetKeyName( SFX_KEY_JAVA_SYSTEMCLASSPATH ),RTL_TEXTENCODING_UTF8)) ); + String aJavaSystemClassPath = ::rtl::OStringToOUString(sTemp,RTL_TEXTENCODING_UTF8); + String aJavaRuntimeLib = ::rtl::OStringToOUString(aJavaCfg.ReadKey( "RuntimeLib" ),RTL_TEXTENCODING_UTF8); + if ( aJavaSystemClassPath.Len() && aJavaRuntimeLib.Len() ) + bRet = TRUE; + } +*/ + return bRet; +} + +// ----------------------------------------------------------------------- + +void SvxNoSpaceEdit::KeyInput( const KeyEvent& rKEvent ) +{ + if ( bOnlyNumeric ) + { + const KeyCode& rKeyCode = rKEvent.GetKeyCode(); + USHORT nGroup = rKeyCode.GetGroup(); + USHORT nKey = rKeyCode.GetCode(); + BOOL bValid = ( KEYGROUP_NUM == nGroup || KEYGROUP_CURSOR == nGroup || + ( KEYGROUP_MISC == nGroup && ( nKey < KEY_ADD || nKey > KEY_EQUAL ) ) ); + if ( !bValid && ( rKeyCode.IsMod1() && ( + KEY_A == nKey || KEY_C == nKey || KEY_V == nKey || KEY_X == nKey || KEY_Z == nKey ) ) ) + // Erase, Copy, Paste, Select All und Undo soll funktionieren + bValid = TRUE; + + if ( bValid ) + Edit::KeyInput(rKEvent); + } + else if( rKEvent.GetKeyCode().GetCode() != KEY_SPACE ) + Edit::KeyInput(rKEvent); +} + +// ----------------------------------------------------------------------- + +void SvxNoSpaceEdit::Modify() +{ + Edit::Modify(); + + if ( bOnlyNumeric ) + { + XubString aValue = GetText(); + + if ( !ByteString(::rtl::OUStringToOString(aValue,RTL_TEXTENCODING_UTF8)).IsNumericAscii() || (long)aValue.ToInt32() > USHRT_MAX ) + // der H�chstwert einer Portnummer ist USHRT_MAX + ErrorBox( this, SVX_RES( RID_SVXERR_OPT_PROXYPORTS ) ).Execute(); + } +} + +/********************************************************************/ +/********************************************************************/ +/* */ +/* SvxProxyTabPage */ +/* */ +/* */ +/********************************************************************/ +/********************************************************************/ + +SvxProxyTabPage::SvxProxyTabPage(Window* pParent, const SfxItemSet& rSet ) : + SfxTabPage( pParent, SVX_RES( RID_SVXPAGE_INET_PROXY ), rSet ), + aOptionGB (this, SVX_RES(GB_SETTINGS)), + + aProxyModeFT (this, SVX_RES(FT_PROXYMODE)), + aProxyModeLB (this, SVX_RES(LB_PROXYMODE)), + + aHttpProxyFT (this, SVX_RES( FT_HTTP_PROXY )), + aHttpProxyED (this, SVX_RES( ED_HTTP_PROXY )), + aHttpPortFT (this, SVX_RES( FT_HTTP_PORT )), + aHttpPortED (this, SVX_RES( ED_HTTP_PORT ), TRUE), + + aHttpsProxyFT (this, SVX_RES( FT_HTTPS_PROXY )), + aHttpsProxyED (this, SVX_RES( ED_HTTPS_PROXY )), + aHttpsPortFT (this, SVX_RES( FT_HTTPS_PORT )), + aHttpsPortED (this, SVX_RES( ED_HTTPS_PORT ), TRUE), + + aFtpProxyFT (this, SVX_RES( FT_FTP_PROXY )), + aFtpProxyED (this, SVX_RES( ED_FTP_PROXY )), + aFtpPortFT (this, SVX_RES( FT_FTP_PORT )), + aFtpPortED (this, SVX_RES( ED_FTP_PORT ), TRUE), + + aNoProxyForFT (this, SVX_RES( FT_NOPROXYFOR )), + aNoProxyForED (this, SVX_RES( ED_NOPROXYFOR )), + aNoProxyDescFT (this, SVX_RES( ED_NOPROXYDESC )), + sFromBrowser ( SVX_RES( ST_PROXY_FROM_BROWSER ) ), + aProxyModePN(RTL_CONSTASCII_USTRINGPARAM("ooInetProxyType")), + aHttpProxyPN(RTL_CONSTASCII_USTRINGPARAM("ooInetHTTPProxyName")), + aHttpPortPN(RTL_CONSTASCII_USTRINGPARAM("ooInetHTTPProxyPort")), + aHttpsProxyPN(RTL_CONSTASCII_USTRINGPARAM("ooInetHTTPSProxyName")), + aHttpsPortPN(RTL_CONSTASCII_USTRINGPARAM("ooInetHTTPSProxyPort")), + aFtpProxyPN(RTL_CONSTASCII_USTRINGPARAM("ooInetFTPProxyName")), + aFtpPortPN(RTL_CONSTASCII_USTRINGPARAM("ooInetFTPProxyPort")), + aNoProxyDescPN(RTL_CONSTASCII_USTRINGPARAM("ooInetNoProxy")) +{ + FreeResource(); + + aHttpPortED.SetMaxTextLen(5); + aHttpsPortED.SetMaxTextLen(5); + aFtpPortED.SetMaxTextLen(5); + Link aLink = LINK( this, SvxProxyTabPage, LoseFocusHdl_Impl ); + aHttpPortED.SetLoseFocusHdl( aLink ); + aHttpsPortED.SetLoseFocusHdl( aLink ); + aFtpPortED.SetLoseFocusHdl( aLink ); + + aProxyModeLB.SetSelectHdl(LINK( this, SvxProxyTabPage, ProxyHdl_Impl )); + + Reference< com::sun::star::lang::XMultiServiceFactory > xServiceManager( + ::comphelper::getProcessServiceFactory()); + + if( xServiceManager.is() ) + { + try + { + Reference< com::sun::star::lang::XMultiServiceFactory > xConfigurationProvider = + Reference< com::sun::star::lang::XMultiServiceFactory > ( xServiceManager->createInstance( rtl::OUString( + RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.configuration.ConfigurationProvider" ) ) ), + UNO_QUERY_THROW); + + OUString aConfigRoot(RTL_CONSTASCII_USTRINGPARAM( "org.openoffice.Inet/Settings" ) ); + + beans::PropertyValue aProperty; + aProperty.Name = OUString(RTL_CONSTASCII_USTRINGPARAM( "nodepath" )); + aProperty.Value = makeAny( aConfigRoot ); + + Sequence< Any > aArgumentList( 1 ); + aArgumentList[0] = makeAny( aProperty ); + + m_xConfigurationUpdateAccess = xConfigurationProvider->createInstanceWithArguments( rtl::OUString( + RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.configuration.ConfigurationUpdateAccess" ) ), + aArgumentList ); + } + catch ( RuntimeException& ) + { + } + } + + ArrangeControls_Impl(); +} + +/*-----------------12.08.96 14.55------------------- + +--------------------------------------------------*/ + +SvxProxyTabPage::~SvxProxyTabPage() +{ +} + +/*-----------------12.08.96 14.55------------------- + +--------------------------------------------------*/ + +SfxTabPage* SvxProxyTabPage::Create(Window* pParent, const SfxItemSet& rAttrSet ) +{ + return new SvxProxyTabPage(pParent, rAttrSet); +} + +/*-----------------02.09.04 14.55------------------- + +--------------------------------------------------*/ + +void SvxProxyTabPage::ReadConfigData_Impl() +{ + try { + Reference< container::XNameAccess > xNameAccess(m_xConfigurationUpdateAccess, UNO_QUERY_THROW); + + sal_Int32 nIntValue = 0; + OUString aStringValue; + + if( xNameAccess->getByName(aProxyModePN) >>= nIntValue ) + { + aProxyModeLB.SelectEntryPos( (USHORT) nIntValue ); + } + + if( xNameAccess->getByName(aHttpProxyPN) >>= aStringValue ) + { + aHttpProxyED.SetText( aStringValue ); + } + + if( xNameAccess->getByName(aHttpPortPN) >>= nIntValue ) + { + aHttpPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xNameAccess->getByName(aHttpsProxyPN) >>= aStringValue ) + { + aHttpsProxyED.SetText( aStringValue ); + } + + if( xNameAccess->getByName(aHttpsPortPN) >>= nIntValue ) + { + aHttpsPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xNameAccess->getByName(aFtpProxyPN) >>= aStringValue ) + { + aFtpProxyED.SetText( aStringValue ); + } + + if( xNameAccess->getByName(aFtpPortPN) >>= nIntValue ) + { + aFtpPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xNameAccess->getByName(aNoProxyDescPN) >>= aStringValue ) + { + aNoProxyForED.SetText( aStringValue ); + } + } + + catch(container::NoSuchElementException e) { + OSL_TRACE( "SvxProxyTabPage::ReadConfigData_Impl: NoSuchElementException caught" ); + } + + catch(com::sun::star::lang::WrappedTargetException e) { + OSL_TRACE( "SvxProxyTabPage::ReadConfigData_Impl: WrappedTargetException caught" ); + } + + catch(RuntimeException e) { + OSL_TRACE( "SvxProxyTabPage::ReadConfigData_Impl: RuntimeException caught" ); + } + +} + +/*-----------------02.09.04 14.55------------------- + +--------------------------------------------------*/ + +void SvxProxyTabPage::ReadConfigDefaults_Impl() +{ + try + { + Reference< beans::XPropertyState > xPropertyState(m_xConfigurationUpdateAccess, UNO_QUERY_THROW); + + sal_Int32 nIntValue = 0; + OUString aStringValue; + + if( xPropertyState->getPropertyDefault(aHttpProxyPN) >>= aStringValue ) + { + aHttpProxyED.SetText( aStringValue ); + } + + if( xPropertyState->getPropertyDefault(aHttpPortPN) >>= nIntValue ) + { + aHttpPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xPropertyState->getPropertyDefault(aHttpsProxyPN) >>= aStringValue ) + { + aHttpsProxyED.SetText( aStringValue ); + } + + if( xPropertyState->getPropertyDefault(aHttpsPortPN) >>= nIntValue ) + { + aHttpsPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xPropertyState->getPropertyDefault(aFtpProxyPN) >>= aStringValue ) + { + aFtpProxyED.SetText( aStringValue ); + } + + if( xPropertyState->getPropertyDefault(aFtpPortPN) >>= nIntValue ) + { + aFtpPortED.SetText( String::CreateFromInt32( nIntValue )); + } + + if( xPropertyState->getPropertyDefault(aNoProxyDescPN) >>= aStringValue ) + { + aNoProxyForED.SetText( aStringValue ); + } + } + catch(beans::UnknownPropertyException e) + { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: UnknownPropertyException caught" ); + } + + catch(com::sun::star::lang::WrappedTargetException e) { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: WrappedTargetException caught" ); + } + + catch(RuntimeException e) + { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: RuntimeException caught" ); + } +} + +/*-----------------02.09.04 14.55------------------- + +--------------------------------------------------*/ + +void SvxProxyTabPage::RestoreConfigDefaults_Impl() +{ + try + { + Reference< beans::XPropertyState > xPropertyState(m_xConfigurationUpdateAccess, UNO_QUERY_THROW); + + xPropertyState->setPropertyToDefault(aProxyModePN); + xPropertyState->setPropertyToDefault(aHttpProxyPN); + xPropertyState->setPropertyToDefault(aHttpPortPN); + xPropertyState->setPropertyToDefault(aHttpsProxyPN); + xPropertyState->setPropertyToDefault(aHttpsPortPN); + xPropertyState->setPropertyToDefault(aFtpProxyPN); + xPropertyState->setPropertyToDefault(aFtpPortPN); + xPropertyState->setPropertyToDefault(aNoProxyDescPN); + + Reference< util::XChangesBatch > xChangesBatch(m_xConfigurationUpdateAccess, UNO_QUERY_THROW); + xChangesBatch->commitChanges(); + } + + catch(beans::UnknownPropertyException e) + { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: UnknownPropertyException caught" ); + } + + catch(com::sun::star::lang::WrappedTargetException e) { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: WrappedTargetException caught" ); + } + + catch(RuntimeException e) + { + OSL_TRACE( "SvxProxyTabPage::RestoreConfigDefaults_Impl: RuntimeException caught" ); + } +} + +/*-----------------12.08.96 14.55------------------- + +--------------------------------------------------*/ + +void SvxProxyTabPage::Reset(const SfxItemSet&) +{ + ReadConfigData_Impl(); + + aProxyModeLB.SaveValue(); + aHttpProxyED.SaveValue(); + aHttpPortED.SaveValue(); + aHttpsProxyED.SaveValue(); + aHttpsPortED.SaveValue(); + aFtpProxyED.SaveValue(); + aFtpPortED.SaveValue(); + aNoProxyForED.SaveValue(); + + EnableControls_Impl( aProxyModeLB.GetSelectEntryPos() == 2 ); +} + +/*-----------------12.08.96 16.34------------------- + +--------------------------------------------------*/ + +BOOL SvxProxyTabPage::FillItemSet(SfxItemSet& ) +{ + BOOL bModified=FALSE; + + try { + Reference< beans::XPropertySet > xPropertySet(m_xConfigurationUpdateAccess, UNO_QUERY_THROW ); + + USHORT nSelPos = aProxyModeLB.GetSelectEntryPos(); + if(aProxyModeLB.GetSavedValue() != nSelPos) + { + if( nSelPos == 1 ) + { + RestoreConfigDefaults_Impl(); + return TRUE; + } + + xPropertySet->setPropertyValue(aProxyModePN, + makeAny((sal_Int32) nSelPos)); + bModified = TRUE; + } + + if(aHttpProxyED.GetSavedValue() != aHttpProxyED.GetText()) + { + xPropertySet->setPropertyValue( aHttpProxyPN, + makeAny(rtl::OUString(aHttpProxyED.GetText()))); + bModified = TRUE; + } + + if ( aHttpPortED.GetSavedValue() != aHttpPortED.GetText() ) + { + xPropertySet->setPropertyValue( aHttpPortPN, + makeAny(aHttpPortED.GetText().ToInt32())); + bModified = TRUE; + } + + if(aHttpsProxyED.GetSavedValue() != aHttpsProxyED.GetText()) + { + xPropertySet->setPropertyValue( aHttpsProxyPN, + makeAny(rtl::OUString(aHttpsProxyED.GetText()))); + bModified = TRUE; + } + + if ( aHttpsPortED.GetSavedValue() != aHttpsPortED.GetText() ) + { + xPropertySet->setPropertyValue( aHttpsPortPN, + makeAny(aHttpsPortED.GetText().ToInt32())); + bModified = TRUE; + } + + if(aFtpProxyED.GetSavedValue() != aFtpProxyED.GetText()) + { + xPropertySet->setPropertyValue( aFtpProxyPN, + makeAny( rtl::OUString(aFtpProxyED.GetText()))); + bModified = TRUE; + } + + if ( aFtpPortED.GetSavedValue() != aFtpPortED.GetText() ) + { + xPropertySet->setPropertyValue( aFtpPortPN, + makeAny(aFtpPortED.GetText().ToInt32())); + bModified = TRUE; + } + + if ( aNoProxyForED.GetSavedValue() != aNoProxyForED.GetText() ) + { + xPropertySet->setPropertyValue( aNoProxyDescPN, + makeAny( rtl::OUString(aNoProxyForED.GetText()))); + bModified = TRUE; + } + + Reference< util::XChangesBatch > xChangesBatch(m_xConfigurationUpdateAccess, UNO_QUERY_THROW); + xChangesBatch->commitChanges(); + } + + catch(com::sun::star::lang::IllegalArgumentException e) { + OSL_TRACE( "SvxProxyTabPage::FillItemSet: IllegalArgumentException caught" ); + } + + catch(beans::UnknownPropertyException e) { + OSL_TRACE( "SvxProxyTabPage::FillItemSet: UnknownPropertyException caught" ); + } + + catch(beans::PropertyVetoException e) { + OSL_TRACE( "SvxProxyTabPage::FillItemSet: PropertyVetoException caught" ); + } + + catch(com::sun::star::lang::WrappedTargetException e) { + OSL_TRACE( "SvxProxyTabPage::FillItemSet: WrappedTargetException caught" ); + } + + catch(RuntimeException e) { + OSL_TRACE( "SvxProxyTabPage::FillItemSet: RuntimeException caught" ); + } + + return bModified; +} + +void SvxProxyTabPage::ArrangeControls_Impl() +{ + //-->Calculate dynamical width of controls, add buy wuy for i71445 Time: 2007.02.27 + long nWidth = aProxyModeFT.GetCtrlTextWidth( aProxyModeFT.GetText() ); + long nTemp = aHttpProxyFT.GetCtrlTextWidth( aHttpProxyFT.GetText() ); + if ( nTemp > nWidth ) + nWidth = nTemp; + nTemp = aHttpsProxyFT.GetCtrlTextWidth( aHttpsProxyFT.GetText() ); + if ( nTemp > nWidth ) + nWidth = nTemp; + nTemp = aFtpProxyFT.GetCtrlTextWidth( aFtpProxyFT.GetText() ); + if ( nTemp > nWidth ) + nWidth = nTemp; + nTemp = aNoProxyForFT.GetCtrlTextWidth( aNoProxyForFT.GetText() ); + if ( nTemp > nWidth ) + nWidth = nTemp; + + nWidth += 10; // To be sure the length of the FixedText is enough on all platforms + const long nFTWidth = aProxyModeFT.GetSizePixel().Width(); + if ( nWidth > nFTWidth ) + { + Size aNewSize = aProxyModeFT.GetSizePixel(); + aNewSize.Width() = nWidth; + + aProxyModeFT.SetSizePixel( aNewSize ); + aHttpProxyFT.SetSizePixel( aNewSize ); + aHttpsProxyFT.SetSizePixel( aNewSize ); + aFtpProxyFT.SetSizePixel( aNewSize ); + aNoProxyForFT.SetSizePixel( aNewSize ); + + const long nDelta = nWidth - nFTWidth; + Point aNewPos = aProxyModeLB.GetPosPixel(); + aNewPos.X() += nDelta; + + aProxyModeLB.SetPosPixel( aNewPos ); + + aNewSize = aHttpProxyED.GetSizePixel(); + aNewSize.Width() -= nDelta; + + aNewPos.Y() = aHttpProxyED.GetPosPixel().Y(); + aHttpProxyED.SetPosSizePixel( aNewPos, aNewSize ); + aNewPos.Y() = aHttpsProxyED.GetPosPixel().Y(); + aHttpsProxyED.SetPosSizePixel( aNewPos, aNewSize ); + aNewPos.Y() = aFtpProxyED.GetPosPixel().Y(); + aFtpProxyED.SetPosSizePixel( aNewPos, aNewSize ); + aNewPos.Y() = aNoProxyForED.GetPosPixel().Y(); + aNoProxyForED.SetPosSizePixel( aNewPos, aNewSize ); + } + //<--End buy wuy for i71445 Time: 2007.02.27 +} + +/*-----------------12.08.96 13.38------------------- + +--------------------------------------------------*/ +void SvxProxyTabPage::EnableControls_Impl(BOOL bEnable) +{ + aHttpProxyFT.Enable(bEnable); + aHttpProxyED.Enable(bEnable); + aHttpPortFT.Enable(bEnable); + aHttpPortED.Enable(bEnable); + + aHttpsProxyFT.Enable(bEnable); + aHttpsProxyED.Enable(bEnable); + aHttpsPortFT.Enable(bEnable); + aHttpsPortED.Enable(bEnable); + + aFtpProxyFT.Enable(bEnable); + aFtpProxyED.Enable(bEnable); + aFtpPortFT.Enable(bEnable); + aFtpPortED.Enable(bEnable); + + aNoProxyForFT.Enable(bEnable); + aNoProxyForED.Enable(bEnable); + aNoProxyDescFT.Enable(bEnable); +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxProxyTabPage, ProxyHdl_Impl, ListBox *, pBox ) +{ + USHORT nPos = pBox->GetSelectEntryPos(); + + // Restore original system values + if( nPos == 1 ) + { + ReadConfigDefaults_Impl(); + } + + EnableControls_Impl(nPos == 2); + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxProxyTabPage, LoseFocusHdl_Impl, Edit *, pEdit ) +{ + XubString aValue = pEdit->GetText(); + + if ( !ByteString(::rtl::OUStringToOString(aValue,RTL_TEXTENCODING_UTF8)).IsNumericAscii() || (long)aValue.ToInt32() > USHRT_MAX ) + pEdit->SetText( '0' ); + return 0; +} + + +/********************************************************************/ +/********************************************************************/ +/* */ +/* SvxSearchTabPage */ +/* */ +/* */ +/********************************************************************/ +/********************************************************************/ + +SvxSearchTabPage::SvxSearchTabPage(Window* pParent, const SfxItemSet& rSet ) : + + SfxTabPage( pParent, SVX_RES( RID_SVXPAGE_INET_SEARCH ), rSet ), + + aSearchGB ( this, SVX_RES( GB_SEARCH ) ), + aSearchLB ( this, SVX_RES( LB_SEARCH ) ), + aSearchNameFT ( this, SVX_RES( FT_SEARCH_NAME ) ), + aSearchNameED ( this, SVX_RES( ED_SEARCH_NAME ) ), + aSearchFT ( this, SVX_RES( FT_SEARCH ) ), + aAndRB ( this, SVX_RES( RB_AND ) ), + aOrRB ( this, SVX_RES( RB_OR ) ), + aExactRB ( this, SVX_RES( RB_EXACT ) ), + + aURLFT ( this, SVX_RES( FT_URL ) ), + aURLED ( this, SVX_RES( ED_URL ) ), + + aPostFixFT ( this, SVX_RES( FT_POSTFIX ) ), + aPostFixED ( this, SVX_RES( ED_POSTFIX ) ), + aSeparatorFT ( this, SVX_RES( FT_SEPARATOR ) ), + aSeparatorED ( this, SVX_RES( ED_SEPARATOR ) ), + aCaseFT ( this, SVX_RES( FT_CASE ) ), + aCaseED ( this, SVX_RES( ED_CASE ) ), + + aNewPB ( this, SVX_RES( PB_NEW ) ), + aAddPB ( this, SVX_RES( PB_ADD ) ), + aChangePB ( this, SVX_RES( PB_CHANGE ) ), + aDeletePB ( this, SVX_RES( PB_DELETE ) ), + + sModifyMsg(SVX_RES(MSG_MODIFY)) +{ + FreeResource(); + + SetExchangeSupport(); + aCaseED.SelectEntryPos(0); // falls kein Eintrag vorhanden ist, kann es sonst "Arger geben + + aNewPB.SetClickHdl(LINK( this, SvxSearchTabPage, NewSearchHdl_Impl ) ); + aAddPB.SetClickHdl(LINK( this, SvxSearchTabPage, AddSearchHdl_Impl ) ); + aChangePB.SetClickHdl(LINK( this, SvxSearchTabPage, ChangeSearchHdl_Impl ) ); + aDeletePB.SetClickHdl(LINK( this, SvxSearchTabPage, DeleteSearchHdl_Impl ) ); + aSearchLB.SetSelectHdl(LINK( this, SvxSearchTabPage, SearchEntryHdl_Impl ) ); + + Link aLink = LINK( this, SvxSearchTabPage, SearchModifyHdl_Impl ); + aSearchNameED.SetModifyHdl( aLink ); + aURLED.SetModifyHdl( aLink ); + aSeparatorED.SetModifyHdl( aLink ); + aPostFixED.SetModifyHdl( aLink ); + aCaseED.SetSelectHdl( aLink ); + + aLink = LINK( this, SvxSearchTabPage, SearchPartHdl_Impl ); + aAndRB.SetClickHdl( aLink ); + aOrRB.SetClickHdl( aLink ); + aExactRB.SetClickHdl( aLink ); + + InitControls_Impl(); +} + +// ----------------------------------------------------------------------- +SvxSearchTabPage::~SvxSearchTabPage() +{ +} +// ----------------------------------------------------------------------- + +SfxTabPage* SvxSearchTabPage::Create(Window* pParent, const SfxItemSet& rAttrSet ) +{ + return new SvxSearchTabPage(pParent, rAttrSet); +} + +// ----------------------------------------------------------------------- + +void SvxSearchTabPage::Reset( const SfxItemSet& ) +{ + //The two lines below are moved here from the last part of this method by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + aChangePB.Disable(); + aAddPB.Disable(); + + sal_uInt16 nCount = aSearchConfig.Count(); + aSearchLB.Clear(); //add by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + for(sal_uInt16 i = 0; i < nCount; i++) + { + const SvxSearchEngineData& rData = aSearchConfig.GetData(i); + aSearchLB.InsertEntry(rData.sEngineName); + } + + if ( nCount ) + { + aSearchLB.SelectEntryPos(0); + SearchEntryHdl_Impl( &aSearchLB ); + } + else + aDeletePB.Disable(); +} + +// ----------------------------------------------------------------------- + +BOOL SvxSearchTabPage::FillItemSet( SfxItemSet& ) +{ + if(aSearchConfig.IsModified()) + aSearchConfig.Commit(); + return TRUE; +} +/*--------------------------------------------------------------------*/ + +void SvxSearchTabPage::ActivatePage( const SfxItemSet& ) +{ +} + +/*--------------------------------------------------------------------*/ + +int SvxSearchTabPage::DeactivatePage( SfxItemSet* _pSet ) +{ + //Modified by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + if(!ConfirmLeave(String())) + return KEEP_PAGE; + + if ( _pSet ) + FillItemSet( *_pSet ); + return LEAVE_PAGE; +} + +// ----------------------------------------------------------------------- + +//add by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) +BOOL SvxSearchTabPage::ConfirmLeave( const String& rStringSelection) +{ + if(aChangePB.IsEnabled()) + { + QueryBox aQuery(this, WB_YES_NO_CANCEL|WB_DEF_YES, sModifyMsg); + USHORT nRet = aQuery.Execute(); + if(RET_CANCEL == nRet) + { + if(rStringSelection.Len()) + aSearchLB.SelectEntry(sLastSelectedEntry); + return FALSE; + } + else if(RET_YES == nRet) + { + USHORT nEntryPos = aSearchLB.GetEntryPos( aSearchNameED.GetText() ); + if ( nEntryPos != LISTBOX_ENTRY_NOTFOUND ) + aSearchLB.SelectEntryPos(nEntryPos); + else + aSearchLB.SetNoSelection(); + ChangeSearchHdl_Impl(0); + if(rStringSelection.Len()) + aSearchLB.SelectEntry(rStringSelection); + } + else if(RET_NO == nRet) + { + aChangePB.Enable(FALSE); + aAddPB.Enable(FALSE); + SearchEntryHdl_Impl(&aSearchLB); + } + } + if(aAddPB.IsEnabled()) + { + QueryBox aQuery(this, WB_YES_NO_CANCEL|WB_DEF_YES, sModifyMsg); + USHORT nRet = aQuery.Execute(); + if(RET_CANCEL == nRet) + { + aSearchLB.SetNoSelection(); + return FALSE; + } + else if(RET_YES == nRet) + { + aSearchLB.SetNoSelection(); + AddSearchHdl_Impl(0); + if(rStringSelection.Len()) + aSearchLB.SelectEntry(rStringSelection); + } + else if(RET_NO == nRet) + { + aAddPB.Enable(FALSE); + aChangePB.Enable(FALSE); + NewSearchHdl_Impl(0); + } + + } + return TRUE; +} + +// ----------------------------------------------------------------------- + +void SvxSearchTabPage::InitControls_Impl() +{ + // detect longest label text + sal_Int32 i = 0; + long nLabelTextWidth = 0; + Window* pLabels[] = { &aSearchNameFT, &aSearchFT, &aURLFT, &aPostFixFT, &aSeparatorFT, &aCaseFT }; + Window** pLabel = pLabels; + const sal_Int32 nLabelCount = sizeof( pLabels ) / sizeof( pLabels[0] ); + for ( ; i < nLabelCount; ++i, ++pLabel ) + { + long nTemp = (*pLabel)->GetCtrlTextWidth( (*pLabel)->GetText() ); + if ( nTemp > nLabelTextWidth ) + nLabelTextWidth = nTemp; + } + + // resize all labels + nLabelTextWidth = nLabelTextWidth * 120 / 100; // additional space looks better + const long nLabelWidth = aSearchNameFT.GetSizePixel().Width(); + const long nDelta = nLabelWidth - nLabelTextWidth; + pLabel = pLabels; + for ( i = 0; i < nLabelCount; ++i, ++pLabel ) + { + Size aNewSize = (*pLabel)->GetSizePixel(); + aNewSize.Width() += nDelta; + (*pLabel)->SetSizePixel( aNewSize ); + } + + // resize and move the edits + Window* pEdits[] = { &aSearchNameED, &aAndRB, &aOrRB, + &aExactRB, &aURLED, &aPostFixED, &aSeparatorED, &aCaseED }; + Window** pEdit = pEdits; + const sal_Int32 nCCount = sizeof( pEdits ) / sizeof( pEdits[ 0 ] ); + for ( i = 0; i < nCCount; ++i, ++pEdit ) + { + Point aNewPos = (*pEdit)->GetPosPixel(); + aNewPos.X() -= nDelta; + Size aNewSize = (*pEdit)->GetSizePixel(); + if ( (*pEdit) != &aSeparatorED && (*pEdit) != &aCaseED ) + aNewSize.Width() += nDelta; + (*pEdit)->SetPosSizePixel( aNewPos, aNewSize ); + } +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, NewSearchHdl_Impl, PushButton *, EMPTYARG ) +{ + //The 3 lines below is modified by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + SearchEntryHdl_Impl(&aSearchLB); + if(aChangePB.IsEnabled() || aAddPB.IsEnabled()) + return 0; + aSearchNameED.SetText( String() ); + aSearchLB.SetNoSelection(); + aCurrentSrchData = SvxSearchEngineData(); + aAndRB.Check( TRUE ); + SearchEntryHdl_Impl( &aSearchLB ); + SearchPartHdl_Impl( &aAndRB ); + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, AddSearchHdl_Impl, PushButton *, EMPTYARG ) +{ + //The following two lines is added by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + aAddPB.Enable(FALSE); + aChangePB.Enable(FALSE); + aCurrentSrchData.sEngineName = aSearchNameED.GetText(); + aSearchConfig.SetData(aCurrentSrchData); + aSearchLB.InsertEntry( aCurrentSrchData.sEngineName ); + aSearchLB.SelectEntry( aCurrentSrchData.sEngineName ); + SearchEntryHdl_Impl( &aSearchLB ); + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, ChangeSearchHdl_Impl, PushButton *, EMPTYARG ) +{ + //The following two lines is added by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + aChangePB.Enable(FALSE); + aAddPB.Enable(FALSE); + USHORT nPos = aSearchLB.GetSelectEntryPos(); + if ( nPos != LISTBOX_ENTRY_NOTFOUND ) + { + String sEngine = aSearchLB.GetSelectEntry(); + aCurrentSrchData.sEngineName = sEngine; + aSearchConfig.SetData(aCurrentSrchData); + aSearchLB.SelectEntry(sEngine); + SearchEntryHdl_Impl(&aSearchLB); + } + else + { + SetUpdateMode(FALSE); + String sEntry = aSearchNameED.GetText(); + // im AddHdl wird sLastSelectedEntry umgesetzt + String sTemp(sLastSelectedEntry); + AddSearchHdl_Impl(0); + aSearchLB.SelectEntry(sTemp); + DeleteSearchHdl_Impl(0); + aSearchLB.SelectEntry(sEntry); + SearchEntryHdl_Impl(&aSearchLB); + SetUpdateMode(TRUE); + } + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, DeleteSearchHdl_Impl, PushButton *, EMPTYARG) +{ + aChangePB.Enable(FALSE); //add by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + USHORT nPos = aSearchLB.GetSelectEntryPos(); + DBG_ASSERT(nPos != LISTBOX_ENTRY_NOTFOUND, "kein Eintrag selektiert!"); + aSearchConfig.RemoveData(aSearchLB.GetSelectEntry()); + aSearchLB.RemoveEntry(nPos); + aSearchLB.SelectEntryPos(0); + SearchEntryHdl_Impl(&aSearchLB); + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, SearchEntryHdl_Impl, ListBox*, pBox ) +{ + USHORT nEntryPos = pBox->GetSelectEntryPos(); + if ( nEntryPos != LISTBOX_ENTRY_NOTFOUND ) + { + String sSelection(pBox->GetSelectEntry()); + //Modified by BerryJia for fixing Bug102610 Time:2002-8-29 11:00 (China Standard Time GMT+08:00) + if(!ConfirmLeave(sSelection)) + return 0; + + const SvxSearchEngineData* pData = aSearchConfig.GetData(sSelection); + DBG_ASSERT(pData, "SearchEngine not available"); + if(pData) + { + aSearchNameED.SetText(sSelection); + sLastSelectedEntry = sSelection; + sal_Bool bAnd = aAndRB.IsChecked(); + sal_Bool bOr = aOrRB.IsChecked(); + + aURLED.SetText(bAnd ? pData->sAndPrefix : bOr ? pData->sOrPrefix : pData->sExactPrefix); + aSeparatorED.SetText( bAnd ? pData->sAndSeparator : bOr ? pData->sOrSeparator : pData->sExactSeparator); + aPostFixED.SetText(bAnd ? pData->sAndSuffix : bOr ? pData->sOrSuffix : pData->sExactSuffix ); + sal_Int32 nCase = bAnd ? pData->nAndCaseMatch : bOr ? pData->nOrCaseMatch : pData->nExactCaseMatch; + aCaseED.SelectEntryPos( (USHORT)nCase ); + aCurrentSrchData = *pData; + } + aDeletePB.Enable(); + } + else + { + aDeletePB.Enable(FALSE); + sLastSelectedEntry.Erase(); + } + aChangePB.Enable(FALSE); + aAddPB.Enable(FALSE); + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, SearchModifyHdl_Impl, SvxNoSpaceEdit*, pEdit ) +{ + if ( pEdit == &aSearchNameED ) + { + BOOL bTextLen = ( 0 != pEdit->GetText().Len() ); + BOOL bFound = FALSE; + if ( bTextLen ) + { + USHORT nEntryPos = aSearchLB.GetEntryPos( pEdit->GetText() ); + bFound = ( nEntryPos != LISTBOX_ENTRY_NOTFOUND ); + if ( bFound ) + aSearchLB.SelectEntryPos(nEntryPos); + else + aSearchLB.SetNoSelection(); + } + aChangePB.Enable( sLastSelectedEntry.Len() > 0 ); + aDeletePB.Enable(bFound); + aAddPB.Enable(bTextLen && !bFound); + } + else + { + if ( aSearchLB.GetSelectEntryCount() && sLastSelectedEntry.Len() > 0 ) + aChangePB.Enable(); + + if(aAndRB.IsChecked()) + { + aCurrentSrchData.sAndPrefix = aURLED.GetText(); + aCurrentSrchData.sAndSeparator = aSeparatorED.GetText(); + aCurrentSrchData.sAndSuffix = aPostFixED.GetText(); + aCurrentSrchData.nAndCaseMatch = aCaseED.GetSelectEntryPos(); + } + else if(aOrRB.IsChecked()) + { + aCurrentSrchData.sOrPrefix = aURLED.GetText(); + aCurrentSrchData.sOrSeparator = aSeparatorED.GetText(); + aCurrentSrchData.sOrSuffix = aPostFixED.GetText(); + aCurrentSrchData.nOrCaseMatch = aCaseED.GetSelectEntryPos(); + } + else + { + aCurrentSrchData.sExactPrefix = aURLED.GetText(); + aCurrentSrchData.sExactSeparator = aSeparatorED.GetText(); + aCurrentSrchData.sExactSuffix = aPostFixED.GetText(); + aCurrentSrchData.nExactCaseMatch = aCaseED.GetSelectEntryPos(); + } + } + return 0; +} + +// ----------------------------------------------------------------------- + +IMPL_LINK( SvxSearchTabPage, SearchPartHdl_Impl, RadioButton *, EMPTYARG ) +{ + sal_Bool bAnd = aAndRB.IsChecked(); + sal_Bool bOr = aOrRB.IsChecked(); + + aURLED.SetText(bAnd ? aCurrentSrchData.sAndPrefix : bOr ? aCurrentSrchData.sOrPrefix : aCurrentSrchData.sExactPrefix); + aSeparatorED.SetText( bAnd ? aCurrentSrchData.sAndSeparator : bOr ? aCurrentSrchData.sOrSeparator : aCurrentSrchData.sExactSeparator); + aPostFixED.SetText(bAnd ? aCurrentSrchData.sAndSuffix : bOr ? aCurrentSrchData.sOrSuffix : aCurrentSrchData.sExactSuffix ); + sal_Int32 nCase = bAnd ? aCurrentSrchData.nAndCaseMatch : bOr ? aCurrentSrchData.nOrCaseMatch : aCurrentSrchData.nExactCaseMatch; + aCaseED.SelectEntryPos( (USHORT)nCase ); + return 0; +} + +// ----------------------------------------------------------------------- + +/********************************************************************/ +/********************************************************************/ +/* */ +/* SvxOtherTabPage */ +/* */ +/********************************************************************/ +/********************************************************************/ + +/*-----------------15.05.97 09:51------------------- + +--------------------------------------------------*/ +/* +SvxPatternField::SvxPatternField( Window* pParent, const ResId& rResId ) : + + PatternField( pParent, rResId ), + + sMsg233 ( ResId( ST_MSG_233 ) ), + sMsg255 ( ResId( ST_MSG_255 ) ) + +{ + FreeResource(); + SelectFixedFont(); +} */ + +/*-----------------15.05.97 09:51------------------- + +--------------------------------------------------*/ + +/*void SvxPatternField::KeyInput( const KeyEvent& rKEvt ) +{ + PatternField::KeyInput( rKEvt ); + BOOL bDelete = ( rKEvt.GetKeyCode().GetCode() == KEY_DELETE ); + String sEntry( GetText() ); + sEntry[(USHORT)3] = '.'; + sEntry[(USHORT)7] = '.'; + sEntry[(USHORT)11] = '.'; + Selection aSelection( GetSelection() ); + String sPart( sEntry.GetToken( 0, '.' ) ); + USHORT i, nPart( sPart.EraseLeadingChars() ); + BOOL bSet = FALSE; + + if ( sPart.Len() && ( !nPart || nPart > 255 ) ) + { + // der erste Part darf nicht 0 und nicht gr"osser 255 sein + String sMsg( sPart ); + sMsg += ' '; + sMsg += sMsg233; + InfoBox( this, sMsg ).Execute(); + + if ( nPart == 0 ) + sPart = " 1"; + else + sPart = "255"; + sEntry.SetToken( 0, '.', sPart ); + bSet = TRUE; + }; + + for ( i = 1; i < 4; i++ ) + { + // die anderen Parts d"urfen nicht gr"osser 255 sein + sPart = sEntry.GetToken( i, '.' ); + nPart = sPart.EraseLeadingChars(); + + if ( nPart > 255 ) + { + String sMsg( sPart ); + sMsg += ' '; + sMsg += sMsg255; + InfoBox( this, sMsg ).Execute(); + + if ( nPart == 0 ) + sPart = " 1"; + else + sPart = "255"; + sEntry.SetToken( i, '.', sPart ); + bSet = TRUE; + }; + } + + if ( bSet ) + { + SetText( sEntry ); + SetSelection( aSelection ); + } +} +*/ +// ----------------------------------------------------------------------- +#if 0 +long SvxPatternField::Notify( NotifyEvent& rNEvt ) +{ + return PatternField::Notify( rNEvt ); +/*! long nHandled = 0; + + if ( rNEvt.GetType() == EVENT_KEYUP ) + { + const KeyEvent* pKEvt = rNEvt.GetKeyEvent(); + KeyInput( *pKEvt ); + nHandled = 1; + } + return nHandled;*/ +} +#endif + +// class JavaScriptDisableQueryBox_Impl -------------------------------------- + +class JavaScriptDisableQueryBox_Impl : public ModalDialog +{ +private: + FixedImage aImage; + FixedText aWarningFT; + CheckBox aDisableCB; + OKButton aYesBtn; + CancelButton aNoBtn; + +public: + JavaScriptDisableQueryBox_Impl( Window* pParent ); + + BOOL IsWarningDisabled() const { return aDisableCB.IsChecked(); } +}; + +JavaScriptDisableQueryBox_Impl::JavaScriptDisableQueryBox_Impl( Window* pParent ) : + + ModalDialog( pParent, SVX_RES( RID_SVXDLG_OPT_JAVASCRIPT_DISABLE ) ), + + aImage ( this, SVX_RES( IMG_JSCPT_WARNING ) ), + aWarningFT ( this, SVX_RES( FT_JSCPT_WARNING ) ), + aDisableCB ( this, SVX_RES( CB_JSCPT_DISABLE ) ), + aYesBtn ( this, SVX_RES( BTN_JSCPT_YES ) ), + aNoBtn ( this, SVX_RES( BTN_JSCPT_NO ) ) + +{ + FreeResource(); + + aYesBtn.SetText( Button::GetStandardText( BUTTON_YES ) ); + aNoBtn.SetText( Button::GetStandardText( BUTTON_NO ) ); + aImage.SetImage( WarningBox::GetStandardImage() ); +} + +//#98647#---------------------------------------------- +void SvxScriptExecListBox::RequestHelp( const HelpEvent& rHEvt ) +{ // try to show tips just like as on toolbars + USHORT nPos=LISTBOX_ENTRY_NOTFOUND; + USHORT nTop = GetTopEntry(); + USHORT nCount = GetDisplayLineCount(); // Attention: Not GetLineCount() + Point aPt = ScreenToOutputPixel( rHEvt.GetMousePosPixel() ); + Rectangle aItemRect; + if( nCount > 0 ) // if there're some entries, find it. + for( nPos = nTop ; nPos <= nTop+nCount-1 ; nPos++ ) { + aItemRect = GetBoundingRectangle(nPos); + if( aPt.Y() < aItemRect.Top() || aPt.Y() > aItemRect.Bottom() ) + continue; + else + break; + } + else // if not, nothing happens. + return; + String aHelpText; + if( nPos <= nTop+nCount-1 ) // if find the matching entry, get its content. + aHelpText = GetEntry(nPos); + if( aHelpText.Len() && GetTextWidth(aHelpText)<GetOutputSizePixel().Width() ) + aHelpText.Erase(); // if the entry is quite short, clear the helping tip content. + aItemRect = Rectangle(Point(0,0),GetSizePixel()); + aPt = Point(OutputToScreenPixel( aItemRect.TopLeft() )); + aItemRect.Left() = aPt.X(); + aItemRect.Top() = aPt.Y(); + aPt = OutputToScreenPixel( aItemRect.BottomRight() ); + aItemRect.Right() = aPt.X(); + aItemRect.Bottom() = aPt.Y(); + if( rHEvt.GetMode() == HELPMODE_BALLOON ) + Help::ShowBalloon( this, aItemRect.Center(), aItemRect, aHelpText); + else + Help::ShowQuickHelp( this, aItemRect, aHelpText ); +} + +/********************************************************************/ +/* */ +/* SvxSecurityTabPage */ +/* */ +/********************************************************************/ + +SvxSecurityTabPage::SvxSecurityTabPage( Window* pParent, const SfxItemSet& rSet ) + :SfxTabPage ( pParent, SVX_RES( RID_SVXPAGE_INET_SECURITY ), rSet ) + + ,maSecurityOptionsFL( this, SVX_RES( FL_SEC_SECURITYOPTIONS ) ) + ,maSecurityOptionsFI( this, SVX_RES( FI_SEC_SECURITYOPTIONS ) ) + ,maSecurityOptionsPB( this, SVX_RES( PB_SEC_SECURITYOPTIONS ) ) + + ,maPasswordsFL ( this, SVX_RES( FL_SEC_PASSWORDS ) ) + ,maSavePasswordsCB ( this, SVX_RES( CB_SEC_SAVEPASSWORDS ) ) + ,maShowConnectionsPB( this, SVX_RES( PB_SEC_CONNECTIONS ) ) + ,maMasterPasswordCB ( this, SVX_RES( CB_SEC_MASTERPASSWORD ) ) + ,maMasterPasswordFI ( this, SVX_RES( FI_SEC_MASTERPASSWORD ) ) + ,maMasterPasswordPB ( this, SVX_RES( PB_SEC_MASTERPASSWORD ) ) + + ,maMacroSecFL ( this, SVX_RES( FL_SEC_MACROSEC ) ) + ,maMacroSecFI ( this, SVX_RES( FI_SEC_MACROSEC ) ) + ,maMacroSecPB ( this, SVX_RES( PB_SEC_MACROSEC ) ) + ,maFilesharingFL ( this, SVX_RES( FL_SEC_FILESHARING ) ) + ,maRecommReadOnlyCB ( this, SVX_RES( CB_SEC_RECOMMREADONLY ) ) + ,maRecordChangesCB ( this, SVX_RES( CB_SEC_RECORDCHANGES ) ) + ,maProtectRecordsPB ( this, SVX_RES( PB_SEC_PROTRECORDS ) ) + + ,mpSecOptions ( new SvtSecurityOptions ) + ,mpSecOptDlg ( NULL ) + ,meRedlingMode ( RL_NONE ) + + ,msProtectRecordsStr( SVX_RES( STR_SEC_PROTRECORDS ) ) + ,msUnprotectRecordsStr( SVX_RES( STR_SEC_UNPROTRECORDS ) ) + ,msPasswordStoringDeactivateStr( SVX_RES( STR_SEC_NOPASSWDSAVE ) ) + +{ + FreeResource(); + + InitControls(); + + maSecurityOptionsPB.SetClickHdl( LINK( this, SvxSecurityTabPage, SecurityOptionsHdl ) ); + maSavePasswordsCB.SetClickHdl( LINK( this, SvxSecurityTabPage, SavePasswordHdl ) ); + maMasterPasswordPB.SetClickHdl( LINK( this, SvxSecurityTabPage, MasterPasswordHdl ) ); + maMasterPasswordCB.SetClickHdl( LINK( this, SvxSecurityTabPage, MasterPasswordCBHdl ) ); + maShowConnectionsPB.SetClickHdl( LINK( this, SvxSecurityTabPage, ShowPasswordsHdl ) ); + maMacroSecPB.SetClickHdl( LINK( this, SvxSecurityTabPage, MacroSecPBHdl ) ); + maProtectRecordsPB.SetClickHdl( LINK( this, SvxSecurityTabPage, ProtectRecordsPBHdl ) ); + maRecordChangesCB.SetClickHdl( LINK( this, SvxSecurityTabPage, RecordChangesCBHdl ) ); + + ActivatePage( rSet ); +} + +SvxSecurityTabPage::~SvxSecurityTabPage() +{ + delete mpSecOptions; + delete mpSecOptDlg; +} + +IMPL_LINK( SvxSecurityTabPage, SecurityOptionsHdl, PushButton*, EMPTYARG ) +{ + if ( !mpSecOptDlg ) + mpSecOptDlg = new svx::SecurityOptionsDialog( this, mpSecOptions ); + mpSecOptDlg->Execute(); + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, SavePasswordHdl, void*, EMPTYARG ) +{ + try + { + Reference< task::XMasterPasswordHandling > xMasterPasswd( + comphelper::getProcessServiceFactory()->createInstance( + rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.task.PasswordContainer" ) ) ), + UNO_QUERY_THROW ); + + if ( maSavePasswordsCB.IsChecked() ) + { + sal_Bool bOldValue = xMasterPasswd->allowPersistentStoring( sal_True ); + xMasterPasswd->removeMasterPassword(); + if ( xMasterPasswd->changeMasterPassword( Reference< task::XInteractionHandler >() ) ) + { + maMasterPasswordPB.Enable( TRUE ); + maMasterPasswordCB.Check( TRUE ); + maMasterPasswordCB.Enable( TRUE ); + maMasterPasswordFI.Enable( TRUE ); + maShowConnectionsPB.Enable( TRUE ); + } + else + { + xMasterPasswd->allowPersistentStoring( bOldValue ); + maSavePasswordsCB.Check( FALSE ); + } + } + else + { + QueryBox aQuery( this, WB_YES_NO|WB_DEF_NO, msPasswordStoringDeactivateStr ); + USHORT nRet = aQuery.Execute(); + + if( RET_YES == nRet ) + { + xMasterPasswd->allowPersistentStoring( sal_False ); + maMasterPasswordCB.Check( TRUE ); + maMasterPasswordPB.Enable( FALSE ); + maMasterPasswordCB.Enable( FALSE ); + maMasterPasswordFI.Enable( FALSE ); + maShowConnectionsPB.Enable( FALSE ); + } + else + { + maSavePasswordsCB.Check( TRUE ); + maMasterPasswordPB.Enable( TRUE ); + maShowConnectionsPB.Enable( TRUE ); + } + } + } + catch( Exception& ) + { + maSavePasswordsCB.Check( !maSavePasswordsCB.IsChecked() ); + } + + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, MasterPasswordHdl, PushButton*, EMPTYARG ) +{ + try + { + Reference< task::XMasterPasswordHandling > xMasterPasswd( + comphelper::getProcessServiceFactory()->createInstance( + rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.task.PasswordContainer" ) ) ), + UNO_QUERY ); + + if ( xMasterPasswd.is() && xMasterPasswd->isPersistentStoringAllowed() ) + xMasterPasswd->changeMasterPassword( Reference< task::XInteractionHandler >() ); + } + catch( Exception& ) + {} + + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, MasterPasswordCBHdl, void*, EMPTYARG ) +{ + try + { + Reference< task::XMasterPasswordHandling2 > xMasterPasswd( + comphelper::getProcessServiceFactory()->createInstance( + rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.task.PasswordContainer" ) ) ), + UNO_QUERY_THROW ); + + if ( maMasterPasswordCB.IsChecked() ) + { + if ( xMasterPasswd->isPersistentStoringAllowed() && xMasterPasswd->changeMasterPassword( Reference< task::XInteractionHandler >() ) ) + { + maMasterPasswordPB.Enable( TRUE ); + maMasterPasswordFI.Enable( TRUE ); + } + else + { + maMasterPasswordCB.Check( FALSE ); + maMasterPasswordPB.Enable( TRUE ); + maMasterPasswordFI.Enable( TRUE ); + } + } + else + { + if ( xMasterPasswd->isPersistentStoringAllowed() && xMasterPasswd->useDefaultMasterPassword( Reference< task::XInteractionHandler >() ) ) + { + maMasterPasswordPB.Enable( FALSE ); + maMasterPasswordFI.Enable( FALSE ); + } + else + { + maMasterPasswordCB.Check( TRUE ); + maMasterPasswordPB.Enable( TRUE ); + maShowConnectionsPB.Enable( TRUE ); + } + } + } + catch( Exception& ) + { + maSavePasswordsCB.Check( !maSavePasswordsCB.IsChecked() ); + } + + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, ShowPasswordsHdl, PushButton*, EMPTYARG ) +{ + try + { + Reference< task::XMasterPasswordHandling > xMasterPasswd( + comphelper::getProcessServiceFactory()->createInstance( + rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.task.PasswordContainer" ) ) ), + UNO_QUERY ); + + if ( xMasterPasswd.is() && xMasterPasswd->isPersistentStoringAllowed() && xMasterPasswd->authorizateWithMasterPassword( Reference< task::XInteractionHandler>() ) ) + { + svx::WebConnectionInfoDialog aDlg( this ); + aDlg.Execute(); + } + } + catch( Exception& ) + {} + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, MacroSecPBHdl, void*, EMPTYARG ) +{ + Reference< security::XDocumentDigitalSignatures > xD( + comphelper::getProcessServiceFactory()->createInstance( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.security.DocumentDigitalSignatures" ) ) ), UNO_QUERY ); + if ( xD.is() ) + xD->manageTrustedSources(); + + return 0; +} + +namespace +{ + enum RedlineFunc { RF_ON, RF_PROTECT }; + + const SfxBoolItem* ExecuteRecordChangesFunc( SvxSecurityTabPage::RedliningMode _eMode, RedlineFunc _eFunc, BOOL _bVal, Window* _pParent = NULL ) + { + const SfxBoolItem* pRet = NULL; + + if( _eMode != SvxSecurityTabPage::RL_NONE ) + { + USHORT nSlot; + if ( _eMode == SvxSecurityTabPage::RL_WRITER ) + nSlot = ( _eFunc == RF_ON )? FN_REDLINE_ON : FN_REDLINE_PROTECT; + else + nSlot = ( _eFunc == RF_ON )? FID_CHG_RECORD : SID_CHG_PROTECT; + + // execute + SfxViewShell* pViewSh = SfxViewShell::Current(); + if( pViewSh ) + { + bool bNeedItem = ( _eMode == SvxSecurityTabPage::RL_WRITER || _eFunc != RF_ON ); + SfxBoolItem* pItem = bNeedItem ? new SfxBoolItem( nSlot, _bVal ) : NULL; + SfxDispatcher* pDisp = pViewSh->GetDispatcher(); + if ( _pParent ) + { + OfaPtrItem aParentItem( SID_ATTR_PARENTWINDOW, _pParent ); + pRet = static_cast< const SfxBoolItem* >( + pDisp->Execute( nSlot, SFX_CALLMODE_SYNCHRON, &aParentItem, pItem, 0L ) ); + } + else + pRet = static_cast< const SfxBoolItem* >( + pDisp->Execute( nSlot, SFX_CALLMODE_SYNCHRON, pItem, 0L ) ); + delete pItem; + } + } + + return pRet; + } + + bool QueryState( USHORT _nSlot, bool& _rValue ) + { + bool bRet = false; + + SfxViewShell* pViewSh = SfxViewShell::Current(); + if( pViewSh ) + { + const SfxPoolItem* pItem; + SfxDispatcher* pDisp = pViewSh->GetDispatcher(); + bRet = SFX_ITEM_AVAILABLE <= pDisp->QueryState( _nSlot, pItem ); + if( bRet ) + _rValue = ( static_cast< const SfxBoolItem* >( pItem ) )->GetValue(); + } + + return bRet; + } + + bool QueryRecordChangesProtectionState( SvxSecurityTabPage::RedliningMode _eMode, bool& _rValue ) + { + bool bRet = false; + + if( _eMode != SvxSecurityTabPage::RL_NONE ) + { + USHORT nSlot = ( _eMode == SvxSecurityTabPage::RL_WRITER )? FN_REDLINE_PROTECT : SID_CHG_PROTECT; + bRet = QueryState( nSlot, _rValue ); + } + + return bRet; + } + + bool QueryRecordChangesState( SvxSecurityTabPage::RedliningMode _eMode, bool& _rValue ) + { + bool bRet = false; + + if( _eMode != SvxSecurityTabPage::RL_NONE ) + { + USHORT nSlot = ( _eMode == SvxSecurityTabPage::RL_WRITER )? FN_REDLINE_ON : FID_CHG_RECORD; + bRet = QueryState( nSlot, _rValue ); + } + + return bRet; + } +} + +IMPL_LINK( SvxSecurityTabPage, RecordChangesCBHdl, void*, EMPTYARG ) +{ + ExecuteRecordChangesFunc( meRedlingMode, RF_ON, maRecordChangesCB.IsChecked(), this ); + CheckRecordChangesState(); + return 0; +} + +IMPL_LINK( SvxSecurityTabPage, ProtectRecordsPBHdl, void*, EMPTYARG ) +{ + bool bProt; + QueryRecordChangesProtectionState( meRedlingMode, bProt ); + ExecuteRecordChangesFunc( meRedlingMode, RF_PROTECT, !bProt, this ); + CheckRecordChangesState(); + + if ( QueryRecordChangesProtectionState( meRedlingMode, bProt ) ) + { + // RecordChangesCB is enabled if protection is off + maRecordChangesCB.Enable( !bProt ); + // toggle text of button "Protect" <-> "Unprotect" + String sNewText = bProt ? msUnprotectRecordsStr : msProtectRecordsStr; + maProtectRecordsPB.SetText( sNewText ); + } + return 0; +} + +void SvxSecurityTabPage::CheckRecordChangesState( void ) +{ + bool bVal; + if( QueryRecordChangesState( meRedlingMode, bVal ) ) + { + maRecordChangesCB.Enable(); + maRecordChangesCB.Check( bVal ); + } + else + maRecordChangesCB.Disable(); // because now we don't know the state! + + maProtectRecordsPB.Enable( QueryRecordChangesProtectionState( meRedlingMode, bVal ) ); +} + +void SvxSecurityTabPage::InitControls() +{ + // Hide all controls which belong to the macro security button in case the macro + // security settings managed by the macro security dialog opened via the button + // are all readonly or if the macros are disabled in general. + // @@@ Better would be to query the dialog whether it is 'useful' or not. Exposing + // macro security dialog implementations here, which is bad. + if ( mpSecOptions->IsMacroDisabled() + || ( mpSecOptions->IsReadOnly( SvtSecurityOptions::E_MACRO_SECLEVEL ) + && mpSecOptions->IsReadOnly( SvtSecurityOptions::E_MACRO_TRUSTEDAUTHORS ) + && mpSecOptions->IsReadOnly( SvtSecurityOptions::E_SECUREURLS ) ) ) + { + maMacroSecFL.Hide(); + maMacroSecFI.Hide(); + maMacroSecPB.Hide(); + + // rearrange the following controls + Point aNewPos = maFilesharingFL.GetPosPixel(); + long nDelta = aNewPos.Y() - maMacroSecFL.GetPosPixel().Y(); + + Window* pWins[] = + { + &maFilesharingFL, &maRecommReadOnlyCB, &maRecordChangesCB, &maProtectRecordsPB + }; + Window** pCurrent = pWins; + const sal_Int32 nCount = sizeof( pWins ) / sizeof( pWins[ 0 ] ); + for ( sal_Int32 i = 0; i < nCount; ++i, ++pCurrent ) + { + aNewPos = (*pCurrent)->GetPosPixel(); + aNewPos.Y() -= nDelta; + (*pCurrent)->SetPosPixel( aNewPos ); + } + } + + // one button too small for its text? + sal_Int32 i = 0; + long nBtnTextWidth = 0; + Window* pButtons[] = { &maSecurityOptionsPB, &maMasterPasswordPB, + &maShowConnectionsPB, &maMacroSecPB, &maProtectRecordsPB }; + Window** pButton = pButtons; + const sal_Int32 nBCount = sizeof( pButtons ) / sizeof( pButtons[ 0 ] ); + for ( ; i < nBCount; ++i, ++pButton ) + { + long nTemp = (*pButton)->GetCtrlTextWidth( (*pButton)->GetText() ); + if ( nTemp > nBtnTextWidth ) + nBtnTextWidth = nTemp; + } + + nBtnTextWidth = nBtnTextWidth * 115 / 100; // a little offset + const long nButtonWidth = maSecurityOptionsPB.GetSizePixel().Width(); + const long nMaxWidth = nButtonWidth * 140 / 100; + long nExtra = ( nBtnTextWidth > nMaxWidth ) ? nBtnTextWidth - nMaxWidth : 0; + nBtnTextWidth = std::min( nBtnTextWidth, nMaxWidth ); + + if ( nBtnTextWidth > nButtonWidth ) + { + // so make the buttons broader and its control in front of it smaller + long nDelta = nBtnTextWidth - nButtonWidth; + pButton = pButtons; + + if ( nExtra > 0 ) + { + long nPos = (*pButton)->GetPosPixel().X() - nDelta; + long nWidth = (*pButton)->GetSizePixel().Width() + nDelta; + long nMaxExtra = GetOutputSizePixel().Width() - ( nPos + nWidth ) - 2; + nExtra = ( nExtra < nMaxExtra ) ? nExtra : nMaxExtra; + } + + for ( i = 0; i < nBCount; ++i, ++pButton ) + { + Point aNewPos = (*pButton)->GetPosPixel(); + aNewPos.X() -= nDelta; + Size aNewSize = (*pButton)->GetSizePixel(); + aNewSize.Width() += ( nDelta + nExtra ); + (*pButton)->SetPosSizePixel( aNewPos, aNewSize ); + } + + Window* pControls[] = { &maSecurityOptionsFI, &maSavePasswordsCB, + &maMasterPasswordFI, &maMacroSecFI, + &maRecommReadOnlyCB, &maRecordChangesCB }; + Window** pControl = pControls; + const sal_Int32 nCCount = sizeof( pControls ) / sizeof( pControls[ 0 ] ); + for ( i = 0; i < nCCount; ++i, ++pControl ) + { + Size aNewSize = (*pControl)->GetSizePixel(); + aNewSize.Width() -= nDelta; + (*pControl)->SetSizePixel( aNewSize ); + } + } + + maMasterPasswordPB.Enable( FALSE ); + maMasterPasswordCB.Enable( FALSE ); + maMasterPasswordCB.Check( TRUE ); + maMasterPasswordFI.Enable( FALSE ); + maShowConnectionsPB.Enable( FALSE ); + + // initialize the password saving checkbox + try + { + Reference< task::XMasterPasswordHandling > xMasterPasswd( + comphelper::getProcessServiceFactory()->createInstance( + rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.task.PasswordContainer" ) ) ), + UNO_QUERY_THROW ); + + if ( xMasterPasswd->isPersistentStoringAllowed() ) + { + maMasterPasswordCB.Enable( TRUE ); + maShowConnectionsPB.Enable( TRUE ); + maSavePasswordsCB.Check( TRUE ); + + Reference< task::XMasterPasswordHandling2 > xMasterPasswd2( xMasterPasswd, UNO_QUERY ); + if ( xMasterPasswd2.is() && xMasterPasswd2->isDefaultMasterPasswordUsed() ) + maMasterPasswordCB.Check( FALSE ); + else + { + maMasterPasswordPB.Enable( TRUE ); + maMasterPasswordCB.Check( TRUE ); + maMasterPasswordFI.Enable( TRUE ); + } + } + } + catch( Exception& ) + { + maSavePasswordsCB.Enable( FALSE ); + } + + +} + +SfxTabPage* SvxSecurityTabPage::Create(Window* pParent, const SfxItemSet& rAttrSet ) +{ + return new SvxSecurityTabPage(pParent, rAttrSet); +} + +void SvxSecurityTabPage::ActivatePage( const SfxItemSet& ) +{ +} + +int SvxSecurityTabPage::DeactivatePage( SfxItemSet* _pSet ) +{ + if( _pSet ) + FillItemSet( *_pSet ); + return LEAVE_PAGE; +} + +namespace +{ +/* bool Enable( const SvtSecurityOptions& _rOpt, SvtSecurityOptions::EOption _eOpt, Control& _rCtrl, FixedImage& _rImg ) + { + bool b = _rOpt.IsOptionEnabled( _eOpt ); + _rCtrl.Enable( b ); + _Img.Show( !b ); + return b; + } +*/ + bool EnableAndSet( const SvtSecurityOptions& _rOpt, SvtSecurityOptions::EOption _eOpt, + CheckBox& _rCtrl, FixedImage& _rImg ) + { +// bool b = Enable( _rOpt, _eOpt, _rCtrl, _rImg ); + bool b = _rOpt.IsOptionEnabled( _eOpt ); + _rCtrl.Enable( b ); + _rImg.Show( !b ); + _rCtrl.Check( _rOpt.IsOptionSet( _eOpt ) ); + return b; + } + + bool CheckAndSave( SvtSecurityOptions& _rOpt, SvtSecurityOptions::EOption _eOpt, const bool _bIsChecked, bool& _rModfied ) + { + bool bModified = false; + if ( _rOpt.IsOptionEnabled( _eOpt ) ) + { + bModified = _rOpt.IsOptionSet( _eOpt ) != _bIsChecked; + if ( bModified ) + { + _rOpt.SetOption( _eOpt, _bIsChecked ); + _rModfied = true; + } + } + + return bModified; + } +} + +BOOL SvxSecurityTabPage::FillItemSet( SfxItemSet& ) +{ + bool bModified = false; + + if ( mpSecOptDlg ) + { + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_SAVEORSEND, mpSecOptDlg->IsSaveOrSendDocsChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_SIGNING, mpSecOptDlg->IsSignDocsChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_PRINT, mpSecOptDlg->IsPrintDocsChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_CREATEPDF, mpSecOptDlg->IsCreatePdfChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_REMOVEPERSONALINFO, mpSecOptDlg->IsRemovePersInfoChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_DOCWARN_RECOMMENDPASSWORD, mpSecOptDlg->IsRecommPasswdChecked(), bModified ); + CheckAndSave( *mpSecOptions, SvtSecurityOptions::E_CTRLCLICK_HYPERLINK, mpSecOptDlg->IsCtrlHyperlinkChecked(), bModified ); + } + + // document options + SfxObjectShell* pCurDocShell = SfxObjectShell::Current(); + if( pCurDocShell ) + { + if( pCurDocShell->HasSecurityOptOpenReadOnly() ) + pCurDocShell->SetSecurityOptOpenReadOnly( maRecommReadOnlyCB.IsChecked() ); + + } + + return bModified; +} + +/*--------------------------------------------------------------------*/ + +void SvxSecurityTabPage::Reset( const SfxItemSet& ) +{ + String sNewText = msProtectRecordsStr; + SfxObjectShell* pCurDocShell = SfxObjectShell::Current(); + if( pCurDocShell ) + { + bool bIsHTMLDoc = false; + SfxViewShell* pViewSh = SfxViewShell::Current(); + if( pViewSh ) + { + const SfxPoolItem* pItem; + SfxDispatcher* pDisp = pViewSh->GetDispatcher(); + if ( SFX_ITEM_AVAILABLE <= pDisp->QueryState( SID_HTML_MODE, pItem ) ) + { + USHORT nMode = static_cast< const SfxUInt16Item* >( pItem )->GetValue(); + bIsHTMLDoc = ( ( nMode & HTMLMODE_ON ) != 0 ); + } + } + + sal_Bool bIsReadonly = pCurDocShell->IsReadOnly(); + if( pCurDocShell->HasSecurityOptOpenReadOnly() && !bIsHTMLDoc ) + { + maRecommReadOnlyCB.Check( pCurDocShell->IsSecurityOptOpenReadOnly() ); + maRecommReadOnlyCB.Enable( !bIsReadonly ); + } + else + maRecommReadOnlyCB.Disable(); + + bool bVal; + if ( QueryRecordChangesState( RL_WRITER, bVal ) && !bIsHTMLDoc ) + meRedlingMode = RL_WRITER; + else if( QueryRecordChangesState( RL_CALC, bVal ) ) + meRedlingMode = RL_CALC; + else + meRedlingMode = RL_NONE; + + if ( meRedlingMode != RL_NONE ) + { + maRecordChangesCB.Check( bVal ); + maRecordChangesCB.Enable( !bVal && !bIsReadonly ); + maProtectRecordsPB.Enable( + QueryRecordChangesProtectionState( meRedlingMode, bVal ) && !bIsReadonly ); + // set the right text + if ( bVal ) + sNewText = msUnprotectRecordsStr; + } + else + { + // only Writer and Calc support redlining + maRecordChangesCB.Disable(); + maProtectRecordsPB.Disable(); + } + } + else + { // no doc -> hide document settings + maRecommReadOnlyCB.Disable(); + maRecordChangesCB.Disable(); + maProtectRecordsPB.Disable(); + } + + maProtectRecordsPB.SetText( sNewText ); +} + +//added by jmeng begin +MozPluginTabPage::MozPluginTabPage(Window* pParent, const SfxItemSet& rSet) + : SfxTabPage( pParent, SVX_RES( RID_SVXPAGE_INET_MOZPLUGIN ), rSet ), + aMSWordGB ( this, SVX_RES( GB_MOZPLUGIN ) ), + aWBasicCodeCB ( this, SVX_RES( CB_MOZPLUGIN_CODE ) ) +{ + FreeResource(); +} + +MozPluginTabPage::~MozPluginTabPage() +{ +} + +SfxTabPage* MozPluginTabPage::Create( Window* pParent, + const SfxItemSet& rAttrSet ) +{ + return new MozPluginTabPage( pParent, rAttrSet ); +} +BOOL MozPluginTabPage::FillItemSet( SfxItemSet& ) +{ + BOOL hasInstall = isInstalled(); + BOOL hasChecked = aWBasicCodeCB.IsChecked(); + if(hasInstall && (!hasChecked)){ + //try to uninstall + uninstallPlugin(); + } + else if((!hasInstall) && hasChecked){ + //try to install + installPlugin(); + } + else{ + // do nothing + } + return TRUE; +} +void MozPluginTabPage::Reset( const SfxItemSet& ) +{ + aWBasicCodeCB.Check( isInstalled()); + aWBasicCodeCB.SaveValue(); +} + +#ifdef WNT +extern "C" { + int lc_isInstalled(const char* realFilePath); + int lc_installPlugin(const char* realFilePath); + int lc_uninstallPlugin(const char* realFilePath); +} +#endif + +#define NPP_PATH_MAX 2048 +inline bool getDllURL(rtl::OString * path) +{ + OSL_ASSERT(path != NULL); + ::rtl::OUString dirPath/*dllPath, */; + if (osl_getExecutableFile(&dirPath.pData) != osl_Process_E_None) { + return false; + } + dirPath = dirPath.copy(0, dirPath.lastIndexOf('/')); +// osl::FileBase::getAbsoluteFileURL(dirPath, libPath, dllPath); + ::rtl::OUString sysDirPath; + osl::FileBase::getSystemPathFromFileURL(dirPath, sysDirPath); + *path = OUStringToOString(sysDirPath, RTL_TEXTENCODING_ASCII_US); + return true; +} + +BOOL MozPluginTabPage::isInstalled() +{ +#ifdef UNIX + // get the real file referred by .so lnk file + char lnkFilePath[NPP_PATH_MAX] = {0}; + char lnkReferFilePath[NPP_PATH_MAX] = {0}; + char* pHome = getpwuid(getuid())->pw_dir; + strcat(lnkFilePath, pHome); + strcat(lnkFilePath, "/.mozilla/plugins/libnpsoplugin" SAL_DLLEXTENSION); + + struct stat sBuf; + if (0 > lstat(lnkFilePath, &sBuf)) + return false; + if (!S_ISLNK(sBuf.st_mode)) + return false; + if (0 >= readlink(lnkFilePath, lnkReferFilePath, NPP_PATH_MAX)) + return false; + // If the link is relative, then we regard it as non-standard + if (lnkReferFilePath[0] != '/') + return false; + + // get the real file path + char realFilePath[NPP_PATH_MAX] = {0}; + ::rtl::OString tempString; + if (!getDllURL(&tempString)) { + return false; + } + strncpy(realFilePath, tempString.getStr(), NPP_PATH_MAX); + strcat(realFilePath, "/libnpsoplugin" SAL_DLLEXTENSION); + + if (0 != strcmp(lnkReferFilePath, realFilePath)) + return false; + return true; +#endif +#ifdef WNT + // get the value from registry + BOOL ret = true; + ::rtl::OString tempString; + char realFilePath[NPP_PATH_MAX] = {0}; + if (!getDllURL(&tempString)){ + return false; + } + strncpy(realFilePath, tempString.getStr(), NPP_PATH_MAX); + if(! lc_isInstalled(realFilePath)) + ret =true; + else + ret = false; + return ret; +#endif +} + +BOOL MozPluginTabPage::installPlugin() +{ +#ifdef UNIX + // get the real file referred by .so lnk file + char lnkFilePath[NPP_PATH_MAX] = {0}; + char* pHome = getpwuid(getuid())->pw_dir; + strcat(lnkFilePath, pHome); + strcat(lnkFilePath, "/.mozilla/plugins/libnpsoplugin" SAL_DLLEXTENSION); + remove(lnkFilePath); + + // create the dirs if necessary + struct stat buf; + char tmpDir[NPP_PATH_MAX] = {0}; + sprintf(tmpDir, "%s/.mozilla", pHome); + if (0 > stat(lnkFilePath, &buf)) + { + mkdir(tmpDir, 0755); + strcat(tmpDir, "/plugins"); + mkdir(tmpDir, 0755); + } + + // get the real file path + char realFilePath[NPP_PATH_MAX] = {0}; + ::rtl::OString tempString; + if (!getDllURL(&tempString)) { + return false; + } + strncpy(realFilePath, tempString.getStr(), NPP_PATH_MAX); + strcat(realFilePath, "/libnpsoplugin" SAL_DLLEXTENSION); + + // create the link + if (0 != symlink(realFilePath, lnkFilePath)) + return false; + return true; +#endif +#ifdef WNT + ::rtl::OString tempString; + char realFilePath[NPP_PATH_MAX] = {0}; + if (!getDllURL(&tempString)) { + return false; + } + strncpy(realFilePath, tempString.getStr(), NPP_PATH_MAX); + if( !lc_installPlugin(realFilePath)) + return true; + else + return false; +#endif +} + +BOOL MozPluginTabPage::uninstallPlugin() +{ +#ifdef UNIX + // get the real file referred by .so lnk file + char lnkFilePath[NPP_PATH_MAX] = {0}; + char* pHome = getpwuid(getuid())->pw_dir; + strcat(lnkFilePath, pHome); + strcat(lnkFilePath, "/.mozilla/plugins/libnpsoplugin" SAL_DLLEXTENSION); + + if(0 > remove(lnkFilePath)) + return false; + return true; +#endif +#ifdef WNT + ::rtl::OString tempString; + char realFilePath[NPP_PATH_MAX] = {0}; + if (!getDllURL(&tempString)) { + return false; + } + strncpy(realFilePath, tempString.getStr(), NPP_PATH_MAX); + if(!lc_uninstallPlugin(realFilePath)) + return true; + else + return false; +#endif +} +//added by jmeng end + +/* -------------------------------------------------------------------------*/ + +class MailerProgramCfg_Impl : public utl::ConfigItem +{ + friend class SvxEMailTabPage; + // variables + OUString sProgram; + // readonly states + sal_Bool bROProgram; + + const Sequence<OUString> GetPropertyNames(); +public: + MailerProgramCfg_Impl(); + virtual ~MailerProgramCfg_Impl(); + + virtual void Commit(); + virtual void Notify( const com::sun::star::uno::Sequence< rtl::OUString >& _rPropertyNames); +}; + +/* -------------------------------------------------------------------------*/ + +MailerProgramCfg_Impl::MailerProgramCfg_Impl() : + utl::ConfigItem(C2U("Office.Common/ExternalMailer")), + bROProgram(sal_False) +{ + const Sequence< OUString > aNames = GetPropertyNames(); + const Sequence< Any > aValues = GetProperties(aNames); + const Sequence< sal_Bool > aROStates = GetReadOnlyStates(aNames); + const Any* pValues = aValues.getConstArray(); + const sal_Bool* pROStates = aROStates.getConstArray(); + for(sal_Int32 nProp = 0; nProp < aValues.getLength(); nProp++) + { + if(pValues[nProp].hasValue()) + { + switch(nProp) + { + case 0 : + { + pValues[nProp] >>= sProgram; + bROProgram = pROStates[nProp]; + } + break; + } + } + } +} + +/* -------------------------------------------------------------------------*/ + +MailerProgramCfg_Impl::~MailerProgramCfg_Impl() +{ +} + +/* -------------------------------------------------------------------------*/ + +const Sequence<OUString> MailerProgramCfg_Impl::GetPropertyNames() +{ + Sequence<OUString> aRet(1); + OUString* pRet = aRet.getArray(); + pRet[0] = C2U("Program"); + return aRet; +} + +/* -------------------------------------------------------------------------*/ + +void MailerProgramCfg_Impl::Commit() +{ + const Sequence< OUString > aOrgNames = GetPropertyNames(); + sal_Int32 nOrgCount = aOrgNames.getLength(); + + Sequence< OUString > aNames(nOrgCount); + Sequence< Any > aValues(nOrgCount); + sal_Int32 nRealCount = 0; + + for(int nProp = 0; nProp < nOrgCount; nProp++) + { + switch(nProp) + { + case 0: + { + if (!bROProgram) + { + aNames[nRealCount] = aOrgNames[nProp]; + aValues[nRealCount] <<= sProgram; + ++nRealCount; + } + } + break; + } + } + + aNames.realloc(nRealCount); + aValues.realloc(nRealCount); + PutProperties(aNames, aValues); +} + +void MailerProgramCfg_Impl::Notify( const com::sun::star::uno::Sequence< rtl::OUString >& ) +{ +} + +/* -------------------------------------------------------------------------*/ + +struct SvxEMailTabPage_Impl +{ + MailerProgramCfg_Impl aMailConfig; +}; + +SvxEMailTabPage::SvxEMailTabPage(Window* pParent, const SfxItemSet& rSet) : + SfxTabPage(pParent, SVX_RES( RID_SVXPAGE_INET_MAIL ), rSet), + aMailFL(this, SVX_RES(FL_MAIL )), + aMailerURLFI(this, SVX_RES(FI_MAILERURL )), + aMailerURLFT(this, SVX_RES(FT_MAILERURL )), + aMailerURLED(this, SVX_RES(ED_MAILERURL )), + aMailerURLPB(this, SVX_RES(PB_MAILERURL )), + m_sDefaultFilterName( SVX_RES(STR_DEFAULT_FILENAME )), + pImpl(new SvxEMailTabPage_Impl) +{ + FreeResource(); + + aMailerURLPB.SetClickHdl( LINK( this, SvxEMailTabPage, FileDialogHdl_Impl ) ); + + // FixedText not wide enough? + long nTxtW = aMailerURLFT.GetCtrlTextWidth( aMailerURLFT.GetText() ); + long nCtrlW = aMailerURLFT.GetSizePixel().Width(); + if ( nTxtW >= nCtrlW ) + { + long nDelta = Max( (long)10, nTxtW - nCtrlW ); + // so FixedText wider + Size aNewSz = aMailerURLFT.GetSizePixel(); + aNewSz.Width() += nDelta; + aMailerURLFT.SetSizePixel( aNewSz ); + // and Edit smaller + aNewSz = aMailerURLED.GetSizePixel(); + aNewSz.Width() -= nDelta; + Point aNewPt = aMailerURLED.GetPosPixel(); + aNewPt.X() += nDelta; + aMailerURLED.SetPosSizePixel( aNewPt, aNewSz ); + } +} + +/* -------------------------------------------------------------------------*/ + +SvxEMailTabPage::~SvxEMailTabPage() +{ + delete pImpl; +} + +/* -------------------------------------------------------------------------*/ + +SfxTabPage* SvxEMailTabPage::Create( Window* pParent, const SfxItemSet& rAttrSet ) +{ + return new SvxEMailTabPage(pParent, rAttrSet); +} + +/* -------------------------------------------------------------------------*/ + +BOOL SvxEMailTabPage::FillItemSet( SfxItemSet& ) +{ + BOOL bMailModified = FALSE; + if(!pImpl->aMailConfig.bROProgram && aMailerURLED.GetSavedValue() != aMailerURLED.GetText()) + { + pImpl->aMailConfig.sProgram = aMailerURLED.GetText(); + bMailModified = TRUE; + } + if ( bMailModified ) + pImpl->aMailConfig.Commit(); + + return FALSE; +} + +/* -------------------------------------------------------------------------*/ + +void SvxEMailTabPage::Reset( const SfxItemSet& ) +{ + aMailerURLED.Enable(TRUE ); + aMailerURLPB.Enable(TRUE ); + + if(pImpl->aMailConfig.bROProgram) + aMailerURLFI.Show(); + + aMailerURLED.SetText(pImpl->aMailConfig.sProgram); + aMailerURLED.SaveValue(); + aMailerURLED.Enable(!pImpl->aMailConfig.bROProgram); + aMailerURLPB.Enable(!pImpl->aMailConfig.bROProgram); + aMailerURLFT.Enable(!pImpl->aMailConfig.bROProgram); + + aMailFL.Enable(aMailerURLFT.IsEnabled() || + aMailerURLED.IsEnabled() || + aMailerURLPB.IsEnabled()); +} + +/* -------------------------------------------------------------------------*/ + +IMPL_LINK( SvxEMailTabPage, FileDialogHdl_Impl, PushButton*, pButton ) +{ + if ( &aMailerURLPB == pButton && !pImpl->aMailConfig.bROProgram ) + { + FileDialogHelper aHelper( + com::sun::star::ui::dialogs::TemplateDescription::FILEOPEN_SIMPLE, + WB_OPEN ); + String sPath = aMailerURLED.GetText(); + if ( !sPath.Len() ) + sPath.AppendAscii("/usr/bin"); + + String sUrl; + ::utl::LocalFileHelper::ConvertPhysicalNameToURL(sPath,sUrl); + aHelper.SetDisplayDirectory(sUrl); + aHelper.AddFilter( m_sDefaultFilterName, String::CreateFromAscii("*")); + + if ( ERRCODE_NONE == aHelper.Execute() ) + { + sUrl = aHelper.GetPath(); + ::utl::LocalFileHelper::ConvertURLToPhysicalName(sUrl,sPath); + aMailerURLED.SetText(sPath); + } + } + return 0; +} + +// ----------------------------------------------------------------------------- |