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/groupwise/kcal_resourcegroupwiseconfig.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/groupwise/kcal_resourcegroupwiseconfig.cpp')
-rw-r--r-- | kresources/groupwise/kcal_resourcegroupwiseconfig.cpp | 176 |
1 files changed, 176 insertions, 0 deletions
diff --git a/kresources/groupwise/kcal_resourcegroupwiseconfig.cpp b/kresources/groupwise/kcal_resourcegroupwiseconfig.cpp new file mode 100644 index 000000000..29741d201 --- /dev/null +++ b/kresources/groupwise/kcal_resourcegroupwiseconfig.cpp @@ -0,0 +1,176 @@ +/* + This file is part of kdepim. + + Copyright (c) 2004 Cornelius Schumacher <schumacher@kde.org> + + 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 <typeinfo> + +#include <qlabel.h> +#include <qlayout.h> +#include <qcheckbox.h> + +#include <klocale.h> +#include <klistview.h> +#include <kdebug.h> +#include <kdialogbase.h> +#include <kstandarddirs.h> +#include <klineedit.h> + +#include <libkcal/resourcecachedconfig.h> + +#include "kcal_resourcegroupwise.h" +#include "kcal_groupwiseprefs.h" +#include "kcal_resourcegroupwiseconfig.h" +#include "groupwisesettingswidget.h" +#include "soap/soapH.h" + +using namespace KCal; + +ResourceGroupwiseConfig::ResourceGroupwiseConfig( QWidget* parent, const char* name ) + : KRES::ConfigWidget( parent, name ) +{ + resize( 245, 115 ); + QGridLayout *mainLayout = new QGridLayout( this, 2, 2 ); + + 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 ); + + QPushButton *settingsButton = new QPushButton( i18n( "View User Settings" ), this ); + mainLayout->addMultiCellWidget( settingsButton, 4, 4, 0, 1 ); + + mReloadConfig = new KCal::ResourceCachedReloadConfig( this ); + mainLayout->addMultiCellWidget( mReloadConfig, 5, 5, 0, 1 ); + + mSaveConfig = new KCal::ResourceCachedSaveConfig( this ); + mainLayout->addMultiCellWidget( mSaveConfig, 6, 6, 0, 1 ); + + settingsButton->hide(); + // connect( settingsButton, SIGNAL( clicked() ), SLOT( slotViewUserSettings() ) ); + +} + +void ResourceGroupwiseConfig::loadSettings( KRES::Resource *resource ) +{ + kdDebug() << "KCal::ResourceGroupwiseConfig::loadSettings()" << endl; + ResourceGroupwise *res = static_cast<ResourceGroupwise *>( resource ); + mResource = res; + + 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() ); + mReloadConfig->loadSettings( res ); + mSaveConfig->loadSettings( res ); + } else { + kdError(5700) << "KCalResourceGroupwiseConfig::loadSettings(): no KCalResourceGroupwise, cast failed" << endl; + } +} + +void ResourceGroupwiseConfig::saveSettings( KRES::Resource *resource ) +{ + ResourceGroupwise *res = static_cast<ResourceGroupwise*>( resource ); + if ( res ) { + res->prefs()->setUrl( mUrl->text() ); + res->prefs()->setUser( mUserEdit->text() ); + res->prefs()->setPassword( mPasswordEdit->text() ); + mReloadConfig->saveSettings( res ); + mSaveConfig->saveSettings( res ); + } else { + kdError(5700) << "KCalResourceGroupwiseConfig::saveSettings(): no KCalResourceGroupwise, cast failed" << endl; + } +} + +void ResourceGroupwiseConfig::slotViewUserSettings() +{ + kdDebug(5700) << "KCal::ResourceGroupwiseConfig::slotViewUserSettings()" << endl; + if ( mResource ) + { + ngwt__Settings * s; + mResource->userSettings( s ); + + if ( s ) + { + KDialogBase * dialog = new KDialogBase( ::qt_cast<QWidget*>(parent() ), "gwsettingswidget", true, i18n( "GroupWise Settings" ) ); +// QVBoxLayout * layout = new QVBoxLayout( dialog ); + GroupWiseSettingsWidget * settingsWidget = new GroupWiseSettingsWidget( dialog ); + dialog->setMainWidget( settingsWidget ); + // populate dialog + kdDebug() << "slotViewUserSettings() - settings are: " << endl; + std::vector<class ngwt__SettingsGroup *>::const_iterator it; + for( it = s->group.begin(); it != s->group.end(); ++it ) + { + ngwt__SettingsGroup * group = *it; + QString groupName; + if ( group->type ) + { + groupName = QString::fromUtf8( group->type->c_str() ); + kdDebug() << "GROUP: " << groupName << endl;; + } + KListViewItem * groupLVI = new KListViewItem( settingsWidget->m_settingsList, groupName ); + std::vector<ngwt__Custom * > setting = group->setting; + std::vector<class ngwt__Custom *>::const_iterator it2; + for( it2 = setting.begin(); it2 != setting.end(); ++it2 ) + { + QString setting, value; + bool locked = false; + setting = QString::fromUtf8( (*it2)->field.c_str() ); + if ( (*it2)->value ) + { + value = QString::fromUtf8( (*it2)->value->c_str() ); + } + if ( (*it2)->locked ) + locked = *((*it2)->locked); + + kdDebug() << " SETTING: " << setting << " value : " << value << (locked ? "locked" : " not locked " ) << endl; + KListViewItem * settingLVI = new KListViewItem( groupLVI, QString::null, setting, value, (locked ? "locked" : " not locked " ) ); + if ( !locked ) + settingLVI->setRenameEnabled( 2, true ); + } + } + + dialog->show(); + if ( dialog->exec() == QDialog::Accepted ) + { + QMap<QString, QString> settings = settingsWidget->dirtySettings(); + mResource->modifyUserSettings( settings ); + } + } + else + kdDebug() << "KCal::ResourceGroupwiseConfig::slotViewUserSettings() - NO SETTINGS" << endl; + } +} + +#include "kcal_resourcegroupwiseconfig.moc" |