-rw-r--r-- | kabc/converter/sharpdtm/sharpdtmconverter.cpp | 270 | ||||
-rw-r--r-- | kabc/converter/sharpdtm/sharpdtmconverter.h | 2 |
2 files changed, 147 insertions, 125 deletions
diff --git a/kabc/converter/sharpdtm/sharpdtmconverter.cpp b/kabc/converter/sharpdtm/sharpdtmconverter.cpp index 4cf2eb3..8f8334e 100644 --- a/kabc/converter/sharpdtm/sharpdtmconverter.cpp +++ b/kabc/converter/sharpdtm/sharpdtmconverter.cpp | |||
@@ -69,29 +69,34 @@ void SharpDTMConverter::deinit() | |||
69 | bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBase* database, Addressee &addr ) | 69 | bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBase* database, Addressee &addr ) |
70 | { | 70 | { |
71 | /*US | 71 | SlZDataBase* db = (SlZDataBase*)database; |
72 | // name | 72 | // name |
73 | addr.setFormattedName(contact.fileAs()); | 73 | qDebug("SharpDTMConverter::sharpToAddressee check if the fileAs transformation works!!"); |
74 | addr.setFamilyName( contact.lastName() ); | 74 | addr.setFormattedName(db->readField(ZdbAdrs::FileAs)); |
75 | addr.setGivenName( contact.firstName() ); | 75 | |
76 | addr.setAdditionalName( contact.middleName() ); | 76 | addr.setFamilyName( db->readField(ZdbAdrs::LastName) ); |
77 | addr.setPrefix( contact.nameTitle() ); | 77 | addr.setGivenName( db->readField(ZdbAdrs::FirstName) ); |
78 | addr.setSuffix( contact.suffix() ); | 78 | addr.setAdditionalName( db->readField(ZdbAdrs::MiddleName) ); |
79 | addr.setPrefix( db->readField(ZdbAdrs::Title) ); | ||
80 | addr.setSuffix( db->readField(ZdbAdrs::Suffix) ); | ||
79 | 81 | ||
80 | 82 | ||
81 | 83 | ||
82 | QStringList emails = contact.emailList(); | 84 | QString emailstr = db->readField(ZdbAdrs::Emails); |
85 | qDebug("SharpDTMConverter::sharpToAddressee whats the character to seperate the emailadresses? %s ", emailstr.latin1()); | ||
86 | QStringList emails = QStringList::split(",", emailstr); | ||
87 | |||
83 | for ( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { | 88 | for ( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { |
84 | addr.insertEmail( *it, ((*it) == contact.defaultEmail()) ); | 89 | addr.insertEmail( *it, ((*it) == db->readField(ZdbAdrs::DefaultEmail)) ); |
85 | } | 90 | } |
86 | 91 | ||
87 | if (!contact.defaultEmail().isEmpty()) | 92 | if (!db->readField(ZdbAdrs::DefaultEmail).isEmpty()) |
88 | addr.insertEmail(contact.defaultEmail(), true); | 93 | addr.insertEmail(db->readField(ZdbAdrs::DefaultEmail), true); |
89 | 94 | ||
90 | // home | 95 | // home |
91 | if ((!contact.homeStreet().isEmpty()) || | 96 | if ((!db->readField(ZdbAdrs::HomeStreet).isEmpty()) || |
92 | (!contact.homeCity().isEmpty()) || | 97 | (!db->readField(ZdbAdrs::HomeCity).isEmpty()) || |
93 | (!contact.homeState().isEmpty()) || | 98 | (!db->readField(ZdbAdrs::HomeState).isEmpty()) || |
94 | (!contact.homeZip().isEmpty()) || | 99 | (!db->readField(ZdbAdrs::HomeZip).isEmpty()) || |
95 | (!contact.homeCountry().isEmpty())) | 100 | (!db->readField(ZdbAdrs::HomeCountry).isEmpty())) |
96 | { | 101 | { |
97 | Address homeaddress; | 102 | Address homeaddress; |
@@ -99,46 +104,46 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
99 | //US homeaddress.setPostOfficeBox( "" ); | 104 | //US homeaddress.setPostOfficeBox( "" ); |
100 | //US homeaddress.setExtended( "" ); | 105 | //US homeaddress.setExtended( "" ); |
101 | homeaddress.setStreet( contact.homeStreet() ); | 106 | homeaddress.setStreet( db->readField(ZdbAdrs::HomeStreet) ); |
102 | homeaddress.setLocality( contact.homeCity() ); | 107 | homeaddress.setLocality( db->readField(ZdbAdrs::HomeCity) ); |
103 | homeaddress.setRegion( contact.homeState() ); | 108 | homeaddress.setRegion( db->readField(ZdbAdrs::HomeState) ); |
104 | homeaddress.setPostalCode( contact.homeZip() ); | 109 | homeaddress.setPostalCode( db->readField(ZdbAdrs::HomeZip) ); |
105 | homeaddress.setCountry( contact.homeCountry() ); | 110 | homeaddress.setCountry( db->readField(ZdbAdrs::HomeCountry) ); |
106 | 111 | ||
107 | addr.insertAddress( homeaddress ); | 112 | addr.insertAddress( homeaddress ); |
108 | } | 113 | } |
109 | 114 | ||
110 | if (!contact.homePhone().isEmpty()) | 115 | if (!db->readField(ZdbAdrs::HomePhone).isEmpty()) |
111 | { | 116 | { |
112 | PhoneNumber homephone; | 117 | PhoneNumber homephone; |
113 | homephone.setType( PhoneNumber::Home ); | 118 | homephone.setType( PhoneNumber::Home ); |
114 | homephone.setNumber( contact.homePhone() ); | 119 | homephone.setNumber( db->readField(ZdbAdrs::HomePhone) ); |
115 | addr.insertPhoneNumber( homephone ); | 120 | addr.insertPhoneNumber( homephone ); |
116 | } | 121 | } |
117 | 122 | ||
118 | if (!contact.homeFax().isEmpty()) | 123 | if (!db->readField(ZdbAdrs::HomeFax).isEmpty()) |
119 | { | 124 | { |
120 | PhoneNumber homefax; | 125 | PhoneNumber homefax; |
121 | homefax.setType( PhoneNumber::Home | PhoneNumber::Fax ); | 126 | homefax.setType( PhoneNumber::Home | PhoneNumber::Fax ); |
122 | homefax.setNumber( contact.homeFax() ); | 127 | homefax.setNumber( db->readField(ZdbAdrs::HomeFax) ); |
123 | addr.insertPhoneNumber( homefax ); | 128 | addr.insertPhoneNumber( homefax ); |
124 | } | 129 | } |
125 | 130 | ||
126 | if (!contact.homeMobile().isEmpty()) | 131 | if (!db->readField(ZdbAdrs::HomeMobile).isEmpty()) |
127 | { | 132 | { |
128 | PhoneNumber homemobile; | 133 | PhoneNumber homemobile; |
129 | homemobile.setType( PhoneNumber::Home | PhoneNumber::Cell ); | 134 | homemobile.setType( PhoneNumber::Home | PhoneNumber::Cell ); |
130 | homemobile.setNumber( contact.homeMobile() ); | 135 | homemobile.setNumber( db->readField(ZdbAdrs::HomeMobile) ); |
131 | addr.insertPhoneNumber( homemobile ); | 136 | addr.insertPhoneNumber( homemobile ); |
132 | } | 137 | } |
133 | 138 | ||
134 | addr.setUrl( contact.homeWebpage() ); | 139 | addr.setUrl( db->readField(ZdbAdrs::HomeWebPage) ); |
135 | 140 | ||
136 | 141 | ||
137 | // business | 142 | // business |
138 | if ((!contact.businessStreet().isEmpty()) || | 143 | if ((!db->readField(ZdbAdrs::BusinessStreet).isEmpty()) || |
139 | (!contact.businessCity().isEmpty()) || | 144 | (!db->readField(ZdbAdrs::BusinessCity).isEmpty()) || |
140 | (!contact.businessState().isEmpty()) || | 145 | (!db->readField(ZdbAdrs::BusinessState).isEmpty()) || |
141 | (!contact.businessZip().isEmpty()) || | 146 | (!db->readField(ZdbAdrs::BusinessZip).isEmpty()) || |
142 | (!contact.businessCountry().isEmpty())) | 147 | (!db->readField(ZdbAdrs::BusinessCountry).isEmpty())) |
143 | { | 148 | { |
144 | Address businessaddress; | 149 | Address businessaddress; |
@@ -146,9 +151,9 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
146 | //US businessaddress.setPostOfficeBox( "" ); | 151 | //US businessaddress.setPostOfficeBox( "" ); |
147 | //US businessaddress.setExtended( "" ); | 152 | //US businessaddress.setExtended( "" ); |
148 | businessaddress.setStreet( contact.businessStreet() ); | 153 | businessaddress.setStreet( db->readField(ZdbAdrs::BusinessStreet) ); |
149 | businessaddress.setLocality( contact.businessCity() ); | 154 | businessaddress.setLocality( db->readField(ZdbAdrs::BusinessCity) ); |
150 | businessaddress.setRegion( contact.businessState() ); | 155 | businessaddress.setRegion( db->readField(ZdbAdrs::BusinessState) ); |
151 | businessaddress.setPostalCode( contact.businessZip() ); | 156 | businessaddress.setPostalCode( db->readField(ZdbAdrs::BusinessZip) ); |
152 | businessaddress.setCountry( contact.businessCountry() ); | 157 | businessaddress.setCountry( db->readField(ZdbAdrs::BusinessCountry) ); |
153 | 158 | ||
154 | addr.insertAddress( businessaddress ); | 159 | addr.insertAddress( businessaddress ); |
@@ -156,55 +161,61 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
156 | 161 | ||
157 | 162 | ||
158 | if (!contact.businessPhone().isEmpty()) | 163 | if (!db->readField(ZdbAdrs::BusinessPhone).isEmpty()) |
159 | { | 164 | { |
160 | PhoneNumber businessphone; | 165 | PhoneNumber businessphone; |
161 | businessphone.setType( PhoneNumber::Work ); | 166 | businessphone.setType( PhoneNumber::Work ); |
162 | businessphone.setNumber( contact.businessPhone() ); | 167 | businessphone.setNumber( db->readField(ZdbAdrs::BusinessPhone) ); |
163 | addr.insertPhoneNumber( businessphone ); | 168 | addr.insertPhoneNumber( businessphone ); |
164 | } | 169 | } |
165 | 170 | ||
166 | if (!contact.businessFax().isEmpty()) | 171 | if (!db->readField(ZdbAdrs::BusinessFax).isEmpty()) |
167 | { | 172 | { |
168 | PhoneNumber businessfax; | 173 | PhoneNumber businessfax; |
169 | businessfax.setType( PhoneNumber::Work | PhoneNumber::Fax ); | 174 | businessfax.setType( PhoneNumber::Work | PhoneNumber::Fax ); |
170 | businessfax.setNumber( contact.businessFax() ); | 175 | businessfax.setNumber( db->readField(ZdbAdrs::BusinessFax) ); |
171 | addr.insertPhoneNumber( businessfax ); | 176 | addr.insertPhoneNumber( businessfax ); |
172 | } | 177 | } |
173 | 178 | ||
174 | if (!contact.businessMobile().isEmpty()) | 179 | if (!db->readField(ZdbAdrs::BusinessMobile).isEmpty()) |
175 | { | 180 | { |
176 | PhoneNumber businessmobile; | 181 | PhoneNumber businessmobile; |
177 | businessmobile.setType( PhoneNumber::Work | PhoneNumber::Cell ); | 182 | businessmobile.setType( PhoneNumber::Work | PhoneNumber::Cell ); |
178 | businessmobile.setNumber( contact.businessMobile() ); | 183 | businessmobile.setNumber( db->readField(ZdbAdrs::BusinessMobile) ); |
179 | addr.insertPhoneNumber( businessmobile ); | 184 | addr.insertPhoneNumber( businessmobile ); |
180 | } | 185 | } |
181 | 186 | ||
182 | if (!contact.businessPager().isEmpty()) | 187 | if (!db->readField(ZdbAdrs::BusinessPager).isEmpty()) |
183 | { | 188 | { |
184 | PhoneNumber businesspager; | 189 | PhoneNumber businesspager; |
185 | businesspager.setType( PhoneNumber::Work | PhoneNumber::Pager ); | 190 | businesspager.setType( PhoneNumber::Work | PhoneNumber::Pager ); |
186 | businesspager.setNumber( contact.businessPager() ); | 191 | businesspager.setNumber( db->readField(ZdbAdrs::BusinessPager) ); |
187 | addr.insertPhoneNumber( businesspager ); | 192 | addr.insertPhoneNumber( businesspager ); |
188 | } | 193 | } |
189 | 194 | ||
190 | addr.setRole( contact.jobTitle() ); //? | 195 | addr.setRole( db->readField(ZdbAdrs::JobTitle) ); //? |
191 | addr.setOrganization( contact.company() ); | 196 | addr.setOrganization( db->readField(ZdbAdrs::Company) ); |
192 | addr.insertCustom( "KADDRESSBOOK", "X-Profession", contact.profession() ); | 197 | addr.insertCustom( "KADDRESSBOOK", "X-Profession", db->readField(ZdbAdrs::Profession) ); |
193 | addr.insertCustom( "KADDRESSBOOK", "X-AssistantsName", contact.assistant() ); | 198 | addr.insertCustom( "KADDRESSBOOK", "X-AssistantsName", db->readField(ZdbAdrs::Assistant) ); |
194 | addr.insertCustom( "KADDRESSBOOK", "X-Department", contact.department() ); | 199 | addr.insertCustom( "KADDRESSBOOK", "X-Department", db->readField(ZdbAdrs::Department) ); |
195 | addr.insertCustom( "KADDRESSBOOK", "X-ManagersName", contact.manager() ); | 200 | addr.insertCustom( "KADDRESSBOOK", "X-ManagersName", db->readField(ZdbAdrs::Manager) ); |
196 | addr.insertCustom( "KADDRESSBOOK", "X-Office", contact.office() ); | 201 | addr.insertCustom( "KADDRESSBOOK", "X-Office", db->readField(ZdbAdrs::Office) ); |
197 | 202 | ||
198 | //personal | 203 | //personal |
199 | addr.insertCustom( "KADDRESSBOOK", "X-SpousesName", contact.spouse() ); | 204 | addr.insertCustom( "KADDRESSBOOK", "X-SpousesName", db->readField(ZdbAdrs::Spouse) ); |
200 | // qtopia uses this categorization: | 205 | |
201 | // enum GenderType { UnspecifiedGender=0, Male, Female }; | 206 | QString gen = db->readField(ZdbAdrs::Gender); |
202 | if (contact.gender() == PimContact::Male) | 207 | qDebug("SharpDTMConverter::sharpToAddressee pleas check that gender works!! : Gender: %s", gen.latin1()); |
208 | qDebug("SharpDTMConverter::sharpToAddressee: may be int db->readUshortField(\"ZdbAdrs::Gender\") is here better suited"); | ||
209 | |||
210 | if (gen == "male") | ||
203 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "male"); | 211 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "male"); |
204 | else if (contact.gender() == PimContact::Female) | 212 | else if (gen == "female") |
205 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "female"); | 213 | addr.insertCustom( "KADDRESSBOOK", "X-Gender", "female"); |
206 | 214 | ||
207 | if (contact.anniversary().isValid()) { | 215 | |
208 | QString dt = KGlobal::locale()->formatDate(contact.anniversary(), true, KLocale::ISODate); | 216 | QDate ann = db->readDateField(ZdbAdrs::Anniversary); |
217 | |||
218 | if (ann.isValid()) { | ||
219 | QString dt = KGlobal::locale()->formatDate(ann, true, KLocale::ISODate); | ||
209 | //US | 220 | //US |
210 | // qDebug("QtopiaConverter::qtopiaToAddressee found:%s", dt.latin1()); | 221 | // qDebug("QtopiaConverter::qtopiaToAddressee found:%s", dt.latin1()); |
@@ -212,16 +223,19 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
212 | } | 223 | } |
213 | 224 | ||
214 | addr.insertCustom( "KADDRESSBOOK", "X-Children", contact.children() ); | 225 | addr.insertCustom( "KADDRESSBOOK", "X-Children", db->readField(ZdbAdrs::Children) ); |
215 | if (contact.birthday().isValid()) | 226 | |
216 | addr.setBirthday( contact.birthday() ); | 227 | |
228 | QDate birthd = db->readDateField(ZdbAdrs::Birthday); | ||
229 | if (birthd.isValid()) | ||
230 | addr.setBirthday( birthd ); | ||
217 | 231 | ||
218 | addr.setNickName( contact.nickname() ); | 232 | addr.setNickName( db->readField(ZdbAdrs::Nickname) ); |
219 | 233 | ||
220 | // others | 234 | // others |
221 | //US I put opies BusinessWebPage into Ka/Pi's notes block, because no other native field is available. | 235 | //US I put opies BusinessWebPage into Ka/Pi's notes block, because no other native field is available. |
222 | QString notes = contact.notes(); | 236 | QString notes = db->readField(ZdbAdrs::Notes); |
223 | notes += "\nBusinessWebPage: " + contact.businessWebpage() + "\n"; | 237 | notes += "\nBusinessWebPage: " + db->readField(ZdbAdrs::BusinessWebPage) + "\n"; |
224 | 238 | ||
225 | addr.setNote( contact.notes() ); | 239 | addr.setNote( db->readField(ZdbAdrs::Notes) ); |
226 | 240 | ||
227 | 241 | ||
@@ -230,34 +244,39 @@ bool SharpDTMConverter::sharpToAddressee( const CardId &contact, const SlZDataBa | |||
230 | //US QStringList groupList() const; | 244 | //US QStringList groupList() const; |
231 | 245 | ||
232 | QArray<int> catArray = contact.categories(); | 246 | qDebug("SharpDTMConverter::sharpToAddressee please check that the categories will be converted" ); |
247 | QArray<int> catArray = db->readCategories(); | ||
233 | QString cat; | 248 | QString cat; |
234 | 249 | ||
235 | for ( unsigned int i=0; i < catArray.size(); i++ ) { | 250 | for ( unsigned int i=0; i < catArray.size(); i++ ) { |
236 | cat = catDB->label("contact", catArray[i]); | 251 | cat = catDB->label(catArray[i]); |
237 | if ( !cat.isEmpty() ) | 252 | if ( cat.isEmpty() ) |
253 | addr.insertCategory(QString::number(catArray[i])); | ||
254 | else | ||
238 | addr.insertCategory( cat ); | 255 | addr.insertCategory( cat ); |
239 | } | 256 | } |
240 | */ | 257 | |
241 | return true; | 258 | return true; |
242 | } | 259 | } |
243 | 260 | ||
244 | bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, const SlZDataBase* database , const CardId &contact ) | 261 | bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ) |
245 | { | 262 | { |
246 | /*US | ||
247 | // name | 263 | // name |
248 | contact.setLastName(addr.familyName()); | 264 | database->writeField(ZdbAdrs::LastName, addr.familyName()); |
249 | contact.setFirstName(addr.givenName()); | 265 | database->writeField(ZdbAdrs::FirstName, addr.givenName()); |
250 | contact.setMiddleName(addr.additionalName()); | 266 | database->writeField(ZdbAdrs::MiddleName, addr.additionalName()); |
251 | contact.setNameTitle(addr.prefix()); | 267 | database->writeField(ZdbAdrs::Title, addr.prefix()); |
252 | contact.setSuffix(addr.suffix()); | 268 | database->writeField(ZdbAdrs::Suffix, addr.suffix()); |
253 | contact.setFileAs(); | 269 | |
270 | qDebug("SharpDTMConverter::addresseeToSharp check if the fileAs transformation works!!"); | ||
271 | database->writeField(ZdbAdrs::FileAs, addr.formattedName()); | ||
254 | 272 | ||
255 | 273 | ||
256 | 274 | ||
257 | QStringList emails = addr.emails(); | 275 | qDebug("SharpDTMConverter::addresseeToSharp check which seperator we need here for the emails!!"); |
258 | for ( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { | 276 | qDebug("SharpDTMConverter::addresseeToSharp its probably the same from sharpToAddressee"); |
259 | contact.insertEmail(*it); | 277 | QString emails = addr.emails().join(","); |
260 | } | 278 | database->writeField(ZdbAdrs::Emails, emails ); |
261 | contact.setDefaultEmail( addr.preferredEmail() ); | 279 | |
280 | database->writeField(ZdbAdrs::DefaultEmail, addr.preferredEmail() ); | ||
262 | 281 | ||
263 | 282 | ||
@@ -265,24 +284,24 @@ bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, const SlZDataBa | |||
265 | const Address homeaddress = addr.address(Address::Home); | 284 | const Address homeaddress = addr.address(Address::Home); |
266 | if (!homeaddress.isEmpty()) { | 285 | if (!homeaddress.isEmpty()) { |
267 | contact.setHomeStreet(homeaddress.street()); | 286 | database->writeField(ZdbAdrs::HomeStreet, homeaddress.street()); |
268 | contact.setHomeCity(homeaddress.locality()); | 287 | database->writeField(ZdbAdrs::HomeCity, homeaddress.locality()); |
269 | contact.setHomeState(homeaddress.region()); | 288 | database->writeField(ZdbAdrs::HomeState, homeaddress.region()); |
270 | contact.setHomeZip(homeaddress.postalCode()); | 289 | database->writeField(ZdbAdrs::HomeZip, homeaddress.postalCode()); |
271 | contact.setHomeCountry(homeaddress.country()); | 290 | database->writeField(ZdbAdrs::HomeCountry, homeaddress.country()); |
272 | } | 291 | } |
273 | 292 | ||
274 | PhoneNumber homephone = addr.phoneNumber( PhoneNumber::Home ); | 293 | PhoneNumber homephone = addr.phoneNumber( PhoneNumber::Home ); |
275 | if (!homephone.number().isEmpty()) | 294 | if (!homephone.number().isEmpty()) |
276 | contact.setHomePhone(homephone.number()); | 295 | database->writeField(ZdbAdrs::HomePhone, homephone.number()); |
277 | 296 | ||
278 | PhoneNumber homefax = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ); | 297 | PhoneNumber homefax = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Fax ); |
279 | if (!homefax.number().isEmpty()) | 298 | if (!homefax.number().isEmpty()) |
280 | contact.setHomeFax(homefax.number()); | 299 | database->writeField(ZdbAdrs::HomeFax, homefax.number()); |
281 | 300 | ||
282 | PhoneNumber homemobile = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Cell ); | 301 | PhoneNumber homemobile = addr.phoneNumber( PhoneNumber::Home | PhoneNumber::Cell ); |
283 | if (!homemobile.number().isEmpty()) | 302 | if (!homemobile.number().isEmpty()) |
284 | contact.setHomeMobile(homemobile.number()); | 303 | database->writeField(ZdbAdrs::HomeMobile, homemobile.number()); |
285 | 304 | ||
286 | contact.setHomeWebpage(addr.url().url()); | 305 | database->writeField(ZdbAdrs::HomeWebPage, addr.url().url()); |
287 | 306 | ||
288 | 307 | ||
@@ -290,60 +309,62 @@ bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, const SlZDataBa | |||
290 | const Address businessaddress = addr.address(Address::Work); | 309 | const Address businessaddress = addr.address(Address::Work); |
291 | if (!businessaddress.isEmpty()) { | 310 | if (!businessaddress.isEmpty()) { |
292 | contact.setBusinessStreet(businessaddress.street()); | 311 | database->writeField(ZdbAdrs::BusinessStreet, businessaddress.street()); |
293 | contact.setBusinessCity(businessaddress.locality()); | 312 | database->writeField(ZdbAdrs::BusinessCity, businessaddress.locality()); |
294 | contact.setBusinessState(businessaddress.region()); | 313 | database->writeField(ZdbAdrs::BusinessState, businessaddress.region()); |
295 | contact.setBusinessZip(businessaddress.postalCode()); | 314 | database->writeField(ZdbAdrs::BusinessZip, businessaddress.postalCode()); |
296 | contact.setBusinessCountry(businessaddress.country()); | 315 | database->writeField(ZdbAdrs::BusinessCountry, businessaddress.country()); |
297 | } | 316 | } |
298 | 317 | ||
299 | PhoneNumber businessphone = addr.phoneNumber( PhoneNumber::Work ); | 318 | PhoneNumber businessphone = addr.phoneNumber( PhoneNumber::Work ); |
300 | if (!businessphone.number().isEmpty()) | 319 | if (!businessphone.number().isEmpty()) |
301 | contact.setBusinessPhone(businessphone.number()); | 320 | database->writeField(ZdbAdrs::BusinessPhone, businessphone.number()); |
302 | 321 | ||
303 | PhoneNumber businessfax = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ); | 322 | PhoneNumber businessfax = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Fax ); |
304 | if (!businessfax.number().isEmpty()) | 323 | if (!businessfax.number().isEmpty()) |
305 | contact.setBusinessFax(businessfax.number()); | 324 | database->writeField(ZdbAdrs::BusinessFax, businessfax.number()); |
306 | 325 | ||
307 | PhoneNumber businessmobile = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Cell ); | 326 | PhoneNumber businessmobile = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Cell ); |
308 | if (!businessmobile.number().isEmpty()) | 327 | if (!businessmobile.number().isEmpty()) |
309 | contact.setBusinessMobile(businessmobile.number()); | 328 | database->writeField(ZdbAdrs::BusinessMobile, businessmobile.number()); |
310 | 329 | ||
311 | PhoneNumber businesspager = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Pager ); | 330 | PhoneNumber businesspager = addr.phoneNumber( PhoneNumber::Work | PhoneNumber::Pager ); |
312 | if (!businesspager.number().isEmpty()) | 331 | if (!businesspager.number().isEmpty()) |
313 | contact.setBusinessPager(businesspager.number()); | 332 | database->writeField(ZdbAdrs::BusinessPager, businesspager.number()); |
314 | 333 | ||
315 | contact.setJobTitle(addr.role()); | 334 | database->writeField(ZdbAdrs::JobTitle, addr.role()); |
316 | contact.setCompany(addr.organization()); | 335 | database->writeField(ZdbAdrs::Company, addr.organization()); |
317 | 336 | ||
318 | contact.setProfession(addr.custom( "KADDRESSBOOK", "X-Profession" )); | 337 | database->writeField(ZdbAdrs::Profession, addr.custom( "KADDRESSBOOK", "X-Profession" )); |
319 | contact.setAssistant(addr.custom( "KADDRESSBOOK", "X-AssistantsName" )); | 338 | database->writeField(ZdbAdrs::Assistant, addr.custom( "KADDRESSBOOK", "X-AssistantsName" )); |
320 | contact.setDepartment(addr.custom( "KADDRESSBOOK", "X-Department" )); | 339 | database->writeField(ZdbAdrs::Department, addr.custom( "KADDRESSBOOK", "X-Department" )); |
321 | contact.setManager(addr.custom( "KADDRESSBOOK", "X-ManagersName" )); | 340 | database->writeField(ZdbAdrs::Manager, addr.custom( "KADDRESSBOOK", "X-ManagersName" )); |
322 | contact.setOffice(addr.custom( "KADDRESSBOOK", "X-Office" )); | 341 | database->writeField(ZdbAdrs::Office, addr.custom( "KADDRESSBOOK", "X-Office" )); |
323 | 342 | ||
324 | //personal | 343 | //personal |
325 | contact.setSpouse(addr.custom( "KADDRESSBOOK", "X-Spouse" )); | 344 | database->writeField(ZdbAdrs::Spouse, addr.custom( "KADDRESSBOOK", "X-Spouse" )); |
326 | // qtopia uses this categorization: | 345 | |
327 | // enum GenderType { UnspecifiedGender=0, Male, Female }; | ||
328 | QString gt = addr.custom( "KADDRESSBOOK", "X-Gender" ); | 346 | QString gt = addr.custom( "KADDRESSBOOK", "X-Gender" ); |
347 | qDebug("SharpDTMConverter::addresseeToSharp please check that gender works!! : Gender: %s", gt.latin1()); | ||
348 | qDebug("SharpDTMConverter::addresseeToSharp: may be writeField(\"ZdbAdrs::Gender\", ushort) is here better suited?"); | ||
349 | qDebug("SharpDTMConverter::addresseeToSharp: check also the reverse functionality in sharpToAddressee"); | ||
329 | if (gt = "male") | 350 | if (gt = "male") |
330 | contact.setGender(PimContact::Male); | 351 | database->writeField(ZdbAdrs::Gender, "male"); |
331 | else if (gt = "female") | 352 | else if (gt = "female") |
332 | contact.setGender(PimContact::Female); | 353 | database->writeField(ZdbAdrs::Gender, "female"); |
333 | else | 354 | else |
334 | contact.setGender(PimContact::UnspecifiedGender); | 355 | database->writeField(ZdbAdrs::Gender, ""); |
335 | 356 | ||
336 | 357 | ||
337 | QDate dt = KGlobal::locale()->readDate( | 358 | QDate dt = KGlobal::locale()->readDate( |
338 | addr.custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); // = Qt::ISODate | 359 | addr.custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); // = Qt::ISODate |
339 | contact.setAnniversary( dt ); | 360 | database->writeField(ZdbAdrs::Anniversary, dt ); |
340 | 361 | ||
341 | contact.setChildren(addr.custom( "KADDRESSBOOK", "X-Children" )); | 362 | database->writeField(ZdbAdrs::Children, addr.custom( "KADDRESSBOOK", "X-Children" )); |
342 | 363 | ||
343 | contact.setBirthday(addr.birthday().date()); | 364 | database->writeField(ZdbAdrs::Birthday, addr.birthday().date()); |
344 | contact.setNickname(addr.nickName()); | 365 | database->writeField(ZdbAdrs::Nickname, addr.nickName()); |
345 | 366 | ||
346 | // other | 367 | // other |
347 | contact.setNotes(addr.note()); | 368 | database->writeField(ZdbAdrs::Notes, addr.note()); |
348 | 369 | ||
349 | //US QString groups() const { return find( Qtopia::Groups ); } | 370 | //US QString groups() const { return find( Qtopia::Groups ); } |
@@ -351,12 +372,13 @@ bool SharpDTMConverter::addresseeToSharp( const Addressee &addr, const SlZDataBa | |||
351 | 372 | ||
352 | 373 | ||
353 | QStringList cats = addr.categories(); | 374 | qDebug("SharpDTMConverter::addresseeToSharp please check if category transformation works"); |
354 | 375 | ||
376 | QStringList cats = addr.categories(); | ||
355 | QArray<int> iar; | 377 | QArray<int> iar; |
356 | if ( !cats.isEmpty() ) { | 378 | if ( !cats.isEmpty() ) { |
357 | QArray<int> iar = catDB->ids("contact", cats); | 379 | QArray<int> iar = catDB->ids(cats); |
358 | contact.setCategories(iar); | 380 | database->updateCategories(contact, iar); |
359 | } | 381 | } |
360 | */ | 382 | |
361 | return true; | 383 | return true; |
362 | } | 384 | } |
diff --git a/kabc/converter/sharpdtm/sharpdtmconverter.h b/kabc/converter/sharpdtm/sharpdtmconverter.h index 6a55431..99e0413 100644 --- a/kabc/converter/sharpdtm/sharpdtmconverter.h +++ b/kabc/converter/sharpdtm/sharpdtmconverter.h | |||
@@ -75,5 +75,5 @@ public: | |||
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, const SlZDataBase* database , const CardId &contact ); | 77 | bool addresseeToSharp( const Addressee &addr, SlZDataBase* database , const CardId &contact ); |
78 | 78 | ||
79 | private: | 79 | private: |