diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | 460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch) | |
tree | 67208f7c145782a7e90b123b982ca78d88cc2c87 /kresources/lib/kcal_resourcegroupwarebaseconfig.cpp | |
download | tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kresources/lib/kcal_resourcegroupwarebaseconfig.cpp')
-rw-r--r-- | kresources/lib/kcal_resourcegroupwarebaseconfig.cpp | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/kresources/lib/kcal_resourcegroupwarebaseconfig.cpp b/kresources/lib/kcal_resourcegroupwarebaseconfig.cpp new file mode 100644 index 000000000..2b4bc81be --- /dev/null +++ b/kresources/lib/kcal_resourcegroupwarebaseconfig.cpp @@ -0,0 +1,137 @@ +/* + This file is part of kdepim. + + Copyright (c) 2004 Cornelius Schumacher <schumacher@kde.org> + Copyright (c) 2004 Till Adam <adam@kde.org> + Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +*/ + +#include "kcal_resourcegroupwarebaseconfig.h" + +#include "kcal_cachesettingsdlg.h" +#include "kcal_resourcegroupwarebase.h" +#include "kresources_groupwareprefs.h" +#include "folderconfig.h" + +#include <libkcal/resourcecachedconfig.h> + +#include <klocale.h> +#include <kdebug.h> +#include <klineedit.h> +#include <kdialog.h> +#include <kpushbutton.h> + +#include <qlabel.h> +#include <qlayout.h> +#include <qhbox.h> + + +using namespace KCal; + +ResourceGroupwareBaseConfig::ResourceGroupwareBaseConfig( QWidget* parent, + const char* name ) + : KRES::ConfigWidget( parent, name ) +{ + resize( 245, 115 ); + + QGridLayout *mainLayout = new QGridLayout( this, 2, 2 ); + mainLayout->setSpacing( KDialog::spacingHint() ); + + QLabel *label = new QLabel( i18n("URL:"), this ); + mainLayout->addWidget( label, 1, 0 ); + mUrl = new KLineEdit( this ); + mainLayout->addWidget( mUrl, 1, 1 ); + + label = new QLabel( i18n("User:"), this ); + mainLayout->addWidget( label, 2, 0 ); + mUserEdit = new KLineEdit( this ); + mainLayout->addWidget( mUserEdit, 2, 1 ); + + label = new QLabel( i18n("Password:"), this ); + mainLayout->addWidget( label, 3, 0 ); + mPasswordEdit = new KLineEdit( this ); + mainLayout->addWidget( mPasswordEdit, 3, 1 ); + mPasswordEdit->setEchoMode( KLineEdit::Password ); + + mFolderConfig = new KPIM::FolderConfig( this ); + connect( mFolderConfig, SIGNAL( updateFoldersClicked() ), + SLOT( updateFolders() ) ); + mainLayout->addMultiCellWidget( mFolderConfig, 4, 4, 0, 1 ); + + QHBox *hBox = new QHBox( this ); + mCacheSettingsButton = new KPushButton( i18n("Configure Cache Settings..."), hBox ); + mainLayout->addMultiCellWidget( hBox, 5, 5, 0, 1 ); + connect( mCacheSettingsButton, SIGNAL( clicked() ), + SLOT( showCacheSettings() ) ); + + mCacheDialog = new CacheSettingsDialog( this ); +} + +void ResourceGroupwareBaseConfig::loadSettings( KRES::Resource *resource ) +{ + kdDebug(7000) << "KCal::ResourceGroupwareBaseConfig::loadSettings()" << endl; + + ResourceGroupwareBase *res = static_cast<ResourceGroupwareBase *>( resource ); + if ( res ) { + if ( !res->prefs() ) { + kdError() << "No PREF" << endl; + return; + } + + mUrl->setText( res->prefs()->url() ); + mUserEdit->setText( res->prefs()->user() ); + mPasswordEdit->setText( res->prefs()->password() ); + if ( mCacheDialog ) mCacheDialog->loadSettings( res ); + + mFolderConfig->setFolderLister( res->folderLister() ); + mFolderConfig->updateFolderList(); + } else { + kdError(5700) << "KCalResourceGroupwareBaseConfig::loadSettings(): " + "no KCalOpenGroupware, cast failed" << endl; + } +} + +void ResourceGroupwareBaseConfig::saveSettings( KRES::Resource *resource ) +{ + ResourceGroupwareBase *res = static_cast<ResourceGroupwareBase*>( resource ); + if ( res ) { + res->prefs()->setUrl( mUrl->text() ); + res->prefs()->setUser( mUserEdit->text() ); + res->prefs()->setPassword( mPasswordEdit->text() ); + if ( mCacheDialog ) mCacheDialog->saveSettings( res ); + mFolderConfig->saveSettings(); + } else { + kdError(5700) << "KCalResourceGroupwareBaseConfig::saveSettings(): " + "no KCalOpenGroupware, cast failed" << endl; + } +} + +void ResourceGroupwareBaseConfig::updateFolders() +{ + KURL url = mUrl->text(); + url.setUser( mUserEdit->text() ); + url.setPass( mPasswordEdit->text() ); + + mFolderConfig->retrieveFolderList( url ); +} + +void ResourceGroupwareBaseConfig::showCacheSettings() +{ + if ( mCacheDialog ) mCacheDialog->exec(); +} + +#include "kcal_resourcegroupwarebaseconfig.moc" |