author | ulf69 <ulf69> | 2004-09-21 19:54:39 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-09-21 19:54:39 (UTC) |
commit | 618dec7bf4371c2085048cc1f95a93220bc8a233 (patch) (unidiff) | |
tree | df5e3e47a417400fa9f6871912eda6558294d9b4 | |
parent | 186ee062d9169860fbab1613ca21b956c69296a6 (diff) | |
download | kdepimpi-618dec7bf4371c2085048cc1f95a93220bc8a233.zip kdepimpi-618dec7bf4371c2085048cc1f95a93220bc8a233.tar.gz kdepimpi-618dec7bf4371c2085048cc1f95a93220bc8a233.tar.bz2 |
modified configdialog to work properly with global configwidget from (libkdepim)
-rw-r--r-- | kaddressbook/kabcore.cpp | 9 | ||||
-rw-r--r-- | kaddressbook/kcmconfigs/kabconfigwidget.cpp | 32 | ||||
-rw-r--r-- | kaddressbook/kcmconfigs/kabconfigwidget.h | 20 | ||||
-rw-r--r-- | kaddressbook/kcmconfigs/kcmkabconfig.cpp | 16 | ||||
-rw-r--r-- | kaddressbook/kcmconfigs/kcmkabconfig.h | 2 |
5 files changed, 26 insertions, 53 deletions
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index 4ebd6a8..1b40d71 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -1158,267 +1158,262 @@ void KABCore::setDetailsVisible( bool visible ) | |||
1158 | { | 1158 | { |
1159 | if (visible && mDetails->isHidden()) | 1159 | if (visible && mDetails->isHidden()) |
1160 | { | 1160 | { |
1161 | KABC::Addressee::List addrList = mViewManager->selectedAddressees(); | 1161 | KABC::Addressee::List addrList = mViewManager->selectedAddressees(); |
1162 | if ( addrList.count() > 0 ) | 1162 | if ( addrList.count() > 0 ) |
1163 | mDetails->setAddressee( addrList[ 0 ] ); | 1163 | mDetails->setAddressee( addrList[ 0 ] ); |
1164 | } | 1164 | } |
1165 | 1165 | ||
1166 | // mMultipleViewsAtOnce=false: mDetails is always visible. But we switch between | 1166 | // mMultipleViewsAtOnce=false: mDetails is always visible. But we switch between |
1167 | // the listview and the detailview. We do that by changing the splitbar size. | 1167 | // the listview and the detailview. We do that by changing the splitbar size. |
1168 | if (mMultipleViewsAtOnce) | 1168 | if (mMultipleViewsAtOnce) |
1169 | { | 1169 | { |
1170 | if ( visible ) | 1170 | if ( visible ) |
1171 | mDetails->show(); | 1171 | mDetails->show(); |
1172 | else | 1172 | else |
1173 | mDetails->hide(); | 1173 | mDetails->hide(); |
1174 | } | 1174 | } |
1175 | else | 1175 | else |
1176 | { | 1176 | { |
1177 | if ( visible ) { | 1177 | if ( visible ) { |
1178 | mViewManager->hide(); | 1178 | mViewManager->hide(); |
1179 | mDetails->show(); | 1179 | mDetails->show(); |
1180 | } | 1180 | } |
1181 | else { | 1181 | else { |
1182 | mViewManager->show(); | 1182 | mViewManager->show(); |
1183 | mDetails->hide(); | 1183 | mDetails->hide(); |
1184 | } | 1184 | } |
1185 | setJumpButtonBarVisible( !visible ); | 1185 | setJumpButtonBarVisible( !visible ); |
1186 | } | 1186 | } |
1187 | 1187 | ||
1188 | } | 1188 | } |
1189 | 1189 | ||
1190 | void KABCore::extensionChanged( int id ) | 1190 | void KABCore::extensionChanged( int id ) |
1191 | { | 1191 | { |
1192 | //change the details view only for non desktop systems | 1192 | //change the details view only for non desktop systems |
1193 | #ifndef DESKTOP_VERSION | 1193 | #ifndef DESKTOP_VERSION |
1194 | 1194 | ||
1195 | if (id == 0) | 1195 | if (id == 0) |
1196 | { | 1196 | { |
1197 | //the user disabled the extension. | 1197 | //the user disabled the extension. |
1198 | 1198 | ||
1199 | if (mMultipleViewsAtOnce) | 1199 | if (mMultipleViewsAtOnce) |
1200 | { // enable detailsview again | 1200 | { // enable detailsview again |
1201 | setDetailsVisible( true ); | 1201 | setDetailsVisible( true ); |
1202 | mActionDetails->setChecked( true ); | 1202 | mActionDetails->setChecked( true ); |
1203 | } | 1203 | } |
1204 | else | 1204 | else |
1205 | { //go back to the listview | 1205 | { //go back to the listview |
1206 | setDetailsVisible( false ); | 1206 | setDetailsVisible( false ); |
1207 | mActionDetails->setChecked( false ); | 1207 | mActionDetails->setChecked( false ); |
1208 | mActionDetails->setEnabled(true); | 1208 | mActionDetails->setEnabled(true); |
1209 | } | 1209 | } |
1210 | 1210 | ||
1211 | } | 1211 | } |
1212 | else | 1212 | else |
1213 | { | 1213 | { |
1214 | //the user enabled the extension. | 1214 | //the user enabled the extension. |
1215 | setDetailsVisible( false ); | 1215 | setDetailsVisible( false ); |
1216 | mActionDetails->setChecked( false ); | 1216 | mActionDetails->setChecked( false ); |
1217 | 1217 | ||
1218 | if (!mMultipleViewsAtOnce) | 1218 | if (!mMultipleViewsAtOnce) |
1219 | { | 1219 | { |
1220 | mActionDetails->setEnabled(false); | 1220 | mActionDetails->setEnabled(false); |
1221 | } | 1221 | } |
1222 | 1222 | ||
1223 | mExtensionManager->setSelectionChanged(); | 1223 | mExtensionManager->setSelectionChanged(); |
1224 | 1224 | ||
1225 | } | 1225 | } |
1226 | 1226 | ||
1227 | #endif// DESKTOP_VERSION | 1227 | #endif// DESKTOP_VERSION |
1228 | 1228 | ||
1229 | } | 1229 | } |
1230 | 1230 | ||
1231 | 1231 | ||
1232 | void KABCore::extensionModified( const KABC::Addressee::List &list ) | 1232 | void KABCore::extensionModified( const KABC::Addressee::List &list ) |
1233 | { | 1233 | { |
1234 | 1234 | ||
1235 | if ( list.count() != 0 ) { | 1235 | if ( list.count() != 0 ) { |
1236 | KABC::Addressee::List::ConstIterator it; | 1236 | KABC::Addressee::List::ConstIterator it; |
1237 | for ( it = list.begin(); it != list.end(); ++it ) | 1237 | for ( it = list.begin(); it != list.end(); ++it ) |
1238 | mAddressBook->insertAddressee( *it ); | 1238 | mAddressBook->insertAddressee( *it ); |
1239 | if ( list.count() > 1 ) | 1239 | if ( list.count() > 1 ) |
1240 | setModified(); | 1240 | setModified(); |
1241 | else | 1241 | else |
1242 | setModifiedWOrefresh(); | 1242 | setModifiedWOrefresh(); |
1243 | } | 1243 | } |
1244 | if ( list.count() == 0 ) | 1244 | if ( list.count() == 0 ) |
1245 | mViewManager->refreshView(); | 1245 | mViewManager->refreshView(); |
1246 | else | 1246 | else |
1247 | mViewManager->refreshView( list[ 0 ].uid() ); | 1247 | mViewManager->refreshView( list[ 0 ].uid() ); |
1248 | 1248 | ||
1249 | 1249 | ||
1250 | 1250 | ||
1251 | } | 1251 | } |
1252 | 1252 | ||
1253 | QString KABCore::getNameByPhone( const QString &phone ) | 1253 | QString KABCore::getNameByPhone( const QString &phone ) |
1254 | { | 1254 | { |
1255 | #ifndef KAB_EMBEDDED | 1255 | #ifndef KAB_EMBEDDED |
1256 | QRegExp r( "[/*/-/ ]" ); | 1256 | QRegExp r( "[/*/-/ ]" ); |
1257 | QString localPhone( phone ); | 1257 | QString localPhone( phone ); |
1258 | 1258 | ||
1259 | bool found = false; | 1259 | bool found = false; |
1260 | QString ownerName = ""; | 1260 | QString ownerName = ""; |
1261 | KABC::AddressBook::Iterator iter; | 1261 | KABC::AddressBook::Iterator iter; |
1262 | KABC::PhoneNumber::List::Iterator phoneIter; | 1262 | KABC::PhoneNumber::List::Iterator phoneIter; |
1263 | KABC::PhoneNumber::List phoneList; | 1263 | KABC::PhoneNumber::List phoneList; |
1264 | for ( iter = mAddressBook->begin(); !found && ( iter != mAddressBook->end() ); ++iter ) { | 1264 | for ( iter = mAddressBook->begin(); !found && ( iter != mAddressBook->end() ); ++iter ) { |
1265 | phoneList = (*iter).phoneNumbers(); | 1265 | phoneList = (*iter).phoneNumbers(); |
1266 | for ( phoneIter = phoneList.begin(); !found && ( phoneIter != phoneList.end() ); | 1266 | for ( phoneIter = phoneList.begin(); !found && ( phoneIter != phoneList.end() ); |
1267 | ++phoneIter) { | 1267 | ++phoneIter) { |
1268 | // Get rid of separator chars so just the numbers are compared. | 1268 | // Get rid of separator chars so just the numbers are compared. |
1269 | if ( (*phoneIter).number().replace( r, "" ) == localPhone.replace( r, "" ) ) { | 1269 | if ( (*phoneIter).number().replace( r, "" ) == localPhone.replace( r, "" ) ) { |
1270 | ownerName = (*iter).formattedName(); | 1270 | ownerName = (*iter).formattedName(); |
1271 | found = true; | 1271 | found = true; |
1272 | } | 1272 | } |
1273 | } | 1273 | } |
1274 | } | 1274 | } |
1275 | 1275 | ||
1276 | return ownerName; | 1276 | return ownerName; |
1277 | #else //KAB_EMBEDDED | 1277 | #else //KAB_EMBEDDED |
1278 | qDebug("KABCore::getNameByPhone finsih method"); | 1278 | qDebug("KABCore::getNameByPhone finsih method"); |
1279 | return ""; | 1279 | return ""; |
1280 | #endif //KAB_EMBEDDED | 1280 | #endif //KAB_EMBEDDED |
1281 | 1281 | ||
1282 | } | 1282 | } |
1283 | 1283 | ||
1284 | void KABCore::openConfigDialog() | 1284 | void KABCore::openConfigDialog() |
1285 | { | 1285 | { |
1286 | KABPrefs* kab_prefs = KABPrefs::instance(); | ||
1287 | KPimGlobalPrefs* kpim_prefs = KPimGlobalPrefs::instance(); | ||
1288 | |||
1289 | KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true ); | 1286 | KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true ); |
1290 | KCMKabConfig* kabcfg = new KCMKabConfig( kab_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" ); | 1287 | KCMKabConfig* kabcfg = new KCMKabConfig( ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" ); |
1291 | ConfigureDialog->addModule(kabcfg ); | 1288 | ConfigureDialog->addModule(kabcfg ); |
1292 | KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( kpim_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); | 1289 | KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); |
1293 | ConfigureDialog->addModule(kdelibcfg ); | 1290 | ConfigureDialog->addModule(kdelibcfg ); |
1294 | 1291 | ||
1295 | |||
1296 | |||
1297 | connect( ConfigureDialog, SIGNAL( applyClicked() ), | 1292 | connect( ConfigureDialog, SIGNAL( applyClicked() ), |
1298 | this, SLOT( configurationChanged() ) ); | 1293 | this, SLOT( configurationChanged() ) ); |
1299 | connect( ConfigureDialog, SIGNAL( okClicked() ), | 1294 | connect( ConfigureDialog, SIGNAL( okClicked() ), |
1300 | this, SLOT( configurationChanged() ) ); | 1295 | this, SLOT( configurationChanged() ) ); |
1301 | saveSettings(); | 1296 | saveSettings(); |
1302 | #ifndef DESKTOP_VERSION | 1297 | #ifndef DESKTOP_VERSION |
1303 | ConfigureDialog->showMaximized(); | 1298 | ConfigureDialog->showMaximized(); |
1304 | #endif | 1299 | #endif |
1305 | if ( ConfigureDialog->exec() ) | 1300 | if ( ConfigureDialog->exec() ) |
1306 | KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") ); | 1301 | KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") ); |
1307 | delete ConfigureDialog; | 1302 | delete ConfigureDialog; |
1308 | } | 1303 | } |
1309 | 1304 | ||
1310 | void KABCore::openLDAPDialog() | 1305 | void KABCore::openLDAPDialog() |
1311 | { | 1306 | { |
1312 | #ifndef KAB_EMBEDDED | 1307 | #ifndef KAB_EMBEDDED |
1313 | if ( !mLdapSearchDialog ) { | 1308 | if ( !mLdapSearchDialog ) { |
1314 | mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this ); | 1309 | mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this ); |
1315 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager, | 1310 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager, |
1316 | SLOT( refreshView() ) ); | 1311 | SLOT( refreshView() ) ); |
1317 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this, | 1312 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this, |
1318 | SLOT( setModified() ) ); | 1313 | SLOT( setModified() ) ); |
1319 | } else | 1314 | } else |
1320 | mLdapSearchDialog->restoreSettings(); | 1315 | mLdapSearchDialog->restoreSettings(); |
1321 | 1316 | ||
1322 | if ( mLdapSearchDialog->isOK() ) | 1317 | if ( mLdapSearchDialog->isOK() ) |
1323 | mLdapSearchDialog->exec(); | 1318 | mLdapSearchDialog->exec(); |
1324 | #else //KAB_EMBEDDED | 1319 | #else //KAB_EMBEDDED |
1325 | qDebug("KABCore::openLDAPDialog() finsih method"); | 1320 | qDebug("KABCore::openLDAPDialog() finsih method"); |
1326 | #endif //KAB_EMBEDDED | 1321 | #endif //KAB_EMBEDDED |
1327 | } | 1322 | } |
1328 | 1323 | ||
1329 | void KABCore::print() | 1324 | void KABCore::print() |
1330 | { | 1325 | { |
1331 | #ifndef KAB_EMBEDDED | 1326 | #ifndef KAB_EMBEDDED |
1332 | KPrinter printer; | 1327 | KPrinter printer; |
1333 | if ( !printer.setup( this ) ) | 1328 | if ( !printer.setup( this ) ) |
1334 | return; | 1329 | return; |
1335 | 1330 | ||
1336 | KABPrinting::PrintingWizard wizard( &printer, mAddressBook, | 1331 | KABPrinting::PrintingWizard wizard( &printer, mAddressBook, |
1337 | mViewManager->selectedUids(), this ); | 1332 | mViewManager->selectedUids(), this ); |
1338 | 1333 | ||
1339 | wizard.exec(); | 1334 | wizard.exec(); |
1340 | #else //KAB_EMBEDDED | 1335 | #else //KAB_EMBEDDED |
1341 | qDebug("KABCore::print() finsih method"); | 1336 | qDebug("KABCore::print() finsih method"); |
1342 | #endif //KAB_EMBEDDED | 1337 | #endif //KAB_EMBEDDED |
1343 | 1338 | ||
1344 | } | 1339 | } |
1345 | 1340 | ||
1346 | 1341 | ||
1347 | void KABCore::addGUIClient( KXMLGUIClient *client ) | 1342 | void KABCore::addGUIClient( KXMLGUIClient *client ) |
1348 | { | 1343 | { |
1349 | if ( mGUIClient ) | 1344 | if ( mGUIClient ) |
1350 | mGUIClient->insertChildClient( client ); | 1345 | mGUIClient->insertChildClient( client ); |
1351 | else | 1346 | else |
1352 | KMessageBox::error( this, "no KXMLGUICLient"); | 1347 | KMessageBox::error( this, "no KXMLGUICLient"); |
1353 | } | 1348 | } |
1354 | 1349 | ||
1355 | 1350 | ||
1356 | void KABCore::configurationChanged() | 1351 | void KABCore::configurationChanged() |
1357 | { | 1352 | { |
1358 | mExtensionManager->reconfigure(); | 1353 | mExtensionManager->reconfigure(); |
1359 | } | 1354 | } |
1360 | 1355 | ||
1361 | void KABCore::addressBookChanged() | 1356 | void KABCore::addressBookChanged() |
1362 | { | 1357 | { |
1363 | /*US | 1358 | /*US |
1364 | QDictIterator<AddresseeEditorDialog> it( mEditorDict ); | 1359 | QDictIterator<AddresseeEditorDialog> it( mEditorDict ); |
1365 | while ( it.current() ) { | 1360 | while ( it.current() ) { |
1366 | if ( it.current()->dirty() ) { | 1361 | if ( it.current()->dirty() ) { |
1367 | QString text = i18n( "Data has been changed externally. Unsaved " | 1362 | QString text = i18n( "Data has been changed externally. Unsaved " |
1368 | "changes will be lost." ); | 1363 | "changes will be lost." ); |
1369 | KMessageBox::information( this, text ); | 1364 | KMessageBox::information( this, text ); |
1370 | } | 1365 | } |
1371 | it.current()->setAddressee( mAddressBook->findByUid( it.currentKey() ) ); | 1366 | it.current()->setAddressee( mAddressBook->findByUid( it.currentKey() ) ); |
1372 | ++it; | 1367 | ++it; |
1373 | } | 1368 | } |
1374 | */ | 1369 | */ |
1375 | if (mEditorDialog) | 1370 | if (mEditorDialog) |
1376 | { | 1371 | { |
1377 | if (mEditorDialog->dirty()) | 1372 | if (mEditorDialog->dirty()) |
1378 | { | 1373 | { |
1379 | QString text = i18n( "Data has been changed externally. Unsaved " | 1374 | QString text = i18n( "Data has been changed externally. Unsaved " |
1380 | "changes will be lost." ); | 1375 | "changes will be lost." ); |
1381 | KMessageBox::information( this, text ); | 1376 | KMessageBox::information( this, text ); |
1382 | } | 1377 | } |
1383 | QString currentuid = mEditorDialog->addressee().uid(); | 1378 | QString currentuid = mEditorDialog->addressee().uid(); |
1384 | mEditorDialog->setAddressee( mAddressBook->findByUid( currentuid ) ); | 1379 | mEditorDialog->setAddressee( mAddressBook->findByUid( currentuid ) ); |
1385 | } | 1380 | } |
1386 | mViewManager->refreshView(); | 1381 | mViewManager->refreshView(); |
1387 | // mDetails->refreshView(); | 1382 | // mDetails->refreshView(); |
1388 | 1383 | ||
1389 | 1384 | ||
1390 | } | 1385 | } |
1391 | 1386 | ||
1392 | AddresseeEditorDialog *KABCore::createAddresseeEditorDialog( QWidget *parent, | 1387 | AddresseeEditorDialog *KABCore::createAddresseeEditorDialog( QWidget *parent, |
1393 | const char *name ) | 1388 | const char *name ) |
1394 | { | 1389 | { |
1395 | 1390 | ||
1396 | if ( mEditorDialog == 0 ) { | 1391 | if ( mEditorDialog == 0 ) { |
1397 | mEditorDialog = new AddresseeEditorDialog( this, parent, | 1392 | mEditorDialog = new AddresseeEditorDialog( this, parent, |
1398 | name ? name : "editorDialog" ); | 1393 | name ? name : "editorDialog" ); |
1399 | 1394 | ||
1400 | 1395 | ||
1401 | connect( mEditorDialog, SIGNAL( contactModified( const KABC::Addressee& ) ), | 1396 | connect( mEditorDialog, SIGNAL( contactModified( const KABC::Addressee& ) ), |
1402 | SLOT( contactModified( const KABC::Addressee& ) ) ); | 1397 | SLOT( contactModified( const KABC::Addressee& ) ) ); |
1403 | //connect( mEditorDialog, SIGNAL( editorDestroyed( const QString& ) ), | 1398 | //connect( mEditorDialog, SIGNAL( editorDestroyed( const QString& ) ), |
1404 | // SLOT( slotEditorDestroyed( const QString& ) ) ; | 1399 | // SLOT( slotEditorDestroyed( const QString& ) ) ; |
1405 | } | 1400 | } |
1406 | 1401 | ||
1407 | return mEditorDialog; | 1402 | return mEditorDialog; |
1408 | } | 1403 | } |
1409 | 1404 | ||
1410 | void KABCore::slotEditorDestroyed( const QString &uid ) | 1405 | void KABCore::slotEditorDestroyed( const QString &uid ) |
1411 | { | 1406 | { |
1412 | //mEditorDict.remove( uid ); | 1407 | //mEditorDict.remove( uid ); |
1413 | } | 1408 | } |
1414 | 1409 | ||
1415 | void KABCore::initGUI() | 1410 | void KABCore::initGUI() |
1416 | { | 1411 | { |
1417 | #ifndef KAB_EMBEDDED | 1412 | #ifndef KAB_EMBEDDED |
1418 | QHBoxLayout *topLayout = new QHBoxLayout( this ); | 1413 | QHBoxLayout *topLayout = new QHBoxLayout( this ); |
1419 | topLayout->setSpacing( KDialogBase::spacingHint() ); | 1414 | topLayout->setSpacing( KDialogBase::spacingHint() ); |
1420 | 1415 | ||
1421 | mExtensionBarSplitter = new QSplitter( this ); | 1416 | mExtensionBarSplitter = new QSplitter( this ); |
1422 | mExtensionBarSplitter->setOrientation( Qt::Vertical ); | 1417 | mExtensionBarSplitter->setOrientation( Qt::Vertical ); |
1423 | 1418 | ||
1424 | mDetailsSplitter = new QSplitter( mExtensionBarSplitter ); | 1419 | mDetailsSplitter = new QSplitter( mExtensionBarSplitter ); |
diff --git a/kaddressbook/kcmconfigs/kabconfigwidget.cpp b/kaddressbook/kcmconfigs/kabconfigwidget.cpp index 0c3a199..e970c3d 100644 --- a/kaddressbook/kcmconfigs/kabconfigwidget.cpp +++ b/kaddressbook/kcmconfigs/kabconfigwidget.cpp | |||
@@ -1,356 +1,338 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KAddressBook. | 2 | This file is part of KAddressBook. |
3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> | 3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> |
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 | #include <qcheckbox.h> | 24 | #include <qcheckbox.h> |
25 | #include <qframe.h> | 25 | #include <qframe.h> |
26 | #include <qgroupbox.h> | 26 | #include <qgroupbox.h> |
27 | #include <qlayout.h> | 27 | #include <qlayout.h> |
28 | #include <qpushbutton.h> | 28 | #include <qpushbutton.h> |
29 | #include <qtabwidget.h> | 29 | #include <qtabwidget.h> |
30 | #include <qcombobox.h> | 30 | #include <qcombobox.h> |
31 | #include <qlineedit.h> | 31 | #include <qlineedit.h> |
32 | #include <qlabel.h> | 32 | #include <qlabel.h> |
33 | #include <qfile.h> | 33 | #include <qfile.h> |
34 | #include <qvbox.h> | 34 | #include <qvbox.h> |
35 | 35 | ||
36 | #include <kconfig.h> | 36 | #include <kconfig.h> |
37 | #include <kdebug.h> | 37 | #include <kdebug.h> |
38 | #include <kdialog.h> | 38 | #include <kdialog.h> |
39 | #include <klistview.h> | 39 | #include <klistview.h> |
40 | #include <klocale.h> | 40 | #include <klocale.h> |
41 | #include <kglobal.h> | 41 | #include <kglobal.h> |
42 | #include <kmessagebox.h> | 42 | #include <kmessagebox.h> |
43 | #include <kstandarddirs.h> | 43 | #include <kstandarddirs.h> |
44 | 44 | ||
45 | #ifndef KAB_EMBEDDED | 45 | #ifndef KAB_EMBEDDED |
46 | #include <ktrader.h> | 46 | #include <ktrader.h> |
47 | #else // KAB_EMBEDDED | 47 | #else // KAB_EMBEDDED |
48 | #include <mergewidget.h> | 48 | #include <mergewidget.h> |
49 | #include <distributionlistwidget.h> | 49 | #include <distributionlistwidget.h> |
50 | #endif // KAB_EMBEDDED | 50 | #endif // KAB_EMBEDDED |
51 | 51 | ||
52 | #include "addresseewidget.h" | 52 | #include "addresseewidget.h" |
53 | #include "extensionconfigdialog.h" | 53 | #include "extensionconfigdialog.h" |
54 | #include "extensionwidget.h" | 54 | #include "extensionwidget.h" |
55 | #include "kabprefs.h" | 55 | #include "kabprefs.h" |
56 | 56 | ||
57 | #include "kabconfigwidget.h" | 57 | #include "kabconfigwidget.h" |
58 | 58 | ||
59 | class ExtensionItem : public QCheckListItem | 59 | class ExtensionItem : public QCheckListItem |
60 | { | 60 | { |
61 | public: | 61 | public: |
62 | 62 | ||
63 | #ifndef KAB_EMBEDDED | 63 | #ifndef KAB_EMBEDDED |
64 | ExtensionItem( QListView *parent, const QString &text ); | 64 | ExtensionItem( QListView *parent, const QString &text ); |
65 | void setService( const KService::Ptr &ptr ); | 65 | void setService( const KService::Ptr &ptr ); |
66 | #else //KAB_EMBEDDED | 66 | #else //KAB_EMBEDDED |
67 | ExtensionItem( QListView *parent, const QString &text, const QString &name, const QString &comment ); | 67 | ExtensionItem( QListView *parent, const QString &text, const QString &name, const QString &comment ); |
68 | void setFactory( ExtensionFactory* fac ); | 68 | void setFactory( ExtensionFactory* fac ); |
69 | #endif //KAB_EMBEDDED | 69 | #endif //KAB_EMBEDDED |
70 | 70 | ||
71 | bool configWidgetAvailable() const; | 71 | bool configWidgetAvailable() const; |
72 | ExtensionFactory *factory() const; | 72 | ExtensionFactory *factory() const; |
73 | 73 | ||
74 | virtual QString text( int column ) const; | 74 | virtual QString text( int column ) const; |
75 | 75 | ||
76 | private: | 76 | private: |
77 | #ifndef KAB_EMBEDDED | 77 | #ifndef KAB_EMBEDDED |
78 | KService::Ptr mPtr; | 78 | KService::Ptr mPtr; |
79 | #else //KAB_EMBEDDED | 79 | #else //KAB_EMBEDDED |
80 | ExtensionFactory* mFactory; | 80 | ExtensionFactory* mFactory; |
81 | QString mName; | 81 | QString mName; |
82 | QString mComment; | 82 | QString mComment; |
83 | 83 | ||
84 | #endif //KAB_EMBEDDED | 84 | #endif //KAB_EMBEDDED |
85 | 85 | ||
86 | }; | 86 | }; |
87 | 87 | ||
88 | KABConfigWidget::KABConfigWidget( QWidget *parent, const char *name ) | 88 | KABConfigWidget::KABConfigWidget( KABPrefs* prefs, QWidget *parent, const char *name ) |
89 | : QWidget( parent, name ) | 89 | : KPrefsWidget( prefs, parent, name ) |
90 | { | 90 | { |
91 | QVBoxLayout *topLayout = new QVBoxLayout( this, 0, | 91 | QVBoxLayout *topLayout = new QVBoxLayout( this, 0, |
92 | KDialog::spacingHint() ); | 92 | KDialog::spacingHint() ); |
93 | 93 | ||
94 | QTabWidget *tabWidget = new QTabWidget( this ); | 94 | QTabWidget *tabWidget = new QTabWidget( this ); |
95 | topLayout->addWidget( tabWidget ); | 95 | topLayout->addWidget( tabWidget ); |
96 | 96 | ||
97 | // General page | 97 | // General page |
98 | QWidget *generalPage = new QWidget( this ); | 98 | QWidget *generalPage = new QWidget( this ); |
99 | QVBoxLayout *layout = new QVBoxLayout( generalPage, KDialog::marginHintSmall(), | 99 | QVBoxLayout *layout = new QVBoxLayout( generalPage, KDialog::marginHintSmall(), |
100 | KDialog::spacingHintSmall() ); | 100 | KDialog::spacingHintSmall() ); |
101 | //general groupbox | 101 | //general groupbox |
102 | QVBox *vBox = new QVBox( generalPage, "qvbox" ); | 102 | QVBox *vBox = new QVBox( generalPage, "qvbox" ); |
103 | QVBoxLayout *boxLayout = new QVBoxLayout( vBox->layout(), -1, "qvboxlayout" ); | 103 | QVBoxLayout *boxLayout = new QVBoxLayout( vBox->layout(), -1, "qvboxlayout" ); |
104 | boxLayout->setAlignment( Qt::AlignTop ); | 104 | boxLayout->setAlignment( Qt::AlignTop ); |
105 | boxLayout->setMargin(KDialog::marginHintSmall() ); | 105 | boxLayout->setMargin(KDialog::marginHintSmall() ); |
106 | vBox->layout()->setMargin(KDialog::marginHintSmall()) ; | 106 | vBox->layout()->setMargin(KDialog::marginHintSmall()) ; |
107 | vBox->layout()->setSpacing(KDialog::spacingHintSmall()); | 107 | vBox->layout()->setSpacing(KDialog::spacingHintSmall()); |
108 | boxLayout->setSpacing( KDialog::spacingHintSmall() ); | 108 | boxLayout->setSpacing( KDialog::spacingHintSmall() ); |
109 | mSearchReturnBox = new QCheckBox( i18n( "Search only after <return> key pressed" ), vBox, "mreturn" ); | 109 | mSearchReturnBox = new QCheckBox( i18n( "Search only after <return> key pressed" ), vBox, "mreturn" ); |
110 | boxLayout->addWidget( mSearchReturnBox ); | 110 | boxLayout->addWidget( mSearchReturnBox ); |
111 | mViewsSingleClickBox = new QCheckBox( i18n( "Honor KDE single click" ), vBox, "msingle" ); | 111 | mViewsSingleClickBox = new QCheckBox( i18n( "Honor KDE single click" ), vBox, "msingle" ); |
112 | boxLayout->addWidget( mViewsSingleClickBox ); | 112 | boxLayout->addWidget( mViewsSingleClickBox ); |
113 | 113 | ||
114 | mNameParsing = new QCheckBox( i18n( "Automatic name parsing for new addressees" ), vBox, "mparse" ); | 114 | mNameParsing = new QCheckBox( i18n( "Automatic name parsing for new addressees" ), vBox, "mparse" ); |
115 | boxLayout->addWidget( mNameParsing ); | 115 | boxLayout->addWidget( mNameParsing ); |
116 | 116 | ||
117 | mMultipleViewsAtOnce = new QCheckBox( i18n( "Display List and Details at once (restart)" ), vBox, "mdisplay" ); | 117 | mMultipleViewsAtOnce = new QCheckBox( i18n( "Display List and Details at once (restart)" ), vBox, "mdisplay" ); |
118 | boxLayout->addWidget( mMultipleViewsAtOnce ); | 118 | boxLayout->addWidget( mMultipleViewsAtOnce ); |
119 | 119 | ||
120 | mAskForQuit = new QCheckBox( i18n( "Ask for quit when closing Ka/Pi" ), vBox, "mquit" ); | 120 | mAskForQuit = new QCheckBox( i18n( "Ask for quit when closing Ka/Pi" ), vBox, "mquit" ); |
121 | boxLayout->addWidget( mAskForQuit ); | 121 | boxLayout->addWidget( mAskForQuit ); |
122 | 122 | ||
123 | layout->addWidget( vBox ); | 123 | layout->addWidget( vBox ); |
124 | 124 | ||
125 | tabWidget->addTab( generalPage, i18n( "General" ) ); | 125 | tabWidget->addTab( generalPage, i18n( "General" ) ); |
126 | 126 | ||
127 | // Extension page | 127 | // Extension page |
128 | QWidget *extensionPage = new QWidget( this ); | 128 | QWidget *extensionPage = new QWidget( this ); |
129 | QVBoxLayout *extensionLayout = new QVBoxLayout( extensionPage, KDialog::marginHintSmall(), | 129 | QVBoxLayout *extensionLayout = new QVBoxLayout( extensionPage, KDialog::marginHintSmall(), |
130 | KDialog::spacingHintSmall() ); | 130 | KDialog::spacingHintSmall() ); |
131 | 131 | ||
132 | //extensions groupbox | 132 | //extensions groupbox |
133 | 133 | ||
134 | QGroupBox* groupBox = new QGroupBox( 0, Qt::Vertical, i18n( "Extensions (restart)" ), extensionPage ); | 134 | QGroupBox* groupBox = new QGroupBox( 0, Qt::Vertical, i18n( "Extensions (restart)" ), extensionPage ); |
135 | boxLayout = new QVBoxLayout( groupBox->layout() ); | 135 | boxLayout = new QVBoxLayout( groupBox->layout() ); |
136 | boxLayout->setAlignment( Qt::AlignTop ); | 136 | boxLayout->setAlignment( Qt::AlignTop ); |
137 | boxLayout->setMargin(KDialog::marginHintSmall()); | 137 | boxLayout->setMargin(KDialog::marginHintSmall()); |
138 | boxLayout->setSpacing(KDialog::spacingHintSmall()); | 138 | boxLayout->setSpacing(KDialog::spacingHintSmall()); |
139 | groupBox->layout()->setMargin(1) ; | 139 | groupBox->layout()->setMargin(1) ; |
140 | groupBox->layout()->setSpacing(0); | 140 | groupBox->layout()->setSpacing(0); |
141 | mExtensionView = new KListView( groupBox ); | 141 | mExtensionView = new KListView( groupBox ); |
142 | mExtensionView->setAllColumnsShowFocus( true ); | 142 | mExtensionView->setAllColumnsShowFocus( true ); |
143 | mExtensionView->addColumn( i18n( "Name" ) ); | 143 | mExtensionView->addColumn( i18n( "Name" ) ); |
144 | mExtensionView->addColumn( i18n( "Description" ) ); | 144 | mExtensionView->addColumn( i18n( "Description" ) ); |
145 | mExtensionView->setMaximumHeight(80); | 145 | mExtensionView->setMaximumHeight(80); |
146 | 146 | ||
147 | boxLayout->addWidget( mExtensionView ); | 147 | boxLayout->addWidget( mExtensionView ); |
148 | 148 | ||
149 | mConfigureButton = new QPushButton( i18n( "Configure..." ), groupBox ); | 149 | mConfigureButton = new QPushButton( i18n( "Configure..." ), groupBox ); |
150 | mConfigureButton->setEnabled( false ); | 150 | mConfigureButton->setEnabled( false ); |
151 | boxLayout->addWidget( mConfigureButton ); | 151 | boxLayout->addWidget( mConfigureButton ); |
152 | 152 | ||
153 | extensionLayout->addWidget( groupBox ); | 153 | extensionLayout->addWidget( groupBox ); |
154 | 154 | ||
155 | connect( mNameParsing, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); | 155 | connect( mNameParsing, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); |
156 | connect( mViewsSingleClickBox, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); | 156 | connect( mViewsSingleClickBox, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); |
157 | connect( mSearchReturnBox, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); | 157 | connect( mSearchReturnBox, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); |
158 | connect( mMultipleViewsAtOnce, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); | 158 | connect( mMultipleViewsAtOnce, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); |
159 | connect( mAskForQuit, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); | 159 | connect( mAskForQuit, SIGNAL( toggled( bool ) ), this, SLOT( modified() ) ); |
160 | connect( mExtensionView, SIGNAL( selectionChanged( QListViewItem* ) ), | 160 | connect( mExtensionView, SIGNAL( selectionChanged( QListViewItem* ) ), |
161 | SLOT( selectionChanged( QListViewItem* ) ) ); | 161 | SLOT( selectionChanged( QListViewItem* ) ) ); |
162 | connect( mExtensionView, SIGNAL( clicked( QListViewItem* ) ), | 162 | connect( mExtensionView, SIGNAL( clicked( QListViewItem* ) ), |
163 | SLOT( itemClicked( QListViewItem* ) ) ); | 163 | SLOT( itemClicked( QListViewItem* ) ) ); |
164 | connect( mConfigureButton, SIGNAL( clicked() ), | 164 | connect( mConfigureButton, SIGNAL( clicked() ), |
165 | SLOT( configureExtension() ) ); | 165 | SLOT( configureExtension() ) ); |
166 | 166 | ||
167 | tabWidget->addTab( extensionPage, i18n( "Extensions" ) ); | 167 | tabWidget->addTab( extensionPage, i18n( "Extensions" ) ); |
168 | 168 | ||
169 | // Addressee page | 169 | // Addressee page |
170 | mAddresseeWidget = new AddresseeWidget( this ); | 170 | mAddresseeWidget = new AddresseeWidget( this ); |
171 | tabWidget->addTab( mAddresseeWidget, i18n( "Contact" ) ); | 171 | tabWidget->addTab( mAddresseeWidget, i18n( "Contact" ) ); |
172 | connect( mAddresseeWidget, SIGNAL( modified() ), SLOT( modified() ) ); | 172 | connect( mAddresseeWidget, SIGNAL( modified() ), SLOT( modified() ) ); |
173 | 173 | ||
174 | } | 174 | } |
175 | 175 | ||
176 | 176 | void KABConfigWidget::usrReadConfig() | |
177 | void KABConfigWidget::restoreSettings(KABPrefs* prefs) | ||
178 | { | 177 | { |
179 | //US prefs was KABPrefs::instance() before | 178 | KABPrefs* prefs = KABPrefs::instance(); |
180 | 179 | ||
181 | bool blocked = signalsBlocked(); | 180 | bool blocked = signalsBlocked(); |
182 | blockSignals( true ); | 181 | blockSignals( true ); |
183 | 182 | ||
184 | mNameParsing->setChecked( prefs->mAutomaticNameParsing ); | 183 | mNameParsing->setChecked( prefs->mAutomaticNameParsing ); |
185 | mViewsSingleClickBox->setChecked( prefs->mHonorSingleClick ); | 184 | mViewsSingleClickBox->setChecked( prefs->mHonorSingleClick ); |
186 | mSearchReturnBox->setChecked( prefs->mSearchWithReturn ); | 185 | mSearchReturnBox->setChecked( prefs->mSearchWithReturn ); |
187 | mMultipleViewsAtOnce->setChecked( prefs->mMultipleViewsAtOnce ); | 186 | mMultipleViewsAtOnce->setChecked( prefs->mMultipleViewsAtOnce ); |
188 | mAskForQuit->setChecked( prefs->mAskForQuit ); | 187 | mAskForQuit->setChecked( prefs->mAskForQuit ); |
189 | 188 | ||
190 | mAddresseeWidget->restoreSettings(); | 189 | mAddresseeWidget->restoreSettings(); |
191 | 190 | ||
192 | restoreExtensionSettings(); | 191 | restoreExtensionSettings(); |
193 | 192 | ||
194 | blockSignals( blocked ); | 193 | blockSignals( blocked ); |
195 | 194 | ||
196 | emit changed( false ); | ||
197 | } | 195 | } |
198 | 196 | ||
199 | void KABConfigWidget::saveSettings(KABPrefs* prefs) | 197 | void KABConfigWidget::usrWriteConfig() |
200 | { | 198 | { |
199 | KABPrefs* prefs = KABPrefs::instance(); | ||
200 | |||
201 | prefs->mAutomaticNameParsing = mNameParsing->isChecked(); | 201 | prefs->mAutomaticNameParsing = mNameParsing->isChecked(); |
202 | prefs->mHonorSingleClick = mViewsSingleClickBox->isChecked(); | 202 | prefs->mHonorSingleClick = mViewsSingleClickBox->isChecked(); |
203 | prefs->mSearchWithReturn = mSearchReturnBox->isChecked(); | 203 | prefs->mSearchWithReturn = mSearchReturnBox->isChecked(); |
204 | prefs->mMultipleViewsAtOnce = mMultipleViewsAtOnce->isChecked(); | 204 | prefs->mMultipleViewsAtOnce = mMultipleViewsAtOnce->isChecked(); |
205 | prefs->mAskForQuit = mAskForQuit->isChecked(); | 205 | prefs->mAskForQuit = mAskForQuit->isChecked(); |
206 | 206 | ||
207 | mAddresseeWidget->saveSettings(); | 207 | mAddresseeWidget->saveSettings(); |
208 | 208 | ||
209 | saveExtensionSettings(); | 209 | saveExtensionSettings(); |
210 | KABPrefs::instance()->writeConfig(); | ||
211 | 210 | ||
212 | emit changed( false ); | ||
213 | } | ||
214 | |||
215 | void KABConfigWidget::defaults(KABPrefs* prefs) | ||
216 | { | ||
217 | mNameParsing->setChecked( true ); | ||
218 | mViewsSingleClickBox->setChecked( false ); | ||
219 | mMultipleViewsAtOnce->setChecked( true ); | ||
220 | mSearchReturnBox->setChecked( true ); | ||
221 | mAskForQuit->setChecked (true); | ||
222 | |||
223 | emit changed( true ); | ||
224 | } | ||
225 | |||
226 | void KABConfigWidget::modified() | ||
227 | { | ||
228 | emit changed( true ); | ||
229 | } | 211 | } |
230 | 212 | ||
231 | void KABConfigWidget::restoreExtensionSettings() | 213 | void KABConfigWidget::restoreExtensionSettings() |
232 | { | 214 | { |
233 | QStringList activeExtensions = KABPrefs::instance()->mActiveExtensions; | 215 | QStringList activeExtensions = KABPrefs::instance()->mActiveExtensions; |
234 | 216 | ||
235 | mExtensionView->clear(); | 217 | mExtensionView->clear(); |
236 | 218 | ||
237 | #ifndef KAB_EMBEDDED | 219 | #ifndef KAB_EMBEDDED |
238 | KTrader::OfferList plugins = KTrader::self()->query( "KAddressBook/Extension" ); | 220 | KTrader::OfferList plugins = KTrader::self()->query( "KAddressBook/Extension" ); |
239 | KTrader::OfferList::ConstIterator it; | 221 | KTrader::OfferList::ConstIterator it; |
240 | for ( it = plugins.begin(); it != plugins.end(); ++it ) { | 222 | for ( it = plugins.begin(); it != plugins.end(); ++it ) { |
241 | if ( !(*it)->hasServiceType( "KAddressBook/Extension" ) ) | 223 | if ( !(*it)->hasServiceType( "KAddressBook/Extension" ) ) |
242 | continue; | 224 | continue; |
243 | 225 | ||
244 | ExtensionItem *item = new ExtensionItem( mExtensionView, (*it)->name() ); | 226 | ExtensionItem *item = new ExtensionItem( mExtensionView, (*it)->name() ); |
245 | item->setService( *it ); | 227 | item->setService( *it ); |
246 | if ( activeExtensions.contains( item->factory()->identifier() ) ) | 228 | if ( activeExtensions.contains( item->factory()->identifier() ) ) |
247 | item->setOn( true ); | 229 | item->setOn( true ); |
248 | } | 230 | } |
249 | #else //KAB_EMBEDDED | 231 | #else //KAB_EMBEDDED |
250 | ExtensionFactory *extensionFactory = new MergeFactory(); | 232 | ExtensionFactory *extensionFactory = new MergeFactory(); |
251 | 233 | ||
252 | ExtensionItem *item = new ExtensionItem( mExtensionView, "Merge", "Merge", "Merge contacts"); | 234 | ExtensionItem *item = new ExtensionItem( mExtensionView, "Merge", "Merge", "Merge contacts"); |
253 | 235 | ||
254 | item->setFactory( extensionFactory ); | 236 | item->setFactory( extensionFactory ); |
255 | if ( activeExtensions.contains( extensionFactory->identifier() ) ) | 237 | if ( activeExtensions.contains( extensionFactory->identifier() ) ) |
256 | item->setOn( true ); | 238 | item->setOn( true ); |
257 | 239 | ||
258 | 240 | ||
259 | 241 | ||
260 | extensionFactory = new DistributionListFactory(); | 242 | extensionFactory = new DistributionListFactory(); |
261 | 243 | ||
262 | item = new ExtensionItem( mExtensionView, "Distribution List", "Distribution List", "Manage Distribution Lists"); | 244 | item = new ExtensionItem( mExtensionView, "Distribution List", "Distribution List", "Manage Distribution Lists"); |
263 | 245 | ||
264 | item->setFactory( extensionFactory ); | 246 | item->setFactory( extensionFactory ); |
265 | if ( activeExtensions.contains( extensionFactory->identifier() ) ) | 247 | if ( activeExtensions.contains( extensionFactory->identifier() ) ) |
266 | item->setOn( true ); | 248 | item->setOn( true ); |
267 | 249 | ||
268 | 250 | ||
269 | #endif //KAB_EMBEDDED | 251 | #endif //KAB_EMBEDDED |
270 | 252 | ||
271 | } | 253 | } |
272 | 254 | ||
273 | void KABConfigWidget::saveExtensionSettings() | 255 | void KABConfigWidget::saveExtensionSettings() |
274 | { | 256 | { |
275 | QStringList activeExtensions; | 257 | QStringList activeExtensions; |
276 | 258 | ||
277 | QPtrList<QListViewItem> list; | 259 | QPtrList<QListViewItem> list; |
278 | QListViewItemIterator it( mExtensionView ); | 260 | QListViewItemIterator it( mExtensionView ); |
279 | while ( it.current() ) { | 261 | while ( it.current() ) { |
280 | ExtensionItem *item = static_cast<ExtensionItem*>( it.current() ); | 262 | ExtensionItem *item = static_cast<ExtensionItem*>( it.current() ); |
281 | if ( item ) { | 263 | if ( item ) { |
282 | if ( item->isOn() ) | 264 | if ( item->isOn() ) |
283 | activeExtensions.append( item->factory()->identifier() ); | 265 | activeExtensions.append( item->factory()->identifier() ); |
284 | } | 266 | } |
285 | ++it; | 267 | ++it; |
286 | } | 268 | } |
287 | 269 | ||
288 | KABPrefs::instance()->mActiveExtensions = activeExtensions; | 270 | KABPrefs::instance()->mActiveExtensions = activeExtensions; |
289 | } | 271 | } |
290 | 272 | ||
291 | void KABConfigWidget::configureExtension() | 273 | void KABConfigWidget::configureExtension() |
292 | { | 274 | { |
293 | ExtensionItem *item = static_cast<ExtensionItem*>( mExtensionView->currentItem() ); | 275 | ExtensionItem *item = static_cast<ExtensionItem*>( mExtensionView->currentItem() ); |
294 | if ( !item ) | 276 | if ( !item ) |
295 | return; | 277 | return; |
296 | 278 | ||
297 | #ifndef KAB_EMBEDDED | 279 | #ifndef KAB_EMBEDDED |
298 | KConfig config( "kaddressbookrc" ); | 280 | KConfig config( "kaddressbookrc" ); |
299 | #else //KAB_EMBEDDED | 281 | #else //KAB_EMBEDDED |
300 | KConfig config( locateLocal("config", "kaddressbookrc") ); | 282 | KConfig config( locateLocal("config", "kaddressbookrc") ); |
301 | #endif //KAB_EMBEDDED | 283 | #endif //KAB_EMBEDDED |
302 | config.setGroup( QString( "Extensions_%1" ).arg( item->factory()->identifier() ) ); | 284 | config.setGroup( QString( "Extensions_%1" ).arg( item->factory()->identifier() ) ); |
303 | 285 | ||
304 | ExtensionConfigDialog dlg( item->factory(), &config, this ); | 286 | ExtensionConfigDialog dlg( item->factory(), &config, this ); |
305 | dlg.exec(); | 287 | dlg.exec(); |
306 | 288 | ||
307 | config.sync(); | 289 | config.sync(); |
308 | } | 290 | } |
309 | 291 | ||
310 | void KABConfigWidget::selectionChanged( QListViewItem *i ) | 292 | void KABConfigWidget::selectionChanged( QListViewItem *i ) |
311 | { | 293 | { |
312 | ExtensionItem *item = static_cast<ExtensionItem*>( i ); | 294 | ExtensionItem *item = static_cast<ExtensionItem*>( i ); |
313 | if ( !item ) | 295 | if ( !item ) |
314 | return; | 296 | return; |
315 | 297 | ||
316 | mConfigureButton->setEnabled( item->configWidgetAvailable() ); | 298 | mConfigureButton->setEnabled( item->configWidgetAvailable() ); |
317 | } | 299 | } |
318 | 300 | ||
319 | void KABConfigWidget::itemClicked( QListViewItem *item ) | 301 | void KABConfigWidget::itemClicked( QListViewItem *item ) |
320 | { | 302 | { |
321 | if ( item != 0 ) | 303 | if ( item != 0 ) |
322 | modified(); | 304 | modified(); |
323 | } | 305 | } |
324 | 306 | ||
325 | #ifndef KAB_EMBEDDED | 307 | #ifndef KAB_EMBEDDED |
326 | ExtensionItem::ExtensionItem( QListView *parent, const QString &text ) | 308 | ExtensionItem::ExtensionItem( QListView *parent, const QString &text ) |
327 | : QCheckListItem( parent, text, CheckBox ) | 309 | : QCheckListItem( parent, text, CheckBox ) |
328 | { | 310 | { |
329 | } | 311 | } |
330 | 312 | ||
331 | void ExtensionItem::setService( const KService::Ptr &ptr ) | 313 | void ExtensionItem::setService( const KService::Ptr &ptr ) |
332 | { | 314 | { |
333 | mPtr = ptr; | 315 | mPtr = ptr; |
334 | } | 316 | } |
335 | #else //KAB_EMBEDDED | 317 | #else //KAB_EMBEDDED |
336 | ExtensionItem::ExtensionItem( QListView *parent, const QString &text, const QString &name, const QString &comment ) | 318 | ExtensionItem::ExtensionItem( QListView *parent, const QString &text, const QString &name, const QString &comment ) |
337 | : QCheckListItem( parent, text, CheckBox ) | 319 | : QCheckListItem( parent, text, CheckBox ) |
338 | { | 320 | { |
339 | mName = name; | 321 | mName = name; |
340 | mComment = comment; | 322 | mComment = comment; |
341 | } | 323 | } |
342 | 324 | ||
343 | 325 | ||
344 | void ExtensionItem::setFactory( ExtensionFactory* fac ) | 326 | void ExtensionItem::setFactory( ExtensionFactory* fac ) |
345 | { | 327 | { |
346 | mFactory = fac; | 328 | mFactory = fac; |
347 | } | 329 | } |
348 | #endif //KAB_EMBEDDED | 330 | #endif //KAB_EMBEDDED |
349 | 331 | ||
350 | bool ExtensionItem::configWidgetAvailable() const | 332 | bool ExtensionItem::configWidgetAvailable() const |
351 | { | 333 | { |
352 | #ifndef KAB_EMBEDDED | 334 | #ifndef KAB_EMBEDDED |
353 | KLibFactory *factory = KLibLoader::self()->factory( mPtr->library().latin1() ); | 335 | KLibFactory *factory = KLibLoader::self()->factory( mPtr->library().latin1() ); |
354 | if ( !factory ) | 336 | if ( !factory ) |
355 | return false; | 337 | return false; |
356 | 338 | ||
diff --git a/kaddressbook/kcmconfigs/kabconfigwidget.h b/kaddressbook/kcmconfigs/kabconfigwidget.h index 6cd4223..1e71fd1 100644 --- a/kaddressbook/kcmconfigs/kabconfigwidget.h +++ b/kaddressbook/kcmconfigs/kabconfigwidget.h | |||
@@ -1,79 +1,75 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KAddressBook. | 2 | This file is part of KAddressBook. |
3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> | 3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> |
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 | #ifndef KABCONFIGWIDGET_H | 24 | #ifndef KABCONFIGWIDGET_H |
25 | #define KABCONFIGWIDGET_H | 25 | #define KABCONFIGWIDGET_H |
26 | 26 | ||
27 | #include <qwidget.h> | 27 | #include <kprefswidget.h> |
28 | 28 | ||
29 | class QCheckBox; | 29 | class QCheckBox; |
30 | class QListViewItem; | 30 | class QListViewItem; |
31 | class QPushButton; | 31 | class QPushButton; |
32 | class QComboBox; | 32 | class QComboBox; |
33 | class QLineEdit; | 33 | class QLineEdit; |
34 | class KListView; | 34 | class KListView; |
35 | class KABPrefs; | 35 | class KABPrefs; |
36 | 36 | ||
37 | class AddresseeWidget; | 37 | class AddresseeWidget; |
38 | 38 | ||
39 | class KABConfigWidget : public QWidget | 39 | class KABConfigWidget : public KPrefsWidget |
40 | { | 40 | { |
41 | Q_OBJECT | 41 | Q_OBJECT |
42 | 42 | ||
43 | public: | 43 | public: |
44 | KABConfigWidget( QWidget *parent, const char *name = 0 ); | 44 | KABConfigWidget(KABPrefs *prefs, QWidget *parent, const char *name = 0 ); |
45 | 45 | ||
46 | void restoreSettings(KABPrefs* prefs); | 46 | protected: |
47 | void saveSettings(KABPrefs* prefs); | 47 | /** Implement this to read custom configuration widgets. */ |
48 | void defaults(KABPrefs* prefs); | 48 | virtual void usrReadConfig(); |
49 | 49 | /** Implement this to write custom configuration widgets. */ | |
50 | signals: | 50 | virtual void usrWriteConfig(); |
51 | void changed( bool ); | ||
52 | |||
53 | public slots: | ||
54 | void modified(); | ||
55 | 51 | ||
56 | 52 | ||
57 | 53 | ||
58 | private slots: | 54 | private slots: |
59 | void configureExtension(); | 55 | void configureExtension(); |
60 | void selectionChanged( QListViewItem* ); | 56 | void selectionChanged( QListViewItem* ); |
61 | void itemClicked( QListViewItem* ); | 57 | void itemClicked( QListViewItem* ); |
62 | 58 | ||
63 | private: | 59 | private: |
64 | void restoreExtensionSettings(); | 60 | void restoreExtensionSettings(); |
65 | void saveExtensionSettings(); | 61 | void saveExtensionSettings(); |
66 | 62 | ||
67 | KListView *mExtensionView; | 63 | KListView *mExtensionView; |
68 | QCheckBox *mSearchReturnBox; | 64 | QCheckBox *mSearchReturnBox; |
69 | QCheckBox *mNameParsing; | 65 | QCheckBox *mNameParsing; |
70 | QCheckBox *mViewsSingleClickBox; | 66 | QCheckBox *mViewsSingleClickBox; |
71 | QCheckBox *mMultipleViewsAtOnce; | 67 | QCheckBox *mMultipleViewsAtOnce; |
72 | QCheckBox *mAskForQuit; | 68 | QCheckBox *mAskForQuit; |
73 | 69 | ||
74 | QPushButton *mConfigureButton; | 70 | QPushButton *mConfigureButton; |
75 | 71 | ||
76 | AddresseeWidget *mAddresseeWidget; | 72 | AddresseeWidget *mAddresseeWidget; |
77 | }; | 73 | }; |
78 | 74 | ||
79 | #endif | 75 | #endif |
diff --git a/kaddressbook/kcmconfigs/kcmkabconfig.cpp b/kaddressbook/kcmconfigs/kcmkabconfig.cpp index b460a81..cbfedbd 100644 --- a/kaddressbook/kcmconfigs/kcmkabconfig.cpp +++ b/kaddressbook/kcmconfigs/kcmkabconfig.cpp | |||
@@ -1,92 +1,92 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KAddressBook. | 2 | This file is part of KAddressBook. |
3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> | 3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> |
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 | #include <qlayout.h> | 24 | #include <qlayout.h> |
25 | 25 | ||
26 | #ifndef KAB_EMBEDDED | 26 | #ifndef KAB_EMBEDDED |
27 | #include <kaboutdata.h> | 27 | #include <kaboutdata.h> |
28 | #endif //KAB_EMBEDDED | 28 | #endif //KAB_EMBEDDED |
29 | #include <kdebug.h> | 29 | #include <kdebug.h> |
30 | //#include <klocale.h> | 30 | //#include <klocale.h> |
31 | //#include <stdlib.h> | 31 | //#include <stdlib.h> |
32 | 32 | ||
33 | #include "kabconfigwidget.h" | 33 | #include "kabconfigwidget.h" |
34 | 34 | ||
35 | #include "kcmkabconfig.h" | 35 | #include "kcmkabconfig.h" |
36 | 36 | ||
37 | #include "kabprefs.h" | 37 | #include "kabprefs.h" |
38 | #include "kprefs.h" | 38 | #include "kprefs.h" |
39 | 39 | ||
40 | extern "C" | 40 | extern "C" |
41 | { | 41 | { |
42 | KCModule *create_kabconfig( KABPrefs* prefs, QWidget *parent, const char * ) { | 42 | KCModule *create_kabconfig( QWidget *parent, const char * ) { |
43 | return new KCMKabConfig( prefs, parent, "kcmkabconfig" ); | 43 | return new KCMKabConfig( parent, "kcmkabconfig" ); |
44 | } | 44 | } |
45 | } | 45 | } |
46 | 46 | ||
47 | KCMKabConfig::KCMKabConfig( KABPrefs* prefs, QWidget *parent, const char *name ) | 47 | KCMKabConfig::KCMKabConfig( QWidget *parent, const char *name ) |
48 | : KCModule( prefs, parent, name ) | 48 | : KCModule( KABPrefs::instance(), parent, name ) |
49 | { | 49 | { |
50 | //abort(); | 50 | //abort(); |
51 | QVBoxLayout *layout = new QVBoxLayout( this ); | 51 | QVBoxLayout *layout = new QVBoxLayout( this ); |
52 | mConfigWidget = new KABConfigWidget( this, "mConfigWidget" ); | 52 | mConfigWidget = new KABConfigWidget( (KABPrefs*)getPreferences(), this, "KABConfigWidget" ); |
53 | layout->addWidget( mConfigWidget ); | 53 | layout->addWidget( mConfigWidget ); |
54 | layout->setSpacing( 0 ); | 54 | layout->setSpacing( 0 ); |
55 | layout->setMargin( 0 ); | 55 | layout->setMargin( 0 ); |
56 | 56 | ||
57 | connect( mConfigWidget, SIGNAL( changed( bool ) ), SIGNAL( changed( bool ) ) ); | 57 | connect( mConfigWidget, SIGNAL( changed( bool ) ), SIGNAL( changed( bool ) ) ); |
58 | } | 58 | } |
59 | 59 | ||
60 | void KCMKabConfig::load() | 60 | void KCMKabConfig::load() |
61 | { | 61 | { |
62 | mConfigWidget->restoreSettings((KABPrefs*)getPreferences()); | 62 | mConfigWidget->readConfig(); |
63 | } | 63 | } |
64 | 64 | ||
65 | void KCMKabConfig::save() | 65 | void KCMKabConfig::save() |
66 | { | 66 | { |
67 | mConfigWidget->saveSettings((KABPrefs*)getPreferences()); | 67 | mConfigWidget->writeConfig(); |
68 | } | 68 | } |
69 | 69 | ||
70 | void KCMKabConfig::defaults() | 70 | void KCMKabConfig::defaults() |
71 | { | 71 | { |
72 | mConfigWidget->defaults((KABPrefs*)getPreferences()); | 72 | mConfigWidget->setDefaults(); |
73 | } | 73 | } |
74 | 74 | ||
75 | #ifndef KAB_EMBEDDED | 75 | #ifndef KAB_EMBEDDED |
76 | const KAboutData* KCMKabConfig::aboutData() const | 76 | const KAboutData* KCMKabConfig::aboutData() const |
77 | { | 77 | { |
78 | KAboutData *about = new KAboutData( I18N_NOOP( "kcmkabconfig" ), | 78 | KAboutData *about = new KAboutData( I18N_NOOP( "kcmkabconfig" ), |
79 | I18N_NOOP( "KAddressBook Configure Dialog" ), | 79 | I18N_NOOP( "KAddressBook Configure Dialog" ), |
80 | 0, 0, KAboutData::License_GPL, | 80 | 0, 0, KAboutData::License_GPL, |
81 | I18N_NOOP( "(c), 2003 Tobias Koenig" ) ); | 81 | I18N_NOOP( "(c), 2003 Tobias Koenig" ) ); |
82 | 82 | ||
83 | about->addAuthor( "Tobias Koenig", 0, "tokoe@kde.org" ); | 83 | about->addAuthor( "Tobias Koenig", 0, "tokoe@kde.org" ); |
84 | 84 | ||
85 | return about; | 85 | return about; |
86 | 86 | ||
87 | } | 87 | } |
88 | #endif //KAB_EMBEDDED | 88 | #endif //KAB_EMBEDDED |
89 | 89 | ||
90 | #ifndef KAB_EMBEDDED | 90 | #ifndef KAB_EMBEDDED |
91 | #include "kcmkabconfig.moc" | 91 | #include "kcmkabconfig.moc" |
92 | #endif //KAB_EMBEDDED | 92 | #endif //KAB_EMBEDDED |
diff --git a/kaddressbook/kcmconfigs/kcmkabconfig.h b/kaddressbook/kcmconfigs/kcmkabconfig.h index 1cb6ad3..2ecbfef 100644 --- a/kaddressbook/kcmconfigs/kcmkabconfig.h +++ b/kaddressbook/kcmconfigs/kcmkabconfig.h | |||
@@ -1,47 +1,47 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KAddressBook. | 2 | This file is part of KAddressBook. |
3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> | 3 | Copyright (c) 2003 Tobias Koenig <tokoe@kde.org> |
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 | #ifndef KCMKABCONFIG_H | 24 | #ifndef KCMKABCONFIG_H |
25 | #define KCMKABCONFIG_H | 25 | #define KCMKABCONFIG_H |
26 | 26 | ||
27 | #include <kcmodule.h> | 27 | #include <kcmodule.h> |
28 | 28 | ||
29 | class KABConfigWidget; | 29 | class KABConfigWidget; |
30 | class KABPrefs; | 30 | class KABPrefs; |
31 | 31 | ||
32 | class KCMKabConfig : public KCModule | 32 | class KCMKabConfig : public KCModule |
33 | { | 33 | { |
34 | Q_OBJECT | 34 | Q_OBJECT |
35 | 35 | ||
36 | public: | 36 | public: |
37 | KCMKabConfig( KABPrefs* prefs, QWidget *parent = 0, const char *name = 0 ); | 37 | KCMKabConfig( QWidget *parent = 0, const char *name = 0 ); |
38 | 38 | ||
39 | virtual void load(); | 39 | virtual void load(); |
40 | virtual void save(); | 40 | virtual void save(); |
41 | virtual void defaults(); | 41 | virtual void defaults(); |
42 | 42 | ||
43 | private: | 43 | private: |
44 | KABConfigWidget *mConfigWidget; | 44 | KABConfigWidget *mConfigWidget; |
45 | }; | 45 | }; |
46 | 46 | ||
47 | #endif | 47 | #endif |