summaryrefslogtreecommitdiffstats
path: root/kresources/groupwise/kcal_resourcegroupwiseconfig.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch)
tree67208f7c145782a7e90b123b982ca78d88cc2c87 /kresources/groupwise/kcal_resourcegroupwiseconfig.cpp
downloadtdepim-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.cpp176
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"