-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 | |||
@@ -2355,437 +2355,441 @@ void KABCore::manageCategories( ) | |||
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() ); |