-rw-r--r-- | bin/kdepim/WhatsNew.txt | 2 | ||||
-rw-r--r-- | kabc/addresseedialog.cpp | 7 | ||||
-rw-r--r-- | kaddressbook/kabcore.cpp | 14 |
3 files changed, 17 insertions, 6 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index 21664de..b6472d7 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,166 +1,168 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 2.1.10 ************ | 3 | ********** VERSION 2.1.10 ************ |
4 | 4 | ||
5 | KO/Pi: | 5 | KO/Pi: |
6 | Importing Birthdays will now create another file resource "Birthdays" and import the birthday data from KA/Pi into that file. | 6 | Importing Birthdays will now create another file resource "Birthdays" and import the birthday data from KA/Pi into that file. |
7 | When a multidayevent is selected in monthview all occurences of this event in the monthview are now hightlighted. | ||
7 | 8 | ||
8 | KA/Pi: | 9 | KA/Pi: |
9 | Fixed two problems in csv export. | 10 | Fixed two problems in csv export. |
11 | Fixed problems when calling the contact selection dialog from KO/Pi or OM/Pi. | ||
10 | 12 | ||
11 | ********** VERSION 2.1.9 ************ | 13 | ********** VERSION 2.1.9 ************ |
12 | 14 | ||
13 | KO/Pi: | 15 | KO/Pi: |
14 | Fixed some problems of the new search options in the search dialog. | 16 | Fixed some problems of the new search options in the search dialog. |
15 | Fixed some problems in the new resource config options. | 17 | Fixed some problems in the new resource config options. |
16 | Changed the recurrence edit of events and todos such that the recurrence edit page now is notified about a change of the start date on the first page. | 18 | Changed the recurrence edit of events and todos such that the recurrence edit page now is notified about a change of the start date on the first page. |
17 | Fixed a problem creating new events in the agenda view if at the day/time is already an agenda item shown: | 19 | Fixed a problem creating new events in the agenda view if at the day/time is already an agenda item shown: |
18 | Now you can click on the bottom/top of an allday agenda item or on the left/right side of an agenda item to get the "new todo/new event" popup. | 20 | Now you can click on the bottom/top of an allday agenda item or on the left/right side of an agenda item to get the "new todo/new event" popup. |
19 | 21 | ||
20 | Fixed a problem in recurrence range in syncing with DTM. | 22 | Fixed a problem in recurrence range in syncing with DTM. |
21 | 23 | ||
22 | KA/Pi: | 24 | KA/Pi: |
23 | Made it posiible to show in the contact overview the details of all data available for that contact( e.g. office, spouse, children, nickname ...) | 25 | Made it posiible to show in the contact overview the details of all data available for that contact( e.g. office, spouse, children, nickname ...) |
24 | 26 | ||
25 | PwM/Pi: | 27 | PwM/Pi: |
26 | Added "sec" to the timeout config settings to make it clear the timeout values are seconds. | 28 | Added "sec" to the timeout config settings to make it clear the timeout values are seconds. |
27 | 29 | ||
28 | ********** VERSION 2.1.8 ************ | 30 | ********** VERSION 2.1.8 ************ |
29 | 31 | ||
30 | KO/Pi: | 32 | KO/Pi: |
31 | Added info about the completion state of a todo in the ListView/Searchdialog. | 33 | Added info about the completion state of a todo in the ListView/Searchdialog. |
32 | If in TodoView is selected "do not show compledted todos" then completed todos are not shown in the ListView as well. | 34 | If in TodoView is selected "do not show compledted todos" then completed todos are not shown in the ListView as well. |
33 | Fixed some updating problems when changing the filter. | 35 | Fixed some updating problems when changing the filter. |
34 | 36 | ||
35 | KA/Pi: | 37 | KA/Pi: |
36 | In the addressee selection dialog now the formatted name is shown, if not empty. | 38 | In the addressee selection dialog now the formatted name is shown, if not empty. |
37 | Added a column "category" to the addressee selection dialog to make it possible to sort addressees after category. | 39 | Added a column "category" to the addressee selection dialog to make it possible to sort addressees after category. |
38 | Now in the addressee selection dialog a selected contact is remove with a single click from the selected list. | 40 | Now in the addressee selection dialog a selected contact is remove with a single click from the selected list. |
39 | 41 | ||
40 | Fixed in the file selector on the Zaurus the problem that symbolic links to files/dirs were ignored. | 42 | Fixed in the file selector on the Zaurus the problem that symbolic links to files/dirs were ignored. |
41 | Fixed the sorting for size in the file selector on the Z. | 43 | Fixed the sorting for size in the file selector on the Z. |
42 | 44 | ||
43 | Changed the color selection dialog on the Zaurus to a more user friendly version. | 45 | Changed the color selection dialog on the Zaurus to a more user friendly version. |
44 | 46 | ||
45 | ********** VERSION 2.1.7 ************ | 47 | ********** VERSION 2.1.7 ************ |
46 | 48 | ||
47 | KO/Pi: | 49 | KO/Pi: |
48 | Fixed several problems in the new Resource handling. | 50 | Fixed several problems in the new Resource handling. |
49 | Added more options to the search dialog. | 51 | Added more options to the search dialog. |
50 | Fixed a problem in the Month view. | 52 | Fixed a problem in the Month view. |
51 | Added more options to the dialog when setting a todo to stopped. | 53 | Added more options to the dialog when setting a todo to stopped. |
52 | 54 | ||
53 | Fixed two small problems in KO/Pi Alarm applet. | 55 | Fixed two small problems in KO/Pi Alarm applet. |
54 | 56 | ||
55 | ********** VERSION 2.1.6 ************ | 57 | ********** VERSION 2.1.6 ************ |
56 | 58 | ||
57 | This release is for testing only. | 59 | This release is for testing only. |
58 | 60 | ||
59 | KO/Pi: | 61 | KO/Pi: |
60 | Added to the list view (the list view is used in search dialog as well) the possibility to print it. | 62 | Added to the list view (the list view is used in search dialog as well) the possibility to print it. |
61 | Added to the list view the possibility to hide entries, if you do not want to print all entries of the list view. | 63 | Added to the list view the possibility to hide entries, if you do not want to print all entries of the list view. |
62 | Added to the list view the possibility to add all subtodos of selected todos to an export/beam. | 64 | Added to the list view the possibility to add all subtodos of selected todos to an export/beam. |
63 | Added to the search dialog the possibility to make an additive search such that you can get a better list for export/printout. | 65 | Added to the search dialog the possibility to make an additive search such that you can get a better list for export/printout. |
64 | Added to the search dialog the possibility to hide the checkboxes such that there is more space for the list view on the Zaurus. | 66 | Added to the search dialog the possibility to hide the checkboxes such that there is more space for the list view on the Zaurus. |
65 | Fixed a problem in the AlarmTimer Applet: Now utf8 messages are displayed properly. | 67 | Fixed a problem in the AlarmTimer Applet: Now utf8 messages are displayed properly. |
66 | 68 | ||
67 | Added support for multiple calendar files in KO/Pi. Only local ical (*.ics) files are supported as calendars. | 69 | Added support for multiple calendar files in KO/Pi. Only local ical (*.ics) files are supported as calendars. |
68 | In the sync profile config it is still missing to specify a particular calendar to sync with this profile. That setting will be added later. | 70 | In the sync profile config it is still missing to specify a particular calendar to sync with this profile. That setting will be added later. |
69 | Now on every sync the set of calendars is synced which are enabled in the resource view. | 71 | Now on every sync the set of calendars is synced which are enabled in the resource view. |
70 | 72 | ||
71 | A calendar is enabled in the resource view if the "eye" column is checked. | 73 | A calendar is enabled in the resource view if the "eye" column is checked. |
72 | You can set a calendar to be the default for new items( "+" column ). | 74 | You can set a calendar to be the default for new items( "+" column ). |
73 | You can tell KO/Pi to ignore all alarm of a calendar ( "bell" column ) and you can set it readonly. | 75 | You can tell KO/Pi to ignore all alarm of a calendar ( "bell" column ) and you can set it readonly. |
74 | To find out how to add a new calendar and how to remove a calendar is left as an exercise to the reader ... | 76 | To find out how to add a new calendar and how to remove a calendar is left as an exercise to the reader ... |
75 | 77 | ||
76 | 78 | ||
77 | ********** VERSION 2.1.5 ************ | 79 | ********** VERSION 2.1.5 ************ |
78 | 80 | ||
79 | This is the new stable version. | 81 | This is the new stable version. |
80 | Bugfix: | 82 | Bugfix: |
81 | Fixed a problem with agenda popup on the desktop in KO/Pi. | 83 | Fixed a problem with agenda popup on the desktop in KO/Pi. |
82 | Fixed a crash when reloading file, e.g. after a passive pi-sync synchronization. | 84 | Fixed a crash when reloading file, e.g. after a passive pi-sync synchronization. |
83 | Added config option to not display completed todos in agenda view. | 85 | Added config option to not display completed todos in agenda view. |
84 | Addressee view is now using the formatted name, if defined. | 86 | Addressee view is now using the formatted name, if defined. |
85 | That makes it possible to display "lastname, firstname" in that view now. | 87 | That makes it possible to display "lastname, firstname" in that view now. |
86 | To set the formatted name for all contacts, please use menu: | 88 | To set the formatted name for all contacts, please use menu: |
87 | Edit->Change->Set formatted name. | 89 | Edit->Change->Set formatted name. |
88 | Fixed the bug in KA/Pi that is was not possible to add images to a contact on Windows. | 90 | Fixed the bug in KA/Pi that is was not possible to add images to a contact on Windows. |
89 | 91 | ||
90 | ********** VERSION 2.1.4 ************ | 92 | ********** VERSION 2.1.4 ************ |
91 | 93 | ||
92 | Fixed two more bugs in the KA/Pi CSV import dialog: | 94 | Fixed two more bugs in the KA/Pi CSV import dialog: |
93 | Made it possible to read multi-line fields and import it to the "Note" field. | 95 | Made it possible to read multi-line fields and import it to the "Note" field. |
94 | Fixed a problem in mapping custom fields, whatever a custem field is... | 96 | Fixed a problem in mapping custom fields, whatever a custem field is... |
95 | 97 | ||
96 | ********** VERSION 2.1.3 ************ | 98 | ********** VERSION 2.1.3 ************ |
97 | 99 | ||
98 | Changed the menu structure of the alarm applet: | 100 | Changed the menu structure of the alarm applet: |
99 | Moved "Simulate" to " Play Beeps" submenu and re-added "Todo List". | 101 | Moved "Simulate" to " Play Beeps" submenu and re-added "Todo List". |
100 | 102 | ||
101 | Fixed several problems in the KA/Pi CSV import dialog: | 103 | Fixed several problems in the KA/Pi CSV import dialog: |
102 | Added "Category", made codec configureable and made it possible to map many fields to the "Note" field. | 104 | Added "Category", made codec configureable and made it possible to map many fields to the "Note" field. |
103 | 105 | ||
104 | 106 | ||
105 | ********** VERSION 2.1.2 ************ | 107 | ********** VERSION 2.1.2 ************ |
106 | 108 | ||
107 | Fixed a problem closing the alarm dialog on Zaurus with "OK" button. | 109 | Fixed a problem closing the alarm dialog on Zaurus with "OK" button. |
108 | 110 | ||
109 | Fixed a problem when importing data from Outlook with mutiple categories set. | 111 | Fixed a problem when importing data from Outlook with mutiple categories set. |
110 | 112 | ||
111 | Changed display of days in datenavigator: | 113 | Changed display of days in datenavigator: |
112 | Birthdays are now blue, not dark green. | 114 | Birthdays are now blue, not dark green. |
113 | When todo view is shown, no birtdays are shown and days with due todos are shown blue. | 115 | When todo view is shown, no birtdays are shown and days with due todos are shown blue. |
114 | When journal view is shown, only holidays are shown and days with journals are blue. | 116 | When journal view is shown, only holidays are shown and days with journals are blue. |
115 | 117 | ||
116 | Added Backup options to global config: | 118 | Added Backup options to global config: |
117 | You can create now x-daily backups for KO/Pi, KA/Pi (for file resources only, file resource is the standard type) and PwM/Pi ( all files you will open ). | 119 | You can create now x-daily backups for KO/Pi, KA/Pi (for file resources only, file resource is the standard type) and PwM/Pi ( all files you will open ). |
118 | It is recommended to use another HDD/Memory card for the backup directory. If (very useful on the Zaurus) the specified backup directory does not exist you are asked if you want to try again to create a backup. That makes it possible to insert your memory card in the Zaurus and then trying again. | 120 | It is recommended to use another HDD/Memory card for the backup directory. If (very useful on the Zaurus) the specified backup directory does not exist you are asked if you want to try again to create a backup. That makes it possible to insert your memory card in the Zaurus and then trying again. |
119 | The backup is created when the application wants to save for the first time on a backup-day. You can specify the amount of backups and the day interval of backups. | 121 | The backup is created when the application wants to save for the first time on a backup-day. You can specify the amount of backups and the day interval of backups. |
120 | 122 | ||
121 | ********** VERSION 2.1.1 ************ | 123 | ********** VERSION 2.1.1 ************ |
122 | 124 | ||
123 | Stable release 2.1.1! | 125 | Stable release 2.1.1! |
124 | 126 | ||
125 | KO/Pi: | 127 | KO/Pi: |
126 | Fixed one problem in the layout of the edit dialogs on the Zaurus with 640x480 display. | 128 | Fixed one problem in the layout of the edit dialogs on the Zaurus with 640x480 display. |
127 | 129 | ||
128 | ********** VERSION 2.1.0 ************ | 130 | ********** VERSION 2.1.0 ************ |
129 | 131 | ||
130 | Stable release 2.1.0! | 132 | Stable release 2.1.0! |
131 | 133 | ||
132 | Summary of changes/fixes compared to version 2.0.6: | 134 | Summary of changes/fixes compared to version 2.0.6: |
133 | 135 | ||
134 | Many bugs of version 2.0.6 fixed. | 136 | Many bugs of version 2.0.6 fixed. |
135 | Most of them were small bugs, but some of them were important. | 137 | Most of them were small bugs, but some of them were important. |
136 | It is recommended to use version 2.1.0 and not version 2.0.6. | 138 | It is recommended to use version 2.1.0 and not version 2.0.6. |
137 | 139 | ||
138 | Important changes: | 140 | Important changes: |
139 | 141 | ||
140 | Added recurring todos to KO/Pi. | 142 | Added recurring todos to KO/Pi. |
141 | 143 | ||
142 | Added global application font settings (for all KDE-Pim/Pi apps) to the general settings. | 144 | Added global application font settings (for all KDE-Pim/Pi apps) to the general settings. |
143 | 145 | ||
144 | Made Passwordmanager PwM/Pi more userfriendly: Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. | 146 | Made Passwordmanager PwM/Pi more userfriendly: Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. |
145 | 147 | ||
146 | Datenavigator can now display many months. Very useful on the desktop. | 148 | Datenavigator can now display many months. Very useful on the desktop. |
147 | 149 | ||
148 | KO/Pi alarm applet changed: Made buttons in alarm dialog much bigger and other usebility enhancements. | 150 | KO/Pi alarm applet changed: Made buttons in alarm dialog much bigger and other usebility enhancements. |
149 | 151 | ||
150 | Made alarm sound working on Linux desktop. | 152 | Made alarm sound working on Linux desktop. |
151 | 153 | ||
152 | Made KO/Pi and KA/Pi running from a memory stick. Please read storage HowTo for details. | 154 | Made KO/Pi and KA/Pi running from a memory stick. Please read storage HowTo for details. |
153 | 155 | ||
154 | Added timetracking feature in KO/Pi todo view. Please read timetraker HowTo for details. | 156 | Added timetracking feature in KO/Pi todo view. Please read timetraker HowTo for details. |
155 | 157 | ||
156 | Many other usebility enhancements. | 158 | Many other usebility enhancements. |
157 | Special thanks to Ben for his suggestions! | 159 | Special thanks to Ben for his suggestions! |
158 | 160 | ||
159 | You can find the complete changelog | 161 | You can find the complete changelog |
160 | from version 1.7.7 to 2.1.0 | 162 | from version 1.7.7 to 2.1.0 |
161 | in the source package or on | 163 | in the source package or on |
162 | 164 | ||
163 | http://www.pi-sync.net/html/changelog.html | 165 | http://www.pi-sync.net/html/changelog.html |
164 | 166 | ||
165 | 167 | ||
166 | 168 | ||
diff --git a/kabc/addresseedialog.cpp b/kabc/addresseedialog.cpp index 9197850..0cf75a0 100644 --- a/kabc/addresseedialog.cpp +++ b/kabc/addresseedialog.cpp | |||
@@ -1,363 +1,368 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkabc. | 2 | This file is part of libkabc. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This library is free software; you can redistribute it and/or | 5 | This library is free software; you can redistribute it and/or |
6 | modify it under the terms of the GNU Library General Public | 6 | modify it under the terms of the GNU Library General Public |
7 | License as published by the Free Software Foundation; either | 7 | License as published by the Free Software Foundation; either |
8 | version 2 of the License, or (at your option) any later version. | 8 | version 2 of the License, or (at your option) any later version. |
9 | 9 | ||
10 | This library is distributed in the hope that it will be useful, | 10 | This library 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 GNU | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
13 | Library General Public License for more details. | 13 | Library General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU Library General Public License | 15 | You should have received a copy of the GNU Library General Public License |
16 | along with this library; see the file COPYING.LIB. If not, write to | 16 | along with this library; see the file COPYING.LIB. If not, write to |
17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
18 | Boston, MA 02111-1307, USA. | 18 | Boston, MA 02111-1307, USA. |
19 | */ | 19 | */ |
20 | 20 | ||
21 | #include <qlayout.h> | 21 | #include <qlayout.h> |
22 | #include <qpushbutton.h> | 22 | #include <qpushbutton.h> |
23 | #include <qgroupbox.h> | 23 | #include <qgroupbox.h> |
24 | #include <qapplication.h> | 24 | #include <qapplication.h> |
25 | #include <qregexp.h> | 25 | #include <qregexp.h> |
26 | #include <qvbox.h> | 26 | #include <qvbox.h> |
27 | #include <qlabel.h> | 27 | #include <qlabel.h> |
28 | 28 | ||
29 | #include <klocale.h> | 29 | #include <klocale.h> |
30 | #include <kdebug.h> | 30 | #include <kdebug.h> |
31 | #include <kglobalsettings.h> | 31 | #include <kglobalsettings.h> |
32 | 32 | ||
33 | #include "stdaddressbook.h" | 33 | #include "stdaddressbook.h" |
34 | 34 | ||
35 | #include "addresseedialog.h" | 35 | #include "addresseedialog.h" |
36 | #include "KDGanttMinimizeSplitter.h" | 36 | #include "KDGanttMinimizeSplitter.h" |
37 | //#include "addresseedialog.moc" | 37 | //#include "addresseedialog.moc" |
38 | 38 | ||
39 | using namespace KABC; | 39 | using namespace KABC; |
40 | 40 | ||
41 | AddresseeItem::AddresseeItem( QListView *parent, const Addressee &addressee ) : | 41 | AddresseeItem::AddresseeItem( QListView *parent, const Addressee &addressee ) : |
42 | QListViewItem( parent ), | 42 | QListViewItem( parent ), |
43 | mAddressee( addressee ) | 43 | mAddressee( addressee ) |
44 | { | 44 | { |
45 | setText( Name,addressee.realName()); | 45 | setText( Name,addressee.realName()); |
46 | setText( Email, addressee.preferredEmail() ); | 46 | setText( Email, addressee.preferredEmail() ); |
47 | setText( Category, addressee.categories().join(";") ); | 47 | setText( Category, addressee.categories().join(";") ); |
48 | } | 48 | } |
49 | 49 | ||
50 | QString AddresseeItem::key( int column, bool ) const | 50 | QString AddresseeItem::key( int column, bool ) const |
51 | { | 51 | { |
52 | 52 | ||
53 | if (column == Email) { | 53 | if (column == Email) { |
54 | QString value = text(Email); | 54 | QString value = text(Email); |
55 | int val = value.findRev("@"); | 55 | int val = value.findRev("@"); |
56 | return value.mid( val) + value.left( val ); | 56 | return value.mid( val) + value.left( val ); |
57 | } | 57 | } |
58 | return text(column).lower(); | 58 | return text(column).lower(); |
59 | } | 59 | } |
60 | 60 | ||
61 | AddresseeDialog::AddresseeDialog( QWidget *parent, bool multiple ) : | 61 | AddresseeDialog::AddresseeDialog( QWidget *parent, bool multiple ) : |
62 | KDialogBase( KDialogBase::Plain, i18n("Select Addressee"), | 62 | KDialogBase( KDialogBase::Plain, i18n("Select Addressee"), |
63 | Ok|Cancel, No, parent ), mMultiple( multiple ) | 63 | Ok|Cancel, No, parent ), mMultiple( multiple ) |
64 | { | 64 | { |
65 | qDebug("NEW AddresseeDialog "); | 65 | qDebug("NEW AddresseeDialog "); |
66 | |||
66 | QWidget *topWidget = plainPage(); | 67 | QWidget *topWidget = plainPage(); |
67 | 68 | ||
68 | QBoxLayout *topLayout = new QHBoxLayout( topWidget ); | 69 | QBoxLayout *topLayout = new QHBoxLayout( topWidget ); |
69 | 70 | ||
70 | 71 | ||
71 | KDGanttMinimizeSplitter* mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, topWidget); | 72 | KDGanttMinimizeSplitter* mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, topWidget); |
72 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); | 73 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); |
73 | 74 | ||
74 | topLayout->addWidget(mMiniSplitter ); | 75 | topLayout->addWidget(mMiniSplitter ); |
75 | 76 | ||
76 | QWidget *listWidget = new QWidget( mMiniSplitter ); | 77 | QWidget *listWidget = new QWidget( mMiniSplitter ); |
77 | 78 | ||
78 | QVBoxLayout *listLayout = new QVBoxLayout (listWidget) ; | 79 | QVBoxLayout *listLayout = new QVBoxLayout (listWidget) ; |
79 | //topLayout->addLayout( listLayout ); | 80 | //topLayout->addLayout( listLayout ); |
80 | 81 | ||
81 | mAddresseeList = new KListView( listWidget ); | 82 | mAddresseeList = new KListView( listWidget ); |
82 | mAddresseeList->addColumn( i18n("Name") ); | 83 | mAddresseeList->addColumn( i18n("Name") ); |
83 | mAddresseeList->addColumn( i18n("Email") ); | 84 | mAddresseeList->addColumn( i18n("Email") ); |
84 | mAddresseeList->addColumn( i18n("Category") ); | 85 | mAddresseeList->addColumn( i18n("Category") ); |
85 | mAddresseeList->setAllColumnsShowFocus( true ); | 86 | mAddresseeList->setAllColumnsShowFocus( true ); |
86 | mAddresseeList->setFullWidth( true ); | 87 | mAddresseeList->setFullWidth( true ); |
87 | listLayout->addWidget( mAddresseeList ); | 88 | listLayout->addWidget( mAddresseeList ); |
88 | connect( mAddresseeList, SIGNAL( doubleClicked( QListViewItem * ) ), | 89 | connect( mAddresseeList, SIGNAL( doubleClicked( QListViewItem * ) ), |
89 | SLOT( slotOk() ) ); | 90 | SLOT( slotOk() ) ); |
90 | 91 | ||
91 | //QHBox* searchBox = new QHBox ( listWidget ); | 92 | //QHBox* searchBox = new QHBox ( listWidget ); |
92 | mAddresseeEdit = new QLineEdit( listWidget ); | 93 | mAddresseeEdit = new QLineEdit( listWidget ); |
93 | connect( mAddresseeEdit, SIGNAL( returnPressed() ), | 94 | connect( mAddresseeEdit, SIGNAL( returnPressed() ), |
94 | SLOT( loadAddressBook() ) ); | 95 | SLOT( loadAddressBook() ) ); |
95 | mAddresseeEdit->setFocus(); | 96 | mAddresseeEdit->setFocus(); |
96 | QPushButton *searchButton = new QPushButton( i18n("Search!"), listWidget ); | 97 | QPushButton *searchButton = new QPushButton( i18n("Search!"), listWidget ); |
97 | connect ( searchButton, SIGNAL( clicked() ), SLOT( loadAddressBook() ) ); | 98 | connect ( searchButton, SIGNAL( clicked() ), SLOT( loadAddressBook() ) ); |
98 | 99 | ||
99 | QHBoxLayout *searchLayout = new QHBoxLayout (listLayout) ; | 100 | QHBoxLayout *searchLayout = new QHBoxLayout (listLayout) ; |
100 | searchLayout->addWidget( mAddresseeEdit ); | 101 | searchLayout->addWidget( mAddresseeEdit ); |
101 | searchLayout->addWidget( searchButton ); | 102 | searchLayout->addWidget( searchButton ); |
102 | //listLayout->addWidget( searchBox ); | 103 | //listLayout->addWidget( searchBox ); |
103 | 104 | ||
104 | if ( mMultiple ) { | 105 | if ( mMultiple ) { |
105 | //QBoxLayout *selectedLayout = new QVBoxLayout; | 106 | //QBoxLayout *selectedLayout = new QVBoxLayout; |
106 | //topLayout->addLayout( selectedLayout ); | 107 | //topLayout->addLayout( selectedLayout ); |
107 | //topLayout->setSpacing( spacingHint() ); | 108 | //topLayout->setSpacing( spacingHint() ); |
108 | 109 | ||
109 | QVBox *selectedGroup = new QVBox( mMiniSplitter ); | 110 | QVBox *selectedGroup = new QVBox( mMiniSplitter ); |
110 | new QLabel ( i18n("Selected:"), selectedGroup ); | 111 | new QLabel ( i18n("Selected:"), selectedGroup ); |
111 | //selectedLayout->addWidget( selectedGroup ); | 112 | //selectedLayout->addWidget( selectedGroup ); |
112 | 113 | ||
113 | mSelectedList = new KListView( selectedGroup ); | 114 | mSelectedList = new KListView( selectedGroup ); |
114 | mSelectedList->addColumn( i18n("Name") ); | 115 | mSelectedList->addColumn( i18n("Name") ); |
115 | mSelectedList->addColumn( i18n("Email") ); | 116 | mSelectedList->addColumn( i18n("Email") ); |
116 | mSelectedList->setAllColumnsShowFocus( true ); | 117 | mSelectedList->setAllColumnsShowFocus( true ); |
117 | mSelectedList->setFullWidth( true ); | 118 | mSelectedList->setFullWidth( true ); |
118 | //connect( mSelectedList, SIGNAL( doubleClicked( QListViewItem * ) ), | 119 | //connect( mSelectedList, SIGNAL( doubleClicked( QListViewItem * ) ), |
119 | // SLOT( removeSelected() ) ); | 120 | // SLOT( removeSelected() ) ); |
120 | connect( mSelectedList, SIGNAL( clicked( QListViewItem * ) ), | 121 | connect( mSelectedList, SIGNAL( clicked( QListViewItem * ) ), |
121 | SLOT( removeSelected() ) ); | 122 | SLOT( removeSelected() ) ); |
122 | connect( mSelectedList, SIGNAL( returnPressed( QListViewItem *) ), | 123 | connect( mSelectedList, SIGNAL( returnPressed( QListViewItem *) ), |
123 | SLOT( removeSelected() ) ); | 124 | SLOT( removeSelected() ) ); |
124 | 125 | ||
125 | #if 0 | 126 | #if 0 |
126 | QPushButton *unselectButton = new QPushButton( i18n("Unselect"), selectedGroup ); | 127 | QPushButton *unselectButton = new QPushButton( i18n("Unselect"), selectedGroup ); |
127 | connect ( unselectButton, SIGNAL( clicked() ), SLOT( removeSelected() ) ); | 128 | connect ( unselectButton, SIGNAL( clicked() ), SLOT( removeSelected() ) ); |
128 | 129 | ||
129 | #endif | 130 | #endif |
130 | connect( mAddresseeList, SIGNAL( clicked( QListViewItem * ) ), | 131 | connect( mAddresseeList, SIGNAL( clicked( QListViewItem * ) ), |
131 | SLOT( addSelected( QListViewItem * ) ) ); | 132 | SLOT( addSelected( QListViewItem * ) ) ); |
132 | connect( mAddresseeList, SIGNAL( returnPressed( QListViewItem * ) ), | 133 | connect( mAddresseeList, SIGNAL( returnPressed( QListViewItem * ) ), |
133 | SLOT( selectNextItem( QListViewItem * ) ) ); | 134 | SLOT( selectNextItem( QListViewItem * ) ) ); |
134 | 135 | ||
135 | } | 136 | } |
136 | 137 | ||
137 | mAddressBook = StdAddressBook::self( true ); | 138 | mAddressBook = StdAddressBook::self( true ); |
138 | connect( mAddressBook, SIGNAL( addressBookChanged( AddressBook* ) ), | 139 | connect( mAddressBook, SIGNAL( addressBookChanged( AddressBook* ) ), |
139 | SLOT( addressBookChanged() ) ); | 140 | SLOT( addressBookChanged() ) ); |
140 | #if 0 | 141 | #if 0 |
141 | connect( mAddressBook, SIGNAL( loadingFinished( Resource* ) ), | 142 | connect( mAddressBook, SIGNAL( loadingFinished( Resource* ) ), |
142 | SLOT( addressBookChanged() ) ); | 143 | SLOT( addressBookChanged() ) ); |
143 | #endif | 144 | #endif |
144 | loadAddressBook(); | 145 | loadAddressBook(); |
145 | QValueList<int> splitterSize; | 146 | QValueList<int> splitterSize; |
146 | splitterSize.append( ( width() / 5 ) * 3 ); | 147 | splitterSize.append( ( width() / 5 ) * 3 ); |
147 | splitterSize.append( ( width() / 5 ) *2 ); | 148 | splitterSize.append( ( width() / 5 ) *2 ); |
148 | mMiniSplitter->setSizes( splitterSize ); | 149 | mMiniSplitter->setSizes( splitterSize ); |
149 | } | 150 | } |
150 | 151 | ||
151 | AddresseeDialog::~AddresseeDialog() | 152 | AddresseeDialog::~AddresseeDialog() |
152 | { | 153 | { |
153 | qDebug("DELETE AddresseeDialog "); | 154 | qDebug("DELETE AddresseeDialog "); |
154 | } | 155 | } |
155 | 156 | ||
156 | void AddresseeDialog::loadAddressBook() | 157 | void AddresseeDialog::loadAddressBook() |
157 | { | 158 | { |
158 | mAddresseeList->clear(); | 159 | mAddresseeList->clear(); |
159 | mItemDict.clear(); | 160 | mItemDict.clear(); |
160 | if ( mAddresseeEdit->text().isEmpty() ) { | 161 | if ( mAddresseeEdit->text().isEmpty() ) { |
161 | AddressBook::Iterator it; | 162 | AddressBook::Iterator it; |
162 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 163 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
163 | if ( (*it).uid().left(2) == "la" && (*it).uid().left(19) == QString("last-syncAddressee-") ) | 164 | if ( (*it).uid().left(2) == "la" && (*it).uid().left(19) == QString("last-syncAddressee-") ) |
164 | continue; | 165 | continue; |
165 | new AddresseeItem( mAddresseeList, (*it) ); | 166 | new AddresseeItem( mAddresseeList, (*it) ); |
166 | } | 167 | } |
167 | return; | 168 | return; |
168 | } | 169 | } |
169 | //mAddresseeEdit->completionObject()->clear(); | 170 | //mAddresseeEdit->completionObject()->clear(); |
170 | QRegExp re; | 171 | QRegExp re; |
171 | re.setWildcard(true); // most people understand these better. | 172 | re.setWildcard(true); // most people understand these better. |
172 | re.setCaseSensitive(false); | 173 | re.setCaseSensitive(false); |
173 | re.setPattern( "*"+ mAddresseeEdit->text() + "*"); | 174 | re.setPattern( "*"+ mAddresseeEdit->text() + "*"); |
174 | 175 | ||
175 | AddressBook::Iterator it; | 176 | AddressBook::Iterator it; |
176 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 177 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
177 | if ( (*it).uid().left(2) == "la" && (*it).uid().left(19) == QString("last-syncAddressee-") ) | 178 | if ( (*it).uid().left(2) == "la" && (*it).uid().left(19) == QString("last-syncAddressee-") ) |
178 | continue; | 179 | continue; |
179 | QString name = (*it).realName(); | 180 | QString name = (*it).realName(); |
180 | name += (*it).preferredEmail(); | 181 | name += (*it).preferredEmail(); |
181 | name += (*it).categories().join(";"); | 182 | name += (*it).categories().join(";"); |
182 | #if QT_VERSION >= 0x030000 | 183 | #if QT_VERSION >= 0x030000 |
183 | if (re.search(name) != -1) | 184 | if (re.search(name) != -1) |
184 | #else | 185 | #else |
185 | if (re.match(name) != -1) | 186 | if (re.match(name) != -1) |
186 | #endif | 187 | #endif |
187 | AddresseeItem *item = new AddresseeItem( mAddresseeList, (*it) ); | 188 | AddresseeItem *item = new AddresseeItem( mAddresseeList, (*it) ); |
188 | } | 189 | } |
189 | } | 190 | } |
190 | 191 | ||
191 | void AddresseeDialog::addCompletionItem( const QString &str, QListViewItem *item ) | 192 | void AddresseeDialog::addCompletionItem( const QString &str, QListViewItem *item ) |
192 | { | 193 | { |
193 | if ( str.isEmpty() ) return; | 194 | if ( str.isEmpty() ) return; |
194 | 195 | ||
195 | mItemDict.insert( str, item ); | 196 | mItemDict.insert( str, item ); |
196 | //mAddresseeEdit->completionObject()->addItem( str ); | 197 | //mAddresseeEdit->completionObject()->addItem( str ); |
197 | } | 198 | } |
198 | 199 | ||
199 | void AddresseeDialog::selectItem( const QString &str ) | 200 | void AddresseeDialog::selectItem( const QString &str ) |
200 | { | 201 | { |
201 | if ( str.isEmpty() ) return; | 202 | if ( str.isEmpty() ) return; |
202 | 203 | ||
203 | QListViewItem *item = mItemDict.find( str ); | 204 | QListViewItem *item = mItemDict.find( str ); |
204 | if ( item ) { | 205 | if ( item ) { |
205 | mAddresseeList->blockSignals( true ); | 206 | mAddresseeList->blockSignals( true ); |
206 | mAddresseeList->setSelected( item, true ); | 207 | mAddresseeList->setSelected( item, true ); |
207 | mAddresseeList->ensureItemVisible( item ); | 208 | mAddresseeList->ensureItemVisible( item ); |
208 | mAddresseeList->blockSignals( false ); | 209 | mAddresseeList->blockSignals( false ); |
209 | } | 210 | } |
210 | } | 211 | } |
211 | 212 | ||
212 | void AddresseeDialog::updateEdit( QListViewItem *item ) | 213 | void AddresseeDialog::updateEdit( QListViewItem *item ) |
213 | { | 214 | { |
214 | mAddresseeEdit->setText( item->text( 0 ) ); | 215 | mAddresseeEdit->setText( item->text( 0 ) ); |
215 | mAddresseeEdit->setSelection( 0, item->text( 0 ).length() ); | 216 | mAddresseeEdit->setSelection( 0, item->text( 0 ).length() ); |
216 | } | 217 | } |
217 | 218 | ||
218 | void AddresseeDialog::selectNextItem( QListViewItem *item ) | 219 | void AddresseeDialog::selectNextItem( QListViewItem *item ) |
219 | { | 220 | { |
220 | addSelected( item ); | 221 | addSelected( item ); |
221 | QListViewItem *next = item->nextSibling(); | 222 | QListViewItem *next = item->nextSibling(); |
222 | if ( next ) { | 223 | if ( next ) { |
223 | next->setSelected( true ); | 224 | next->setSelected( true ); |
224 | item->setSelected( false ); | 225 | item->setSelected( false ); |
225 | mAddresseeList->setCurrentItem( next ); | 226 | mAddresseeList->setCurrentItem( next ); |
226 | } | 227 | } |
227 | } | 228 | } |
228 | void AddresseeDialog::addSelected( QListViewItem *item ) | 229 | void AddresseeDialog::addSelected( QListViewItem *item ) |
229 | { | 230 | { |
230 | AddresseeItem *addrItem = (AddresseeItem *)( item ); | 231 | AddresseeItem *addrItem = (AddresseeItem *)( item ); |
231 | if ( !addrItem ) return; | 232 | if ( !addrItem ) return; |
232 | 233 | ||
233 | Addressee a = addrItem->addressee(); | 234 | Addressee a = addrItem->addressee(); |
234 | 235 | ||
235 | QListViewItem *selectedItem = mSelectedDict.find( a.uid() ); | 236 | QListViewItem *selectedItem = mSelectedDict.find( a.uid() ); |
236 | if ( !selectedItem ) { | 237 | if ( !selectedItem ) { |
237 | selectedItem = new AddresseeItem( mSelectedList, a ); | 238 | selectedItem = new AddresseeItem( mSelectedList, a ); |
238 | mSelectedDict.insert( a.uid(), selectedItem ); | 239 | mSelectedDict.insert( a.uid(), selectedItem ); |
239 | } | 240 | } |
240 | 241 | ||
241 | } | 242 | } |
242 | 243 | ||
243 | void AddresseeDialog::removeSelected() | 244 | void AddresseeDialog::removeSelected() |
244 | { | 245 | { |
245 | QListViewItem *item = mSelectedList->selectedItem(); | 246 | QListViewItem *item = mSelectedList->selectedItem(); |
246 | AddresseeItem *addrItem = (AddresseeItem *)( item ); | 247 | AddresseeItem *addrItem = (AddresseeItem *)( item ); |
247 | if ( !addrItem ) return; | 248 | if ( !addrItem ) return; |
248 | QListViewItem *next = item->nextSibling(); | 249 | QListViewItem *next = item->nextSibling(); |
249 | mSelectedDict.remove( addrItem->addressee().uid() ); | 250 | mSelectedDict.remove( addrItem->addressee().uid() ); |
250 | delete addrItem; | 251 | delete addrItem; |
251 | if ( next ) | 252 | if ( next ) |
252 | next->setSelected( true ); | 253 | next->setSelected( true ); |
253 | } | 254 | } |
254 | 255 | ||
255 | Addressee AddresseeDialog::addressee() | 256 | Addressee AddresseeDialog::addressee() |
256 | { | 257 | { |
257 | AddresseeItem *aItem = 0; | 258 | AddresseeItem *aItem = 0; |
258 | 259 | ||
259 | if ( mMultiple ) | 260 | if ( mMultiple ) |
260 | aItem = (AddresseeItem *)( mSelectedList->firstChild() ); | 261 | aItem = (AddresseeItem *)( mSelectedList->firstChild() ); |
261 | else | 262 | else |
262 | aItem = (AddresseeItem *)( mAddresseeList->selectedItem() ); | 263 | aItem = (AddresseeItem *)( mAddresseeList->selectedItem() ); |
263 | 264 | ||
264 | if (aItem) return aItem->addressee(); | 265 | if (aItem) return aItem->addressee(); |
265 | return Addressee(); | 266 | return Addressee(); |
266 | } | 267 | } |
267 | 268 | ||
268 | Addressee::List AddresseeDialog::addressees() | 269 | Addressee::List AddresseeDialog::addressees() |
269 | { | 270 | { |
270 | Addressee::List al; | 271 | Addressee::List al; |
271 | AddresseeItem *aItem = 0; | 272 | AddresseeItem *aItem = 0; |
272 | 273 | ||
273 | if ( mMultiple ) { | 274 | if ( mMultiple ) { |
274 | QListViewItem *item = mSelectedList->firstChild(); | 275 | QListViewItem *item = mSelectedList->firstChild(); |
275 | while( item ) { | 276 | while( item ) { |
276 | aItem = (AddresseeItem *)( item ); | 277 | aItem = (AddresseeItem *)( item ); |
277 | if ( aItem ) al.append( aItem->addressee() ); | 278 | if ( aItem ) al.append( aItem->addressee() ); |
278 | item = item->nextSibling(); | 279 | item = item->nextSibling(); |
279 | } | 280 | } |
280 | } | 281 | } |
281 | else | 282 | else |
282 | { | 283 | { |
283 | aItem = (AddresseeItem *)( mAddresseeList->selectedItem() ); | 284 | aItem = (AddresseeItem *)( mAddresseeList->selectedItem() ); |
284 | if (aItem) al.append( aItem->addressee() ); | 285 | if (aItem) al.append( aItem->addressee() ); |
285 | } | 286 | } |
286 | 287 | ||
287 | return al; | 288 | return al; |
288 | } | 289 | } |
289 | 290 | ||
290 | Addressee AddresseeDialog::getAddressee( QWidget *parent ) | 291 | Addressee AddresseeDialog::getAddressee( QWidget *parent ) |
291 | { | 292 | { |
292 | AddresseeDialog *dlg = new AddresseeDialog( parent ); | 293 | AddresseeDialog *dlg = new AddresseeDialog( parent ); |
293 | Addressee addressee; | 294 | Addressee addressee; |
294 | #ifdef DESKTOP_VERSION | 295 | #ifdef DESKTOP_VERSION |
295 | static int geoX = 0; | 296 | static int geoX = 0; |
296 | static int geoY = 0; | 297 | static int geoY = 0; |
297 | static int geoW = 0; | 298 | static int geoW = 0; |
298 | static int geoH = 0; | 299 | static int geoH = 0; |
299 | if ( !geoX && ! geoY && !geoW &&!geoH ) { | 300 | if ( !geoX && ! geoY && !geoW &&!geoH ) { |
300 | geoX = dlg->geometry().x(); | 301 | geoX = dlg->geometry().x(); |
301 | geoY = dlg->geometry().y(); | 302 | geoY = dlg->geometry().y(); |
302 | geoW = dlg->width(); | 303 | geoW = dlg->width(); |
303 | geoH = dlg->height(); | 304 | geoH = dlg->height(); |
304 | } else { | 305 | } else { |
305 | dlg->show(); | 306 | dlg->show(); |
306 | dlg->setGeometry(geoX , geoY,geoW , geoH ); | 307 | dlg->setGeometry(geoX , geoY,geoW , geoH ); |
307 | 308 | ||
308 | } | 309 | } |
309 | #endif | 310 | #endif |
310 | int result = dlg->exec(); | 311 | int result = dlg->exec(); |
311 | #ifdef DESKTOP_VERSION | 312 | #ifdef DESKTOP_VERSION |
312 | geoX = dlg->geometry().x(); | 313 | geoX = dlg->geometry().x(); |
313 | geoY = dlg->geometry().y(); | 314 | geoY = dlg->geometry().y(); |
314 | geoW = dlg->width(); | 315 | geoW = dlg->width(); |
315 | geoH = dlg->height(); | 316 | geoH = dlg->height(); |
316 | #endif | 317 | #endif |
317 | if ( result == QDialog::Accepted ) { | 318 | if ( result == QDialog::Accepted ) { |
318 | addressee = dlg->addressee(); | 319 | addressee = dlg->addressee(); |
319 | } | 320 | } |
320 | 321 | ||
321 | delete dlg; | 322 | delete dlg; |
322 | return addressee; | 323 | return addressee; |
323 | } | 324 | } |
324 | 325 | ||
325 | Addressee::List AddresseeDialog::getAddressees( QWidget *parent ) | 326 | Addressee::List AddresseeDialog::getAddressees( QWidget *parent ) |
326 | { | 327 | { |
327 | AddresseeDialog *dlg = new AddresseeDialog( parent, true ); | ||
328 | Addressee::List addressees; | 328 | Addressee::List addressees; |
329 | static bool running = false; | ||
330 | if ( running ) return addressees; | ||
331 | running = true; | ||
332 | AddresseeDialog *dlg = new AddresseeDialog( parent, true ); | ||
329 | static int geoX = 0; | 333 | static int geoX = 0; |
330 | static int geoY = 0; | 334 | static int geoY = 0; |
331 | static int geoW = 0; | 335 | static int geoW = 0; |
332 | static int geoH = 0; | 336 | static int geoH = 0; |
333 | if ( QApplication::desktop()->width() <= 640 ) | 337 | if ( QApplication::desktop()->width() <= 640 ) |
334 | dlg->showMaximized(); | 338 | dlg->showMaximized(); |
335 | else { | 339 | else { |
336 | if ( !geoX && ! geoY && !geoW &&!geoH ) { | 340 | if ( !geoX && ! geoY && !geoW &&!geoH ) { |
337 | geoX = dlg->geometry().x(); | 341 | geoX = dlg->geometry().x(); |
338 | geoY = dlg->geometry().y(); | 342 | geoY = dlg->geometry().y(); |
339 | geoW = dlg->width(); | 343 | geoW = dlg->width(); |
340 | geoH = dlg->height(); | 344 | geoH = dlg->height(); |
341 | } else { | 345 | } else { |
342 | dlg->show(); | 346 | dlg->show(); |
343 | dlg->setGeometry(geoX , geoY,geoW , geoH ); | 347 | dlg->setGeometry(geoX , geoY,geoW , geoH ); |
344 | 348 | ||
345 | } | 349 | } |
346 | } | 350 | } |
347 | int result = dlg->exec(); | 351 | int result = dlg->exec(); |
348 | geoX = dlg->geometry().x(); | 352 | geoX = dlg->geometry().x(); |
349 | geoY = dlg->geometry().y(); | 353 | geoY = dlg->geometry().y(); |
350 | geoW = dlg->width(); | 354 | geoW = dlg->width(); |
351 | geoH = dlg->height(); | 355 | geoH = dlg->height(); |
352 | if ( result == QDialog::Accepted ) { | 356 | if ( result == QDialog::Accepted ) { |
353 | addressees = dlg->addressees(); | 357 | addressees = dlg->addressees(); |
354 | } | 358 | } |
355 | 359 | ||
356 | delete dlg; | 360 | delete dlg; |
361 | running = false; | ||
357 | return addressees; | 362 | return addressees; |
358 | } | 363 | } |
359 | 364 | ||
360 | void AddresseeDialog::addressBookChanged() | 365 | void AddresseeDialog::addressBookChanged() |
361 | { | 366 | { |
362 | loadAddressBook(); | 367 | loadAddressBook(); |
363 | } | 368 | } |
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp index b107e2d..3715786 100644 --- a/kaddressbook/kabcore.cpp +++ b/kaddressbook/kabcore.cpp | |||
@@ -1779,1589 +1779,1593 @@ void KABCore::initGUI() | |||
1779 | topLayout->addWidget( mJumpButtonBar ); | 1779 | topLayout->addWidget( mJumpButtonBar ); |
1780 | //topLayout->setStretchFactor( mJumpButtonBar, 1 ); | 1780 | //topLayout->setStretchFactor( mJumpButtonBar, 1 ); |
1781 | 1781 | ||
1782 | mXXPortManager = new XXPortManager( this, this ); | 1782 | mXXPortManager = new XXPortManager( this, this ); |
1783 | 1783 | ||
1784 | #else //KAB_EMBEDDED | 1784 | #else //KAB_EMBEDDED |
1785 | //US initialize viewMenu before settingup viewmanager. | 1785 | //US initialize viewMenu before settingup viewmanager. |
1786 | // Viewmanager needs this menu to plugin submenues. | 1786 | // Viewmanager needs this menu to plugin submenues. |
1787 | viewMenu = new QPopupMenu( this ); | 1787 | viewMenu = new QPopupMenu( this ); |
1788 | settingsMenu = new QPopupMenu( this ); | 1788 | settingsMenu = new QPopupMenu( this ); |
1789 | //filterMenu = new QPopupMenu( this ); | 1789 | //filterMenu = new QPopupMenu( this ); |
1790 | ImportMenu = new QPopupMenu( this ); | 1790 | ImportMenu = new QPopupMenu( this ); |
1791 | ExportMenu = new QPopupMenu( this ); | 1791 | ExportMenu = new QPopupMenu( this ); |
1792 | syncMenu = new QPopupMenu( this ); | 1792 | syncMenu = new QPopupMenu( this ); |
1793 | changeMenu= new QPopupMenu( this ); | 1793 | changeMenu= new QPopupMenu( this ); |
1794 | beamMenu= new QPopupMenu( this ); | 1794 | beamMenu= new QPopupMenu( this ); |
1795 | 1795 | ||
1796 | //US since we have no splitter for the embedded system, setup | 1796 | //US since we have no splitter for the embedded system, setup |
1797 | // a layout with two frames. One left and one right. | 1797 | // a layout with two frames. One left and one right. |
1798 | 1798 | ||
1799 | QBoxLayout *topLayout; | 1799 | QBoxLayout *topLayout; |
1800 | 1800 | ||
1801 | // = new QHBoxLayout( this ); | 1801 | // = new QHBoxLayout( this ); |
1802 | // QBoxLayout *topLayout = (QBoxLayout*)layout(); | 1802 | // QBoxLayout *topLayout = (QBoxLayout*)layout(); |
1803 | 1803 | ||
1804 | // QWidget *mainBox = new QWidget( this ); | 1804 | // QWidget *mainBox = new QWidget( this ); |
1805 | // QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox); | 1805 | // QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox); |
1806 | 1806 | ||
1807 | #ifdef DESKTOP_VERSION | 1807 | #ifdef DESKTOP_VERSION |
1808 | topLayout = new QHBoxLayout( this ); | 1808 | topLayout = new QHBoxLayout( this ); |
1809 | 1809 | ||
1810 | 1810 | ||
1811 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); | 1811 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); |
1812 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); | 1812 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); |
1813 | 1813 | ||
1814 | topLayout->addWidget(mMiniSplitter ); | 1814 | topLayout->addWidget(mMiniSplitter ); |
1815 | 1815 | ||
1816 | mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter ); | 1816 | mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter ); |
1817 | mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); | 1817 | mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); |
1818 | mViewManager = new ViewManager( this, mExtensionBarSplitter ); | 1818 | mViewManager = new ViewManager( this, mExtensionBarSplitter ); |
1819 | mDetails = new ViewContainer( mMiniSplitter ); | 1819 | mDetails = new ViewContainer( mMiniSplitter ); |
1820 | mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); | 1820 | mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); |
1821 | #else | 1821 | #else |
1822 | if ( QApplication::desktop()->width() > 480 ) { | 1822 | if ( QApplication::desktop()->width() > 480 ) { |
1823 | topLayout = new QHBoxLayout( this ); | 1823 | topLayout = new QHBoxLayout( this ); |
1824 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); | 1824 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); |
1825 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); | 1825 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); |
1826 | } else { | 1826 | } else { |
1827 | 1827 | ||
1828 | topLayout = new QHBoxLayout( this ); | 1828 | topLayout = new QHBoxLayout( this ); |
1829 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this); | 1829 | mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this); |
1830 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); | 1830 | mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); |
1831 | } | 1831 | } |
1832 | 1832 | ||
1833 | topLayout->addWidget(mMiniSplitter ); | 1833 | topLayout->addWidget(mMiniSplitter ); |
1834 | mViewManager = new ViewManager( this, mMiniSplitter ); | 1834 | mViewManager = new ViewManager( this, mMiniSplitter ); |
1835 | mDetails = new ViewContainer( mMiniSplitter ); | 1835 | mDetails = new ViewContainer( mMiniSplitter ); |
1836 | 1836 | ||
1837 | 1837 | ||
1838 | mExtensionManager = new ExtensionManager( this, mMiniSplitter ); | 1838 | mExtensionManager = new ExtensionManager( this, mMiniSplitter ); |
1839 | #endif | 1839 | #endif |
1840 | //eh->hide(); | 1840 | //eh->hide(); |
1841 | // topLayout->addWidget(mExtensionManager ); | 1841 | // topLayout->addWidget(mExtensionManager ); |
1842 | 1842 | ||
1843 | 1843 | ||
1844 | /*US | 1844 | /*US |
1845 | #ifndef KAB_NOSPLITTER | 1845 | #ifndef KAB_NOSPLITTER |
1846 | QHBoxLayout *topLayout = new QHBoxLayout( this ); | 1846 | QHBoxLayout *topLayout = new QHBoxLayout( this ); |
1847 | //US topLayout->setSpacing( KDialogBase::spacingHint() ); | 1847 | //US topLayout->setSpacing( KDialogBase::spacingHint() ); |
1848 | topLayout->setSpacing( 10 ); | 1848 | topLayout->setSpacing( 10 ); |
1849 | 1849 | ||
1850 | mDetailsSplitter = new QSplitter( this ); | 1850 | mDetailsSplitter = new QSplitter( this ); |
1851 | 1851 | ||
1852 | QVBox *viewSpace = new QVBox( mDetailsSplitter ); | 1852 | QVBox *viewSpace = new QVBox( mDetailsSplitter ); |
1853 | 1853 | ||
1854 | mViewManager = new ViewManager( this, viewSpace ); | 1854 | mViewManager = new ViewManager( this, viewSpace ); |
1855 | viewSpace->setStretchFactor( mViewManager, 1 ); | 1855 | viewSpace->setStretchFactor( mViewManager, 1 ); |
1856 | 1856 | ||
1857 | mDetails = new ViewContainer( mDetailsSplitter ); | 1857 | mDetails = new ViewContainer( mDetailsSplitter ); |
1858 | 1858 | ||
1859 | topLayout->addWidget( mDetailsSplitter ); | 1859 | topLayout->addWidget( mDetailsSplitter ); |
1860 | topLayout->setStretchFactor( mDetailsSplitter, 100 ); | 1860 | topLayout->setStretchFactor( mDetailsSplitter, 100 ); |
1861 | #else //KAB_NOSPLITTER | 1861 | #else //KAB_NOSPLITTER |
1862 | QHBoxLayout *topLayout = new QHBoxLayout( this ); | 1862 | QHBoxLayout *topLayout = new QHBoxLayout( this ); |
1863 | //US topLayout->setSpacing( KDialogBase::spacingHint() ); | 1863 | //US topLayout->setSpacing( KDialogBase::spacingHint() ); |
1864 | topLayout->setSpacing( 10 ); | 1864 | topLayout->setSpacing( 10 ); |
1865 | 1865 | ||
1866 | // mDetailsSplitter = new QSplitter( this ); | 1866 | // mDetailsSplitter = new QSplitter( this ); |
1867 | 1867 | ||
1868 | QVBox *viewSpace = new QVBox( this ); | 1868 | QVBox *viewSpace = new QVBox( this ); |
1869 | 1869 | ||
1870 | mViewManager = new ViewManager( this, viewSpace ); | 1870 | mViewManager = new ViewManager( this, viewSpace ); |
1871 | viewSpace->setStretchFactor( mViewManager, 1 ); | 1871 | viewSpace->setStretchFactor( mViewManager, 1 ); |
1872 | 1872 | ||
1873 | mDetails = new ViewContainer( this ); | 1873 | mDetails = new ViewContainer( this ); |
1874 | 1874 | ||
1875 | topLayout->addWidget( viewSpace ); | 1875 | topLayout->addWidget( viewSpace ); |
1876 | // topLayout->setStretchFactor( mDetailsSplitter, 100 ); | 1876 | // topLayout->setStretchFactor( mDetailsSplitter, 100 ); |
1877 | topLayout->addWidget( mDetails ); | 1877 | topLayout->addWidget( mDetails ); |
1878 | #endif //KAB_NOSPLITTER | 1878 | #endif //KAB_NOSPLITTER |
1879 | */ | 1879 | */ |
1880 | 1880 | ||
1881 | syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu); | 1881 | syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu); |
1882 | syncManager->setBlockSave(false); | 1882 | syncManager->setBlockSave(false); |
1883 | 1883 | ||
1884 | connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); | 1884 | connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); |
1885 | connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); | 1885 | connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); |
1886 | QString sync_file = sentSyncFile(); | 1886 | QString sync_file = sentSyncFile(); |
1887 | //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1()); | 1887 | //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1()); |
1888 | syncManager->setDefaultFileName( sync_file ); | 1888 | syncManager->setDefaultFileName( sync_file ); |
1889 | //connect(syncManager , SIGNAL( ), this, SLOT( ) ); | 1889 | //connect(syncManager , SIGNAL( ), this, SLOT( ) ); |
1890 | 1890 | ||
1891 | #endif //KAB_EMBEDDED | 1891 | #endif //KAB_EMBEDDED |
1892 | initActions(); | 1892 | initActions(); |
1893 | 1893 | ||
1894 | #ifdef KAB_EMBEDDED | 1894 | #ifdef KAB_EMBEDDED |
1895 | addActionsManually(); | 1895 | addActionsManually(); |
1896 | //US make sure the export and import menues are initialized before creating the xxPortManager. | 1896 | //US make sure the export and import menues are initialized before creating the xxPortManager. |
1897 | mXXPortManager = new XXPortManager( this, this ); | 1897 | mXXPortManager = new XXPortManager( this, this ); |
1898 | 1898 | ||
1899 | // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() ); | 1899 | // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() ); |
1900 | //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget); | 1900 | //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget); |
1901 | // mActionQuit->plug ( mMainWindow->toolBar()); | 1901 | // mActionQuit->plug ( mMainWindow->toolBar()); |
1902 | //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() ); | 1902 | //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() ); |
1903 | //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget); | 1903 | //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget); |
1904 | // mIncSearchWidget->hide(); | 1904 | // mIncSearchWidget->hide(); |
1905 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), | 1905 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), |
1906 | SLOT( incrementalSearch( const QString& ) ) ); | 1906 | SLOT( incrementalSearch( const QString& ) ) ); |
1907 | connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) ); | 1907 | connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) ); |
1908 | connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) ); | 1908 | connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) ); |
1909 | 1909 | ||
1910 | mJumpButtonBar = new JumpButtonBar( this, this ); | 1910 | mJumpButtonBar = new JumpButtonBar( this, this ); |
1911 | 1911 | ||
1912 | topLayout->addWidget( mJumpButtonBar ); | 1912 | topLayout->addWidget( mJumpButtonBar ); |
1913 | //US topLayout->setStretchFactor( mJumpButtonBar, 10 ); | 1913 | //US topLayout->setStretchFactor( mJumpButtonBar, 10 ); |
1914 | 1914 | ||
1915 | // mMainWindow->getIconToolBar()->raise(); | 1915 | // mMainWindow->getIconToolBar()->raise(); |
1916 | 1916 | ||
1917 | #endif //KAB_EMBEDDED | 1917 | #endif //KAB_EMBEDDED |
1918 | 1918 | ||
1919 | } | 1919 | } |
1920 | void KABCore::initActions() | 1920 | void KABCore::initActions() |
1921 | { | 1921 | { |
1922 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); | 1922 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); |
1923 | 1923 | ||
1924 | #ifndef KAB_EMBEDDED | 1924 | #ifndef KAB_EMBEDDED |
1925 | connect( QApplication::clipboard(), SIGNAL( dataChanged() ), | 1925 | connect( QApplication::clipboard(), SIGNAL( dataChanged() ), |
1926 | SLOT( clipboardDataChanged() ) ); | 1926 | SLOT( clipboardDataChanged() ) ); |
1927 | #endif //KAB_EMBEDDED | 1927 | #endif //KAB_EMBEDDED |
1928 | 1928 | ||
1929 | // file menu | 1929 | // file menu |
1930 | 1930 | ||
1931 | mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() ); | 1931 | mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() ); |
1932 | //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() ); | 1932 | //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() ); |
1933 | mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager, | 1933 | mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager, |
1934 | SLOT( printView() ), actionCollection(), "kaddressbook_print" ); | 1934 | SLOT( printView() ), actionCollection(), "kaddressbook_print" ); |
1935 | 1935 | ||
1936 | 1936 | ||
1937 | mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails, | 1937 | mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails, |
1938 | SLOT( printView() ), actionCollection(), "kaddressbook_print2" ); | 1938 | SLOT( printView() ), actionCollection(), "kaddressbook_print2" ); |
1939 | 1939 | ||
1940 | mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this, | 1940 | mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this, |
1941 | SLOT( save() ), actionCollection(), "file_sync" ); | 1941 | SLOT( save() ), actionCollection(), "file_sync" ); |
1942 | 1942 | ||
1943 | mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this, | 1943 | mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this, |
1944 | SLOT( newContact() ), actionCollection(), "file_new_contact" ); | 1944 | SLOT( newContact() ), actionCollection(), "file_new_contact" ); |
1945 | 1945 | ||
1946 | mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0, | 1946 | mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0, |
1947 | this, SLOT( mailVCard() ), | 1947 | this, SLOT( mailVCard() ), |
1948 | actionCollection(), "file_mail_vcard"); | 1948 | actionCollection(), "file_mail_vcard"); |
1949 | 1949 | ||
1950 | mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this, | 1950 | mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this, |
1951 | SLOT( export2phone() ), actionCollection(), | 1951 | SLOT( export2phone() ), actionCollection(), |
1952 | "kaddressbook_ex2phone" ); | 1952 | "kaddressbook_ex2phone" ); |
1953 | 1953 | ||
1954 | mActionBeamVCard = 0; | 1954 | mActionBeamVCard = 0; |
1955 | mActionBeam = 0; | 1955 | mActionBeam = 0; |
1956 | 1956 | ||
1957 | #ifndef DESKTOP_VERSION | 1957 | #ifndef DESKTOP_VERSION |
1958 | if ( Ir::supported() ) { | 1958 | if ( Ir::supported() ) { |
1959 | mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this, | 1959 | mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this, |
1960 | SLOT( beamVCard() ), actionCollection(), | 1960 | SLOT( beamVCard() ), actionCollection(), |
1961 | "kaddressbook_beam_vcard" ); | 1961 | "kaddressbook_beam_vcard" ); |
1962 | 1962 | ||
1963 | mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this, | 1963 | mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this, |
1964 | SLOT( beamMySelf() ), actionCollection(), | 1964 | SLOT( beamMySelf() ), actionCollection(), |
1965 | "kaddressbook_beam_myself" ); | 1965 | "kaddressbook_beam_myself" ); |
1966 | } | 1966 | } |
1967 | #endif | 1967 | #endif |
1968 | 1968 | ||
1969 | mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0, | 1969 | mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0, |
1970 | this, SLOT( editContact2() ), | 1970 | this, SLOT( editContact2() ), |
1971 | actionCollection(), "file_properties" ); | 1971 | actionCollection(), "file_properties" ); |
1972 | 1972 | ||
1973 | #ifdef KAB_EMBEDDED | 1973 | #ifdef KAB_EMBEDDED |
1974 | // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() ); | 1974 | // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() ); |
1975 | mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0, | 1975 | mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0, |
1976 | mMainWindow, SLOT( exit() ), | 1976 | mMainWindow, SLOT( exit() ), |
1977 | actionCollection(), "quit" ); | 1977 | actionCollection(), "quit" ); |
1978 | #endif //KAB_EMBEDDED | 1978 | #endif //KAB_EMBEDDED |
1979 | 1979 | ||
1980 | // edit menu | 1980 | // edit menu |
1981 | if ( mIsPart ) { | 1981 | if ( mIsPart ) { |
1982 | mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this, | 1982 | mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this, |
1983 | SLOT( copyContacts() ), actionCollection(), | 1983 | SLOT( copyContacts() ), actionCollection(), |
1984 | "kaddressbook_copy" ); | 1984 | "kaddressbook_copy" ); |
1985 | mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this, | 1985 | mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this, |
1986 | SLOT( cutContacts() ), actionCollection(), | 1986 | SLOT( cutContacts() ), actionCollection(), |
1987 | "kaddressbook_cut" ); | 1987 | "kaddressbook_cut" ); |
1988 | mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this, | 1988 | mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this, |
1989 | SLOT( pasteContacts() ), actionCollection(), | 1989 | SLOT( pasteContacts() ), actionCollection(), |
1990 | "kaddressbook_paste" ); | 1990 | "kaddressbook_paste" ); |
1991 | mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this, | 1991 | mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this, |
1992 | SLOT( selectAllContacts() ), actionCollection(), | 1992 | SLOT( selectAllContacts() ), actionCollection(), |
1993 | "kaddressbook_select_all" ); | 1993 | "kaddressbook_select_all" ); |
1994 | mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this, | 1994 | mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this, |
1995 | SLOT( undo() ), actionCollection(), | 1995 | SLOT( undo() ), actionCollection(), |
1996 | "kaddressbook_undo" ); | 1996 | "kaddressbook_undo" ); |
1997 | mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z, | 1997 | mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z, |
1998 | this, SLOT( redo() ), actionCollection(), | 1998 | this, SLOT( redo() ), actionCollection(), |
1999 | "kaddressbook_redo" ); | 1999 | "kaddressbook_redo" ); |
2000 | } else { | 2000 | } else { |
2001 | mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() ); | 2001 | mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() ); |
2002 | mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() ); | 2002 | mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() ); |
2003 | mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() ); | 2003 | mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() ); |
2004 | mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() ); | 2004 | mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() ); |
2005 | mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() ); | 2005 | mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() ); |
2006 | mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() ); | 2006 | mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() ); |
2007 | } | 2007 | } |
2008 | 2008 | ||
2009 | mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", | 2009 | mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", |
2010 | Key_Delete, this, SLOT( deleteContacts() ), | 2010 | Key_Delete, this, SLOT( deleteContacts() ), |
2011 | actionCollection(), "edit_delete" ); | 2011 | actionCollection(), "edit_delete" ); |
2012 | 2012 | ||
2013 | mActionUndo->setEnabled( false ); | 2013 | mActionUndo->setEnabled( false ); |
2014 | mActionRedo->setEnabled( false ); | 2014 | mActionRedo->setEnabled( false ); |
2015 | 2015 | ||
2016 | // settings menu | 2016 | // settings menu |
2017 | #ifdef KAB_EMBEDDED | 2017 | #ifdef KAB_EMBEDDED |
2018 | //US special menuentry to configure the addressbook resources. On KDE | 2018 | //US special menuentry to configure the addressbook resources. On KDE |
2019 | // you do that through the control center !!! | 2019 | // you do that through the control center !!! |
2020 | mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, | 2020 | mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, |
2021 | SLOT( configureResources() ), actionCollection(), | 2021 | SLOT( configureResources() ), actionCollection(), |
2022 | "kaddressbook_configure_resources" ); | 2022 | "kaddressbook_configure_resources" ); |
2023 | #endif //KAB_EMBEDDED | 2023 | #endif //KAB_EMBEDDED |
2024 | 2024 | ||
2025 | if ( mIsPart ) { | 2025 | if ( mIsPart ) { |
2026 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, | 2026 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, |
2027 | SLOT( openConfigDialog() ), actionCollection(), | 2027 | SLOT( openConfigDialog() ), actionCollection(), |
2028 | "kaddressbook_configure" ); | 2028 | "kaddressbook_configure" ); |
2029 | 2029 | ||
2030 | //US not implemented yet | 2030 | //US not implemented yet |
2031 | //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, | 2031 | //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, |
2032 | // this, SLOT( configureKeyBindings() ), actionCollection(), | 2032 | // this, SLOT( configureKeyBindings() ), actionCollection(), |
2033 | // "kaddressbook_configure_shortcuts" ); | 2033 | // "kaddressbook_configure_shortcuts" ); |
2034 | #ifdef KAB_EMBEDDED | 2034 | #ifdef KAB_EMBEDDED |
2035 | mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); | 2035 | mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); |
2036 | mActionConfigureToolbars->setEnabled( false ); | 2036 | mActionConfigureToolbars->setEnabled( false ); |
2037 | #endif //KAB_EMBEDDED | 2037 | #endif //KAB_EMBEDDED |
2038 | 2038 | ||
2039 | } else { | 2039 | } else { |
2040 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KA/Pi..." ), "configure", 0, this, | 2040 | mActionConfigKAddressbook = new KAction( i18n( "&Configure KA/Pi..." ), "configure", 0, this, |
2041 | SLOT( openConfigDialog() ), actionCollection(), | 2041 | SLOT( openConfigDialog() ), actionCollection(), |
2042 | "kaddressbook_configure" ); | 2042 | "kaddressbook_configure" ); |
2043 | mActionConfigGlobal = new KAction( i18n( "Global Settings..." ), "configure", 0, this, | 2043 | mActionConfigGlobal = new KAction( i18n( "Global Settings..." ), "configure", 0, this, |
2044 | SLOT( openConfigGlobalDialog() ), actionCollection(), | 2044 | SLOT( openConfigGlobalDialog() ), actionCollection(), |
2045 | "kaddressbook_configure" ); | 2045 | "kaddressbook_configure" ); |
2046 | } | 2046 | } |
2047 | mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, | 2047 | mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, |
2048 | actionCollection(), "options_show_jump_bar" ); | 2048 | actionCollection(), "options_show_jump_bar" ); |
2049 | connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) ); | 2049 | connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) ); |
2050 | 2050 | ||
2051 | mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, | 2051 | mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, |
2052 | actionCollection(), "options_show_details" ); | 2052 | actionCollection(), "options_show_details" ); |
2053 | connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); | 2053 | connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); |
2054 | 2054 | ||
2055 | 2055 | ||
2056 | mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, | 2056 | mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, |
2057 | SLOT( toggleBeamReceive() ), actionCollection(), | 2057 | SLOT( toggleBeamReceive() ), actionCollection(), |
2058 | "kaddressbook_beam_rec" ); | 2058 | "kaddressbook_beam_rec" ); |
2059 | 2059 | ||
2060 | 2060 | ||
2061 | // misc | 2061 | // misc |
2062 | // only enable LDAP lookup if we can handle the protocol | 2062 | // only enable LDAP lookup if we can handle the protocol |
2063 | #ifndef KAB_EMBEDDED | 2063 | #ifndef KAB_EMBEDDED |
2064 | if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { | 2064 | if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { |
2065 | new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, | 2065 | new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, |
2066 | this, SLOT( openLDAPDialog() ), actionCollection(), | 2066 | this, SLOT( openLDAPDialog() ), actionCollection(), |
2067 | "ldap_lookup" ); | 2067 | "ldap_lookup" ); |
2068 | } | 2068 | } |
2069 | #else //KAB_EMBEDDED | 2069 | #else //KAB_EMBEDDED |
2070 | //qDebug("KABCore::initActions() LDAP has to be implemented"); | 2070 | //qDebug("KABCore::initActions() LDAP has to be implemented"); |
2071 | #endif //KAB_EMBEDDED | 2071 | #endif //KAB_EMBEDDED |
2072 | 2072 | ||
2073 | 2073 | ||
2074 | mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, | 2074 | mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, |
2075 | SLOT( setWhoAmI() ), actionCollection(), | 2075 | SLOT( setWhoAmI() ), actionCollection(), |
2076 | "set_personal" ); | 2076 | "set_personal" ); |
2077 | 2077 | ||
2078 | 2078 | ||
2079 | mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this, | 2079 | mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this, |
2080 | SLOT( setCategories() ), actionCollection(), | 2080 | SLOT( setCategories() ), actionCollection(), |
2081 | "edit_set_categories" ); | 2081 | "edit_set_categories" ); |
2082 | mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this, | 2082 | mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this, |
2083 | SLOT( editCategories() ), actionCollection(), | 2083 | SLOT( editCategories() ), actionCollection(), |
2084 | "edit__categories" ); | 2084 | "edit__categories" ); |
2085 | 2085 | ||
2086 | mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, | 2086 | mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, |
2087 | SLOT( removeVoice() ), actionCollection(), | 2087 | SLOT( removeVoice() ), actionCollection(), |
2088 | "remove_voice" ); | 2088 | "remove_voice" ); |
2089 | mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this, | 2089 | mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this, |
2090 | SLOT( setFormattedName() ), actionCollection(), | 2090 | SLOT( setFormattedName() ), actionCollection(), |
2091 | "set_formatted" ); | 2091 | "set_formatted" ); |
2092 | 2092 | ||
2093 | mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this, | 2093 | mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this, |
2094 | SLOT( manageCategories() ), actionCollection(), | 2094 | SLOT( manageCategories() ), actionCollection(), |
2095 | "remove_voice" ); | 2095 | "remove_voice" ); |
2096 | 2096 | ||
2097 | 2097 | ||
2098 | mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, | 2098 | mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, |
2099 | SLOT( importFromOL() ), actionCollection(), | 2099 | SLOT( importFromOL() ), actionCollection(), |
2100 | "import_OL" ); | 2100 | "import_OL" ); |
2101 | #ifdef KAB_EMBEDDED | 2101 | #ifdef KAB_EMBEDDED |
2102 | mActionLicence = new KAction( i18n( "Licence" ), 0, | 2102 | mActionLicence = new KAction( i18n( "Licence" ), 0, |
2103 | this, SLOT( showLicence() ), actionCollection(), | 2103 | this, SLOT( showLicence() ), actionCollection(), |
2104 | "licence_about_data" ); | 2104 | "licence_about_data" ); |
2105 | mActionFaq = new KAction( i18n( "Faq" ), 0, | 2105 | mActionFaq = new KAction( i18n( "Faq" ), 0, |
2106 | this, SLOT( faq() ), actionCollection(), | 2106 | this, SLOT( faq() ), actionCollection(), |
2107 | "faq_about_data" ); | 2107 | "faq_about_data" ); |
2108 | mActionWN = new KAction( i18n( "What's New?" ), 0, | 2108 | mActionWN = new KAction( i18n( "What's New?" ), 0, |
2109 | this, SLOT( whatsnew() ), actionCollection(), | 2109 | this, SLOT( whatsnew() ), actionCollection(), |
2110 | "wn" ); | 2110 | "wn" ); |
2111 | 2111 | ||
2112 | 2112 | ||
2113 | 2113 | ||
2114 | mActionStorageHowto = new KAction( i18n( "Storage HowTo" ), 0, | 2114 | mActionStorageHowto = new KAction( i18n( "Storage HowTo" ), 0, |
2115 | this, SLOT( storagehowto() ), actionCollection(), | 2115 | this, SLOT( storagehowto() ), actionCollection(), |
2116 | "storage" ); | 2116 | "storage" ); |
2117 | 2117 | ||
2118 | mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, | 2118 | mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, |
2119 | this, SLOT( synchowto() ), actionCollection(), | 2119 | this, SLOT( synchowto() ), actionCollection(), |
2120 | "sync" ); | 2120 | "sync" ); |
2121 | mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0, | 2121 | mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0, |
2122 | this, SLOT( kdesynchowto() ), actionCollection(), | 2122 | this, SLOT( kdesynchowto() ), actionCollection(), |
2123 | "kdesync" ); | 2123 | "kdesync" ); |
2124 | mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0, | 2124 | mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0, |
2125 | this, SLOT( multisynchowto() ), actionCollection(), | 2125 | this, SLOT( multisynchowto() ), actionCollection(), |
2126 | "multisync" ); | 2126 | "multisync" ); |
2127 | 2127 | ||
2128 | mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, | 2128 | mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, |
2129 | this, SLOT( createAboutData() ), actionCollection(), | 2129 | this, SLOT( createAboutData() ), actionCollection(), |
2130 | "kaddressbook_about_data" ); | 2130 | "kaddressbook_about_data" ); |
2131 | #endif //KAB_EMBEDDED | 2131 | #endif //KAB_EMBEDDED |
2132 | 2132 | ||
2133 | clipboardDataChanged(); | 2133 | clipboardDataChanged(); |
2134 | connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); | 2134 | connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); |
2135 | connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); | 2135 | connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); |
2136 | } | 2136 | } |
2137 | 2137 | ||
2138 | //US we need this function, to plug all actions into the correct menues. | 2138 | //US we need this function, to plug all actions into the correct menues. |
2139 | // KDE uses a XML format to plug the actions, but we work her without this overhead. | 2139 | // KDE uses a XML format to plug the actions, but we work her without this overhead. |
2140 | void KABCore::addActionsManually() | 2140 | void KABCore::addActionsManually() |
2141 | { | 2141 | { |
2142 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); | 2142 | //US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); |
2143 | 2143 | ||
2144 | #ifdef KAB_EMBEDDED | 2144 | #ifdef KAB_EMBEDDED |
2145 | QPopupMenu *fileMenu = new QPopupMenu( this ); | 2145 | QPopupMenu *fileMenu = new QPopupMenu( this ); |
2146 | QPopupMenu *editMenu = new QPopupMenu( this ); | 2146 | QPopupMenu *editMenu = new QPopupMenu( this ); |
2147 | QPopupMenu *helpMenu = new QPopupMenu( this ); | 2147 | QPopupMenu *helpMenu = new QPopupMenu( this ); |
2148 | 2148 | ||
2149 | KToolBar* tb = mMainWindow->toolBar(); | 2149 | KToolBar* tb = mMainWindow->toolBar(); |
2150 | mMainWindow->setToolBarsMovable (false ); | 2150 | mMainWindow->setToolBarsMovable (false ); |
2151 | #ifndef DESKTOP_VERSION | 2151 | #ifndef DESKTOP_VERSION |
2152 | if ( KABPrefs::instance()->mFullMenuBarVisible ) { | 2152 | if ( KABPrefs::instance()->mFullMenuBarVisible ) { |
2153 | #endif | 2153 | #endif |
2154 | QMenuBar* mb = mMainWindow->menuBar(); | 2154 | QMenuBar* mb = mMainWindow->menuBar(); |
2155 | 2155 | ||
2156 | //US setup menubar. | 2156 | //US setup menubar. |
2157 | //Disable the following block if you do not want to have a menubar. | 2157 | //Disable the following block if you do not want to have a menubar. |
2158 | mb->insertItem( i18n("&File"), fileMenu ); | 2158 | mb->insertItem( i18n("&File"), fileMenu ); |
2159 | mb->insertItem( i18n("&Edit"), editMenu ); | 2159 | mb->insertItem( i18n("&Edit"), editMenu ); |
2160 | mb->insertItem( i18n("&View"), viewMenu ); | 2160 | mb->insertItem( i18n("&View"), viewMenu ); |
2161 | mb->insertItem( i18n("&Settings"), settingsMenu ); | 2161 | mb->insertItem( i18n("&Settings"), settingsMenu ); |
2162 | #ifdef DESKTOP_VERSION | 2162 | #ifdef DESKTOP_VERSION |
2163 | mb->insertItem( i18n("Synchronize"), syncMenu ); | 2163 | mb->insertItem( i18n("Synchronize"), syncMenu ); |
2164 | #else | 2164 | #else |
2165 | mb->insertItem( i18n("Sync"), syncMenu ); | 2165 | mb->insertItem( i18n("Sync"), syncMenu ); |
2166 | #endif | 2166 | #endif |
2167 | //mb->insertItem( i18n("&Change"), changeMenu ); | 2167 | //mb->insertItem( i18n("&Change"), changeMenu ); |
2168 | mb->insertItem( i18n("&Help"), helpMenu ); | 2168 | mb->insertItem( i18n("&Help"), helpMenu ); |
2169 | mIncSearchWidget = new IncSearchWidget( tb ); | 2169 | mIncSearchWidget = new IncSearchWidget( tb ); |
2170 | // tb->insertWidget(-1, 0, mIncSearchWidget); | 2170 | // tb->insertWidget(-1, 0, mIncSearchWidget); |
2171 | #ifndef DESKTOP_VERSION | 2171 | #ifndef DESKTOP_VERSION |
2172 | } else { | 2172 | } else { |
2173 | //US setup toolbar | 2173 | //US setup toolbar |
2174 | QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); | 2174 | QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); |
2175 | QPopupMenu *popupBarTB = new QPopupMenu( this ); | 2175 | QPopupMenu *popupBarTB = new QPopupMenu( this ); |
2176 | menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB); | 2176 | menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB); |
2177 | tb->insertWidget(-1, 0, menuBarTB); | 2177 | tb->insertWidget(-1, 0, menuBarTB); |
2178 | mIncSearchWidget = new IncSearchWidget( tb ); | 2178 | mIncSearchWidget = new IncSearchWidget( tb ); |
2179 | tb->enableMoving(false); | 2179 | tb->enableMoving(false); |
2180 | popupBarTB->insertItem( i18n("&File"), fileMenu ); | 2180 | popupBarTB->insertItem( i18n("&File"), fileMenu ); |
2181 | popupBarTB->insertItem( i18n("&Edit"), editMenu ); | 2181 | popupBarTB->insertItem( i18n("&Edit"), editMenu ); |
2182 | popupBarTB->insertItem( i18n("&View"), viewMenu ); | 2182 | popupBarTB->insertItem( i18n("&View"), viewMenu ); |
2183 | popupBarTB->insertItem( i18n("&Settings"), settingsMenu ); | 2183 | popupBarTB->insertItem( i18n("&Settings"), settingsMenu ); |
2184 | popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); | 2184 | popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); |
2185 | mViewManager->getFilterAction()->plug ( popupBarTB); | 2185 | mViewManager->getFilterAction()->plug ( popupBarTB); |
2186 | //popupBarTB->insertItem( i18n("&Change selected"), changeMenu ); | 2186 | //popupBarTB->insertItem( i18n("&Change selected"), changeMenu ); |
2187 | popupBarTB->insertItem( i18n("&Help"), helpMenu ); | 2187 | popupBarTB->insertItem( i18n("&Help"), helpMenu ); |
2188 | if (QApplication::desktop()->width() > 320 ) { | 2188 | if (QApplication::desktop()->width() > 320 ) { |
2189 | // mViewManager->getFilterAction()->plug ( tb); | 2189 | // mViewManager->getFilterAction()->plug ( tb); |
2190 | } | 2190 | } |
2191 | } | 2191 | } |
2192 | #endif | 2192 | #endif |
2193 | mIncSearchWidget->setSize(); | 2193 | mIncSearchWidget->setSize(); |
2194 | // mActionQuit->plug ( mMainWindow->toolBar()); | 2194 | // mActionQuit->plug ( mMainWindow->toolBar()); |
2195 | 2195 | ||
2196 | 2196 | ||
2197 | 2197 | ||
2198 | //US Now connect the actions with the menue entries. | 2198 | //US Now connect the actions with the menue entries. |
2199 | #ifdef DESKTOP_VERSION | 2199 | #ifdef DESKTOP_VERSION |
2200 | mActionPrint->plug( fileMenu ); | 2200 | mActionPrint->plug( fileMenu ); |
2201 | mActionPrintDetails->plug( fileMenu ); | 2201 | mActionPrintDetails->plug( fileMenu ); |
2202 | fileMenu->insertSeparator(); | 2202 | fileMenu->insertSeparator(); |
2203 | #endif | 2203 | #endif |
2204 | mActionMail->plug( fileMenu ); | 2204 | mActionMail->plug( fileMenu ); |
2205 | fileMenu->insertSeparator(); | 2205 | fileMenu->insertSeparator(); |
2206 | 2206 | ||
2207 | mActionNewContact->plug( editMenu ); | 2207 | mActionNewContact->plug( editMenu ); |
2208 | mActionNewContact->plug( tb ); | 2208 | mActionNewContact->plug( tb ); |
2209 | 2209 | ||
2210 | mActionEditAddressee->plug( editMenu ); | 2210 | mActionEditAddressee->plug( editMenu ); |
2211 | editMenu->insertSeparator(); | 2211 | editMenu->insertSeparator(); |
2212 | // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || | 2212 | // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || |
2213 | // (!KABPrefs::instance()->mMultipleViewsAtOnce )) | 2213 | // (!KABPrefs::instance()->mMultipleViewsAtOnce )) |
2214 | mActionEditAddressee->plug( tb ); | 2214 | mActionEditAddressee->plug( tb ); |
2215 | 2215 | ||
2216 | // fileMenu->insertSeparator(); | 2216 | // fileMenu->insertSeparator(); |
2217 | mActionSave->plug( fileMenu ); | 2217 | mActionSave->plug( fileMenu ); |
2218 | fileMenu->insertItem( "&Import", ImportMenu ); | 2218 | fileMenu->insertItem( "&Import", ImportMenu ); |
2219 | fileMenu->insertItem( "&Export", ExportMenu ); | 2219 | fileMenu->insertItem( "&Export", ExportMenu ); |
2220 | editMenu->insertItem( i18n("&Change"), changeMenu ); | 2220 | editMenu->insertItem( i18n("&Change"), changeMenu ); |
2221 | editMenu->insertSeparator(); | 2221 | editMenu->insertSeparator(); |
2222 | #ifndef DESKTOP_VERSION | 2222 | #ifndef DESKTOP_VERSION |
2223 | if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu ); | 2223 | if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu ); |
2224 | #endif | 2224 | #endif |
2225 | #if 0 | 2225 | #if 0 |
2226 | // PENDING fix MailVCard | 2226 | // PENDING fix MailVCard |
2227 | fileMenu->insertSeparator(); | 2227 | fileMenu->insertSeparator(); |
2228 | mActionMailVCard->plug( fileMenu ); | 2228 | mActionMailVCard->plug( fileMenu ); |
2229 | #endif | 2229 | #endif |
2230 | #ifndef DESKTOP_VERSION | 2230 | #ifndef DESKTOP_VERSION |
2231 | if ( Ir::supported() ) mActionBR->plug( beamMenu ); | 2231 | if ( Ir::supported() ) mActionBR->plug( beamMenu ); |
2232 | if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu ); | 2232 | if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu ); |
2233 | if ( Ir::supported() ) mActionBeam->plug( beamMenu ); | 2233 | if ( Ir::supported() ) mActionBeam->plug( beamMenu ); |
2234 | #endif | 2234 | #endif |
2235 | fileMenu->insertSeparator(); | 2235 | fileMenu->insertSeparator(); |
2236 | mActionQuit->plug( fileMenu ); | 2236 | mActionQuit->plug( fileMenu ); |
2237 | #ifdef _OL_IMPORT_ | 2237 | #ifdef _OL_IMPORT_ |
2238 | mActionImportOL->plug( ImportMenu ); | 2238 | mActionImportOL->plug( ImportMenu ); |
2239 | #endif | 2239 | #endif |
2240 | // edit menu | 2240 | // edit menu |
2241 | mActionUndo->plug( editMenu ); | 2241 | mActionUndo->plug( editMenu ); |
2242 | mActionRedo->plug( editMenu ); | 2242 | mActionRedo->plug( editMenu ); |
2243 | editMenu->insertSeparator(); | 2243 | editMenu->insertSeparator(); |
2244 | mActionCut->plug( editMenu ); | 2244 | mActionCut->plug( editMenu ); |
2245 | mActionCopy->plug( editMenu ); | 2245 | mActionCopy->plug( editMenu ); |
2246 | mActionPaste->plug( editMenu ); | 2246 | mActionPaste->plug( editMenu ); |
2247 | mActionDelete->plug( editMenu ); | 2247 | mActionDelete->plug( editMenu ); |
2248 | editMenu->insertSeparator(); | 2248 | editMenu->insertSeparator(); |
2249 | mActionSelectAll->plug( editMenu ); | 2249 | mActionSelectAll->plug( editMenu ); |
2250 | 2250 | ||
2251 | mActionSetFormattedName->plug( changeMenu ); | 2251 | mActionSetFormattedName->plug( changeMenu ); |
2252 | mActionRemoveVoice->plug( changeMenu ); | 2252 | mActionRemoveVoice->plug( changeMenu ); |
2253 | // settingsmings menu | 2253 | // settingsmings menu |
2254 | //US special menuentry to configure the addressbook resources. On KDE | 2254 | //US special menuentry to configure the addressbook resources. On KDE |
2255 | // you do that through the control center !!! | 2255 | // you do that through the control center !!! |
2256 | // settingsMenu->insertSeparator(); | 2256 | // settingsMenu->insertSeparator(); |
2257 | 2257 | ||
2258 | mActionConfigKAddressbook->plug( settingsMenu, 0 ); | 2258 | mActionConfigKAddressbook->plug( settingsMenu, 0 ); |
2259 | mActionConfigGlobal->plug( settingsMenu, 1 ); | 2259 | mActionConfigGlobal->plug( settingsMenu, 1 ); |
2260 | mActionConfigResources->plug( settingsMenu,2 ); | 2260 | mActionConfigResources->plug( settingsMenu,2 ); |
2261 | settingsMenu->insertSeparator(3); | 2261 | settingsMenu->insertSeparator(3); |
2262 | 2262 | ||
2263 | if ( mIsPart ) { | 2263 | if ( mIsPart ) { |
2264 | //US not implemented yet | 2264 | //US not implemented yet |
2265 | //mActionConfigShortcuts->plug( settingsMenu ); | 2265 | //mActionConfigShortcuts->plug( settingsMenu ); |
2266 | //mActionConfigureToolbars->plug( settingsMenu ); | 2266 | //mActionConfigureToolbars->plug( settingsMenu ); |
2267 | 2267 | ||
2268 | } else { | 2268 | } else { |
2269 | //US not implemented yet | 2269 | //US not implemented yet |
2270 | //mActionKeyBindings->plug( settingsMenu ); | 2270 | //mActionKeyBindings->plug( settingsMenu ); |
2271 | } | 2271 | } |
2272 | 2272 | ||
2273 | mActionEditCategories->plug( settingsMenu ); | 2273 | mActionEditCategories->plug( settingsMenu ); |
2274 | mActionManageCategories->plug( settingsMenu ); | 2274 | mActionManageCategories->plug( settingsMenu ); |
2275 | mActionJumpBar->plug( viewMenu,0 ); | 2275 | mActionJumpBar->plug( viewMenu,0 ); |
2276 | mActionDetails->plug( viewMenu,0 ); | 2276 | mActionDetails->plug( viewMenu,0 ); |
2277 | //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) | 2277 | //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) |
2278 | mActionDetails->plug( tb ); | 2278 | mActionDetails->plug( tb ); |
2279 | settingsMenu->insertSeparator(); | 2279 | settingsMenu->insertSeparator(); |
2280 | #ifndef DESKTOP_VERSION | 2280 | #ifndef DESKTOP_VERSION |
2281 | if ( Ir::supported() ) mActionBR->plug(settingsMenu ); | 2281 | if ( Ir::supported() ) mActionBR->plug(settingsMenu ); |
2282 | settingsMenu->insertSeparator(); | 2282 | settingsMenu->insertSeparator(); |
2283 | #endif | 2283 | #endif |
2284 | 2284 | ||
2285 | mActionWhoAmI->plug( settingsMenu ); | 2285 | mActionWhoAmI->plug( settingsMenu ); |
2286 | //mActionEditCategories->plug( changeMenu ); | 2286 | //mActionEditCategories->plug( changeMenu ); |
2287 | mActionCategories->plug( changeMenu ); | 2287 | mActionCategories->plug( changeMenu ); |
2288 | //mActionManageCategories->plug( changeMenu ); | 2288 | //mActionManageCategories->plug( changeMenu ); |
2289 | 2289 | ||
2290 | //mActionCategories->plug( settingsMenu ); | 2290 | //mActionCategories->plug( settingsMenu ); |
2291 | 2291 | ||
2292 | 2292 | ||
2293 | mActionWN->plug( helpMenu ); | 2293 | mActionWN->plug( helpMenu ); |
2294 | mActionStorageHowto->plug( helpMenu ); | 2294 | mActionStorageHowto->plug( helpMenu ); |
2295 | mActionSyncHowto->plug( helpMenu ); | 2295 | mActionSyncHowto->plug( helpMenu ); |
2296 | mActionKdeSyncHowto->plug( helpMenu ); | 2296 | mActionKdeSyncHowto->plug( helpMenu ); |
2297 | mActionMultiSyncHowto->plug( helpMenu ); | 2297 | mActionMultiSyncHowto->plug( helpMenu ); |
2298 | mActionFaq->plug( helpMenu ); | 2298 | mActionFaq->plug( helpMenu ); |
2299 | mActionLicence->plug( helpMenu ); | 2299 | mActionLicence->plug( helpMenu ); |
2300 | mActionAboutKAddressbook->plug( helpMenu ); | 2300 | mActionAboutKAddressbook->plug( helpMenu ); |
2301 | 2301 | ||
2302 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { | 2302 | if (KGlobal::getDesktopSize() > KGlobal::Small ) { |
2303 | 2303 | ||
2304 | mActionSave->plug( tb ); | 2304 | mActionSave->plug( tb ); |
2305 | mViewManager->getFilterAction()->plug ( tb); | 2305 | mViewManager->getFilterAction()->plug ( tb); |
2306 | //LR hide filteraction on started in 480x640 | 2306 | //LR hide filteraction on started in 480x640 |
2307 | if (QApplication::desktop()->width() == 480 ) { | 2307 | if (QApplication::desktop()->width() == 480 ) { |
2308 | mViewManager->getFilterAction()->setComboWidth( 0 ); | 2308 | mViewManager->getFilterAction()->setComboWidth( 0 ); |
2309 | } | 2309 | } |
2310 | mActionUndo->plug( tb ); | 2310 | mActionUndo->plug( tb ); |
2311 | mActionDelete->plug( tb ); | 2311 | mActionDelete->plug( tb ); |
2312 | mActionRedo->plug( tb ); | 2312 | mActionRedo->plug( tb ); |
2313 | } else { | 2313 | } else { |
2314 | mActionSave->plug( tb ); | 2314 | mActionSave->plug( tb ); |
2315 | tb->enableMoving(false); | 2315 | tb->enableMoving(false); |
2316 | } | 2316 | } |
2317 | //mActionQuit->plug ( tb ); | 2317 | //mActionQuit->plug ( tb ); |
2318 | //tb->insertWidget(-1, 0, mIncSearchWidget, 6); | 2318 | //tb->insertWidget(-1, 0, mIncSearchWidget, 6); |
2319 | 2319 | ||
2320 | //US link the searchwidget first to this. | 2320 | //US link the searchwidget first to this. |
2321 | // The real linkage to the toolbar happens later. | 2321 | // The real linkage to the toolbar happens later. |
2322 | //US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); | 2322 | //US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); |
2323 | //US tb->insertItem( mIncSearchWidget ); | 2323 | //US tb->insertItem( mIncSearchWidget ); |
2324 | /*US | 2324 | /*US |
2325 | mIncSearchWidget = new IncSearchWidget( tb ); | 2325 | mIncSearchWidget = new IncSearchWidget( tb ); |
2326 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), | 2326 | connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), |
2327 | SLOT( incrementalSearch( const QString& ) ) ); | 2327 | SLOT( incrementalSearch( const QString& ) ) ); |
2328 | 2328 | ||
2329 | mJumpButtonBar = new JumpButtonBar( this, this ); | 2329 | mJumpButtonBar = new JumpButtonBar( this, this ); |
2330 | 2330 | ||
2331 | //US topLayout->addWidget( mJumpButtonBar ); | 2331 | //US topLayout->addWidget( mJumpButtonBar ); |
2332 | this->layout()->add( mJumpButtonBar ); | 2332 | this->layout()->add( mJumpButtonBar ); |
2333 | */ | 2333 | */ |
2334 | 2334 | ||
2335 | #endif //KAB_EMBEDDED | 2335 | #endif //KAB_EMBEDDED |
2336 | 2336 | ||
2337 | mActionExport2phone->plug( ExportMenu ); | 2337 | mActionExport2phone->plug( ExportMenu ); |
2338 | connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); | 2338 | connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); |
2339 | syncManager->fillSyncMenu(); | 2339 | syncManager->fillSyncMenu(); |
2340 | 2340 | ||
2341 | } | 2341 | } |
2342 | void KABCore::showLicence() | 2342 | void KABCore::showLicence() |
2343 | { | 2343 | { |
2344 | KApplication::showLicence(); | 2344 | KApplication::showLicence(); |
2345 | } | 2345 | } |
2346 | 2346 | ||
2347 | void KABCore::manageCategories( ) | 2347 | void KABCore::manageCategories( ) |
2348 | { | 2348 | { |
2349 | KABCatPrefs* cp = new KABCatPrefs(); | 2349 | KABCatPrefs* cp = new KABCatPrefs(); |
2350 | cp->show(); | 2350 | cp->show(); |
2351 | int w =cp->sizeHint().width() ; | 2351 | int w =cp->sizeHint().width() ; |
2352 | int h = cp->sizeHint().height() ; | 2352 | int h = cp->sizeHint().height() ; |
2353 | int dw = QApplication::desktop()->width(); | 2353 | int dw = QApplication::desktop()->width(); |
2354 | int dh = QApplication::desktop()->height(); | 2354 | int dh = QApplication::desktop()->height(); |
2355 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 2355 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
2356 | if ( !cp->exec() ) { | 2356 | if ( !cp->exec() ) { |
2357 | delete cp; | 2357 | delete cp; |
2358 | return; | 2358 | return; |
2359 | } | 2359 | } |
2360 | int count = 0; | 2360 | int count = 0; |
2361 | int cc = 0; | 2361 | int cc = 0; |
2362 | message( i18n("Please wait, processing categories...")); | 2362 | message( i18n("Please wait, processing categories...")); |
2363 | if ( cp->addCat() ) { | 2363 | if ( cp->addCat() ) { |
2364 | KABC::AddressBook::Iterator it; | 2364 | KABC::AddressBook::Iterator it; |
2365 | QStringList catList = KABPrefs::instance()->mCustomCategories; | 2365 | QStringList catList = KABPrefs::instance()->mCustomCategories; |
2366 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 2366 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
2367 | ++cc; | 2367 | ++cc; |
2368 | if ( cc %10 == 0) | 2368 | if ( cc %10 == 0) |
2369 | message(i18n("Processing contact #%1").arg(cc)); | 2369 | message(i18n("Processing contact #%1").arg(cc)); |
2370 | QStringList catIncList = (*it).categories(); | 2370 | QStringList catIncList = (*it).categories(); |
2371 | int i; | 2371 | int i; |
2372 | for( i = 0; i< catIncList.count(); ++i ) { | 2372 | for( i = 0; i< catIncList.count(); ++i ) { |
2373 | if ( !catList.contains (catIncList[i])) { | 2373 | if ( !catList.contains (catIncList[i])) { |
2374 | catList.append( catIncList[i] ); | 2374 | catList.append( catIncList[i] ); |
2375 | //qDebug("add cat %s ", catIncList[i].latin1()); | 2375 | //qDebug("add cat %s ", catIncList[i].latin1()); |
2376 | ++count; | 2376 | ++count; |
2377 | } | 2377 | } |
2378 | } | 2378 | } |
2379 | } | 2379 | } |
2380 | catList.sort(); | 2380 | catList.sort(); |
2381 | KABPrefs::instance()->mCustomCategories = catList; | 2381 | KABPrefs::instance()->mCustomCategories = catList; |
2382 | KABPrefs::instance()->writeConfig(); | 2382 | KABPrefs::instance()->writeConfig(); |
2383 | message(QString::number( count )+ i18n(" categories added to list! ")); | 2383 | message(QString::number( count )+ i18n(" categories added to list! ")); |
2384 | } else { | 2384 | } else { |
2385 | QStringList catList = KABPrefs::instance()->mCustomCategories; | 2385 | QStringList catList = KABPrefs::instance()->mCustomCategories; |
2386 | QStringList catIncList; | 2386 | QStringList catIncList; |
2387 | QStringList newCatList; | 2387 | QStringList newCatList; |
2388 | KABC::AddressBook::Iterator it; | 2388 | KABC::AddressBook::Iterator it; |
2389 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 2389 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
2390 | ++cc; | 2390 | ++cc; |
2391 | if ( cc %10 == 0) | 2391 | if ( cc %10 == 0) |
2392 | message(i18n("Processing contact #%1").arg(cc)); | 2392 | message(i18n("Processing contact #%1").arg(cc)); |
2393 | QStringList catIncList = (*it).categories(); | 2393 | QStringList catIncList = (*it).categories(); |
2394 | int i; | 2394 | int i; |
2395 | if ( catIncList.count() ) { | 2395 | if ( catIncList.count() ) { |
2396 | newCatList.clear(); | 2396 | newCatList.clear(); |
2397 | for( i = 0; i< catIncList.count(); ++i ) { | 2397 | for( i = 0; i< catIncList.count(); ++i ) { |
2398 | if ( catList.contains (catIncList[i])) { | 2398 | if ( catList.contains (catIncList[i])) { |
2399 | newCatList.append( catIncList[i] ); | 2399 | newCatList.append( catIncList[i] ); |
2400 | } | 2400 | } |
2401 | } | 2401 | } |
2402 | newCatList.sort(); | 2402 | newCatList.sort(); |
2403 | (*it).setCategories( newCatList ); | 2403 | (*it).setCategories( newCatList ); |
2404 | mAddressBook->insertAddressee( (*it) ); | 2404 | mAddressBook->insertAddressee( (*it) ); |
2405 | } | 2405 | } |
2406 | } | 2406 | } |
2407 | setModified( true ); | 2407 | setModified( true ); |
2408 | mViewManager->refreshView(); | 2408 | mViewManager->refreshView(); |
2409 | message( i18n("Removing categories done!")); | 2409 | message( i18n("Removing categories done!")); |
2410 | } | 2410 | } |
2411 | delete cp; | 2411 | delete cp; |
2412 | } | 2412 | } |
2413 | void KABCore::removeVoice() | 2413 | void KABCore::removeVoice() |
2414 | { | 2414 | { |
2415 | if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No ) | 2415 | if ( KMessageBox::questionYesNo( this, i18n("After importing, phone numbers\nmay have two or more types.\n(E.g. work+voice)\nThese numbers are shown as \"other\".\nClick Yes to remove the voice type\nfrom numbers with more than one type.\n\nRemove voice type?") ) == KMessageBox::No ) |
2416 | return; | 2416 | return; |
2417 | XXPortSelectDialog dlg( this, false, this ); | 2417 | XXPortSelectDialog dlg( this, false, this ); |
2418 | if ( !dlg.exec() ) | 2418 | if ( !dlg.exec() ) |
2419 | return; | 2419 | return; |
2420 | mAddressBook->setUntagged(); | 2420 | mAddressBook->setUntagged(); |
2421 | dlg.tagSelected(); | 2421 | dlg.tagSelected(); |
2422 | message(i18n("Removing voice..."), false ); | 2422 | message(i18n("Removing voice..."), false ); |
2423 | KABC::AddressBook::Iterator it; | 2423 | KABC::AddressBook::Iterator it; |
2424 | for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 2424 | for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
2425 | if ( (*it).tagged() ) { | 2425 | if ( (*it).tagged() ) { |
2426 | (*it).removeVoice(); | 2426 | (*it).removeVoice(); |
2427 | } | 2427 | } |
2428 | } | 2428 | } |
2429 | message(i18n("Refreshing view...") ); | 2429 | message(i18n("Refreshing view...") ); |
2430 | qApp->processEvents(); | 2430 | qApp->processEvents(); |
2431 | mViewManager->refreshView( "" ); | 2431 | mViewManager->refreshView( "" ); |
2432 | Addressee add; | 2432 | Addressee add; |
2433 | mDetails->setAddressee( add ); | 2433 | mDetails->setAddressee( add ); |
2434 | message(i18n("Remove voice completed!") ); | 2434 | message(i18n("Remove voice completed!") ); |
2435 | 2435 | ||
2436 | 2436 | ||
2437 | 2437 | ||
2438 | } | 2438 | } |
2439 | 2439 | ||
2440 | void KABCore::setFormattedName() | 2440 | void KABCore::setFormattedName() |
2441 | { | 2441 | { |
2442 | KABFormatPrefs setpref; | 2442 | KABFormatPrefs setpref; |
2443 | if ( !setpref.exec() ) { | 2443 | if ( !setpref.exec() ) { |
2444 | return; | 2444 | return; |
2445 | } | 2445 | } |
2446 | XXPortSelectDialog dlg( this, false, this ); | 2446 | XXPortSelectDialog dlg( this, false, this ); |
2447 | if ( !dlg.exec() ) | 2447 | if ( !dlg.exec() ) |
2448 | return; | 2448 | return; |
2449 | mAddressBook->setUntagged(); | 2449 | mAddressBook->setUntagged(); |
2450 | dlg.tagSelected(); | 2450 | dlg.tagSelected(); |
2451 | int count = 0; | 2451 | int count = 0; |
2452 | KABC::AddressBook::Iterator it; | 2452 | KABC::AddressBook::Iterator it; |
2453 | bool modified = false; | 2453 | bool modified = false; |
2454 | for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 2454 | for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
2455 | if ( (*it).tagged() ) { | 2455 | if ( (*it).tagged() ) { |
2456 | if ( (*it).uid().left( 2 ) == "la" ) | 2456 | if ( (*it).uid().left( 2 ) == "la" ) |
2457 | if ( (*it).uid().left( 19 ) == QString("last-syncAddressee-") ) | 2457 | if ( (*it).uid().left( 19 ) == QString("last-syncAddressee-") ) |
2458 | continue; | 2458 | continue; |
2459 | ++count; | 2459 | ++count; |
2460 | if ( count %10 == 0 ) | 2460 | if ( count %10 == 0 ) |
2461 | message(i18n("Changing contact #%1").arg( count ) ); | 2461 | message(i18n("Changing contact #%1").arg( count ) ); |
2462 | qApp->processEvents(); | 2462 | qApp->processEvents(); |
2463 | QString fName; | 2463 | QString fName; |
2464 | if ( setpref.simple->isChecked() ) | 2464 | if ( setpref.simple->isChecked() ) |
2465 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName ); | 2465 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName ); |
2466 | else if ( setpref.full->isChecked() ) | 2466 | else if ( setpref.full->isChecked() ) |
2467 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName ); | 2467 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName ); |
2468 | else if ( setpref.reverse->isChecked() ) | 2468 | else if ( setpref.reverse->isChecked() ) |
2469 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName ); | 2469 | fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName ); |
2470 | else | 2470 | else |
2471 | fName = (*it).organization(); | 2471 | fName = (*it).organization(); |
2472 | if ( setpref.setCompany->isChecked() ) | 2472 | if ( setpref.setCompany->isChecked() ) |
2473 | if ( fName.isEmpty() || fName =="," ) | 2473 | if ( fName.isEmpty() || fName =="," ) |
2474 | fName = (*it).organization(); | 2474 | fName = (*it).organization(); |
2475 | (*it).setFormattedName( fName ); | 2475 | (*it).setFormattedName( fName ); |
2476 | (*it).setChanged( true ); | 2476 | (*it).setChanged( true ); |
2477 | modified = true; | 2477 | modified = true; |
2478 | (*it).setRevision( QDateTime::currentDateTime() ); | 2478 | (*it).setRevision( QDateTime::currentDateTime() ); |
2479 | } | 2479 | } |
2480 | } | 2480 | } |
2481 | message(i18n("Refreshing view...") ); | 2481 | message(i18n("Refreshing view...") ); |
2482 | qApp->processEvents(); | 2482 | qApp->processEvents(); |
2483 | if ( modified ) | 2483 | if ( modified ) |
2484 | setModified( true ); | 2484 | setModified( true ); |
2485 | Addressee add; | 2485 | Addressee add; |
2486 | mDetails->setAddressee( add ); | 2486 | mDetails->setAddressee( add ); |
2487 | if ( count == 0 ) | 2487 | if ( count == 0 ) |
2488 | message(i18n("No contact changed!") ); | 2488 | message(i18n("No contact changed!") ); |
2489 | else | 2489 | else |
2490 | message(i18n("%1 contacts changed!").arg( count ) ); | 2490 | message(i18n("%1 contacts changed!").arg( count ) ); |
2491 | } | 2491 | } |
2492 | 2492 | ||
2493 | void KABCore::clipboardDataChanged() | 2493 | void KABCore::clipboardDataChanged() |
2494 | { | 2494 | { |
2495 | 2495 | ||
2496 | if ( mReadWrite ) | 2496 | if ( mReadWrite ) |
2497 | mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); | 2497 | mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); |
2498 | 2498 | ||
2499 | } | 2499 | } |
2500 | 2500 | ||
2501 | void KABCore::updateActionMenu() | 2501 | void KABCore::updateActionMenu() |
2502 | { | 2502 | { |
2503 | UndoStack *undo = UndoStack::instance(); | 2503 | UndoStack *undo = UndoStack::instance(); |
2504 | RedoStack *redo = RedoStack::instance(); | 2504 | RedoStack *redo = RedoStack::instance(); |
2505 | 2505 | ||
2506 | if ( undo->isEmpty() ) | 2506 | if ( undo->isEmpty() ) |
2507 | mActionUndo->setText( i18n( "Undo" ) ); | 2507 | mActionUndo->setText( i18n( "Undo" ) ); |
2508 | else | 2508 | else |
2509 | mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); | 2509 | mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); |
2510 | 2510 | ||
2511 | mActionUndo->setEnabled( !undo->isEmpty() ); | 2511 | mActionUndo->setEnabled( !undo->isEmpty() ); |
2512 | 2512 | ||
2513 | if ( !redo->top() ) | 2513 | if ( !redo->top() ) |
2514 | mActionRedo->setText( i18n( "Redo" ) ); | 2514 | mActionRedo->setText( i18n( "Redo" ) ); |
2515 | else | 2515 | else |
2516 | mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); | 2516 | mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); |
2517 | 2517 | ||
2518 | mActionRedo->setEnabled( !redo->isEmpty() ); | 2518 | mActionRedo->setEnabled( !redo->isEmpty() ); |
2519 | } | 2519 | } |
2520 | 2520 | ||
2521 | void KABCore::configureKeyBindings() | 2521 | void KABCore::configureKeyBindings() |
2522 | { | 2522 | { |
2523 | #ifndef KAB_EMBEDDED | 2523 | #ifndef KAB_EMBEDDED |
2524 | KKeyDialog::configure( actionCollection(), true ); | 2524 | KKeyDialog::configure( actionCollection(), true ); |
2525 | #else //KAB_EMBEDDED | 2525 | #else //KAB_EMBEDDED |
2526 | qDebug("KABCore::configureKeyBindings() not implemented"); | 2526 | qDebug("KABCore::configureKeyBindings() not implemented"); |
2527 | #endif //KAB_EMBEDDED | 2527 | #endif //KAB_EMBEDDED |
2528 | } | 2528 | } |
2529 | 2529 | ||
2530 | #ifdef KAB_EMBEDDED | 2530 | #ifdef KAB_EMBEDDED |
2531 | void KABCore::configureResources() | 2531 | void KABCore::configureResources() |
2532 | { | 2532 | { |
2533 | KRES::KCMKResources dlg( this, "" , 0 ); | 2533 | KRES::KCMKResources dlg( this, "" , 0 ); |
2534 | 2534 | ||
2535 | if ( !dlg.exec() ) | 2535 | if ( !dlg.exec() ) |
2536 | return; | 2536 | return; |
2537 | KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") ); | 2537 | KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") ); |
2538 | } | 2538 | } |
2539 | #endif //KAB_EMBEDDED | 2539 | #endif //KAB_EMBEDDED |
2540 | 2540 | ||
2541 | 2541 | ||
2542 | /* this method will be called through the QCop interface from Ko/Pi to select addresses | 2542 | /* this method will be called through the QCop interface from Ko/Pi to select addresses |
2543 | * for the attendees list of an event. | 2543 | * for the attendees list of an event. |
2544 | */ | 2544 | */ |
2545 | void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid) | 2545 | void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid) |
2546 | { | 2546 | { |
2547 | 2547 | qDebug("KABCore::requestForNameEmailUidList "); | |
2548 | bool ok = false; | 2548 | bool ok = false; |
2549 | mEmailSourceChannel = sourceChannel; | 2549 | mEmailSourceChannel = sourceChannel; |
2550 | mEmailSourceUID = uid; | 2550 | mEmailSourceUID = uid; |
2551 | callContactdialog(); | 2551 | QTimer::singleShot( 10,this, SLOT ( callContactdialog() ) ); |
2552 | //callContactdialog(); | ||
2552 | #if 0 | 2553 | #if 0 |
2553 | int wid = uid.toInt( &ok ); | 2554 | int wid = uid.toInt( &ok ); |
2554 | qDebug("UID %s ", uid.latin1()); | 2555 | qDebug("UID %s ", uid.latin1()); |
2555 | if ( ok ) { | 2556 | if ( ok ) { |
2556 | if ( wid != QApplication::desktop()->width() ) { | 2557 | if ( wid != QApplication::desktop()->width() ) { |
2557 | qDebug("KA/Pi: Request from different desktop geometry. Resizing ..."); | 2558 | qDebug("KA/Pi: Request from different desktop geometry. Resizing ..."); |
2558 | message( i18n("Resizing, please wait...") ); | 2559 | message( i18n("Resizing, please wait...") ); |
2559 | mMainWindow->showMinimized(); | 2560 | mMainWindow->showMinimized(); |
2560 | /* | 2561 | /* |
2561 | { | 2562 | { |
2562 | QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); | 2563 | QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); |
2563 | } | 2564 | } |
2564 | */ | 2565 | */ |
2565 | QTimer::singleShot( 1,this, SLOT ( resizeAndCallContactdialog() ) ); | 2566 | QTimer::singleShot( 1,this, SLOT ( resizeAndCallContactdialog() ) ); |
2566 | return; | 2567 | return; |
2567 | } | 2568 | } |
2568 | 2569 | ||
2569 | } else { | 2570 | } else { |
2570 | qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid "); | 2571 | qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid "); |
2571 | } | 2572 | } |
2572 | callContactdialog(); | 2573 | callContactdialog(); |
2573 | //QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); | 2574 | //QCopEnvelope e("QPE/Application/kapi", "callContactdialog()"); |
2574 | #endif | 2575 | #endif |
2575 | } | 2576 | } |
2576 | void KABCore::resizeAndCallContactdialog() | 2577 | void KABCore::resizeAndCallContactdialog() |
2577 | { | 2578 | { |
2578 | updateMainWindow(); | 2579 | updateMainWindow(); |
2579 | QTimer::singleShot( 100,this, SLOT ( callContactdialog() ) ); | 2580 | QTimer::singleShot( 10,this, SLOT ( callContactdialog() ) ); |
2580 | } | 2581 | } |
2581 | 2582 | ||
2582 | void KABCore::callContactdialog() | 2583 | void KABCore::callContactdialog() |
2583 | { | 2584 | { |
2584 | QStringList nameList; | 2585 | static bool running = false; |
2586 | if (running) return; | ||
2587 | running = true; | ||
2588 | QStringList nameList; | ||
2585 | QStringList emailList; | 2589 | QStringList emailList; |
2586 | QStringList uidList; | 2590 | QStringList uidList; |
2587 | qDebug(" KABCore::callContactdialog:DESKTOP WIDTH %d ", QApplication::desktop()->width() ); | 2591 | qDebug(" KABCore::callContactdialog:DESKTOP WIDTH %d ", QApplication::desktop()->width() ); |
2588 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); | 2592 | KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); |
2589 | uint i=0; | 2593 | uint i=0; |
2590 | for (i=0; i < list.count(); i++) | 2594 | for (i=0; i < list.count(); i++) |
2591 | { | 2595 | { |
2592 | nameList.append(list[i].realName()); | 2596 | nameList.append(list[i].realName()); |
2593 | emailList.append(list[i].preferredEmail()); | 2597 | emailList.append(list[i].preferredEmail()); |
2594 | uidList.append(list[i].uid()); | 2598 | uidList.append(list[i].uid()); |
2595 | } | 2599 | } |
2596 | QString uid = mEmailSourceUID; | 2600 | QString uid = mEmailSourceUID; |
2597 | //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1()); | 2601 | //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1()); |
2598 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(mEmailSourceChannel, uid, nameList, emailList, uidList); | 2602 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(mEmailSourceChannel, uid, nameList, emailList, uidList); |
2599 | 2603 | running = false; | |
2600 | } | 2604 | } |
2601 | /* this method will be called through the QCop interface from Ko/Pi to select birthdays | 2605 | /* this method will be called through the QCop interface from Ko/Pi to select birthdays |
2602 | * to put them into the calendar. | 2606 | * to put them into the calendar. |
2603 | */ | 2607 | */ |
2604 | void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid) | 2608 | void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid) |
2605 | { | 2609 | { |
2606 | // qDebug("KABCore::requestForBirthdayList"); | 2610 | // qDebug("KABCore::requestForBirthdayList"); |
2607 | QStringList birthdayList; | 2611 | QStringList birthdayList; |
2608 | QStringList anniversaryList; | 2612 | QStringList anniversaryList; |
2609 | QStringList realNameList; | 2613 | QStringList realNameList; |
2610 | QStringList preferredEmailList; | 2614 | QStringList preferredEmailList; |
2611 | QStringList assembledNameList; | 2615 | QStringList assembledNameList; |
2612 | QStringList uidList; | 2616 | QStringList uidList; |
2613 | 2617 | ||
2614 | KABC::AddressBook::Iterator it; | 2618 | KABC::AddressBook::Iterator it; |
2615 | 2619 | ||
2616 | int count = 0; | 2620 | int count = 0; |
2617 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { | 2621 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { |
2618 | ++count; | 2622 | ++count; |
2619 | } | 2623 | } |
2620 | QProgressBar bar(count,0 ); | 2624 | QProgressBar bar(count,0 ); |
2621 | int w = 300; | 2625 | int w = 300; |
2622 | if ( QApplication::desktop()->width() < 320 ) | 2626 | if ( QApplication::desktop()->width() < 320 ) |
2623 | w = 220; | 2627 | w = 220; |
2624 | int h = bar.sizeHint().height() ; | 2628 | int h = bar.sizeHint().height() ; |
2625 | int dw = QApplication::desktop()->width(); | 2629 | int dw = QApplication::desktop()->width(); |
2626 | int dh = QApplication::desktop()->height(); | 2630 | int dh = QApplication::desktop()->height(); |
2627 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 2631 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
2628 | bar.show(); | 2632 | bar.show(); |
2629 | bar.setCaption (i18n("Collecting birthdays - close to abort!") ); | 2633 | bar.setCaption (i18n("Collecting birthdays - close to abort!") ); |
2630 | qApp->processEvents(); | 2634 | qApp->processEvents(); |
2631 | 2635 | ||
2632 | QDate bday; | 2636 | QDate bday; |
2633 | QString anni; | 2637 | QString anni; |
2634 | QString formattedbday; | 2638 | QString formattedbday; |
2635 | 2639 | ||
2636 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) | 2640 | for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) |
2637 | { | 2641 | { |
2638 | if ( ! bar.isVisible() ) | 2642 | if ( ! bar.isVisible() ) |
2639 | return; | 2643 | return; |
2640 | bar.setProgress( count++ ); | 2644 | bar.setProgress( count++ ); |
2641 | qApp->processEvents(); | 2645 | qApp->processEvents(); |
2642 | bday = (*it).birthday().date(); | 2646 | bday = (*it).birthday().date(); |
2643 | anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" ); | 2647 | anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" ); |
2644 | 2648 | ||
2645 | if ( bday.isValid() || !anni.isEmpty()) | 2649 | if ( bday.isValid() || !anni.isEmpty()) |
2646 | { | 2650 | { |
2647 | if (bday.isValid()) | 2651 | if (bday.isValid()) |
2648 | formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate); | 2652 | formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate); |
2649 | else | 2653 | else |
2650 | formattedbday = "NOTVALID"; | 2654 | formattedbday = "NOTVALID"; |
2651 | if (anni.isEmpty()) | 2655 | if (anni.isEmpty()) |
2652 | anni = "INVALID"; | 2656 | anni = "INVALID"; |
2653 | 2657 | ||
2654 | birthdayList.append(formattedbday); | 2658 | birthdayList.append(formattedbday); |
2655 | anniversaryList.append(anni); //should be ISODate | 2659 | anniversaryList.append(anni); //should be ISODate |
2656 | realNameList.append((*it).realName()); | 2660 | realNameList.append((*it).realName()); |
2657 | preferredEmailList.append((*it).preferredEmail()); | 2661 | preferredEmailList.append((*it).preferredEmail()); |
2658 | assembledNameList.append((*it).assembledName()); | 2662 | assembledNameList.append((*it).assembledName()); |
2659 | uidList.append((*it).uid()); | 2663 | uidList.append((*it).uid()); |
2660 | 2664 | ||
2661 | //qDebug("found birthday in KA/Pi: %s,%s,%s,%s: %s, %s", (*it).realName().latin1(), (*it).preferredEmail().latin1(), (*it).assembledName().latin1(), (*it).uid().latin1(), formattedbday.latin1(), anni.latin1() ); | 2665 | //qDebug("found birthday in KA/Pi: %s,%s,%s,%s: %s, %s", (*it).realName().latin1(), (*it).preferredEmail().latin1(), (*it).assembledName().latin1(), (*it).uid().latin1(), formattedbday.latin1(), anni.latin1() ); |
2662 | } | 2666 | } |
2663 | } | 2667 | } |
2664 | 2668 | ||
2665 | bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList); | 2669 | bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList); |
2666 | 2670 | ||
2667 | } | 2671 | } |
2668 | 2672 | ||
2669 | /* this method will be called through the QCop interface from other apps to show details of a contact. | 2673 | /* this method will be called through the QCop interface from other apps to show details of a contact. |
2670 | */ | 2674 | */ |
2671 | void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid) | 2675 | void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid) |
2672 | { | 2676 | { |
2673 | //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); | 2677 | //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); |
2674 | 2678 | ||
2675 | QString foundUid = QString::null; | 2679 | QString foundUid = QString::null; |
2676 | if ( ! uid.isEmpty() ) { | 2680 | if ( ! uid.isEmpty() ) { |
2677 | Addressee adrr = mAddressBook->findByUid( uid ); | 2681 | Addressee adrr = mAddressBook->findByUid( uid ); |
2678 | if ( !adrr.isEmpty() ) { | 2682 | if ( !adrr.isEmpty() ) { |
2679 | foundUid = uid; | 2683 | foundUid = uid; |
2680 | } | 2684 | } |
2681 | if ( email == "sendbacklist" ) { | 2685 | if ( email == "sendbacklist" ) { |
2682 | //qDebug("ssssssssssssssssssssssend "); | 2686 | //qDebug("ssssssssssssssssssssssend "); |
2683 | QStringList nameList; | 2687 | QStringList nameList; |
2684 | QStringList emailList; | 2688 | QStringList emailList; |
2685 | QStringList uidList; | 2689 | QStringList uidList; |
2686 | nameList.append(adrr.realName()); | 2690 | nameList.append(adrr.realName()); |
2687 | emailList = adrr.emails(); | 2691 | emailList = adrr.emails(); |
2688 | uidList.append( adrr.preferredEmail()); | 2692 | uidList.append( adrr.preferredEmail()); |
2689 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); | 2693 | bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); |
2690 | return; | 2694 | return; |
2691 | } | 2695 | } |
2692 | 2696 | ||
2693 | } | 2697 | } |
2694 | 2698 | ||
2695 | if ( email == "sendbacklist" ) | 2699 | if ( email == "sendbacklist" ) |
2696 | return; | 2700 | return; |
2697 | if (foundUid.isEmpty()) | 2701 | if (foundUid.isEmpty()) |
2698 | { | 2702 | { |
2699 | //find the uid of the person first | 2703 | //find the uid of the person first |
2700 | Addressee::List namelist; | 2704 | Addressee::List namelist; |
2701 | Addressee::List emaillist; | 2705 | Addressee::List emaillist; |
2702 | 2706 | ||
2703 | if (!name.isEmpty()) | 2707 | if (!name.isEmpty()) |
2704 | namelist = mAddressBook->findByName( name ); | 2708 | namelist = mAddressBook->findByName( name ); |
2705 | 2709 | ||
2706 | if (!email.isEmpty()) | 2710 | if (!email.isEmpty()) |
2707 | emaillist = mAddressBook->findByEmail( email ); | 2711 | emaillist = mAddressBook->findByEmail( email ); |
2708 | //qDebug("count %d %d ", namelist.count(),emaillist.count() ); | 2712 | //qDebug("count %d %d ", namelist.count(),emaillist.count() ); |
2709 | //check if we have a match in Namelist and Emaillist | 2713 | //check if we have a match in Namelist and Emaillist |
2710 | if ((namelist.count() == 0) && (emaillist.count() > 0)) { | 2714 | if ((namelist.count() == 0) && (emaillist.count() > 0)) { |
2711 | foundUid = emaillist[0].uid(); | 2715 | foundUid = emaillist[0].uid(); |
2712 | } | 2716 | } |
2713 | else if ((namelist.count() > 0) && (emaillist.count() == 0)) | 2717 | else if ((namelist.count() > 0) && (emaillist.count() == 0)) |
2714 | foundUid = namelist[0].uid(); | 2718 | foundUid = namelist[0].uid(); |
2715 | else | 2719 | else |
2716 | { | 2720 | { |
2717 | for (int i = 0; i < namelist.count(); i++) | 2721 | for (int i = 0; i < namelist.count(); i++) |
2718 | { | 2722 | { |
2719 | for (int j = 0; j < emaillist.count(); j++) | 2723 | for (int j = 0; j < emaillist.count(); j++) |
2720 | { | 2724 | { |
2721 | if (namelist[i] == emaillist[j]) | 2725 | if (namelist[i] == emaillist[j]) |
2722 | { | 2726 | { |
2723 | foundUid = namelist[i].uid(); | 2727 | foundUid = namelist[i].uid(); |
2724 | } | 2728 | } |
2725 | } | 2729 | } |
2726 | } | 2730 | } |
2727 | } | 2731 | } |
2728 | } | 2732 | } |
2729 | else | 2733 | else |
2730 | { | 2734 | { |
2731 | foundUid = uid; | 2735 | foundUid = uid; |
2732 | } | 2736 | } |
2733 | 2737 | ||
2734 | if (!foundUid.isEmpty()) | 2738 | if (!foundUid.isEmpty()) |
2735 | { | 2739 | { |
2736 | 2740 | ||
2737 | // raise Ka/Pi if it is in the background | 2741 | // raise Ka/Pi if it is in the background |
2738 | #ifndef DESKTOP_VERSION | 2742 | #ifndef DESKTOP_VERSION |
2739 | #ifndef KORG_NODCOP | 2743 | #ifndef KORG_NODCOP |
2740 | //QCopEnvelope e("QPE/Application/kapi", "raise()"); | 2744 | //QCopEnvelope e("QPE/Application/kapi", "raise()"); |
2741 | #endif | 2745 | #endif |
2742 | #endif | 2746 | #endif |
2743 | 2747 | ||
2744 | mMainWindow->showMaximized(); | 2748 | mMainWindow->showMaximized(); |
2745 | mMainWindow-> raise(); | 2749 | mMainWindow-> raise(); |
2746 | 2750 | ||
2747 | mViewManager->setSelected( "", false); | 2751 | mViewManager->setSelected( "", false); |
2748 | mViewManager->refreshView( "" ); | 2752 | mViewManager->refreshView( "" ); |
2749 | mViewManager->setSelected( foundUid, true ); | 2753 | mViewManager->setSelected( foundUid, true ); |
2750 | mViewManager->refreshView( foundUid ); | 2754 | mViewManager->refreshView( foundUid ); |
2751 | 2755 | ||
2752 | if ( !mMultipleViewsAtOnce ) | 2756 | if ( !mMultipleViewsAtOnce ) |
2753 | { | 2757 | { |
2754 | setDetailsVisible( true ); | 2758 | setDetailsVisible( true ); |
2755 | mActionDetails->setChecked(true); | 2759 | mActionDetails->setChecked(true); |
2756 | } | 2760 | } |
2757 | } | 2761 | } |
2758 | } | 2762 | } |
2759 | void KABCore::storagehowto() | 2763 | void KABCore::storagehowto() |
2760 | { | 2764 | { |
2761 | KApplication::showFile( "KDE-Pim/Pi Storage HowTo", "kdepim/storagehowto.txt" ); | 2765 | KApplication::showFile( "KDE-Pim/Pi Storage HowTo", "kdepim/storagehowto.txt" ); |
2762 | } | 2766 | } |
2763 | void KABCore::whatsnew() | 2767 | void KABCore::whatsnew() |
2764 | { | 2768 | { |
2765 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); | 2769 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); |
2766 | } | 2770 | } |
2767 | void KABCore::synchowto() | 2771 | void KABCore::synchowto() |
2768 | { | 2772 | { |
2769 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); | 2773 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); |
2770 | } | 2774 | } |
2771 | void KABCore::kdesynchowto() | 2775 | void KABCore::kdesynchowto() |
2772 | { | 2776 | { |
2773 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); | 2777 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); |
2774 | } | 2778 | } |
2775 | void KABCore::multisynchowto() | 2779 | void KABCore::multisynchowto() |
2776 | { | 2780 | { |
2777 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); | 2781 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); |
2778 | } | 2782 | } |
2779 | void KABCore::faq() | 2783 | void KABCore::faq() |
2780 | { | 2784 | { |
2781 | KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); | 2785 | KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); |
2782 | } | 2786 | } |
2783 | 2787 | ||
2784 | #include <libkcal/syncdefines.h> | 2788 | #include <libkcal/syncdefines.h> |
2785 | 2789 | ||
2786 | KABC::Addressee KABCore::getLastSyncAddressee() | 2790 | KABC::Addressee KABCore::getLastSyncAddressee() |
2787 | { | 2791 | { |
2788 | Addressee lse; | 2792 | Addressee lse; |
2789 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2793 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2790 | 2794 | ||
2791 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 2795 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
2792 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2796 | lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2793 | if (lse.isEmpty()) { | 2797 | if (lse.isEmpty()) { |
2794 | qDebug("KA: Creating new last-syncAddressee "); | 2798 | qDebug("KA: Creating new last-syncAddressee "); |
2795 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); | 2799 | lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); |
2796 | QString sum = ""; | 2800 | QString sum = ""; |
2797 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 2801 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
2798 | sum = "E: "; | 2802 | sum = "E: "; |
2799 | lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); | 2803 | lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); |
2800 | lse.setRevision( mLastAddressbookSync ); | 2804 | lse.setRevision( mLastAddressbookSync ); |
2801 | lse.setCategories( i18n("SyncEvent") ); | 2805 | lse.setCategories( i18n("SyncEvent") ); |
2802 | mAddressBook->insertAddressee( lse ); | 2806 | mAddressBook->insertAddressee( lse ); |
2803 | } | 2807 | } |
2804 | return lse; | 2808 | return lse; |
2805 | } | 2809 | } |
2806 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) | 2810 | int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) |
2807 | { | 2811 | { |
2808 | 2812 | ||
2809 | //void setZaurusId(int id); | 2813 | //void setZaurusId(int id); |
2810 | // int zaurusId() const; | 2814 | // int zaurusId() const; |
2811 | // void setZaurusUid(int id); | 2815 | // void setZaurusUid(int id); |
2812 | // int zaurusUid() const; | 2816 | // int zaurusUid() const; |
2813 | // void setZaurusStat(int id); | 2817 | // void setZaurusStat(int id); |
2814 | // int zaurusStat() const; | 2818 | // int zaurusStat() const; |
2815 | // 0 equal | 2819 | // 0 equal |
2816 | // 1 take local | 2820 | // 1 take local |
2817 | // 2 take remote | 2821 | // 2 take remote |
2818 | // 3 cancel | 2822 | // 3 cancel |
2819 | QDateTime lastSync = mLastAddressbookSync; | 2823 | QDateTime lastSync = mLastAddressbookSync; |
2820 | QDateTime localMod = local->revision(); | 2824 | QDateTime localMod = local->revision(); |
2821 | QDateTime remoteMod = remote->revision(); | 2825 | QDateTime remoteMod = remote->revision(); |
2822 | 2826 | ||
2823 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2827 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2824 | 2828 | ||
2825 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2829 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2826 | bool remCh, locCh; | 2830 | bool remCh, locCh; |
2827 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); | 2831 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); |
2828 | //if ( remCh ) | 2832 | //if ( remCh ) |
2829 | // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); | 2833 | // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); |
2830 | locCh = ( localMod > mLastAddressbookSync ); | 2834 | locCh = ( localMod > mLastAddressbookSync ); |
2831 | //qDebug("cahnged rem %d loc %d",remCh, locCh ); | 2835 | //qDebug("cahnged rem %d loc %d",remCh, locCh ); |
2832 | if ( !remCh && ! locCh ) { | 2836 | if ( !remCh && ! locCh ) { |
2833 | //qDebug("both not changed "); | 2837 | //qDebug("both not changed "); |
2834 | lastSync = localMod.addDays(1); | 2838 | lastSync = localMod.addDays(1); |
2835 | if ( mode <= SYNC_PREF_ASK ) | 2839 | if ( mode <= SYNC_PREF_ASK ) |
2836 | return 0; | 2840 | return 0; |
2837 | } else { | 2841 | } else { |
2838 | if ( locCh ) { | 2842 | if ( locCh ) { |
2839 | //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); | 2843 | //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); |
2840 | lastSync = localMod.addDays( -1 ); | 2844 | lastSync = localMod.addDays( -1 ); |
2841 | if ( !remCh ) | 2845 | if ( !remCh ) |
2842 | remoteMod =( lastSync.addDays( -1 ) ); | 2846 | remoteMod =( lastSync.addDays( -1 ) ); |
2843 | } else { | 2847 | } else { |
2844 | //qDebug(" not loc changed "); | 2848 | //qDebug(" not loc changed "); |
2845 | lastSync = localMod.addDays( 1 ); | 2849 | lastSync = localMod.addDays( 1 ); |
2846 | if ( remCh ) { | 2850 | if ( remCh ) { |
2847 | //qDebug("rem changed "); | 2851 | //qDebug("rem changed "); |
2848 | remoteMod =( lastSync.addDays( 1 ) ); | 2852 | remoteMod =( lastSync.addDays( 1 ) ); |
2849 | } | 2853 | } |
2850 | 2854 | ||
2851 | } | 2855 | } |
2852 | } | 2856 | } |
2853 | full = true; | 2857 | full = true; |
2854 | if ( mode < SYNC_PREF_ASK ) | 2858 | if ( mode < SYNC_PREF_ASK ) |
2855 | mode = SYNC_PREF_ASK; | 2859 | mode = SYNC_PREF_ASK; |
2856 | } else { | 2860 | } else { |
2857 | if ( localMod == remoteMod ) | 2861 | if ( localMod == remoteMod ) |
2858 | return 0; | 2862 | return 0; |
2859 | 2863 | ||
2860 | } | 2864 | } |
2861 | //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec()); | 2865 | //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec()); |
2862 | //qDebug("lastsync %s ", lastSync.toString().latin1() ); | 2866 | //qDebug("lastsync %s ", lastSync.toString().latin1() ); |
2863 | //full = true; //debug only | 2867 | //full = true; //debug only |
2864 | if ( full ) { | 2868 | if ( full ) { |
2865 | bool equ = ( (*local) == (*remote) ); | 2869 | bool equ = ( (*local) == (*remote) ); |
2866 | if ( equ ) { | 2870 | if ( equ ) { |
2867 | //qDebug("equal "); | 2871 | //qDebug("equal "); |
2868 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2872 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2869 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); | 2873 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); |
2870 | } | 2874 | } |
2871 | if ( mode < SYNC_PREF_FORCE_LOCAL ) | 2875 | if ( mode < SYNC_PREF_FORCE_LOCAL ) |
2872 | return 0; | 2876 | return 0; |
2873 | 2877 | ||
2874 | }//else //debug only | 2878 | }//else //debug only |
2875 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); | 2879 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); |
2876 | } | 2880 | } |
2877 | int result; | 2881 | int result; |
2878 | bool localIsNew; | 2882 | bool localIsNew; |
2879 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , local->lastModified().toString().latin1() , remote->lastModified().toString().latin1() ); | 2883 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , local->lastModified().toString().latin1() , remote->lastModified().toString().latin1() ); |
2880 | 2884 | ||
2881 | if ( full && mode < SYNC_PREF_NEWEST ) | 2885 | if ( full && mode < SYNC_PREF_NEWEST ) |
2882 | mode = SYNC_PREF_ASK; | 2886 | mode = SYNC_PREF_ASK; |
2883 | 2887 | ||
2884 | switch( mode ) { | 2888 | switch( mode ) { |
2885 | case SYNC_PREF_LOCAL: | 2889 | case SYNC_PREF_LOCAL: |
2886 | if ( lastSync > remoteMod ) | 2890 | if ( lastSync > remoteMod ) |
2887 | return 1; | 2891 | return 1; |
2888 | if ( lastSync > localMod ) | 2892 | if ( lastSync > localMod ) |
2889 | return 2; | 2893 | return 2; |
2890 | return 1; | 2894 | return 1; |
2891 | break; | 2895 | break; |
2892 | case SYNC_PREF_REMOTE: | 2896 | case SYNC_PREF_REMOTE: |
2893 | if ( lastSync > localMod ) | 2897 | if ( lastSync > localMod ) |
2894 | return 2; | 2898 | return 2; |
2895 | if ( lastSync > remoteMod ) | 2899 | if ( lastSync > remoteMod ) |
2896 | return 1; | 2900 | return 1; |
2897 | return 2; | 2901 | return 2; |
2898 | break; | 2902 | break; |
2899 | case SYNC_PREF_NEWEST: | 2903 | case SYNC_PREF_NEWEST: |
2900 | if ( localMod > remoteMod ) | 2904 | if ( localMod > remoteMod ) |
2901 | return 1; | 2905 | return 1; |
2902 | else | 2906 | else |
2903 | return 2; | 2907 | return 2; |
2904 | break; | 2908 | break; |
2905 | case SYNC_PREF_ASK: | 2909 | case SYNC_PREF_ASK: |
2906 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); | 2910 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); |
2907 | if ( lastSync > remoteMod && lastSync > localMod) | 2911 | if ( lastSync > remoteMod && lastSync > localMod) |
2908 | return 0; | 2912 | return 0; |
2909 | if ( lastSync > remoteMod ) | 2913 | if ( lastSync > remoteMod ) |
2910 | return 1; | 2914 | return 1; |
2911 | if ( lastSync > localMod ) { | 2915 | if ( lastSync > localMod ) { |
2912 | return 2; | 2916 | return 2; |
2913 | } | 2917 | } |
2914 | localIsNew = localMod >= remoteMod; | 2918 | localIsNew = localMod >= remoteMod; |
2915 | //qDebug("conflict! ************************************** "); | 2919 | //qDebug("conflict! ************************************** "); |
2916 | { | 2920 | { |
2917 | KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this ); | 2921 | KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this ); |
2918 | result = acd.executeD(localIsNew); | 2922 | result = acd.executeD(localIsNew); |
2919 | return result; | 2923 | return result; |
2920 | } | 2924 | } |
2921 | break; | 2925 | break; |
2922 | case SYNC_PREF_FORCE_LOCAL: | 2926 | case SYNC_PREF_FORCE_LOCAL: |
2923 | return 1; | 2927 | return 1; |
2924 | break; | 2928 | break; |
2925 | case SYNC_PREF_FORCE_REMOTE: | 2929 | case SYNC_PREF_FORCE_REMOTE: |
2926 | return 2; | 2930 | return 2; |
2927 | break; | 2931 | break; |
2928 | 2932 | ||
2929 | default: | 2933 | default: |
2930 | // SYNC_PREF_TAKE_BOTH not implemented | 2934 | // SYNC_PREF_TAKE_BOTH not implemented |
2931 | break; | 2935 | break; |
2932 | } | 2936 | } |
2933 | return 0; | 2937 | return 0; |
2934 | } | 2938 | } |
2935 | 2939 | ||
2936 | 2940 | ||
2937 | bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode) | 2941 | bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode) |
2938 | { | 2942 | { |
2939 | bool syncOK = true; | 2943 | bool syncOK = true; |
2940 | int addedAddressee = 0; | 2944 | int addedAddressee = 0; |
2941 | int addedAddresseeR = 0; | 2945 | int addedAddresseeR = 0; |
2942 | int deletedAddresseeR = 0; | 2946 | int deletedAddresseeR = 0; |
2943 | int deletedAddresseeL = 0; | 2947 | int deletedAddresseeL = 0; |
2944 | int changedLocal = 0; | 2948 | int changedLocal = 0; |
2945 | int changedRemote = 0; | 2949 | int changedRemote = 0; |
2946 | int filteredIN = 0; | 2950 | int filteredIN = 0; |
2947 | int filteredOUT = 0; | 2951 | int filteredOUT = 0; |
2948 | 2952 | ||
2949 | QString mCurrentSyncName = syncManager->getCurrentSyncName(); | 2953 | QString mCurrentSyncName = syncManager->getCurrentSyncName(); |
2950 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); | 2954 | QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); |
2951 | 2955 | ||
2952 | //QPtrList<Addressee> el = local->rawAddressees(); | 2956 | //QPtrList<Addressee> el = local->rawAddressees(); |
2953 | Addressee addresseeR; | 2957 | Addressee addresseeR; |
2954 | QString uid; | 2958 | QString uid; |
2955 | int take; | 2959 | int take; |
2956 | Addressee addresseeL; | 2960 | Addressee addresseeL; |
2957 | Addressee addresseeRSync; | 2961 | Addressee addresseeRSync; |
2958 | Addressee addresseeLSync; | 2962 | Addressee addresseeLSync; |
2959 | // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees(); | 2963 | // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees(); |
2960 | //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees(); | 2964 | //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees(); |
2961 | bool fullDateRange = false; | 2965 | bool fullDateRange = false; |
2962 | local->resetTempSyncStat(); | 2966 | local->resetTempSyncStat(); |
2963 | mLastAddressbookSync = QDateTime::currentDateTime(); | 2967 | mLastAddressbookSync = QDateTime::currentDateTime(); |
2964 | if ( syncManager->syncWithDesktop() ) { | 2968 | if ( syncManager->syncWithDesktop() ) { |
2965 | // remote->removeSyncInfo( QString());//remove all info | 2969 | // remote->removeSyncInfo( QString());//remove all info |
2966 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { | 2970 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { |
2967 | mLastAddressbookSync = KSyncManager::mRequestedSyncEvent; | 2971 | mLastAddressbookSync = KSyncManager::mRequestedSyncEvent; |
2968 | qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() ); | 2972 | qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() ); |
2969 | } else { | 2973 | } else { |
2970 | qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime "); | 2974 | qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime "); |
2971 | } | 2975 | } |
2972 | } | 2976 | } |
2973 | QDateTime modifiedCalendar = mLastAddressbookSync; | 2977 | QDateTime modifiedCalendar = mLastAddressbookSync; |
2974 | addresseeLSync = getLastSyncAddressee(); | 2978 | addresseeLSync = getLastSyncAddressee(); |
2975 | qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1()); | 2979 | qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1()); |
2976 | addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName ); | 2980 | addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName ); |
2977 | if ( !addresseeR.isEmpty() ) { | 2981 | if ( !addresseeR.isEmpty() ) { |
2978 | addresseeRSync = addresseeR; | 2982 | addresseeRSync = addresseeR; |
2979 | remote->removeAddressee(addresseeR ); | 2983 | remote->removeAddressee(addresseeR ); |
2980 | 2984 | ||
2981 | } else { | 2985 | } else { |
2982 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 2986 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
2983 | addresseeRSync = addresseeLSync ; | 2987 | addresseeRSync = addresseeLSync ; |
2984 | } else { | 2988 | } else { |
2985 | //qDebug("FULLDATE 1"); | 2989 | //qDebug("FULLDATE 1"); |
2986 | fullDateRange = true; | 2990 | fullDateRange = true; |
2987 | Addressee newAdd; | 2991 | Addressee newAdd; |
2988 | addresseeRSync = newAdd; | 2992 | addresseeRSync = newAdd; |
2989 | addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee")); | 2993 | addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee")); |
2990 | addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName ); | 2994 | addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName ); |
2991 | addresseeRSync.setRevision( mLastAddressbookSync ); | 2995 | addresseeRSync.setRevision( mLastAddressbookSync ); |
2992 | addresseeRSync.setCategories( i18n("SyncAddressee") ); | 2996 | addresseeRSync.setCategories( i18n("SyncAddressee") ); |
2993 | } | 2997 | } |
2994 | } | 2998 | } |
2995 | if ( addresseeLSync.revision() == mLastAddressbookSync ) { | 2999 | if ( addresseeLSync.revision() == mLastAddressbookSync ) { |
2996 | // qDebug("FULLDATE 2"); | 3000 | // qDebug("FULLDATE 2"); |
2997 | fullDateRange = true; | 3001 | fullDateRange = true; |
2998 | } | 3002 | } |
2999 | if ( ! fullDateRange ) { | 3003 | if ( ! fullDateRange ) { |
3000 | if ( addresseeLSync.revision() != addresseeRSync.revision() ) { | 3004 | if ( addresseeLSync.revision() != addresseeRSync.revision() ) { |
3001 | 3005 | ||
3002 | // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() ); | 3006 | // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() ); |
3003 | //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec()); | 3007 | //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec()); |
3004 | fullDateRange = true; | 3008 | fullDateRange = true; |
3005 | //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() ); | 3009 | //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() ); |
3006 | } | 3010 | } |
3007 | } | 3011 | } |
3008 | // fullDateRange = true; // debug only! | 3012 | // fullDateRange = true; // debug only! |
3009 | if ( fullDateRange ) | 3013 | if ( fullDateRange ) |
3010 | mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365); | 3014 | mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365); |
3011 | else | 3015 | else |
3012 | mLastAddressbookSync = addresseeLSync.revision(); | 3016 | mLastAddressbookSync = addresseeLSync.revision(); |
3013 | // for resyncing if own file has changed | 3017 | // for resyncing if own file has changed |
3014 | // PENDING fixme later when implemented | 3018 | // PENDING fixme later when implemented |
3015 | #if 0 | 3019 | #if 0 |
3016 | if ( mCurrentSyncDevice == "deleteaftersync" ) { | 3020 | if ( mCurrentSyncDevice == "deleteaftersync" ) { |
3017 | mLastAddressbookSync = loadedFileVersion; | 3021 | mLastAddressbookSync = loadedFileVersion; |
3018 | qDebug("setting mLastAddressbookSync "); | 3022 | qDebug("setting mLastAddressbookSync "); |
3019 | } | 3023 | } |
3020 | #endif | 3024 | #endif |
3021 | 3025 | ||
3022 | 3026 | ||
3023 | // ********** setting filters **************** | 3027 | // ********** setting filters **************** |
3024 | Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB ); | 3028 | Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB ); |
3025 | Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB ); | 3029 | Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB ); |
3026 | 3030 | ||
3027 | //qDebug("*************************** "); | 3031 | //qDebug("*************************** "); |
3028 | // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() ); | 3032 | // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() ); |
3029 | QStringList er = remote->uidList(); | 3033 | QStringList er = remote->uidList(); |
3030 | Addressee inR ;//= er.first(); | 3034 | Addressee inR ;//= er.first(); |
3031 | Addressee inL; | 3035 | Addressee inL; |
3032 | 3036 | ||
3033 | syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count()); | 3037 | syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count()); |
3034 | 3038 | ||
3035 | int modulo = (er.count()/10)+1; | 3039 | int modulo = (er.count()/10)+1; |
3036 | int incCounter = 0; | 3040 | int incCounter = 0; |
3037 | while ( incCounter < er.count()) { | 3041 | while ( incCounter < er.count()) { |
3038 | if (syncManager->isProgressBarCanceled()) | 3042 | if (syncManager->isProgressBarCanceled()) |
3039 | return false; | 3043 | return false; |
3040 | if ( incCounter % modulo == 0 ) | 3044 | if ( incCounter % modulo == 0 ) |
3041 | syncManager->showProgressBar(incCounter); | 3045 | syncManager->showProgressBar(incCounter); |
3042 | 3046 | ||
3043 | uid = er[ incCounter ]; | 3047 | uid = er[ incCounter ]; |
3044 | bool skipIncidence = false; | 3048 | bool skipIncidence = false; |
3045 | if ( uid.left(19) == QString("last-syncAddressee-") ) | 3049 | if ( uid.left(19) == QString("last-syncAddressee-") ) |
3046 | skipIncidence = true; | 3050 | skipIncidence = true; |
3047 | QString idS,OidS; | 3051 | QString idS,OidS; |
3048 | qApp->processEvents(); | 3052 | qApp->processEvents(); |
3049 | if ( !skipIncidence ) { | 3053 | if ( !skipIncidence ) { |
3050 | inL = local->findByUid( uid ); | 3054 | inL = local->findByUid( uid ); |
3051 | inR = remote->findByUid( uid ); | 3055 | inR = remote->findByUid( uid ); |
3052 | //inL.setResource( 0 ); | 3056 | //inL.setResource( 0 ); |
3053 | //inR.setResource( 0 ); | 3057 | //inR.setResource( 0 ); |
3054 | if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars | 3058 | if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars |
3055 | if ( !inL.resource() || inL.resource()->includeInSync() ) { | 3059 | if ( !inL.resource() || inL.resource()->includeInSync() ) { |
3056 | if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) { | 3060 | if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) { |
3057 | //qDebug("take %d %s ", take, inL.summary().latin1()); | 3061 | //qDebug("take %d %s ", take, inL.summary().latin1()); |
3058 | if ( take == 3 ) | 3062 | if ( take == 3 ) |
3059 | return false; | 3063 | return false; |
3060 | if ( take == 1 ) {// take local ********************** | 3064 | if ( take == 1 ) {// take local ********************** |
3061 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3065 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3062 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); | 3066 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); |
3063 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); | 3067 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); |
3064 | local->insertAddressee( inL, false ); | 3068 | local->insertAddressee( inL, false ); |
3065 | idS = inR.externalUID(); | 3069 | idS = inR.externalUID(); |
3066 | OidS = inR.originalExternalUID(); | 3070 | OidS = inR.originalExternalUID(); |
3067 | } | 3071 | } |
3068 | else | 3072 | else |
3069 | idS = inR.IDStr(); | 3073 | idS = inR.IDStr(); |
3070 | remote->removeAddressee( inR ); | 3074 | remote->removeAddressee( inR ); |
3071 | inR = inL; | 3075 | inR = inL; |
3072 | inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 3076 | inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
3073 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3077 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3074 | inR.setOriginalExternalUID( OidS ); | 3078 | inR.setOriginalExternalUID( OidS ); |
3075 | inR.setExternalUID( idS ); | 3079 | inR.setExternalUID( idS ); |
3076 | if ( syncManager->syncWithDesktop() ) { | 3080 | if ( syncManager->syncWithDesktop() ) { |
3077 | inR.setIDStr("changed" ); | 3081 | inR.setIDStr("changed" ); |
3078 | } | 3082 | } |
3079 | //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" ); | 3083 | //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" ); |
3080 | } else { | 3084 | } else { |
3081 | inR.setIDStr( idS ); | 3085 | inR.setIDStr( idS ); |
3082 | } | 3086 | } |
3083 | inR.setResource( 0 ); | 3087 | inR.setResource( 0 ); |
3084 | remote->insertAddressee( inR , false); | 3088 | remote->insertAddressee( inR , false); |
3085 | ++changedRemote; | 3089 | ++changedRemote; |
3086 | } else { // take == 2 take remote ********************** | 3090 | } else { // take == 2 take remote ********************** |
3087 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3091 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3088 | if ( inR.revision().date().year() < 2004 ) | 3092 | if ( inR.revision().date().year() < 2004 ) |
3089 | inR.setRevision( modifiedCalendar ); | 3093 | inR.setRevision( modifiedCalendar ); |
3090 | } | 3094 | } |
3091 | idS = inL.IDStr(); | 3095 | idS = inL.IDStr(); |
3092 | local->removeAddressee( inL ); | 3096 | local->removeAddressee( inL ); |
3093 | inL = inR; | 3097 | inL = inR; |
3094 | inL.setIDStr( idS ); | 3098 | inL.setIDStr( idS ); |
3095 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3099 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3096 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); | 3100 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); |
3097 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); | 3101 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); |
3098 | } | 3102 | } |
3099 | inL.setResource( 0 ); | 3103 | inL.setResource( 0 ); |
3100 | local->insertAddressee( inL , false ); | 3104 | local->insertAddressee( inL , false ); |
3101 | ++changedLocal; | 3105 | ++changedLocal; |
3102 | } | 3106 | } |
3103 | } | 3107 | } |
3104 | } | 3108 | } |
3105 | } else { // no conflict ********** add or delete remote | 3109 | } else { // no conflict ********** add or delete remote |
3106 | if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) { | 3110 | if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) { |
3107 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3111 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3108 | QString des = addresseeLSync.note(); | 3112 | QString des = addresseeLSync.note(); |
3109 | if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it | 3113 | if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it |
3110 | inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE ); | 3114 | inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE ); |
3111 | remote->insertAddressee( inR, false ); | 3115 | remote->insertAddressee( inR, false ); |
3112 | ++deletedAddresseeR; | 3116 | ++deletedAddresseeR; |
3113 | } else { | 3117 | } else { |
3114 | inR.setRevision( modifiedCalendar ); | 3118 | inR.setRevision( modifiedCalendar ); |
3115 | remote->insertAddressee( inR, false ); | 3119 | remote->insertAddressee( inR, false ); |
3116 | inL = inR; | 3120 | inL = inR; |
3117 | inL.setIDStr( ":" ); | 3121 | inL.setIDStr( ":" ); |
3118 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); | 3122 | inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); |
3119 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); | 3123 | inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); |
3120 | inL.setResource( 0 ); | 3124 | inL.setResource( 0 ); |
3121 | local->insertAddressee( inL , false); | 3125 | local->insertAddressee( inL , false); |
3122 | ++addedAddressee; | 3126 | ++addedAddressee; |
3123 | } | 3127 | } |
3124 | } else { | 3128 | } else { |
3125 | if ( inR.revision() > mLastAddressbookSync || mode == 5 ) { | 3129 | if ( inR.revision() > mLastAddressbookSync || mode == 5 ) { |
3126 | inR.setRevision( modifiedCalendar ); | 3130 | inR.setRevision( modifiedCalendar ); |
3127 | remote->insertAddressee( inR, false ); | 3131 | remote->insertAddressee( inR, false ); |
3128 | inR.setResource( 0 ); | 3132 | inR.setResource( 0 ); |
3129 | local->insertAddressee( inR, false ); | 3133 | local->insertAddressee( inR, false ); |
3130 | ++addedAddressee; | 3134 | ++addedAddressee; |
3131 | } else { | 3135 | } else { |
3132 | // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); | 3136 | // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); |
3133 | remote->removeAddressee( inR ); | 3137 | remote->removeAddressee( inR ); |
3134 | ++deletedAddresseeR; | 3138 | ++deletedAddresseeR; |
3135 | } | 3139 | } |
3136 | } | 3140 | } |
3137 | } else { | 3141 | } else { |
3138 | ++filteredIN; | 3142 | ++filteredIN; |
3139 | } | 3143 | } |
3140 | } | 3144 | } |
3141 | } | 3145 | } |
3142 | ++incCounter; | 3146 | ++incCounter; |
3143 | } | 3147 | } |
3144 | er.clear(); | 3148 | er.clear(); |
3145 | QStringList el = local->uidList(); | 3149 | QStringList el = local->uidList(); |
3146 | modulo = (el.count()/10)+1; | 3150 | modulo = (el.count()/10)+1; |
3147 | 3151 | ||
3148 | syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); | 3152 | syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); |
3149 | incCounter = 0; | 3153 | incCounter = 0; |
3150 | while ( incCounter < el.count()) { | 3154 | while ( incCounter < el.count()) { |
3151 | qApp->processEvents(); | 3155 | qApp->processEvents(); |
3152 | if (syncManager->isProgressBarCanceled()) | 3156 | if (syncManager->isProgressBarCanceled()) |
3153 | return false; | 3157 | return false; |
3154 | if ( incCounter % modulo == 0 ) | 3158 | if ( incCounter % modulo == 0 ) |
3155 | syncManager->showProgressBar(incCounter); | 3159 | syncManager->showProgressBar(incCounter); |
3156 | uid = el[ incCounter ]; | 3160 | uid = el[ incCounter ]; |
3157 | bool skipIncidence = false; | 3161 | bool skipIncidence = false; |
3158 | if ( uid.left(19) == QString("last-syncAddressee-") ) | 3162 | if ( uid.left(19) == QString("last-syncAddressee-") ) |
3159 | skipIncidence = true; | 3163 | skipIncidence = true; |
3160 | if ( !skipIncidence ) { | 3164 | if ( !skipIncidence ) { |
3161 | inL = local->findByUid( uid ); | 3165 | inL = local->findByUid( uid ); |
3162 | if ( !inL.resource() || inL.resource()->includeInSync() ) { | 3166 | if ( !inL.resource() || inL.resource()->includeInSync() ) { |
3163 | inR = remote->findByUid( uid ); | 3167 | inR = remote->findByUid( uid ); |
3164 | if ( inR.isEmpty() ){ | 3168 | if ( inR.isEmpty() ){ |
3165 | if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) { | 3169 | if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) { |
3166 | // no conflict ********** add or delete local | 3170 | // no conflict ********** add or delete local |
3167 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 3171 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
3168 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 3172 | if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
3169 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 3173 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
3170 | local->removeAddressee( inL ); | 3174 | local->removeAddressee( inL ); |
3171 | ++deletedAddresseeL; | 3175 | ++deletedAddresseeL; |
3172 | } else { | 3176 | } else { |
3173 | if ( ! syncManager->mWriteBackExistingOnly ) { | 3177 | if ( ! syncManager->mWriteBackExistingOnly ) { |
3174 | inL.removeID(mCurrentSyncDevice ); | 3178 | inL.removeID(mCurrentSyncDevice ); |
3175 | ++addedAddresseeR; | 3179 | ++addedAddresseeR; |
3176 | inL.setRevision( modifiedCalendar ); | 3180 | inL.setRevision( modifiedCalendar ); |
3177 | local->insertAddressee( inL, false ); | 3181 | local->insertAddressee( inL, false ); |
3178 | inR = inL; | 3182 | inR = inL; |
3179 | inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); | 3183 | inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); |
3180 | inR.setResource( 0 ); | 3184 | inR.setResource( 0 ); |
3181 | remote->insertAddressee( inR, false ); | 3185 | remote->insertAddressee( inR, false ); |
3182 | } | 3186 | } |
3183 | } | 3187 | } |
3184 | } else { | 3188 | } else { |
3185 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { | 3189 | if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { |
3186 | //qDebug("data %s ", inL.revision().toString().latin1()); | 3190 | //qDebug("data %s ", inL.revision().toString().latin1()); |
3187 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); | 3191 | // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); |
3188 | local->removeAddressee( inL ); | 3192 | local->removeAddressee( inL ); |
3189 | ++deletedAddresseeL; | 3193 | ++deletedAddresseeL; |
3190 | } else { | 3194 | } else { |
3191 | if ( ! syncManager->mWriteBackExistingOnly ) { | 3195 | if ( ! syncManager->mWriteBackExistingOnly ) { |
3192 | ++addedAddresseeR; | 3196 | ++addedAddresseeR; |
3193 | inL.setRevision( modifiedCalendar ); | 3197 | inL.setRevision( modifiedCalendar ); |
3194 | local->insertAddressee( inL, false ); | 3198 | local->insertAddressee( inL, false ); |
3195 | inR = inL; | 3199 | inR = inL; |
3196 | inR.setIDStr( ":" ); | 3200 | inR.setIDStr( ":" ); |
3197 | inR.setResource( 0 ); | 3201 | inR.setResource( 0 ); |
3198 | remote->insertAddressee( inR, false ); | 3202 | remote->insertAddressee( inR, false ); |
3199 | } | 3203 | } |
3200 | } | 3204 | } |
3201 | } | 3205 | } |
3202 | } else { | 3206 | } else { |
3203 | ++filteredOUT; | 3207 | ++filteredOUT; |
3204 | } | 3208 | } |
3205 | } | 3209 | } |
3206 | } | 3210 | } |
3207 | } | 3211 | } |
3208 | ++incCounter; | 3212 | ++incCounter; |
3209 | } | 3213 | } |
3210 | el.clear(); | 3214 | el.clear(); |
3211 | syncManager->hideProgressBar(); | 3215 | syncManager->hideProgressBar(); |
3212 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); | 3216 | mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); |
3213 | // get rid of micro seconds | 3217 | // get rid of micro seconds |
3214 | QTime t = mLastAddressbookSync.time(); | 3218 | QTime t = mLastAddressbookSync.time(); |
3215 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); | 3219 | mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); |
3216 | addresseeLSync.setRevision( mLastAddressbookSync ); | 3220 | addresseeLSync.setRevision( mLastAddressbookSync ); |
3217 | addresseeRSync.setRevision( mLastAddressbookSync ); | 3221 | addresseeRSync.setRevision( mLastAddressbookSync ); |
3218 | addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; | 3222 | addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; |
3219 | addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); | 3223 | addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); |
3220 | addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; | 3224 | addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; |
3221 | addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); | 3225 | addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); |
3222 | addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; | 3226 | addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; |
3223 | addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); | 3227 | addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); |
3224 | addresseeRSync.setNote( "" ) ; | 3228 | addresseeRSync.setNote( "" ) ; |
3225 | addresseeLSync.setNote( "" ); | 3229 | addresseeLSync.setNote( "" ); |
3226 | 3230 | ||
3227 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) | 3231 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) |
3228 | remote->insertAddressee( addresseeRSync, false ); | 3232 | remote->insertAddressee( addresseeRSync, false ); |
3229 | local->insertAddressee( addresseeLSync, false ); | 3233 | local->insertAddressee( addresseeLSync, false ); |
3230 | QString mes; | 3234 | QString mes; |
3231 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR, filteredIN, filteredOUT ); | 3235 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out"),addedAddressee, addedAddresseeR, changedLocal, changedRemote, deletedAddresseeL, deletedAddresseeR, filteredIN, filteredOUT ); |
3232 | qDebug( mes ); | 3236 | qDebug( mes ); |
3233 | mes = i18n("Local addressbook changed!\n") +mes; | 3237 | mes = i18n("Local addressbook changed!\n") +mes; |
3234 | if ( syncManager->mShowSyncSummary ) { | 3238 | if ( syncManager->mShowSyncSummary ) { |
3235 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, | 3239 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, |
3236 | i18n("KA/Pi Synchronization"),i18n("Write back"))) { | 3240 | i18n("KA/Pi Synchronization"),i18n("Write back"))) { |
3237 | qDebug("KA: WB cancelled "); | 3241 | qDebug("KA: WB cancelled "); |
3238 | syncManager->mWriteBackFile = false; | 3242 | syncManager->mWriteBackFile = false; |
3239 | return syncOK; | 3243 | return syncOK; |
3240 | } | 3244 | } |
3241 | } | 3245 | } |
3242 | return syncOK; | 3246 | return syncOK; |
3243 | } | 3247 | } |
3244 | 3248 | ||
3245 | 3249 | ||
3246 | //this is a overwritten callbackmethods from the syncinterface | 3250 | //this is a overwritten callbackmethods from the syncinterface |
3247 | bool KABCore::sync(KSyncManager* manager, QString filename, int mode) | 3251 | bool KABCore::sync(KSyncManager* manager, QString filename, int mode) |
3248 | { | 3252 | { |
3249 | 3253 | ||
3250 | //pending prepare addresseeview for output | 3254 | //pending prepare addresseeview for output |
3251 | //pending detect, if remote file has REV field. if not switch to external sync | 3255 | //pending detect, if remote file has REV field. if not switch to external sync |
3252 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 3256 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
3253 | if ( manager != syncManager ) | 3257 | if ( manager != syncManager ) |
3254 | qDebug("KABCore::sync:: ERROR! :: manager != syncManager "); | 3258 | qDebug("KABCore::sync:: ERROR! :: manager != syncManager "); |
3255 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); | 3259 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); |
3256 | 3260 | ||
3257 | AddressBook abLocal(filename,"syncContact"); | 3261 | AddressBook abLocal(filename,"syncContact"); |
3258 | bool syncOK = false; | 3262 | bool syncOK = false; |
3259 | if ( abLocal.load() ) { | 3263 | if ( abLocal.load() ) { |
3260 | qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode ); | 3264 | qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode ); |
3261 | bool external = false; | 3265 | bool external = false; |
3262 | bool isXML = false; | 3266 | bool isXML = false; |
3263 | if ( filename.right(4) == ".xml") { | 3267 | if ( filename.right(4) == ".xml") { |
3264 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 3268 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
3265 | isXML = true; | 3269 | isXML = true; |
3266 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); | 3270 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); |
3267 | } else { | 3271 | } else { |
3268 | external = !manager->mIsKapiFile; | 3272 | external = !manager->mIsKapiFile; |
3269 | if ( external ) { | 3273 | if ( external ) { |
3270 | qDebug("KA: Sync::Setting vcf mode to external "); | 3274 | qDebug("KA: Sync::Setting vcf mode to external "); |
3271 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 3275 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
3272 | AddressBook::Iterator it; | 3276 | AddressBook::Iterator it; |
3273 | for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { | 3277 | for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { |
3274 | (*it).setID( mCurrentSyncDevice, (*it).uid() ); | 3278 | (*it).setID( mCurrentSyncDevice, (*it).uid() ); |
3275 | (*it).computeCsum( mCurrentSyncDevice ); | 3279 | (*it).computeCsum( mCurrentSyncDevice ); |
3276 | } | 3280 | } |
3277 | } | 3281 | } |
3278 | } | 3282 | } |
3279 | //AddressBook::Iterator it; | 3283 | //AddressBook::Iterator it; |
3280 | //QStringList vcards; | 3284 | //QStringList vcards; |
3281 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { | 3285 | //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { |
3282 | // qDebug("Name %s ", (*it).familyName().latin1()); | 3286 | // qDebug("Name %s ", (*it).familyName().latin1()); |
3283 | //} | 3287 | //} |
3284 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); | 3288 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); |
3285 | syncManager->hideProgressBar(); | 3289 | syncManager->hideProgressBar(); |
3286 | if ( syncOK ) { | 3290 | if ( syncOK ) { |
3287 | if ( syncManager->mWriteBackFile ) | 3291 | if ( syncManager->mWriteBackFile ) |
3288 | { | 3292 | { |
3289 | if ( external ) | 3293 | if ( external ) |
3290 | abLocal.removeSyncAddressees( !isXML); | 3294 | abLocal.removeSyncAddressees( !isXML); |
3291 | qDebug("KA: Sync::Saving remote AB "); | 3295 | qDebug("KA: Sync::Saving remote AB "); |
3292 | if ( ! abLocal.saveAB()) | 3296 | if ( ! abLocal.saveAB()) |
3293 | qDebug("KA: sync::Error writing back AB to file "); | 3297 | qDebug("KA: sync::Error writing back AB to file "); |
3294 | if ( external ) { | 3298 | if ( external ) { |
3295 | // afterwrite processing | 3299 | // afterwrite processing |
3296 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); | 3300 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); |
3297 | } | 3301 | } |
3298 | } | 3302 | } |
3299 | } | 3303 | } |
3300 | setModified(); | 3304 | setModified(); |
3301 | 3305 | ||
3302 | } | 3306 | } |
3303 | abLocal.removeResources(); | 3307 | abLocal.removeResources(); |
3304 | if ( syncOK ) | 3308 | if ( syncOK ) |
3305 | mViewManager->refreshView(); | 3309 | mViewManager->refreshView(); |
3306 | return syncOK; | 3310 | return syncOK; |
3307 | 3311 | ||
3308 | } | 3312 | } |
3309 | void KABCore::removeSyncInfo( QString syncProfile) | 3313 | void KABCore::removeSyncInfo( QString syncProfile) |
3310 | { | 3314 | { |
3311 | qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1()); | 3315 | qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1()); |
3312 | mAddressBook->removeSyncInfo( syncProfile ); | 3316 | mAddressBook->removeSyncInfo( syncProfile ); |
3313 | setModified(); | 3317 | setModified(); |
3314 | } | 3318 | } |
3315 | 3319 | ||
3316 | 3320 | ||
3317 | //this is a overwritten callbackmethods from the syncinterface | 3321 | //this is a overwritten callbackmethods from the syncinterface |
3318 | bool KABCore::syncExternal(KSyncManager* manager, QString resource) | 3322 | bool KABCore::syncExternal(KSyncManager* manager, QString resource) |
3319 | { | 3323 | { |
3320 | if ( resource == "phone" ) | 3324 | if ( resource == "phone" ) |
3321 | return syncPhone(); | 3325 | return syncPhone(); |
3322 | disableBR( true ); | 3326 | disableBR( true ); |
3323 | if ( manager != syncManager ) | 3327 | if ( manager != syncManager ) |
3324 | qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager "); | 3328 | qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager "); |
3325 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); | 3329 | QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); |
3326 | 3330 | ||
3327 | AddressBook abLocal( resource,"syncContact"); | 3331 | AddressBook abLocal( resource,"syncContact"); |
3328 | bool syncOK = false; | 3332 | bool syncOK = false; |
3329 | message(i18n("Loading DTM address data..."), false); | 3333 | message(i18n("Loading DTM address data..."), false); |
3330 | if ( abLocal.load() ) { | 3334 | if ( abLocal.load() ) { |
3331 | qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); | 3335 | qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); |
3332 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 3336 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
3333 | message(i18n("Sync preprocessing..."),false); | 3337 | message(i18n("Sync preprocessing..."),false); |
3334 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); | 3338 | abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); |
3335 | message(i18n("Synchronizing..."),false); | 3339 | message(i18n("Synchronizing..."),false); |
3336 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); | 3340 | syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); |
3337 | syncManager->hideProgressBar(); | 3341 | syncManager->hideProgressBar(); |
3338 | if ( syncOK ) { | 3342 | if ( syncOK ) { |
3339 | if ( syncManager->mWriteBackFile ) { | 3343 | if ( syncManager->mWriteBackFile ) { |
3340 | abLocal.removeSyncAddressees( false ); | 3344 | abLocal.removeSyncAddressees( false ); |
3341 | message(i18n("Saving DTM address data..."),false); | 3345 | message(i18n("Saving DTM address data..."),false); |
3342 | abLocal.saveAB(); | 3346 | abLocal.saveAB(); |
3343 | message(i18n("Sync postprocessing..."),false); | 3347 | message(i18n("Sync postprocessing..."),false); |
3344 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); | 3348 | abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); |
3345 | } | 3349 | } |
3346 | } else | 3350 | } else |
3347 | message( i18n("Sync cancelled or failed.") ); | 3351 | message( i18n("Sync cancelled or failed.") ); |
3348 | setModified(); | 3352 | setModified(); |
3349 | } | 3353 | } |
3350 | abLocal.removeResources(); | 3354 | abLocal.removeResources(); |
3351 | if ( syncOK ) { | 3355 | if ( syncOK ) { |
3352 | mViewManager->refreshView(); | 3356 | mViewManager->refreshView(); |
3353 | message(i18n("DTM syncing finished.")); | 3357 | message(i18n("DTM syncing finished.")); |
3354 | } | 3358 | } |
3355 | disableBR( false ); | 3359 | disableBR( false ); |
3356 | return syncOK; | 3360 | return syncOK; |
3357 | 3361 | ||
3358 | } | 3362 | } |
3359 | void KABCore::message( QString m, bool startTimer) | 3363 | void KABCore::message( QString m, bool startTimer) |
3360 | { | 3364 | { |
3361 | topLevelWidget()->setCaption( m ); | 3365 | topLevelWidget()->setCaption( m ); |
3362 | qApp->processEvents(); | 3366 | qApp->processEvents(); |
3363 | if ( startTimer ) | 3367 | if ( startTimer ) |
3364 | mMessageTimer->start( 15000, true ); | 3368 | mMessageTimer->start( 15000, true ); |
3365 | else | 3369 | else |
3366 | mMessageTimer->stop(); | 3370 | mMessageTimer->stop(); |
3367 | } | 3371 | } |