-rw-r--r-- | bin/kdepim/WhatsNew.txt | 11 | ||||
-rw-r--r-- | kabc/plugins/sharpdtm/resourcesharpdtm.cpp | 4 | ||||
-rw-r--r-- | kabc/plugins/sharpdtm/sharpdtmconverter.cpp | 154 | ||||
-rw-r--r-- | kabc/plugins/sharpdtm/sharpdtmconverter.h | 1 |
4 files changed, 109 insertions, 61 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index 756ccc1..f38dd70 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,178 +1,185 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 1.9.11 ************ | 3 | ********** VERSION 1.9.11 ************ |
4 | 4 | ||
5 | Fixed several problems in PWM/Pi, like | 5 | Fixed several problems in PWM/Pi, like |
6 | asking the user, if unsaved changed are pending | 6 | asking the user, if unsaved changed are pending |
7 | when closing the app. | 7 | when closing the app. |
8 | And PwM/Pi handles now different texts for the | ||
9 | fields Description, Username, Password, configurable per category. | ||
8 | 10 | ||
9 | Fixed a crash in KO/Pi , when importing/loading vcs files | 11 | Fixed a crash in KO/Pi , when importing/loading vcs files |
10 | which have an entry with an attendee with state: | 12 | which have an entry with an attendee with state: |
11 | NEEDS ACTION | 13 | NEEDS ACTION |
12 | 14 | ||
13 | Fixed some problems in the German translation of OM/Pi, | 15 | Fixed some problems in the German translation of OM/Pi, |
14 | which makes some dialogs not fitting on the screen | 16 | which makes some dialogs not fitting on the screen |
15 | of the Z 5500. | 17 | of the Z 5500. |
16 | 18 | ||
17 | Fixed Qtopia crash, when disabling/deinstalling | 19 | Fixed Qtopia crash, when disabling/deinstalling |
18 | KO/Pi alarm applet. | 20 | KO/Pi alarm applet. |
19 | 21 | ||
20 | Implemented direct KDE<->KA/Pi sync for KA/Pi running | 22 | Implemented direct KDE<->KA/Pi sync for KA/Pi running |
21 | on Linux desktop. | 23 | on Linux desktop. |
22 | 24 | ||
23 | Added feature "remove sync info" to sync menu. | 25 | Added feature "remove sync info" to sync menu. |
24 | 26 | ||
25 | Tweaked the KO/Pi What's next view a bit, added | 27 | Tweaked the KO/Pi What's next view a bit, added |
26 | setting to hide events that are done. | 28 | setting to hide events that are done. |
27 | 29 | ||
28 | Disabled "beam receive enabled" on startup to | 30 | Disabled "beam receive enabled" on startup to |
29 | avoid problems if Fastload is enabled. | 31 | avoid problems if Fastload is enabled. |
30 | Please set "beam receive enabled", | 32 | Please set "beam receive enabled", |
31 | if you want to receive data via IR. | 33 | if you want to receive data via IR. |
32 | 34 | ||
33 | Fixed bug in direct KDE<->KO/Pi sync for KO/Pi running | 35 | Fixed bug in direct KDE<->KO/Pi sync for KO/Pi running |
34 | on Linux desktop. | 36 | on Linux desktop. |
35 | 37 | ||
36 | Made in KA/Pi scrolling possible, if details view is selected. | 38 | Made in KA/Pi scrolling possible, if details view is selected. |
37 | (The keyboard focus is set automatically to the search line) | 39 | (The keyboard focus is set automatically to the search line) |
38 | 40 | ||
39 | Fixed a bug in DMT sync, that a new entry in DTM was added | 41 | Fixed a bug in DMT sync, that a new entry in DTM was added |
40 | on every sync to Kx/Pi. | 42 | on every sync to Kx/Pi. |
41 | 43 | ||
42 | Fixed a bug in DMT sync with todos created in KO/Pi containing | 44 | Fixed a bug in DMT sync with todos created in KO/Pi containing |
43 | non-latin1 characters. | 45 | non-latin1 characters. |
44 | 46 | ||
45 | Rearranged package contents of Sharp-ipks and made all | 47 | Rearranged package contents of Sharp-ipks and made all |
46 | packages installable on SD again. | 48 | packages installable on SD again. |
47 | 49 | ||
48 | PwM/Pi handles now different texts for the | 50 | Fixed the writing of addressbook data in DTM sync. |
49 | fields Description, Username, Password, configurable per category. | 51 | Empty fields in KA/Pi were not removed. |
50 | 52 | ||
53 | Added better category handling in KA/Pi: | ||
54 | Menu "change selected has now" | ||
55 | Set Categories and | ||
56 | Add Categories option. | ||
57 | Possible to configure a view to display categories. | ||
51 | 58 | ||
52 | 59 | ||
53 | ********** VERSION 1.9.10 ************ | 60 | ********** VERSION 1.9.10 ************ |
54 | 61 | ||
55 | Many internal small bugfixes. | 62 | Many internal small bugfixes. |
56 | And fix of the "big" bug in KO/Pi, | 63 | And fix of the "big" bug in KO/Pi, |
57 | that after Syncing the appointments had an offset by several hours. | 64 | that after Syncing the appointments had an offset by several hours. |
58 | That was a problem with the internal timezone setting, | 65 | That was a problem with the internal timezone setting, |
59 | introduced by the changed timezone configuration settings. | 66 | introduced by the changed timezone configuration settings. |
60 | 67 | ||
61 | German translation for OM/Pi is now available. | 68 | German translation for OM/Pi is now available. |
62 | 69 | ||
63 | 70 | ||
64 | ********** VERSION 1.9.9 ************ | 71 | ********** VERSION 1.9.9 ************ |
65 | 72 | ||
66 | KDE-Pim/Pi has a new Member! | 73 | KDE-Pim/Pi has a new Member! |
67 | It is called PWM/Pi (Passwordmanager/platform-independent) | 74 | It is called PWM/Pi (Passwordmanager/platform-independent) |
68 | and it is available for the Zaurus. | 75 | and it is available for the Zaurus. |
69 | It is planned, that it will be available later for Windows. | 76 | It is planned, that it will be available later for Windows. |
70 | (And for Linux, of course). | 77 | (And for Linux, of course). |
71 | It is a port of the Passwordmanager of KDE. | 78 | It is a port of the Passwordmanager of KDE. |
72 | It will need the MicroKDElibs to run. | 79 | It will need the MicroKDElibs to run. |
73 | 80 | ||
74 | Made loading of addressbooks in KA/Pi up to 7 times faster! | 81 | Made loading of addressbooks in KA/Pi up to 7 times faster! |
75 | The bigger your addressbook file, the more starting speed | 82 | The bigger your addressbook file, the more starting speed |
76 | will you gain. (relatively) | 83 | will you gain. (relatively) |
77 | 84 | ||
78 | The Qtopia addressbook connector is now platform independend | 85 | The Qtopia addressbook connector is now platform independend |
79 | as well and should work on any platform for importing/exporting | 86 | as well and should work on any platform for importing/exporting |
80 | Qtopia and Opie XML files. | 87 | Qtopia and Opie XML files. |
81 | 88 | ||
82 | Added a +30min feature to the timezone settings to make | 89 | Added a +30min feature to the timezone settings to make |
83 | KDE-Pim/Pi useable in Australia and other parts on the | 90 | KDE-Pim/Pi useable in Australia and other parts on the |
84 | world with strange timezones ;-) | 91 | world with strange timezones ;-) |
85 | 92 | ||
86 | German "Umlaute" should now be sorted correctly on the Z in KA/Pi. | 93 | German "Umlaute" should now be sorted correctly on the Z in KA/Pi. |
87 | 94 | ||
88 | It is now possible to disable the | 95 | It is now possible to disable the |
89 | "receive data via infrared" feature, such that syncing with | 96 | "receive data via infrared" feature, such that syncing with |
90 | Outlook is now possible again with Kx/Pi runing. | 97 | Outlook is now possible again with Kx/Pi runing. |
91 | Please disable it, before syncing Sharp DTM with Outlook. | 98 | Please disable it, before syncing Sharp DTM with Outlook. |
92 | For your convenience, the "receive data via infrared" feature | 99 | For your convenience, the "receive data via infrared" feature |
93 | is disabled automatically, if you sync Kx/Pi with DTM. | 100 | is disabled automatically, if you sync Kx/Pi with DTM. |
94 | You have to enable it again manually after syncing. | 101 | You have to enable it again manually after syncing. |
95 | Enabling this feature makes it impossible to start the | 102 | Enabling this feature makes it impossible to start the |
96 | Sharp DTM apps. If this feature is enabled, you will only get the | 103 | Sharp DTM apps. If this feature is enabled, you will only get the |
97 | alarm notification from KO/Pi and not from the Sharp calendar. | 104 | alarm notification from KO/Pi and not from the Sharp calendar. |
98 | This is very useful if you sync KO/Pi with Sharp DTM, | 105 | This is very useful if you sync KO/Pi with Sharp DTM, |
99 | because after syncing you usually would get notified about | 106 | because after syncing you usually would get notified about |
100 | an alarm by KO/Pi and the Sharp Calendar. | 107 | an alarm by KO/Pi and the Sharp Calendar. |
101 | 108 | ||
102 | Together with the Linux desktop version of KO/Pi | 109 | Together with the Linux desktop version of KO/Pi |
103 | it is now possible to sync KO/Pi on the Zaurus | 110 | it is now possible to sync KO/Pi on the Zaurus |
104 | with the complete KDE-desktop (3.3 or later) | 111 | with the complete KDE-desktop (3.3 or later) |
105 | calendar data easily. | 112 | calendar data easily. |
106 | That makes it possible to sync the Z with one | 113 | That makes it possible to sync the Z with one |
107 | click of a mouse with the KDE-Desktop. | 114 | click of a mouse with the KDE-Desktop. |
108 | This feature it available for all Zaurus platforms KO/Pi | 115 | This feature it available for all Zaurus platforms KO/Pi |
109 | is running on. | 116 | is running on. |
110 | The only thing needed is a running KO/Pi on Linux and | 117 | The only thing needed is a running KO/Pi on Linux and |
111 | a compiled version of the small | 118 | a compiled version of the small |
112 | KDE-Pim/Pi<->KDE-Desktop access command line program, | 119 | KDE-Pim/Pi<->KDE-Desktop access command line program, |
113 | which is in the KDE-Pim/Pi sources available. | 120 | which is in the KDE-Pim/Pi sources available. |
114 | 121 | ||
115 | The "KDE-desktop" syncing feature for KA/Pi will follow | 122 | The "KDE-desktop" syncing feature for KA/Pi will follow |
116 | in the next releases. | 123 | in the next releases. |
117 | 124 | ||
118 | Fixed the vcard export bug, which had the version 1.9.8. | 125 | Fixed the vcard export bug, which had the version 1.9.8. |
119 | 126 | ||
120 | Added missing GERMAN translation to KO/Pi. | 127 | Added missing GERMAN translation to KO/Pi. |
121 | Hi PsionX, could you add the missing french translation?Thx! | 128 | Hi PsionX, could you add the missing french translation?Thx! |
122 | 129 | ||
123 | Translation files for KA/Pi are available as well. | 130 | Translation files for KA/Pi are available as well. |
124 | GERMAN translation will be available in the next release. | 131 | GERMAN translation will be available in the next release. |
125 | PsionX ( yres, you again ;-) ), could you start translating | 132 | PsionX ( yres, you again ;-) ), could you start translating |
126 | KA/Pi? Thx! | 133 | KA/Pi? Thx! |
127 | 134 | ||
128 | You can download the version 1.9.9 at | 135 | You can download the version 1.9.9 at |
129 | 136 | ||
130 | http://sourceforge.net/project/showfiles.php?group_id=104103&package_id=112604 | 137 | http://sourceforge.net/project/showfiles.php?group_id=104103&package_id=112604 |
131 | 138 | ||
132 | Note: | 139 | Note: |
133 | To run the mail program OM/Pi you need libopenssl. | 140 | To run the mail program OM/Pi you need libopenssl. |
134 | A link to a download loaction is available at | 141 | A link to a download loaction is available at |
135 | ZSI at www.killefiz.de | 142 | ZSI at www.killefiz.de |
136 | 143 | ||
137 | 144 | ||
138 | ********** VERSION 1.9.8 ************ | 145 | ********** VERSION 1.9.8 ************ |
139 | 146 | ||
140 | Fixed character decoding in OM/Pi. | 147 | Fixed character decoding in OM/Pi. |
141 | (e.g. German "Umlaute" were not displayed properly.) | 148 | (e.g. German "Umlaute" were not displayed properly.) |
142 | 149 | ||
143 | Made is possible to reparent todos in KO/Pi. | 150 | Made is possible to reparent todos in KO/Pi. |
144 | Use contextmenu or keys (look at Help-Keys + Colors) for that. | 151 | Use contextmenu or keys (look at Help-Keys + Colors) for that. |
145 | 152 | ||
146 | Added the missing Sync-Howto and WhatsNew to the packages. | 153 | Added the missing Sync-Howto and WhatsNew to the packages. |
147 | 154 | ||
148 | KO/Pi on Linux desktop can now sync with KDE desktop. | 155 | KO/Pi on Linux desktop can now sync with KDE desktop. |
149 | That means: When using KO/Pi on Linux desktop for syncing with | 156 | That means: When using KO/Pi on Linux desktop for syncing with |
150 | KDE desktop and the Zaurus, the Zaurus can be synced now | 157 | KDE desktop and the Zaurus, the Zaurus can be synced now |
151 | with all KDE-Calendar resources, not only with one local file. | 158 | with all KDE-Calendar resources, not only with one local file. |
152 | (That makes it possible to sync the Zaurus with the | 159 | (That makes it possible to sync the Zaurus with the |
153 | calendar data on a Kolab server) | 160 | calendar data on a Kolab server) |
154 | 161 | ||
155 | KA/Pi syncing with KDE desktop will be available in the next version. | 162 | KA/Pi syncing with KDE desktop will be available in the next version. |
156 | 163 | ||
157 | 164 | ||
158 | ********** VERSION 1.9.7 ************ | 165 | ********** VERSION 1.9.7 ************ |
159 | 166 | ||
160 | KO/Pi - KA/Pi on Windows: | 167 | KO/Pi - KA/Pi on Windows: |
161 | Now a directory can be defined by the user, where the | 168 | Now a directory can be defined by the user, where the |
162 | application/config data should be saved. | 169 | application/config data should be saved. |
163 | Define your desired path in the evironment variable | 170 | Define your desired path in the evironment variable |
164 | MICROKDEHOME | 171 | MICROKDEHOME |
165 | before starting KO/Pi or KA/Pi. | 172 | before starting KO/Pi or KA/Pi. |
166 | 173 | ||
167 | An easy Kx/Pi to Kx/Pi syncing is now possible | 174 | An easy Kx/Pi to Kx/Pi syncing is now possible |
168 | (it is called Pi-Sync) via network. | 175 | (it is called Pi-Sync) via network. |
169 | Please look at the Sync Howto. | 176 | Please look at the Sync Howto. |
170 | 177 | ||
171 | Exporting of calendar data and contacts to mobile phones is now possible. | 178 | Exporting of calendar data and contacts to mobile phones is now possible. |
172 | The SyncHowto is updated with information howto | 179 | The SyncHowto is updated with information howto |
173 | access/sync mobile phones. | 180 | access/sync mobile phones. |
174 | Please look at the Sync Howto. | 181 | Please look at the Sync Howto. |
175 | 182 | ||
176 | Now KO/Pi and KA/Pi on the Zaurus can receive data via infrared directly. | 183 | Now KO/Pi and KA/Pi on the Zaurus can receive data via infrared directly. |
177 | Please disable Fastload for the original contact/calendar applications | 184 | Please disable Fastload for the original contact/calendar applications |
178 | and close them. | 185 | and close them. |
diff --git a/kabc/plugins/sharpdtm/resourcesharpdtm.cpp b/kabc/plugins/sharpdtm/resourcesharpdtm.cpp index 7069f5d..6413b42 100644 --- a/kabc/plugins/sharpdtm/resourcesharpdtm.cpp +++ b/kabc/plugins/sharpdtm/resourcesharpdtm.cpp | |||
@@ -75,227 +75,229 @@ ResourceSharpDTM::ResourceSharpDTM( const KConfig *config ) | |||
75 | ResourceSharpDTM::ResourceSharpDTM( const QString &fileName ) | 75 | ResourceSharpDTM::ResourceSharpDTM( const QString &fileName ) |
76 | : Resource( 0 ) | 76 | : Resource( 0 ) |
77 | { | 77 | { |
78 | mAccess = 0; | 78 | mAccess = 0; |
79 | init( fileName ); | 79 | init( fileName ); |
80 | } | 80 | } |
81 | 81 | ||
82 | void ResourceSharpDTM::init( const QString &fileName ) | 82 | void ResourceSharpDTM::init( const QString &fileName ) |
83 | { | 83 | { |
84 | if (mConverter == 0) { | 84 | if (mConverter == 0) { |
85 | mConverter = new SharpDTMConverter(); | 85 | mConverter = new SharpDTMConverter(); |
86 | bool res = mConverter->init(); | 86 | bool res = mConverter->init(); |
87 | if ( !res ) | 87 | if ( !res ) |
88 | { | 88 | { |
89 | QString msg("Unable to initialize sharp converter. Most likely a problem with the category file"); | 89 | QString msg("Unable to initialize sharp converter. Most likely a problem with the category file"); |
90 | qDebug(msg); | 90 | qDebug(msg); |
91 | return; | 91 | return; |
92 | } | 92 | } |
93 | } | 93 | } |
94 | setFileName( fileName ); | 94 | setFileName( fileName ); |
95 | } | 95 | } |
96 | 96 | ||
97 | ResourceSharpDTM::~ResourceSharpDTM() | 97 | ResourceSharpDTM::~ResourceSharpDTM() |
98 | { | 98 | { |
99 | if (mConverter != 0) | 99 | if (mConverter != 0) |
100 | delete mConverter; | 100 | delete mConverter; |
101 | 101 | ||
102 | if(mAccess != 0) | 102 | if(mAccess != 0) |
103 | delete mAccess; | 103 | delete mAccess; |
104 | } | 104 | } |
105 | 105 | ||
106 | void ResourceSharpDTM::writeConfig( KConfig *config ) | 106 | void ResourceSharpDTM::writeConfig( KConfig *config ) |
107 | { | 107 | { |
108 | Resource::writeConfig( config ); | 108 | Resource::writeConfig( config ); |
109 | } | 109 | } |
110 | 110 | ||
111 | Ticket *ResourceSharpDTM::requestSaveTicket() | 111 | Ticket *ResourceSharpDTM::requestSaveTicket() |
112 | { | 112 | { |
113 | 113 | ||
114 | qDebug("ResourceSharpDTM::requestSaveTicket: %s", fileName().latin1()); | 114 | qDebug("ResourceSharpDTM::requestSaveTicket: %s", fileName().latin1()); |
115 | 115 | ||
116 | if ( !addressBook() ) return 0; | 116 | if ( !addressBook() ) return 0; |
117 | return createTicket( this ); | 117 | return createTicket( this ); |
118 | } | 118 | } |
119 | 119 | ||
120 | 120 | ||
121 | bool ResourceSharpDTM::doOpen() | 121 | bool ResourceSharpDTM::doOpen() |
122 | { | 122 | { |
123 | if (!mConverter) | 123 | if (!mConverter) |
124 | return false; | 124 | return false; |
125 | return true; | 125 | return true; |
126 | } | 126 | } |
127 | 127 | ||
128 | void ResourceSharpDTM::doClose() | 128 | void ResourceSharpDTM::doClose() |
129 | { | 129 | { |
130 | return; | 130 | return; |
131 | } | 131 | } |
132 | 132 | ||
133 | bool ResourceSharpDTM::load() | 133 | bool ResourceSharpDTM::load() |
134 | { | 134 | { |
135 | if (!mConverter) | 135 | if (!mConverter) |
136 | return false; | 136 | return false; |
137 | QString fileN = SlZDataBase::addressbookFileName(); | 137 | QString fileN = SlZDataBase::addressbookFileName(); |
138 | if ( ! mAccess ) { | 138 | if ( ! mAccess ) { |
139 | mAccess = new SlZDataBase(fileN, | 139 | mAccess = new SlZDataBase(fileN, |
140 | SlZDataBase::addressbookItems(), | 140 | SlZDataBase::addressbookItems(), |
141 | 0, false); | 141 | 0, false); |
142 | } | 142 | } |
143 | if(mAccess == 0) | 143 | if(mAccess == 0) |
144 | return false; | 144 | return false; |
145 | 145 | ||
146 | qDebug("%xResourceSharpDTM::load: %s",this, fileName().latin1()); | 146 | qDebug("%xResourceSharpDTM::load: %s",this, fileName().latin1()); |
147 | bool res = false; | 147 | bool res = false; |
148 | CardId id; | 148 | CardId id; |
149 | for (bool res=mAccess->first(); res == true; res=mAccess->next()) | 149 | for (bool res=mAccess->first(); res == true; res=mAccess->next()) |
150 | { | 150 | { |
151 | id = mAccess->cardId(); | 151 | id = mAccess->cardId(); |
152 | KABC::Addressee addressee; | 152 | KABC::Addressee addressee; |
153 | res = mConverter->sharpToAddressee( id, mAccess, addressee ); | 153 | res = mConverter->sharpToAddressee( id, mAccess, addressee ); |
154 | if ( !addressee.isEmpty() && res ) | 154 | if ( !addressee.isEmpty() && res ) |
155 | { | 155 | { |
156 | addressee.setResource( this ); | 156 | addressee.setResource( this ); |
157 | addressBook()->insertAddressee( addressee ); | 157 | addressBook()->insertAddressee( addressee ); |
158 | } | 158 | } |
159 | } | 159 | } |
160 | if(mAccess != 0) | 160 | if(mAccess != 0) |
161 | delete mAccess; | 161 | delete mAccess; |
162 | mAccess = 0; | 162 | mAccess = 0; |
163 | 163 | ||
164 | return true; | 164 | return true; |
165 | } | 165 | } |
166 | 166 | ||
167 | bool ResourceSharpDTM::save( Ticket *ticket ) | 167 | bool ResourceSharpDTM::save( Ticket *ticket ) |
168 | { | 168 | { |
169 | if (!mConverter) | 169 | if (!mConverter) |
170 | return false; | 170 | return false; |
171 | QString fileN = SlZDataBase::addressbookFileName(); | 171 | QString fileN = SlZDataBase::addressbookFileName(); |
172 | if ( ! mAccess ) { | 172 | if ( ! mAccess ) { |
173 | mAccess = new SlZDataBase(fileN, | 173 | mAccess = new SlZDataBase(fileN, |
174 | SlZDataBase::addressbookItems(), | 174 | SlZDataBase::addressbookItems(), |
175 | 0, false); | 175 | 0, false); |
176 | } | 176 | } |
177 | if(mAccess == 0) | 177 | if(mAccess == 0) |
178 | return false; | 178 | return false; |
179 | qDebug("ResourceSharpDTM::save: %s", fileName().latin1()); | 179 | qDebug("ResourceSharpDTM::save: %s", fileName().latin1()); |
180 | KABC::AddressBook::Iterator it; | 180 | KABC::AddressBook::Iterator it; |
181 | bool res; | 181 | bool res; |
182 | KABC::Addressee::List changedAddressees; | 182 | KABC::Addressee::List changedAddressees; |
183 | typedef QMap<int,QString> AddresseeMap; | 183 | typedef QMap<int,QString> AddresseeMap; |
184 | AddresseeMap map; | 184 | AddresseeMap map; |
185 | CardId id ; | 185 | CardId id ; |
186 | for ( it = addressBook()->begin(); it != addressBook()->end(); ++it ) { | 186 | for ( it = addressBook()->begin(); it != addressBook()->end(); ++it ) { |
187 | 187 | ||
188 | if ( (*it).tempSyncStat() != SYNC_TEMPSTATE_NEW_EXTERNAL ) { | 188 | if ( (*it).tempSyncStat() != SYNC_TEMPSTATE_NEW_EXTERNAL ) { |
189 | QString uid = (*it).originalExternalUID(); | 189 | QString uid = (*it).originalExternalUID(); |
190 | bool res; | 190 | bool res; |
191 | if ( uid.isEmpty() ) | 191 | if ( uid.isEmpty() ) |
192 | id = 0; | 192 | id = 0; |
193 | else | 193 | else |
194 | id = uid.toUInt(); | 194 | id = uid.toUInt(); |
195 | KABC::Addressee addressee = (*it); | 195 | KABC::Addressee addressee = (*it); |
196 | if ( (*it).tempSyncStat() == SYNC_TEMPSTATE_ADDED_EXTERNAL ) { | 196 | if ( (*it).tempSyncStat() == SYNC_TEMPSTATE_ADDED_EXTERNAL ) { |
197 | res = mAccess->startEditCard(id); | 197 | res = mAccess->startEditCard(id); |
198 | if (res == true) | 198 | if (res == true) |
199 | { | 199 | { |
200 | res = mConverter->addresseeToSharp( (*it), mAccess, id ); | 200 | res = mConverter->addresseeToSharp( (*it), mAccess, id ); |
201 | if (res == true) | 201 | if (res == true) |
202 | { | 202 | { |
203 | res = mAccess->finishEditCard(&id);; | 203 | res = mAccess->finishEditCard(&id);; |
204 | mConverter->setCategories( (*it), mAccess, id ); | ||
204 | map.insert(id,(*it).uid()); | 205 | map.insert(id,(*it).uid()); |
205 | if (res == false) | 206 | if (res == false) |
206 | qDebug("Unable to append Contact: %s", addressee.formattedName().latin1()); | 207 | qDebug("Unable to append Contact: %s", addressee.formattedName().latin1()); |
207 | 208 | ||
208 | } | 209 | } |
209 | else | 210 | else |
210 | { | 211 | { |
211 | qDebug("Unable to convert Addressee: %s", addressee.formattedName().latin1()); | 212 | qDebug("Unable to convert Addressee: %s", addressee.formattedName().latin1()); |
212 | mAccess->cancelEditCard(); | 213 | mAccess->cancelEditCard(); |
213 | } | 214 | } |
214 | } | 215 | } |
215 | 216 | ||
216 | } else if ( (*it).tempSyncStat() == SYNC_TEMPSTATE_DELETE ) { | 217 | } else if ( (*it).tempSyncStat() == SYNC_TEMPSTATE_DELETE ) { |
217 | res = mAccess->deleteCard(&id); | 218 | res = mAccess->deleteCard(&id); |
218 | if ( !res ) | 219 | if ( !res ) |
219 | qDebug("delete error "); | 220 | qDebug("delete error "); |
220 | 221 | ||
221 | 222 | ||
222 | } else if ( (*it).tempSyncStat() != SYNC_TEMPSTATE_NEW_EXTERNAL ) { | 223 | } else if ( (*it).tempSyncStat() != SYNC_TEMPSTATE_NEW_EXTERNAL ) { |
223 | //changed | 224 | //changed |
224 | res = mAccess->startEditCard(id); | 225 | res = mAccess->startEditCard(id); |
225 | if (res == true) | 226 | if (res == true) |
226 | { | 227 | { |
227 | res = mConverter->addresseeToSharp( (*it), mAccess, id ); | 228 | res = mConverter->addresseeToSharp( (*it), mAccess, id ); |
228 | if (res == true) | 229 | if (res == true) |
229 | { | 230 | { |
230 | res = mAccess->finishEditCard(&id); | 231 | res = mAccess->finishEditCard(&id); |
232 | mConverter->setCategories( (*it), mAccess, id ); | ||
231 | map.insert(id,(*it).uid()); | 233 | map.insert(id,(*it).uid()); |
232 | if (res == false) | 234 | if (res == false) |
233 | qDebug("Unable to append Contact: %s", addressee.formattedName().latin1()); | 235 | qDebug("Unable to append Contact: %s", addressee.formattedName().latin1()); |
234 | } | 236 | } |
235 | else | 237 | else |
236 | { | 238 | { |
237 | qDebug("Unable to convert Addressee: %s", addressee.formattedName().latin1()); | 239 | qDebug("Unable to convert Addressee: %s", addressee.formattedName().latin1()); |
238 | mAccess->cancelEditCard(); | 240 | mAccess->cancelEditCard(); |
239 | } | 241 | } |
240 | } | 242 | } |
241 | } | 243 | } |
242 | } | 244 | } |
243 | 245 | ||
244 | } | 246 | } |
245 | AddresseeMap::Iterator itam; | 247 | AddresseeMap::Iterator itam; |
246 | for ( res=mAccess->first(); res == true; res=mAccess->next()) | 248 | for ( res=mAccess->first(); res == true; res=mAccess->next()) |
247 | { | 249 | { |
248 | id = mAccess->cardId(); | 250 | id = mAccess->cardId(); |
249 | int idint = id; | 251 | int idint = id; |
250 | itam = map.find( idint ); | 252 | itam = map.find( idint ); |
251 | if ( itam != map.end() ) { | 253 | if ( itam != map.end() ) { |
252 | KABC::Addressee addressee; | 254 | KABC::Addressee addressee; |
253 | res = mConverter->sharpToAddressee( id, mAccess, addressee ); | 255 | res = mConverter->sharpToAddressee( id, mAccess, addressee ); |
254 | 256 | ||
255 | if ( !addressee.isEmpty() && res ) | 257 | if ( !addressee.isEmpty() && res ) |
256 | { | 258 | { |
257 | addressee.setResource( this ); | 259 | addressee.setResource( this ); |
258 | addressee.setUid( itam.data() ); | 260 | addressee.setUid( itam.data() ); |
259 | addressee.setTempSyncStat( SYNC_TEMPSTATE_NEW_ID ); | 261 | addressee.setTempSyncStat( SYNC_TEMPSTATE_NEW_ID ); |
260 | addressBook()->insertAddressee( addressee , false ); | 262 | addressBook()->insertAddressee( addressee , false ); |
261 | } | 263 | } |
262 | } | 264 | } |
263 | } | 265 | } |
264 | delete ticket; | 266 | delete ticket; |
265 | if(mAccess != 0) | 267 | if(mAccess != 0) |
266 | delete mAccess; | 268 | delete mAccess; |
267 | mAccess = 0; | 269 | mAccess = 0; |
268 | return true; | 270 | return true; |
269 | } | 271 | } |
270 | 272 | ||
271 | bool ResourceSharpDTM::lock( const QString &lockfileName ) | 273 | bool ResourceSharpDTM::lock( const QString &lockfileName ) |
272 | { | 274 | { |
273 | return true; | 275 | return true; |
274 | } | 276 | } |
275 | 277 | ||
276 | void ResourceSharpDTM::unlock( const QString &fileName ) | 278 | void ResourceSharpDTM::unlock( const QString &fileName ) |
277 | { | 279 | { |
278 | 280 | ||
279 | } | 281 | } |
280 | 282 | ||
281 | void ResourceSharpDTM::setFileName( const QString &newFileName ) | 283 | void ResourceSharpDTM::setFileName( const QString &newFileName ) |
282 | { | 284 | { |
283 | Resource::setFileName( newFileName ); | 285 | Resource::setFileName( newFileName ); |
284 | } | 286 | } |
285 | 287 | ||
286 | void ResourceSharpDTM::fileChanged() | 288 | void ResourceSharpDTM::fileChanged() |
287 | { | 289 | { |
288 | 290 | ||
289 | } | 291 | } |
290 | 292 | ||
291 | void ResourceSharpDTM::removeAddressee( const Addressee &addr ) | 293 | void ResourceSharpDTM::removeAddressee( const Addressee &addr ) |
292 | { | 294 | { |
293 | } | 295 | } |
294 | 296 | ||
295 | void ResourceSharpDTM::cleanUp() | 297 | void ResourceSharpDTM::cleanUp() |
296 | { | 298 | { |
297 | 299 | ||
298 | } | 300 | } |
299 | 301 | ||
300 | 302 | ||
301 | 303 | ||
diff --git a/kabc/plugins/sharpdtm/sharpdtmconverter.cpp b/kabc/plugins/sharpdtm/sharpdtmconverter.cpp index 396be0a..ae4cfbb 100644 --- a/kabc/plugins/sharpdtm/sharpdtmconverter.cpp +++ b/kabc/plugins/sharpdtm/sharpdtmconverter.cpp | |||
@@ -182,263 +182,301 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
182 | businessphone.setType( PhoneNumber::Work ); | 182 | businessphone.setType( PhoneNumber::Work ); |
183 | businessphone.setNumber( db->readField(ZdbAdrs::BusinessPhone) ); | 183 | businessphone.setNumber( db->readField(ZdbAdrs::BusinessPhone) ); |
184 | addr.insertPhoneNumber( businessphone ); | 184 | addr.insertPhoneNumber( businessphone ); |
185 | } | 185 | } |
186 | 186 | ||
187 | if (!db->readField(ZdbAdrs::BusinessFax).isEmpty()) | 187 | if (!db->readField(ZdbAdrs::BusinessFax).isEmpty()) |
188 | { | 188 | { |
189 | PhoneNumber businessfax; | 189 | PhoneNumber businessfax; |
190 | businessfax.setType( PhoneNumber::Work | PhoneNumber::Fax ); | 190 | businessfax.setType( PhoneNumber::Work | PhoneNumber::Fax ); |
191 | businessfax.setNumber( db->readField(ZdbAdrs::BusinessFax) ); | 191 | businessfax.setNumber( db->readField(ZdbAdrs::BusinessFax) ); |
192 | addr.insertPhoneNumber( businessfax ); | 192 | addr.insertPhoneNumber( businessfax ); |
193 | } | 193 | } |
194 | 194 | ||
195 | if (!db->readField(ZdbAdrs::BusinessMobile).isEmpty()) | 195 | if (!db->readField(ZdbAdrs::BusinessMobile).isEmpty()) |
196 | { | 196 | { |
197 | PhoneNumber businessmobile; | 197 | PhoneNumber businessmobile; |
198 | businessmobile.setType( PhoneNumber::Work | PhoneNumber::Cell ); | 198 | businessmobile.setType( PhoneNumber::Work | PhoneNumber::Cell ); |
199 | businessmobile.setNumber( db->readField(ZdbAdrs::BusinessMobile) ); | 199 | businessmobile.setNumber( db->readField(ZdbAdrs::BusinessMobile) ); |
200 | addr.insertPhoneNumber( businessmobile ); | 200 | addr.insertPhoneNumber( businessmobile ); |
201 | } | 201 | } |
202 | 202 | ||
203 | if (!db->readField(ZdbAdrs::BusinessPager).isEmpty()) | 203 | if (!db->readField(ZdbAdrs::BusinessPager).isEmpty()) |
204 | { | 204 | { |
205 | PhoneNumber businesspager; | 205 | PhoneNumber businesspager; |
206 | businesspager.setType( PhoneNumber::Work | PhoneNumber::Pager ); | 206 | businesspager.setType( PhoneNumber::Work | PhoneNumber::Pager ); |
207 | businesspager.setNumber( db->readField(ZdbAdrs::BusinessPager) ); | 207 | businesspager.setNumber( db->readField(ZdbAdrs::BusinessPager) ); |
208 | addr.insertPhoneNumber( businesspager ); | 208 | addr.insertPhoneNumber( businesspager ); |
209 | } | 209 | } |
210 | 210 | ||
211 | addr.setRole( db->readField(ZdbAdrs::JobTitle) ); | 211 | addr.setRole( db->readField(ZdbAdrs::JobTitle) ); |
212 | addr.setOrganization( db->readField(ZdbAdrs::Company) ); | 212 | addr.setOrganization( db->readField(ZdbAdrs::Company) ); |
213 | addr.insertCustom( "KADDRESSBOOK", "X-Profession", db->readField(ZdbAdrs::Profession) ); | 213 | addr.insertCustom( "KADDRESSBOOK", "X-Profession", db->readField(ZdbAdrs::Profession) ); |
214 | addr.insertCustom( "KADDRESSBOOK", "X-AssistantsName", db->readField(ZdbAdrs::Assistant) ); | 214 | addr.insertCustom( "KADDRESSBOOK", "X-AssistantsName", db->readField(ZdbAdrs::Assistant) ); |
215 | addr.insertCustom( "KADDRESSBOOK", "X-Department", db->readField(ZdbAdrs::Department) ); | 215 | addr.insertCustom( "KADDRESSBOOK", "X-Department", db->readField(ZdbAdrs::Department) ); |
216 | addr.insertCustom( "KADDRESSBOOK", "X-ManagersName", db->readField(ZdbAdrs::Manager) ); | 216 | addr.insertCustom( "KADDRESSBOOK", "X-ManagersName", db->readField(ZdbAdrs::Manager) ); |
217 | addr.insertCustom( "KADDRESSBOOK", "X-Office", db->readField(ZdbAdrs::Office) ); | 217 | addr.insertCustom( "KADDRESSBOOK", "X-Office", db->readField(ZdbAdrs::Office) ); |
218 | 218 | ||
219 | //personal | 219 | //personal |
220 | addr.insertCustom( "KADDRESSBOOK", "X-SpousesName", db->readField(ZdbAdrs::Spouse) ); | 220 | addr.insertCustom( "KADDRESSBOOK", "X-SpousesName", db->readField(ZdbAdrs::Spouse) ); |
221 | 221 | ||
222 | QString gen = db->readField(ZdbAdrs::Gender); | 222 | QString gen = db->readField(ZdbAdrs::Gender); |
223 | //qDebug("SharpDTMConverter::sharpToAddressee pleas check that gender works!! : Gender: %s", gen.latin1()); | 223 | //qDebug("SharpDTMConverter::sharpToAddressee pleas check that gender works!! : Gender: %s", gen.latin1()); |
224 | //qDebug("SharpDTMConverter::sharpToAddressee: may be int db->readUshortField(\"ZdbAdrs::Gender\") is here better suited"); | 224 | //qDebug("SharpDTMConverter::sharpToAddressee: may be int db->readUshortField(\"ZdbAdrs::Gender\") is here better suited"); |
225 | 225 | ||
226 | if (gen == "male") | 226 | if (gen == "male") |
227 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "male"); | 227 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "male"); |
228 | else if (gen == "female") | 228 | else if (gen == "female") |
229 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "female"); | 229 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "female"); |
230 | 230 | ||
231 | 231 | ||
232 | QDate ann = KGlobal::locale()->readDate( db->readField(ZdbAdrs::Anniversary) ); | 232 | QDate ann = KGlobal::locale()->readDate( db->readField(ZdbAdrs::Anniversary) ); |
233 | if (ann.isValid()) { | 233 | if (ann.isValid()) { |
234 | QString dt = KGlobal::locale()->formatDate(ann, true, KLocale::ISODate); | 234 | QString dt = KGlobal::locale()->formatDate(ann, true, KLocale::ISODate); |
235 | //qDebug("qtopiaToAddressee annyversary found:%s", dt.latin1()); | 235 | //qDebug("qtopiaToAddressee annyversary found:%s", dt.latin1()); |
236 | addr.insertCustom( "KADDRESSBOOK", "X-Anniversary", dt); | 236 | addr.insertCustom( "KADDRESSBOOK", "X-Anniversary", dt); |
237 | } | 237 | } |
238 | 238 | ||
239 | 239 | ||
240 | addr.insertCustom( "KADDRESSBOOK", "X-Children", db->readField(ZdbAdrs::Children) ); | 240 | addr.insertCustom( "KADDRESSBOOK", "X-Children", db->readField(ZdbAdrs::Children) ); |
241 | 241 | ||
242 | 242 | ||
243 | QDate birthd = KGlobal::locale()->readDate( db->readField(ZdbAdrs::Birthday) ); | 243 | QDate birthd = KGlobal::locale()->readDate( db->readField(ZdbAdrs::Birthday) ); |
244 | //qDebug("birtd %s ", birthd.toString().latin1()); | 244 | //qDebug("birtd %s ", birthd.toString().latin1()); |
245 | if (birthd.isValid()) | 245 | if (birthd.isValid()) |
246 | addr.setBirthday( birthd ); | 246 | addr.setBirthday( birthd ); |
247 | 247 | ||
248 | addr.setNickName( db->readField(ZdbAdrs::Nickname) ); | 248 | addr.setNickName( db->readField(ZdbAdrs::Nickname) ); |
249 | 249 | ||
250 | // others | 250 | // others |
251 | //US I put opies BusinessWebPage into Ka/Pi's notes block, because no other native field is available. | 251 | //US I put opies BusinessWebPage into Ka/Pi's notes block, because no other native field is available. |
252 | //QString notes = db->readField(ZdbAdrs::Notes); | 252 | //QString notes = db->readField(ZdbAdrs::Notes); |
253 | //notes += "\nBusinessWebPage: " + db->readField(ZdbAdrs::BusinessWebPage) + "\n"; | 253 | //notes += "\nBusinessWebPage: " + db->readField(ZdbAdrs::BusinessWebPage) + "\n"; |
254 | if ( addr.url().isEmpty() ) | 254 | if ( addr.url().isEmpty() ) |
255 | addr.setUrl( db->readField(ZdbAdrs::BusinessWebPage) ); | 255 | addr.setUrl( db->readField(ZdbAdrs::BusinessWebPage) ); |
256 | addr.setNote( db->readField(ZdbAdrs::Notes).replace( QRegExp("\\r"), "")); | 256 | addr.setNote( db->readField(ZdbAdrs::Notes).replace( QRegExp("\\r"), "")); |
257 | 257 | ||
258 | 258 | ||
259 | 259 | ||
260 | //US QString groups() const { return find( Qtopia::Groups ); } | 260 | //US QString groups() const { return find( Qtopia::Groups ); } |
261 | //US QStringList groupList() const; | 261 | //US QStringList groupList() const; |
262 | 262 | ||
263 | //qDebug("SharpDTMConverter::sharpToAddressee please check that the categories will be converted" ); | 263 | //qDebug("SharpDTMConverter::sharpToAddressee please check that the categories will be converted" ); |
264 | QArray<int> catArray = db->readCategories(); | 264 | QArray<int> catArray = db->readCategories(); |
265 | QString cat; | 265 | QString cat; |
266 | 266 | ||
267 | for ( unsigned int i=0; i < catArray.size(); i++ ) { | 267 | for ( unsigned int i=0; i < catArray.size(); i++ ) { |
268 | cat = catDB->label(catArray[i]); | 268 | cat = catDB->label(catArray[i]); |
269 | if ( cat.isEmpty() ) | 269 | if ( cat.isEmpty() ) |
270 | addr.insertCategory(QString::number(catArray[i])); | 270 | addr.insertCategory(QString::number(catArray[i])); |
271 | else | 271 | else |
272 | addr.insertCategory( cat ); | 272 | addr.insertCategory( cat ); |
273 | } | 273 | } |
274 | 274 | ||
275 | return true; | 275 | return true; |
276 | } | 276 | } |
277 | 277 | ||
278 | bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ) | 278 | bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ) |
279 | { | 279 | { |
280 | bool cellHome = false, cellWork = false; | 280 | bool cellHome = false, cellWork = false; |
281 | // name | 281 | // name |
282 | database->writeField(ZdbAdrs::LastName, addr.familyName()); | 282 | database->writeField(ZdbAdrs::LastName, addr.familyName()); |
283 | database->writeField(ZdbAdrs::FirstName, addr.givenName()); | 283 | database->writeField(ZdbAdrs::FirstName, addr.givenName()); |
284 | database->writeField(ZdbAdrs::MiddleName, addr.additionalName()); | 284 | database->writeField(ZdbAdrs::MiddleName, addr.additionalName()); |
285 | database->writeField(ZdbAdrs::Title, addr.prefix()); | 285 | database->writeField(ZdbAdrs::Title, addr.prefix()); |
286 | database->writeField(ZdbAdrs::Suffix, addr.suffix()); | 286 | database->writeField(ZdbAdrs::Suffix, addr.suffix()); |
287 | 287 | ||
288 | //qDebug("SharpDTMConverter::addresseeToSharp check if the fileAs transformation works!!\n%s",addr.formattedName().latin1() ); | 288 | //qDebug("SharpDTMConverter::addresseeToSharp check if the fileAs transformation works!!\n%s",addr.formattedName().latin1() ); |
289 | QString formattedName = addr.formattedName(); | 289 | QString formattedName = addr.formattedName(); |
290 | if ( formattedName.isEmpty() ) { | 290 | if ( formattedName.isEmpty() ) { |
291 | if ( !addr.familyName().isEmpty() ) { | 291 | if ( !addr.familyName().isEmpty() ) { |
292 | formattedName = addr.familyName(); | 292 | formattedName = addr.familyName(); |
293 | if ( !addr.givenName().isEmpty() ) { | 293 | if ( !addr.givenName().isEmpty() ) { |
294 | formattedName += ", "; | 294 | formattedName += ", "; |
295 | formattedName += addr.givenName(); | 295 | formattedName += addr.givenName(); |
296 | } | 296 | } |
297 | } else | 297 | } else |
298 | formattedName = addr.givenName(); | 298 | formattedName = addr.givenName(); |
299 | } | 299 | } |
300 | database->writeField(ZdbAdrs::FileAs, formattedName); | 300 | database->writeField(ZdbAdrs::FileAs, formattedName); |
301 | database->writeField(ZdbAdrs::FullName, formattedName); | 301 | database->writeField(ZdbAdrs::FullName, formattedName); |
302 | 302 | ||
303 | 303 | ||
304 | //qDebug("SharpDTMConverter::addresseeToSharp check which seperator we need here for the emails!!"); | 304 | //qDebug("SharpDTMConverter::addresseeToSharp check which seperator we need here for the emails!!"); |
305 | //qDebug("SharpDTMConverter::addresseeToSharp its probably the same from sharpToAddressee"); | 305 | //qDebug("SharpDTMConverter::addresseeToSharp its probably the same from sharpToAddressee"); |
306 | QString emails = addr.emails().join(" "); | 306 | QString emails = addr.emails().join(" "); |
307 | database->writeField(ZdbAdrs::Emails, emails ); | 307 | database->writeField(ZdbAdrs::Emails, emails ); |
308 | 308 | ||
309 | database->writeField(ZdbAdrs::DefaultEmail, addr.preferredEmail() ); | 309 | database->writeField(ZdbAdrs::DefaultEmail, addr.preferredEmail() ); |
310 | |||
311 | |||
312 | // home | 310 | // home |
313 | const Address homeaddress = addr.address(Address::Home); | 311 | const Address homeaddress = addr.address(Address::Home); |
314 | if (!homeaddress.isEmpty()) { | 312 | database->writeField(ZdbAdrs::HomeStreet, homeaddress.street()); |
315 | //qDebug("write home address "); | 313 | database->writeField(ZdbAdrs::HomeCity, homeaddress.locality()); |
316 | database->writeField(ZdbAdrs::HomeStreet, homeaddress.street()); | 314 | database->writeField(ZdbAdrs::HomeState, homeaddress.region()); |
317 | database->writeField(ZdbAdrs::HomeCity, homeaddress.locality()); | 315 | database->writeField(ZdbAdrs::HomeZip, homeaddress.postalCode()); |
318 | database->writeField(ZdbAdrs::HomeState, homeaddress.region()); | 316 | database->writeField(ZdbAdrs::HomeCountry, homeaddress.country()); |
319 | database->writeField(ZdbAdrs::HomeZip, homeaddress.postalCode()); | 317 | |
320 | database->writeField(ZdbAdrs::HomeCountry, homeaddress.country()); | ||
321 | } | ||
322 | |||
323 | PhoneNumber homephone = addr.phoneNumber( PhoneNumber::Home ); | 318 | PhoneNumber homephone = addr.phoneNumber( PhoneNumber::Home ); |
324 | if (!homephone.number().isEmpty()) | 319 | database->writeField(ZdbAdrs::HomePhone, homephone.number()); |
325 | database->writeField(ZdbAdrs::HomePhone, homephone.number()); | ||
326 | |||
327 | PhoneNumber homefax = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ); | 320 | PhoneNumber homefax = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ); |
328 | if (!homefax.number().isEmpty()) | 321 | database->writeField(ZdbAdrs::HomeFax, homefax.number()); |
329 | database->writeField(ZdbAdrs::HomeFax, homefax.number()); | ||
330 | |||
331 | PhoneNumber homemobile = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Cell ); | 322 | PhoneNumber homemobile = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Cell ); |
323 | database->writeField(ZdbAdrs::HomeMobile, homemobile.number()); | ||
332 | if (!homemobile.number().isEmpty()) { | 324 | if (!homemobile.number().isEmpty()) { |
333 | database->writeField(ZdbAdrs::HomeMobile, homemobile.number()); | ||
334 | cellHome = true; | 325 | cellHome = true; |
335 | } | 326 | } |
336 | |||
337 | database->writeField(ZdbAdrs::HomeWebPage, addr.url().url()); | 327 | database->writeField(ZdbAdrs::HomeWebPage, addr.url().url()); |
338 | |||
339 | |||
340 | // business | 328 | // business |
341 | const Address businessaddress = addr.address(Address::Work); | 329 | const Address businessaddress = addr.address(Address::Work); |
342 | if (!businessaddress.isEmpty()) { | ||
343 | //qDebug("write business address "); | 330 | //qDebug("write business address "); |
344 | database->writeField(ZdbAdrs::BusinessStreet, businessaddress.street()); | 331 | database->writeField(ZdbAdrs::BusinessStreet, businessaddress.street()); |
345 | database->writeField(ZdbAdrs::BusinessCity, businessaddress.locality()); | 332 | database->writeField(ZdbAdrs::BusinessCity, businessaddress.locality()); |
346 | database->writeField(ZdbAdrs::BusinessState, businessaddress.region()); | 333 | database->writeField(ZdbAdrs::BusinessState, businessaddress.region()); |
347 | database->writeField(ZdbAdrs::BusinessZip, businessaddress.postalCode()); | 334 | database->writeField(ZdbAdrs::BusinessZip, businessaddress.postalCode()); |
348 | database->writeField(ZdbAdrs::BusinessCountry, businessaddress.country()); | 335 | database->writeField(ZdbAdrs::BusinessCountry, businessaddress.country()); |
349 | } | 336 | |
350 | |||
351 | PhoneNumber businessphone = addr.phoneNumber( PhoneNumber::Work ); | 337 | PhoneNumber businessphone = addr.phoneNumber( PhoneNumber::Work ); |
352 | if (!businessphone.number().isEmpty()) | 338 | database->writeField(ZdbAdrs::BusinessPhone, businessphone.number()); |
353 | database->writeField(ZdbAdrs::BusinessPhone, businessphone.number()); | ||
354 | 339 | ||
355 | PhoneNumber businessfax = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ); | 340 | PhoneNumber businessfax = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ); |
356 | if (!businessfax.number().isEmpty()) | 341 | database->writeField(ZdbAdrs::BusinessFax, businessfax.number()); |
357 | database->writeField(ZdbAdrs::BusinessFax, businessfax.number()); | ||
358 | 342 | ||
359 | PhoneNumber businessmobile = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Cell ); | 343 | PhoneNumber businessmobile = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Cell ); |
344 | database->writeField(ZdbAdrs::BusinessMobile, businessmobile.number()); | ||
360 | if (!businessmobile.number().isEmpty()) { | 345 | if (!businessmobile.number().isEmpty()) { |
361 | cellWork = true; | 346 | cellWork = true; |
362 | database->writeField(ZdbAdrs::BusinessMobile, businessmobile.number()); | ||
363 | } | 347 | } |
364 | PhoneNumber mobile = addr.phoneNumber( PhoneNumber::Cell ); | 348 | PhoneNumber mobile = addr.phoneNumber( PhoneNumber::Cell ); |
365 | if (! mobile.number().isEmpty()) { | 349 | if (! mobile.number().isEmpty()) { |
366 | if ( ! cellHome ) | 350 | if ( ! cellHome ) |
367 | database->writeField(ZdbAdrs::HomeMobile, mobile.number()); | 351 | database->writeField(ZdbAdrs::HomeMobile, mobile.number()); |
368 | else if (! cellWork ) | 352 | else if (! cellWork ) |
369 | database->writeField(ZdbAdrs::BusinessMobile, mobile.number()); | 353 | database->writeField(ZdbAdrs::BusinessMobile, mobile.number()); |
370 | } | 354 | } |
371 | 355 | ||
372 | PhoneNumber businesspager = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Pager ); | 356 | PhoneNumber businesspager = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Pager ); |
373 | if (!businesspager.number().isEmpty()) | 357 | database->writeField(ZdbAdrs::BusinessPager, businesspager.number()); |
374 | database->writeField(ZdbAdrs::BusinessPager, businesspager.number()); | ||
375 | 358 | ||
376 | database->writeField(ZdbAdrs::JobTitle, addr.role()); | 359 | database->writeField(ZdbAdrs::JobTitle, addr.role()); |
377 | database->writeField(ZdbAdrs::Company, addr.organization()); | 360 | database->writeField(ZdbAdrs::Company, addr.organization()); |
378 | 361 | ||
379 | database->writeField(ZdbAdrs::Profession, addr.custom( "KADDRESSBOOK", "X-Profession" )); | 362 | database->writeField(ZdbAdrs::Profession, addr.custom( "KADDRESSBOOK", "X-Profession" )); |
380 | database->writeField(ZdbAdrs::Assistant, addr.custom( "KADDRESSBOOK", "X-AssistantsName" )); | 363 | database->writeField(ZdbAdrs::Assistant, addr.custom( "KADDRESSBOOK", "X-AssistantsName" )); |
381 | database->writeField(ZdbAdrs::Department, addr.custom( "KADDRESSBOOK", "X-Department" )); | 364 | database->writeField(ZdbAdrs::Department, addr.custom( "KADDRESSBOOK", "X-Department" )); |
382 | database->writeField(ZdbAdrs::Manager, addr.custom( "KADDRESSBOOK", "X-ManagersName" )); | 365 | database->writeField(ZdbAdrs::Manager, addr.custom( "KADDRESSBOOK", "X-ManagersName" )); |
383 | database->writeField(ZdbAdrs::Office, addr.custom( "KADDRESSBOOK", "X-Office" )); | 366 | database->writeField(ZdbAdrs::Office, addr.custom( "KADDRESSBOOK", "X-Office" )); |
384 | 367 | ||
385 | //personal | 368 | //personal |
386 | database->writeField(ZdbAdrs::Spouse, addr.custom( "KADDRESSBOOK", "X-Spouse" )); | 369 | database->writeField(ZdbAdrs::Spouse, addr.custom( "KADDRESSBOOK", "X-Spouse" )); |
387 | 370 | ||
388 | QString gt = addr.custom( "KADDRESSBOOK", "X-Gender" ); | 371 | QString gt = addr.custom( "KADDRESSBOOK", "X-Gender" ); |
389 | //qDebug("SharpDTMConverter::addresseeToSharp please check that gender works!! : Gender: %s", gt.latin1()); | 372 | //qDebug("SharpDTMConverter::addresseeToSharp please check that gender works!! : Gender: %s", gt.latin1()); |
390 | //qDebug("SharpDTMConverter::addresseeToSharp: may be writeField(\"ZdbAdrs::Gender\", ushort) is here better suited?"); | 373 | //qDebug("SharpDTMConverter::addresseeToSharp: may be writeField(\"ZdbAdrs::Gender\", ushort) is here better suited?"); |
391 | //qDebug("SharpDTMConverter::addresseeToSharp: check also the reverse functionality in sharpToAddressee"); | 374 | //qDebug("SharpDTMConverter::addresseeToSharp: check also the reverse functionality in sharpToAddressee"); |
392 | if (gt == "male") | 375 | if (gt == "male") |
393 | database->writeField(ZdbAdrs::Gender, "male"); | 376 | database->writeField(ZdbAdrs::Gender, "male"); |
394 | else if (gt == "female") | 377 | else if (gt == "female") |
395 | database->writeField(ZdbAdrs::Gender, "female"); | 378 | database->writeField(ZdbAdrs::Gender, "female"); |
396 | else | 379 | else |
397 | database->writeField(ZdbAdrs::Gender, ""); | 380 | database->writeField(ZdbAdrs::Gender, ""); |
398 | 381 | ||
399 | 382 | QString dateS ; | |
400 | QDate dt = KGlobal::locale()->readDate( | 383 | QDate dt = KGlobal::locale()->readDate(addr.custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); // = Qt::ISODate |
401 | addr.custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); // = Qt::ISODate | ||
402 | if ( dt.isValid() ) { | 384 | if ( dt.isValid() ) { |
403 | QString dateS = KGlobal::locale()->formatDate(dt, true ); | 385 | dateS = KGlobal::locale()->formatDate(dt, true ); |
404 | database->writeField(ZdbAdrs::Anniversary, dateS ); | ||
405 | } | 386 | } |
387 | database->writeField(ZdbAdrs::Anniversary, dateS ); | ||
406 | database->writeField(ZdbAdrs::Children, addr.custom( "KADDRESSBOOK", "X-Children" )); | 388 | database->writeField(ZdbAdrs::Children, addr.custom( "KADDRESSBOOK", "X-Children" )); |
407 | dt = addr.birthday().date(); | 389 | dt = addr.birthday().date(); |
390 | dateS = ""; | ||
408 | if ( dt.isValid() ) { | 391 | if ( dt.isValid() ) { |
409 | QString dateS = KGlobal::locale()->formatDate(dt, true ); | 392 | dateS = KGlobal::locale()->formatDate(dt, true ); |
410 | database->writeField(ZdbAdrs::Birthday, dateS); | ||
411 | } | 393 | } |
394 | database->writeField(ZdbAdrs::Birthday, dateS); | ||
412 | database->writeField(ZdbAdrs::Nickname, addr.nickName()); | 395 | database->writeField(ZdbAdrs::Nickname, addr.nickName()); |
413 | 396 | ||
414 | // other | 397 | // other |
415 | database->writeField(ZdbAdrs::Notes, addr.note()); | 398 | database->writeField(ZdbAdrs::Notes, addr.note()); |
416 | 399 | ||
417 | //US QString groups() const { return find( Qtopia::Groups ); } | 400 | //US QString groups() const { return find( Qtopia::Groups ); } |
418 | //US QStringList groupList() const; | 401 | //US QStringList groupList() const; |
419 | 402 | ||
420 | 403 | ||
421 | //qDebug("SharpDTMConverter::addresseeToSharp please check if category transformation works"); | 404 | //qDebug("SharpDTMConverter::addresseeToSharp please check if category transformation works"); |
422 | 405 | ||
423 | QStringList cats = addr.categories(); | ||
424 | int ii; | ||
425 | for ( ii = 0; ii < cats.count() ;++ii ) { | ||
426 | if ( !catDB->exists( cats[ii] )) | ||
427 | catDB->addCategory(cats[ii]); | ||
428 | } | ||
429 | QArray<int> iar; | ||
430 | if ( !cats.isEmpty() ) { | ||
431 | QArray<int> iar = catDB->ids(cats); | ||
432 | //qDebug("***cat count is %d ", iar.count()); | ||
433 | database->updateCategories(contact, iar); | ||
434 | } | ||
435 | |||
436 | return true; | 406 | return true; |
437 | } | 407 | } |
438 | 408 | ||
409 | |||
410 | bool SharpDTMConverter::setCategories( const Addressee &addr, SlZDataBase* database , const CardId &contact ) | ||
411 | { | ||
412 | QStringList list = addr.categories(); | ||
413 | |||
414 | QArray<int> ids(list.count()); | ||
415 | uint index = 0; | ||
416 | for(uint i=0; i<ids.size(); i++){ | ||
417 | if(catDB->exists(list[i])){ | ||
418 | ids[index] = catDB->id(list[i]); | ||
419 | qDebug("set ex cat %d %s ",ids[index] , list[i].latin1()); | ||
420 | index++; | ||
421 | } else { | ||
422 | ids[index] = catDB->addCategory(list[i]); | ||
423 | qDebug("add new cat %d %s ",ids[index] , list[i].latin1()); | ||
424 | index++; | ||
425 | } | ||
426 | } | ||
427 | bool res ; | ||
428 | if ( res = database->updateCategories(contact, ids) ) | ||
429 | qDebug("cat updated "); | ||
430 | else | ||
431 | qDebug("error cat updating "); | ||
432 | |||
433 | return res; | ||
434 | } | ||
435 | |||
436 | #if 0 | ||
437 | m_pCategories = new SlCategories; | ||
438 | catDB | ||
439 | |||
440 | if(categories == QString::null) return true; | ||
441 | QStringList list = CSVParser::parse(categories); | ||
442 | QArray<int> ids(list.count()); | ||
443 | uint index = 0; | ||
444 | for(uint i=0; i<ids.size(); i++){ | ||
445 | #if 0 | ||
446 | bool ok; | ||
447 | ids[index] = list[i].toInt(&ok); | ||
448 | if(ok){ | ||
449 | index++; | ||
450 | } else { | ||
451 | if(m_pCategories->exists(list[i])){ | ||
452 | ids[index] = m_pCategories->id(list[i]); | ||
453 | index++; | ||
454 | } | ||
455 | } | ||
456 | #else | ||
457 | if(m_pCategories->exists(list[i])){ | ||
458 | ids[index] = m_pCategories->id(list[i]); | ||
459 | index++; | ||
460 | } else if(m_addCategory){ | ||
461 | ids[index] = m_pCategories->addCategory(list[i]); | ||
462 | index++; | ||
463 | } | ||
464 | #endif | ||
465 | } | ||
466 | if(ids.size() > 0 && index == 0){ | ||
467 | return true; | ||
468 | } else if(index != ids.size()){ | ||
469 | ids.resize(index); | ||
470 | } | ||
471 | if(!m_pZdb->updateCategories(id, ids)){ | ||
472 | return false; | ||
473 | } | ||
474 | return true; | ||
475 | #endif | ||
476 | |||
439 | QDate SharpDTMConverter::convertDate( QString s) | 477 | QDate SharpDTMConverter::convertDate( QString s) |
440 | { | 478 | { |
441 | QDate dt = KGlobal::locale()->readDate( s ); | 479 | QDate dt = KGlobal::locale()->readDate( s ); |
442 | return dt; | 480 | return dt; |
443 | return QDate (); | 481 | return QDate (); |
444 | } | 482 | } |
diff --git a/kabc/plugins/sharpdtm/sharpdtmconverter.h b/kabc/plugins/sharpdtm/sharpdtmconverter.h index a04083e..db1bf2d 100644 --- a/kabc/plugins/sharpdtm/sharpdtmconverter.h +++ b/kabc/plugins/sharpdtm/sharpdtmconverter.h | |||
@@ -1,87 +1,88 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkabc. | 2 | This file is part of libkabc. |
3 | Copyright (c) 2002 Tobias Koenig <tokoe@kde.org> | 3 | Copyright (c) 2002 Tobias Koenig <tokoe@kde.org> |
4 | 4 | ||
5 | This library is free software; you can redistribute it and/or | 5 | This library is free software; you can redistribute it and/or |
6 | modify it under the terms of the GNU Library General Public | 6 | modify it under the terms of the GNU Library General Public |
7 | License as published by the Free Software Foundation; either | 7 | License as published by the Free Software Foundation; either |
8 | version 2 of the License, or (at your option) any later version. | 8 | version 2 of the License, or (at your option) any later version. |
9 | 9 | ||
10 | This library is distributed in the hope that it will be useful, | 10 | This library is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
13 | Library General Public License for more details. | 13 | Library General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU Library General Public License | 15 | You should have received a copy of the GNU Library General Public License |
16 | along with this library; see the file COPYING.LIB. If not, write to | 16 | along with this library; see the file COPYING.LIB. If not, write to |
17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 17 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
18 | Boston, MA 02111-1307, USA. | 18 | Boston, MA 02111-1307, USA. |
19 | */ | 19 | */ |
20 | 20 | ||
21 | /* | 21 | /* |
22 | Enhanced Version of the file for platform independent KDE tools. | 22 | Enhanced Version of the file for platform independent KDE tools. |
23 | Copyright (c) 2004 Ulf Schenk | 23 | Copyright (c) 2004 Ulf Schenk |
24 | $Id$ | 24 | $Id$ |
25 | */ | 25 | */ |
26 | 26 | ||
27 | #ifndef KABC_SHARPDTMCONVERTER_H | 27 | #ifndef KABC_SHARPDTMCONVERTER_H |
28 | #define KABC_SHARPDTMCONVERTER_H | 28 | #define KABC_SHARPDTMCONVERTER_H |
29 | 29 | ||
30 | #include <qstring.h> | 30 | #include <qstring.h> |
31 | 31 | ||
32 | #include <sl/slzdb.h> | 32 | #include <sl/slzdb.h> |
33 | 33 | ||
34 | #include "addressee.h" | 34 | #include "addressee.h" |
35 | 35 | ||
36 | namespace SlCategory { | 36 | namespace SlCategory { |
37 | class SlCategories; | 37 | class SlCategories; |
38 | } | 38 | } |
39 | 39 | ||
40 | class SlZDataBase; | 40 | class SlZDataBase; |
41 | 41 | ||
42 | namespace KABC { | 42 | namespace KABC { |
43 | 43 | ||
44 | class SharpDTMConverter | 44 | class SharpDTMConverter |
45 | { | 45 | { |
46 | public: | 46 | public: |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * Constructor. | 49 | * Constructor. |
50 | */ | 50 | */ |
51 | SharpDTMConverter(); | 51 | SharpDTMConverter(); |
52 | 52 | ||
53 | /** | 53 | /** |
54 | * Destructor. | 54 | * Destructor. |
55 | */ | 55 | */ |
56 | virtual ~SharpDTMConverter(); | 56 | virtual ~SharpDTMConverter(); |
57 | 57 | ||
58 | bool init(); | 58 | bool init(); |
59 | void deinit(); | 59 | void deinit(); |
60 | 60 | ||
61 | /** | 61 | /** |
62 | * Converts a given sharp card to an addressee. | 62 | * Converts a given sharp card to an addressee. |
63 | * | 63 | * |
64 | * @param contact The sharp card id, eventhough it might be 0, if the contact is a new one. | 64 | * @param contact The sharp card id, eventhough it might be 0, if the contact is a new one. |
65 | * @param database The sharp database pointer we use for the conversion | 65 | * @param database The sharp database pointer we use for the conversion |
66 | * @param addr The addressee. | 66 | * @param addr The addressee. |
67 | */ | 67 | */ |
68 | bool sharpToAddressee( const CardId &contact, const SlZDataBase* database, Addressee &addr ); | 68 | bool sharpToAddressee( const CardId &contact, const SlZDataBase* database, Addressee &addr ); |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * Converts an addressee to a sharp dtm contact. | 71 | * Converts an addressee to a sharp dtm contact. |
72 | * | 72 | * |
73 | * @param addr The addressee. | 73 | * @param addr The addressee. |
74 | * @param database The sharp database pointer we use for the conversion | 74 | * @param database The sharp database pointer we use for the conversion |
75 | * @param contact The sharp card id, eventhough it might be 0, if the contact is a new one. | 75 | * @param contact The sharp card id, eventhough it might be 0, if the contact is a new one. |
76 | */ | 76 | */ |
77 | bool addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ); | 77 | bool addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ); |
78 | bool setCategories( const Addressee &addr, SlZDataBase* database , const CardId &contact ); | ||
78 | 79 | ||
79 | private: | 80 | private: |
80 | SlCategory::SlCategories* catDB; | 81 | SlCategory::SlCategories* catDB; |
81 | QDate convertDate( QString ); | 82 | QDate convertDate( QString ); |
82 | 83 | ||
83 | 84 | ||
84 | }; | 85 | }; |
85 | 86 | ||
86 | } | 87 | } |
87 | #endif | 88 | #endif |