-rw-r--r-- | kaddressbook/kabcore.cpp | 138 | ||||
-rw-r--r-- | kaddressbook/kabcore.h | 7 |
2 files changed, 100 insertions, 45 deletions
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index 96603e6..6807bed 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -176,50 +176,42 @@ KABCore::KABCore( KXMLGUIClient *client, bool readWrite, QWidget *parent, const | |||
176 | //US added this field to become compatible with Opie/qtopia addressbook | 176 | //US added this field to become compatible with Opie/qtopia addressbook |
177 | // values can be "female" or "male" or "". An empty field represents undefined. | 177 | // values can be "female" or "male" or "". An empty field represents undefined. |
178 | mAddressBook->addCustomField( i18n( "Gender" ), KABC::Field::Personal, | 178 | mAddressBook->addCustomField( i18n( "Gender" ), KABC::Field::Personal, |
179 | "X-Gender", "KADDRESSBOOK" ); | 179 | "X-Gender", "KADDRESSBOOK" ); |
180 | mAddressBook->addCustomField( i18n( "Children" ), KABC::Field::Personal, | 180 | mAddressBook->addCustomField( i18n( "Children" ), KABC::Field::Personal, |
181 | "X-Children", "KADDRESSBOOK" ); | 181 | "X-Children", "KADDRESSBOOK" ); |
182 | mAddressBook->addCustomField( i18n( "FreeBusyUrl" ), KABC::Field::Personal, | 182 | mAddressBook->addCustomField( i18n( "FreeBusyUrl" ), KABC::Field::Personal, |
183 | "X-FreeBusyUrl", "KADDRESSBOOK" ); | 183 | "X-FreeBusyUrl", "KADDRESSBOOK" ); |
184 | 184 | ||
185 | initGUI(); | 185 | initGUI(); |
186 | 186 | ||
187 | mIncSearchWidget->setFocus(); | 187 | mIncSearchWidget->setFocus(); |
188 | 188 | ||
189 | 189 | ||
190 | connect( mViewManager, SIGNAL( selected( const QString& ) ), | 190 | connect( mViewManager, SIGNAL( selected( const QString& ) ), |
191 | SLOT( setContactSelected( const QString& ) ) ); | 191 | SLOT( setContactSelected( const QString& ) ) ); |
192 | 192 | connect( mViewManager, SIGNAL( executed( const QString& ) ), | |
193 | //small devices show only the details view. bigger devices can edit the entry | 193 | SLOT( executeContact( const QString& ) ) ); |
194 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | ||
195 | connect( mViewManager, SIGNAL( executed( const QString& ) ), | ||
196 | SLOT( editContact( const QString& ) ) ); | ||
197 | } | ||
198 | else | ||
199 | { | ||
200 | connect( mViewManager, SIGNAL( executed( const QString& ) ), | ||
201 | SLOT( showContact( const QString& ) ) ); | ||
202 | } | ||
203 | 194 | ||
204 | connect( mViewManager, SIGNAL( deleteRequest( ) ), | 195 | connect( mViewManager, SIGNAL( deleteRequest( ) ), |
205 | SLOT( deleteContacts( ) ) ); | 196 | SLOT( deleteContacts( ) ) ); |
206 | connect( mViewManager, SIGNAL( modified() ), | 197 | connect( mViewManager, SIGNAL( modified() ), |
207 | SLOT( setModified() ) ); | 198 | SLOT( setModified() ) ); |
208 | 199 | ||
209 | connect( mExtensionManager, SIGNAL( modified( const KABC::Addressee::List& ) ), this, SLOT( extensionModified( const KABC::Addressee::List& ) ) ); | 200 | connect( mExtensionManager, SIGNAL( modified( const KABC::Addressee::List& ) ), this, SLOT( extensionModified( const KABC::Addressee::List& ) ) ); |
201 | connect( mExtensionManager, SIGNAL( changedActiveExtension( int ) ), this, SLOT( extensionChanged( int ) ) ); | ||
210 | 202 | ||
211 | connect( mXXPortManager, SIGNAL( modified() ), | 203 | connect( mXXPortManager, SIGNAL( modified() ), |
212 | SLOT( setModified() ) ); | 204 | SLOT( setModified() ) ); |
213 | 205 | ||
214 | connect( mJumpButtonBar, SIGNAL( jumpToLetter( const QString& ) ), | 206 | connect( mJumpButtonBar, SIGNAL( jumpToLetter( const QString& ) ), |
215 | SLOT( incrementalSearch( const QString& ) ) ); | 207 | SLOT( incrementalSearch( const QString& ) ) ); |
216 | connect( mIncSearchWidget, SIGNAL( fieldChanged() ), | 208 | connect( mIncSearchWidget, SIGNAL( fieldChanged() ), |
217 | mJumpButtonBar, SLOT( recreateButtons() ) ); | 209 | mJumpButtonBar, SLOT( recreateButtons() ) ); |
218 | 210 | ||
219 | connect( mDetails, SIGNAL( sendEmail( const QString& ) ), | 211 | connect( mDetails, SIGNAL( sendEmail( const QString& ) ), |
220 | SLOT( sendMail( const QString& ) ) ); | 212 | SLOT( sendMail( const QString& ) ) ); |
221 | 213 | ||
222 | #ifndef KAB_EMBEDDED | 214 | #ifndef KAB_EMBEDDED |
223 | connect( mViewManager, SIGNAL( urlDropped( const KURL& ) ), | 215 | connect( mViewManager, SIGNAL( urlDropped( const KURL& ) ), |
224 | mXXPortManager, SLOT( importVCard( const KURL& ) ) ); | 216 | mXXPortManager, SLOT( importVCard( const KURL& ) ) ); |
225 | 217 | ||
@@ -233,85 +225,86 @@ KABCore::KABCore( KXMLGUIClient *client, bool readWrite, QWidget *parent, const | |||
233 | createAddresseeEditorDialog( this ); | 225 | createAddresseeEditorDialog( this ); |
234 | setModified( false ); | 226 | setModified( false ); |
235 | } | 227 | } |
236 | 228 | ||
237 | KABCore::~KABCore() | 229 | KABCore::~KABCore() |
238 | { | 230 | { |
239 | // save(); | 231 | // save(); |
240 | //saveSettings(); | 232 | //saveSettings(); |
241 | //KABPrefs::instance()->writeConfig(); | 233 | //KABPrefs::instance()->writeConfig(); |
242 | delete AddresseeConfig::instance(); | 234 | delete AddresseeConfig::instance(); |
243 | mAddressBook = 0; | 235 | mAddressBook = 0; |
244 | KABC::StdAddressBook::close(); | 236 | KABC::StdAddressBook::close(); |
245 | } | 237 | } |
246 | 238 | ||
247 | void KABCore::restoreSettings() | 239 | void KABCore::restoreSettings() |
248 | { | 240 | { |
241 | mMultipleViewsAtOnce = KABPrefs::instance()->mMultipleViewsAtOnce; | ||
242 | |||
249 | bool state; | 243 | bool state; |
250 | 244 | ||
251 | //small devices have at startup the details view disabled | 245 | if (mMultipleViewsAtOnce) |
252 | if (KGlobal::getDesktopSize() > KGlobal::Small ) | ||
253 | state = KABPrefs::instance()->mDetailsPageVisible; | 246 | state = KABPrefs::instance()->mDetailsPageVisible; |
254 | else | 247 | else |
255 | state = false; | 248 | state = false; |
256 | 249 | ||
257 | mActionDetails->setChecked( state ); | 250 | mActionDetails->setChecked( state ); |
258 | setDetailsVisible( state ); | 251 | setDetailsVisible( state ); |
259 | 252 | ||
260 | state = KABPrefs::instance()->mJumpButtonBarVisible; | 253 | state = KABPrefs::instance()->mJumpButtonBarVisible; |
261 | 254 | ||
262 | mActionJumpBar->setChecked( state ); | 255 | mActionJumpBar->setChecked( state ); |
263 | setJumpButtonBarVisible( state ); | 256 | setJumpButtonBarVisible( state ); |
264 | 257 | /*US | |
265 | QValueList<int> splitterSize = KABPrefs::instance()->mDetailsSplitter; | 258 | QValueList<int> splitterSize = KABPrefs::instance()->mDetailsSplitter; |
266 | if ( splitterSize.count() == 0 ) { | 259 | if ( splitterSize.count() == 0 ) { |
267 | splitterSize.append( width() / 2 ); | 260 | splitterSize.append( width() / 2 ); |
268 | splitterSize.append( width() / 2 ); | 261 | splitterSize.append( width() / 2 ); |
269 | } | 262 | } |
270 | mMiniSplitter->setSizes( splitterSize ); | 263 | mMiniSplitter->setSizes( splitterSize ); |
271 | if ( mExtensionBarSplitter ) { | 264 | if ( mExtensionBarSplitter ) { |
272 | splitterSize = KABPrefs::instance()->mExtensionsSplitter; | 265 | splitterSize = KABPrefs::instance()->mExtensionsSplitter; |
273 | if ( splitterSize.count() == 0 ) { | 266 | if ( splitterSize.count() == 0 ) { |
274 | splitterSize.append( width() / 2 ); | 267 | splitterSize.append( width() / 2 ); |
275 | splitterSize.append( width() / 2 ); | 268 | splitterSize.append( width() / 2 ); |
276 | } | 269 | } |
277 | mExtensionBarSplitter->setSizes( splitterSize ); | 270 | mExtensionBarSplitter->setSizes( splitterSize ); |
278 | 271 | ||
279 | } | 272 | } |
280 | #ifndef KAB_EMBEDDED | 273 | */ |
281 | QValueList<int> splitterSize = KABPrefs::instance()->mExtensionsSplitter; | 274 | mViewManager->restoreSettings(); |
275 | mIncSearchWidget->setCurrentItem( KABPrefs::instance()->mCurrentIncSearchField ); | ||
276 | mExtensionManager->restoreSettings(); | ||
277 | |||
278 | QValueList<int> splitterSize = KABPrefs::instance()->mDetailsSplitter; | ||
282 | if ( splitterSize.count() == 0 ) { | 279 | if ( splitterSize.count() == 0 ) { |
283 | splitterSize.append( width() / 2 ); | 280 | splitterSize.append( width() / 2 ); |
284 | splitterSize.append( width() / 2 ); | 281 | splitterSize.append( width() / 2 ); |
285 | } | 282 | } |
286 | mExtensionBarSplitter->setSizes( splitterSize ); | 283 | mMiniSplitter->setSizes( splitterSize ); |
287 | 284 | if ( mExtensionBarSplitter ) { | |
288 | splitterSize = KABPrefs::instance()->mDetailsSplitter; | 285 | splitterSize = KABPrefs::instance()->mExtensionsSplitter; |
289 | if ( splitterSize.count() == 0 ) { | 286 | if ( splitterSize.count() == 0 ) { |
290 | splitterSize.append( height() / 2 ); | 287 | splitterSize.append( width() / 2 ); |
291 | splitterSize.append( height() / 2 ); | 288 | splitterSize.append( width() / 2 ); |
292 | } | 289 | } |
293 | mDetailsSplitter->setSizes( splitterSize ); | 290 | mExtensionBarSplitter->setSizes( splitterSize ); |
294 | 291 | ||
295 | mExtensionManager->restoreSettings(); | 292 | } |
296 | 293 | ||
297 | #endif //KAB_EMBEDDED | ||
298 | 294 | ||
299 | mViewManager->restoreSettings(); | ||
300 | mIncSearchWidget->setCurrentItem( KABPrefs::instance()->mCurrentIncSearchField ); | ||
301 | mExtensionManager->restoreSettings(); | ||
302 | } | 295 | } |
303 | 296 | ||
304 | void KABCore::saveSettings() | 297 | void KABCore::saveSettings() |
305 | { | 298 | { |
306 | KABPrefs::instance()->mJumpButtonBarVisible = mActionJumpBar->isChecked(); | 299 | KABPrefs::instance()->mJumpButtonBarVisible = mActionJumpBar->isChecked(); |
307 | if ( mExtensionBarSplitter ) | 300 | if ( mExtensionBarSplitter ) |
308 | KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); | 301 | KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); |
309 | KABPrefs::instance()->mDetailsPageVisible = mActionDetails->isChecked(); | 302 | KABPrefs::instance()->mDetailsPageVisible = mActionDetails->isChecked(); |
310 | KABPrefs::instance()->mDetailsSplitter = mMiniSplitter->sizes(); | 303 | KABPrefs::instance()->mDetailsSplitter = mMiniSplitter->sizes(); |
311 | #ifndef KAB_EMBEDDED | 304 | #ifndef KAB_EMBEDDED |
312 | 305 | ||
313 | KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); | 306 | KABPrefs::instance()->mExtensionsSplitter = mExtensionBarSplitter->sizes(); |
314 | KABPrefs::instance()->mDetailsSplitter = mDetailsSplitter->sizes(); | 307 | KABPrefs::instance()->mDetailsSplitter = mDetailsSplitter->sizes(); |
315 | #endif //KAB_EMBEDDED | 308 | #endif //KAB_EMBEDDED |
316 | mExtensionManager->saveSettings(); | 309 | mExtensionManager->saveSettings(); |
317 | mViewManager->saveSettings(); | 310 | mViewManager->saveSettings(); |
@@ -417,33 +410,33 @@ void KABCore::createAboutData() | |||
417 | "Don Sanders Original author\n" | 410 | "Don Sanders Original author\n" |
418 | "Cornelius Schumacher Co-maintainer schumacher@kde.org\n" | 411 | "Cornelius Schumacher Co-maintainer schumacher@kde.org\n" |
419 | "Mike Pilone GUI and framework redesign mpilone@slac.com\n" | 412 | "Mike Pilone GUI and framework redesign mpilone@slac.com\n" |
420 | "Greg Stern DCOP interface\n" | 413 | "Greg Stern DCOP interface\n" |
421 | "Mark Westcot Contact pinning\n" | 414 | "Mark Westcot Contact pinning\n" |
422 | "Michel Boyer de la Giroday LDAP Lookup\n" "michel@klaralvdalens-datakonsult.se\n" | 415 | "Michel Boyer de la Giroday LDAP Lookup\n" "michel@klaralvdalens-datakonsult.se\n" |
423 | "Steffen Hansen LDAP Lookup hansen@kde.org\n" | 416 | "Steffen Hansen LDAP Lookup hansen@kde.org\n" |
424 | #ifdef _WIN32_ | 417 | #ifdef _WIN32_ |
425 | "(c) 2004 Lutz Rogowski Import from OL rogowski@kde.org\n" | 418 | "(c) 2004 Lutz Rogowski Import from OL rogowski@kde.org\n" |
426 | #endif | 419 | #endif |
427 | ); | 420 | ); |
428 | } | 421 | } |
429 | 422 | ||
430 | void KABCore::setContactSelected( const QString &uid ) | 423 | void KABCore::setContactSelected( const QString &uid ) |
431 | { | 424 | { |
432 | KABC::Addressee addr = mAddressBook->findByUid( uid ); | 425 | KABC::Addressee addr = mAddressBook->findByUid( uid ); |
433 | //US if ( !mDetails->isHidden() ) | 426 | if ( !mDetails->isHidden() ) |
434 | mDetails->setAddressee( addr ); | 427 | mDetails->setAddressee( addr ); |
435 | 428 | ||
436 | if ( !addr.isEmpty() ) { | 429 | if ( !addr.isEmpty() ) { |
437 | emit contactSelected( addr.formattedName() ); | 430 | emit contactSelected( addr.formattedName() ); |
438 | KABC::Picture pic = addr.photo(); | 431 | KABC::Picture pic = addr.photo(); |
439 | if ( pic.isIntern() ) { | 432 | if ( pic.isIntern() ) { |
440 | //US emit contactSelected( pic.data() ); | 433 | //US emit contactSelected( pic.data() ); |
441 | //US instead use: | 434 | //US instead use: |
442 | QPixmap px; | 435 | QPixmap px; |
443 | if (pic.data().isNull() != true) | 436 | if (pic.data().isNull() != true) |
444 | { | 437 | { |
445 | px.convertFromImage(pic.data()); | 438 | px.convertFromImage(pic.data()); |
446 | } | 439 | } |
447 | 440 | ||
448 | emit contactSelected( px ); | 441 | emit contactSelected( px ); |
449 | } | 442 | } |
@@ -1044,40 +1037,47 @@ void KABCore::editContact( const QString &uid ) | |||
1044 | // First, locate the contact entry | 1037 | // First, locate the contact entry |
1045 | QString localUID = uid; | 1038 | QString localUID = uid; |
1046 | if ( localUID.isNull() ) { | 1039 | if ( localUID.isNull() ) { |
1047 | QStringList uidList = mViewManager->selectedUids(); | 1040 | QStringList uidList = mViewManager->selectedUids(); |
1048 | if ( uidList.count() > 0 ) | 1041 | if ( uidList.count() > 0 ) |
1049 | localUID = *( uidList.at( 0 ) ); | 1042 | localUID = *( uidList.at( 0 ) ); |
1050 | } | 1043 | } |
1051 | 1044 | ||
1052 | KABC::Addressee addr = mAddressBook->findByUid( localUID ); | 1045 | KABC::Addressee addr = mAddressBook->findByUid( localUID ); |
1053 | if ( !addr.isEmpty() ) { | 1046 | if ( !addr.isEmpty() ) { |
1054 | mEditorDialog->setAddressee( addr ); | 1047 | mEditorDialog->setAddressee( addr ); |
1055 | KApplication::execDialog ( mEditorDialog ); | 1048 | KApplication::execDialog ( mEditorDialog ); |
1056 | } | 1049 | } |
1057 | } | 1050 | } |
1058 | 1051 | ||
1059 | /** | 1052 | /** |
1060 | Shows the detail view for the given uid. If the uid is QString::null, | 1053 | Shows or edits the detail view for the given uid. If the uid is QString::null, |
1061 | the method will try to find a selected addressee in the view. | 1054 | the method will try to find a selected addressee in the view. |
1062 | We call this method only if we use a small device. Bigger devices are calling editContact instead | ||
1063 | */ | 1055 | */ |
1064 | void KABCore::showContact( const QString &uid /*US = QString::null*/ ) | 1056 | void KABCore::executeContact( const QString &uid /*US = QString::null*/ ) |
1065 | { | 1057 | { |
1066 | setDetailsVisible( true ); | 1058 | if ( mMultipleViewsAtOnce ) |
1067 | mActionDetails->setChecked(true); | 1059 | { |
1060 | editContact( uid ); | ||
1061 | } | ||
1062 | else | ||
1063 | { | ||
1064 | setDetailsVisible( true ); | ||
1065 | mActionDetails->setChecked(true); | ||
1066 | } | ||
1067 | |||
1068 | } | 1068 | } |
1069 | 1069 | ||
1070 | void KABCore::save() | 1070 | void KABCore::save() |
1071 | { | 1071 | { |
1072 | if ( !mModified ) | 1072 | if ( !mModified ) |
1073 | return; | 1073 | return; |
1074 | QString text = i18n( "There was an error while attempting to save\n the " | 1074 | QString text = i18n( "There was an error while attempting to save\n the " |
1075 | "address book. Please check that some \nother application is " | 1075 | "address book. Please check that some \nother application is " |
1076 | "not using it. " ); | 1076 | "not using it. " ); |
1077 | statusMessage(i18n("Saving addressbook ... ")); | 1077 | statusMessage(i18n("Saving addressbook ... ")); |
1078 | #ifndef KAB_EMBEDDED | 1078 | #ifndef KAB_EMBEDDED |
1079 | KABC::StdAddressBook *b = dynamic_cast<KABC::StdAddressBook*>( mAddressBook ); | 1079 | KABC::StdAddressBook *b = dynamic_cast<KABC::StdAddressBook*>( mAddressBook ); |
1080 | if ( !b || !b->save() ) { | 1080 | if ( !b || !b->save() ) { |
1081 | KMessageBox::error( this, text, i18n( "Unable to Save" ) ); | 1081 | KMessageBox::error( this, text, i18n( "Unable to Save" ) ); |
1082 | } | 1082 | } |
1083 | #else //KAB_EMBEDDED | 1083 | #else //KAB_EMBEDDED |
@@ -1101,90 +1101,139 @@ void KABCore::undo() | |||
1101 | UndoStack::instance()->undo(); | 1101 | UndoStack::instance()->undo(); |
1102 | 1102 | ||
1103 | // Refresh the view | 1103 | // Refresh the view |
1104 | mViewManager->refreshView(); | 1104 | mViewManager->refreshView(); |
1105 | } | 1105 | } |
1106 | 1106 | ||
1107 | void KABCore::redo() | 1107 | void KABCore::redo() |
1108 | { | 1108 | { |
1109 | RedoStack::instance()->redo(); | 1109 | RedoStack::instance()->redo(); |
1110 | 1110 | ||
1111 | // Refresh the view | 1111 | // Refresh the view |
1112 | mViewManager->refreshView(); | 1112 | mViewManager->refreshView(); |
1113 | } | 1113 | } |
1114 | 1114 | ||
1115 | void KABCore::setJumpButtonBarVisible( bool visible ) | 1115 | void KABCore::setJumpButtonBarVisible( bool visible ) |
1116 | { | 1116 | { |
1117 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | 1117 | if (mMultipleViewsAtOnce) |
1118 | { | ||
1118 | if ( visible ) | 1119 | if ( visible ) |
1119 | mJumpButtonBar->show(); | 1120 | mJumpButtonBar->show(); |
1120 | else | 1121 | else |
1121 | mJumpButtonBar->hide(); | 1122 | mJumpButtonBar->hide(); |
1122 | } | 1123 | } |
1123 | else | 1124 | else |
1124 | { | 1125 | { |
1125 | // for the Z5500, show the jumpbar only if "the details are hidden" == "viewmanager are shown" | 1126 | // show the jumpbar only if "the details are hidden" == "viewmanager are shown" |
1126 | if (mViewManager->isVisible()) | 1127 | if (mViewManager->isVisible()) |
1127 | { | 1128 | { |
1128 | if ( visible ) | 1129 | if ( visible ) |
1129 | mJumpButtonBar->show(); | 1130 | mJumpButtonBar->show(); |
1130 | else | 1131 | else |
1131 | mJumpButtonBar->hide(); | 1132 | mJumpButtonBar->hide(); |
1132 | } | 1133 | } |
1133 | else | 1134 | else |
1134 | { | 1135 | { |
1135 | mJumpButtonBar->hide(); | 1136 | mJumpButtonBar->hide(); |
1136 | } | 1137 | } |
1137 | } | 1138 | } |
1138 | } | 1139 | } |
1140 | |||
1141 | |||
1139 | void KABCore::setDetailsToState() | 1142 | void KABCore::setDetailsToState() |
1140 | { | 1143 | { |
1141 | setDetailsVisible( mActionDetails->isChecked() ); | 1144 | setDetailsVisible( mActionDetails->isChecked() ); |
1142 | } | 1145 | } |
1143 | 1146 | ||
1144 | 1147 | ||
1145 | 1148 | ||
1146 | void KABCore::setDetailsVisible( bool visible ) | 1149 | void KABCore::setDetailsVisible( bool visible ) |
1147 | { | 1150 | { |
1148 | //US "details visible" has two different meanings for small devices like the 5500 | 1151 | if (visible && mDetails->isHidden()) |
1149 | // compared with large devices like the c series. | 1152 | { |
1153 | KABC::Addressee::List addrList = mViewManager->selectedAddressees(); | ||
1154 | if ( addrList.count() > 0 ) | ||
1155 | mDetails->setAddressee( addrList[ 0 ] ); | ||
1156 | } | ||
1150 | 1157 | ||
1151 | // small devices: mDetails is always visible. But we switch between | 1158 | // mMultipleViewsAtOnce=false: mDetails is always visible. But we switch between |
1152 | // the listview and the detailview. We do that by changing the splitbar size. | 1159 | // the listview and the detailview. We do that by changing the splitbar size. |
1153 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | 1160 | if (mMultipleViewsAtOnce) |
1161 | { | ||
1154 | if ( visible ) | 1162 | if ( visible ) |
1155 | mDetails->show(); | 1163 | mDetails->show(); |
1156 | else | 1164 | else |
1157 | mDetails->hide(); | 1165 | mDetails->hide(); |
1158 | } | 1166 | } |
1159 | else | 1167 | else |
1160 | { | 1168 | { |
1161 | if ( visible ) { | 1169 | if ( visible ) { |
1162 | mViewManager->hide(); | 1170 | mViewManager->hide(); |
1163 | mDetails->show(); | 1171 | mDetails->show(); |
1164 | // mDetails->show(); | ||
1165 | } | 1172 | } |
1166 | else { | 1173 | else { |
1167 | mViewManager->show(); | 1174 | mViewManager->show(); |
1168 | mDetails->hide(); | 1175 | mDetails->hide(); |
1169 | } | 1176 | } |
1170 | setJumpButtonBarVisible( !visible ); | 1177 | setJumpButtonBarVisible( !visible ); |
1178 | } | ||
1179 | |||
1180 | } | ||
1181 | |||
1182 | void KABCore::extensionChanged( int id ) | ||
1183 | { | ||
1184 | //change the details view only for non desktop systems | ||
1185 | #ifndef DESKTOP_VERSION | ||
1186 | |||
1187 | if (id == 0) | ||
1188 | { | ||
1189 | //the user disabled the extension. | ||
1190 | |||
1191 | if (mMultipleViewsAtOnce) | ||
1192 | { // enable detailsview again | ||
1193 | setDetailsVisible( true ); | ||
1194 | mActionDetails->setChecked( true ); | ||
1195 | } | ||
1196 | else | ||
1197 | { //go back to the listview | ||
1198 | setDetailsVisible( false ); | ||
1199 | mActionDetails->setChecked( false ); | ||
1200 | mActionDetails->setEnabled(true); | ||
1201 | } | ||
1171 | 1202 | ||
1172 | } | 1203 | } |
1204 | else | ||
1205 | { | ||
1206 | //the user enabled the extension. | ||
1207 | setDetailsVisible( false ); | ||
1208 | mActionDetails->setChecked( false ); | ||
1209 | |||
1210 | if (!mMultipleViewsAtOnce) | ||
1211 | { | ||
1212 | mActionDetails->setEnabled(false); | ||
1213 | } | ||
1214 | |||
1215 | mExtensionManager->setSelectionChanged(); | ||
1216 | |||
1217 | } | ||
1218 | |||
1219 | #endif// DESKTOP_VERSION | ||
1220 | |||
1173 | } | 1221 | } |
1174 | 1222 | ||
1223 | |||
1175 | void KABCore::extensionModified( const KABC::Addressee::List &list ) | 1224 | void KABCore::extensionModified( const KABC::Addressee::List &list ) |
1176 | { | 1225 | { |
1177 | 1226 | ||
1178 | if ( list.count() != 0 ) { | 1227 | if ( list.count() != 0 ) { |
1179 | KABC::Addressee::List::ConstIterator it; | 1228 | KABC::Addressee::List::ConstIterator it; |
1180 | for ( it = list.begin(); it != list.end(); ++it ) | 1229 | for ( it = list.begin(); it != list.end(); ++it ) |
1181 | mAddressBook->insertAddressee( *it ); | 1230 | mAddressBook->insertAddressee( *it ); |
1182 | if ( list.count() > 1 ) | 1231 | if ( list.count() > 1 ) |
1183 | setModified(); | 1232 | setModified(); |
1184 | else | 1233 | else |
1185 | setModifiedWOrefresh(); | 1234 | setModifiedWOrefresh(); |
1186 | } | 1235 | } |
1187 | if ( list.count() == 0 ) | 1236 | if ( list.count() == 0 ) |
1188 | mViewManager->refreshView(); | 1237 | mViewManager->refreshView(); |
1189 | else | 1238 | else |
1190 | mViewManager->refreshView( list[ 0 ].uid() ); | 1239 | mViewManager->refreshView( list[ 0 ].uid() ); |
@@ -1231,33 +1280,33 @@ void KABCore::openConfigDialog() | |||
1231 | 1280 | ||
1232 | KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true ); | 1281 | KCMultiDialog* ConfigureDialog = new KCMultiDialog( "PIM", this ,"kabconfigdialog", true ); |
1233 | KCMKabConfig* kabcfg = new KCMKabConfig( kab_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" ); | 1282 | KCMKabConfig* kabcfg = new KCMKabConfig( kab_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Addressbook")) , "KCMKabConfig" ); |
1234 | ConfigureDialog->addModule(kabcfg ); | 1283 | ConfigureDialog->addModule(kabcfg ); |
1235 | KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( kpim_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); | 1284 | KCMKdePimConfig* kdelibcfg = new KCMKdePimConfig( kpim_prefs, ConfigureDialog->getNewVBoxPage(i18n( "Global")) , "KCMKdeLibConfig" ); |
1236 | ConfigureDialog->addModule(kdelibcfg ); | 1285 | ConfigureDialog->addModule(kdelibcfg ); |
1237 | 1286 | ||
1238 | 1287 | ||
1239 | 1288 | ||
1240 | connect( ConfigureDialog, SIGNAL( applyClicked() ), | 1289 | connect( ConfigureDialog, SIGNAL( applyClicked() ), |
1241 | this, SLOT( configurationChanged() ) ); | 1290 | this, SLOT( configurationChanged() ) ); |
1242 | connect( ConfigureDialog, SIGNAL( okClicked() ), | 1291 | connect( ConfigureDialog, SIGNAL( okClicked() ), |
1243 | this, SLOT( configurationChanged() ) ); | 1292 | this, SLOT( configurationChanged() ) ); |
1244 | saveSettings(); | 1293 | saveSettings(); |
1245 | ConfigureDialog->showMaximized(); | 1294 | ConfigureDialog->showMaximized(); |
1246 | if ( ConfigureDialog->exec() ) | 1295 | if ( ConfigureDialog->exec() ) |
1247 | KMessageBox::information( this, i18n("If you configured \nExtensions,\nplease restart!\n") ); | 1296 | KMessageBox::information( this, i18n("Some changes are only\neffective after a restart!\n") ); |
1248 | delete ConfigureDialog; | 1297 | delete ConfigureDialog; |
1249 | } | 1298 | } |
1250 | 1299 | ||
1251 | void KABCore::openLDAPDialog() | 1300 | void KABCore::openLDAPDialog() |
1252 | { | 1301 | { |
1253 | #ifndef KAB_EMBEDDED | 1302 | #ifndef KAB_EMBEDDED |
1254 | if ( !mLdapSearchDialog ) { | 1303 | if ( !mLdapSearchDialog ) { |
1255 | mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this ); | 1304 | mLdapSearchDialog = new LDAPSearchDialog( mAddressBook, this ); |
1256 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager, | 1305 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), mViewManager, |
1257 | SLOT( refreshView() ) ); | 1306 | SLOT( refreshView() ) ); |
1258 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this, | 1307 | connect( mLdapSearchDialog, SIGNAL( addresseesAdded() ), this, |
1259 | SLOT( setModified() ) ); | 1308 | SLOT( setModified() ) ); |
1260 | } else | 1309 | } else |
1261 | mLdapSearchDialog->restoreSettings(); | 1310 | mLdapSearchDialog->restoreSettings(); |
1262 | 1311 | ||
1263 | if ( mLdapSearchDialog->isOK() ) | 1312 | if ( mLdapSearchDialog->isOK() ) |
@@ -1732,33 +1781,36 @@ void KABCore::addActionsManually() | |||
1732 | // mViewManager->getFilterAction()->plug ( tb); | 1781 | // mViewManager->getFilterAction()->plug ( tb); |
1733 | } | 1782 | } |
1734 | #endif | 1783 | #endif |
1735 | // mActionQuit->plug ( mMainWindow->toolBar()); | 1784 | // mActionQuit->plug ( mMainWindow->toolBar()); |
1736 | 1785 | ||
1737 | 1786 | ||
1738 | 1787 | ||
1739 | //US Now connect the actions with the menue entries. | 1788 | //US Now connect the actions with the menue entries. |
1740 | mActionPrint->plug( fileMenu ); | 1789 | mActionPrint->plug( fileMenu ); |
1741 | mActionMail->plug( fileMenu ); | 1790 | mActionMail->plug( fileMenu ); |
1742 | fileMenu->insertSeparator(); | 1791 | fileMenu->insertSeparator(); |
1743 | 1792 | ||
1744 | mActionNewContact->plug( fileMenu ); | 1793 | mActionNewContact->plug( fileMenu ); |
1745 | mActionNewContact->plug( tb ); | 1794 | mActionNewContact->plug( tb ); |
1746 | 1795 | ||
1747 | mActionEditAddressee->plug( fileMenu ); | 1796 | mActionEditAddressee->plug( fileMenu ); |
1748 | mActionEditAddressee->plug( tb ); | 1797 | if ((KGlobal::getDesktopSize() > KGlobal::Small ) || |
1798 | (!KABPrefs::instance()->mMultipleViewsAtOnce )) | ||
1799 | mActionEditAddressee->plug( tb ); | ||
1800 | |||
1749 | fileMenu->insertSeparator(); | 1801 | fileMenu->insertSeparator(); |
1750 | mActionSave->plug( fileMenu ); | 1802 | mActionSave->plug( fileMenu ); |
1751 | fileMenu->insertItem( "&Import", ImportMenu ); | 1803 | fileMenu->insertItem( "&Import", ImportMenu ); |
1752 | fileMenu->insertItem( "&Emport", ExportMenu ); | 1804 | fileMenu->insertItem( "&Emport", ExportMenu ); |
1753 | fileMenu->insertSeparator(); | 1805 | fileMenu->insertSeparator(); |
1754 | mActionMailVCard->plug( fileMenu ); | 1806 | mActionMailVCard->plug( fileMenu ); |
1755 | #ifndef DESKTOP_VERSION | 1807 | #ifndef DESKTOP_VERSION |
1756 | if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu ); | 1808 | if ( Ir::supported() ) mActionBeamVCard->plug( fileMenu ); |
1757 | if ( Ir::supported() ) mActionBeam->plug(fileMenu ); | 1809 | if ( Ir::supported() ) mActionBeam->plug(fileMenu ); |
1758 | #endif | 1810 | #endif |
1759 | fileMenu->insertSeparator(); | 1811 | fileMenu->insertSeparator(); |
1760 | mActionQuit->plug( fileMenu ); | 1812 | mActionQuit->plug( fileMenu ); |
1761 | #ifdef _WIN32_ | 1813 | #ifdef _WIN32_ |
1762 | mActionImportOL->plug( ImportMenu ); | 1814 | mActionImportOL->plug( ImportMenu ); |
1763 | #endif | 1815 | #endif |
1764 | // edit menu | 1816 | // edit menu |
@@ -1780,33 +1832,33 @@ void KABCore::addActionsManually() | |||
1780 | settingsMenu->insertSeparator(); | 1832 | settingsMenu->insertSeparator(); |
1781 | 1833 | ||
1782 | mActionConfigKAddressbook->plug( settingsMenu ); | 1834 | mActionConfigKAddressbook->plug( settingsMenu ); |
1783 | 1835 | ||
1784 | if ( mIsPart ) { | 1836 | if ( mIsPart ) { |
1785 | mActionConfigShortcuts->plug( settingsMenu ); | 1837 | mActionConfigShortcuts->plug( settingsMenu ); |
1786 | mActionConfigureToolbars->plug( settingsMenu ); | 1838 | mActionConfigureToolbars->plug( settingsMenu ); |
1787 | 1839 | ||
1788 | } else { | 1840 | } else { |
1789 | mActionKeyBindings->plug( settingsMenu ); | 1841 | mActionKeyBindings->plug( settingsMenu ); |
1790 | } | 1842 | } |
1791 | 1843 | ||
1792 | settingsMenu->insertSeparator(); | 1844 | settingsMenu->insertSeparator(); |
1793 | 1845 | ||
1794 | mActionJumpBar->plug( settingsMenu ); | 1846 | mActionJumpBar->plug( settingsMenu ); |
1795 | mActionDetails->plug( settingsMenu ); | 1847 | mActionDetails->plug( settingsMenu ); |
1796 | if (KGlobal::getDesktopSize() == KGlobal::Small ) | 1848 | if (!KABPrefs::instance()->mMultipleViewsAtOnce ) |
1797 | mActionDetails->plug( tb ); | 1849 | mActionDetails->plug( tb ); |
1798 | settingsMenu->insertSeparator(); | 1850 | settingsMenu->insertSeparator(); |
1799 | 1851 | ||
1800 | mActionWhoAmI->plug( settingsMenu ); | 1852 | mActionWhoAmI->plug( settingsMenu ); |
1801 | mActionCategories->plug( settingsMenu ); | 1853 | mActionCategories->plug( settingsMenu ); |
1802 | 1854 | ||
1803 | mActionAboutKAddressbook->plug( helpMenu ); | 1855 | mActionAboutKAddressbook->plug( helpMenu ); |
1804 | mActionLicence->plug( helpMenu ); | 1856 | mActionLicence->plug( helpMenu ); |
1805 | 1857 | ||
1806 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | 1858 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { |
1807 | 1859 | ||
1808 | mActionSave->plug( tb ); | 1860 | mActionSave->plug( tb ); |
1809 | mViewManager->getFilterAction()->plug ( tb); | 1861 | mViewManager->getFilterAction()->plug ( tb); |
1810 | if (KGlobal::getDesktopSize() == KGlobal::Desktop ) { | 1862 | if (KGlobal::getDesktopSize() == KGlobal::Desktop ) { |
1811 | mActionUndo->plug( tb ); | 1863 | mActionUndo->plug( tb ); |
1812 | mActionDelete->plug( tb ); | 1864 | mActionDelete->plug( tb ); |
diff --git a/kaddressbook/kabcore.h b/kaddressbook/kabcore.h index a45c4c6..d4d28f1 100644 --- a/kaddressbook/kabcore.h +++ b/kaddressbook/kabcore.h | |||
@@ -289,68 +289,69 @@ class KABCore : public QWidget | |||
289 | void undo(); | 289 | void undo(); |
290 | 290 | ||
291 | /** | 291 | /** |
292 | Redos the last command that was undone, using the redo stack. | 292 | Redos the last command that was undone, using the redo stack. |
293 | */ | 293 | */ |
294 | void redo(); | 294 | void redo(); |
295 | 295 | ||
296 | /** | 296 | /** |
297 | Shows the edit dialog for the given uid. If the uid is QString::null, | 297 | Shows the edit dialog for the given uid. If the uid is QString::null, |
298 | the method will try to find a selected addressee in the view. | 298 | the method will try to find a selected addressee in the view. |
299 | */ | 299 | */ |
300 | void editContact( const QString &uid /*US = QString::null*/ ); | 300 | void editContact( const QString &uid /*US = QString::null*/ ); |
301 | //US added a second method without defaultparameter | 301 | //US added a second method without defaultparameter |
302 | void editContact2(); | 302 | void editContact2(); |
303 | 303 | ||
304 | /** | 304 | /** |
305 | Shows the detail view for the given uid. If the uid is QString::null, | 305 | Shows or edits the detail view for the given uid. If the uid is QString::null, |
306 | the method will try to find a selected addressee in the view. | 306 | the method will try to find a selected addressee in the view. |
307 | */ | 307 | */ |
308 | void showContact( const QString &uid /*US = QString::null*/ ); | 308 | void executeContact( const QString &uid /*US = QString::null*/ ); |
309 | 309 | ||
310 | /** | 310 | /** |
311 | Launches the configuration dialog. | 311 | Launches the configuration dialog. |
312 | */ | 312 | */ |
313 | void openConfigDialog(); | 313 | void openConfigDialog(); |
314 | 314 | ||
315 | /** | 315 | /** |
316 | Launches the ldap search dialog. | 316 | Launches the ldap search dialog. |
317 | */ | 317 | */ |
318 | void openLDAPDialog(); | 318 | void openLDAPDialog(); |
319 | 319 | ||
320 | /** | 320 | /** |
321 | Creates a KAddressBookPrinter, which will display the print | 321 | Creates a KAddressBookPrinter, which will display the print |
322 | dialog and do the printing. | 322 | dialog and do the printing. |
323 | */ | 323 | */ |
324 | void print(); | 324 | void print(); |
325 | 325 | ||
326 | /** | 326 | /** |
327 | Registers a new GUI client, so plugins can register its actions. | 327 | Registers a new GUI client, so plugins can register its actions. |
328 | */ | 328 | */ |
329 | void addGUIClient( KXMLGUIClient *client ); | 329 | void addGUIClient( KXMLGUIClient *client ); |
330 | 330 | ||
331 | signals: | 331 | signals: |
332 | void contactSelected( const QString &name ); | 332 | void contactSelected( const QString &name ); |
333 | void contactSelected( const QPixmap &pixmap ); | 333 | void contactSelected( const QPixmap &pixmap ); |
334 | public slots: | 334 | public slots: |
335 | void setDetailsVisible( bool visible ); | 335 | void setDetailsVisible( bool visible ); |
336 | void setDetailsToState(); | 336 | void setDetailsToState(); |
337 | private slots: | 337 | private slots: |
338 | void setJumpButtonBarVisible( bool visible ); | 338 | void setJumpButtonBarVisible( bool visible ); |
339 | void importFromOL(); | 339 | void importFromOL(); |
340 | void extensionModified( const KABC::Addressee::List &list ); | 340 | void extensionModified( const KABC::Addressee::List &list ); |
341 | void extensionChanged( int id ); | ||
341 | void clipboardDataChanged(); | 342 | void clipboardDataChanged(); |
342 | void updateActionMenu(); | 343 | void updateActionMenu(); |
343 | void configureKeyBindings(); | 344 | void configureKeyBindings(); |
344 | void removeVoice(); | 345 | void removeVoice(); |
345 | #ifdef KAB_EMBEDDED | 346 | #ifdef KAB_EMBEDDED |
346 | void configureResources(); | 347 | void configureResources(); |
347 | #endif //KAB_EMBEDDED | 348 | #endif //KAB_EMBEDDED |
348 | 349 | ||
349 | void slotEditorDestroyed( const QString &uid ); | 350 | void slotEditorDestroyed( const QString &uid ); |
350 | void configurationChanged(); | 351 | void configurationChanged(); |
351 | void addressBookChanged(); | 352 | void addressBookChanged(); |
352 | 353 | ||
353 | private: | 354 | private: |
354 | void initGUI(); | 355 | void initGUI(); |
355 | void initActions(); | 356 | void initActions(); |
356 | 357 | ||
@@ -368,32 +369,34 @@ class KABCore : public QWidget | |||
368 | KDGanttMinimizeSplitter* mMiniSplitter; | 369 | KDGanttMinimizeSplitter* mMiniSplitter; |
369 | XXPortManager *mXXPortManager; | 370 | XXPortManager *mXXPortManager; |
370 | JumpButtonBar *mJumpButtonBar; | 371 | JumpButtonBar *mJumpButtonBar; |
371 | IncSearchWidget *mIncSearchWidget; | 372 | IncSearchWidget *mIncSearchWidget; |
372 | ExtensionManager *mExtensionManager; | 373 | ExtensionManager *mExtensionManager; |
373 | 374 | ||
374 | KCMultiDialog *mConfigureDialog; | 375 | KCMultiDialog *mConfigureDialog; |
375 | 376 | ||
376 | #ifndef KAB_EMBEDDED | 377 | #ifndef KAB_EMBEDDED |
377 | LDAPSearchDialog *mLdapSearchDialog; | 378 | LDAPSearchDialog *mLdapSearchDialog; |
378 | #endif //KAB_EMBEDDED | 379 | #endif //KAB_EMBEDDED |
379 | // QDict<AddresseeEditorDialog> mEditorDict; | 380 | // QDict<AddresseeEditorDialog> mEditorDict; |
380 | AddresseeEditorDialog *mEditorDialog; | 381 | AddresseeEditorDialog *mEditorDialog; |
381 | bool mReadWrite; | 382 | bool mReadWrite; |
382 | bool mModified; | 383 | bool mModified; |
383 | bool mIsPart; | 384 | bool mIsPart; |
385 | bool mMultipleViewsAtOnce; | ||
386 | |||
384 | 387 | ||
385 | //US file menu | 388 | //US file menu |
386 | KAction *mActionMail; | 389 | KAction *mActionMail; |
387 | KAction *mActionBeam; | 390 | KAction *mActionBeam; |
388 | KAction* mActionPrint; | 391 | KAction* mActionPrint; |
389 | KAction* mActionNewContact; | 392 | KAction* mActionNewContact; |
390 | KAction *mActionSave; | 393 | KAction *mActionSave; |
391 | KAction *mActionEditAddressee; | 394 | KAction *mActionEditAddressee; |
392 | KAction *mActionMailVCard; | 395 | KAction *mActionMailVCard; |
393 | KAction *mActionBeamVCard; | 396 | KAction *mActionBeamVCard; |
394 | 397 | ||
395 | KAction *mActionQuit; | 398 | KAction *mActionQuit; |
396 | 399 | ||
397 | //US edit menu | 400 | //US edit menu |
398 | KAction *mActionCopy; | 401 | KAction *mActionCopy; |
399 | KAction *mActionCut; | 402 | KAction *mActionCut; |