-rw-r--r-- | libkdepim/externalapphandler.h | 18 | ||||
-rw-r--r-- | libkdepim/kcmconfigs/kdepimconfigwidget.cpp | 15 |
2 files changed, 21 insertions, 12 deletions
diff --git a/libkdepim/externalapphandler.h b/libkdepim/externalapphandler.h index efcdd89..3cf9e06 100644 --- a/libkdepim/externalapphandler.h +++ b/libkdepim/externalapphandler.h | |||
@@ -1,139 +1,145 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkdepim. | 2 | This file is part of libkdepim. |
3 | Copyright (c) 2004 Ulf Schenk | 3 | Copyright (c) 2004 Ulf Schenk |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
6 | it under the terms of the GNU General Public License as published by | 6 | it under the terms of the GNU General Public License as published by |
7 | the Free Software Foundation; either version 2 of the License, or | 7 | the Free Software Foundation; either version 2 of the License, or |
8 | (at your option) any later version. | 8 | (at your option) any later version. |
9 | 9 | ||
10 | This program is distributed in the hope that it will be useful, | 10 | This program is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | GNU General Public License for more details. | 13 | GNU General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU General Public License | 15 | You should have received a copy of the GNU General Public License |
16 | along with this program; if not, write to the Free Software | 16 | along with this program; if not, write to the Free Software |
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | 18 | ||
19 | As a special exception, permission is given to link this program | 19 | As a special exception, permission is given to link this program |
20 | with any edition of Qt, and distribute the resulting executable, | 20 | with any edition of Qt, and distribute the resulting executable, |
21 | without including the source code for Qt in the source distribution. | 21 | without including the source code for Qt in the source distribution. |
22 | */ | 22 | */ |
23 | 23 | ||
24 | /* | 24 | /* |
25 | Enhanced Version of the file for platform independent KDE tools. | 25 | Enhanced Version of the file for platform independent KDE tools. |
26 | Copyright (c) 2004 Ulf Schenk | 26 | Copyright (c) 2004 Ulf Schenk |
27 | 27 | ||
28 | $Id$ | 28 | $Id$ |
29 | */ | 29 | */ |
30 | 30 | ||
31 | #ifndef EXTERNALAPPHANDLER_H | 31 | #ifndef EXTERNALAPPHANDLER_H |
32 | #define EXTERNALAPPHANDLER_H | 32 | #define EXTERNALAPPHANDLER_H |
33 | 33 | ||
34 | #include <qlist.h> | 34 | #include <qlist.h> |
35 | 35 | ||
36 | class QCopEnvelope; | 36 | class QCopEnvelope; |
37 | 37 | ||
38 | 38 | ||
39 | class ExternalAppHandler; | 39 | class ExternalAppHandler; |
40 | 40 | ||
41 | class DefaultAppItem | 41 | class DefaultAppItem |
42 | { | 42 | { |
43 | public: | 43 | public: |
44 | DefaultAppItem(int type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameters, const QString& message2, const QString& parameters2) | 44 | DefaultAppItem(int type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameters, const QString& message2, const QString& parameters2) |
45 | : _type(type), _id(id), _label(label), _channel(channel), _message(message), _parameters(parameters), _message2(message2), _parameters2(parameters2) | 45 | : _type(type), _id(id), _label(label), _channel(channel), _message(message), _parameters(parameters), _message2(message2), _parameters2(parameters2) |
46 | {} | 46 | {} |
47 | 47 | ||
48 | DefaultAppItem() | 48 | DefaultAppItem() |
49 | { } | 49 | { } |
50 | 50 | ||
51 | public: | 51 | public: |
52 | int _type; | 52 | int _type; |
53 | int _id; | 53 | int _id; |
54 | QString _label; | 54 | QString _label; |
55 | QString _channel; | 55 | QString _channel; |
56 | QString _message; | 56 | QString _message; |
57 | QString _parameters;// a list of parameters in stringrepresentation. Delimiter is ; | 57 | QString _parameters;// a list of parameters in stringrepresentation. Delimiter is ; |
58 | QString _message2; | 58 | QString _message2; |
59 | QString _parameters2; // a list of parameters in stringrepresentation. Delimiter is ; | 59 | QString _parameters2; // a list of parameters in stringrepresentation. Delimiter is ; |
60 | 60 | ||
61 | }; | 61 | }; |
62 | 62 | ||
63 | class ExternalAppHandler | 63 | class ExternalAppHandler |
64 | { | 64 | { |
65 | public: | 65 | public: |
66 | virtual ~ExternalAppHandler(); | 66 | virtual ~ExternalAppHandler(); |
67 | 67 | ||
68 | static ExternalAppHandler *instance(); | 68 | static ExternalAppHandler *instance(); |
69 | 69 | ||
70 | enum Types { | 70 | enum Types { |
71 | EMAIL = 0, | 71 | EMAIL = 0, |
72 | PHONE = 1, | 72 | PHONE = 1, |
73 | SMS = 2, | 73 | SMS = 2, |
74 | FAX = 3, | 74 | FAX = 3, |
75 | PAGER = 4 | 75 | PAGER = 4 |
76 | }; | 76 | }; |
77 | 77 | ||
78 | enum Availability { | 78 | enum Availability { |
79 | UNDEFINED = -1, | 79 | UNDEFINED = -1, |
80 | UNAVAILABLE = 0, | 80 | UNAVAILABLE = 0, |
81 | AVAILABLE = 1 | 81 | AVAILABLE = 1 |
82 | }; | 82 | }; |
83 | 83 | ||
84 | //calls the emailapplication with a number of attachments that need to be send | 84 | //calls the emailapplication with a number of attachments that need to be send. |
85 | bool mailAttachments( const QString& urls ); | 85 | //either parameter can be left empty. |
86 | bool mailToMultipleContacts( const QString& recipients, const QString& attachmenturls ); | ||
86 | 87 | ||
87 | //calls the emailapplication and creates a mail with parameter emails as recipients | 88 | //calls the emailapplication and creates a mail with parameter emailadress as recipients |
88 | bool mailToContacts( const QString& emails ); | 89 | bool mailToOneContact( const QString& name, const QString& emailadress ); |
90 | |||
91 | //calls the emailapplication and creates a mail with parameter as recipients | ||
92 | // parameters format is | ||
93 | // NAME <EMAIL>:SUBJECT | ||
94 | bool mailToOneContact( const QString& adressline ); | ||
89 | 95 | ||
90 | //calls the phoneapplication with the number | 96 | //calls the phoneapplication with the number |
91 | bool callByPhone( const QString& phonenumber ); | 97 | bool callByPhone( const QString& phonenumber ); |
92 | 98 | ||
93 | //calls the smsapplication with the number | 99 | //calls the smsapplication with the number |
94 | bool callBySMS( const QString& phonenumber ); | 100 | bool callBySMS( const QString& phonenumber ); |
95 | 101 | ||
96 | //calls the pagerapplication with the number | 102 | //calls the pagerapplication with the number |
97 | bool callByPager( const QString& pagernumber ); | 103 | bool callByPager( const QString& pagernumber ); |
98 | 104 | ||
99 | //calls the faxapplication with the number | 105 | //calls the faxapplication with the number |
100 | bool callByFax( const QString& faxnumber ); | 106 | bool callByFax( const QString& faxnumber ); |
101 | 107 | ||
102 | bool isEmailAppAvailable(); | 108 | bool isEmailAppAvailable(); |
103 | bool isSMSAppAvailable(); | 109 | bool isSMSAppAvailable(); |
104 | bool isPhoneAppAvailable(); | 110 | bool isPhoneAppAvailable(); |
105 | bool isFaxAppAvailable(); | 111 | bool isFaxAppAvailable(); |
106 | bool isPagerAppAvailable(); | 112 | bool isPagerAppAvailable(); |
107 | 113 | ||
108 | 114 | ||
109 | 115 | ||
110 | //loadConfig clears the cache and checks again if the applications are available or not | 116 | //loadConfig clears the cache and checks again if the applications are available or not |
111 | void loadConfig(); | 117 | void loadConfig(); |
112 | 118 | ||
113 | QList<DefaultAppItem> getAvailableDefaultItems(Types); | 119 | QList<DefaultAppItem> getAvailableDefaultItems(Types); |
114 | DefaultAppItem* getDefaultItem(Types, int); | 120 | DefaultAppItem* getDefaultItem(Types, int); |
115 | 121 | ||
116 | 122 | ||
117 | private: | 123 | private: |
118 | ExternalAppHandler(); | 124 | ExternalAppHandler(); |
119 | QList<DefaultAppItem> mDefaultItems; | 125 | QList<DefaultAppItem> mDefaultItems; |
120 | 126 | ||
121 | Availability mEmailAppAvailable; | 127 | Availability mEmailAppAvailable; |
122 | Availability mPhoneAppAvailable; | 128 | Availability mPhoneAppAvailable; |
123 | Availability mFaxAppAvailable; | 129 | Availability mFaxAppAvailable; |
124 | Availability mSMSAppAvailable; | 130 | Availability mSMSAppAvailable; |
125 | Availability mPagerAppAvailable; | 131 | Availability mPagerAppAvailable; |
126 | 132 | ||
127 | 133 | ||
128 | void addDefaultAppItem(Types type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameters, const QString& message2, const QString& parameters2); | 134 | void addDefaultAppItem(Types type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameters, const QString& message2, const QString& parameters2); |
129 | 135 | ||
130 | QString& translateMessage(QString& message, const QString& emails) const; | 136 | QString& translateMessage(QString& message, const QString& param1, const QString& param2) const; |
131 | void passParameter(QCopEnvelope* e, const QString& parameters, const QString& param1) const; | 137 | void passParameters(QCopEnvelope* e, const QString& parameters, const QString& param1, const QString& param2) const; |
132 | 138 | ||
133 | 139 | ||
134 | static ExternalAppHandler *sInstance; | 140 | static ExternalAppHandler *sInstance; |
135 | 141 | ||
136 | 142 | ||
137 | }; | 143 | }; |
138 | 144 | ||
139 | #endif | 145 | #endif |
diff --git a/libkdepim/kcmconfigs/kdepimconfigwidget.cpp b/libkdepim/kcmconfigs/kdepimconfigwidget.cpp index c8b94db..4f4cc6a 100644 --- a/libkdepim/kcmconfigs/kdepimconfigwidget.cpp +++ b/libkdepim/kcmconfigs/kdepimconfigwidget.cpp | |||
@@ -48,206 +48,209 @@ $Id$ | |||
48 | #include <qcombobox.h> | 48 | #include <qcombobox.h> |
49 | #include <qlineedit.h> | 49 | #include <qlineedit.h> |
50 | #include <qlabel.h> | 50 | #include <qlabel.h> |
51 | #include <qfile.h> | 51 | #include <qfile.h> |
52 | 52 | ||
53 | #include <kconfig.h> | 53 | #include <kconfig.h> |
54 | #include <kdebug.h> | 54 | #include <kdebug.h> |
55 | #include <kdialog.h> | 55 | #include <kdialog.h> |
56 | #include <klistview.h> | 56 | #include <klistview.h> |
57 | #include <klocale.h> | 57 | #include <klocale.h> |
58 | #include <kglobal.h> | 58 | #include <kglobal.h> |
59 | #include <kmessagebox.h> | 59 | #include <kmessagebox.h> |
60 | #include <kstandarddirs.h> | 60 | #include <kstandarddirs.h> |
61 | 61 | ||
62 | #ifndef KAB_EMBEDDED | 62 | #ifndef KAB_EMBEDDED |
63 | #include <ktrader.h> | 63 | #include <ktrader.h> |
64 | #else // KAB_EMBEDDED | 64 | #else // KAB_EMBEDDED |
65 | #include <mergewidget.h> | 65 | #include <mergewidget.h> |
66 | #include <distributionlistwidget.h> | 66 | #include <distributionlistwidget.h> |
67 | #endif // KAB_EMBEDDED | 67 | #endif // KAB_EMBEDDED |
68 | 68 | ||
69 | #include "addresseewidget.h" | 69 | #include "addresseewidget.h" |
70 | #include "extensionconfigdialog.h" | 70 | #include "extensionconfigdialog.h" |
71 | #include "extensionwidget.h" | 71 | #include "extensionwidget.h" |
72 | */ | 72 | */ |
73 | 73 | ||
74 | #include "kpimglobalprefs.h" | 74 | #include "kpimglobalprefs.h" |
75 | 75 | ||
76 | #include "kdepimconfigwidget.h" | 76 | #include "kdepimconfigwidget.h" |
77 | 77 | ||
78 | 78 | ||
79 | KDEPIMConfigWidget::KDEPIMConfigWidget( QWidget *parent, const char *name ) | 79 | KDEPIMConfigWidget::KDEPIMConfigWidget( QWidget *parent, const char *name ) |
80 | : QWidget( parent, name ) | 80 | : QWidget( parent, name ) |
81 | { | 81 | { |
82 | mExternalAppsMap.insert(ExternalAppHandler::EMAIL, i18n("Email")); | 82 | mExternalAppsMap.insert(ExternalAppHandler::EMAIL, i18n("Email")); |
83 | mExternalAppsMap.insert(ExternalAppHandler::PHONE, i18n("Phone")); | 83 | mExternalAppsMap.insert(ExternalAppHandler::PHONE, i18n("Phone")); |
84 | mExternalAppsMap.insert(ExternalAppHandler::SMS, i18n("SMS")); | 84 | mExternalAppsMap.insert(ExternalAppHandler::SMS, i18n("SMS")); |
85 | mExternalAppsMap.insert(ExternalAppHandler::FAX, i18n("Fax")); | 85 | mExternalAppsMap.insert(ExternalAppHandler::FAX, i18n("Fax")); |
86 | mExternalAppsMap.insert(ExternalAppHandler::PAGER, i18n("Pager")); | 86 | mExternalAppsMap.insert(ExternalAppHandler::PAGER, i18n("Pager")); |
87 | 87 | ||
88 | 88 | ||
89 | QVBoxLayout *topLayout = new QVBoxLayout( this, 0, | 89 | QVBoxLayout *topLayout = new QVBoxLayout( this, 0, |
90 | KDialog::spacingHint() ); | 90 | KDialog::spacingHint() ); |
91 | 91 | ||
92 | QTabWidget *tabWidget = new QTabWidget( this ); | 92 | QTabWidget *tabWidget = new QTabWidget( this ); |
93 | topLayout->addWidget( tabWidget ); | 93 | topLayout->addWidget( tabWidget ); |
94 | 94 | ||
95 | 95 | ||
96 | 96 | ||
97 | // mailclient page | 97 | // mailclient page |
98 | QWidget *externalAppsPage = new QWidget( this ); | 98 | QWidget *externalAppsPage = new QWidget( this ); |
99 | QVBoxLayout* layout = new QVBoxLayout( externalAppsPage, KDialog::marginHintSmall(), | 99 | QVBoxLayout* layout = new QVBoxLayout( externalAppsPage, KDialog::marginHintSmall(), |
100 | KDialog::spacingHintSmall() ); | 100 | KDialog::spacingHintSmall() ); |
101 | 101 | ||
102 | mExternalApps = new QComboBox( externalAppsPage ); | 102 | mExternalApps = new QComboBox( externalAppsPage ); |
103 | 103 | ||
104 | QMap<ExternalAppHandler::Types, QString>::Iterator it; | 104 | QMap<ExternalAppHandler::Types, QString>::Iterator it; |
105 | for( it = mExternalAppsMap.begin(); it != mExternalAppsMap.end(); ++it ) | 105 | for( it = mExternalAppsMap.begin(); it != mExternalAppsMap.end(); ++it ) |
106 | mExternalApps->insertItem( it.data(), it.key() ); | 106 | mExternalApps->insertItem( it.data(), it.key() ); |
107 | 107 | ||
108 | layout->addWidget( mExternalApps ); | 108 | layout->addWidget( mExternalApps ); |
109 | 109 | ||
110 | connect( mExternalApps, SIGNAL( activated( int ) ), | 110 | connect( mExternalApps, SIGNAL( activated( int ) ), |
111 | this, SLOT (externalapp_changed( int ) ) ); | 111 | this, SLOT (externalapp_changed( int ) ) ); |
112 | 112 | ||
113 | 113 | ||
114 | 114 | ||
115 | 115 | ||
116 | mExternalAppGroupBox = new QGroupBox( 0, Qt::Vertical, i18n( "Used Mail Client" ), externalAppsPage ); | 116 | mExternalAppGroupBox = new QGroupBox( 0, Qt::Vertical, i18n( "Used Mail Client" ), externalAppsPage ); |
117 | QGridLayout *boxLayout = new QGridLayout( mExternalAppGroupBox->layout(), 4, 2, -1, "gridlayout" ); | 117 | QGridLayout *boxLayout = new QGridLayout( mExternalAppGroupBox->layout(), 4, 2, -1, "gridlayout" ); |
118 | 118 | ||
119 | 119 | ||
120 | mClient = new QComboBox( mExternalAppGroupBox ); | 120 | mClient = new QComboBox( mExternalAppGroupBox ); |
121 | boxLayout->addMultiCellWidget( mClient, 0, 0, 0, 1 ); | 121 | boxLayout->addMultiCellWidget( mClient, 0, 0, 0, 1 ); |
122 | 122 | ||
123 | connect( mClient, SIGNAL( activated( int ) ), | 123 | connect( mClient, SIGNAL( activated( int ) ), |
124 | this, SLOT (client_changed( int ) ) ); | 124 | this, SLOT (client_changed( int ) ) ); |
125 | 125 | ||
126 | QLabel* lab = new QLabel( i18n("Channel:"), mExternalAppGroupBox); | 126 | QLabel* lab = new QLabel( i18n("Channel:"), mExternalAppGroupBox); |
127 | boxLayout->addWidget( lab, 1, 0 ); | 127 | boxLayout->addWidget( lab, 1, 0 ); |
128 | mChannel = new QLineEdit(mExternalAppGroupBox); | 128 | mChannel = new QLineEdit(mExternalAppGroupBox); |
129 | mChannel->setReadOnly(true); | 129 | mChannel->setReadOnly(true); |
130 | boxLayout->addMultiCellWidget( mChannel, 2 , 2, 0, 1 ); | 130 | boxLayout->addMultiCellWidget( mChannel, 2 , 2, 0, 1 ); |
131 | 131 | ||
132 | lab = new QLabel( i18n("Message:"), mExternalAppGroupBox); | 132 | lab = new QLabel( i18n("Message:"), mExternalAppGroupBox); |
133 | boxLayout->addWidget( lab, 3, 0 ); | 133 | boxLayout->addWidget( lab, 3, 0 ); |
134 | mMessage = new QLineEdit(mExternalAppGroupBox); | 134 | mMessage = new QLineEdit(mExternalAppGroupBox); |
135 | mMessage->setReadOnly(true); | 135 | mMessage->setReadOnly(true); |
136 | boxLayout->addWidget( mMessage , 4, 0); | 136 | boxLayout->addWidget( mMessage , 4, 0); |
137 | 137 | ||
138 | lab = new QLabel( i18n("Parameters:"), mExternalAppGroupBox); | 138 | lab = new QLabel( i18n("Parameters:"), mExternalAppGroupBox); |
139 | boxLayout->addWidget( lab, 3, 1 ); | 139 | boxLayout->addWidget( lab, 3, 1 ); |
140 | mParameters = new QLineEdit(mExternalAppGroupBox); | 140 | mParameters = new QLineEdit(mExternalAppGroupBox); |
141 | mParameters->setReadOnly(true); | 141 | mParameters->setReadOnly(true); |
142 | boxLayout->addWidget( mParameters, 4, 1 ); | 142 | boxLayout->addWidget( mParameters, 4, 1 ); |
143 | 143 | ||
144 | lab = new QLabel( i18n("HINT: Delimiter=; Name=%1,Email=%2"), mExternalAppGroupBox); | ||
145 | boxLayout->addMultiCellWidget( lab, 5, 5, 0, 1 ); | ||
146 | |||
144 | lab = new QLabel( i18n("extra Message:"), mExternalAppGroupBox); | 147 | lab = new QLabel( i18n("extra Message:"), mExternalAppGroupBox); |
145 | boxLayout->addWidget( lab, 5, 0 ); | 148 | boxLayout->addWidget( lab, 6, 0 ); |
146 | mMessage2 = new QLineEdit(mExternalAppGroupBox); | 149 | mMessage2 = new QLineEdit(mExternalAppGroupBox); |
147 | mMessage2->setReadOnly(true); | 150 | mMessage2->setReadOnly(true); |
148 | boxLayout->addWidget( mMessage2 , 6, 0); | 151 | boxLayout->addWidget( mMessage2 , 7, 0); |
149 | 152 | ||
150 | lab = new QLabel( i18n("extra Parameters:"), mExternalAppGroupBox); | 153 | lab = new QLabel( i18n("extra Parameters:"), mExternalAppGroupBox); |
151 | boxLayout->addWidget( lab, 5, 1 ); | 154 | boxLayout->addWidget( lab, 6, 1 ); |
152 | mParameters2 = new QLineEdit(mExternalAppGroupBox); | 155 | mParameters2 = new QLineEdit(mExternalAppGroupBox); |
153 | mParameters2->setReadOnly(true); | 156 | mParameters2->setReadOnly(true); |
154 | boxLayout->addWidget( mParameters2, 6, 1 ); | 157 | boxLayout->addWidget( mParameters2, 7, 1 ); |
155 | 158 | ||
156 | lab = new QLabel( i18n("HINT: Delimiter=; Data=%1 "), mExternalAppGroupBox); | 159 | lab = new QLabel( i18n("HINT: Emails=%1,Attachments=%2"), mExternalAppGroupBox); |
157 | boxLayout->addMultiCellWidget( lab, 7, 7, 0, 1 ); | 160 | boxLayout->addMultiCellWidget( lab, 8, 8, 0, 1 ); |
158 | 161 | ||
159 | 162 | ||
160 | connect( mChannel, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); | 163 | connect( mChannel, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); |
161 | connect( mMessage, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); | 164 | connect( mMessage, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); |
162 | connect( mParameters, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); | 165 | connect( mParameters, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); |
163 | connect( mMessage2, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); | 166 | connect( mMessage2, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); |
164 | connect( mParameters2, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); | 167 | connect( mParameters2, SIGNAL( textChanged ( const QString & )), this, SLOT( textChanged ( const QString & )) ); |
165 | 168 | ||
166 | 169 | ||
167 | 170 | ||
168 | layout->addWidget( mExternalAppGroupBox ); | 171 | layout->addWidget( mExternalAppGroupBox ); |
169 | tabWidget->addTab( externalAppsPage, i18n( "External Apps." ) ); | 172 | tabWidget->addTab( externalAppsPage, i18n( "External Apps." ) ); |
170 | 173 | ||
171 | } | 174 | } |
172 | 175 | ||
173 | void KDEPIMConfigWidget::externalapp_changed( int newApp ) | 176 | void KDEPIMConfigWidget::externalapp_changed( int newApp ) |
174 | { | 177 | { |
175 | // first store the current data | 178 | // first store the current data |
176 | saveEditFieldSettings(); | 179 | saveEditFieldSettings(); |
177 | 180 | ||
178 | // set mCurrentApp | 181 | // set mCurrentApp |
179 | mCurrentApp = (ExternalAppHandler::Types)newApp; | 182 | mCurrentApp = (ExternalAppHandler::Types)newApp; |
180 | 183 | ||
181 | // set mCurrentClient | 184 | // set mCurrentClient |
182 | switch(mCurrentApp) | 185 | switch(mCurrentApp) |
183 | { | 186 | { |
184 | case(ExternalAppHandler::EMAIL): | 187 | case(ExternalAppHandler::EMAIL): |
185 | mCurrentClient = mEmailClient; | 188 | mCurrentClient = mEmailClient; |
186 | break; | 189 | break; |
187 | case(ExternalAppHandler::PHONE): | 190 | case(ExternalAppHandler::PHONE): |
188 | mCurrentClient = mPhoneClient; | 191 | mCurrentClient = mPhoneClient; |
189 | break; | 192 | break; |
190 | case(ExternalAppHandler::SMS): | 193 | case(ExternalAppHandler::SMS): |
191 | mCurrentClient = mSMSClient; | 194 | mCurrentClient = mSMSClient; |
192 | break; | 195 | break; |
193 | case(ExternalAppHandler::FAX): | 196 | case(ExternalAppHandler::FAX): |
194 | mCurrentClient = mFaxClient; | 197 | mCurrentClient = mFaxClient; |
195 | break; | 198 | break; |
196 | case(ExternalAppHandler::PAGER): | 199 | case(ExternalAppHandler::PAGER): |
197 | mCurrentClient = mPagerClient; | 200 | mCurrentClient = mPagerClient; |
198 | break; | 201 | break; |
199 | default: | 202 | default: |
200 | return; | 203 | return; |
201 | } | 204 | } |
202 | 205 | ||
203 | // and at last update the widgets | 206 | // and at last update the widgets |
204 | updateClientWidgets(); | 207 | updateClientWidgets(); |
205 | } | 208 | } |
206 | 209 | ||
207 | 210 | ||
208 | 211 | ||
209 | void KDEPIMConfigWidget::client_changed( int newClient ) | 212 | void KDEPIMConfigWidget::client_changed( int newClient ) |
210 | { | 213 | { |
211 | if (newClient == mCurrentClient) | 214 | if (newClient == mCurrentClient) |
212 | return; | 215 | return; |
213 | 216 | ||
214 | // first store the current data | 217 | // first store the current data |
215 | saveEditFieldSettings(); | 218 | saveEditFieldSettings(); |
216 | 219 | ||
217 | 220 | ||
218 | //then reset the clientvariable | 221 | //then reset the clientvariable |
219 | mCurrentClient = newClient; | 222 | mCurrentClient = newClient; |
220 | 223 | ||
221 | // and at last update the widgets | 224 | // and at last update the widgets |
222 | updateClientWidgets(); | 225 | updateClientWidgets(); |
223 | 226 | ||
224 | modified(); | 227 | modified(); |
225 | } | 228 | } |
226 | 229 | ||
227 | void KDEPIMConfigWidget::saveEditFieldSettings() | 230 | void KDEPIMConfigWidget::saveEditFieldSettings() |
228 | { | 231 | { |
229 | 232 | ||
230 | switch(mCurrentApp) | 233 | switch(mCurrentApp) |
231 | { | 234 | { |
232 | case(ExternalAppHandler::EMAIL): | 235 | case(ExternalAppHandler::EMAIL): |
233 | mEmailClient = mClient->currentItem(); | 236 | mEmailClient = mClient->currentItem(); |
234 | break; | 237 | break; |
235 | case(ExternalAppHandler::PHONE): | 238 | case(ExternalAppHandler::PHONE): |
236 | mPhoneClient= mClient->currentItem(); | 239 | mPhoneClient= mClient->currentItem(); |
237 | break; | 240 | break; |
238 | case(ExternalAppHandler::SMS): | 241 | case(ExternalAppHandler::SMS): |
239 | mSMSClient = mClient->currentItem(); | 242 | mSMSClient = mClient->currentItem(); |
240 | break; | 243 | break; |
241 | case(ExternalAppHandler::FAX): | 244 | case(ExternalAppHandler::FAX): |
242 | mFaxClient = mClient->currentItem(); | 245 | mFaxClient = mClient->currentItem(); |
243 | break; | 246 | break; |
244 | case(ExternalAppHandler::PAGER): | 247 | case(ExternalAppHandler::PAGER): |
245 | mPagerClient = mClient->currentItem(); | 248 | mPagerClient = mClient->currentItem(); |
246 | break; | 249 | break; |
247 | default: | 250 | default: |
248 | return; | 251 | return; |
249 | } | 252 | } |
250 | 253 | ||
251 | //store the current data back to the apropriate membervariables if we had set it to "other" | 254 | //store the current data back to the apropriate membervariables if we had set it to "other" |
252 | if ((mCurrentApp == ExternalAppHandler::EMAIL) && (mCurrentClient == KPimGlobalPrefs::OTHER_EMC)) | 255 | if ((mCurrentApp == ExternalAppHandler::EMAIL) && (mCurrentClient == KPimGlobalPrefs::OTHER_EMC)) |
253 | { | 256 | { |