summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2005-03-29 14:23:43 (UTC)
committer zautrix <zautrix>2005-03-29 14:23:43 (UTC)
commit3116f249fc6ccd0e067213e826d3d924f6986972 (patch) (unidiff)
treefe37b19450279d07b6767d56ef0deeff51f7485e
parentc873163eca527625ce22ed461ee5d4fec61b3b18 (diff)
downloadkdepimpi-3116f249fc6ccd0e067213e826d3d924f6986972.zip
kdepimpi-3116f249fc6ccd0e067213e826d3d924f6986972.tar.gz
kdepimpi-3116f249fc6ccd0e067213e826d3d924f6986972.tar.bz2
fix
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--bin/kdepim/WhatsNew.txt3
-rw-r--r--kaddressbook/kabcore.cpp1
-rw-r--r--libkdepim/externalapphandler.cpp5
3 files changed, 8 insertions, 1 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt
index b5285bf..03aec7b 100644
--- a/bin/kdepim/WhatsNew.txt
+++ b/bin/kdepim/WhatsNew.txt
@@ -1,217 +1,220 @@
1Info about the changes in new versions of KDE-Pim/Pi 1Info about the changes in new versions of KDE-Pim/Pi
2 2
3********** VERSION 2.0.22 ************ 3********** VERSION 2.0.22 ************
4 4
5KO/Pi: 5KO/Pi:
6Fix for creating events/todos via the abgenda context menu. 6Fix for creating events/todos via the abgenda context menu.
7Added option to split toolbar to 3 toolbars. 7Added option to split toolbar to 3 toolbars.
8Added option to show one small filter-view-toolbar. 8Added option to show one small filter-view-toolbar.
9Added a print option to the desktop version: 9Added a print option to the desktop version:
10Now you can print out the view of the "Event Viewer". 10Now you can print out the view of the "Event Viewer".
11That means you can print all data of one particular event/todo. 11That means you can print all data of one particular event/todo.
12Added scaling options to printout of Event Viewer and What'sNext View. 12Added scaling options to printout of Event Viewer and What'sNext View.
13Fixed some problems in the month view in "week start sunday" mode. 13Fixed some problems in the month view in "week start sunday" mode.
14KA/Pi:
15Added two more config options.
16Fixed resizing problem of address request dialog when orientation was switched.
14 17
15********** VERSION 2.0.21 ************ 18********** VERSION 2.0.21 ************
16 19
17Fixed another SMTP problem in OM/Pi. 20Fixed another SMTP problem in OM/Pi.
18Some small changed in the new datenavigator in KO/Pi. 21Some small changed in the new datenavigator in KO/Pi.
19Changed default setting for new filter in KA/Pi to "exclude categories". 22Changed default setting for new filter in KA/Pi to "exclude categories".
20Changed the default font size for 640x480 display . 23Changed the default font size for 640x480 display .
21Changed popup menu behaviour in agenda and list view. 24Changed popup menu behaviour in agenda and list view.
22Fixed some layout problems of the date label size in the month view. 25Fixed some layout problems of the date label size in the month view.
23Made month view update faster. 26Made month view update faster.
24Made first datenavigator repainting faster. 27Made first datenavigator repainting faster.
25Changed the title of the event/todo edit dialogs. 28Changed the title of the event/todo edit dialogs.
26Timelabels in agenga changed from 22:00 to 22 oo. ( the oo higher, of course). 29Timelabels in agenga changed from 22:00 to 22 oo. ( the oo higher, of course).
27Many small usebility fixes in KO/Pi. 30Many small usebility fixes in KO/Pi.
28Pressing the "Calendar" button on the Z switches now to the next view in KO/Pi. 31Pressing the "Calendar" button on the Z switches now to the next view in KO/Pi.
29The set of possible "next views" are the views you have toolbar buttons for. 32The set of possible "next views" are the views you have toolbar buttons for.
30 33
31Made alarm sound working on Linux. 34Made alarm sound working on Linux.
32 35
33KO/Pi alarm applet changed: 36KO/Pi alarm applet changed:
34Made buttons in alarm dialog much bigger. 37Made buttons in alarm dialog much bigger.
35Made setting of timer more user friendly by showing the actual timer fire time and making the buttons in the timer settings much bigger. 38Made setting of timer more user friendly by showing the actual timer fire time and making the buttons in the timer settings much bigger.
36The goal was it to make it possible to use a finger tip ( and not the stylus ) on the touchscreen to adjust the settings. 39The goal was it to make it possible to use a finger tip ( and not the stylus ) on the touchscreen to adjust the settings.
37 40
38And because this version is realeased at Easter, I added an Easter-egg: 41And because this version is realeased at Easter, I added an Easter-egg:
39With a new undocumented command you can get a message box about the next alarm. 42With a new undocumented command you can get a message box about the next alarm.
40Good luck to find it! 43Good luck to find it!
41 44
42 45
43 46
44********** VERSION 2.0.20 ************ 47********** VERSION 2.0.20 ************
45 48
46Two small fixes in OM/Pi. 49Two small fixes in OM/Pi.
47 50
48Better resizing of the new datenavigator in KO/Pi. 51Better resizing of the new datenavigator in KO/Pi.
49 52
50********** VERSION 2.0.19 ************ 53********** VERSION 2.0.19 ************
51KO/Pi: 54KO/Pi:
52Enhancements and bugfixes in the new datenavigator. 55Enhancements and bugfixes in the new datenavigator.
53Bugfix in this changelog: 56Bugfix in this changelog:
54The datenavigator was changed in version 2.0.18, not the datepicker. 57The datenavigator was changed in version 2.0.18, not the datepicker.
55 58
56********** VERSION 2.0.18 ************ 59********** VERSION 2.0.18 ************
57KO/Pi: 60KO/Pi:
58Fixed some minor problems. 61Fixed some minor problems.
59Cleaned up the KO/Pi config dialog. 62Cleaned up the KO/Pi config dialog.
60Fixed problem moving events in aganda view. 63Fixed problem moving events in aganda view.
61Made datepicker scaleable, i.e. if the datenavigator shows now a 64Made datepicker scaleable, i.e. if the datenavigator shows now a
62datenavigator matrix depending on its size. 65datenavigator matrix depending on its size.
63Birthdays are now displayed green in the datenavigator. 66Birthdays are now displayed green in the datenavigator.
64What'sThis Help in datenavigator shows all events of the day. 67What'sThis Help in datenavigator shows all events of the day.
65 68
66OM/Pi: 69OM/Pi:
67Updated the backend mail library to the latest version. 70Updated the backend mail library to the latest version.
68Please backup your mail before using this version. 71Please backup your mail before using this version.
69 72
70********** VERSION 2.0.17 ************ 73********** VERSION 2.0.17 ************
71 74
72KO/Pi: 75KO/Pi:
73Tooltips in month view were not sorted. Fixed. 76Tooltips in month view were not sorted. Fixed.
74Daylabel in agenda view ( for display of one day ) was too short. Fixed. 77Daylabel in agenda view ( for display of one day ) was too short. Fixed.
75Conflict display dialog for syncing was not on top of other windows. Fixed. 78Conflict display dialog for syncing was not on top of other windows. Fixed.
76Fixed some minor problems. 79Fixed some minor problems.
77 80
78Fixed an endless loop when importing vcs file with RESOURCES entry. 81Fixed an endless loop when importing vcs file with RESOURCES entry.
79 82
80********** VERSION 2.0.16 ************ 83********** VERSION 2.0.16 ************
81OM/Pi: 84OM/Pi:
82Fixed the SMTP account setting the option. 85Fixed the SMTP account setting the option.
83Fixed something in mail sending. 86Fixed something in mail sending.
84 87
85KO/Pi: 88KO/Pi:
86Added possibility to export selected events/todos as vcal file. 89Added possibility to export selected events/todos as vcal file.
87 90
88********** VERSION 2.0.15 ************ 91********** VERSION 2.0.15 ************
89 92
90PwM/Pi: 93PwM/Pi:
91Added keyboard shorcuts for 94Added keyboard shorcuts for
92- toggling summary view (space bar) 95- toggling summary view (space bar)
93- delete item (delete + backspace key) 96- delete item (delete + backspace key)
94- add new item ( i + n key) 97- add new item ( i + n key)
95Fixed length of info in the title. 98Fixed length of info in the title.
96 99
97KO/Pi-KA/Pi: 100KO/Pi-KA/Pi:
98Changed "ME" menu bar entry to an icon. 101Changed "ME" menu bar entry to an icon.
99 102
100KO/Pi: 103KO/Pi:
101Fixed two minor bugs in displaying todos. 104Fixed two minor bugs in displaying todos.
102If in month view a cell is selected, the key shortcut "d" shows now that date. 105If in month view a cell is selected, the key shortcut "d" shows now that date.
103Added complete info for a todo in month view as an icon left of the text. 106Added complete info for a todo in month view as an icon left of the text.
104Fixed problems of displaying data when "<" or ">" are used in summary/location/description. 107Fixed problems of displaying data when "<" or ">" are used in summary/location/description.
105Fixed problem of search dialog size when switching displays. 108Fixed problem of search dialog size when switching displays.
106Cancel key now closes date picker. 109Cancel key now closes date picker.
107Rearranged KO/Pi file menu structure. 110Rearranged KO/Pi file menu structure.
108 111
109OM/Pi: 112OM/Pi:
110Added to the SMTP account setting the option 113Added to the SMTP account setting the option
111"No secure connection". 114"No secure connection".
112You have to configure your SMTP accounts again, sorry. 115You have to configure your SMTP accounts again, sorry.
113 116
114KA/Pi: 117KA/Pi:
115Added support for importing quoted-printable. 118Added support for importing quoted-printable.
116Support was added by Peter P.. Thanks, Peter! 119Support was added by Peter P.. Thanks, Peter!
117 120
118 121
119********** VERSION 2.0.14 ************ 122********** VERSION 2.0.14 ************
120 123
121Made Passwordmanager PwM/Pi more userfriendly: 124Made Passwordmanager PwM/Pi more userfriendly:
122Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more. 125Rearranged some toolbar icons, optimized setting of focus, fixed layout problems and more.
123Fixed bug in KO/Pi todo printing. 126Fixed bug in KO/Pi todo printing.
124Made Qtopia calendar import possible on desktop . 127Made Qtopia calendar import possible on desktop .
125 128
126********** VERSION 2.0.13 ************ 129********** VERSION 2.0.13 ************
127 130
128Fixed a problem in the addressee select dialog and made it more user friendly by adding a minimize splitter. 131Fixed a problem in the addressee select dialog and made it more user friendly by adding a minimize splitter.
129 132
130In the search dialog you can switch now the focus from search line edit to the list view by pressing key "arrow down". 133In the search dialog you can switch now the focus from search line edit to the list view by pressing key "arrow down".
131 134
132OM/Pi: 135OM/Pi:
133Fixed a refresh problem of outgoing/sent/sendfailed folders after sending mails. 136Fixed a refresh problem of outgoing/sent/sendfailed folders after sending mails.
134Added missing German translation. 137Added missing German translation.
135Added warning if path is specified in local folder settings of account config. 138Added warning if path is specified in local folder settings of account config.
136 139
137********** VERSION 2.0.12 ************ 140********** VERSION 2.0.12 ************
138 141
139KO/Pi: 142KO/Pi:
140Fixed a bug in todo start/due date handling for non recurring todos with a start and due date. 143Fixed a bug in todo start/due date handling for non recurring todos with a start and due date.
141Fixed some layout problems in the KO/Pi agenda view when there were many conflicting itmes. 144Fixed some layout problems in the KO/Pi agenda view when there were many conflicting itmes.
142Fixed several problems of the keyboard focus in the desktop versions when opening the search dialog/event viewer. 145Fixed several problems of the keyboard focus in the desktop versions when opening the search dialog/event viewer.
143 146
144Fixed problem in pi-sync mode when wrong password was sent. 147Fixed problem in pi-sync mode when wrong password was sent.
145 148
146OM/Pi: 149OM/Pi:
147Fixed a crash when displaying mails with "Show mail as html" was checked in the config. 150Fixed a crash when displaying mails with "Show mail as html" was checked in the config.
148Added a check before displaying the mail if the mail is in html format, if "Show mail as html" is enabled. 151Added a check before displaying the mail if the mail is in html format, if "Show mail as html" is enabled.
149 152
150********** VERSION 2.0.11 ************ 153********** VERSION 2.0.11 ************
151 154
152Fixed some problems in pi-sync mode 155Fixed some problems in pi-sync mode
153(e.g. details of events were not synced properly) 156(e.g. details of events were not synced properly)
154 157
155********** VERSION 2.0.10 ************ 158********** VERSION 2.0.10 ************
156 159
157KO/Pi: 160KO/Pi:
158In the desktop versions the context menu in the search dialog was broken after introducing the What'sThis info for the list view. 161In the desktop versions the context menu in the search dialog was broken after introducing the What'sThis info for the list view.
159This is fixed. 162This is fixed.
160Changed the search dialog a bit to make it more user friendly. 163Changed the search dialog a bit to make it more user friendly.
161(E.g.: Removed message box about "no items found" and set key focus to search line edit after search). 164(E.g.: Removed message box about "no items found" and set key focus to search line edit after search).
162 165
163Added config option to hide the week number in KO/Pi toolbar. 166Added config option to hide the week number in KO/Pi toolbar.
164 167
165********** VERSION 2.0.9 ************ 168********** VERSION 2.0.9 ************
166 169
167Made month view icons for multiday events a bit nicer. 170Made month view icons for multiday events a bit nicer.
168Some minor fixes in KO/Pi 171Some minor fixes in KO/Pi
169(e.g. go to today did not work for new week view properly). 172(e.g. go to today did not work for new week view properly).
170 173
171 174
172********** VERSION 2.0.8 ************ 175********** VERSION 2.0.8 ************
173 176
174Fixed a problem in dependency info in the ipk files for the Zaurus. 177Fixed a problem in dependency info in the ipk files for the Zaurus.
175 178
176Added icon for the stealth new week view and made navigation more user friendly in monthview by adding a prev/next week button to the navigator bar. 179Added icon for the stealth new week view and made navigation more user friendly in monthview by adding a prev/next week button to the navigator bar.
177 180
178Added a "go today" button to the datepicker. 181Added a "go today" button to the datepicker.
179 182
180Added "created" and "last modified" to event/todo viewer (and What'sThis viewer) 183Added "created" and "last modified" to event/todo viewer (and What'sThis viewer)
181and made it configureable to show these values. 184and made it configureable to show these values.
182 185
183Fixed a problem for events (from external iCal files) that do have a duration but no end date. 186Fixed a problem for events (from external iCal files) that do have a duration but no end date.
184 187
185 188
186********** VERSION 2.0.7 ************ 189********** VERSION 2.0.7 ************
187 190
188Added global application font settings 191Added global application font settings
189(for all KDE-Pim/Pi apps) to the general settings. 192(for all KDE-Pim/Pi apps) to the general settings.
190 193
191Fixed a problem in OM/Pi when trying to login to some IMAP servers 194Fixed a problem in OM/Pi when trying to login to some IMAP servers
192(like the IMAP server of Apple: mail.mac.com ) 195(like the IMAP server of Apple: mail.mac.com )
193 196
194Added recurring todos to KO/Pi. 197Added recurring todos to KO/Pi.
195 198
196 199
197********** VERSION 2.0.6 ************ 200********** VERSION 2.0.6 ************
198 201
199Stable release 2.0.6! 202Stable release 2.0.6!
200 203
201Some bugfixes in the pi-sync mode. 204Some bugfixes in the pi-sync mode.
202Added German translation for pi-sync mode. 205Added German translation for pi-sync mode.
203 206
204KO/Pi: 207KO/Pi:
205Made the todolist using alternate background. 208Made the todolist using alternate background.
206 209
207Other minor fixes in KO/Pi. 210Other minor fixes in KO/Pi.
208 211
209 212
210You can find the complete changelog 213You can find the complete changelog
211from version 1.7.7 to 2.0.5 214from version 1.7.7 to 2.0.5
212in the source package or on 215in the source package or on
213 216
214http://www.pi-sync.net/html/changelog.html 217http://www.pi-sync.net/html/changelog.html
215 218
216 219
217 220
diff --git a/kaddressbook/kabcore.cpp b/kaddressbook/kabcore.cpp
index db19dd5..27aca2d 100644
--- a/kaddressbook/kabcore.cpp
+++ b/kaddressbook/kabcore.cpp
@@ -1748,1536 +1748,1537 @@ void KABCore::initGUI()
1748 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 1748 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
1749 SLOT( incrementalSearch( const QString& ) ) ); 1749 SLOT( incrementalSearch( const QString& ) ) );
1750 1750
1751 mViewManager = new ViewManager( this, viewSpace ); 1751 mViewManager = new ViewManager( this, viewSpace );
1752 viewSpace->setStretchFactor( mViewManager, 1 ); 1752 viewSpace->setStretchFactor( mViewManager, 1 );
1753 1753
1754 mDetails = new ViewContainer( mDetailsSplitter ); 1754 mDetails = new ViewContainer( mDetailsSplitter );
1755 1755
1756 mJumpButtonBar = new JumpButtonBar( this, this ); 1756 mJumpButtonBar = new JumpButtonBar( this, this );
1757 1757
1758 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); 1758 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter );
1759 1759
1760 topLayout->addWidget( mExtensionBarSplitter ); 1760 topLayout->addWidget( mExtensionBarSplitter );
1761 topLayout->setStretchFactor( mExtensionBarSplitter, 100 ); 1761 topLayout->setStretchFactor( mExtensionBarSplitter, 100 );
1762 topLayout->addWidget( mJumpButtonBar ); 1762 topLayout->addWidget( mJumpButtonBar );
1763 //topLayout->setStretchFactor( mJumpButtonBar, 1 ); 1763 //topLayout->setStretchFactor( mJumpButtonBar, 1 );
1764 1764
1765 mXXPortManager = new XXPortManager( this, this ); 1765 mXXPortManager = new XXPortManager( this, this );
1766 1766
1767#else //KAB_EMBEDDED 1767#else //KAB_EMBEDDED
1768 //US initialize viewMenu before settingup viewmanager. 1768 //US initialize viewMenu before settingup viewmanager.
1769 // Viewmanager needs this menu to plugin submenues. 1769 // Viewmanager needs this menu to plugin submenues.
1770 viewMenu = new QPopupMenu( this ); 1770 viewMenu = new QPopupMenu( this );
1771 settingsMenu = new QPopupMenu( this ); 1771 settingsMenu = new QPopupMenu( this );
1772 //filterMenu = new QPopupMenu( this ); 1772 //filterMenu = new QPopupMenu( this );
1773 ImportMenu = new QPopupMenu( this ); 1773 ImportMenu = new QPopupMenu( this );
1774 ExportMenu = new QPopupMenu( this ); 1774 ExportMenu = new QPopupMenu( this );
1775 syncMenu = new QPopupMenu( this ); 1775 syncMenu = new QPopupMenu( this );
1776 changeMenu= new QPopupMenu( this ); 1776 changeMenu= new QPopupMenu( this );
1777 beamMenu= new QPopupMenu( this ); 1777 beamMenu= new QPopupMenu( this );
1778 1778
1779//US since we have no splitter for the embedded system, setup 1779//US since we have no splitter for the embedded system, setup
1780// a layout with two frames. One left and one right. 1780// a layout with two frames. One left and one right.
1781 1781
1782 QBoxLayout *topLayout; 1782 QBoxLayout *topLayout;
1783 1783
1784 // = new QHBoxLayout( this ); 1784 // = new QHBoxLayout( this );
1785// QBoxLayout *topLayout = (QBoxLayout*)layout(); 1785// QBoxLayout *topLayout = (QBoxLayout*)layout();
1786 1786
1787// QWidget *mainBox = new QWidget( this ); 1787// QWidget *mainBox = new QWidget( this );
1788// QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox); 1788// QBoxLayout * mainBoxLayout = new QHBoxLayout(mainBox);
1789 1789
1790#ifdef DESKTOP_VERSION 1790#ifdef DESKTOP_VERSION
1791 topLayout = new QHBoxLayout( this ); 1791 topLayout = new QHBoxLayout( this );
1792 1792
1793 1793
1794 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); 1794 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this);
1795 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); 1795 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right );
1796 1796
1797 topLayout->addWidget(mMiniSplitter ); 1797 topLayout->addWidget(mMiniSplitter );
1798 1798
1799 mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter ); 1799 mExtensionBarSplitter = new KDGanttMinimizeSplitter( Qt::Vertical,mMiniSplitter );
1800 mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); 1800 mExtensionBarSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down );
1801 mViewManager = new ViewManager( this, mExtensionBarSplitter ); 1801 mViewManager = new ViewManager( this, mExtensionBarSplitter );
1802 mDetails = new ViewContainer( mMiniSplitter ); 1802 mDetails = new ViewContainer( mMiniSplitter );
1803 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter ); 1803 mExtensionManager = new ExtensionManager( this, mExtensionBarSplitter );
1804#else 1804#else
1805 if ( QApplication::desktop()->width() > 480 ) { 1805 if ( QApplication::desktop()->width() > 480 ) {
1806 topLayout = new QHBoxLayout( this ); 1806 topLayout = new QHBoxLayout( this );
1807 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this); 1807 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Horizontal, this);
1808 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right ); 1808 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Right );
1809 } else { 1809 } else {
1810 1810
1811 topLayout = new QHBoxLayout( this ); 1811 topLayout = new QHBoxLayout( this );
1812 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this); 1812 mMiniSplitter = new KDGanttMinimizeSplitter( Qt::Vertical, this);
1813 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down ); 1813 mMiniSplitter->setMinimizeDirection ( KDGanttMinimizeSplitter::Down );
1814 } 1814 }
1815 1815
1816 topLayout->addWidget(mMiniSplitter ); 1816 topLayout->addWidget(mMiniSplitter );
1817 mViewManager = new ViewManager( this, mMiniSplitter ); 1817 mViewManager = new ViewManager( this, mMiniSplitter );
1818 mDetails = new ViewContainer( mMiniSplitter ); 1818 mDetails = new ViewContainer( mMiniSplitter );
1819 1819
1820 1820
1821 mExtensionManager = new ExtensionManager( this, mMiniSplitter ); 1821 mExtensionManager = new ExtensionManager( this, mMiniSplitter );
1822#endif 1822#endif
1823 //eh->hide(); 1823 //eh->hide();
1824 // topLayout->addWidget(mExtensionManager ); 1824 // topLayout->addWidget(mExtensionManager );
1825 1825
1826 1826
1827/*US 1827/*US
1828#ifndef KAB_NOSPLITTER 1828#ifndef KAB_NOSPLITTER
1829 QHBoxLayout *topLayout = new QHBoxLayout( this ); 1829 QHBoxLayout *topLayout = new QHBoxLayout( this );
1830//US topLayout->setSpacing( KDialogBase::spacingHint() ); 1830//US topLayout->setSpacing( KDialogBase::spacingHint() );
1831 topLayout->setSpacing( 10 ); 1831 topLayout->setSpacing( 10 );
1832 1832
1833 mDetailsSplitter = new QSplitter( this ); 1833 mDetailsSplitter = new QSplitter( this );
1834 1834
1835 QVBox *viewSpace = new QVBox( mDetailsSplitter ); 1835 QVBox *viewSpace = new QVBox( mDetailsSplitter );
1836 1836
1837 mViewManager = new ViewManager( this, viewSpace ); 1837 mViewManager = new ViewManager( this, viewSpace );
1838 viewSpace->setStretchFactor( mViewManager, 1 ); 1838 viewSpace->setStretchFactor( mViewManager, 1 );
1839 1839
1840 mDetails = new ViewContainer( mDetailsSplitter ); 1840 mDetails = new ViewContainer( mDetailsSplitter );
1841 1841
1842 topLayout->addWidget( mDetailsSplitter ); 1842 topLayout->addWidget( mDetailsSplitter );
1843 topLayout->setStretchFactor( mDetailsSplitter, 100 ); 1843 topLayout->setStretchFactor( mDetailsSplitter, 100 );
1844#else //KAB_NOSPLITTER 1844#else //KAB_NOSPLITTER
1845 QHBoxLayout *topLayout = new QHBoxLayout( this ); 1845 QHBoxLayout *topLayout = new QHBoxLayout( this );
1846//US topLayout->setSpacing( KDialogBase::spacingHint() ); 1846//US topLayout->setSpacing( KDialogBase::spacingHint() );
1847 topLayout->setSpacing( 10 ); 1847 topLayout->setSpacing( 10 );
1848 1848
1849// mDetailsSplitter = new QSplitter( this ); 1849// mDetailsSplitter = new QSplitter( this );
1850 1850
1851 QVBox *viewSpace = new QVBox( this ); 1851 QVBox *viewSpace = new QVBox( this );
1852 1852
1853 mViewManager = new ViewManager( this, viewSpace ); 1853 mViewManager = new ViewManager( this, viewSpace );
1854 viewSpace->setStretchFactor( mViewManager, 1 ); 1854 viewSpace->setStretchFactor( mViewManager, 1 );
1855 1855
1856 mDetails = new ViewContainer( this ); 1856 mDetails = new ViewContainer( this );
1857 1857
1858 topLayout->addWidget( viewSpace ); 1858 topLayout->addWidget( viewSpace );
1859// topLayout->setStretchFactor( mDetailsSplitter, 100 ); 1859// topLayout->setStretchFactor( mDetailsSplitter, 100 );
1860 topLayout->addWidget( mDetails ); 1860 topLayout->addWidget( mDetails );
1861#endif //KAB_NOSPLITTER 1861#endif //KAB_NOSPLITTER
1862*/ 1862*/
1863 1863
1864 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu); 1864 syncManager = new KSyncManager((QWidget*)this, (KSyncInterface*)this, KSyncManager::KAPI, KABPrefs::instance(), syncMenu);
1865 syncManager->setBlockSave(false); 1865 syncManager->setBlockSave(false);
1866 1866
1867 connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); 1867 connect(syncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) );
1868 connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); 1868 connect(syncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) );
1869 QString sync_file = sentSyncFile(); 1869 QString sync_file = sentSyncFile();
1870 //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1()); 1870 //qDebug("KABCore::initGUI()::setting tmp sync file to:%s ",sync_file.latin1());
1871 syncManager->setDefaultFileName( sync_file ); 1871 syncManager->setDefaultFileName( sync_file );
1872 //connect(syncManager , SIGNAL( ), this, SLOT( ) ); 1872 //connect(syncManager , SIGNAL( ), this, SLOT( ) );
1873 1873
1874#endif //KAB_EMBEDDED 1874#endif //KAB_EMBEDDED
1875 initActions(); 1875 initActions();
1876 1876
1877#ifdef KAB_EMBEDDED 1877#ifdef KAB_EMBEDDED
1878 addActionsManually(); 1878 addActionsManually();
1879 //US make sure the export and import menues are initialized before creating the xxPortManager. 1879 //US make sure the export and import menues are initialized before creating the xxPortManager.
1880 mXXPortManager = new XXPortManager( this, this ); 1880 mXXPortManager = new XXPortManager( this, this );
1881 1881
1882 // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() ); 1882 // LR mIncSearchWidget = new IncSearchWidget( mMainWindow->getIconToolBar() );
1883 //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget); 1883 //mMainWindow->toolBar()->insertWidget(-1, 4, mIncSearchWidget);
1884 // mActionQuit->plug ( mMainWindow->toolBar()); 1884 // mActionQuit->plug ( mMainWindow->toolBar());
1885 //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() ); 1885 //mIncSearchWidget = new IncSearchWidget( mMainWindow->toolBar() );
1886 //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget); 1886 //mMainWindow->toolBar()->insertWidget(-1, 0, mIncSearchWidget);
1887 // mIncSearchWidget->hide(); 1887 // mIncSearchWidget->hide();
1888 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 1888 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
1889 SLOT( incrementalSearch( const QString& ) ) ); 1889 SLOT( incrementalSearch( const QString& ) ) );
1890 connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) ); 1890 connect( mIncSearchWidget, SIGNAL( scrollUP() ),mViewManager, SLOT( scrollUP() ) );
1891 connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) ); 1891 connect( mIncSearchWidget, SIGNAL( scrollDOWN() ),mViewManager, SLOT( scrollDOWN() ) );
1892 1892
1893 mJumpButtonBar = new JumpButtonBar( this, this ); 1893 mJumpButtonBar = new JumpButtonBar( this, this );
1894 1894
1895 topLayout->addWidget( mJumpButtonBar ); 1895 topLayout->addWidget( mJumpButtonBar );
1896//US topLayout->setStretchFactor( mJumpButtonBar, 10 ); 1896//US topLayout->setStretchFactor( mJumpButtonBar, 10 );
1897 1897
1898// mMainWindow->getIconToolBar()->raise(); 1898// mMainWindow->getIconToolBar()->raise();
1899 1899
1900#endif //KAB_EMBEDDED 1900#endif //KAB_EMBEDDED
1901 1901
1902} 1902}
1903void KABCore::initActions() 1903void KABCore::initActions()
1904{ 1904{
1905//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 1905//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
1906 1906
1907#ifndef KAB_EMBEDDED 1907#ifndef KAB_EMBEDDED
1908 connect( QApplication::clipboard(), SIGNAL( dataChanged() ), 1908 connect( QApplication::clipboard(), SIGNAL( dataChanged() ),
1909 SLOT( clipboardDataChanged() ) ); 1909 SLOT( clipboardDataChanged() ) );
1910#endif //KAB_EMBEDDED 1910#endif //KAB_EMBEDDED
1911 1911
1912 // file menu 1912 // file menu
1913 1913
1914 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() ); 1914 mActionMail = KStdAction::mail( this, SLOT( sendMail() ), actionCollection() );
1915 //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() ); 1915 //mActionPrint = KStdAction::print( this, SLOT( print() ), actionCollection() );
1916 mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager, 1916 mActionPrint = new KAction( i18n( "&Print View" ), "fileprint", CTRL + Key_P, mViewManager,
1917 SLOT( printView() ), actionCollection(), "kaddressbook_print" ); 1917 SLOT( printView() ), actionCollection(), "kaddressbook_print" );
1918 1918
1919 1919
1920 mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails, 1920 mActionPrintDetails = new KAction( i18n( "&Print Details" ), "fileprint", 0, mDetails,
1921 SLOT( printView() ), actionCollection(), "kaddressbook_print2" ); 1921 SLOT( printView() ), actionCollection(), "kaddressbook_print2" );
1922 1922
1923 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this, 1923 mActionSave = new KAction( i18n( "&Save" ), "filesave", CTRL+Key_S, this,
1924 SLOT( save() ), actionCollection(), "file_sync" ); 1924 SLOT( save() ), actionCollection(), "file_sync" );
1925 1925
1926 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this, 1926 mActionNewContact = new KAction( i18n( "&New Contact..." ), "filenew", CTRL+Key_N, this,
1927 SLOT( newContact() ), actionCollection(), "file_new_contact" ); 1927 SLOT( newContact() ), actionCollection(), "file_new_contact" );
1928 1928
1929 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0, 1929 mActionMailVCard = new KAction(i18n("Mail &vCard..."), "mail_post_to", 0,
1930 this, SLOT( mailVCard() ), 1930 this, SLOT( mailVCard() ),
1931 actionCollection(), "file_mail_vcard"); 1931 actionCollection(), "file_mail_vcard");
1932 1932
1933 mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this, 1933 mActionExport2phone = new KAction( i18n( "Export to phone" ), "ex2phone", 0, this,
1934 SLOT( export2phone() ), actionCollection(), 1934 SLOT( export2phone() ), actionCollection(),
1935 "kaddressbook_ex2phone" ); 1935 "kaddressbook_ex2phone" );
1936 1936
1937 mActionBeamVCard = 0; 1937 mActionBeamVCard = 0;
1938 mActionBeam = 0; 1938 mActionBeam = 0;
1939 1939
1940#ifndef DESKTOP_VERSION 1940#ifndef DESKTOP_VERSION
1941 if ( Ir::supported() ) { 1941 if ( Ir::supported() ) {
1942 mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this, 1942 mActionBeamVCard = new KAction( i18n( "Beam v&Card(s)..." ), "beam", 0, this,
1943 SLOT( beamVCard() ), actionCollection(), 1943 SLOT( beamVCard() ), actionCollection(),
1944 "kaddressbook_beam_vcard" ); 1944 "kaddressbook_beam_vcard" );
1945 1945
1946 mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this, 1946 mActionBeam = new KAction( i18n( "&Beam personal vCard" ), "beam", 0, this,
1947 SLOT( beamMySelf() ), actionCollection(), 1947 SLOT( beamMySelf() ), actionCollection(),
1948 "kaddressbook_beam_myself" ); 1948 "kaddressbook_beam_myself" );
1949 } 1949 }
1950#endif 1950#endif
1951 1951
1952 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0, 1952 mActionEditAddressee = new KAction( i18n( "&Edit Contact..." ), "edit", 0,
1953 this, SLOT( editContact2() ), 1953 this, SLOT( editContact2() ),
1954 actionCollection(), "file_properties" ); 1954 actionCollection(), "file_properties" );
1955 1955
1956#ifdef KAB_EMBEDDED 1956#ifdef KAB_EMBEDDED
1957 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() ); 1957 // mActionQuit = KStdAction::quit( mMainWindow, SLOT( exit() ), actionCollection() );
1958 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0, 1958 mActionQuit = new KAction( i18n( "&Exit" ), "exit", 0,
1959 mMainWindow, SLOT( exit() ), 1959 mMainWindow, SLOT( exit() ),
1960 actionCollection(), "quit" ); 1960 actionCollection(), "quit" );
1961#endif //KAB_EMBEDDED 1961#endif //KAB_EMBEDDED
1962 1962
1963 // edit menu 1963 // edit menu
1964 if ( mIsPart ) { 1964 if ( mIsPart ) {
1965 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this, 1965 mActionCopy = new KAction( i18n( "&Copy" ), "editcopy", CTRL + Key_C, this,
1966 SLOT( copyContacts() ), actionCollection(), 1966 SLOT( copyContacts() ), actionCollection(),
1967 "kaddressbook_copy" ); 1967 "kaddressbook_copy" );
1968 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this, 1968 mActionCut = new KAction( i18n( "Cu&t" ), "editcut", CTRL + Key_X, this,
1969 SLOT( cutContacts() ), actionCollection(), 1969 SLOT( cutContacts() ), actionCollection(),
1970 "kaddressbook_cut" ); 1970 "kaddressbook_cut" );
1971 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this, 1971 mActionPaste = new KAction( i18n( "&Paste" ), "editpaste", CTRL + Key_V, this,
1972 SLOT( pasteContacts() ), actionCollection(), 1972 SLOT( pasteContacts() ), actionCollection(),
1973 "kaddressbook_paste" ); 1973 "kaddressbook_paste" );
1974 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this, 1974 mActionSelectAll = new KAction( i18n( "Select &All" ), CTRL + Key_A, this,
1975 SLOT( selectAllContacts() ), actionCollection(), 1975 SLOT( selectAllContacts() ), actionCollection(),
1976 "kaddressbook_select_all" ); 1976 "kaddressbook_select_all" );
1977 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this, 1977 mActionUndo = new KAction( i18n( "&Undo" ), "undo", CTRL + Key_Z, this,
1978 SLOT( undo() ), actionCollection(), 1978 SLOT( undo() ), actionCollection(),
1979 "kaddressbook_undo" ); 1979 "kaddressbook_undo" );
1980 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z, 1980 mActionRedo = new KAction( i18n( "Re&do" ), "redo", CTRL + SHIFT + Key_Z,
1981 this, SLOT( redo() ), actionCollection(), 1981 this, SLOT( redo() ), actionCollection(),
1982 "kaddressbook_redo" ); 1982 "kaddressbook_redo" );
1983 } else { 1983 } else {
1984 mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() ); 1984 mActionCopy = KStdAction::copy( this, SLOT( copyContacts() ), actionCollection() );
1985 mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() ); 1985 mActionCut = KStdAction::cut( this, SLOT( cutContacts() ), actionCollection() );
1986 mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() ); 1986 mActionPaste = KStdAction::paste( this, SLOT( pasteContacts() ), actionCollection() );
1987 mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() ); 1987 mActionSelectAll = KStdAction::selectAll( this, SLOT( selectAllContacts() ), actionCollection() );
1988 mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() ); 1988 mActionUndo = KStdAction::undo( this, SLOT( undo() ), actionCollection() );
1989 mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() ); 1989 mActionRedo = KStdAction::redo( this, SLOT( redo() ), actionCollection() );
1990 } 1990 }
1991 1991
1992 mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete", 1992 mActionDelete = new KAction( i18n( "&Delete Contact" ), "editdelete",
1993 Key_Delete, this, SLOT( deleteContacts() ), 1993 Key_Delete, this, SLOT( deleteContacts() ),
1994 actionCollection(), "edit_delete" ); 1994 actionCollection(), "edit_delete" );
1995 1995
1996 mActionUndo->setEnabled( false ); 1996 mActionUndo->setEnabled( false );
1997 mActionRedo->setEnabled( false ); 1997 mActionRedo->setEnabled( false );
1998 1998
1999 // settings menu 1999 // settings menu
2000#ifdef KAB_EMBEDDED 2000#ifdef KAB_EMBEDDED
2001//US special menuentry to configure the addressbook resources. On KDE 2001//US special menuentry to configure the addressbook resources. On KDE
2002// you do that through the control center !!! 2002// you do that through the control center !!!
2003 mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this, 2003 mActionConfigResources = new KAction( i18n( "Configure &Resources..." ), "configure_resources", 0, this,
2004 SLOT( configureResources() ), actionCollection(), 2004 SLOT( configureResources() ), actionCollection(),
2005 "kaddressbook_configure_resources" ); 2005 "kaddressbook_configure_resources" );
2006#endif //KAB_EMBEDDED 2006#endif //KAB_EMBEDDED
2007 2007
2008 if ( mIsPart ) { 2008 if ( mIsPart ) {
2009 mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this, 2009 mActionConfigKAddressbook = new KAction( i18n( "&Configure KAddressBook..." ), "configure", 0, this,
2010 SLOT( openConfigDialog() ), actionCollection(), 2010 SLOT( openConfigDialog() ), actionCollection(),
2011 "kaddressbook_configure" ); 2011 "kaddressbook_configure" );
2012 2012
2013 //US not implemented yet 2013 //US not implemented yet
2014 //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0, 2014 //mActionConfigShortcuts = new KAction( i18n( "Configure S&hortcuts..." ), "configure_shortcuts", 0,
2015 // this, SLOT( configureKeyBindings() ), actionCollection(), 2015 // this, SLOT( configureKeyBindings() ), actionCollection(),
2016 // "kaddressbook_configure_shortcuts" ); 2016 // "kaddressbook_configure_shortcuts" );
2017#ifdef KAB_EMBEDDED 2017#ifdef KAB_EMBEDDED
2018 mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() ); 2018 mActionConfigureToolbars = KStdAction::configureToolbars( this, SLOT( mMainWindow->configureToolbars() ), actionCollection() );
2019 mActionConfigureToolbars->setEnabled( false ); 2019 mActionConfigureToolbars->setEnabled( false );
2020#endif //KAB_EMBEDDED 2020#endif //KAB_EMBEDDED
2021 2021
2022 } else { 2022 } else {
2023 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() ); 2023 mActionConfigKAddressbook = KStdAction::preferences( this, SLOT( openConfigDialog() ), actionCollection() );
2024 2024
2025 //US not implemented yet 2025 //US not implemented yet
2026 //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() ); 2026 //mActionKeyBindings = KStdAction::keyBindings( this, SLOT( configureKeyBindings() ), actionCollection() );
2027 } 2027 }
2028 2028
2029 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0, 2029 mActionJumpBar = new KToggleAction( i18n( "Show Jump Bar" ), 0, 0,
2030 actionCollection(), "options_show_jump_bar" ); 2030 actionCollection(), "options_show_jump_bar" );
2031 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) ); 2031 connect( mActionJumpBar, SIGNAL( toggled( bool ) ), SLOT( setJumpButtonBar( bool ) ) );
2032 2032
2033 mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0, 2033 mActionDetails = new KToggleAction( i18n( "Show Details" ), "listview", 0,
2034 actionCollection(), "options_show_details" ); 2034 actionCollection(), "options_show_details" );
2035 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) ); 2035 connect( mActionDetails, SIGNAL( toggled( bool ) ), SLOT( setDetailsVisible( bool ) ) );
2036 2036
2037 2037
2038 mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this, 2038 mActionBR = new KToggleAction( i18n( "Beam receive enabled" ), "beam", 0, this,
2039 SLOT( toggleBeamReceive() ), actionCollection(), 2039 SLOT( toggleBeamReceive() ), actionCollection(),
2040 "kaddressbook_beam_rec" ); 2040 "kaddressbook_beam_rec" );
2041 2041
2042 2042
2043 // misc 2043 // misc
2044 // only enable LDAP lookup if we can handle the protocol 2044 // only enable LDAP lookup if we can handle the protocol
2045#ifndef KAB_EMBEDDED 2045#ifndef KAB_EMBEDDED
2046 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) { 2046 if ( KProtocolInfo::isKnownProtocol( KURL( "ldap://localhost" ) ) ) {
2047 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0, 2047 new KAction( i18n( "&Lookup Addresses in Directory" ), "find", 0,
2048 this, SLOT( openLDAPDialog() ), actionCollection(), 2048 this, SLOT( openLDAPDialog() ), actionCollection(),
2049 "ldap_lookup" ); 2049 "ldap_lookup" );
2050 } 2050 }
2051#else //KAB_EMBEDDED 2051#else //KAB_EMBEDDED
2052 //qDebug("KABCore::initActions() LDAP has to be implemented"); 2052 //qDebug("KABCore::initActions() LDAP has to be implemented");
2053#endif //KAB_EMBEDDED 2053#endif //KAB_EMBEDDED
2054 2054
2055 2055
2056 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this, 2056 mActionWhoAmI = new KAction( i18n( "Set Who Am I" ), "personal", 0, this,
2057 SLOT( setWhoAmI() ), actionCollection(), 2057 SLOT( setWhoAmI() ), actionCollection(),
2058 "set_personal" ); 2058 "set_personal" );
2059 2059
2060 2060
2061 mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this, 2061 mActionCategories = new KAction( i18n( "Set Categories for Contacts..." ), 0, this,
2062 SLOT( setCategories() ), actionCollection(), 2062 SLOT( setCategories() ), actionCollection(),
2063 "edit_set_categories" ); 2063 "edit_set_categories" );
2064 mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this, 2064 mActionEditCategories = new KAction( i18n( "Edit Category List..." ), 0, this,
2065 SLOT( editCategories() ), actionCollection(), 2065 SLOT( editCategories() ), actionCollection(),
2066 "edit__categories" ); 2066 "edit__categories" );
2067 2067
2068 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this, 2068 mActionRemoveVoice = new KAction( i18n( "Remove \"voice\"..." ), 0, this,
2069 SLOT( removeVoice() ), actionCollection(), 2069 SLOT( removeVoice() ), actionCollection(),
2070 "remove_voice" ); 2070 "remove_voice" );
2071 mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this, 2071 mActionSetFormattedName = new KAction( i18n( "Set formatted name..." ), 0, this,
2072 SLOT( setFormattedName() ), actionCollection(), 2072 SLOT( setFormattedName() ), actionCollection(),
2073 "set_formatted" ); 2073 "set_formatted" );
2074 2074
2075 mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this, 2075 mActionManageCategories= new KAction( i18n( "Manage new categories..." ), 0, this,
2076 SLOT( manageCategories() ), actionCollection(), 2076 SLOT( manageCategories() ), actionCollection(),
2077 "remove_voice" ); 2077 "remove_voice" );
2078 2078
2079 2079
2080 mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this, 2080 mActionImportOL = new KAction( i18n( "Import from Outlook..." ), 0, this,
2081 SLOT( importFromOL() ), actionCollection(), 2081 SLOT( importFromOL() ), actionCollection(),
2082 "import_OL" ); 2082 "import_OL" );
2083#ifdef KAB_EMBEDDED 2083#ifdef KAB_EMBEDDED
2084 mActionLicence = new KAction( i18n( "Licence" ), 0, 2084 mActionLicence = new KAction( i18n( "Licence" ), 0,
2085 this, SLOT( showLicence() ), actionCollection(), 2085 this, SLOT( showLicence() ), actionCollection(),
2086 "licence_about_data" ); 2086 "licence_about_data" );
2087 mActionFaq = new KAction( i18n( "Faq" ), 0, 2087 mActionFaq = new KAction( i18n( "Faq" ), 0,
2088 this, SLOT( faq() ), actionCollection(), 2088 this, SLOT( faq() ), actionCollection(),
2089 "faq_about_data" ); 2089 "faq_about_data" );
2090 mActionWN = new KAction( i18n( "What's New?" ), 0, 2090 mActionWN = new KAction( i18n( "What's New?" ), 0,
2091 this, SLOT( whatsnew() ), actionCollection(), 2091 this, SLOT( whatsnew() ), actionCollection(),
2092 "wn" ); 2092 "wn" );
2093 mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0, 2093 mActionSyncHowto = new KAction( i18n( "Sync HowTo" ), 0,
2094 this, SLOT( synchowto() ), actionCollection(), 2094 this, SLOT( synchowto() ), actionCollection(),
2095 "sync" ); 2095 "sync" );
2096 mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0, 2096 mActionKdeSyncHowto = new KAction( i18n( "Kde Sync HowTo" ), 0,
2097 this, SLOT( kdesynchowto() ), actionCollection(), 2097 this, SLOT( kdesynchowto() ), actionCollection(),
2098 "kdesync" ); 2098 "kdesync" );
2099 mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0, 2099 mActionMultiSyncHowto = new KAction( i18n( "Multi Sync HowTo" ), 0,
2100 this, SLOT( multisynchowto() ), actionCollection(), 2100 this, SLOT( multisynchowto() ), actionCollection(),
2101 "multisync" ); 2101 "multisync" );
2102 2102
2103 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0, 2103 mActionAboutKAddressbook = new KAction( i18n( "&About KAddressBook" ), "kaddressbook2", 0,
2104 this, SLOT( createAboutData() ), actionCollection(), 2104 this, SLOT( createAboutData() ), actionCollection(),
2105 "kaddressbook_about_data" ); 2105 "kaddressbook_about_data" );
2106#endif //KAB_EMBEDDED 2106#endif //KAB_EMBEDDED
2107 2107
2108 clipboardDataChanged(); 2108 clipboardDataChanged();
2109 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 2109 connect( UndoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
2110 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) ); 2110 connect( RedoStack::instance(), SIGNAL( changed() ), SLOT( updateActionMenu() ) );
2111} 2111}
2112 2112
2113//US we need this function, to plug all actions into the correct menues. 2113//US we need this function, to plug all actions into the correct menues.
2114// KDE uses a XML format to plug the actions, but we work her without this overhead. 2114// KDE uses a XML format to plug the actions, but we work her without this overhead.
2115void KABCore::addActionsManually() 2115void KABCore::addActionsManually()
2116{ 2116{
2117//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart); 2117//US qDebug("KABCore::initActions(): mIsPart %i", mIsPart);
2118 2118
2119#ifdef KAB_EMBEDDED 2119#ifdef KAB_EMBEDDED
2120 QPopupMenu *fileMenu = new QPopupMenu( this ); 2120 QPopupMenu *fileMenu = new QPopupMenu( this );
2121 QPopupMenu *editMenu = new QPopupMenu( this ); 2121 QPopupMenu *editMenu = new QPopupMenu( this );
2122 QPopupMenu *helpMenu = new QPopupMenu( this ); 2122 QPopupMenu *helpMenu = new QPopupMenu( this );
2123 2123
2124 KToolBar* tb = mMainWindow->toolBar(); 2124 KToolBar* tb = mMainWindow->toolBar();
2125 2125
2126#ifndef DESKTOP_VERSION 2126#ifndef DESKTOP_VERSION
2127 if ( KABPrefs::instance()->mFullMenuBarVisible ) { 2127 if ( KABPrefs::instance()->mFullMenuBarVisible ) {
2128#endif 2128#endif
2129 QMenuBar* mb = mMainWindow->menuBar(); 2129 QMenuBar* mb = mMainWindow->menuBar();
2130 2130
2131 //US setup menubar. 2131 //US setup menubar.
2132 //Disable the following block if you do not want to have a menubar. 2132 //Disable the following block if you do not want to have a menubar.
2133 mb->insertItem( i18n("&File"), fileMenu ); 2133 mb->insertItem( i18n("&File"), fileMenu );
2134 mb->insertItem( i18n("&Edit"), editMenu ); 2134 mb->insertItem( i18n("&Edit"), editMenu );
2135 mb->insertItem( i18n("&View"), viewMenu ); 2135 mb->insertItem( i18n("&View"), viewMenu );
2136 mb->insertItem( i18n("&Settings"), settingsMenu ); 2136 mb->insertItem( i18n("&Settings"), settingsMenu );
2137#ifdef DESKTOP_VERSION 2137#ifdef DESKTOP_VERSION
2138 mb->insertItem( i18n("Synchronize"), syncMenu ); 2138 mb->insertItem( i18n("Synchronize"), syncMenu );
2139#else 2139#else
2140 mb->insertItem( i18n("Sync"), syncMenu ); 2140 mb->insertItem( i18n("Sync"), syncMenu );
2141#endif 2141#endif
2142 //mb->insertItem( i18n("&Change"), changeMenu ); 2142 //mb->insertItem( i18n("&Change"), changeMenu );
2143 mb->insertItem( i18n("&Help"), helpMenu ); 2143 mb->insertItem( i18n("&Help"), helpMenu );
2144 mIncSearchWidget = new IncSearchWidget( tb ); 2144 mIncSearchWidget = new IncSearchWidget( tb );
2145 // tb->insertWidget(-1, 0, mIncSearchWidget); 2145 // tb->insertWidget(-1, 0, mIncSearchWidget);
2146#ifndef DESKTOP_VERSION 2146#ifndef DESKTOP_VERSION
2147 } else { 2147 } else {
2148 //US setup toolbar 2148 //US setup toolbar
2149 QPEMenuBar *menuBarTB = new QPEMenuBar( tb ); 2149 QPEMenuBar *menuBarTB = new QPEMenuBar( tb );
2150 QPopupMenu *popupBarTB = new QPopupMenu( this ); 2150 QPopupMenu *popupBarTB = new QPopupMenu( this );
2151 menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB); 2151 menuBarTB->insertItem( SmallIcon( "z_menu" ) , popupBarTB);
2152 tb->insertWidget(-1, 0, menuBarTB); 2152 tb->insertWidget(-1, 0, menuBarTB);
2153 mIncSearchWidget = new IncSearchWidget( tb ); 2153 mIncSearchWidget = new IncSearchWidget( tb );
2154 tb->enableMoving(false); 2154 tb->enableMoving(false);
2155 popupBarTB->insertItem( i18n("&File"), fileMenu ); 2155 popupBarTB->insertItem( i18n("&File"), fileMenu );
2156 popupBarTB->insertItem( i18n("&Edit"), editMenu ); 2156 popupBarTB->insertItem( i18n("&Edit"), editMenu );
2157 popupBarTB->insertItem( i18n("&View"), viewMenu ); 2157 popupBarTB->insertItem( i18n("&View"), viewMenu );
2158 popupBarTB->insertItem( i18n("&Settings"), settingsMenu ); 2158 popupBarTB->insertItem( i18n("&Settings"), settingsMenu );
2159 popupBarTB->insertItem( i18n("Synchronize"), syncMenu ); 2159 popupBarTB->insertItem( i18n("Synchronize"), syncMenu );
2160 mViewManager->getFilterAction()->plug ( popupBarTB); 2160 mViewManager->getFilterAction()->plug ( popupBarTB);
2161 //popupBarTB->insertItem( i18n("&Change selected"), changeMenu ); 2161 //popupBarTB->insertItem( i18n("&Change selected"), changeMenu );
2162 popupBarTB->insertItem( i18n("&Help"), helpMenu ); 2162 popupBarTB->insertItem( i18n("&Help"), helpMenu );
2163 if (QApplication::desktop()->width() > 320 ) { 2163 if (QApplication::desktop()->width() > 320 ) {
2164 // mViewManager->getFilterAction()->plug ( tb); 2164 // mViewManager->getFilterAction()->plug ( tb);
2165 } 2165 }
2166 } 2166 }
2167#endif 2167#endif
2168 // mActionQuit->plug ( mMainWindow->toolBar()); 2168 // mActionQuit->plug ( mMainWindow->toolBar());
2169 2169
2170 2170
2171 2171
2172 //US Now connect the actions with the menue entries. 2172 //US Now connect the actions with the menue entries.
2173#ifdef DESKTOP_VERSION 2173#ifdef DESKTOP_VERSION
2174 mActionPrint->plug( fileMenu ); 2174 mActionPrint->plug( fileMenu );
2175 mActionPrintDetails->plug( fileMenu ); 2175 mActionPrintDetails->plug( fileMenu );
2176 fileMenu->insertSeparator(); 2176 fileMenu->insertSeparator();
2177#endif 2177#endif
2178 mActionMail->plug( fileMenu ); 2178 mActionMail->plug( fileMenu );
2179 fileMenu->insertSeparator(); 2179 fileMenu->insertSeparator();
2180 2180
2181 mActionNewContact->plug( fileMenu ); 2181 mActionNewContact->plug( fileMenu );
2182 mActionNewContact->plug( tb ); 2182 mActionNewContact->plug( tb );
2183 2183
2184 mActionEditAddressee->plug( fileMenu ); 2184 mActionEditAddressee->plug( fileMenu );
2185 // if ((KGlobal::getDesktopSize() > KGlobal::Small ) || 2185 // if ((KGlobal::getDesktopSize() > KGlobal::Small ) ||
2186 // (!KABPrefs::instance()->mMultipleViewsAtOnce )) 2186 // (!KABPrefs::instance()->mMultipleViewsAtOnce ))
2187 mActionEditAddressee->plug( tb ); 2187 mActionEditAddressee->plug( tb );
2188 2188
2189 fileMenu->insertSeparator(); 2189 fileMenu->insertSeparator();
2190 mActionSave->plug( fileMenu ); 2190 mActionSave->plug( fileMenu );
2191 fileMenu->insertItem( "&Import", ImportMenu ); 2191 fileMenu->insertItem( "&Import", ImportMenu );
2192 fileMenu->insertItem( "&Export", ExportMenu ); 2192 fileMenu->insertItem( "&Export", ExportMenu );
2193 fileMenu->insertItem( i18n("&Change"), changeMenu ); 2193 fileMenu->insertItem( i18n("&Change"), changeMenu );
2194#ifndef DESKTOP_VERSION 2194#ifndef DESKTOP_VERSION
2195 if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu ); 2195 if ( Ir::supported() ) fileMenu->insertItem( i18n("&Beam"), beamMenu );
2196#endif 2196#endif
2197#if 0 2197#if 0
2198 // PENDING fix MailVCard 2198 // PENDING fix MailVCard
2199 fileMenu->insertSeparator(); 2199 fileMenu->insertSeparator();
2200 mActionMailVCard->plug( fileMenu ); 2200 mActionMailVCard->plug( fileMenu );
2201#endif 2201#endif
2202#ifndef DESKTOP_VERSION 2202#ifndef DESKTOP_VERSION
2203 if ( Ir::supported() ) mActionBR->plug( beamMenu ); 2203 if ( Ir::supported() ) mActionBR->plug( beamMenu );
2204 if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu ); 2204 if ( Ir::supported() ) mActionBeamVCard->plug( beamMenu );
2205 if ( Ir::supported() ) mActionBeam->plug( beamMenu ); 2205 if ( Ir::supported() ) mActionBeam->plug( beamMenu );
2206#endif 2206#endif
2207 fileMenu->insertSeparator(); 2207 fileMenu->insertSeparator();
2208 mActionQuit->plug( fileMenu ); 2208 mActionQuit->plug( fileMenu );
2209#ifdef _OL_IMPORT_ 2209#ifdef _OL_IMPORT_
2210 mActionImportOL->plug( ImportMenu ); 2210 mActionImportOL->plug( ImportMenu );
2211#endif 2211#endif
2212 // edit menu 2212 // edit menu
2213 mActionUndo->plug( editMenu ); 2213 mActionUndo->plug( editMenu );
2214 mActionRedo->plug( editMenu ); 2214 mActionRedo->plug( editMenu );
2215 editMenu->insertSeparator(); 2215 editMenu->insertSeparator();
2216 mActionCut->plug( editMenu ); 2216 mActionCut->plug( editMenu );
2217 mActionCopy->plug( editMenu ); 2217 mActionCopy->plug( editMenu );
2218 mActionPaste->plug( editMenu ); 2218 mActionPaste->plug( editMenu );
2219 mActionDelete->plug( editMenu ); 2219 mActionDelete->plug( editMenu );
2220 editMenu->insertSeparator(); 2220 editMenu->insertSeparator();
2221 mActionSelectAll->plug( editMenu ); 2221 mActionSelectAll->plug( editMenu );
2222 2222
2223 mActionSetFormattedName->plug( changeMenu ); 2223 mActionSetFormattedName->plug( changeMenu );
2224 mActionRemoveVoice->plug( changeMenu ); 2224 mActionRemoveVoice->plug( changeMenu );
2225 // settingsmings menu 2225 // settingsmings menu
2226//US special menuentry to configure the addressbook resources. On KDE 2226//US special menuentry to configure the addressbook resources. On KDE
2227// you do that through the control center !!! 2227// you do that through the control center !!!
2228 // settingsMenu->insertSeparator(); 2228 // settingsMenu->insertSeparator();
2229 2229
2230 mActionConfigKAddressbook->plug( settingsMenu, 0 ); 2230 mActionConfigKAddressbook->plug( settingsMenu, 0 );
2231 mActionConfigResources->plug( settingsMenu,1 ); 2231 mActionConfigResources->plug( settingsMenu,1 );
2232 settingsMenu->insertSeparator(2); 2232 settingsMenu->insertSeparator(2);
2233 2233
2234 if ( mIsPart ) { 2234 if ( mIsPart ) {
2235 //US not implemented yet 2235 //US not implemented yet
2236 //mActionConfigShortcuts->plug( settingsMenu ); 2236 //mActionConfigShortcuts->plug( settingsMenu );
2237 //mActionConfigureToolbars->plug( settingsMenu ); 2237 //mActionConfigureToolbars->plug( settingsMenu );
2238 2238
2239 } else { 2239 } else {
2240 //US not implemented yet 2240 //US not implemented yet
2241 //mActionKeyBindings->plug( settingsMenu ); 2241 //mActionKeyBindings->plug( settingsMenu );
2242 } 2242 }
2243 2243
2244 settingsMenu->insertSeparator(); 2244 settingsMenu->insertSeparator();
2245 2245
2246 mActionJumpBar->plug( settingsMenu ); 2246 mActionJumpBar->plug( settingsMenu );
2247 mActionDetails->plug( settingsMenu ); 2247 mActionDetails->plug( settingsMenu );
2248 //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop ) 2248 //if (!KABPrefs::instance()->mMultipleViewsAtOnce || KGlobal::getDesktopSize() == KGlobal::Desktop )
2249 mActionDetails->plug( tb ); 2249 mActionDetails->plug( tb );
2250 settingsMenu->insertSeparator(); 2250 settingsMenu->insertSeparator();
2251#ifndef DESKTOP_VERSION 2251#ifndef DESKTOP_VERSION
2252 if ( Ir::supported() ) mActionBR->plug(settingsMenu ); 2252 if ( Ir::supported() ) mActionBR->plug(settingsMenu );
2253 settingsMenu->insertSeparator(); 2253 settingsMenu->insertSeparator();
2254#endif 2254#endif
2255 2255
2256 mActionWhoAmI->plug( settingsMenu ); 2256 mActionWhoAmI->plug( settingsMenu );
2257 mActionEditCategories->plug( settingsMenu ); 2257 mActionEditCategories->plug( settingsMenu );
2258 mActionEditCategories->plug( changeMenu ); 2258 mActionEditCategories->plug( changeMenu );
2259 mActionCategories->plug( changeMenu ); 2259 mActionCategories->plug( changeMenu );
2260 mActionManageCategories->plug( changeMenu ); 2260 mActionManageCategories->plug( changeMenu );
2261 2261
2262 mActionCategories->plug( settingsMenu ); 2262 mActionCategories->plug( settingsMenu );
2263 mActionManageCategories->plug( settingsMenu ); 2263 mActionManageCategories->plug( settingsMenu );
2264 2264
2265 2265
2266 mActionWN->plug( helpMenu ); 2266 mActionWN->plug( helpMenu );
2267 mActionSyncHowto->plug( helpMenu ); 2267 mActionSyncHowto->plug( helpMenu );
2268 mActionKdeSyncHowto->plug( helpMenu ); 2268 mActionKdeSyncHowto->plug( helpMenu );
2269 mActionMultiSyncHowto->plug( helpMenu ); 2269 mActionMultiSyncHowto->plug( helpMenu );
2270 mActionFaq->plug( helpMenu ); 2270 mActionFaq->plug( helpMenu );
2271 mActionLicence->plug( helpMenu ); 2271 mActionLicence->plug( helpMenu );
2272 mActionAboutKAddressbook->plug( helpMenu ); 2272 mActionAboutKAddressbook->plug( helpMenu );
2273 2273
2274 if (KGlobal::getDesktopSize() > KGlobal::Small ) { 2274 if (KGlobal::getDesktopSize() > KGlobal::Small ) {
2275 2275
2276 mActionSave->plug( tb ); 2276 mActionSave->plug( tb );
2277 mViewManager->getFilterAction()->plug ( tb); 2277 mViewManager->getFilterAction()->plug ( tb);
2278 //LR hide filteraction on started in 480x640 2278 //LR hide filteraction on started in 480x640
2279 if (QApplication::desktop()->width() == 480 ) { 2279 if (QApplication::desktop()->width() == 480 ) {
2280 mViewManager->getFilterAction()->setComboWidth( 0 ); 2280 mViewManager->getFilterAction()->setComboWidth( 0 );
2281 } 2281 }
2282 mActionUndo->plug( tb ); 2282 mActionUndo->plug( tb );
2283 mActionDelete->plug( tb ); 2283 mActionDelete->plug( tb );
2284 mActionRedo->plug( tb ); 2284 mActionRedo->plug( tb );
2285 } else { 2285 } else {
2286 mActionSave->plug( tb ); 2286 mActionSave->plug( tb );
2287 tb->enableMoving(false); 2287 tb->enableMoving(false);
2288 } 2288 }
2289 //mActionQuit->plug ( tb ); 2289 //mActionQuit->plug ( tb );
2290 // tb->insertWidget(-1, 0, mIncSearchWidget, 6); 2290 // tb->insertWidget(-1, 0, mIncSearchWidget, 6);
2291 2291
2292 //US link the searchwidget first to this. 2292 //US link the searchwidget first to this.
2293 // The real linkage to the toolbar happens later. 2293 // The real linkage to the toolbar happens later.
2294//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE); 2294//US mIncSearchWidget->reparent(tb, 0, QPoint(50,0), TRUE);
2295//US tb->insertItem( mIncSearchWidget ); 2295//US tb->insertItem( mIncSearchWidget );
2296/*US 2296/*US
2297 mIncSearchWidget = new IncSearchWidget( tb ); 2297 mIncSearchWidget = new IncSearchWidget( tb );
2298 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ), 2298 connect( mIncSearchWidget, SIGNAL( doSearch( const QString& ) ),
2299 SLOT( incrementalSearch( const QString& ) ) ); 2299 SLOT( incrementalSearch( const QString& ) ) );
2300 2300
2301 mJumpButtonBar = new JumpButtonBar( this, this ); 2301 mJumpButtonBar = new JumpButtonBar( this, this );
2302 2302
2303//US topLayout->addWidget( mJumpButtonBar ); 2303//US topLayout->addWidget( mJumpButtonBar );
2304 this->layout()->add( mJumpButtonBar ); 2304 this->layout()->add( mJumpButtonBar );
2305*/ 2305*/
2306 2306
2307#endif //KAB_EMBEDDED 2307#endif //KAB_EMBEDDED
2308 2308
2309 mActionExport2phone->plug( ExportMenu ); 2309 mActionExport2phone->plug( ExportMenu );
2310 connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) ); 2310 connect ( syncMenu, SIGNAL( activated ( int ) ), syncManager, SLOT (slotSyncMenu( int ) ) );
2311 syncManager->fillSyncMenu(); 2311 syncManager->fillSyncMenu();
2312 2312
2313} 2313}
2314void KABCore::showLicence() 2314void KABCore::showLicence()
2315{ 2315{
2316 KApplication::showLicence(); 2316 KApplication::showLicence();
2317} 2317}
2318 2318
2319void KABCore::manageCategories( ) 2319void KABCore::manageCategories( )
2320{ 2320{
2321 KABCatPrefs* cp = new KABCatPrefs(); 2321 KABCatPrefs* cp = new KABCatPrefs();
2322 cp->show(); 2322 cp->show();
2323 int w =cp->sizeHint().width() ; 2323 int w =cp->sizeHint().width() ;
2324 int h = cp->sizeHint().height() ; 2324 int h = cp->sizeHint().height() ;
2325 int dw = QApplication::desktop()->width(); 2325 int dw = QApplication::desktop()->width();
2326 int dh = QApplication::desktop()->height(); 2326 int dh = QApplication::desktop()->height();
2327 cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); 2327 cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h );
2328 if ( !cp->exec() ) { 2328 if ( !cp->exec() ) {
2329 delete cp; 2329 delete cp;
2330 return; 2330 return;
2331 } 2331 }
2332 int count = 0; 2332 int count = 0;
2333 int cc = 0; 2333 int cc = 0;
2334 message( i18n("Please wait, processing categories...")); 2334 message( i18n("Please wait, processing categories..."));
2335 if ( cp->addCat() ) { 2335 if ( cp->addCat() ) {
2336 KABC::AddressBook::Iterator it; 2336 KABC::AddressBook::Iterator it;
2337 QStringList catList = KABPrefs::instance()->mCustomCategories; 2337 QStringList catList = KABPrefs::instance()->mCustomCategories;
2338 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2338 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2339 ++cc; 2339 ++cc;
2340 if ( cc %10 == 0) 2340 if ( cc %10 == 0)
2341 message(i18n("Processing contact #%1").arg(cc)); 2341 message(i18n("Processing contact #%1").arg(cc));
2342 QStringList catIncList = (*it).categories(); 2342 QStringList catIncList = (*it).categories();
2343 int i; 2343 int i;
2344 for( i = 0; i< catIncList.count(); ++i ) { 2344 for( i = 0; i< catIncList.count(); ++i ) {
2345 if ( !catList.contains (catIncList[i])) { 2345 if ( !catList.contains (catIncList[i])) {
2346 catList.append( catIncList[i] ); 2346 catList.append( catIncList[i] );
2347 //qDebug("add cat %s ", catIncList[i].latin1()); 2347 //qDebug("add cat %s ", catIncList[i].latin1());
2348 ++count; 2348 ++count;
2349 } 2349 }
2350 } 2350 }
2351 } 2351 }
2352 catList.sort(); 2352 catList.sort();
2353 KABPrefs::instance()->mCustomCategories = catList; 2353 KABPrefs::instance()->mCustomCategories = catList;
2354 KABPrefs::instance()->writeConfig(); 2354 KABPrefs::instance()->writeConfig();
2355 message(QString::number( count )+ i18n(" categories added to list! ")); 2355 message(QString::number( count )+ i18n(" categories added to list! "));
2356 } else { 2356 } else {
2357 QStringList catList = KABPrefs::instance()->mCustomCategories; 2357 QStringList catList = KABPrefs::instance()->mCustomCategories;
2358 QStringList catIncList; 2358 QStringList catIncList;
2359 QStringList newCatList; 2359 QStringList newCatList;
2360 KABC::AddressBook::Iterator it; 2360 KABC::AddressBook::Iterator it;
2361 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2361 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2362 ++cc; 2362 ++cc;
2363 if ( cc %10 == 0) 2363 if ( cc %10 == 0)
2364 message(i18n("Processing contact #%1").arg(cc)); 2364 message(i18n("Processing contact #%1").arg(cc));
2365 QStringList catIncList = (*it).categories(); 2365 QStringList catIncList = (*it).categories();
2366 int i; 2366 int i;
2367 if ( catIncList.count() ) { 2367 if ( catIncList.count() ) {
2368 newCatList.clear(); 2368 newCatList.clear();
2369 for( i = 0; i< catIncList.count(); ++i ) { 2369 for( i = 0; i< catIncList.count(); ++i ) {
2370 if ( catList.contains (catIncList[i])) { 2370 if ( catList.contains (catIncList[i])) {
2371 newCatList.append( catIncList[i] ); 2371 newCatList.append( catIncList[i] );
2372 } 2372 }
2373 } 2373 }
2374 newCatList.sort(); 2374 newCatList.sort();
2375 (*it).setCategories( newCatList ); 2375 (*it).setCategories( newCatList );
2376 mAddressBook->insertAddressee( (*it) ); 2376 mAddressBook->insertAddressee( (*it) );
2377 } 2377 }
2378 } 2378 }
2379 setModified( true ); 2379 setModified( true );
2380 mViewManager->refreshView(); 2380 mViewManager->refreshView();
2381 message( i18n("Removing categories done!")); 2381 message( i18n("Removing categories done!"));
2382 } 2382 }
2383 delete cp; 2383 delete cp;
2384} 2384}
2385void KABCore::removeVoice() 2385void KABCore::removeVoice()
2386{ 2386{
2387 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 ) 2387 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 )
2388 return; 2388 return;
2389 XXPortSelectDialog dlg( this, false, this ); 2389 XXPortSelectDialog dlg( this, false, this );
2390 if ( !dlg.exec() ) 2390 if ( !dlg.exec() )
2391 return; 2391 return;
2392 mAddressBook->setUntagged(); 2392 mAddressBook->setUntagged();
2393 dlg.tagSelected(); 2393 dlg.tagSelected();
2394 message(i18n("Removing voice..."), false ); 2394 message(i18n("Removing voice..."), false );
2395 KABC::AddressBook::Iterator it; 2395 KABC::AddressBook::Iterator it;
2396 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2396 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2397 if ( (*it).tagged() ) { 2397 if ( (*it).tagged() ) {
2398 (*it).removeVoice(); 2398 (*it).removeVoice();
2399 } 2399 }
2400 } 2400 }
2401 message(i18n("Refreshing view...") ); 2401 message(i18n("Refreshing view...") );
2402 qApp->processEvents(); 2402 qApp->processEvents();
2403 mViewManager->refreshView( "" ); 2403 mViewManager->refreshView( "" );
2404 Addressee add; 2404 Addressee add;
2405 mDetails->setAddressee( add ); 2405 mDetails->setAddressee( add );
2406 message(i18n("Remove voice completed!") ); 2406 message(i18n("Remove voice completed!") );
2407 2407
2408 2408
2409 2409
2410} 2410}
2411 2411
2412void KABCore::setFormattedName() 2412void KABCore::setFormattedName()
2413{ 2413{
2414 KABFormatPrefs setpref; 2414 KABFormatPrefs setpref;
2415 if ( !setpref.exec() ) { 2415 if ( !setpref.exec() ) {
2416 return; 2416 return;
2417 } 2417 }
2418 XXPortSelectDialog dlg( this, false, this ); 2418 XXPortSelectDialog dlg( this, false, this );
2419 if ( !dlg.exec() ) 2419 if ( !dlg.exec() )
2420 return; 2420 return;
2421 mAddressBook->setUntagged(); 2421 mAddressBook->setUntagged();
2422 dlg.tagSelected(); 2422 dlg.tagSelected();
2423 int count = 0; 2423 int count = 0;
2424 KABC::AddressBook::Iterator it; 2424 KABC::AddressBook::Iterator it;
2425 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2425 for ( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2426 if ( (*it).tagged() ) { 2426 if ( (*it).tagged() ) {
2427 ++count; 2427 ++count;
2428 if ( count %10 == 0 ) 2428 if ( count %10 == 0 )
2429 message(i18n("Changing contact #%1").arg( count ) ); 2429 message(i18n("Changing contact #%1").arg( count ) );
2430 qApp->processEvents(); 2430 qApp->processEvents();
2431 QString fName; 2431 QString fName;
2432 if ( setpref.simple->isChecked() ) 2432 if ( setpref.simple->isChecked() )
2433 fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName ); 2433 fName = NameEditDialog::formattedName( (*it), NameEditDialog::SimpleName );
2434 else if ( setpref.full->isChecked() ) 2434 else if ( setpref.full->isChecked() )
2435 fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName ); 2435 fName = NameEditDialog::formattedName( (*it), NameEditDialog::FullName );
2436 else if ( setpref.reverse->isChecked() ) 2436 else if ( setpref.reverse->isChecked() )
2437 fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName ); 2437 fName = NameEditDialog::formattedName( (*it), NameEditDialog::ReverseName );
2438 else 2438 else
2439 fName = (*it).organization(); 2439 fName = (*it).organization();
2440 if ( setpref.setCompany->isChecked() ) 2440 if ( setpref.setCompany->isChecked() )
2441 if ( fName.isEmpty() || fName =="," ) 2441 if ( fName.isEmpty() || fName =="," )
2442 fName = (*it).organization(); 2442 fName = (*it).organization();
2443 (*it).setFormattedName( fName ); 2443 (*it).setFormattedName( fName );
2444 } 2444 }
2445 } 2445 }
2446 message(i18n("Refreshing view...") ); 2446 message(i18n("Refreshing view...") );
2447 qApp->processEvents(); 2447 qApp->processEvents();
2448 mViewManager->refreshView( "" ); 2448 mViewManager->refreshView( "" );
2449 Addressee add; 2449 Addressee add;
2450 mDetails->setAddressee( add ); 2450 mDetails->setAddressee( add );
2451 message(i18n("Setting formatted name completed!") ); 2451 message(i18n("Setting formatted name completed!") );
2452} 2452}
2453 2453
2454void KABCore::clipboardDataChanged() 2454void KABCore::clipboardDataChanged()
2455{ 2455{
2456 2456
2457 if ( mReadWrite ) 2457 if ( mReadWrite )
2458 mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() ); 2458 mActionPaste->setEnabled( !QApplication::clipboard()->text().isEmpty() );
2459 2459
2460} 2460}
2461 2461
2462void KABCore::updateActionMenu() 2462void KABCore::updateActionMenu()
2463{ 2463{
2464 UndoStack *undo = UndoStack::instance(); 2464 UndoStack *undo = UndoStack::instance();
2465 RedoStack *redo = RedoStack::instance(); 2465 RedoStack *redo = RedoStack::instance();
2466 2466
2467 if ( undo->isEmpty() ) 2467 if ( undo->isEmpty() )
2468 mActionUndo->setText( i18n( "Undo" ) ); 2468 mActionUndo->setText( i18n( "Undo" ) );
2469 else 2469 else
2470 mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) ); 2470 mActionUndo->setText( i18n( "Undo %1" ).arg( undo->top()->name() ) );
2471 2471
2472 mActionUndo->setEnabled( !undo->isEmpty() ); 2472 mActionUndo->setEnabled( !undo->isEmpty() );
2473 2473
2474 if ( !redo->top() ) 2474 if ( !redo->top() )
2475 mActionRedo->setText( i18n( "Redo" ) ); 2475 mActionRedo->setText( i18n( "Redo" ) );
2476 else 2476 else
2477 mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) ); 2477 mActionRedo->setText( i18n( "Redo %1" ).arg( redo->top()->name() ) );
2478 2478
2479 mActionRedo->setEnabled( !redo->isEmpty() ); 2479 mActionRedo->setEnabled( !redo->isEmpty() );
2480} 2480}
2481 2481
2482void KABCore::configureKeyBindings() 2482void KABCore::configureKeyBindings()
2483{ 2483{
2484#ifndef KAB_EMBEDDED 2484#ifndef KAB_EMBEDDED
2485 KKeyDialog::configure( actionCollection(), true ); 2485 KKeyDialog::configure( actionCollection(), true );
2486#else //KAB_EMBEDDED 2486#else //KAB_EMBEDDED
2487 qDebug("KABCore::configureKeyBindings() not implemented"); 2487 qDebug("KABCore::configureKeyBindings() not implemented");
2488#endif //KAB_EMBEDDED 2488#endif //KAB_EMBEDDED
2489} 2489}
2490 2490
2491#ifdef KAB_EMBEDDED 2491#ifdef KAB_EMBEDDED
2492void KABCore::configureResources() 2492void KABCore::configureResources()
2493{ 2493{
2494 KRES::KCMKResources dlg( this, "" , 0 ); 2494 KRES::KCMKResources dlg( this, "" , 0 );
2495 2495
2496 if ( !dlg.exec() ) 2496 if ( !dlg.exec() )
2497 return; 2497 return;
2498 KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") ); 2498 KMessageBox::information( this, i18n("Please restart to get the \nchanged resources (re)loaded!\n") );
2499} 2499}
2500#endif //KAB_EMBEDDED 2500#endif //KAB_EMBEDDED
2501 2501
2502 2502
2503/* this method will be called through the QCop interface from Ko/Pi to select addresses 2503/* this method will be called through the QCop interface from Ko/Pi to select addresses
2504 * for the attendees list of an event. 2504 * for the attendees list of an event.
2505 */ 2505 */
2506void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid) 2506void KABCore::requestForNameEmailUidList(const QString& sourceChannel, const QString& uid)
2507{ 2507{
2508 QStringList nameList; 2508 QStringList nameList;
2509 QStringList emailList; 2509 QStringList emailList;
2510 QStringList uidList; 2510 QStringList uidList;
2511 bool ok = false; 2511 bool ok = false;
2512 int wid = uid.toInt( &ok ); 2512 int wid = uid.toInt( &ok );
2513 if ( ok ) { 2513 if ( ok ) {
2514 if ( wid != QApplication::desktop()->width() ) { 2514 if ( wid != QApplication::desktop()->width() ) {
2515 qDebug("KA/Pi: Request from different desktop geometry. Resizing ..."); 2515 qDebug("KA/Pi: Request from different desktop geometry. Resizing ...");
2516 message( i18n("Resizing, please wait...") );
2516 raise(); 2517 raise();
2517 qApp->processEvents(); 2518 qApp->processEvents();
2518 } 2519 }
2519 2520
2520 } else { 2521 } else {
2521 qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid "); 2522 qDebug("KABCore::requestForNameEmailUidList:: Got invalid uid ");
2522 } 2523 }
2523 2524
2524 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this); 2525 KABC::Addressee::List list = KABC::AddresseeDialog::getAddressees(this);
2525 uint i=0; 2526 uint i=0;
2526 for (i=0; i < list.count(); i++) 2527 for (i=0; i < list.count(); i++)
2527 { 2528 {
2528 nameList.append(list[i].realName()); 2529 nameList.append(list[i].realName());
2529 emailList.append(list[i].preferredEmail()); 2530 emailList.append(list[i].preferredEmail());
2530 uidList.append(list[i].uid()); 2531 uidList.append(list[i].uid());
2531 } 2532 }
2532 //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1()); 2533 //qDebug("%s %s ", sourceChannel.latin1(), uid.latin1());
2533 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(sourceChannel, uid, nameList, emailList, uidList); 2534 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI(sourceChannel, uid, nameList, emailList, uidList);
2534 2535
2535} 2536}
2536 2537
2537/* this method will be called through the QCop interface from Ko/Pi to select birthdays 2538/* this method will be called through the QCop interface from Ko/Pi to select birthdays
2538 * to put them into the calendar. 2539 * to put them into the calendar.
2539 */ 2540 */
2540void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid) 2541void KABCore::requestForBirthdayList(const QString& sourceChannel, const QString& uid)
2541{ 2542{
2542 // qDebug("KABCore::requestForBirthdayList"); 2543 // qDebug("KABCore::requestForBirthdayList");
2543 QStringList birthdayList; 2544 QStringList birthdayList;
2544 QStringList anniversaryList; 2545 QStringList anniversaryList;
2545 QStringList realNameList; 2546 QStringList realNameList;
2546 QStringList preferredEmailList; 2547 QStringList preferredEmailList;
2547 QStringList assembledNameList; 2548 QStringList assembledNameList;
2548 QStringList uidList; 2549 QStringList uidList;
2549 2550
2550 KABC::AddressBook::Iterator it; 2551 KABC::AddressBook::Iterator it;
2551 2552
2552 int count = 0; 2553 int count = 0;
2553 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) { 2554 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) {
2554 ++count; 2555 ++count;
2555 } 2556 }
2556 QProgressBar bar(count,0 ); 2557 QProgressBar bar(count,0 );
2557 int w = 300; 2558 int w = 300;
2558 if ( QApplication::desktop()->width() < 320 ) 2559 if ( QApplication::desktop()->width() < 320 )
2559 w = 220; 2560 w = 220;
2560 int h = bar.sizeHint().height() ; 2561 int h = bar.sizeHint().height() ;
2561 int dw = QApplication::desktop()->width(); 2562 int dw = QApplication::desktop()->width();
2562 int dh = QApplication::desktop()->height(); 2563 int dh = QApplication::desktop()->height();
2563 bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); 2564 bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h );
2564 bar.show(); 2565 bar.show();
2565 bar.setCaption (i18n("Collecting birthdays - close to abort!") ); 2566 bar.setCaption (i18n("Collecting birthdays - close to abort!") );
2566 qApp->processEvents(); 2567 qApp->processEvents();
2567 2568
2568 QDate bday; 2569 QDate bday;
2569 QString anni; 2570 QString anni;
2570 QString formattedbday; 2571 QString formattedbday;
2571 2572
2572 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it ) 2573 for( it = mAddressBook->begin(); it != mAddressBook->end(); ++it )
2573 { 2574 {
2574 if ( ! bar.isVisible() ) 2575 if ( ! bar.isVisible() )
2575 return; 2576 return;
2576 bar.setProgress( count++ ); 2577 bar.setProgress( count++ );
2577 qApp->processEvents(); 2578 qApp->processEvents();
2578 bday = (*it).birthday().date(); 2579 bday = (*it).birthday().date();
2579 anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" ); 2580 anni = (*it).custom("KADDRESSBOOK", "X-Anniversary" );
2580 2581
2581 if ( bday.isValid() || !anni.isEmpty()) 2582 if ( bday.isValid() || !anni.isEmpty())
2582 { 2583 {
2583 if (bday.isValid()) 2584 if (bday.isValid())
2584 formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate); 2585 formattedbday = KGlobal::locale()->formatDate(bday, true, KLocale::ISODate);
2585 else 2586 else
2586 formattedbday = "NOTVALID"; 2587 formattedbday = "NOTVALID";
2587 if (anni.isEmpty()) 2588 if (anni.isEmpty())
2588 anni = "INVALID"; 2589 anni = "INVALID";
2589 2590
2590 birthdayList.append(formattedbday); 2591 birthdayList.append(formattedbday);
2591 anniversaryList.append(anni); //should be ISODate 2592 anniversaryList.append(anni); //should be ISODate
2592 realNameList.append((*it).realName()); 2593 realNameList.append((*it).realName());
2593 preferredEmailList.append((*it).preferredEmail()); 2594 preferredEmailList.append((*it).preferredEmail());
2594 assembledNameList.append((*it).assembledName()); 2595 assembledNameList.append((*it).assembledName());
2595 uidList.append((*it).uid()); 2596 uidList.append((*it).uid());
2596 2597
2597 //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() ); 2598 //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() );
2598 } 2599 }
2599 } 2600 }
2600 2601
2601 bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList); 2602 bool res = ExternalAppHandler::instance()->returnBirthdayListFromKAPI(sourceChannel, uid, birthdayList, anniversaryList, realNameList, preferredEmailList, assembledNameList, uidList);
2602 2603
2603} 2604}
2604 2605
2605/* this method will be called through the QCop interface from other apps to show details of a contact. 2606/* this method will be called through the QCop interface from other apps to show details of a contact.
2606 */ 2607 */
2607void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid) 2608void KABCore::requestForDetails(const QString& sourceChannel, const QString& sessionuid, const QString& name, const QString& email, const QString& uid)
2608{ 2609{
2609 //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1()); 2610 //qDebug("KABCore::requestForDetails %s %s %s %s %s", sourceChannel.latin1(), sessionuid.latin1(), name.latin1(), email.latin1(), uid.latin1());
2610 2611
2611 QString foundUid = QString::null; 2612 QString foundUid = QString::null;
2612 if ( ! uid.isEmpty() ) { 2613 if ( ! uid.isEmpty() ) {
2613 Addressee adrr = mAddressBook->findByUid( uid ); 2614 Addressee adrr = mAddressBook->findByUid( uid );
2614 if ( !adrr.isEmpty() ) { 2615 if ( !adrr.isEmpty() ) {
2615 foundUid = uid; 2616 foundUid = uid;
2616 } 2617 }
2617 if ( email == "sendbacklist" ) { 2618 if ( email == "sendbacklist" ) {
2618 //qDebug("ssssssssssssssssssssssend "); 2619 //qDebug("ssssssssssssssssssssssend ");
2619 QStringList nameList; 2620 QStringList nameList;
2620 QStringList emailList; 2621 QStringList emailList;
2621 QStringList uidList; 2622 QStringList uidList;
2622 nameList.append(adrr.realName()); 2623 nameList.append(adrr.realName());
2623 emailList = adrr.emails(); 2624 emailList = adrr.emails();
2624 uidList.append( adrr.preferredEmail()); 2625 uidList.append( adrr.preferredEmail());
2625 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList); 2626 bool res = ExternalAppHandler::instance()->returnNameEmailUidListFromKAPI("QPE/Application/ompi", uid, nameList, emailList, uidList);
2626 return; 2627 return;
2627 } 2628 }
2628 2629
2629 } 2630 }
2630 2631
2631 if ( email == "sendbacklist" ) 2632 if ( email == "sendbacklist" )
2632 return; 2633 return;
2633 if (foundUid.isEmpty()) 2634 if (foundUid.isEmpty())
2634 { 2635 {
2635 //find the uid of the person first 2636 //find the uid of the person first
2636 Addressee::List namelist; 2637 Addressee::List namelist;
2637 Addressee::List emaillist; 2638 Addressee::List emaillist;
2638 2639
2639 if (!name.isEmpty()) 2640 if (!name.isEmpty())
2640 namelist = mAddressBook->findByName( name ); 2641 namelist = mAddressBook->findByName( name );
2641 2642
2642 if (!email.isEmpty()) 2643 if (!email.isEmpty())
2643 emaillist = mAddressBook->findByEmail( email ); 2644 emaillist = mAddressBook->findByEmail( email );
2644 //qDebug("count %d %d ", namelist.count(),emaillist.count() ); 2645 //qDebug("count %d %d ", namelist.count(),emaillist.count() );
2645 //check if we have a match in Namelist and Emaillist 2646 //check if we have a match in Namelist and Emaillist
2646 if ((namelist.count() == 0) && (emaillist.count() > 0)) { 2647 if ((namelist.count() == 0) && (emaillist.count() > 0)) {
2647 foundUid = emaillist[0].uid(); 2648 foundUid = emaillist[0].uid();
2648 } 2649 }
2649 else if ((namelist.count() > 0) && (emaillist.count() == 0)) 2650 else if ((namelist.count() > 0) && (emaillist.count() == 0))
2650 foundUid = namelist[0].uid(); 2651 foundUid = namelist[0].uid();
2651 else 2652 else
2652 { 2653 {
2653 for (int i = 0; i < namelist.count(); i++) 2654 for (int i = 0; i < namelist.count(); i++)
2654 { 2655 {
2655 for (int j = 0; j < emaillist.count(); j++) 2656 for (int j = 0; j < emaillist.count(); j++)
2656 { 2657 {
2657 if (namelist[i] == emaillist[j]) 2658 if (namelist[i] == emaillist[j])
2658 { 2659 {
2659 foundUid = namelist[i].uid(); 2660 foundUid = namelist[i].uid();
2660 } 2661 }
2661 } 2662 }
2662 } 2663 }
2663 } 2664 }
2664 } 2665 }
2665 else 2666 else
2666 { 2667 {
2667 foundUid = uid; 2668 foundUid = uid;
2668 } 2669 }
2669 2670
2670 if (!foundUid.isEmpty()) 2671 if (!foundUid.isEmpty())
2671 { 2672 {
2672 2673
2673 // raise Ka/Pi if it is in the background 2674 // raise Ka/Pi if it is in the background
2674#ifndef DESKTOP_VERSION 2675#ifndef DESKTOP_VERSION
2675#ifndef KORG_NODCOP 2676#ifndef KORG_NODCOP
2676 //QCopEnvelope e("QPE/Application/kapi", "raise()"); 2677 //QCopEnvelope e("QPE/Application/kapi", "raise()");
2677#endif 2678#endif
2678#endif 2679#endif
2679 2680
2680 mMainWindow->showMaximized(); 2681 mMainWindow->showMaximized();
2681 mMainWindow-> raise(); 2682 mMainWindow-> raise();
2682 2683
2683 mViewManager->setSelected( "", false); 2684 mViewManager->setSelected( "", false);
2684 mViewManager->refreshView( "" ); 2685 mViewManager->refreshView( "" );
2685 mViewManager->setSelected( foundUid, true ); 2686 mViewManager->setSelected( foundUid, true );
2686 mViewManager->refreshView( foundUid ); 2687 mViewManager->refreshView( foundUid );
2687 2688
2688 if ( !mMultipleViewsAtOnce ) 2689 if ( !mMultipleViewsAtOnce )
2689 { 2690 {
2690 setDetailsVisible( true ); 2691 setDetailsVisible( true );
2691 mActionDetails->setChecked(true); 2692 mActionDetails->setChecked(true);
2692 } 2693 }
2693 } 2694 }
2694} 2695}
2695 2696
2696void KABCore::whatsnew() 2697void KABCore::whatsnew()
2697{ 2698{
2698 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); 2699 KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" );
2699} 2700}
2700void KABCore::synchowto() 2701void KABCore::synchowto()
2701{ 2702{
2702 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); 2703 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" );
2703} 2704}
2704void KABCore::kdesynchowto() 2705void KABCore::kdesynchowto()
2705{ 2706{
2706 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" ); 2707 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/Zaurus-KDE_syncHowTo.txt" );
2707} 2708}
2708void KABCore::multisynchowto() 2709void KABCore::multisynchowto()
2709{ 2710{
2710 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" ); 2711 KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/MultiSyncHowTo.txt" );
2711} 2712}
2712void KABCore::faq() 2713void KABCore::faq()
2713{ 2714{
2714 KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" ); 2715 KApplication::showFile( "KA/Pi FAQ", "kdepim/kaddressbook/kapiFAQ.txt" );
2715} 2716}
2716 2717
2717#include <libkcal/syncdefines.h> 2718#include <libkcal/syncdefines.h>
2718 2719
2719KABC::Addressee KABCore::getLastSyncAddressee() 2720KABC::Addressee KABCore::getLastSyncAddressee()
2720{ 2721{
2721 Addressee lse; 2722 Addressee lse;
2722 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2723 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2723 2724
2724 //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); 2725 //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() );
2725 lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice ); 2726 lse = mAddressBook->findByUid( "last-syncAddressee-"+mCurrentSyncDevice );
2726 if (lse.isEmpty()) { 2727 if (lse.isEmpty()) {
2727 qDebug("KA: Creating new last-syncAddressee "); 2728 qDebug("KA: Creating new last-syncAddressee ");
2728 lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice ); 2729 lse.setUid( "last-syncAddressee-"+mCurrentSyncDevice );
2729 QString sum = ""; 2730 QString sum = "";
2730 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) 2731 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL )
2731 sum = "E: "; 2732 sum = "E: ";
2732 lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event")); 2733 lse.setFamilyName("!"+sum+mCurrentSyncDevice + i18n(" - sync event"));
2733 lse.setRevision( mLastAddressbookSync ); 2734 lse.setRevision( mLastAddressbookSync );
2734 lse.setCategories( i18n("SyncEvent") ); 2735 lse.setCategories( i18n("SyncEvent") );
2735 mAddressBook->insertAddressee( lse ); 2736 mAddressBook->insertAddressee( lse );
2736 } 2737 }
2737 return lse; 2738 return lse;
2738} 2739}
2739int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full ) 2740int KABCore::takeAddressee( KABC::Addressee* local, KABC::Addressee* remote, int mode , bool full )
2740{ 2741{
2741 2742
2742 //void setZaurusId(int id); 2743 //void setZaurusId(int id);
2743 // int zaurusId() const; 2744 // int zaurusId() const;
2744 // void setZaurusUid(int id); 2745 // void setZaurusUid(int id);
2745 // int zaurusUid() const; 2746 // int zaurusUid() const;
2746 // void setZaurusStat(int id); 2747 // void setZaurusStat(int id);
2747 // int zaurusStat() const; 2748 // int zaurusStat() const;
2748 // 0 equal 2749 // 0 equal
2749 // 1 take local 2750 // 1 take local
2750 // 2 take remote 2751 // 2 take remote
2751 // 3 cancel 2752 // 3 cancel
2752 QDateTime lastSync = mLastAddressbookSync; 2753 QDateTime lastSync = mLastAddressbookSync;
2753 QDateTime localMod = local->revision(); 2754 QDateTime localMod = local->revision();
2754 QDateTime remoteMod = remote->revision(); 2755 QDateTime remoteMod = remote->revision();
2755 2756
2756 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2757 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2757 2758
2758 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2759 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2759 bool remCh, locCh; 2760 bool remCh, locCh;
2760 remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); 2761 remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) );
2761 //if ( remCh ) 2762 //if ( remCh )
2762 // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); 2763 // qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() );
2763 locCh = ( localMod > mLastAddressbookSync ); 2764 locCh = ( localMod > mLastAddressbookSync );
2764 //qDebug("cahnged rem %d loc %d",remCh, locCh ); 2765 //qDebug("cahnged rem %d loc %d",remCh, locCh );
2765 if ( !remCh && ! locCh ) { 2766 if ( !remCh && ! locCh ) {
2766 //qDebug("both not changed "); 2767 //qDebug("both not changed ");
2767 lastSync = localMod.addDays(1); 2768 lastSync = localMod.addDays(1);
2768 if ( mode <= SYNC_PREF_ASK ) 2769 if ( mode <= SYNC_PREF_ASK )
2769 return 0; 2770 return 0;
2770 } else { 2771 } else {
2771 if ( locCh ) { 2772 if ( locCh ) {
2772 //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1()); 2773 //qDebug("loc changed %s %s", localMod.toString().latin1(), mLastAddressbookSync.toString().latin1());
2773 lastSync = localMod.addDays( -1 ); 2774 lastSync = localMod.addDays( -1 );
2774 if ( !remCh ) 2775 if ( !remCh )
2775 remoteMod =( lastSync.addDays( -1 ) ); 2776 remoteMod =( lastSync.addDays( -1 ) );
2776 } else { 2777 } else {
2777 //qDebug(" not loc changed "); 2778 //qDebug(" not loc changed ");
2778 lastSync = localMod.addDays( 1 ); 2779 lastSync = localMod.addDays( 1 );
2779 if ( remCh ) { 2780 if ( remCh ) {
2780 //qDebug("rem changed "); 2781 //qDebug("rem changed ");
2781 remoteMod =( lastSync.addDays( 1 ) ); 2782 remoteMod =( lastSync.addDays( 1 ) );
2782 } 2783 }
2783 2784
2784 } 2785 }
2785 } 2786 }
2786 full = true; 2787 full = true;
2787 if ( mode < SYNC_PREF_ASK ) 2788 if ( mode < SYNC_PREF_ASK )
2788 mode = SYNC_PREF_ASK; 2789 mode = SYNC_PREF_ASK;
2789 } else { 2790 } else {
2790 if ( localMod == remoteMod ) 2791 if ( localMod == remoteMod )
2791 return 0; 2792 return 0;
2792 2793
2793 } 2794 }
2794 //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec()); 2795 //qDebug("%s %s --- %d %d", localMod.toString().latin1() , remoteMod.toString().latin1(), localMod.time().msec(), remoteMod.time().msec());
2795 //qDebug("lastsync %s ", lastSync.toString().latin1() ); 2796 //qDebug("lastsync %s ", lastSync.toString().latin1() );
2796 //full = true; //debug only 2797 //full = true; //debug only
2797 if ( full ) { 2798 if ( full ) {
2798 bool equ = ( (*local) == (*remote) ); 2799 bool equ = ( (*local) == (*remote) );
2799 if ( equ ) { 2800 if ( equ ) {
2800 //qDebug("equal "); 2801 //qDebug("equal ");
2801 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2802 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2802 local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); 2803 local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) );
2803 } 2804 }
2804 if ( mode < SYNC_PREF_FORCE_LOCAL ) 2805 if ( mode < SYNC_PREF_FORCE_LOCAL )
2805 return 0; 2806 return 0;
2806 2807
2807 }//else //debug only 2808 }//else //debug only
2808 //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); 2809 //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1());
2809 } 2810 }
2810 int result; 2811 int result;
2811 bool localIsNew; 2812 bool localIsNew;
2812 //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() ); 2813 //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() );
2813 2814
2814 if ( full && mode < SYNC_PREF_NEWEST ) 2815 if ( full && mode < SYNC_PREF_NEWEST )
2815 mode = SYNC_PREF_ASK; 2816 mode = SYNC_PREF_ASK;
2816 2817
2817 switch( mode ) { 2818 switch( mode ) {
2818 case SYNC_PREF_LOCAL: 2819 case SYNC_PREF_LOCAL:
2819 if ( lastSync > remoteMod ) 2820 if ( lastSync > remoteMod )
2820 return 1; 2821 return 1;
2821 if ( lastSync > localMod ) 2822 if ( lastSync > localMod )
2822 return 2; 2823 return 2;
2823 return 1; 2824 return 1;
2824 break; 2825 break;
2825 case SYNC_PREF_REMOTE: 2826 case SYNC_PREF_REMOTE:
2826 if ( lastSync > remoteMod ) 2827 if ( lastSync > remoteMod )
2827 return 1; 2828 return 1;
2828 if ( lastSync > localMod ) 2829 if ( lastSync > localMod )
2829 return 2; 2830 return 2;
2830 return 2; 2831 return 2;
2831 break; 2832 break;
2832 case SYNC_PREF_NEWEST: 2833 case SYNC_PREF_NEWEST:
2833 if ( localMod > remoteMod ) 2834 if ( localMod > remoteMod )
2834 return 1; 2835 return 1;
2835 else 2836 else
2836 return 2; 2837 return 2;
2837 break; 2838 break;
2838 case SYNC_PREF_ASK: 2839 case SYNC_PREF_ASK:
2839 //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); 2840 //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() );
2840 if ( lastSync > remoteMod ) 2841 if ( lastSync > remoteMod )
2841 return 1; 2842 return 1;
2842 if ( lastSync > localMod ) { 2843 if ( lastSync > localMod ) {
2843 return 2; 2844 return 2;
2844 } 2845 }
2845 localIsNew = localMod >= remoteMod; 2846 localIsNew = localMod >= remoteMod;
2846 //qDebug("conflict! ************************************** "); 2847 //qDebug("conflict! ************************************** ");
2847 { 2848 {
2848 KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this ); 2849 KABC::AddresseeChooser acd ( *local,*remote, localIsNew , this );
2849 result = acd.executeD(localIsNew); 2850 result = acd.executeD(localIsNew);
2850 return result; 2851 return result;
2851 } 2852 }
2852 break; 2853 break;
2853 case SYNC_PREF_FORCE_LOCAL: 2854 case SYNC_PREF_FORCE_LOCAL:
2854 return 1; 2855 return 1;
2855 break; 2856 break;
2856 case SYNC_PREF_FORCE_REMOTE: 2857 case SYNC_PREF_FORCE_REMOTE:
2857 return 2; 2858 return 2;
2858 break; 2859 break;
2859 2860
2860 default: 2861 default:
2861 // SYNC_PREF_TAKE_BOTH not implemented 2862 // SYNC_PREF_TAKE_BOTH not implemented
2862 break; 2863 break;
2863 } 2864 }
2864 return 0; 2865 return 0;
2865} 2866}
2866 2867
2867 2868
2868bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode) 2869bool KABCore::synchronizeAddressbooks( KABC::AddressBook* local, KABC::AddressBook* remote,int mode)
2869{ 2870{
2870 bool syncOK = true; 2871 bool syncOK = true;
2871 int addedAddressee = 0; 2872 int addedAddressee = 0;
2872 int addedAddresseeR = 0; 2873 int addedAddresseeR = 0;
2873 int deletedAddresseeR = 0; 2874 int deletedAddresseeR = 0;
2874 int deletedAddresseeL = 0; 2875 int deletedAddresseeL = 0;
2875 int changedLocal = 0; 2876 int changedLocal = 0;
2876 int changedRemote = 0; 2877 int changedRemote = 0;
2877 int filteredIN = 0; 2878 int filteredIN = 0;
2878 int filteredOUT = 0; 2879 int filteredOUT = 0;
2879 2880
2880 QString mCurrentSyncName = syncManager->getCurrentSyncName(); 2881 QString mCurrentSyncName = syncManager->getCurrentSyncName();
2881 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice(); 2882 QString mCurrentSyncDevice = syncManager->getCurrentSyncDevice();
2882 2883
2883 //QPtrList<Addressee> el = local->rawAddressees(); 2884 //QPtrList<Addressee> el = local->rawAddressees();
2884 Addressee addresseeR; 2885 Addressee addresseeR;
2885 QString uid; 2886 QString uid;
2886 int take; 2887 int take;
2887 Addressee addresseeL; 2888 Addressee addresseeL;
2888 Addressee addresseeRSync; 2889 Addressee addresseeRSync;
2889 Addressee addresseeLSync; 2890 Addressee addresseeLSync;
2890 // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees(); 2891 // KABC::Addressee::List addresseeRSyncSharp = remote->getExternLastSyncAddressees();
2891 //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees(); 2892 //KABC::Addressee::List addresseeLSyncSharp = local->getExternLastSyncAddressees();
2892 bool fullDateRange = false; 2893 bool fullDateRange = false;
2893 local->resetTempSyncStat(); 2894 local->resetTempSyncStat();
2894 mLastAddressbookSync = QDateTime::currentDateTime(); 2895 mLastAddressbookSync = QDateTime::currentDateTime();
2895 if ( syncManager->syncWithDesktop() ) { 2896 if ( syncManager->syncWithDesktop() ) {
2896 // remote->removeSyncInfo( QString());//remove all info 2897 // remote->removeSyncInfo( QString());//remove all info
2897 if ( KSyncManager::mRequestedSyncEvent.isValid() ) { 2898 if ( KSyncManager::mRequestedSyncEvent.isValid() ) {
2898 mLastAddressbookSync = KSyncManager::mRequestedSyncEvent; 2899 mLastAddressbookSync = KSyncManager::mRequestedSyncEvent;
2899 qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() ); 2900 qDebug("KA: using extern time for calendar sync: %s ", mLastAddressbookSync.toString().latin1() );
2900 } else { 2901 } else {
2901 qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime "); 2902 qDebug("KA: KSyncManager::mRequestedSyncEvent has invalid datatime ");
2902 } 2903 }
2903 } 2904 }
2904 QDateTime modifiedCalendar = mLastAddressbookSync; 2905 QDateTime modifiedCalendar = mLastAddressbookSync;
2905 addresseeLSync = getLastSyncAddressee(); 2906 addresseeLSync = getLastSyncAddressee();
2906 qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1()); 2907 qDebug("KA: Last Sync %s ", addresseeLSync.revision().toString().latin1());
2907 addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName ); 2908 addresseeR = remote->findByUid("last-syncAddressee-"+mCurrentSyncName );
2908 if ( !addresseeR.isEmpty() ) { 2909 if ( !addresseeR.isEmpty() ) {
2909 addresseeRSync = addresseeR; 2910 addresseeRSync = addresseeR;
2910 remote->removeAddressee(addresseeR ); 2911 remote->removeAddressee(addresseeR );
2911 2912
2912 } else { 2913 } else {
2913 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2914 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2914 addresseeRSync = addresseeLSync ; 2915 addresseeRSync = addresseeLSync ;
2915 } else { 2916 } else {
2916 //qDebug("FULLDATE 1"); 2917 //qDebug("FULLDATE 1");
2917 fullDateRange = true; 2918 fullDateRange = true;
2918 Addressee newAdd; 2919 Addressee newAdd;
2919 addresseeRSync = newAdd; 2920 addresseeRSync = newAdd;
2920 addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee")); 2921 addresseeRSync.setFamilyName(mCurrentSyncName + i18n(" - sync addressee"));
2921 addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName ); 2922 addresseeRSync.setUid("last-syncAddressee-"+mCurrentSyncName );
2922 addresseeRSync.setRevision( mLastAddressbookSync ); 2923 addresseeRSync.setRevision( mLastAddressbookSync );
2923 addresseeRSync.setCategories( i18n("SyncAddressee") ); 2924 addresseeRSync.setCategories( i18n("SyncAddressee") );
2924 } 2925 }
2925 } 2926 }
2926 if ( addresseeLSync.revision() == mLastAddressbookSync ) { 2927 if ( addresseeLSync.revision() == mLastAddressbookSync ) {
2927 // qDebug("FULLDATE 2"); 2928 // qDebug("FULLDATE 2");
2928 fullDateRange = true; 2929 fullDateRange = true;
2929 } 2930 }
2930 if ( ! fullDateRange ) { 2931 if ( ! fullDateRange ) {
2931 if ( addresseeLSync.revision() != addresseeRSync.revision() ) { 2932 if ( addresseeLSync.revision() != addresseeRSync.revision() ) {
2932 2933
2933 // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() ); 2934 // qDebug("set fulldate to true %s %s" ,addresseeLSync->dtStart().toString().latin1(), addresseeRSync->dtStart().toString().latin1() );
2934 //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec()); 2935 //qDebug("%d %d %d %d ", addresseeLSync->dtStart().time().second(), addresseeLSync->dtStart().time().msec() , addresseeRSync->dtStart().time().second(), addresseeRSync->dtStart().time().msec());
2935 fullDateRange = true; 2936 fullDateRange = true;
2936 //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() ); 2937 //qDebug("FULLDATE 3 %s %s", addresseeLSync.revision().toString().latin1() , addresseeRSync.revision().toString().latin1() );
2937 } 2938 }
2938 } 2939 }
2939 // fullDateRange = true; // debug only! 2940 // fullDateRange = true; // debug only!
2940 if ( fullDateRange ) 2941 if ( fullDateRange )
2941 mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365); 2942 mLastAddressbookSync = QDateTime::currentDateTime().addDays( -100*365);
2942 else 2943 else
2943 mLastAddressbookSync = addresseeLSync.revision(); 2944 mLastAddressbookSync = addresseeLSync.revision();
2944 // for resyncing if own file has changed 2945 // for resyncing if own file has changed
2945 // PENDING fixme later when implemented 2946 // PENDING fixme later when implemented
2946#if 0 2947#if 0
2947 if ( mCurrentSyncDevice == "deleteaftersync" ) { 2948 if ( mCurrentSyncDevice == "deleteaftersync" ) {
2948 mLastAddressbookSync = loadedFileVersion; 2949 mLastAddressbookSync = loadedFileVersion;
2949 qDebug("setting mLastAddressbookSync "); 2950 qDebug("setting mLastAddressbookSync ");
2950 } 2951 }
2951#endif 2952#endif
2952 2953
2953 2954
2954 // ********** setting filters **************** 2955 // ********** setting filters ****************
2955 Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB ); 2956 Filter filterIN = mViewManager->getFilterByName( syncManager->mFilterInAB );
2956 Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB ); 2957 Filter filterOUT = mViewManager->getFilterByName( syncManager->mFilterOutAB );
2957 2958
2958 //qDebug("*************************** "); 2959 //qDebug("*************************** ");
2959 // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() ); 2960 // qDebug("mLastAddressbookSync %s ",mLastAddressbookSync.toString().latin1() );
2960 QStringList er = remote->uidList(); 2961 QStringList er = remote->uidList();
2961 Addressee inR ;//= er.first(); 2962 Addressee inR ;//= er.first();
2962 Addressee inL; 2963 Addressee inL;
2963 2964
2964 syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count()); 2965 syncManager->showProgressBar(0, i18n("Syncing - close to abort!"), er.count());
2965 2966
2966 int modulo = (er.count()/10)+1; 2967 int modulo = (er.count()/10)+1;
2967 int incCounter = 0; 2968 int incCounter = 0;
2968 while ( incCounter < er.count()) { 2969 while ( incCounter < er.count()) {
2969 if (syncManager->isProgressBarCanceled()) 2970 if (syncManager->isProgressBarCanceled())
2970 return false; 2971 return false;
2971 if ( incCounter % modulo == 0 ) 2972 if ( incCounter % modulo == 0 )
2972 syncManager->showProgressBar(incCounter); 2973 syncManager->showProgressBar(incCounter);
2973 2974
2974 uid = er[ incCounter ]; 2975 uid = er[ incCounter ];
2975 bool skipIncidence = false; 2976 bool skipIncidence = false;
2976 if ( uid.left(19) == QString("last-syncAddressee-") ) 2977 if ( uid.left(19) == QString("last-syncAddressee-") )
2977 skipIncidence = true; 2978 skipIncidence = true;
2978 QString idS,OidS; 2979 QString idS,OidS;
2979 qApp->processEvents(); 2980 qApp->processEvents();
2980 if ( !skipIncidence ) { 2981 if ( !skipIncidence ) {
2981 inL = local->findByUid( uid ); 2982 inL = local->findByUid( uid );
2982 inR = remote->findByUid( uid ); 2983 inR = remote->findByUid( uid );
2983 //inL.setResource( 0 ); 2984 //inL.setResource( 0 );
2984 //inR.setResource( 0 ); 2985 //inR.setResource( 0 );
2985 if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars 2986 if ( !inL.isEmpty() ) { // maybe conflict - same uid in both calendars
2986 if ( !inL.resource() || inL.resource()->includeInSync() ) { 2987 if ( !inL.resource() || inL.resource()->includeInSync() ) {
2987 if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) { 2988 if ( (take = takeAddressee( &inL, &inR, mode, fullDateRange )) ) {
2988 //qDebug("take %d %s ", take, inL.summary().latin1()); 2989 //qDebug("take %d %s ", take, inL.summary().latin1());
2989 if ( take == 3 ) 2990 if ( take == 3 )
2990 return false; 2991 return false;
2991 if ( take == 1 ) {// take local ********************** 2992 if ( take == 1 ) {// take local **********************
2992 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 2993 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
2993 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 2994 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
2994 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 2995 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
2995 local->insertAddressee( inL, false ); 2996 local->insertAddressee( inL, false );
2996 idS = inR.externalUID(); 2997 idS = inR.externalUID();
2997 OidS = inR.originalExternalUID(); 2998 OidS = inR.originalExternalUID();
2998 } 2999 }
2999 else 3000 else
3000 idS = inR.IDStr(); 3001 idS = inR.IDStr();
3001 remote->removeAddressee( inR ); 3002 remote->removeAddressee( inR );
3002 inR = inL; 3003 inR = inL;
3003 inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); 3004 inR.setTempSyncStat( SYNC_TEMPSTATE_INITIAL );
3004 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3005 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3005 inR.setOriginalExternalUID( OidS ); 3006 inR.setOriginalExternalUID( OidS );
3006 inR.setExternalUID( idS ); 3007 inR.setExternalUID( idS );
3007 if ( syncManager->syncWithDesktop() ) { 3008 if ( syncManager->syncWithDesktop() ) {
3008 inR.setIDStr("changed" ); 3009 inR.setIDStr("changed" );
3009 } 3010 }
3010 //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" ); 3011 //inR.insertCustom( "KADDRESSBOOK", "X-KDESYNC","changed" );
3011 } else { 3012 } else {
3012 inR.setIDStr( idS ); 3013 inR.setIDStr( idS );
3013 } 3014 }
3014 inR.setResource( 0 ); 3015 inR.setResource( 0 );
3015 remote->insertAddressee( inR , false); 3016 remote->insertAddressee( inR , false);
3016 ++changedRemote; 3017 ++changedRemote;
3017 } else { // take == 2 take remote ********************** 3018 } else { // take == 2 take remote **********************
3018 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3019 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3019 if ( inR.revision().date().year() < 2004 ) 3020 if ( inR.revision().date().year() < 2004 )
3020 inR.setRevision( modifiedCalendar ); 3021 inR.setRevision( modifiedCalendar );
3021 } 3022 }
3022 idS = inL.IDStr(); 3023 idS = inL.IDStr();
3023 local->removeAddressee( inL ); 3024 local->removeAddressee( inL );
3024 inL = inR; 3025 inL = inR;
3025 inL.setIDStr( idS ); 3026 inL.setIDStr( idS );
3026 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3027 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3027 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 3028 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
3028 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 3029 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
3029 } 3030 }
3030 inL.setResource( 0 ); 3031 inL.setResource( 0 );
3031 local->insertAddressee( inL , false ); 3032 local->insertAddressee( inL , false );
3032 ++changedLocal; 3033 ++changedLocal;
3033 } 3034 }
3034 } 3035 }
3035 } 3036 }
3036 } else { // no conflict ********** add or delete remote 3037 } else { // no conflict ********** add or delete remote
3037 if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) { 3038 if ( filterIN.name().isEmpty() || filterIN.filterAddressee( inR ) ) {
3038 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3039 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3039 QString des = addresseeLSync.note(); 3040 QString des = addresseeLSync.note();
3040 if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it 3041 if ( des.find( inR.getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it
3041 inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE ); 3042 inR.setTempSyncStat( SYNC_TEMPSTATE_DELETE );
3042 remote->insertAddressee( inR, false ); 3043 remote->insertAddressee( inR, false );
3043 ++deletedAddresseeR; 3044 ++deletedAddresseeR;
3044 } else { 3045 } else {
3045 inR.setRevision( modifiedCalendar ); 3046 inR.setRevision( modifiedCalendar );
3046 remote->insertAddressee( inR, false ); 3047 remote->insertAddressee( inR, false );
3047 inL = inR; 3048 inL = inR;
3048 inL.setIDStr( ":" ); 3049 inL.setIDStr( ":" );
3049 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) ); 3050 inL.setCsum( mCurrentSyncDevice, inR.getCsum(mCurrentSyncDevice) );
3050 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) ); 3051 inL.setID( mCurrentSyncDevice, inR.getID(mCurrentSyncDevice) );
3051 inL.setResource( 0 ); 3052 inL.setResource( 0 );
3052 local->insertAddressee( inL , false); 3053 local->insertAddressee( inL , false);
3053 ++addedAddressee; 3054 ++addedAddressee;
3054 } 3055 }
3055 } else { 3056 } else {
3056 if ( inR.revision() > mLastAddressbookSync || mode == 5 ) { 3057 if ( inR.revision() > mLastAddressbookSync || mode == 5 ) {
3057 inR.setRevision( modifiedCalendar ); 3058 inR.setRevision( modifiedCalendar );
3058 remote->insertAddressee( inR, false ); 3059 remote->insertAddressee( inR, false );
3059 inR.setResource( 0 ); 3060 inR.setResource( 0 );
3060 local->insertAddressee( inR, false ); 3061 local->insertAddressee( inR, false );
3061 ++addedAddressee; 3062 ++addedAddressee;
3062 } else { 3063 } else {
3063 // pending checkExternSyncAddressee(addresseeRSyncSharp, inR); 3064 // pending checkExternSyncAddressee(addresseeRSyncSharp, inR);
3064 remote->removeAddressee( inR ); 3065 remote->removeAddressee( inR );
3065 ++deletedAddresseeR; 3066 ++deletedAddresseeR;
3066 } 3067 }
3067 } 3068 }
3068 } else { 3069 } else {
3069 ++filteredIN; 3070 ++filteredIN;
3070 } 3071 }
3071 } 3072 }
3072 } 3073 }
3073 ++incCounter; 3074 ++incCounter;
3074 } 3075 }
3075 er.clear(); 3076 er.clear();
3076 QStringList el = local->uidList(); 3077 QStringList el = local->uidList();
3077 modulo = (el.count()/10)+1; 3078 modulo = (el.count()/10)+1;
3078 3079
3079 syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count()); 3080 syncManager->showProgressBar(0, i18n("Add / remove addressees"), el.count());
3080 incCounter = 0; 3081 incCounter = 0;
3081 while ( incCounter < el.count()) { 3082 while ( incCounter < el.count()) {
3082 qApp->processEvents(); 3083 qApp->processEvents();
3083 if (syncManager->isProgressBarCanceled()) 3084 if (syncManager->isProgressBarCanceled())
3084 return false; 3085 return false;
3085 if ( incCounter % modulo == 0 ) 3086 if ( incCounter % modulo == 0 )
3086 syncManager->showProgressBar(incCounter); 3087 syncManager->showProgressBar(incCounter);
3087 uid = el[ incCounter ]; 3088 uid = el[ incCounter ];
3088 bool skipIncidence = false; 3089 bool skipIncidence = false;
3089 if ( uid.left(19) == QString("last-syncAddressee-") ) 3090 if ( uid.left(19) == QString("last-syncAddressee-") )
3090 skipIncidence = true; 3091 skipIncidence = true;
3091 if ( !skipIncidence ) { 3092 if ( !skipIncidence ) {
3092 inL = local->findByUid( uid ); 3093 inL = local->findByUid( uid );
3093 if ( !inL.resource() || inL.resource()->includeInSync() ) { 3094 if ( !inL.resource() || inL.resource()->includeInSync() ) {
3094 inR = remote->findByUid( uid ); 3095 inR = remote->findByUid( uid );
3095 if ( inR.isEmpty() ){ 3096 if ( inR.isEmpty() ){
3096 if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) { 3097 if ( filterOUT.name().isEmpty() || filterOUT.filterAddressee( inL ) ) {
3097 // no conflict ********** add or delete local 3098 // no conflict ********** add or delete local
3098 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { 3099 if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) {
3099 if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { 3100 if ( !inL.getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) {
3100 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); 3101 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL);
3101 local->removeAddressee( inL ); 3102 local->removeAddressee( inL );
3102 ++deletedAddresseeL; 3103 ++deletedAddresseeL;
3103 } else { 3104 } else {
3104 if ( ! syncManager->mWriteBackExistingOnly ) { 3105 if ( ! syncManager->mWriteBackExistingOnly ) {
3105 inL.removeID(mCurrentSyncDevice ); 3106 inL.removeID(mCurrentSyncDevice );
3106 ++addedAddresseeR; 3107 ++addedAddresseeR;
3107 inL.setRevision( modifiedCalendar ); 3108 inL.setRevision( modifiedCalendar );
3108 local->insertAddressee( inL, false ); 3109 local->insertAddressee( inL, false );
3109 inR = inL; 3110 inR = inL;
3110 inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL ); 3111 inR.setTempSyncStat( SYNC_TEMPSTATE_ADDED_EXTERNAL );
3111 inR.setResource( 0 ); 3112 inR.setResource( 0 );
3112 remote->insertAddressee( inR, false ); 3113 remote->insertAddressee( inR, false );
3113 } 3114 }
3114 } 3115 }
3115 } else { 3116 } else {
3116 if ( inL.revision() < mLastAddressbookSync && mode != 4 ) { 3117 if ( inL.revision() < mLastAddressbookSync && mode != 4 ) {
3117 //qDebug("data %s ", inL.revision().toString().latin1()); 3118 //qDebug("data %s ", inL.revision().toString().latin1());
3118 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL); 3119 // pending checkExternSyncAddressee(addresseeLSyncSharp, inL);
3119 local->removeAddressee( inL ); 3120 local->removeAddressee( inL );
3120 ++deletedAddresseeL; 3121 ++deletedAddresseeL;
3121 } else { 3122 } else {
3122 if ( ! syncManager->mWriteBackExistingOnly ) { 3123 if ( ! syncManager->mWriteBackExistingOnly ) {
3123 ++addedAddresseeR; 3124 ++addedAddresseeR;
3124 inL.setRevision( modifiedCalendar ); 3125 inL.setRevision( modifiedCalendar );
3125 local->insertAddressee( inL, false ); 3126 local->insertAddressee( inL, false );
3126 inR = inL; 3127 inR = inL;
3127 inR.setIDStr( ":" ); 3128 inR.setIDStr( ":" );
3128 inR.setResource( 0 ); 3129 inR.setResource( 0 );
3129 remote->insertAddressee( inR, false ); 3130 remote->insertAddressee( inR, false );
3130 } 3131 }
3131 } 3132 }
3132 } 3133 }
3133 } else { 3134 } else {
3134 ++filteredOUT; 3135 ++filteredOUT;
3135 } 3136 }
3136 } 3137 }
3137 } 3138 }
3138 } 3139 }
3139 ++incCounter; 3140 ++incCounter;
3140 } 3141 }
3141 el.clear(); 3142 el.clear();
3142 syncManager->hideProgressBar(); 3143 syncManager->hideProgressBar();
3143 mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 ); 3144 mLastAddressbookSync = QDateTime::currentDateTime().addSecs( 1 );
3144 // get rid of micro seconds 3145 // get rid of micro seconds
3145 QTime t = mLastAddressbookSync.time(); 3146 QTime t = mLastAddressbookSync.time();
3146 mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) ); 3147 mLastAddressbookSync.setTime( QTime (t.hour (), t.minute (), t.second () ) );
3147 addresseeLSync.setRevision( mLastAddressbookSync ); 3148 addresseeLSync.setRevision( mLastAddressbookSync );
3148 addresseeRSync.setRevision( mLastAddressbookSync ); 3149 addresseeRSync.setRevision( mLastAddressbookSync );
3149 addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ; 3150 addresseeRSync.setRole( i18n("!Remote from: ")+mCurrentSyncName ) ;
3150 addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName ); 3151 addresseeLSync.setRole(i18n("!Local from: ") + mCurrentSyncName );
3151 addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ; 3152 addresseeRSync.setGivenName( i18n("!DO NOT EDIT!") ) ;
3152 addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") ); 3153 addresseeLSync.setGivenName(i18n("!DO NOT EDIT!") );
3153 addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ; 3154 addresseeRSync.setOrganization( "!"+mLastAddressbookSync.toString() ) ;
3154 addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() ); 3155 addresseeLSync.setOrganization("!"+ mLastAddressbookSync.toString() );
3155 addresseeRSync.setNote( "" ) ; 3156 addresseeRSync.setNote( "" ) ;
3156 addresseeLSync.setNote( "" ); 3157 addresseeLSync.setNote( "" );
3157 3158
3158 if ( mGlobalSyncMode == SYNC_MODE_NORMAL) 3159 if ( mGlobalSyncMode == SYNC_MODE_NORMAL)
3159 remote->insertAddressee( addresseeRSync, false ); 3160 remote->insertAddressee( addresseeRSync, false );
3160 local->insertAddressee( addresseeLSync, false ); 3161 local->insertAddressee( addresseeLSync, false );
3161 QString mes; 3162 QString mes;
3162 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 ); 3163 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 );
3163 qDebug( mes ); 3164 qDebug( mes );
3164 mes = i18n("Local addressbook changed!\n") +mes; 3165 mes = i18n("Local addressbook changed!\n") +mes;
3165 if ( syncManager->mShowSyncSummary ) { 3166 if ( syncManager->mShowSyncSummary ) {
3166 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, 3167 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes,
3167 i18n("KA/Pi Synchronization"),i18n("Write back"))) { 3168 i18n("KA/Pi Synchronization"),i18n("Write back"))) {
3168 qDebug("KA: WB cancelled "); 3169 qDebug("KA: WB cancelled ");
3169 syncManager->mWriteBackFile = false; 3170 syncManager->mWriteBackFile = false;
3170 return syncOK; 3171 return syncOK;
3171 } 3172 }
3172 } 3173 }
3173 return syncOK; 3174 return syncOK;
3174} 3175}
3175 3176
3176 3177
3177//this is a overwritten callbackmethods from the syncinterface 3178//this is a overwritten callbackmethods from the syncinterface
3178bool KABCore::sync(KSyncManager* manager, QString filename, int mode) 3179bool KABCore::sync(KSyncManager* manager, QString filename, int mode)
3179{ 3180{
3180 3181
3181 //pending prepare addresseeview for output 3182 //pending prepare addresseeview for output
3182 //pending detect, if remote file has REV field. if not switch to external sync 3183 //pending detect, if remote file has REV field. if not switch to external sync
3183 mGlobalSyncMode = SYNC_MODE_NORMAL; 3184 mGlobalSyncMode = SYNC_MODE_NORMAL;
3184 if ( manager != syncManager ) 3185 if ( manager != syncManager )
3185 qDebug("KABCore::sync:: ERROR! :: manager != syncManager "); 3186 qDebug("KABCore::sync:: ERROR! :: manager != syncManager ");
3186 QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); 3187 QString mCurrentSyncDevice = manager->getCurrentSyncDevice();
3187 3188
3188 AddressBook abLocal(filename,"syncContact"); 3189 AddressBook abLocal(filename,"syncContact");
3189 bool syncOK = false; 3190 bool syncOK = false;
3190 if ( abLocal.load() ) { 3191 if ( abLocal.load() ) {
3191 qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode ); 3192 qDebug("KA: Sync::AB loaded %s,sync mode %d",filename.latin1(), mode );
3192 bool external = false; 3193 bool external = false;
3193 bool isXML = false; 3194 bool isXML = false;
3194 if ( filename.right(4) == ".xml") { 3195 if ( filename.right(4) == ".xml") {
3195 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3196 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3196 isXML = true; 3197 isXML = true;
3197 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true ); 3198 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, true );
3198 } else { 3199 } else {
3199 external = !manager->mIsKapiFile; 3200 external = !manager->mIsKapiFile;
3200 if ( external ) { 3201 if ( external ) {
3201 qDebug("KA: Sync::Setting vcf mode to external "); 3202 qDebug("KA: Sync::Setting vcf mode to external ");
3202 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3203 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3203 AddressBook::Iterator it; 3204 AddressBook::Iterator it;
3204 for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { 3205 for ( it = abLocal.begin(); it != abLocal.end(); ++it ) {
3205 (*it).setID( mCurrentSyncDevice, (*it).uid() ); 3206 (*it).setID( mCurrentSyncDevice, (*it).uid() );
3206 (*it).computeCsum( mCurrentSyncDevice ); 3207 (*it).computeCsum( mCurrentSyncDevice );
3207 } 3208 }
3208 } 3209 }
3209 } 3210 }
3210 //AddressBook::Iterator it; 3211 //AddressBook::Iterator it;
3211 //QStringList vcards; 3212 //QStringList vcards;
3212 //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) { 3213 //for ( it = abLocal.begin(); it != abLocal.end(); ++it ) {
3213 // qDebug("Name %s ", (*it).familyName().latin1()); 3214 // qDebug("Name %s ", (*it).familyName().latin1());
3214 //} 3215 //}
3215 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode ); 3216 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, mode );
3216 syncManager->hideProgressBar(); 3217 syncManager->hideProgressBar();
3217 if ( syncOK ) { 3218 if ( syncOK ) {
3218 if ( syncManager->mWriteBackFile ) 3219 if ( syncManager->mWriteBackFile )
3219 { 3220 {
3220 if ( external ) 3221 if ( external )
3221 abLocal.removeSyncAddressees( !isXML); 3222 abLocal.removeSyncAddressees( !isXML);
3222 qDebug("KA: Sync::Saving remote AB "); 3223 qDebug("KA: Sync::Saving remote AB ");
3223 if ( ! abLocal.saveAB()) 3224 if ( ! abLocal.saveAB())
3224 qDebug("KA: sync::Error writing back AB to file "); 3225 qDebug("KA: sync::Error writing back AB to file ");
3225 if ( external ) { 3226 if ( external ) {
3226 // afterwrite processing 3227 // afterwrite processing
3227 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML); 3228 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice ,isXML);
3228 } 3229 }
3229 } 3230 }
3230 } 3231 }
3231 setModified(); 3232 setModified();
3232 3233
3233 } 3234 }
3234 abLocal.removeResources(); 3235 abLocal.removeResources();
3235 if ( syncOK ) 3236 if ( syncOK )
3236 mViewManager->refreshView(); 3237 mViewManager->refreshView();
3237 return syncOK; 3238 return syncOK;
3238 3239
3239} 3240}
3240void KABCore::removeSyncInfo( QString syncProfile) 3241void KABCore::removeSyncInfo( QString syncProfile)
3241{ 3242{
3242 qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1()); 3243 qDebug("KA: AB:removeSyncInfo for profile %s ", syncProfile.latin1());
3243 mAddressBook->removeSyncInfo( syncProfile ); 3244 mAddressBook->removeSyncInfo( syncProfile );
3244 setModified(); 3245 setModified();
3245} 3246}
3246 3247
3247 3248
3248//this is a overwritten callbackmethods from the syncinterface 3249//this is a overwritten callbackmethods from the syncinterface
3249bool KABCore::syncExternal(KSyncManager* manager, QString resource) 3250bool KABCore::syncExternal(KSyncManager* manager, QString resource)
3250{ 3251{
3251 if ( resource == "phone" ) 3252 if ( resource == "phone" )
3252 return syncPhone(); 3253 return syncPhone();
3253 disableBR( true ); 3254 disableBR( true );
3254 if ( manager != syncManager ) 3255 if ( manager != syncManager )
3255 qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager "); 3256 qDebug("KABCore::syncExternal:: ERROR! :: manager != syncManager ");
3256 QString mCurrentSyncDevice = manager->getCurrentSyncDevice(); 3257 QString mCurrentSyncDevice = manager->getCurrentSyncDevice();
3257 3258
3258 AddressBook abLocal( resource,"syncContact"); 3259 AddressBook abLocal( resource,"syncContact");
3259 bool syncOK = false; 3260 bool syncOK = false;
3260 message(i18n("Loading DTM address data..."), false); 3261 message(i18n("Loading DTM address data..."), false);
3261 if ( abLocal.load() ) { 3262 if ( abLocal.load() ) {
3262 qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1()); 3263 qDebug("KA: AB sharp loaded ,sync device %s",mCurrentSyncDevice.latin1());
3263 mGlobalSyncMode = SYNC_MODE_EXTERNAL; 3264 mGlobalSyncMode = SYNC_MODE_EXTERNAL;
3264 message(i18n("Sync preprocessing..."),false); 3265 message(i18n("Sync preprocessing..."),false);
3265 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false ); 3266 abLocal.preExternSync( mAddressBook ,mCurrentSyncDevice, false );
3266 message(i18n("Synchronizing..."),false); 3267 message(i18n("Synchronizing..."),false);
3267 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs ); 3268 syncOK = synchronizeAddressbooks( mAddressBook, &abLocal, syncManager->mSyncAlgoPrefs );
3268 syncManager->hideProgressBar(); 3269 syncManager->hideProgressBar();
3269 if ( syncOK ) { 3270 if ( syncOK ) {
3270 if ( syncManager->mWriteBackFile ) { 3271 if ( syncManager->mWriteBackFile ) {
3271 abLocal.removeSyncAddressees( false ); 3272 abLocal.removeSyncAddressees( false );
3272 message(i18n("Saving DTM address data..."),false); 3273 message(i18n("Saving DTM address data..."),false);
3273 abLocal.saveAB(); 3274 abLocal.saveAB();
3274 message(i18n("Sync postprocessing..."),false); 3275 message(i18n("Sync postprocessing..."),false);
3275 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true ); 3276 abLocal.postExternSync( mAddressBook,mCurrentSyncDevice, true );
3276 } 3277 }
3277 } else 3278 } else
3278 message( i18n("Sync cancelled or failed.") ); 3279 message( i18n("Sync cancelled or failed.") );
3279 setModified(); 3280 setModified();
3280 } 3281 }
3281 abLocal.removeResources(); 3282 abLocal.removeResources();
3282 if ( syncOK ) { 3283 if ( syncOK ) {
3283 mViewManager->refreshView(); 3284 mViewManager->refreshView();
diff --git a/libkdepim/externalapphandler.cpp b/libkdepim/externalapphandler.cpp
index 7200da9..f8f4c8a 100644
--- a/libkdepim/externalapphandler.cpp
+++ b/libkdepim/externalapphandler.cpp
@@ -387,815 +387,818 @@ ExternalAppHandler::~ExternalAppHandler()
387} 387}
388 388
389void ExternalAppHandler::receivedNameEmailUidList_Slot(const QString& uid, 389void ExternalAppHandler::receivedNameEmailUidList_Slot(const QString& uid,
390 const QStringList& nameList, 390 const QStringList& nameList,
391 const QStringList& emailList, 391 const QStringList& emailList,
392 const QStringList& uidList, 392 const QStringList& uidList,
393 const QStringList&, 393 const QStringList&,
394 const QStringList&, 394 const QStringList&,
395 const QStringList& ) 395 const QStringList& )
396{ 396{
397 // this method is a conevnient way to reduce the number of parameters I have to pass 397 // this method is a conevnient way to reduce the number of parameters I have to pass
398 emit receivedNameEmailUidListEvent(uid, nameList, emailList, uidList); 398 emit receivedNameEmailUidListEvent(uid, nameList, emailList, uidList);
399} 399}
400 400
401 401
402void ExternalAppHandler::loadConfig() 402void ExternalAppHandler::loadConfig()
403{ 403{
404 404
405 mDefaultItems.clear(); 405 mDefaultItems.clear();
406 mEmailAppAvailable = UNDEFINED; 406 mEmailAppAvailable = UNDEFINED;
407 mPhoneAppAvailable = UNDEFINED; 407 mPhoneAppAvailable = UNDEFINED;
408 mFaxAppAvailable = UNDEFINED; 408 mFaxAppAvailable = UNDEFINED;
409 mSMSAppAvailable = UNDEFINED; 409 mSMSAppAvailable = UNDEFINED;
410 mPagerAppAvailable = UNDEFINED; 410 mPagerAppAvailable = UNDEFINED;
411 mSIPAppAvailable = UNDEFINED; 411 mSIPAppAvailable = UNDEFINED;
412 412
413 QString opiepath = QString::fromLatin1( getenv("OPIEDIR") ); 413 QString opiepath = QString::fromLatin1( getenv("OPIEDIR") );
414 QString qtopiapath = QString::fromLatin1( getenv("QPEDIR") ); 414 QString qtopiapath = QString::fromLatin1( getenv("QPEDIR") );
415 QString qtpath = QString::fromLatin1( getenv("QTDIR") ); 415 QString qtpath = QString::fromLatin1( getenv("QTDIR") );
416 416
417 //if qtopiapath is not set, fallback to qt 417 //if qtopiapath is not set, fallback to qt
418 if (qtopiapath.isEmpty()) 418 if (qtopiapath.isEmpty())
419 qtopiapath = qtpath; 419 qtopiapath = qtpath;
420 420
421 //if opiepath is not set, fallback to qtopia 421 //if opiepath is not set, fallback to qtopia
422 if (opiepath.isEmpty()) 422 if (opiepath.isEmpty())
423 opiepath = qtopiapath; 423 opiepath = qtopiapath;
424 424
425 425
426 426
427 //mailclients 427 //mailclients
428 QString mailmsg1 = "writeMail(QString,QString)"; 428 QString mailmsg1 = "writeMail(QString,QString)";
429 QString mailmsg2 = "writeMail(QMap(QString,QString))"; 429 QString mailmsg2 = "writeMail(QMap(QString,QString))";
430 430
431 QString undefined = ""; 431 QString undefined = "";
432 432
433 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::NONE_EMC, "No email client installed", undefined, undefined, undefined, undefined, undefined); 433 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::NONE_EMC, "No email client installed", undefined, undefined, undefined, undefined, undefined);
434 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OTHER_EMC, "Userdefined email client", undefined, undefined, undefined, undefined, undefined); 434 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OTHER_EMC, "Userdefined email client", undefined, undefined, undefined, undefined, undefined);
435 435
436 if (( QFile::exists( qtopiapath + "/bin/ompi" )) || 436 if (( QFile::exists( qtopiapath + "/bin/ompi" )) ||
437 ( QFile::exists( opiepath + "/bin/ompi" )) || 437 ( QFile::exists( opiepath + "/bin/ompi" )) ||
438 ( QFile::exists( qtpath + "/bin/ompi" ))) 438 ( QFile::exists( qtpath + "/bin/ompi" )))
439 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OMPI_EMC, "OM/Pi email client", "QPE/Application/ompi", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2"); 439 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OMPI_EMC, "OM/Pi email client", "QPE/Application/ompi", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2");
440 440
441 if (( QFile::exists( qtopiapath + "/bin/qtmail" )) || 441 if (( QFile::exists( qtopiapath + "/bin/qtmail" )) ||
442 ( QFile::exists( qtpath + "/bin/qtmail" ))) 442 ( QFile::exists( qtpath + "/bin/qtmail" )))
443 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::QTOPIA_EMC, "Qtopia email client", "QPE/Application/qtmail", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2"); 443 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::QTOPIA_EMC, "Qtopia email client", "QPE/Application/qtmail", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2");
444 444
445 if ( QFile::exists( opiepath + "/bin/opiemail" )) 445 if ( QFile::exists( opiepath + "/bin/opiemail" ))
446 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OPIE_EMC, "Opie email client", "QPE/Application/opiemail", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2"); 446 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OPIE_EMC, "Opie email client", "QPE/Application/opiemail", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2");
447 447
448 if ( QFile::exists( opiepath + "/bin/mailit" )) 448 if ( QFile::exists( opiepath + "/bin/mailit" ))
449 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OPIE_MAILIT_EMC, "Opie mailit email client", "QPE/Application/mailit", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2"); 449 addDefaultAppItem(ExternalAppHandler::EMAIL, KPimGlobalPrefs::OPIE_MAILIT_EMC, "Opie mailit email client", "QPE/Application/mailit", mailmsg1, "%1;%2", mailmsg2, "TO=%1;ATTACHMENT=%2");
450 450
451 451
452 452
453 //phoneclients 453 //phoneclients
454 454
455 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::NONE_PHC, "No phone client installed", undefined, undefined, undefined, undefined, undefined); 455 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::NONE_PHC, "No phone client installed", undefined, undefined, undefined, undefined, undefined);
456 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::OTHER_PHC, "Other phone client", undefined, undefined, undefined, undefined, undefined); 456 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::OTHER_PHC, "Other phone client", undefined, undefined, undefined, undefined, undefined);
457 if (( QFile::exists( qtopiapath + "/bin/kppi" )) || 457 if (( QFile::exists( qtopiapath + "/bin/kppi" )) ||
458 ( QFile::exists( opiepath + "/bin/kppi" ))) 458 ( QFile::exists( opiepath + "/bin/kppi" )))
459 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::KPPI_PHC, "KP/Pi phone client", "QPE/Application/kppi", "-ring:%1", "", undefined, undefined); 459 addDefaultAppItem(ExternalAppHandler::PHONE, KPimGlobalPrefs::KPPI_PHC, "KP/Pi phone client", "QPE/Application/kppi", "-ring:%1", "", undefined, undefined);
460 460
461 //faxclients 461 //faxclients
462 addDefaultAppItem(ExternalAppHandler::FAX, KPimGlobalPrefs::NONE_FAC, "No fax client installed", undefined, undefined, undefined, undefined, undefined); 462 addDefaultAppItem(ExternalAppHandler::FAX, KPimGlobalPrefs::NONE_FAC, "No fax client installed", undefined, undefined, undefined, undefined, undefined);
463 addDefaultAppItem(ExternalAppHandler::FAX, KPimGlobalPrefs::OTHER_FAC, "Other fax client", undefined, undefined, undefined, undefined, undefined); 463 addDefaultAppItem(ExternalAppHandler::FAX, KPimGlobalPrefs::OTHER_FAC, "Other fax client", undefined, undefined, undefined, undefined, undefined);
464 464
465 //smsclients 465 //smsclients
466 addDefaultAppItem(ExternalAppHandler::SMS, KPimGlobalPrefs::NONE_SMC, "No sms client installed", undefined, undefined, undefined, undefined, undefined); 466 addDefaultAppItem(ExternalAppHandler::SMS, KPimGlobalPrefs::NONE_SMC, "No sms client installed", undefined, undefined, undefined, undefined, undefined);
467 addDefaultAppItem(ExternalAppHandler::SMS, KPimGlobalPrefs::OTHER_SMC, "Other sms client", undefined, undefined, undefined, undefined, undefined); 467 addDefaultAppItem(ExternalAppHandler::SMS, KPimGlobalPrefs::OTHER_SMC, "Other sms client", undefined, undefined, undefined, undefined, undefined);
468 468
469 //pagerclients 469 //pagerclients
470 addDefaultAppItem(ExternalAppHandler::PAGER, KPimGlobalPrefs::NONE_PAC, "No pager client installed", undefined, undefined, undefined, undefined, undefined); 470 addDefaultAppItem(ExternalAppHandler::PAGER, KPimGlobalPrefs::NONE_PAC, "No pager client installed", undefined, undefined, undefined, undefined, undefined);
471 addDefaultAppItem(ExternalAppHandler::PAGER, KPimGlobalPrefs::OTHER_PAC, "Other pager client", undefined, undefined, undefined, undefined, undefined); 471 addDefaultAppItem(ExternalAppHandler::PAGER, KPimGlobalPrefs::OTHER_PAC, "Other pager client", undefined, undefined, undefined, undefined, undefined);
472 472
473 //sipclients 473 //sipclients
474 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::NONE_SIC, "No SIP client installed", undefined, undefined, undefined, undefined, undefined); 474 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::NONE_SIC, "No SIP client installed", undefined, undefined, undefined, undefined, undefined);
475 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::OTHER_SIC, "Other SIP client", undefined, undefined, undefined, undefined, undefined); 475 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::OTHER_SIC, "Other SIP client", undefined, undefined, undefined, undefined, undefined);
476 if (( QFile::exists( qtopiapath + "/bin/kppi" )) || 476 if (( QFile::exists( qtopiapath + "/bin/kppi" )) ||
477 ( QFile::exists( opiepath + "/bin/kppi" ))) 477 ( QFile::exists( opiepath + "/bin/kppi" )))
478 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::KPPI_SIC, "KP/Pi SIP client", "QPE/Application/kppi", "-ring:%1", "", undefined, undefined); 478 addDefaultAppItem(ExternalAppHandler::SIP, KPimGlobalPrefs::KPPI_SIC, "KP/Pi SIP client", "QPE/Application/kppi", "-ring:%1", "", undefined, undefined);
479 479
480} 480}
481 481
482ExternalAppHandler *ExternalAppHandler::instance() 482ExternalAppHandler *ExternalAppHandler::instance()
483{ 483{
484 if ( !sInstance ) { 484 if ( !sInstance ) {
485 sInstance = staticDeleter.setObject( new ExternalAppHandler() ); 485 sInstance = staticDeleter.setObject( new ExternalAppHandler() );
486 sInstance->loadConfig(); 486 sInstance->loadConfig();
487 } 487 }
488 488
489 return sInstance; 489 return sInstance;
490} 490}
491 491
492void ExternalAppHandler::addDefaultAppItem(Types type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameter, const QString& message2, const QString& parameter2) 492void ExternalAppHandler::addDefaultAppItem(Types type, int id, const QString& label, const QString& channel, const QString& message, const QString& parameter, const QString& message2, const QString& parameter2)
493{ 493{
494 DefaultAppItem* dai = new DefaultAppItem(type, id, label, channel, message, parameter, message2, parameter2); 494 DefaultAppItem* dai = new DefaultAppItem(type, id, label, channel, message, parameter, message2, parameter2);
495 // qDebug("%d %d %s %s ", type, id, label.latin1(), channel.latin1() ); 495 // qDebug("%d %d %s %s ", type, id, label.latin1(), channel.latin1() );
496 mDefaultItems.append(dai); 496 mDefaultItems.append(dai);
497} 497}
498 498
499 499
500QList<DefaultAppItem> ExternalAppHandler::getAvailableDefaultItems(Types type) 500QList<DefaultAppItem> ExternalAppHandler::getAvailableDefaultItems(Types type)
501{ 501{
502 QList<DefaultAppItem> list; 502 QList<DefaultAppItem> list;
503 503
504 DefaultAppItem* dai; 504 DefaultAppItem* dai;
505 505
506 for ( dai=mDefaultItems.first(); dai != 0; dai=mDefaultItems.next() ) 506 for ( dai=mDefaultItems.first(); dai != 0; dai=mDefaultItems.next() )
507 { 507 {
508 if (dai->_type == type) 508 if (dai->_type == type)
509 list.append(dai); 509 list.append(dai);
510 } 510 }
511 511
512 return list; 512 return list;
513} 513}
514 514
515DefaultAppItem* ExternalAppHandler::getDefaultItem(Types type, int clientid) 515DefaultAppItem* ExternalAppHandler::getDefaultItem(Types type, int clientid)
516{ 516{
517 DefaultAppItem* dai; 517 DefaultAppItem* dai;
518 518
519 for ( dai=mDefaultItems.first(); dai != 0; dai=mDefaultItems.next() ) 519 for ( dai=mDefaultItems.first(); dai != 0; dai=mDefaultItems.next() )
520 { 520 {
521 if (dai->_type == type && dai->_id == clientid) 521 if (dai->_type == type && dai->_id == clientid)
522 return dai; 522 return dai;
523 } 523 }
524 524
525 return 0; 525 return 0;
526} 526}
527 527
528bool ExternalAppHandler::isEmailAppAvailable() 528bool ExternalAppHandler::isEmailAppAvailable()
529{ 529{
530#ifndef DESKTOP_VERSION 530#ifndef DESKTOP_VERSION
531 if (mEmailAppAvailable == UNDEFINED) 531 if (mEmailAppAvailable == UNDEFINED)
532 { 532 {
533 int client = KPimGlobalPrefs::instance()->mEmailClient; 533 int client = KPimGlobalPrefs::instance()->mEmailClient;
534 if (client == KPimGlobalPrefs::NONE_EMC) 534 if (client == KPimGlobalPrefs::NONE_EMC)
535 mEmailAppAvailable = UNAVAILABLE; 535 mEmailAppAvailable = UNAVAILABLE;
536 else 536 else
537 mEmailAppAvailable = AVAILABLE; 537 mEmailAppAvailable = AVAILABLE;
538 } 538 }
539 return (mEmailAppAvailable == AVAILABLE); 539 return (mEmailAppAvailable == AVAILABLE);
540 540
541#else //DESKTOP_VERSION 541#else //DESKTOP_VERSION
542 return false; 542 return false;
543#endif //DESKTOP_VERSION 543#endif //DESKTOP_VERSION
544} 544}
545 545
546bool ExternalAppHandler::isSMSAppAvailable() 546bool ExternalAppHandler::isSMSAppAvailable()
547{ 547{
548#ifndef DESKTOP_VERSION 548#ifndef DESKTOP_VERSION
549 if (mSMSAppAvailable == UNDEFINED) 549 if (mSMSAppAvailable == UNDEFINED)
550 { 550 {
551 int client = KPimGlobalPrefs::instance()->mSMSClient; 551 int client = KPimGlobalPrefs::instance()->mSMSClient;
552 if (client == KPimGlobalPrefs::NONE_SMC) 552 if (client == KPimGlobalPrefs::NONE_SMC)
553 mSMSAppAvailable = UNAVAILABLE; 553 mSMSAppAvailable = UNAVAILABLE;
554 else 554 else
555 mSMSAppAvailable = AVAILABLE; 555 mSMSAppAvailable = AVAILABLE;
556 } 556 }
557 557
558 return (mSMSAppAvailable == AVAILABLE); 558 return (mSMSAppAvailable == AVAILABLE);
559#else //DESKTOP_VERSION 559#else //DESKTOP_VERSION
560 return false; 560 return false;
561#endif //DESKTOP_VERSION 561#endif //DESKTOP_VERSION
562} 562}
563 563
564bool ExternalAppHandler::isPhoneAppAvailable() 564bool ExternalAppHandler::isPhoneAppAvailable()
565{ 565{
566#ifndef DESKTOP_VERSION 566#ifndef DESKTOP_VERSION
567 if (mPhoneAppAvailable == UNDEFINED) 567 if (mPhoneAppAvailable == UNDEFINED)
568 { 568 {
569 int client = KPimGlobalPrefs::instance()->mPhoneClient; 569 int client = KPimGlobalPrefs::instance()->mPhoneClient;
570 if (client == KPimGlobalPrefs::NONE_PHC) 570 if (client == KPimGlobalPrefs::NONE_PHC)
571 mPhoneAppAvailable = UNAVAILABLE; 571 mPhoneAppAvailable = UNAVAILABLE;
572 else 572 else
573 mPhoneAppAvailable = AVAILABLE; 573 mPhoneAppAvailable = AVAILABLE;
574 } 574 }
575 575
576 return (mPhoneAppAvailable == AVAILABLE); 576 return (mPhoneAppAvailable == AVAILABLE);
577#else //DESKTOP_VERSION 577#else //DESKTOP_VERSION
578 return false; 578 return false;
579#endif //DESKTOP_VERSION 579#endif //DESKTOP_VERSION
580} 580}
581 581
582bool ExternalAppHandler::isFaxAppAvailable() 582bool ExternalAppHandler::isFaxAppAvailable()
583{ 583{
584#ifndef DESKTOP_VERSION 584#ifndef DESKTOP_VERSION
585 if (mFaxAppAvailable == UNDEFINED) 585 if (mFaxAppAvailable == UNDEFINED)
586 { 586 {
587 int client = KPimGlobalPrefs::instance()->mFaxClient; 587 int client = KPimGlobalPrefs::instance()->mFaxClient;
588 if (client == KPimGlobalPrefs::NONE_FAC) 588 if (client == KPimGlobalPrefs::NONE_FAC)
589 mFaxAppAvailable = UNAVAILABLE; 589 mFaxAppAvailable = UNAVAILABLE;
590 else 590 else
591 mFaxAppAvailable = AVAILABLE; 591 mFaxAppAvailable = AVAILABLE;
592 } 592 }
593 593
594 return (mFaxAppAvailable == AVAILABLE); 594 return (mFaxAppAvailable == AVAILABLE);
595#else //DESKTOP_VERSION 595#else //DESKTOP_VERSION
596 return false; 596 return false;
597#endif //DESKTOP_VERSION 597#endif //DESKTOP_VERSION
598} 598}
599 599
600bool ExternalAppHandler::isPagerAppAvailable() 600bool ExternalAppHandler::isPagerAppAvailable()
601{ 601{
602#ifndef DESKTOP_VERSION 602#ifndef DESKTOP_VERSION
603 if (mPagerAppAvailable == UNDEFINED) 603 if (mPagerAppAvailable == UNDEFINED)
604 { 604 {
605 int client = KPimGlobalPrefs::instance()->mPagerClient; 605 int client = KPimGlobalPrefs::instance()->mPagerClient;
606 if (client == KPimGlobalPrefs::NONE_PAC) 606 if (client == KPimGlobalPrefs::NONE_PAC)
607 mPagerAppAvailable = UNAVAILABLE; 607 mPagerAppAvailable = UNAVAILABLE;
608 else 608 else
609 mPagerAppAvailable = AVAILABLE; 609 mPagerAppAvailable = AVAILABLE;
610 } 610 }
611 611
612 return (mPagerAppAvailable == AVAILABLE); 612 return (mPagerAppAvailable == AVAILABLE);
613#else //DESKTOP_VERSION 613#else //DESKTOP_VERSION
614 return false; 614 return false;
615#endif //DESKTOP_VERSION 615#endif //DESKTOP_VERSION
616} 616}
617 617
618 618
619bool ExternalAppHandler::isSIPAppAvailable() 619bool ExternalAppHandler::isSIPAppAvailable()
620{ 620{
621#ifndef DESKTOP_VERSION 621#ifndef DESKTOP_VERSION
622 if (mSIPAppAvailable == UNDEFINED) 622 if (mSIPAppAvailable == UNDEFINED)
623 { 623 {
624 int client = KPimGlobalPrefs::instance()->mSipClient; 624 int client = KPimGlobalPrefs::instance()->mSipClient;
625 if (client == KPimGlobalPrefs::NONE_SIC) 625 if (client == KPimGlobalPrefs::NONE_SIC)
626 mSIPAppAvailable = UNAVAILABLE; 626 mSIPAppAvailable = UNAVAILABLE;
627 else 627 else
628 mSIPAppAvailable = AVAILABLE; 628 mSIPAppAvailable = AVAILABLE;
629 } 629 }
630 630
631 return (mSIPAppAvailable == AVAILABLE); 631 return (mSIPAppAvailable == AVAILABLE);
632#else //DESKTOP_VERSION 632#else //DESKTOP_VERSION
633 return false; 633 return false;
634#endif //DESKTOP_VERSION 634#endif //DESKTOP_VERSION
635} 635}
636 636
637/************************************************************************** 637/**************************************************************************
638 * 638 *
639 **************************************************************************/ 639 **************************************************************************/
640 640
641 641
642//calls the emailapplication with a number of attachments that need to be send (Seperated by Comma) 642//calls the emailapplication with a number of attachments that need to be send (Seperated by Comma)
643bool ExternalAppHandler::mailToMultipleContacts( const QString& emails, const QString& urls ) 643bool ExternalAppHandler::mailToMultipleContacts( const QString& emails, const QString& urls )
644{ 644{
645 645
646#ifndef DESKTOP_VERSION 646#ifndef DESKTOP_VERSION
647 QString channel; 647 QString channel;
648 QString message2; 648 QString message2;
649 QString parameters2; 649 QString parameters2;
650 650
651 651
652 int client = KPimGlobalPrefs::instance()->mEmailClient; 652 int client = KPimGlobalPrefs::instance()->mEmailClient;
653 if (client == KPimGlobalPrefs::OTHER_EMC) 653 if (client == KPimGlobalPrefs::OTHER_EMC)
654 { 654 {
655 channel = KPimGlobalPrefs::instance()->mEmailOtherChannel; 655 channel = KPimGlobalPrefs::instance()->mEmailOtherChannel;
656 message2 = KPimGlobalPrefs::instance()->mEmailOtherMessage; 656 message2 = KPimGlobalPrefs::instance()->mEmailOtherMessage;
657 parameters2 = KPimGlobalPrefs::instance()->mEmailOtherMessageParameters; 657 parameters2 = KPimGlobalPrefs::instance()->mEmailOtherMessageParameters;
658 } 658 }
659 else 659 else
660 { 660 {
661 DefaultAppItem* dai = getDefaultItem(EMAIL, client); 661 DefaultAppItem* dai = getDefaultItem(EMAIL, client);
662 if (!dai) 662 if (!dai)
663 { 663 {
664 qDebug("could not find configured email application."); 664 qDebug("could not find configured email application.");
665 return false; 665 return false;
666 } 666 }
667 channel = dai->_channel; 667 channel = dai->_channel;
668 message2 = dai->_message2; 668 message2 = dai->_message2;
669 parameters2 = dai->_parameters2; 669 parameters2 = dai->_parameters2;
670 } 670 }
671 671
672 //first check if one of the mailers need the emails right in the message. 672 //first check if one of the mailers need the emails right in the message.
673 message2 = translateMessage(message2, emails, urls); 673 message2 = translateMessage(message2, emails, urls);
674 674
675 675
676#ifdef DEBUG_EXT_APP_HANDLER 676#ifdef DEBUG_EXT_APP_HANDLER
677 qDebug("4Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message2.latin1()); 677 qDebug("4Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message2.latin1());
678 qDebug("passing emailadresses(%s), attachmenturls(%s) as parameters in the form %s to QCopEnvelope", emails.latin1() , urls.latin1(), parameters2.latin1()); 678 qDebug("passing emailadresses(%s), attachmenturls(%s) as parameters in the form %s to QCopEnvelope", emails.latin1() , urls.latin1(), parameters2.latin1());
679#endif 679#endif
680 680
681 681
682 QCopEnvelope e(channel.latin1(), message2.latin1()); 682 QCopEnvelope e(channel.latin1(), message2.latin1());
683 //US we need no names in the To field. The emailadresses are enough 683 //US we need no names in the To field. The emailadresses are enough
684 684
685 passParameters(&e, parameters2, emails, urls); 685 passParameters(&e, parameters2, emails, urls);
686 686
687 687
688 688
689#else 689#else
690 KMessageBox::sorry( 0, i18n( "This version does not support the sending of emails." ) ); 690 KMessageBox::sorry( 0, i18n( "This version does not support the sending of emails." ) );
691#endif 691#endif
692 692
693 return true; 693 return true;
694} 694}
695 695
696/************************************************************************** 696/**************************************************************************
697 * 697 *
698 **************************************************************************/ 698 **************************************************************************/
699 699
700 700
701//calls the emailapplication and creates a mail with parameter emails as recipients 701//calls the emailapplication and creates a mail with parameter emails as recipients
702bool ExternalAppHandler::mailToOneContact( const QString& name, const QString& emailadress ) 702bool ExternalAppHandler::mailToOneContact( const QString& name, const QString& emailadress )
703{ 703{
704#ifndef DESKTOP_VERSION 704#ifndef DESKTOP_VERSION
705 QString channel; 705 QString channel;
706 QString message; 706 QString message;
707 QString parameters; 707 QString parameters;
708 708
709 709
710 int client = KPimGlobalPrefs::instance()->mEmailClient; 710 int client = KPimGlobalPrefs::instance()->mEmailClient;
711 if (client == KPimGlobalPrefs::OTHER_EMC) 711 if (client == KPimGlobalPrefs::OTHER_EMC)
712 { 712 {
713 channel = KPimGlobalPrefs::instance()->mEmailOtherChannel; 713 channel = KPimGlobalPrefs::instance()->mEmailOtherChannel;
714 message = KPimGlobalPrefs::instance()->mEmailOtherMessage; 714 message = KPimGlobalPrefs::instance()->mEmailOtherMessage;
715 parameters = KPimGlobalPrefs::instance()->mEmailOtherMessageParameters; 715 parameters = KPimGlobalPrefs::instance()->mEmailOtherMessageParameters;
716 } 716 }
717 else 717 else
718 { 718 {
719 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(EMAIL, client); 719 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(EMAIL, client);
720 if (!dai) 720 if (!dai)
721 { 721 {
722 qDebug("could not find configured email application."); 722 qDebug("could not find configured email application.");
723 return false; 723 return false;
724 } 724 }
725 channel = dai->_channel; 725 channel = dai->_channel;
726 message = dai->_message; 726 message = dai->_message;
727 parameters = dai->_parameters; 727 parameters = dai->_parameters;
728 } 728 }
729 729
730 730
731 //first check if one of the mailers need the emails right in the message. 731 //first check if one of the mailers need the emails right in the message.
732 message = translateMessage(message, name, emailadress); 732 message = translateMessage(message, name, emailadress);
733 733
734 734
735#ifdef DEBUG_EXT_APP_HANDLER 735#ifdef DEBUG_EXT_APP_HANDLER
736 qDebug("5Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 736 qDebug("5Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
737 qDebug("passing name(%s), emailadresses(%s) as parameters in the form %s to QCopEnvelope", name.latin1(), emailadress.latin1(), parameters.latin1()); 737 qDebug("passing name(%s), emailadresses(%s) as parameters in the form %s to QCopEnvelope", name.latin1(), emailadress.latin1(), parameters.latin1());
738#endif 738#endif
739 739
740 QCopEnvelope e(channel.latin1(), message.latin1()); 740 QCopEnvelope e(channel.latin1(), message.latin1());
741 //US we need no names in the To field. The emailadresses are enough 741 //US we need no names in the To field. The emailadresses are enough
742 742
743 passParameters(&e, parameters, name, emailadress); 743 passParameters(&e, parameters, name, emailadress);
744 744
745 745
746#else 746#else
747 KMessageBox::sorry( 0, i18n( "This version does not support the sending of emails." ) ); 747 KMessageBox::sorry( 0, i18n( "This version does not support the sending of emails." ) );
748#endif 748#endif
749 749
750 750
751 return true; 751 return true;
752} 752}
753 753
754/************************************************************************** 754/**************************************************************************
755 * 755 *
756 **************************************************************************/ 756 **************************************************************************/
757 757
758//calls the emailapplication and creates a mail with parameter as recipients 758//calls the emailapplication and creates a mail with parameter as recipients
759// parameters format is 759// parameters format is
760// NAME <EMAIL>:SUBJECT 760// NAME <EMAIL>:SUBJECT
761bool ExternalAppHandler::mailToOneContact( const QString& adressline ) 761bool ExternalAppHandler::mailToOneContact( const QString& adressline )
762{ 762{
763 QString line = adressline; 763 QString line = adressline;
764 764
765 int first = line.find( "<"); 765 int first = line.find( "<");
766 int last = line.find( ">"); 766 int last = line.find( ">");
767 QString name = line.left(first); 767 QString name = line.left(first);
768 QString emailadress = line.mid(first+1, last-first-1); 768 QString emailadress = line.mid(first+1, last-first-1);
769 769
770 //Subject can not be handled right now. 770 //Subject can not be handled right now.
771 return mailToOneContact( name, emailadress ); 771 return mailToOneContact( name, emailadress );
772 772
773} 773}
774 774
775 775
776/************************************************************************** 776/**************************************************************************
777 * 777 *
778 **************************************************************************/ 778 **************************************************************************/
779 779
780//calls the phoneapplication with the number 780//calls the phoneapplication with the number
781bool ExternalAppHandler::callByPhone( const QString& phonenumber ) 781bool ExternalAppHandler::callByPhone( const QString& phonenumber )
782{ 782{
783#ifndef DESKTOP_VERSION 783#ifndef DESKTOP_VERSION
784 QString channel; 784 QString channel;
785 QString message; 785 QString message;
786 QString parameters; 786 QString parameters;
787 787
788 788
789 int client = KPimGlobalPrefs::instance()->mPhoneClient; 789 int client = KPimGlobalPrefs::instance()->mPhoneClient;
790 if (client == KPimGlobalPrefs::OTHER_PHC) 790 if (client == KPimGlobalPrefs::OTHER_PHC)
791 { 791 {
792 channel = KPimGlobalPrefs::instance()->mPhoneOtherChannel; 792 channel = KPimGlobalPrefs::instance()->mPhoneOtherChannel;
793 message = KPimGlobalPrefs::instance()->mPhoneOtherMessage; 793 message = KPimGlobalPrefs::instance()->mPhoneOtherMessage;
794 parameters = KPimGlobalPrefs::instance()->mPhoneOtherMessageParameters; 794 parameters = KPimGlobalPrefs::instance()->mPhoneOtherMessageParameters;
795 } 795 }
796 else 796 else
797 { 797 {
798 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(PHONE, client); 798 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(PHONE, client);
799 if (!dai) 799 if (!dai)
800 { 800 {
801 qDebug("could not find configured phone application."); 801 qDebug("could not find configured phone application.");
802 return false; 802 return false;
803 } 803 }
804 channel = dai->_channel; 804 channel = dai->_channel;
805 message = dai->_message; 805 message = dai->_message;
806 parameters = dai->_parameters; 806 parameters = dai->_parameters;
807 } 807 }
808 808
809 809
810 //first check if one of the mailers need the emails right in the message. 810 //first check if one of the mailers need the emails right in the message.
811 message = translateMessage(message, phonenumber, ""); 811 message = translateMessage(message, phonenumber, "");
812 812
813 813
814#ifdef DEBUG_EXT_APP_HANDLER 814#ifdef DEBUG_EXT_APP_HANDLER
815 qDebug("6Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 815 qDebug("6Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
816 qDebug("passing phonenumber(%s) as parameter in the form %s to QCopEnvelope", phonenumber.latin1(), parameters.latin1()); 816 qDebug("passing phonenumber(%s) as parameter in the form %s to QCopEnvelope", phonenumber.latin1(), parameters.latin1());
817#endif 817#endif
818 818
819 QCopEnvelope e(channel.latin1(), message.latin1()); 819 QCopEnvelope e(channel.latin1(), message.latin1());
820 //US we need no names in the To field. The emailadresses are enough 820 //US we need no names in the To field. The emailadresses are enough
821 821
822 passParameters(&e, parameters, phonenumber, ""); 822 passParameters(&e, parameters, phonenumber, "");
823 823
824 824
825#else 825#else
826 KMessageBox::sorry( 0, i18n( "This version does not support phonecalls." ) ); 826 KMessageBox::sorry( 0, i18n( "This version does not support phonecalls." ) );
827#endif 827#endif
828 828
829 829
830 return true; 830 return true;
831} 831}
832 832
833/************************************************************************** 833/**************************************************************************
834 * 834 *
835 **************************************************************************/ 835 **************************************************************************/
836 836
837//calls the smsapplication with the number 837//calls the smsapplication with the number
838bool ExternalAppHandler::callBySMS( const QString& phonenumber ) 838bool ExternalAppHandler::callBySMS( const QString& phonenumber )
839{ 839{
840#ifndef DESKTOP_VERSION 840#ifndef DESKTOP_VERSION
841 QString channel; 841 QString channel;
842 QString message; 842 QString message;
843 QString parameters; 843 QString parameters;
844 844
845 845
846 int client = KPimGlobalPrefs::instance()->mSMSClient; 846 int client = KPimGlobalPrefs::instance()->mSMSClient;
847 if (client == KPimGlobalPrefs::OTHER_SMC) 847 if (client == KPimGlobalPrefs::OTHER_SMC)
848 { 848 {
849 channel = KPimGlobalPrefs::instance()->mSMSOtherChannel; 849 channel = KPimGlobalPrefs::instance()->mSMSOtherChannel;
850 message = KPimGlobalPrefs::instance()->mSMSOtherMessage; 850 message = KPimGlobalPrefs::instance()->mSMSOtherMessage;
851 parameters = KPimGlobalPrefs::instance()->mSMSOtherMessageParameters; 851 parameters = KPimGlobalPrefs::instance()->mSMSOtherMessageParameters;
852 } 852 }
853 else 853 else
854 { 854 {
855 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(SMS, client); 855 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(SMS, client);
856 if (!dai) 856 if (!dai)
857 { 857 {
858 qDebug("could not find configured sms application."); 858 qDebug("could not find configured sms application.");
859 return false; 859 return false;
860 } 860 }
861 channel = dai->_channel; 861 channel = dai->_channel;
862 message = dai->_message; 862 message = dai->_message;
863 parameters = dai->_parameters; 863 parameters = dai->_parameters;
864 } 864 }
865 865
866 866
867 //first check if one of the mailers need the emails right in the message. 867 //first check if one of the mailers need the emails right in the message.
868 message = translateMessage(message, phonenumber, ""); 868 message = translateMessage(message, phonenumber, "");
869 869
870 870
871#ifdef DEBUG_EXT_APP_HANDLER 871#ifdef DEBUG_EXT_APP_HANDLER
872 qDebug("7Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 872 qDebug("7Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
873 qDebug("passing phonenumber(%s) as parameter in the form %s to QCopEnvelope", phonenumber.latin1(), parameters.latin1()); 873 qDebug("passing phonenumber(%s) as parameter in the form %s to QCopEnvelope", phonenumber.latin1(), parameters.latin1());
874#endif 874#endif
875 875
876 QCopEnvelope e(channel.latin1(), message.latin1()); 876 QCopEnvelope e(channel.latin1(), message.latin1());
877 //US we need no names in the To field. The emailadresses are enough 877 //US we need no names in the To field. The emailadresses are enough
878 878
879 passParameters(&e, parameters, phonenumber, ""); 879 passParameters(&e, parameters, phonenumber, "");
880 880
881 881
882#else 882#else
883 KMessageBox::sorry( 0, i18n( "This version does not support the sending of sms." ) ); 883 KMessageBox::sorry( 0, i18n( "This version does not support the sending of sms." ) );
884#endif 884#endif
885 885
886 886
887 return true; 887 return true;
888} 888}
889 889
890/************************************************************************** 890/**************************************************************************
891 * 891 *
892 **************************************************************************/ 892 **************************************************************************/
893 893
894//calls the pagerapplication with the number 894//calls the pagerapplication with the number
895bool ExternalAppHandler::callByPager( const QString& pagernumber ) 895bool ExternalAppHandler::callByPager( const QString& pagernumber )
896{ 896{
897#ifndef DESKTOP_VERSION 897#ifndef DESKTOP_VERSION
898 QString channel; 898 QString channel;
899 QString message; 899 QString message;
900 QString parameters; 900 QString parameters;
901 901
902 902
903 int client = KPimGlobalPrefs::instance()->mPagerClient; 903 int client = KPimGlobalPrefs::instance()->mPagerClient;
904 if (client == KPimGlobalPrefs::OTHER_PAC) 904 if (client == KPimGlobalPrefs::OTHER_PAC)
905 { 905 {
906 channel = KPimGlobalPrefs::instance()->mPagerOtherChannel; 906 channel = KPimGlobalPrefs::instance()->mPagerOtherChannel;
907 message = KPimGlobalPrefs::instance()->mPagerOtherMessage; 907 message = KPimGlobalPrefs::instance()->mPagerOtherMessage;
908 parameters = KPimGlobalPrefs::instance()->mPagerOtherMessageParameters; 908 parameters = KPimGlobalPrefs::instance()->mPagerOtherMessageParameters;
909 } 909 }
910 else 910 else
911 { 911 {
912 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(PAGER, client); 912 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(PAGER, client);
913 if (!dai) 913 if (!dai)
914 { 914 {
915 qDebug("could not find configured pager application."); 915 qDebug("could not find configured pager application.");
916 return false; 916 return false;
917 } 917 }
918 channel = dai->_channel; 918 channel = dai->_channel;
919 message = dai->_message; 919 message = dai->_message;
920 parameters = dai->_parameters; 920 parameters = dai->_parameters;
921 } 921 }
922 922
923 923
924 //first check if one of the mailers need the emails right in the message. 924 //first check if one of the mailers need the emails right in the message.
925 message = translateMessage(message, pagernumber, ""); 925 message = translateMessage(message, pagernumber, "");
926 926
927 927
928#ifdef DEBUG_EXT_APP_HANDLER 928#ifdef DEBUG_EXT_APP_HANDLER
929 qDebug("8Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 929 qDebug("8Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
930 qDebug("passing pagernumber(%s) as parameter in the form %s to QCopEnvelope", pagernumber.latin1(), parameters.latin1()); 930 qDebug("passing pagernumber(%s) as parameter in the form %s to QCopEnvelope", pagernumber.latin1(), parameters.latin1());
931#endif 931#endif
932 932
933 QCopEnvelope e(channel.latin1(), message.latin1()); 933 QCopEnvelope e(channel.latin1(), message.latin1());
934 //US we need no names in the To field. The emailadresses are enough 934 //US we need no names in the To field. The emailadresses are enough
935 935
936 passParameters(&e, parameters, pagernumber, ""); 936 passParameters(&e, parameters, pagernumber, "");
937 937
938 938
939#else 939#else
940 KMessageBox::sorry( 0, i18n( "This version does not support paging." ) ); 940 KMessageBox::sorry( 0, i18n( "This version does not support paging." ) );
941#endif 941#endif
942 942
943 943
944 return true; 944 return true;
945} 945}
946 946
947/************************************************************************** 947/**************************************************************************
948 * 948 *
949 **************************************************************************/ 949 **************************************************************************/
950 950
951//calls the faxapplication with the number 951//calls the faxapplication with the number
952bool ExternalAppHandler::callByFax( const QString& faxnumber ) 952bool ExternalAppHandler::callByFax( const QString& faxnumber )
953{ 953{
954#ifndef DESKTOP_VERSION 954#ifndef DESKTOP_VERSION
955 QString channel; 955 QString channel;
956 QString message; 956 QString message;
957 QString parameters; 957 QString parameters;
958 958
959 959
960 int client = KPimGlobalPrefs::instance()->mFaxClient; 960 int client = KPimGlobalPrefs::instance()->mFaxClient;
961 if (client == KPimGlobalPrefs::OTHER_FAC) 961 if (client == KPimGlobalPrefs::OTHER_FAC)
962 { 962 {
963 channel = KPimGlobalPrefs::instance()->mFaxOtherChannel; 963 channel = KPimGlobalPrefs::instance()->mFaxOtherChannel;
964 message = KPimGlobalPrefs::instance()->mFaxOtherMessage; 964 message = KPimGlobalPrefs::instance()->mFaxOtherMessage;
965 parameters = KPimGlobalPrefs::instance()->mFaxOtherMessageParameters; 965 parameters = KPimGlobalPrefs::instance()->mFaxOtherMessageParameters;
966 } 966 }
967 else 967 else
968 { 968 {
969 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(FAX, client); 969 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(FAX, client);
970 if (!dai) 970 if (!dai)
971 { 971 {
972 qDebug("could not find configured fax application."); 972 qDebug("could not find configured fax application.");
973 return false; 973 return false;
974 } 974 }
975 channel = dai->_channel; 975 channel = dai->_channel;
976 message = dai->_message; 976 message = dai->_message;
977 parameters = dai->_parameters; 977 parameters = dai->_parameters;
978 } 978 }
979 979
980 980
981 //first check if one of the mailers need the emails right in the message. 981 //first check if one of the mailers need the emails right in the message.
982 message = translateMessage(message, faxnumber, ""); 982 message = translateMessage(message, faxnumber, "");
983 983
984 984
985#ifdef DEBUG_EXT_APP_HANDLER 985#ifdef DEBUG_EXT_APP_HANDLER
986 qDebug("9Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 986 qDebug("9Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
987 qDebug("passing faxnumber(%s) as parameter in the form %s to QCopEnvelope", faxnumber.latin1(), parameters.latin1()); 987 qDebug("passing faxnumber(%s) as parameter in the form %s to QCopEnvelope", faxnumber.latin1(), parameters.latin1());
988#endif 988#endif
989 989
990 QCopEnvelope e(channel.latin1(), message.latin1()); 990 QCopEnvelope e(channel.latin1(), message.latin1());
991 //US we need no names in the To field. The emailadresses are enough 991 //US we need no names in the To field. The emailadresses are enough
992 992
993 passParameters(&e, parameters, faxnumber, ""); 993 passParameters(&e, parameters, faxnumber, "");
994 994
995 995
996#else 996#else
997 KMessageBox::sorry( 0, i18n( "This version does not support the sending of faxes." ) ); 997 KMessageBox::sorry( 0, i18n( "This version does not support the sending of faxes." ) );
998#endif 998#endif
999 999
1000 1000
1001 return true; 1001 return true;
1002} 1002}
1003 1003
1004/************************************************************************** 1004/**************************************************************************
1005 * 1005 *
1006 **************************************************************************/ 1006 **************************************************************************/
1007 1007
1008//calls the sipapplication with the number 1008//calls the sipapplication with the number
1009bool ExternalAppHandler::callBySIP( const QString& sipnumber ) 1009bool ExternalAppHandler::callBySIP( const QString& sipnumber )
1010{ 1010{
1011#ifndef DESKTOP_VERSION 1011#ifndef DESKTOP_VERSION
1012 QString channel; 1012 QString channel;
1013 QString message; 1013 QString message;
1014 QString parameters; 1014 QString parameters;
1015 1015
1016 1016
1017 int client = KPimGlobalPrefs::instance()->mSipClient; 1017 int client = KPimGlobalPrefs::instance()->mSipClient;
1018 if (client == KPimGlobalPrefs::OTHER_SIC) 1018 if (client == KPimGlobalPrefs::OTHER_SIC)
1019 { 1019 {
1020 channel = KPimGlobalPrefs::instance()->mSipOtherChannel; 1020 channel = KPimGlobalPrefs::instance()->mSipOtherChannel;
1021 message = KPimGlobalPrefs::instance()->mSipOtherMessage; 1021 message = KPimGlobalPrefs::instance()->mSipOtherMessage;
1022 parameters = KPimGlobalPrefs::instance()->mSipOtherMessageParameters; 1022 parameters = KPimGlobalPrefs::instance()->mSipOtherMessageParameters;
1023 } 1023 }
1024 else 1024 else
1025 { 1025 {
1026 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(SIP, client); 1026 DefaultAppItem* dai = ExternalAppHandler::getDefaultItem(SIP, client);
1027 if (!dai) 1027 if (!dai)
1028 { 1028 {
1029 qDebug("could not find configured sip application."); 1029 qDebug("could not find configured sip application.");
1030 return false; 1030 return false;
1031 } 1031 }
1032 channel = dai->_channel; 1032 channel = dai->_channel;
1033 message = dai->_message; 1033 message = dai->_message;
1034 parameters = dai->_parameters; 1034 parameters = dai->_parameters;
1035 } 1035 }
1036 1036
1037 1037
1038 //first check if one of the sip apps need the emails right in the message. 1038 //first check if one of the sip apps need the emails right in the message.
1039 message = translateMessage(message, sipnumber, ""); 1039 message = translateMessage(message, sipnumber, "");
1040 1040
1041 1041
1042#ifdef DEBUG_EXT_APP_HANDLER 1042#ifdef DEBUG_EXT_APP_HANDLER
1043 qDebug("10Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1()); 1043 qDebug("10Using QCopEnvelope e(\"%s\",\"%s\")", channel.latin1(), message.latin1());
1044 qDebug("passing sipnumber(%s) as parameter in the form %s to QCopEnvelope", sipnumber.latin1(), parameters.latin1()); 1044 qDebug("passing sipnumber(%s) as parameter in the form %s to QCopEnvelope", sipnumber.latin1(), parameters.latin1());
1045#endif 1045#endif
1046 1046
1047 QCopEnvelope e(channel.latin1(), message.latin1()); 1047 QCopEnvelope e(channel.latin1(), message.latin1());
1048 //US we need no names in the To field. The emailadresses are enough 1048 //US we need no names in the To field. The emailadresses are enough
1049 1049
1050 passParameters(&e, parameters, sipnumber, ""); 1050 passParameters(&e, parameters, sipnumber, "");
1051 1051
1052 1052
1053#else 1053#else
1054 KMessageBox::sorry( 0, i18n( "This version does not support sip." ) ); 1054 KMessageBox::sorry( 0, i18n( "This version does not support sip." ) );
1055#endif 1055#endif
1056 1056
1057 1057
1058 return true; 1058 return true;
1059} 1059}
1060 1060
1061 1061
1062/************************************************************************** 1062/**************************************************************************
1063 * 1063 *
1064 **************************************************************************/ 1064 **************************************************************************/
1065 1065
1066 1066
1067QString& ExternalAppHandler::translateMessage(QString& message, const QString& param1, const QString& param2 ) const 1067QString& ExternalAppHandler::translateMessage(QString& message, const QString& param1, const QString& param2 ) const
1068{ 1068{
1069 message = message.replace( QRegExp("%1"), param1 ); 1069 message = message.replace( QRegExp("%1"), param1 );
1070 return message.replace( QRegExp("%2"), param2 ); 1070 return message.replace( QRegExp("%2"), param2 );
1071} 1071}
1072 1072
1073/************************************************************************** 1073/**************************************************************************
1074 * 1074 *
1075 **************************************************************************/ 1075 **************************************************************************/
1076 1076
1077void ExternalAppHandler::passParameters(QCopEnvelope* e, const QString& parameters, const QString& param1 , const QString& param2) const 1077void ExternalAppHandler::passParameters(QCopEnvelope* e, const QString& parameters, const QString& param1 , const QString& param2) const
1078{ 1078{
1079#ifndef DESKTOP_VERSION 1079#ifndef DESKTOP_VERSION
1080 QMap<QString, QString> valmap; 1080 QMap<QString, QString> valmap;
1081 bool useValMap = false; 1081 bool useValMap = false;
1082 1082
1083 // first extract all parts of the parameters. 1083 // first extract all parts of the parameters.
1084 QStringList paramlist = QStringList::split(";", parameters); 1084 QStringList paramlist = QStringList::split(";", parameters);
1085 1085
1086 //Now check how many parts we have. 1086 //Now check how many parts we have.
1087 //=0 :no params to pass 1087 //=0 :no params to pass
1088 //>0 :parameters to pass 1088 //>0 :parameters to pass
1089 for ( QStringList::Iterator it = paramlist.begin(); it != paramlist.end(); ++it ) 1089 for ( QStringList::Iterator it = paramlist.begin(); it != paramlist.end(); ++it )
1090 { 1090 {
1091 QString param = (*it); 1091 QString param = (*it);
1092 QStringList keyvallist = QStringList::split("=", param); 1092 QStringList keyvallist = QStringList::split("=", param);
1093 1093
1094 //if we have keyvalue pairs, we assume that we pass a map to the envelope 1094 //if we have keyvalue pairs, we assume that we pass a map to the envelope
1095 QStringList::Iterator it2 = keyvallist.begin(); 1095 QStringList::Iterator it2 = keyvallist.begin();
1096 QString key = (*it2); 1096 QString key = (*it2);
1097 key = key.replace( QRegExp("%1"), param1 ); 1097 key = key.replace( QRegExp("%1"), param1 );
1098 key = key.replace( QRegExp("%2"), param2 ); 1098 key = key.replace( QRegExp("%2"), param2 );
1099 ++it2; 1099 ++it2;
1100 1100
1101 if(it2 != keyvallist.end()) 1101 if(it2 != keyvallist.end())
1102 { 1102 {
1103 QString value = (*it2); 1103 QString value = (*it2);
1104 value = value.replace( QRegExp("%1"), param1 ); 1104 value = value.replace( QRegExp("%1"), param1 );
1105 value = value.replace( QRegExp("%2"), param2 ); 1105 value = value.replace( QRegExp("%2"), param2 );
1106 1106
1107 valmap.insert(key, value); 1107 valmap.insert(key, value);
1108 useValMap = true; 1108 useValMap = true;
1109 } 1109 }
1110 else 1110 else
1111 { 1111 {
1112 // qDebug("pass parameter << %s", key.latin1()); 1112 // qDebug("pass parameter << %s", key.latin1());
1113 (*e) << key; 1113 (*e) << key;
1114 } 1114 }
1115 } 1115 }
1116 1116
1117 if (useValMap == true) 1117 if (useValMap == true)
1118 (*e) << valmap; 1118 (*e) << valmap;
1119 1119
1120#endif 1120#endif
1121 1121
1122} 1122}
1123 1123
1124 1124
1125 1125
1126/************************************************************************** 1126/**************************************************************************
1127 * 1127 *
1128 **************************************************************************/ 1128 **************************************************************************/
1129 1129
1130void ExternalAppHandler::appMessage( const QCString& cmsg, const QByteArray& data ) 1130void ExternalAppHandler::appMessage( const QCString& cmsg, const QByteArray& data )
1131{ 1131{
1132 1132
1133 if ( cmsg == "nextView()" ) { 1133 if ( cmsg == "nextView()" ) {
1134 qDebug("nextView()"); 1134 qDebug("nextView()");
1135 emit nextView(); 1135 emit nextView();
1136 return; 1136 return;
1137 } 1137 }
1138 1138
1139 bool res = mNameEmailUidListFromKAPITransfer->appMessage( cmsg, data ); 1139 bool res = mNameEmailUidListFromKAPITransfer->appMessage( cmsg, data );
1140 if (!res) 1140 if (!res)
1141 res = mBirthdayListFromKAPITransfer->appMessage( cmsg, data ); 1141 res = mBirthdayListFromKAPITransfer->appMessage( cmsg, data );
1142 1142
1143 if (!res) 1143 if (!res)
1144 res = mDisplayDetails->appMessage( cmsg, data ); 1144 res = mDisplayDetails->appMessage( cmsg, data );
1145 1145
1146// if (!res) 1146// if (!res)
1147// res = mNameEmailUidListFromKAPITransfer->appMessage( cmsg, data ); 1147// res = mNameEmailUidListFromKAPITransfer->appMessage( cmsg, data );
1148} 1148}
1149 1149
1150 1150
1151 1151
1152bool ExternalAppHandler::requestNameEmailUidListFromKAPI(const QString& sourceChannel, const QString& sessionuid) 1152bool ExternalAppHandler::requestNameEmailUidListFromKAPI(const QString& sourceChannel, const QString& sessionuid)
1153{ 1153{
1154 mNameEmailUidListFromKAPITransfer->setSourceChannel(sourceChannel); 1154 mNameEmailUidListFromKAPITransfer->setSourceChannel(sourceChannel);
1155 return mNameEmailUidListFromKAPITransfer->sendMessageToTarget(sessionuid); 1155 // maybe we are sending to KA/Pi fom a different worldd...
1156 // it may be that the QAplication::desktop()->width() values in KA/Pi are not the same as in our application
1157 // for that reason we send the current QApplication::desktop()->width() to KA/Pi
1158 return mNameEmailUidListFromKAPITransfer->sendMessageToTarget(QString::number ( QApplication::desktop()->width() ));
1156} 1159}
1157 1160
1158bool ExternalAppHandler::returnNameEmailUidListFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3) 1161bool ExternalAppHandler::returnNameEmailUidListFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3)
1159{ 1162{
1160 QStringList list4, list5, list6; 1163 QStringList list4, list5, list6;
1161 1164
1162 mNameEmailUidListFromKAPITransfer->setSourceChannel(sourceChannel); 1165 mNameEmailUidListFromKAPITransfer->setSourceChannel(sourceChannel);
1163 return mNameEmailUidListFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6); 1166 return mNameEmailUidListFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6);
1164} 1167}
1165 1168
1166bool ExternalAppHandler::requestFindByEmailFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QString& email) 1169bool ExternalAppHandler::requestFindByEmailFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QString& email)
1167{ 1170{
1168 mFindByEmailFromKAPITransfer->setSourceChannel(sourceChannel); 1171 mFindByEmailFromKAPITransfer->setSourceChannel(sourceChannel);
1169 return mFindByEmailFromKAPITransfer->sendMessageToTarget(sessionuid, email); 1172 return mFindByEmailFromKAPITransfer->sendMessageToTarget(sessionuid, email);
1170} 1173}
1171 1174
1172bool ExternalAppHandler::returnFindByEmailFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3) 1175bool ExternalAppHandler::returnFindByEmailFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3)
1173{ 1176{
1174 QStringList list4, list5, list6; 1177 QStringList list4, list5, list6;
1175 1178
1176 mFindByEmailFromKAPITransfer->setSourceChannel(sourceChannel); 1179 mFindByEmailFromKAPITransfer->setSourceChannel(sourceChannel);
1177 return mFindByEmailFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6); 1180 return mFindByEmailFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6);
1178} 1181}
1179 1182
1180bool ExternalAppHandler::requestDetailsFromKAPI(const QString& name, const QString& email, const QString& uid) 1183bool ExternalAppHandler::requestDetailsFromKAPI(const QString& name, const QString& email, const QString& uid)
1181{ 1184{
1182 mDisplayDetails->setSourceChannel(""); 1185 mDisplayDetails->setSourceChannel("");
1183 return mDisplayDetails->sendMessageToTarget("", name, email, uid); 1186 return mDisplayDetails->sendMessageToTarget("", name, email, uid);
1184} 1187}
1185 1188
1186bool ExternalAppHandler::requestBirthdayListFromKAPI(const QString& sourceChannel, const QString& sessionuid) 1189bool ExternalAppHandler::requestBirthdayListFromKAPI(const QString& sourceChannel, const QString& sessionuid)
1187{ 1190{
1188 mBirthdayListFromKAPITransfer->setSourceChannel(sourceChannel); 1191 mBirthdayListFromKAPITransfer->setSourceChannel(sourceChannel);
1189 return mBirthdayListFromKAPITransfer->sendMessageToTarget(sessionuid); 1192 return mBirthdayListFromKAPITransfer->sendMessageToTarget(sessionuid);
1190} 1193}
1191 1194
1192bool ExternalAppHandler::returnBirthdayListFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3, const QStringList& list4, const QStringList& list5, const QStringList& list6) 1195bool ExternalAppHandler::returnBirthdayListFromKAPI(const QString& sourceChannel, const QString& sessionuid, const QStringList& list1, const QStringList& list2, const QStringList& list3, const QStringList& list4, const QStringList& list5, const QStringList& list6)
1193{ 1196{
1194 mBirthdayListFromKAPITransfer->setSourceChannel(sourceChannel); 1197 mBirthdayListFromKAPITransfer->setSourceChannel(sourceChannel);
1195 return mBirthdayListFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6); 1198 return mBirthdayListFromKAPITransfer->sendMessageToSource(sessionuid, list1, list2, list3, list4, list5, list6);
1196} 1199}
1197 1200
1198 1201
1199 1202
1200 1203
1201 1204