summaryrefslogtreecommitdiffstats
path: root/knode/knconfigmanager.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 /knode/knconfigmanager.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 'knode/knconfigmanager.cpp')
-rw-r--r--knode/knconfigmanager.cpp133
1 files changed, 133 insertions, 0 deletions
diff --git a/knode/knconfigmanager.cpp b/knode/knconfigmanager.cpp
new file mode 100644
index 00000000..b117f3c4
--- /dev/null
+++ b/knode/knconfigmanager.cpp
@@ -0,0 +1,133 @@
+/*
+ knconfigmanager.cpp
+
+ KNode, the KDE newsreader
+ Copyright (c) 1999-2005 the KNode authors.
+ See file AUTHORS for details
+
+ 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.
+ 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, US
+*/
+
+#include "knconfigmanager.h"
+
+#include <kcmultidialog.h>
+#include <kiconloader.h>
+#include <klocale.h>
+#include <kwin.h>
+
+#include <qhbox.h>
+
+#include "utilities.h"
+#include "knglobals.h"
+#include "articlewidget.h"
+#include "knarticlefactory.h"
+#include "knmainwidget.h"
+
+
+KNConfigManager::KNConfigManager(QObject *p, const char *n)
+ : QObject(p, n), d_ialog(0)
+{
+ i_dentity = new KNConfig::Identity();
+ a_ppearance = new KNConfig::Appearance();
+ r_eadNewsGeneral = new KNConfig::ReadNewsGeneral();
+ r_eadNewsNavigation = new KNConfig::ReadNewsNavigation();
+ r_eadNewsViewer = new KNConfig::ReadNewsViewer();
+ d_isplayedHeaders = new KNConfig::DisplayedHeaders();
+ s_coring = new KNConfig::Scoring();
+ p_ostNewsTechnical = new KNConfig::PostNewsTechnical();
+ p_ostNewsCompose = new KNConfig::PostNewsComposer();
+ c_leanup = new KNConfig::Cleanup();
+ //c_ache = new KNConfig::Cache();
+}
+
+
+KNConfigManager::~KNConfigManager()
+{
+ delete i_dentity;
+ delete a_ppearance;
+ delete r_eadNewsGeneral;
+ delete r_eadNewsNavigation;
+ delete r_eadNewsViewer;
+ delete d_isplayedHeaders;
+ delete s_coring;
+ delete p_ostNewsTechnical;
+ delete p_ostNewsCompose;
+ delete c_leanup;
+ //delete c_ache;
+}
+
+
+void KNConfigManager::configure()
+{
+ if(!d_ialog) {
+ d_ialog=new KNConfigDialog(knGlobals.topWidget, "Preferences_Dlg");
+ connect(d_ialog, SIGNAL(finished()), this, SLOT(slotDialogDone()));
+ d_ialog->show();
+ }
+ else
+ KWin::activateWindow(d_ialog->winId());
+}
+
+
+void KNConfigManager::syncConfig()
+{
+ a_ppearance->save();
+ r_eadNewsGeneral->save();
+ r_eadNewsNavigation->save();
+ r_eadNewsViewer->save();
+ d_isplayedHeaders->save();
+ s_coring->save();
+ p_ostNewsTechnical->save();
+ p_ostNewsCompose->save();
+ c_leanup->save();
+ //c_ache->save();
+}
+
+
+void KNConfigManager::slotDialogDone()
+{
+ d_ialog->delayedDestruct();
+ d_ialog=0;
+}
+
+
+//===================================================================================================
+
+
+KNConfigDialog::KNConfigDialog(QWidget *p, const char *n)
+ : KCMultiDialog(p, n)
+{
+ addModule ( "knode_config_identity", false );
+ addModule ( "knode_config_accounts", false );
+ addModule ( "knode_config_appearance", false );
+ addModule ( "knode_config_read_news", false );
+ addModule ( "knode_config_post_news", false );
+ addModule ( "knode_config_privacy", false );
+ addModule ( "knode_config_cleanup", false );
+
+ setHelp("anc-setting-your-identity");
+
+ connect(this, SIGNAL(configCommitted()), this, SLOT(slotConfigCommitted()));
+}
+
+
+void KNConfigDialog::slotConfigCommitted()
+{
+ knGlobals.configManager()->syncConfig();
+
+ KNode::ArticleWidget::configChanged();
+ if(knGlobals.top)
+ knGlobals.top->configChanged();
+ if(knGlobals.artFactory)
+ knGlobals.artFactory->configChanged();
+}
+
+
+//-----------------------------
+#include "knconfigmanager.moc"