summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/TODO16
-rw-r--r--core/pim/addressbook/abtable.cpp40
-rw-r--r--core/pim/addressbook/abview.cpp48
-rw-r--r--core/pim/addressbook/contacteditor.cpp75
-rw-r--r--core/pim/addressbook/contacteditor.h5
-rw-r--r--core/pim/addressbook/ocontactfields.cpp101
-rw-r--r--core/pim/addressbook/ocontactfields.h34
-rw-r--r--core/pim/addressbook/version.h4
8 files changed, 251 insertions, 72 deletions
diff --git a/core/pim/addressbook/TODO b/core/pim/addressbook/TODO
index 76247c1..c600d20 100644
--- a/core/pim/addressbook/TODO
+++ b/core/pim/addressbook/TODO
@@ -1,112 +1,114 @@
1Stuff todo until OPIE 1.0 : 1Stuff todo until OPIE 1.0 :
2=========================== 2===========================
3 3
4Feature requests: 4Feature requests:
5----------------- 5-----------------
6- Dial by mobile phone by tapping the number.. 6- Dial by mobile phone by tapping the number..
7 (Maybe using gsmtool. And we may 7 (Maybe using gsmtool. And we may
8 add a library class for this) 8 add a library class for this)
9- dial with dtmfdial incase it's installed and there's no mobile 9- dial with dtmfdial in case it's installed and there's no mobile
10- 3rd column for 2. Contact 10- 3rd column for 2. Contact
11- Implementing additional Views (Phonebook, ...) 11- Implementing additional Views (Phonebook, ...)
12- Birthday & Anniversary Reminder 12- Birthday & Anniversary Reminder
13- Plugin for Today for Birthdays and Anniversaries
14- Beaming of multiple contacts (current list/ by search or by category) 13- Beaming of multiple contacts (current list/ by search or by category)
14- Configure the letter-picker: lastname/fullname search
15 15
16Known Bugs: 16Known Bugs:
17----------- 17-----------
18 18- Email-button: A lot of problems.. :(
19- Default Email-Button: Sometimes not hiding the textfields completely
19 20
20Bugs but not in addressbook: 21Bugs but not in addressbook:
21----------------------------- 22-----------------------------
22- VCARD: If umlaut (äöüß) in address, the parser gets confused.. 23- VCARD: If umlaut (äöüß) in address, the parser gets confused..
23 24
24- Exporting and reimporting of Jobtitle was reported to fail (Could not reproduce this ! (se)) 25- Exporting and reimporting of Jobtitle was reported to fail (Could not reproduce this ! (se))
25 26
26 27
27Urgent: 28Urgent:
28-------- 29--------
29ContactEditor: 30ContactEditor:
30- Contact-Editor is temporarely reenabled. Wait for replacement. 31- Contact-Editor is temporarely reenabled. Wait for replacement.
31- Redesign of Contacteditor 32- Redesign of Contacteditor
32- Store last settings of combo-boxes
33- Category is on the wrong position after changing to personal and back to normal 33- Category is on the wrong position after changing to personal and back to normal
34 ( Temporarily workaround: Category is never deactivated.. :S ) 34 ( Temporarily workaround: Category is never deactivated.. :S )
35 35
36- Personal and Business Web-page is not editable 36- Personal and Business Web-page is not editable
37 37
38Important: 38Important:
39---------- 39----------
40 40
41- If new contact is added (contacteditor closed): focus (table, card) to 41- If new contact is added (contacteditor closed): focus (table, card) to
42 this entry ! 42 this entry !
43- Implement a picker/combo for the default email.
44- After search (Started with Return): KeyFocus should be on Tabelle 43- After search (Started with Return): KeyFocus should be on Tabelle
45 44
46- "What's this" should be added (Deleyed after Feature Freeze) 45- "What's this" should be added (Deleyed after Feature Freeze)
47 46
48Less important: 47Less important:
49--------------- 48---------------
50- Reload if contacts were changed externally 49- Reload if contacts were changed externally
51- Overview window cleanup needed..
52- The picker (alphabetical sort widget) should be 50- The picker (alphabetical sort widget) should be
53 placed verticaly or horizontally (configurable) 51 placed verticaly or horizontally (configurable)
54- Find a smart solution for activating/deactivating the "send email" event 52- Find a smart solution for activating/deactivating the "send email" event
55 53
56Should be Fixed (not absolute sure, need further validation): 54Should be Fixed (not absolute sure, need further validation):
57------------------------------------------------------------- 55-------------------------------------------------------------
58 56
59 57
60Fixed: 58Fixed/Ready:
61------- 59-------
62- Syncing: abtable not reloaded after sync. 60- Syncing: abtable not reloaded after sync.
63- Find widget should be replaced by something like 61- Find widget should be replaced by something like
64 qpdf has. 62 qpdf has.
65- Adding a configuration dialog 63- Adding a configuration dialog
66- Picker: Activated letter schould be more visible 64- Picker: Activated letter schould be more visible
67- Advanced handling of cursor keys (search..) 65- Advanced handling of cursor keys (search..)
68- Mail-Icon is missing 66- Mail-Icon is missing
69- Use opie-mail insted of qt-mail if possible. 67- Use opie-mail insted of qt-mail if possible.
70- Font menu is invisible using german translation 68- Font menu is invisible using german translation
71- Personal contact editor: Disable categories 69- Personal contact editor: Disable categories
72- "Nonenglish" translation bug has to be fixed. 70- "Nonenglish" translation bug has to be fixed.
73- contacteditor: Birthday, annyversary, ... : Use Dateselector 71- contacteditor: Birthday, annyversary, ... : Use Dateselector
74- The names of the countries are sorted by there english names, only.. 72- The names of the countries are sorted by there english names, only..
75 Even if they are translated.. :S 73 Even if they are translated.. :S
76- Cursor keys should work in detail-view (ablabel) 74- Cursor keys should work in detail-view (ablabel)
77 -> Ablabel should be removed and Abtable should be increased with 75 -> Ablabel should be removed and Abtable should be increased with
78 different views (as started by darwin zins).. 76 different views (as started by darwin zins)..
79- Use advanced database functions in abtable to decrease 77- Use advanced database functions in abtable to decrease
80 memory footprint and to make everything more easy ! 78 memory footprint and to make everything more easy !
81 (abtable should store Iterator for selected Category) 79 (abtable should store Iterator for selected Category)
82- Abtable: Configure Contact column (internally already available, 80- Abtable: Configure Contact column (internally already available,
83 need configuration) 81 need configuration)
84- Select of primary contact (see #274 on mantis) 82- Select of primary contact (see #274 on mantis)
85- Category-select does not work completely: "Unfiled" is always in listview .. 83- Category-select does not work completely: "Unfiled" is always in listview ..
86- Return from Contacteditor: Category resettet to all 84- Return from Contacteditor: Category resettet to all
87- Personal Details not working 85- Personal Details not working
88- If category changed, the letterpicker should be resetted 86- If category changed, the letterpicker should be resetted
89- There should be some icons for List and Cardview 87- There should be some icons for List and Cardview
90- If in Cardview and a category change removes all entries: 88- If in Cardview and a category change removes all entries:
91 There are already entries in Cardview after up/down 89 There are already entries in Cardview after up/down
92- Personal Details: Anniversary zeigt Fantasie-Werte 90- Personal Details: Anniversary zeigt Fantasie-Werte
93- Unfiled shown just in Category "All" and "Unfiled". 91- Unfiled shown just in Category "All" and "Unfiled".
94- After finising search and after Edit: Clear Picker 92- After finising search and after Edit: Clear Picker
95- After Edit: Table position back to edited entry. 93- After Edit: Table position back to edited entry.
96- Optimize Table Update... 94- Optimize Table Update...
97- Change MyDialog to Config 95- Change MyDialog to Config
98- Store position and state of toolbar 96- Store position and state of toolbar
99- Searchwidget closed: Selected user is jumping 97- Searchwidget closed: Selected user is jumping
100- Wenn suchen beendet, dann dauert das Tabellenupdate (was überhaupt überflüssig ist) 98- Wenn suchen beendet, dann dauert das Tabellenupdate (was überhaupt überflüssig ist)
101 zu lange.. 99 zu lange..
102- VCARD: Import of Anniversary does not work correctly (currently disabled) 100- VCARD: Import of Anniversary does not work correctly (currently disabled)
103- Name order selected in "contacteditor" not used in list view. 101- Name order selected in "contacteditor" not used in list view.
104- OK-Key does not switch from Detailview (ablable) to Listview 102- OK-Key does not switch from Detailview (ablable) to Listview
105- Receiving of beams should open a dialog 103- Receiving of beams should open a dialog
106- Fix start of opie-mail 104- Fix start of opie-mail
107- Implement Button Pics 105- Implement Button Pics
108- Add a dialog to accept and optionally edit received contacts by IRDA. 106- Add a dialog to accept and optionally edit received contacts by IRDA.
109- Language not English (tested with german opie-translation): 107- Language not English (tested with german opie-translation):
110 1. Configure nicht übersetzt (alles leer). 108 1. Configure nicht übersetzt (alles leer).
111 2. Contacteditor nur teilweise übersetzt. 109 2. Contacteditor nur teilweise übersetzt.
112 3. Kategorie-Picker geht nicht. 110 3. Kategorie-Picker geht nicht.
111- Plugin for Today for Birthdays and Anniversaries
112- Implement a picker/combo for the default email.
113- Overview window cleanup needed..
114- Store last settings of combo-boxes
diff --git a/core/pim/addressbook/abtable.cpp b/core/pim/addressbook/abtable.cpp
index 00335ae..aec390d 100644
--- a/core/pim/addressbook/abtable.cpp
+++ b/core/pim/addressbook/abtable.cpp
@@ -81,577 +81,577 @@ void AbTableItem::setItem( const QString &txt, const QString &secondKey )
81 81
82 \brief QTableItem based class for showing slection of an entry 82 \brief QTableItem based class for showing slection of an entry
83*/ 83*/
84 84
85AbPickItem::AbPickItem( QTable *t ) : 85AbPickItem::AbPickItem( QTable *t ) :
86 QTableItem(t, WhenCurrent, "?") 86 QTableItem(t, WhenCurrent, "?")
87{ 87{
88} 88}
89 89
90QWidget *AbPickItem::createEditor() const 90QWidget *AbPickItem::createEditor() const
91{ 91{
92 QComboBox* combo = new QComboBox( table()->viewport() ); 92 QComboBox* combo = new QComboBox( table()->viewport() );
93 ( (AbPickItem*)this )->cb = combo; 93 ( (AbPickItem*)this )->cb = combo;
94 AbTable* t = static_cast<AbTable*>(table()); 94 AbTable* t = static_cast<AbTable*>(table());
95 QStringList c = t->choiceNames(); 95 QStringList c = t->choiceNames();
96 int cur = 0; 96 int cur = 0;
97 for (QStringList::ConstIterator it = c.begin(); it!=c.end(); ++it) { 97 for (QStringList::ConstIterator it = c.begin(); it!=c.end(); ++it) {
98 if ( *it == text() ) 98 if ( *it == text() )
99 cur = combo->count(); 99 cur = combo->count();
100 combo->insertItem(*it); 100 combo->insertItem(*it);
101 } 101 }
102 combo->setCurrentItem(cur); 102 combo->setCurrentItem(cur);
103 return combo; 103 return combo;
104} 104}
105 105
106void AbPickItem::setContentFromEditor( QWidget *w ) 106void AbPickItem::setContentFromEditor( QWidget *w )
107{ 107{
108 if ( w->inherits("QComboBox") ) 108 if ( w->inherits("QComboBox") )
109 setText( ( (QComboBox*)w )->currentText() ); 109 setText( ( (QComboBox*)w )->currentText() );
110 else 110 else
111 QTableItem::setContentFromEditor( w ); 111 QTableItem::setContentFromEditor( w );
112} 112}
113 113
114/*! 114/*!
115 \class AbTable abtable.h 115 \class AbTable abtable.h
116 116
117 \brief QTable based class for showing a list of entries 117 \brief QTable based class for showing a list of entries
118*/ 118*/
119 119
120AbTable::AbTable( const QValueList<int> order, QWidget *parent, const char *name ) 120AbTable::AbTable( const QValueList<int> order, QWidget *parent, const char *name )
121 : QTable( parent, name ), 121 : QTable( parent, name ),
122 lastSortCol( -1 ), 122 lastSortCol( -1 ),
123 asc( TRUE ), 123 asc( TRUE ),
124 intFields( order ), 124 intFields( order ),
125 enablePainting( true ), 125 enablePainting( true ),
126 columnVisible( true ), 126 columnVisible( true ),
127 countNested( 0 ) 127 countNested( 0 )
128{ 128{
129 qWarning("C'tor start"); 129 //qWarning("C'tor start");
130 130
131 setSelectionMode( NoSelection ); 131 setSelectionMode( NoSelection );
132 init(); 132 init();
133 setSorting( TRUE ); 133 setSorting( TRUE );
134 connect( this, SIGNAL(clicked(int,int,int,const QPoint &)), 134 connect( this, SIGNAL(clicked(int,int,int,const QPoint &)),
135 this, SLOT(itemClicked(int,int)) ); 135 this, SLOT(itemClicked(int,int)) );
136 136
137 contactList.clear(); 137 contactList.clear();
138 qWarning("C'tor end"); 138 //qWarning("C'tor end");
139} 139}
140 140
141AbTable::~AbTable() 141AbTable::~AbTable()
142{ 142{
143} 143}
144 144
145void AbTable::init() 145void AbTable::init()
146{ 146{
147 // :SX showChar = '\0'; 147 // :SX showChar = '\0';
148 setNumRows( 0 ); 148 setNumRows( 0 );
149 setNumCols( 2 ); 149 setNumCols( 2 );
150 150
151 horizontalHeader()->setLabel( 0, tr( "Full Name" )); 151 horizontalHeader()->setLabel( 0, tr( "Full Name" ));
152 horizontalHeader()->setLabel( 1, tr( "Contact" )); 152 horizontalHeader()->setLabel( 1, tr( "Contact" ));
153 setLeftMargin( 0 ); 153 setLeftMargin( 0 );
154 verticalHeader()->hide(); 154 verticalHeader()->hide();
155 columnVisible = true; 155 columnVisible = true;
156} 156}
157 157
158void AbTable::setContacts( const OContactAccess::List& viewList ) 158void AbTable::setContacts( const OContactAccess::List& viewList )
159{ 159{
160 qWarning("AbTable::setContacts()"); 160 //qWarning("AbTable::setContacts()");
161 161
162 clear(); 162 clear();
163 m_viewList = viewList; 163 m_viewList = viewList;
164 164
165 setSorting( false ); 165 setSorting( false );
166 setPaintingEnabled( FALSE ); 166 setPaintingEnabled( FALSE );
167 167
168 OContactAccess::List::Iterator it; 168 OContactAccess::List::Iterator it;
169 setNumRows( m_viewList.count() ); 169 setNumRows( m_viewList.count() );
170 int row = 0; 170 int row = 0;
171 for ( it = m_viewList.begin(); it != m_viewList.end(); ++it ) 171 for ( it = m_viewList.begin(); it != m_viewList.end(); ++it )
172 insertIntoTable( *it, row++ ); 172 insertIntoTable( *it, row++ );
173 173
174 setSorting( true ); 174 setSorting( true );
175 175
176 resort(); 176 resort();
177 177
178 updateVisible(); 178 updateVisible();
179 179
180 setPaintingEnabled( TRUE ); 180 setPaintingEnabled( TRUE );
181 181
182} 182}
183 183
184bool AbTable::selectContact( int UID ) 184bool AbTable::selectContact( int UID )
185{ 185{
186 qWarning( "AbTable::selectContact( %d )", UID ); 186 //qWarning( "AbTable::selectContact( %d )", UID );
187 int rows = numRows(); 187 int rows = numRows();
188 AbTableItem *abi; 188 AbTableItem *abi;
189 OContact* foundContact = 0l; 189 OContact* foundContact = 0l;
190 bool found = false; 190 bool found = false;
191 191
192 setPaintingEnabled( FALSE ); 192 setPaintingEnabled( FALSE );
193 for ( int r = 0; r < rows; ++r ) { 193 for ( int r = 0; r < rows; ++r ) {
194 abi = static_cast<AbTableItem*>( item(r, 0) ); 194 abi = static_cast<AbTableItem*>( item(r, 0) );
195 foundContact = &contactList[abi]; 195 foundContact = &contactList[abi];
196 if ( foundContact -> uid() == UID ){ 196 if ( foundContact -> uid() == UID ){
197 ensureCellVisible( r, 0 ); 197 ensureCellVisible( r, 0 );
198 setCurrentCell( r, 0 ); 198 setCurrentCell( r, 0 );
199 found = true; 199 found = true;
200 break; 200 break;
201 } 201 }
202 } 202 }
203 203
204 if ( !found ){ 204 if ( !found ){
205 ensureCellVisible( 0,0 ); 205 ensureCellVisible( 0,0 );
206 setCurrentCell( 0, 0 ); 206 setCurrentCell( 0, 0 );
207 } 207 }
208 208
209 setPaintingEnabled( TRUE ); 209 setPaintingEnabled( TRUE );
210 210
211 return true; 211 return true;
212} 212}
213 213
214void AbTable::insertIntoTable( const OContact& cnt, int row ) 214void AbTable::insertIntoTable( const OContact& cnt, int row )
215{ 215{
216 qWarning( "void AbTable::insertIntoTable( const OContact& cnt, %d )", row ); 216 //qWarning( "void AbTable::insertIntoTable( const OContact& cnt, %d )", row );
217 QString strName, 217 QString strName,
218 strContact; 218 strContact;
219 219
220 strName = findContactName( cnt ); 220 strName = findContactName( cnt );
221 strContact = findContactContact( cnt, row ); 221 strContact = findContactContact( cnt, row );
222 222
223 AbTableItem *ati; 223 AbTableItem *ati;
224 ati = new AbTableItem( this, QTableItem::Never, strName, strContact); 224 ati = new AbTableItem( this, QTableItem::Never, strName, strContact);
225 contactList.insert( ati, cnt ); 225 contactList.insert( ati, cnt );
226 setItem( row, 0, ati ); 226 setItem( row, 0, ati );
227 ati = new AbTableItem( this, QTableItem::Never, strContact, strName); 227 ati = new AbTableItem( this, QTableItem::Never, strContact, strName);
228 setItem( row, 1, ati ); 228 setItem( row, 1, ati );
229 229
230 //### cannot do this; table only has two columns at this point 230 //### cannot do this; table only has two columns at this point
231 // setItem( row, 2, new AbPickItem( this ) ); 231 // setItem( row, 2, new AbPickItem( this ) );
232 232
233} 233}
234 234
235 235
236 236
237void AbTable::columnClicked( int col ) 237void AbTable::columnClicked( int col )
238{ 238{
239 if ( !sorting() ) 239 if ( !sorting() )
240 return; 240 return;
241 241
242 if ( lastSortCol == -1 ) 242 if ( lastSortCol == -1 )
243 lastSortCol = col; 243 lastSortCol = col;
244 244
245 if ( col == lastSortCol ) { 245 if ( col == lastSortCol ) {
246 asc = !asc; 246 asc = !asc;
247 } else { 247 } else {
248 lastSortCol = col; 248 lastSortCol = col;
249 asc = TRUE; 249 asc = TRUE;
250 } 250 }
251 //QMessageBox::information( this, "resort", "columnClicked" ); 251 //QMessageBox::information( this, "resort", "columnClicked" );
252 resort(); 252 resort();
253} 253}
254 254
255void AbTable::resort() 255void AbTable::resort()
256{ 256{
257 qWarning( "void AbTable::resort()" ); 257 //qWarning( "void AbTable::resort()" );
258 setPaintingEnabled( FALSE ); 258 setPaintingEnabled( FALSE );
259 if ( sorting() ) { 259 if ( sorting() ) {
260 if ( lastSortCol == -1 ) 260 if ( lastSortCol == -1 )
261 lastSortCol = 0; 261 lastSortCol = 0;
262 sortColumn( lastSortCol, asc, TRUE ); 262 sortColumn( lastSortCol, asc, TRUE );
263 //QMessageBox::information( this, "resort", "resort" ); 263 //QMessageBox::information( this, "resort", "resort" );
264 updateVisible(); 264 updateVisible();
265 } 265 }
266 setPaintingEnabled( TRUE ); 266 setPaintingEnabled( TRUE );
267} 267}
268 268
269OContact AbTable::currentEntry() 269OContact AbTable::currentEntry()
270{ 270{
271 qWarning( "OContact AbTable::currentEntry()" ); 271 //qWarning( "OContact AbTable::currentEntry()" );
272 OContact cnt; 272 OContact cnt;
273 AbTableItem *abItem; 273 AbTableItem *abItem;
274 abItem = static_cast<AbTableItem*>(item( currentRow(), 0 )); 274 abItem = static_cast<AbTableItem*>(item( currentRow(), 0 ));
275 if ( abItem ) { 275 if ( abItem ) {
276 cnt = contactList[abItem]; 276 cnt = contactList[abItem];
277 //cnt = contactList[currentRow()]; 277 //cnt = contactList[currentRow()];
278 } 278 }
279 return cnt; 279 return cnt;
280} 280}
281 281
282int AbTable::currentEntry_UID() 282int AbTable::currentEntry_UID()
283{ 283{
284 return ( currentEntry().uid() ); 284 return ( currentEntry().uid() );
285} 285}
286 286
287void AbTable::clear() 287void AbTable::clear()
288{ 288{
289 qWarning( "void AbTable::clear()" ); 289 //qWarning( "void AbTable::clear()" );
290 contactList.clear(); 290 contactList.clear();
291 291
292 setPaintingEnabled( FALSE ); 292 setPaintingEnabled( FALSE );
293 for ( int r = 0; r < numRows(); ++r ) { 293 for ( int r = 0; r < numRows(); ++r ) {
294 for ( int c = 0; c < numCols(); ++c ) { 294 for ( int c = 0; c < numCols(); ++c ) {
295 if ( cellWidget( r, c ) ) 295 if ( cellWidget( r, c ) )
296 clearCellWidget( r, c ); 296 clearCellWidget( r, c );
297 clearCell( r, c ); 297 clearCell( r, c );
298 } 298 }
299 } 299 }
300 setNumRows( 0 ); 300 setNumRows( 0 );
301 setPaintingEnabled( TRUE ); 301 setPaintingEnabled( TRUE );
302} 302}
303 303
304// Refresh updates column 2 if the contactsettings changed 304// Refresh updates column 2 if the contactsettings changed
305void AbTable::refresh() 305void AbTable::refresh()
306{ 306{
307 qWarning( "void AbTable::refresh()" ); 307 //qWarning( "void AbTable::refresh()" );
308 int rows = numRows(); 308 int rows = numRows();
309 QString value; 309 QString value;
310 AbTableItem *abi; 310 AbTableItem *abi;
311 311
312 setPaintingEnabled( FALSE ); 312 setPaintingEnabled( FALSE );
313 for ( int r = 0; r < rows; ++r ) { 313 for ( int r = 0; r < rows; ++r ) {
314 abi = static_cast<AbTableItem*>( item(r, 0) ); 314 abi = static_cast<AbTableItem*>( item(r, 0) );
315 value = findContactContact( contactList[abi], r ); 315 value = findContactContact( contactList[abi], r );
316 static_cast<AbTableItem*>( item(r, 1) )->setItem( value, abi->text() ); 316 static_cast<AbTableItem*>( item(r, 1) )->setItem( value, abi->text() );
317 } 317 }
318 resort(); 318 resort();
319 setPaintingEnabled( TRUE ); 319 setPaintingEnabled( TRUE );
320} 320}
321 321
322void AbTable::keyPressEvent( QKeyEvent *e ) 322void AbTable::keyPressEvent( QKeyEvent *e )
323{ 323{
324 char key = toupper( e->ascii() ); 324 char key = toupper( e->ascii() );
325 325
326 if ( key >= 'A' && key <= 'Z' ) 326 if ( key >= 'A' && key <= 'Z' )
327 moveTo( key ); 327 moveTo( key );
328 328
329 qWarning("Received key .."); 329 //qWarning("Received key ..");
330 switch( e->key() ) { 330 switch( e->key() ) {
331 case Qt::Key_Space: 331 case Qt::Key_Space:
332 case Qt::Key_Return: 332 case Qt::Key_Return:
333 case Qt::Key_Enter: 333 case Qt::Key_Enter:
334 emit signalSwitch(); 334 emit signalSwitch();
335 break; 335 break;
336 // case Qt::Key_Up: 336 // case Qt::Key_Up:
337 // qWarning("a"); 337 // qWarning("a");
338 // emit signalKeyUp(); 338 // emit signalKeyUp();
339 // break; 339 // break;
340 // case Qt::Key_Down: 340 // case Qt::Key_Down:
341 // qWarning("b"); 341 // qWarning("b");
342 // emit signalKeyDown(); 342 // emit signalKeyDown();
343 // break; 343 // break;
344 default: 344 default:
345 QTable::keyPressEvent( e ); 345 QTable::keyPressEvent( e );
346 } 346 }
347 347
348} 348}
349 349
350void AbTable::moveTo( char c ) 350void AbTable::moveTo( char c )
351{ 351{
352 qWarning( "void AbTable::moveTo( char c )" ); 352 qWarning( "void AbTable::moveTo( char c )" );
353 353
354 int rows = numRows(); 354 int rows = numRows();
355 QString value; 355 QString value;
356 AbTableItem *abi; 356 AbTableItem *abi;
357 int r; 357 int r;
358 if ( asc ) { 358 if ( asc ) {
359 r = 0; 359 r = 0;
360 while ( r < rows-1) { 360 while ( r < rows-1) {
361 abi = static_cast<AbTableItem*>( item(r, 0) ); 361 abi = static_cast<AbTableItem*>( item(r, 0) );
362 QChar first = abi->key()[0]; 362 QChar first = abi->key()[0];
363 //### is there a bug in QChar to char comparison??? 363 //### is there a bug in QChar to char comparison???
364 if ( first.row() || first.cell() >= c ) 364 if ( first.row() || first.cell() >= c )
365 break; 365 break;
366 r++; 366 r++;
367 } 367 }
368 } else { 368 } else {
369 //### should probably disable reverse sorting instead 369 //### should probably disable reverse sorting instead
370 r = rows - 1; 370 r = rows - 1;
371 while ( r > 0 ) { 371 while ( r > 0 ) {
372 abi = static_cast<AbTableItem*>( item(r, 0) ); 372 abi = static_cast<AbTableItem*>( item(r, 0) );
373 QChar first = abi->key()[0]; 373 QChar first = abi->key()[0];
374 //### is there a bug in QChar to char comparison??? 374 //### is there a bug in QChar to char comparison???
375 if ( first.row() || first.cell() >= c ) 375 if ( first.row() || first.cell() >= c )
376 break; 376 break;
377 r--; 377 r--;
378 } 378 }
379 } 379 }
380 setCurrentCell( r, currentColumn() ); 380 setCurrentCell( r, currentColumn() );
381} 381}
382 382
383 383
384QString AbTable::findContactName( const OContact &entry ) 384QString AbTable::findContactName( const OContact &entry )
385{ 385{
386 // We use the fileAs, then company, defaultEmail 386 // We use the fileAs, then company, defaultEmail
387 QString str; 387 QString str;
388 str = entry.fileAs(); 388 str = entry.fileAs();
389 if ( str.isEmpty() ) { 389 if ( str.isEmpty() ) {
390 str = entry.company(); 390 str = entry.company();
391 if ( str.isEmpty() ) { 391 if ( str.isEmpty() ) {
392 str = entry.defaultEmail(); 392 str = entry.defaultEmail();
393 } 393 }
394 } 394 }
395 return str; 395 return str;
396} 396}
397 397
398 398
399 399
400void AbTable::resizeRows() { 400void AbTable::resizeRows() {
401 /* 401 /*
402 if (numRows()) { 402 if (numRows()) {
403 for (int i = 0; i < numRows(); i++) { 403 for (int i = 0; i < numRows(); i++) {
404 setRowHeight( i, size ); 404 setRowHeight( i, size );
405 } 405 }
406 } 406 }
407 updateVisible(); 407 updateVisible();
408 */ 408 */
409} 409}
410 410
411 411
412void AbTable::realignTable() 412void AbTable::realignTable()
413{ 413{
414 qWarning( "void AbTable::realignTable()" ); 414 //qWarning( "void AbTable::realignTable()" );
415 415
416 setPaintingEnabled( FALSE ); 416 setPaintingEnabled( FALSE );
417 417
418 resizeRows(); 418 resizeRows();
419 fitColumns(); 419 fitColumns();
420 420
421 setPaintingEnabled( TRUE ); 421 setPaintingEnabled( TRUE );
422 422
423} 423}
424 424
425 425
426 426
427 427
428#if QT_VERSION <= 230 428#if QT_VERSION <= 230
429#ifndef SINGLE_APP 429#ifndef SINGLE_APP
430void QTable::paintEmptyArea( QPainter *p, int cx, int cy, int cw, int ch ) 430void QTable::paintEmptyArea( QPainter *p, int cx, int cy, int cw, int ch )
431{ 431{
432 // Region of the rect we should draw 432 // Region of the rect we should draw
433 QRegion reg( QRect( cx, cy, cw, ch ) ); 433 QRegion reg( QRect( cx, cy, cw, ch ) );
434 // Subtract the table from it 434 // Subtract the table from it
435 reg = reg.subtract( QRect( QPoint( 0, 0 ), tableSize() ) ); 435 reg = reg.subtract( QRect( QPoint( 0, 0 ), tableSize() ) );
436 // And draw the rectangles (transformed as needed) 436 // And draw the rectangles (transformed as needed)
437 QArray<QRect> r = reg.rects(); 437 QArray<QRect> r = reg.rects();
438 for (unsigned int i=0; i<r.count(); i++) 438 for (unsigned int i=0; i<r.count(); i++)
439 p->fillRect( r[i], colorGroup().brush( QColorGroup::Base ) ); 439 p->fillRect( r[i], colorGroup().brush( QColorGroup::Base ) );
440} 440}
441#endif 441#endif
442#endif 442#endif
443 443
444 444
445// int AbTable::rowHeight( int ) const 445// int AbTable::rowHeight( int ) const
446// { 446// {
447// return 18; 447// return 18;
448// } 448// }
449 449
450// int AbTable::rowPos( int row ) const 450// int AbTable::rowPos( int row ) const
451// { 451// {
452// return 18*row; 452// return 18*row;
453// } 453// }
454 454
455// int AbTable::rowAt( int pos ) const 455// int AbTable::rowAt( int pos ) const
456// { 456// {
457// return QMIN( pos/18, numRows()-1 ); 457// return QMIN( pos/18, numRows()-1 );
458// } 458// }
459 459
460 460
461 461
462void AbTable::fitColumns() 462void AbTable::fitColumns()
463{ 463{
464 qWarning( "void AbTable::fitColumns()" ); 464 //qWarning( "void AbTable::fitColumns()" );
465 int contentsWidth = visibleWidth() / 2; // :SX Why too low 465 int contentsWidth = visibleWidth() / 2; // :SX Why too low
466 // Fix to better value 466 // Fix to better value
467 // contentsWidth = 130; 467 // contentsWidth = 130;
468 468
469 setPaintingEnabled( FALSE ); 469 setPaintingEnabled( FALSE );
470 470
471 if ( columnVisible == false ){ 471 if ( columnVisible == false ){
472 showColumn(0); 472 showColumn(0);
473 columnVisible = true; 473 columnVisible = true;
474 } 474 }
475 475
476 qWarning("Width: %d", contentsWidth); 476 //qWarning("Width: %d", contentsWidth);
477 477
478 setColumnWidth( 0, contentsWidth ); 478 setColumnWidth( 0, contentsWidth );
479 adjustColumn(1); 479 adjustColumn(1);
480 if ( columnWidth(1) < contentsWidth ) 480 if ( columnWidth(1) < contentsWidth )
481 setColumnWidth( 1, contentsWidth ); 481 setColumnWidth( 1, contentsWidth );
482 482
483 setPaintingEnabled( TRUE ); 483 setPaintingEnabled( TRUE );
484} 484}
485 485
486void AbTable::show() 486void AbTable::show()
487{ 487{
488 qWarning( "void AbTable::show()" ); 488 //qWarning( "void AbTable::show()" );
489 realignTable(); 489 realignTable();
490 QTable::show(); 490 QTable::show();
491} 491}
492 492
493void AbTable::setChoiceNames( const QStringList& list) 493void AbTable::setChoiceNames( const QStringList& list)
494{ 494{
495 choicenames = list; 495 choicenames = list;
496 if ( choicenames.isEmpty() ) { 496 if ( choicenames.isEmpty() ) {
497 // hide pick column 497 // hide pick column
498 setNumCols( 2 ); 498 setNumCols( 2 );
499 } else { 499 } else {
500 // show pick column 500 // show pick column
501 setNumCols( 3 ); 501 setNumCols( 3 );
502 setColumnWidth( 2, fontMetrics().width(tr( "Pick" ))+8 ); 502 setColumnWidth( 2, fontMetrics().width(tr( "Pick" ))+8 );
503 horizontalHeader()->setLabel( 2, tr( "Pick" )); 503 horizontalHeader()->setLabel( 2, tr( "Pick" ));
504 } 504 }
505 fitColumns(); 505 fitColumns();
506} 506}
507 507
508void AbTable::itemClicked(int,int col) 508void AbTable::itemClicked(int,int col)
509{ 509{
510 qWarning( "AbTable::itemClicked(int, col:%d)", col); 510 //qWarning( "AbTable::itemClicked(int, col:%d)", col);
511 if ( col == 2 ) { 511 if ( col == 2 ) {
512 return; 512 return;
513 } else { 513 } else {
514 qWarning ("Emitting signalSwitch()"); 514 // qWarning ("Emitting signalSwitch()");
515 emit signalSwitch(); 515 emit signalSwitch();
516 } 516 }
517} 517}
518 518
519QStringList AbTable::choiceNames() const 519QStringList AbTable::choiceNames() const
520{ 520{
521 return choicenames; 521 return choicenames;
522} 522}
523 523
524void AbTable::setChoiceSelection( const QValueList<int>& list ) 524void AbTable::setChoiceSelection( const QValueList<int>& list )
525{ 525{
526 intFields = list; 526 intFields = list;
527} 527}
528 528
529QStringList AbTable::choiceSelection(int /*index*/) const 529QStringList AbTable::choiceSelection(int /*index*/) const
530{ 530{
531 QStringList r; 531 QStringList r;
532 /* ###### 532 /* ######
533 533
534 QString selname = choicenames.at(index); 534 QString selname = choicenames.at(index);
535 for (each row) { 535 for (each row) {
536 OContact *c = contactForRow(row); 536 OContact *c = contactForRow(row);
537 if ( text(row,2) == selname ) { 537 if ( text(row,2) == selname ) {
538 r.append(c->email); 538 r.append(c->email);
539 } 539 }
540 } 540 }
541 541
542 */ 542 */
543 return r; 543 return r;
544} 544}
545 545
546 546
547 547
548 548
549void AbTable::updateVisible() 549void AbTable::updateVisible()
550{ 550{
551 qWarning("void AbTable::updateVisible()"); 551 //qWarning("void AbTable::updateVisible()");
552 552
553 int visible, 553 int visible,
554 totalRows, 554 totalRows,
555 row, 555 row,
556 selectedRow = 0; 556 selectedRow = 0;
557 557
558 visible = 0; 558 visible = 0;
559 559
560 setPaintingEnabled( FALSE ); 560 setPaintingEnabled( FALSE );
561 561
562 realignTable(); 562 realignTable();
563 563
564 totalRows = numRows(); 564 totalRows = numRows();
565 for ( row = 0; row < totalRows; row++ ) { 565 for ( row = 0; row < totalRows; row++ ) {
566 if ( rowHeight(row) == 0 ) { 566 if ( rowHeight(row) == 0 ) {
567 showRow( row ); 567 showRow( row );
568 adjustRow( row ); 568 adjustRow( row );
569 if ( isSelected( row,0 ) || isSelected( row,1 ) ) 569 if ( isSelected( row,0 ) || isSelected( row,1 ) )
570 selectedRow = row; 570 selectedRow = row;
571 } 571 }
572 visible++; 572 visible++;
573 } 573 }
574 574
575 if ( selectedRow ) 575 if ( selectedRow )
576 setCurrentCell( selectedRow, 0 ); 576 setCurrentCell( selectedRow, 0 );
577 577
578 if ( !visible ) 578 if ( !visible )
579 setCurrentCell( -1, 0 ); 579 setCurrentCell( -1, 0 );
580 580
581 setPaintingEnabled( TRUE ); 581 setPaintingEnabled( TRUE );
582 582
583 583
584} 584}
585 585
586 586
587void AbTable::setPaintingEnabled( bool e ) 587void AbTable::setPaintingEnabled( bool e )
588{ 588{
589 qWarning("IN void AbTable::setPaintingEnabled( %d )->Nested: %d", e, countNested ); 589 //qWarning("IN void AbTable::setPaintingEnabled( %d )->Nested: %d", e, countNested );
590 590
591 if ( e ) { 591 if ( e ) {
592 if ( countNested > 0 ) 592 if ( countNested > 0 )
593 --countNested; 593 --countNested;
594 if ( ! countNested ){ 594 if ( ! countNested ){
595 setUpdatesEnabled( true ); 595 setUpdatesEnabled( true );
596 enablePainting = true; 596 enablePainting = true;
597 rowHeightChanged( 0 ); 597 rowHeightChanged( 0 );
598 viewport()->update(); 598 viewport()->update();
599 } 599 }
600 } else { 600 } else {
601 ++countNested; 601 ++countNested;
602 enablePainting = false; 602 enablePainting = false;
603 setUpdatesEnabled( false ); 603 setUpdatesEnabled( false );
604 } 604 }
605 qWarning("OUT void AbTable::setPaintingEnabled( %d )->Nested: %d", e, countNested ); 605 //qWarning("OUT void AbTable::setPaintingEnabled( %d )->Nested: %d", e, countNested );
606} 606}
607 607
608void AbTable::viewportPaintEvent( QPaintEvent* e ) { 608void AbTable::viewportPaintEvent( QPaintEvent* e ) {
609 qWarning(" void AbTable::viewportPaintEvent( QPaintEvent* e ) -> %d", enablePainting); 609 //qWarning(" void AbTable::viewportPaintEvent( QPaintEvent* e ) -> %d", enablePainting);
610 if ( enablePainting ) 610 if ( enablePainting )
611 QTable::viewportPaintEvent( e ); 611 QTable::viewportPaintEvent( e );
612} 612}
613 613
614 614
615 615
616void AbTable::rowHeightChanged( int row ) 616void AbTable::rowHeightChanged( int row )
617{ 617{
618 if ( enablePainting ) 618 if ( enablePainting )
619 QTable::rowHeightChanged( row ); 619 QTable::rowHeightChanged( row );
620} 620}
621QString AbTable::findContactContact( const OContact &entry, int /* row */ ) 621QString AbTable::findContactContact( const OContact &entry, int /* row */ )
622{ 622{
623 QString value; 623 QString value;
624 value = ""; 624 value = "";
625 for ( QValueList<int>::ConstIterator it = intFields.begin(); 625 for ( QValueList<int>::ConstIterator it = intFields.begin();
626 it != intFields.end(); ++it ) { 626 it != intFields.end(); ++it ) {
627 switch ( *it ) { 627 switch ( *it ) {
628 default: 628 default:
629 break; 629 break;
630 case Qtopia::Title: 630 case Qtopia::Title:
631 value = entry.title(); 631 value = entry.title();
632 break; 632 break;
633 case Qtopia::Suffix: 633 case Qtopia::Suffix:
634 value = entry.suffix(); 634 value = entry.suffix();
635 break; 635 break;
636 case Qtopia::FileAs: 636 case Qtopia::FileAs:
637 value = entry.fileAs(); 637 value = entry.fileAs();
638 break; 638 break;
639 case Qtopia::DefaultEmail: 639 case Qtopia::DefaultEmail:
640 value = entry.defaultEmail(); 640 value = entry.defaultEmail();
641 case Qtopia::Emails: 641 case Qtopia::Emails:
642 value = entry.emails(); 642 value = entry.emails();
643 break; 643 break;
644 case Qtopia::HomeStreet: 644 case Qtopia::HomeStreet:
645 value = entry.homeStreet(); 645 value = entry.homeStreet();
646 break; 646 break;
647 case Qtopia::HomeCity: 647 case Qtopia::HomeCity:
648 value = entry.homeCity(); 648 value = entry.homeCity();
649 break; 649 break;
650 case Qtopia::HomeState: 650 case Qtopia::HomeState:
651 value = entry.homeState(); 651 value = entry.homeState();
652 break; 652 break;
653 case Qtopia::HomeZip: 653 case Qtopia::HomeZip:
654 value = entry.homeZip(); 654 value = entry.homeZip();
655 break; 655 break;
656 case Qtopia::HomeCountry: 656 case Qtopia::HomeCountry:
657 value = entry.homeCountry(); 657 value = entry.homeCountry();
diff --git a/core/pim/addressbook/abview.cpp b/core/pim/addressbook/abview.cpp
index 93e57ca..7da0992 100644
--- a/core/pim/addressbook/abview.cpp
+++ b/core/pim/addressbook/abview.cpp
@@ -50,424 +50,424 @@ AbView::AbView ( QWidget* parent, const QValueList<int>& ordered ):
50 m_orderedFields( ordered ) 50 m_orderedFields( ordered )
51{ 51{
52 // Load default database and handle syncing myself.. ! 52 // Load default database and handle syncing myself.. !
53 m_contactdb = new OContactAccess ( "addressbook", 0l, 0l, false ), 53 m_contactdb = new OContactAccess ( "addressbook", 0l, 0l, false ),
54 mCat.load( categoryFileName() ); 54 mCat.load( categoryFileName() );
55 55
56 // Create Layout and put WidgetStack into it. 56 // Create Layout and put WidgetStack into it.
57 QVBoxLayout *vb = new QVBoxLayout( this ); 57 QVBoxLayout *vb = new QVBoxLayout( this );
58 m_viewStack = new QWidgetStack( this ); 58 m_viewStack = new QWidgetStack( this );
59 vb->addWidget( m_viewStack ); 59 vb->addWidget( m_viewStack );
60 60
61 // Creat TableView 61 // Creat TableView
62 QVBox* tableBox = new QVBox( m_viewStack ); 62 QVBox* tableBox = new QVBox( m_viewStack );
63 m_abTable = new AbTable( m_orderedFields, tableBox, "table" ); 63 m_abTable = new AbTable( m_orderedFields, tableBox, "table" );
64 m_abTable->setCurrentCell( 0, 0 ); 64 m_abTable->setCurrentCell( 0, 0 );
65 m_abTable->setFocus(); 65 m_abTable->setFocus();
66 66
67 // Add TableView to WidgetStack and raise it 67 // Add TableView to WidgetStack and raise it
68 m_viewStack -> addWidget( tableBox , TableView ); 68 m_viewStack -> addWidget( tableBox , TableView );
69 69
70 // Create CardView and add it to WidgetStack 70 // Create CardView and add it to WidgetStack
71 QVBox* cardBox = new QVBox( m_viewStack ); 71 QVBox* cardBox = new QVBox( m_viewStack );
72 m_ablabel = new AbLabel( cardBox, "CardView"); 72 m_ablabel = new AbLabel( cardBox, "CardView");
73 m_viewStack -> addWidget( cardBox , CardView ); 73 m_viewStack -> addWidget( cardBox , CardView );
74 74
75 // Connect views to me 75 // Connect views to me
76 connect ( m_abTable, SIGNAL( signalSwitch( void ) ), 76 connect ( m_abTable, SIGNAL( signalSwitch( void ) ),
77 this, SLOT( slotSwitch( void ) ) ); 77 this, SLOT( slotSwitch( void ) ) );
78 connect ( m_ablabel, SIGNAL( signalOkPressed( void ) ), 78 connect ( m_ablabel, SIGNAL( signalOkPressed( void ) ),
79 this, SLOT( slotSwitch( void ) ) ); 79 this, SLOT( slotSwitch( void ) ) );
80 80
81 load(); 81 load();
82} 82}
83 83
84AbView::~AbView() 84AbView::~AbView()
85{ 85{
86 m_contactdb -> save(); 86 m_contactdb -> save();
87 delete m_contactdb; 87 delete m_contactdb;
88 88
89 if ( m_storedDB ){ 89 if ( m_storedDB ){
90 m_storedDB -> save(); 90 m_storedDB -> save();
91 delete m_storedDB; 91 delete m_storedDB;
92 } 92 }
93} 93}
94 94
95 95
96void AbView::setView( Views view ) 96void AbView::setView( Views view )
97{ 97{
98 qWarning("AbView::setView( Views view )"); 98 //qWarning("AbView::setView( Views view )");
99 m_curr_View = view; 99 m_curr_View = view;
100 load(); 100 load();
101} 101}
102 102
103void AbView::addEntry( const OContact &newContact ) 103void AbView::addEntry( const OContact &newContact )
104{ 104{
105 qWarning("abview:AddContact"); 105 //qWarning("abview:AddContact");
106 m_contactdb->add ( newContact ); 106 m_contactdb->add ( newContact );
107 load(); 107 load();
108 108
109} 109}
110void AbView::removeEntry( const int UID ) 110void AbView::removeEntry( const int UID )
111{ 111{
112 qWarning("abview:RemoveContact"); 112 //qWarning("abview:RemoveContact");
113 m_contactdb->remove( UID ); 113 m_contactdb->remove( UID );
114 load(); 114 load();
115} 115}
116 116
117void AbView::replaceEntry( const OContact &contact ) 117void AbView::replaceEntry( const OContact &contact )
118{ 118{
119 qWarning("abview:ReplaceContact"); 119 //qWarning("abview:ReplaceContact");
120 m_contactdb->replace( contact ); 120 m_contactdb->replace( contact );
121 load(); 121 load();
122 122
123} 123}
124 124
125OContact AbView::currentEntry() 125OContact AbView::currentEntry()
126{ 126{
127 OContact currentContact; 127 OContact currentContact;
128 128
129 switch ( (int) m_curr_View ) { 129 switch ( (int) m_curr_View ) {
130 case TableView: 130 case TableView:
131 currentContact = m_abTable -> currentEntry(); 131 currentContact = m_abTable -> currentEntry();
132 break; 132 break;
133 case CardView: 133 case CardView:
134 currentContact = m_ablabel -> currentEntry(); 134 currentContact = m_ablabel -> currentEntry();
135 break; 135 break;
136 } 136 }
137 m_curr_Contact = currentContact.uid(); 137 m_curr_Contact = currentContact.uid();
138 return currentContact; 138 return currentContact;
139} 139}
140 140
141bool AbView::save() 141bool AbView::save()
142{ 142{
143 qWarning("abView:Save data"); 143 //qWarning("abView:Save data");
144 144
145 return m_contactdb->save(); 145 return m_contactdb->save();
146} 146}
147 147
148void AbView::load() 148void AbView::load()
149{ 149{
150 qWarning("abView:Load data"); 150 //qWarning("abView:Load data");
151 151
152 // Letter Search is stopped at this place 152 // Letter Search is stopped at this place
153 emit signalClearLetterPicker(); 153 emit signalClearLetterPicker();
154 154
155 if ( m_inPersonal ) 155 if ( m_inPersonal )
156 // VCard Backend does not sort.. 156 // VCard Backend does not sort..
157 m_list = m_contactdb->allRecords(); 157 m_list = m_contactdb->allRecords();
158 else{ 158 else{
159 m_list = m_contactdb->sorted( true, 0, 0, 0 ); 159 m_list = m_contactdb->sorted( true, 0, 0, 0 );
160 clearForCategory(); 160 clearForCategory();
161 } 161 }
162 162
163 qWarning ("Number of contacts: %d", m_list.count()); 163 //qWarning ("Number of contacts: %d", m_list.count());
164 164
165 updateView( true ); 165 updateView( true );
166 166
167} 167}
168 168
169void AbView::reload() 169void AbView::reload()
170{ 170{
171 qWarning( "void AbView::reload()" ); 171 //qWarning( "void AbView::reload()" );
172 172
173 m_contactdb->reload(); 173 m_contactdb->reload();
174 load(); 174 load();
175} 175}
176 176
177void AbView::clear() 177void AbView::clear()
178{ 178{
179 // :SX 179 // :SX
180} 180}
181 181
182void AbView::setShowByCategory( const QString& cat ) 182void AbView::setShowByCategory( const QString& cat )
183{ 183{
184 qWarning("AbView::setShowCategory( const QString& cat )"); 184 //qWarning("AbView::setShowCategory( const QString& cat )");
185 185
186 int intCat = 0; 186 int intCat = 0;
187 187
188 // All (cat == NULL) will be stored as -1 188 // All (cat == NULL) will be stored as -1
189 if ( cat.isNull() ) 189 if ( cat.isNull() )
190 intCat = -1; 190 intCat = -1;
191 else 191 else
192 intCat = mCat.id("Contacts", cat ); 192 intCat = mCat.id("Contacts", cat );
193 193
194 // Just do anything if we really change the category 194 // Just do anything if we really change the category
195 if ( intCat != m_curr_category ){ 195 if ( intCat != m_curr_category ){
196 qWarning ("Categories: Selected %s.. Number: %d", cat.latin1(), m_curr_category); 196 // qWarning ("Categories: Selected %s.. Number: %d", cat.latin1(), m_curr_category);
197 197
198 m_curr_category = intCat; 198 m_curr_category = intCat;
199 emit signalClearLetterPicker(); 199 emit signalClearLetterPicker();
200 200
201 load(); 201 load();
202 } 202 }
203 203
204} 204}
205 205
206void AbView::setShowToView( Views view ) 206void AbView::setShowToView( Views view )
207{ 207{
208 qWarning("void AbView::setShowToView( View %d )", view); 208 //qWarning("void AbView::setShowToView( View %d )", view);
209 209
210 qWarning ("Change the View (Category is: %d)", m_curr_category); 210 //qWarning ("Change the View (Category is: %d)", m_curr_category);
211 211
212 if ( m_curr_View != view ){ 212 if ( m_curr_View != view ){
213 m_prev_View = m_curr_View; 213 m_prev_View = m_curr_View;
214 m_curr_View = view; 214 m_curr_View = view;
215 215
216 updateView(); 216 updateView();
217 } 217 }
218 218
219} 219}
220 220
221void AbView::setShowByLetter( char c ) 221void AbView::setShowByLetter( char c )
222{ 222{
223 qWarning("void AbView::setShowByLetter( %c )", c ); 223 //qWarning("void AbView::setShowByLetter( %c )", c );
224 OContact query; 224 OContact query;
225 if ( c == 0 ){ 225 if ( c == 0 ){
226 load(); 226 load();
227 return; 227 return;
228 }else{ 228 }else{
229 // If the current Backend is unable to solve the query, we will 229 // If the current Backend is unable to solve the query, we will
230 // ignore the request .. 230 // ignore the request ..
231 if ( ! m_contactdb->hasQuerySettings( OContactAccess::WildCards | OContactAccess::IgnoreCase ) ){ 231 if ( ! m_contactdb->hasQuerySettings( OContactAccess::WildCards | OContactAccess::IgnoreCase ) ){
232 return; 232 return;
233 } 233 }
234 234
235 query.setLastName( QString("%1*").arg(c) ); 235 query.setLastName( QString("%1*").arg(c) );
236 m_list = m_contactdb->queryByExample( query, OContactAccess::WildCards | OContactAccess::IgnoreCase ); 236 m_list = m_contactdb->queryByExample( query, OContactAccess::WildCards | OContactAccess::IgnoreCase );
237 clearForCategory(); 237 clearForCategory();
238 m_curr_Contact = 0; 238 m_curr_Contact = 0;
239 } 239 }
240 updateView( true ); 240 updateView( true );
241} 241}
242 242
243void AbView::setListOrder( const QValueList<int>& ordered ) 243void AbView::setListOrder( const QValueList<int>& ordered )
244{ 244{
245 m_orderedFields = ordered; 245 m_orderedFields = ordered;
246 updateView(); 246 updateView();
247} 247}
248 248
249 249
250QString AbView::showCategory() const 250QString AbView::showCategory() const
251{ 251{
252 return mCat.label( "Contacts", m_curr_category ); 252 return mCat.label( "Contacts", m_curr_category );
253} 253}
254 254
255void AbView::showPersonal( bool personal ) 255void AbView::showPersonal( bool personal )
256{ 256{
257 qWarning ("void AbView::showPersonal( %d )", personal); 257 //qWarning ("void AbView::showPersonal( %d )", personal);
258 258
259 if ( personal ){ 259 if ( personal ){
260 260
261 if ( m_inPersonal ) 261 if ( m_inPersonal )
262 return; 262 return;
263 263
264 // Now switch to vCard Backend and load data. 264 // Now switch to vCard Backend and load data.
265 // The current default backend will be stored 265 // The current default backend will be stored
266 // to avoid unneeded load/stores. 266 // to avoid unneeded load/stores.
267 m_storedDB = m_contactdb; 267 m_storedDB = m_contactdb;
268 268
269 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null, 269 OContactAccessBackend* vcard_backend = new OContactAccessBackend_VCard( QString::null,
270 addressbookPersonalVCardName() ); 270 addressbookPersonalVCardName() );
271 m_contactdb = new OContactAccess ( "addressbook", QString::null , vcard_backend, true ); 271 m_contactdb = new OContactAccess ( "addressbook", QString::null , vcard_backend, true );
272 272
273 m_inPersonal = true; 273 m_inPersonal = true;
274 m_curr_View = CardView; 274 m_curr_View = CardView;
275 275
276 }else{ 276 }else{
277 277
278 if ( !m_inPersonal ) 278 if ( !m_inPersonal )
279 return; 279 return;
280 280
281 // Remove vCard Backend and restore default 281 // Remove vCard Backend and restore default
282 m_contactdb->save(); 282 m_contactdb->save();
283 delete m_contactdb; 283 delete m_contactdb;
284 284
285 m_contactdb = m_storedDB; 285 m_contactdb = m_storedDB;
286 m_storedDB = 0l; 286 m_storedDB = 0l;
287 287
288 m_curr_View = TableView; 288 m_curr_View = TableView;
289 m_inPersonal = false; 289 m_inPersonal = false;
290 290
291 } 291 }
292 load(); 292 load();
293} 293}
294 294
295QStringList AbView::categories() 295QStringList AbView::categories()
296{ 296{
297 mCat.load( categoryFileName() ); 297 mCat.load( categoryFileName() );
298 QStringList categoryList = mCat.labels( "Contacts" ); 298 QStringList categoryList = mCat.labels( "Contacts" );
299 return categoryList; 299 return categoryList;
300} 300}
301 301
302// BEGIN: Slots 302// BEGIN: Slots
303void AbView::slotDoFind( const QString &str, bool caseSensitive, bool useRegExp, 303void AbView::slotDoFind( const QString &str, bool caseSensitive, bool useRegExp,
304 bool , QString cat ) 304 bool , QString cat )
305{ 305{
306 qWarning( "void AbView::slotDoFind" ); 306 //qWarning( "void AbView::slotDoFind" );
307 307
308 // We reloading the data: Deselect Letterpicker 308 // We reloading the data: Deselect Letterpicker
309 emit signalClearLetterPicker(); 309 emit signalClearLetterPicker();
310 310
311 // Use the current Category if nothing else selected 311 // Use the current Category if nothing else selected
312 int category = 0; 312 int category = 0;
313 313
314 if ( cat.isEmpty() ) 314 if ( cat.isEmpty() )
315 category = m_curr_category; 315 category = m_curr_category;
316 else{ 316 else{
317 category = mCat.id("Contacts", cat ); 317 category = mCat.id("Contacts", cat );
318 } 318 }
319 319
320 qWarning ("Find in Category %d", category); 320 //qWarning ("Find in Category %d", category);
321 321
322 QRegExp r( str ); 322 QRegExp r( str );
323 r.setCaseSensitive( caseSensitive ); 323 r.setCaseSensitive( caseSensitive );
324 r.setWildcard( !useRegExp ); 324 r.setWildcard( !useRegExp );
325 325
326 // Get all matching entries out of the database 326 // Get all matching entries out of the database
327 m_list = m_contactdb->matchRegexp( r ); 327 m_list = m_contactdb->matchRegexp( r );
328 328
329 qWarning( "found: %d", m_list.count() ); 329 //qWarning( "found: %d", m_list.count() );
330 if ( m_list.count() == 0 ){ 330 if ( m_list.count() == 0 ){
331 emit signalNotFound(); 331 emit signalNotFound();
332 return; 332 return;
333 } 333 }
334 334
335 // Now remove all contacts with wrong category (if any selected) 335 // Now remove all contacts with wrong category (if any selected)
336 // This algorithm is a litte bit ineffective, but 336 // This algorithm is a litte bit ineffective, but
337 // we will not have a lot of matching entries.. 337 // we will not have a lot of matching entries..
338 clearForCategory(); 338 clearForCategory();
339 339
340 // Now show all found entries 340 // Now show all found entries
341 updateView( true ); 341 updateView( true );
342} 342}
343 343
344void AbView::offSearch() 344void AbView::offSearch()
345{ 345{
346 m_inSearch = false; 346 m_inSearch = false;
347 347
348 load(); 348 load();
349} 349}
350 350
351void AbView::slotSwitch(){ 351void AbView::slotSwitch(){
352 qWarning("AbView::slotSwitch()"); 352 //qWarning("AbView::slotSwitch()");
353 353
354 m_prev_View = m_curr_View; 354 m_prev_View = m_curr_View;
355 switch ( (int) m_curr_View ){ 355 switch ( (int) m_curr_View ){
356 case TableView: 356 case TableView:
357 qWarning("Switching to CardView"); 357 qWarning("Switching to CardView");
358 m_curr_View = CardView; 358 m_curr_View = CardView;
359 break; 359 break;
360 case CardView: 360 case CardView:
361 qWarning("Switching to TableView"); 361 qWarning("Switching to TableView");
362 m_curr_View = TableView; 362 m_curr_View = TableView;
363 break; 363 break;
364 } 364 }
365 updateView(); 365 updateView();
366 366
367} 367}
368 368
369// END: Slots 369// END: Slots
370 370
371void AbView::clearForCategory() 371void AbView::clearForCategory()
372{ 372{
373 OContactAccess::List::Iterator it; 373 OContactAccess::List::Iterator it;
374 // Now remove all contacts with wrong category if any category selected 374 // Now remove all contacts with wrong category if any category selected
375 375
376 OContactAccess::List allList = m_list; 376 OContactAccess::List allList = m_list;
377 if ( m_curr_category != -1 ){ 377 if ( m_curr_category != -1 ){
378 for ( it = allList.begin(); it != allList.end(); ++it ){ 378 for ( it = allList.begin(); it != allList.end(); ++it ){
379 if ( !contactCompare( *it, m_curr_category ) ){ 379 if ( !contactCompare( *it, m_curr_category ) ){
380 qWarning("Removing %d", (*it).uid()); 380 // qWarning("Removing %d", (*it).uid());
381 m_list.remove( (*it).uid() ); 381 m_list.remove( (*it).uid() );
382 } 382 }
383 } 383 }
384 } 384 }
385 385
386} 386}
387 387
388bool AbView::contactCompare( const OContact &cnt, int category ) 388bool AbView::contactCompare( const OContact &cnt, int category )
389{ 389{
390 qWarning ("bool AbView::contactCompare( const OContact &cnt, %d )", category); 390 //qWarning ("bool AbView::contactCompare( const OContact &cnt, %d )", category);
391 391
392 bool returnMe; 392 bool returnMe;
393 QArray<int> cats; 393 QArray<int> cats;
394 cats = cnt.categories(); 394 cats = cnt.categories();
395 395
396 qWarning ("Number of categories: %d", cats.count() ); 396 //qWarning ("Number of categories: %d", cats.count() );
397 397
398 returnMe = false; 398 returnMe = false;
399 if ( cats.count() == 0 && category == 0 ) 399 if ( cats.count() == 0 && category == 0 )
400 // Contacts with no category will just shown on "All" and "Unfiled" 400 // Contacts with no category will just shown on "All" and "Unfiled"
401 returnMe = true; 401 returnMe = true;
402 else { 402 else {
403 int i; 403 int i;
404 for ( i = 0; i < int(cats.count()); i++ ) { 404 for ( i = 0; i < int(cats.count()); i++ ) {
405 qWarning("Comparing %d with %d",cats[i],category ); 405 // qWarning("Comparing %d with %d",cats[i],category );
406 if ( cats[i] == category ) { 406 if ( cats[i] == category ) {
407 returnMe = true; 407 returnMe = true;
408 break; 408 break;
409 } 409 }
410 } 410 }
411 } 411 }
412 qWarning ("Return: %d", returnMe); 412 //qWarning ("Return: %d", returnMe);
413 return returnMe; 413 return returnMe;
414} 414}
415 415
416// In Some rare cases we have to update all lists.. 416// In Some rare cases we have to update all lists..
417void AbView::updateListinViews() 417void AbView::updateListinViews()
418{ 418{
419 m_abTable -> setContacts( m_list ); 419 m_abTable -> setContacts( m_list );
420 m_ablabel -> setContacts( m_list ); 420 m_ablabel -> setContacts( m_list );
421} 421}
422 422
423void AbView::updateView( bool newdata ) 423void AbView::updateView( bool newdata )
424{ 424{
425 qWarning("AbView::updateView()"); 425 //qWarning("AbView::updateView()");
426 426
427 if ( m_viewStack -> visibleWidget() ){ 427 if ( m_viewStack -> visibleWidget() ){
428 m_viewStack -> visibleWidget() -> clearFocus(); 428 m_viewStack -> visibleWidget() -> clearFocus();
429 } 429 }
430 430
431 // If we switching the view, we have to store some information 431 // If we switching the view, we have to store some information
432 if ( !newdata ){ 432 if ( !newdata ){
433 if ( m_list.count() ){ 433 if ( m_list.count() ){
434 switch ( (int) m_prev_View ) { 434 switch ( (int) m_prev_View ) {
435 case TableView: 435 case TableView:
436 m_curr_Contact = m_abTable -> currentEntry_UID(); 436 m_curr_Contact = m_abTable -> currentEntry_UID();
437 break; 437 break;
438 case CardView: 438 case CardView:
439 m_curr_Contact = m_ablabel -> currentEntry_UID(); 439 m_curr_Contact = m_ablabel -> currentEntry_UID();
440 break; 440 break;
441 } 441 }
442 }else 442 }else
443 m_curr_Contact = 0; 443 m_curr_Contact = 0;
444 } 444 }
445 445
446 // Feed all views with new lists 446 // Feed all views with new lists
447 if ( newdata ) 447 if ( newdata )
448 updateListinViews(); 448 updateListinViews();
449 449
450 // Tell the world that the view is changed 450 // Tell the world that the view is changed
451 if ( m_curr_View != m_prev_View ) 451 if ( m_curr_View != m_prev_View )
452 emit signalViewSwitched ( (int) m_curr_View ); 452 emit signalViewSwitched ( (int) m_curr_View );
453 453
454 m_prev_View = m_curr_View; 454 m_prev_View = m_curr_View;
455 455
456 // Switch to new View 456 // Switch to new View
457 switch ( (int) m_curr_View ) { 457 switch ( (int) m_curr_View ) {
458 case TableView: 458 case TableView:
459 m_abTable -> setChoiceSelection( m_orderedFields ); 459 m_abTable -> setChoiceSelection( m_orderedFields );
460 if ( m_curr_Contact != 0 ) 460 if ( m_curr_Contact != 0 )
461 m_abTable -> selectContact ( m_curr_Contact ); 461 m_abTable -> selectContact ( m_curr_Contact );
462 m_abTable -> setFocus(); 462 m_abTable -> setFocus();
463 break; 463 break;
464 case CardView: 464 case CardView:
465 if ( m_curr_Contact != 0 ) 465 if ( m_curr_Contact != 0 )
466 m_ablabel -> selectContact( m_curr_Contact ); 466 m_ablabel -> selectContact( m_curr_Contact );
467 m_ablabel -> setFocus(); 467 m_ablabel -> setFocus();
468 break; 468 break;
469 } 469 }
470 470
471 // Raise the current View 471 // Raise the current View
472 m_viewStack -> raiseWidget( m_curr_View ); 472 m_viewStack -> raiseWidget( m_curr_View );
473} 473}
diff --git a/core/pim/addressbook/contacteditor.cpp b/core/pim/addressbook/contacteditor.cpp
index d14ac51..d830ad3 100644
--- a/core/pim/addressbook/contacteditor.cpp
+++ b/core/pim/addressbook/contacteditor.cpp
@@ -22,110 +22,117 @@
22#include "contacteditor.h" 22#include "contacteditor.h"
23#include "addresspicker.h" 23#include "addresspicker.h"
24#include "ocontactfields.h" 24#include "ocontactfields.h"
25 25
26#include <qpe/categoryselect.h> 26#include <qpe/categoryselect.h>
27#include <qpe/qpeapplication.h> 27#include <qpe/qpeapplication.h>
28#include <qpe/qpedialog.h> 28#include <qpe/qpedialog.h>
29#include <qpe/timeconversion.h> 29#include <qpe/timeconversion.h>
30#include <opie/ocontact.h> 30#include <opie/ocontact.h>
31#include <qpe/resource.h> 31#include <qpe/resource.h>
32 32
33#include <qcombobox.h> 33#include <qcombobox.h>
34#include <qlabel.h> 34#include <qlabel.h>
35#include <qtabwidget.h> 35#include <qtabwidget.h>
36#include <qlayout.h> 36#include <qlayout.h>
37#include <qlineedit.h> 37#include <qlineedit.h>
38#include <qmultilineedit.h> 38#include <qmultilineedit.h>
39#include <qscrollview.h> 39#include <qscrollview.h>
40#include <qtoolbutton.h> 40#include <qtoolbutton.h>
41#include <qpushbutton.h> 41#include <qpushbutton.h>
42#include <qmainwindow.h> 42#include <qmainwindow.h>
43#include <qvaluelist.h> 43#include <qvaluelist.h>
44#include <qpopupmenu.h> 44#include <qpopupmenu.h>
45#include <qlistbox.h> 45#include <qlistbox.h>
46#include <qhbox.h> 46#include <qhbox.h>
47#include <qaction.h> 47#include <qaction.h>
48#include <qiconset.h> 48#include <qiconset.h>
49#include <qmessagebox.h> 49#include <qmessagebox.h>
50 50
51#include <assert.h> 51#include <assert.h>
52 52
53static inline bool containsAlphaNum( const QString &str ); 53static inline bool containsAlphaNum( const QString &str );
54static inline bool constainsWhiteSpace( const QString &str ); 54static inline bool constainsWhiteSpace( const QString &str );
55 55
56// helper functions, convert our comma delimited list to proper 56// helper functions, convert our comma delimited list to proper
57// file format... 57// file format...
58void parseEmailFrom( const QString &txt, QString &strDefaultEmail, 58void parseEmailFrom( const QString &txt, QString &strDefaultEmail,
59 QString &strAll ); 59 QString &strAll );
60 60
61// helper convert from file format to comma delimited... 61// helper convert from file format to comma delimited...
62void parseEmailTo( const QString &strDefaultEmail, 62void parseEmailTo( const QString &strDefaultEmail,
63 const QString &strOtherEmail, QString &strBack ); 63 const QString &strOtherEmail, QString &strBack );
64 64
65 ContactEditor::ContactEditor(const OContact &entry, 65 ContactEditor::ContactEditor(const OContact &entry,
66 QWidget *parent, 66 QWidget *parent,
67 const char *name, 67 const char *name,
68 WFlags fl ) 68 WFlags fl )
69 : QDialog( parent, name, TRUE, fl ), 69 : QDialog( parent, name, TRUE, fl ),
70 m_personalView ( false ) 70 defaultEmailChooserPosition( -1 ),
71 71 m_personalView ( false ),
72 cmbDefaultEmail( 0 ),
73 initializing ( false )
72{ 74{
73 75
76 initializing = true;
77
74 init(); 78 init();
75 setEntry( entry ); 79 setEntry( entry );
76 cmbDefaultEmail = 0; 80 // cmbDefaultEmail = 0;
77 defaultEmailChooserPosition = -1; 81 // defaultEmailChooserPosition = -1;
82
83 initializing = false;
78} 84}
79 85
80ContactEditor::~ContactEditor() { 86ContactEditor::~ContactEditor() {
81} 87}
82 88
83void ContactEditor::init() { 89void ContactEditor::init() {
90 qWarning("init() START");
84 91
85 useFullName = true; 92 useFullName = true;
86 93
87 uint i = 0; 94 uint i = 0;
88 95
89 QStringList trlChooserNames; 96 QStringList trlChooserNames;
90 97
91 for (i = 0; i <= 6; i++) { 98 for (i = 0; i <= 6; i++) {
92 slHomeAddress.append( "" ); 99 slHomeAddress.append( "" );
93 slBusinessAddress.append( "" ); 100 slBusinessAddress.append( "" );
94 } 101 }
95 102
96 trlChooserNames = OContactFields::trphonefields( false ); 103 trlChooserNames = OContactFields::trphonefields( false );
97 slChooserNames = OContactFields::untrphonefields( false ); 104 slChooserNames = OContactFields::untrphonefields( false );
98 slDynamicEntries = OContactFields::untrdetailsfields( false ); 105 slDynamicEntries = OContactFields::untrdetailsfields( false );
99 trlDynamicEntries = OContactFields::trdetailsfields( false ); 106 trlDynamicEntries = OContactFields::trdetailsfields( false );
100 107
101 // Ok, we have to remove elements from the list of dynamic entries 108 // Ok, we have to remove elements from the list of dynamic entries
102 // which are now stored in special (not dynamic) widgets.. 109 // which are now stored in special (not dynamic) widgets..
103 // Otherwise we will get problems with field assignments! (se) 110 // Otherwise we will get problems with field assignments! (se)
104 slDynamicEntries.remove("Anniversary"); 111 slDynamicEntries.remove("Anniversary");
105 slDynamicEntries.remove("Birthday"); 112 slDynamicEntries.remove("Birthday");
106 slDynamicEntries.remove("Gender"); 113 slDynamicEntries.remove("Gender");
107 114
108 // The same with translated fields.. But I will 115 // The same with translated fields.. But I will
109 // use the translation map to avoid mismatches.. 116 // use the translation map to avoid mismatches..
110 QMap<int, QString> translMap = OContactFields::idToTrFields(); 117 QMap<int, QString> translMap = OContactFields::idToTrFields();
111 trlDynamicEntries.remove( translMap[Qtopia::Anniversary] ); 118 trlDynamicEntries.remove( translMap[Qtopia::Anniversary] );
112 trlDynamicEntries.remove( translMap[Qtopia::Birthday] ); 119 trlDynamicEntries.remove( translMap[Qtopia::Birthday] );
113 trlDynamicEntries.remove( translMap[Qtopia::Gender] ); 120 trlDynamicEntries.remove( translMap[Qtopia::Gender] );
114 121
115 // Last Check to be sure.. 122 // Last Check to be sure..
116 assert( slDynamicEntries.count() == trlDynamicEntries.count() ); 123 assert( slDynamicEntries.count() == trlDynamicEntries.count() );
117 assert( slChooserNames.count() == trlChooserNames.count() ); 124 assert( slChooserNames.count() == trlChooserNames.count() );
118 125
119 for (i = 0; i < slChooserNames.count(); i++) 126 for (i = 0; i < slChooserNames.count(); i++)
120 slChooserValues.append(""); 127 slChooserValues.append("");
121 128
122 129
123 QVBoxLayout *vb = new QVBoxLayout( this ); 130 QVBoxLayout *vb = new QVBoxLayout( this );
124 131
125 tabMain = new QTabWidget( this ); 132 tabMain = new QTabWidget( this );
126 vb->addWidget( tabMain ); 133 vb->addWidget( tabMain );
127 134
128 QWidget *tabViewport = new QWidget ( tabMain ); 135 QWidget *tabViewport = new QWidget ( tabMain );
129 136
130 vb = new QVBoxLayout( tabViewport ); 137 vb = new QVBoxLayout( tabViewport );
131 138
@@ -555,207 +562,218 @@ void ContactEditor::init() {
555 gl->addWidget( e, i, 1); 562 gl->addWidget( e, i, 1);
556 } 563 }
557 // Fill labels with names.. 564 // Fill labels with names..
558 //loadFields(); 565 //loadFields();
559 566
560 567
561 tabMain->insertTab( tabViewport, tr( "Details" ) ); 568 tabMain->insertTab( tabViewport, tr( "Details" ) );
562 569
563 dlgNote = new QDialog( this, "Note Dialog", TRUE ); 570 dlgNote = new QDialog( this, "Note Dialog", TRUE );
564 dlgNote->setCaption( tr("Enter Note") ); 571 dlgNote->setCaption( tr("Enter Note") );
565 QVBoxLayout *vbNote = new QVBoxLayout( dlgNote ); 572 QVBoxLayout *vbNote = new QVBoxLayout( dlgNote );
566 txtNote = new QMultiLineEdit( dlgNote ); 573 txtNote = new QMultiLineEdit( dlgNote );
567 vbNote->addWidget( txtNote ); 574 vbNote->addWidget( txtNote );
568 connect( btnNote, SIGNAL(clicked()), this, SLOT(slotNote()) ); 575 connect( btnNote, SIGNAL(clicked()), this, SLOT(slotNote()) );
569 576
570 dlgName = new QDialog( this, "Name Dialog", TRUE ); 577 dlgName = new QDialog( this, "Name Dialog", TRUE );
571 dlgName->setCaption( tr("Edit Name") ); 578 dlgName->setCaption( tr("Edit Name") );
572 gl = new QGridLayout( dlgName, 5, 2, 2, 3 ); 579 gl = new QGridLayout( dlgName, 5, 2, 2, 3 );
573 580
574 l = new QLabel( tr("First Name"), dlgName ); 581 l = new QLabel( tr("First Name"), dlgName );
575 gl->addWidget( l, 0, 0 ); 582 gl->addWidget( l, 0, 0 );
576 txtFirstName = new QLineEdit( dlgName ); 583 txtFirstName = new QLineEdit( dlgName );
577 gl->addWidget( txtFirstName, 0, 1 ); 584 gl->addWidget( txtFirstName, 0, 1 );
578 585
579 l = new QLabel( tr("Middle Name"), dlgName ); 586 l = new QLabel( tr("Middle Name"), dlgName );
580 gl->addWidget( l, 1, 0 ); 587 gl->addWidget( l, 1, 0 );
581 txtMiddleName = new QLineEdit( dlgName ); 588 txtMiddleName = new QLineEdit( dlgName );
582 gl->addWidget( txtMiddleName, 1, 1 ); 589 gl->addWidget( txtMiddleName, 1, 1 );
583 590
584 l = new QLabel( tr("Last Name"), dlgName ); 591 l = new QLabel( tr("Last Name"), dlgName );
585 gl->addWidget( l, 2, 0 ); 592 gl->addWidget( l, 2, 0 );
586 txtLastName = new QLineEdit( dlgName ); 593 txtLastName = new QLineEdit( dlgName );
587 gl->addWidget( txtLastName, 2, 1 ); 594 gl->addWidget( txtLastName, 2, 1 );
588 595
589 l = new QLabel( tr("Suffix"), dlgName ); 596 l = new QLabel( tr("Suffix"), dlgName );
590 gl->addWidget( l, 3, 0 ); 597 gl->addWidget( l, 3, 0 );
591 txtSuffix = new QLineEdit( dlgName ); 598 txtSuffix = new QLineEdit( dlgName );
592 gl->addWidget( txtSuffix, 3, 1 ); 599 gl->addWidget( txtSuffix, 3, 1 );
593 space = new QSpacerItem(1,1, 600 space = new QSpacerItem(1,1,
594 QSizePolicy::Maximum, 601 QSizePolicy::Maximum,
595 QSizePolicy::MinimumExpanding ); 602 QSizePolicy::MinimumExpanding );
596 gl->addItem( space, 4, 0 ); 603 gl->addItem( space, 4, 0 );
597 604
598 cmbChooserField1->insertStringList( trlChooserNames ); 605 cmbChooserField1->insertStringList( trlChooserNames );
599 cmbChooserField2->insertStringList( trlChooserNames ); 606 cmbChooserField2->insertStringList( trlChooserNames );
600 cmbChooserField3->insertStringList( trlChooserNames ); 607 cmbChooserField3->insertStringList( trlChooserNames );
601 cmbChooserField4->insertStringList( trlChooserNames ); 608 cmbChooserField4->insertStringList( trlChooserNames );
602 609
603 cmbChooserField1->setCurrentItem( 0 ); 610 cmbChooserField1->setCurrentItem( 0 );
604 cmbChooserField2->setCurrentItem( 1 ); 611 cmbChooserField2->setCurrentItem( 1 );
605 cmbChooserField3->setCurrentItem( 2 ); 612 cmbChooserField3->setCurrentItem( 2 );
606 613
607 connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) ); 614 connect( btnFullName, SIGNAL(clicked()), this, SLOT(slotName()) );
608 615
609 connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) ); 616 connect( txtFullName, SIGNAL(textChanged(const QString &)), this, SLOT(slotFullNameChange(const QString &)) );
610 617
611 connect( txtChooserField1, SIGNAL(textChanged(const QString &)), 618 connect( txtChooserField1, SIGNAL(textChanged(const QString &)),
612 this, SLOT(slotChooser1Change(const QString &)) ); 619 this, SLOT(slotChooser1Change(const QString &)) );
613 connect( txtChooserField2, SIGNAL(textChanged(const QString &)), 620 connect( txtChooserField2, SIGNAL(textChanged(const QString &)),
614 this, SLOT(slotChooser2Change(const QString &)) ); 621 this, SLOT(slotChooser2Change(const QString &)) );
615 connect( txtChooserField3, SIGNAL(textChanged(const QString &)), 622 connect( txtChooserField3, SIGNAL(textChanged(const QString &)),
616 this, SLOT(slotChooser3Change(const QString &)) ); 623 this, SLOT(slotChooser3Change(const QString &)) );
617 connect( txtChooserField4, SIGNAL(textChanged(const QString &)), 624 connect( txtChooserField4, SIGNAL(textChanged(const QString &)),
618 this, SLOT(slotChooser4Change(const QString &)) ); 625 this, SLOT(slotChooser4Change(const QString &)) );
619 connect( txtAddress, SIGNAL(textChanged(const QString &)), 626 connect( txtAddress, SIGNAL(textChanged(const QString &)),
620 this, SLOT(slotAddressChange(const QString &)) ); 627 this, SLOT(slotAddressChange(const QString &)) );
621 connect( txtCity, SIGNAL(textChanged(const QString &)), 628 connect( txtCity, SIGNAL(textChanged(const QString &)),
622 this, SLOT(slotCityChange(const QString &)) ); 629 this, SLOT(slotCityChange(const QString &)) );
623 connect( txtState, SIGNAL(textChanged(const QString &)), 630 connect( txtState, SIGNAL(textChanged(const QString &)),
624 this, SLOT(slotStateChange(const QString &)) ); 631 this, SLOT(slotStateChange(const QString &)) );
625 connect( txtZip, SIGNAL(textChanged(const QString &)), 632 connect( txtZip, SIGNAL(textChanged(const QString &)),
626 this, SLOT(slotZipChange(const QString &)) ); 633 this, SLOT(slotZipChange(const QString &)) );
627 connect( cmbCountry, SIGNAL(textChanged(const QString &)), 634 connect( cmbCountry, SIGNAL(textChanged(const QString &)),
628 this, SLOT(slotCountryChange(const QString &)) ); 635 this, SLOT(slotCountryChange(const QString &)) );
629 connect( cmbCountry, SIGNAL(activated(const QString &)), 636 connect( cmbCountry, SIGNAL(activated(const QString &)),
630 this, SLOT(slotCountryChange(const QString &)) ); 637 this, SLOT(slotCountryChange(const QString &)) );
631 connect( cmbChooserField1, SIGNAL(activated(int)), 638 connect( cmbChooserField1, SIGNAL(activated(int)),
632 this, SLOT(slotCmbChooser1Change(int)) ); 639 this, SLOT(slotCmbChooser1Change(int)) );
633 connect( cmbChooserField2, SIGNAL(activated(int)), 640 connect( cmbChooserField2, SIGNAL(activated(int)),
634 this, SLOT(slotCmbChooser2Change(int)) ); 641 this, SLOT(slotCmbChooser2Change(int)) );
635 connect( cmbChooserField3, SIGNAL(activated(int)), 642 connect( cmbChooserField3, SIGNAL(activated(int)),
636 this, SLOT(slotCmbChooser3Change(int)) ); 643 this, SLOT(slotCmbChooser3Change(int)) );
637 connect( cmbChooserField4, SIGNAL(activated(int)), 644 connect( cmbChooserField4, SIGNAL(activated(int)),
638 this, SLOT(slotCmbChooser4Change(int)) ); 645 this, SLOT(slotCmbChooser4Change(int)) );
639 connect( cmbAddress, SIGNAL(activated(int)), 646 connect( cmbAddress, SIGNAL(activated(int)),
640 this, SLOT(slotAddressTypeChange(int)) ); 647 this, SLOT(slotAddressTypeChange(int)) );
641 648
642 new QPEDialogListener(this); 649 new QPEDialogListener(this);
643 650
644 setPersonalView ( m_personalView ); 651 setPersonalView ( m_personalView );
652
653 qWarning("init() END");
645} 654}
646 655
647void ContactEditor::defaultEmailChanged(int i){ 656void ContactEditor::defaultEmailChanged(int i){
648 qDebug("defaultEmailChanged"); 657 qDebug("defaultEmailChanged");
649 658
650 // was sollte das ? (se) 659 // was sollte das ? (se)
651 // int index = cmbChooserField1->currentItem(); 660 // int index = cmbChooserField1->currentItem();
652 // slChooserValues[index] = cmbDefaultEmail->text(i); 661 // slChooserValues[index] = cmbDefaultEmail->text(i);
653 662
654 defaultEmail = cmbDefaultEmail->text(i); 663 defaultEmail = cmbDefaultEmail->text(i);
655 qDebug ("Changed to: %s", defaultEmail.latin1()); 664 qDebug ("Changed to: %s", defaultEmail.latin1());
656 665
657} 666}
658 667
659void ContactEditor::populateDefaultEmailCmb(){ 668void ContactEditor::populateDefaultEmailCmb(){
660 669
661 // if the default-email combo was not selected and therfore not created 670 // if the default-email combo was not selected and therfore not created
662 // we get a lot of trouble.. Therfore create an invisible one.. 671 // we get a lot of trouble.. Therfore create an invisible one..
663 if ( !cmbDefaultEmail ){ 672 if ( !cmbDefaultEmail ){
664 cmbDefaultEmail = new QComboBox(this); 673 cmbDefaultEmail = new QComboBox(this);
665 cmbDefaultEmail -> hide(); 674 cmbDefaultEmail -> hide();
666 } 675 }
667 cmbDefaultEmail->clear(); 676 cmbDefaultEmail->clear();
668 cmbDefaultEmail->insertStringList( emails ); 677 cmbDefaultEmail->insertStringList( emails );
669 // cmbDefaultEmail->show(); 678 // cmbDefaultEmail->show();
670 679
671 // Select default email in combo.. 680 // Select default email in combo..
672 bool found = false; 681 bool found = false;
673 for ( int i = 0; i < cmbDefaultEmail->count(); i++){ 682 for ( int i = 0; i < cmbDefaultEmail->count(); i++){
674 qDebug(" populateDefaultEmailCmb text >%s< defaultEmail >%s<", 683 qDebug(" populateDefaultEmailCmb text >%s< defaultEmail >%s<",
675 cmbDefaultEmail->text( i ).latin1(), defaultEmail.latin1()); 684 cmbDefaultEmail->text( i ).latin1(), defaultEmail.latin1());
676 685
677 if ( cmbDefaultEmail->text( i ).stripWhiteSpace() == defaultEmail.stripWhiteSpace() ){ 686 if ( cmbDefaultEmail->text( i ).stripWhiteSpace() == defaultEmail.stripWhiteSpace() ){
678 cmbDefaultEmail->setCurrentItem( i ); 687 cmbDefaultEmail->setCurrentItem( i );
679 qDebug("set"); 688 qDebug("set");
680 found = true; 689 found = true;
681 } 690 }
682 } 691 }
683 692
684 // If the current default email is not found in the list, we choose the 693 // If the current default email is not found in the list, we choose the
685 // first one.. 694 // first one..
686 if ( !found ) 695 if ( !found )
687 defaultEmail = cmbDefaultEmail->text(0); 696 defaultEmail = cmbDefaultEmail->text(0);
688} 697}
689 698
690// Called when any combobox was changed. 699// Called when any combobox was changed.
691// "true" returned if the change was chandled by this function, else it should 700// "true" returned if the change was chandled by this function, else it should
692// be handled by something else.. 701// be handled by something else..
693bool ContactEditor::cmbChooserChange( int index, QLineEdit *inputWid, int widgetPos ) { 702bool ContactEditor::cmbChooserChange( int index, QLineEdit *inputWid, int widgetPos ) {
694 QString type = slChooserNames[index]; 703 QString type = slChooserNames[index];
695 qWarning("ContactEditor::cmbChooserChange -> Type: %s", type.latin1() ); 704 qWarning("ContactEditor::cmbChooserChange -> Type: %s, WidgetPos: %d", type.latin1(), widgetPos );
705
706 if ( !initializing )
707 contactfields.setFieldOrder( widgetPos-1, index );
696 708
697 // Create and connect combobox for selecting the default email 709 // Create and connect combobox for selecting the default email
698 if ( type == "Default Email"){ 710 if ( type == "Default Email"){
699 qWarning("Choosing default-email "); 711 qWarning("Choosing default-email (defaultEmailChooserPosition= %d) ", defaultEmailChooserPosition);
700 712
701 // More than one defaul-email chooser is not allowed ! 713 // More than one defaul-email chooser is not allowed !
702 if ( ( defaultEmailChooserPosition != -1 ) && 714 if ( ( defaultEmailChooserPosition != -1 ) &&
703 defaultEmailChooserPosition != widgetPos ){ 715 defaultEmailChooserPosition != widgetPos && !initializing){
704 chooserError( widgetPos ); 716 chooserError( widgetPos );
705 return true; 717 return true;
706 } 718 }
707 719
708 if ( cmbDefaultEmail ){ 720 if ( cmbDefaultEmail ){
709 delete cmbDefaultEmail; 721 delete cmbDefaultEmail;
710 cmbDefaultEmail = 0l; 722 cmbDefaultEmail = 0l;
711 } 723 }
712 cmbDefaultEmail = new QComboBox(inputWid->parentWidget()); 724 cmbDefaultEmail = new QComboBox(inputWid->parentWidget());
713 cmbDefaultEmail->setGeometry(inputWid->frameGeometry()); 725 cmbDefaultEmail->setGeometry(inputWid->frameGeometry()); /* :SX */
726
727 QRect rect = inputWid->frameGeometry();
728 qWarning("Geometrie: X=%d, Y=%d, Left=%d, Top=%d, Right=%d, Bottom=%d",
729 rect.x(), rect.y(), rect.left(), rect.top(), rect.right(), rect.bottom());
730 QPoint pnt = inputWid->pos();
731 qWarning("Position : X=%d, Y=%d", pnt.x(), pnt.y() );
714 732
715 connect( cmbDefaultEmail,SIGNAL( activated(int) ), 733 connect( cmbDefaultEmail,SIGNAL( activated(int) ),
716 SLOT( defaultEmailChanged(int) ) ); 734 SLOT( defaultEmailChanged(int) ) );
717 735
718 cmbDefaultEmail->clear(); 736 cmbDefaultEmail->clear();
719 cmbDefaultEmail->insertStringList( emails ); 737 cmbDefaultEmail->insertStringList( emails );
720 cmbDefaultEmail->show(); 738 cmbDefaultEmail->show();
721 739
722 defaultEmailChooserPosition = widgetPos; 740 defaultEmailChooserPosition = widgetPos;
723 741
724 // Set current default email 742 // Set current default email
725 populateDefaultEmailCmb(); 743 populateDefaultEmailCmb();
726 744
727 745
728 } else { 746 } else {
729 // Something else was selected: Hide combo.. 747 // Something else was selected: Hide combo..
730 qWarning(" Hiding default-email combo" ); 748 qWarning(" Hiding default-email combo" );
731 if ( defaultEmailChooserPosition == widgetPos ){ 749 if ( defaultEmailChooserPosition == widgetPos ){
732 defaultEmailChooserPosition = -1; 750 defaultEmailChooserPosition = -1;
733 if ( cmbDefaultEmail ) 751 if ( cmbDefaultEmail )
734 cmbDefaultEmail->hide(); 752 cmbDefaultEmail->hide();
735 753
736 } 754 }
737 755
738 // Caller should initialize the responsible textfield, therefore 756 // Caller should initialize the responsible textfield, therefore
739 // "false" is returned 757 // "false" is returned
740 return false; 758 return false;
741 } 759 }
742 760
743 // Everything is worked off .. 761 // Everything is worked off ..
744 return true; 762 return true;
745 763
746} 764}
747 765
748// Currently accessed when we select default-email more than once ! 766// Currently accessed when we select default-email more than once !
749void ContactEditor::chooserError( int index ) 767void ContactEditor::chooserError( int index )
750{ 768{
751 qWarning("ContactEditor::chooserError( %d )", index); 769 qWarning("ContactEditor::chooserError( %d )", index);
752 QMessageBox::warning( this, "Chooser Error", 770 QMessageBox::warning( this, "Chooser Error",
753 "Multiple selection of this\n" 771 "Multiple selection of this\n"
754 "Item is not allowed !\n\n" 772 "Item is not allowed !\n\n"
755 "First deselect the previous one !", 773 "First deselect the previous one !",
756 "&OK", 0, 0, 774 "&OK", 0, 0,
757 0, 0 ); 775 0, 0 );
758 776
759 // Reset the selected Chooser. Unfortunately the chooser 777 // Reset the selected Chooser. Unfortunately the chooser
760 // generates no signal, therfore we have to 778 // generates no signal, therfore we have to
761 // call the cmbChooserChange function manually.. 779 // call the cmbChooserChange function manually..
@@ -899,96 +917,101 @@ void ContactEditor::slotCountryChange( const QString &textChanged ) {
899 917
900 918
901void ContactEditor::slotCmbChooser1Change( int index ) { 919void ContactEditor::slotCmbChooser1Change( int index ) {
902 qWarning("ContactEditor::slotCmbChooser1Change( %d )", index); 920 qWarning("ContactEditor::slotCmbChooser1Change( %d )", index);
903 if ( !cmbChooserChange( cmbChooserField1->currentItem(), txtChooserField1, 1) ){ 921 if ( !cmbChooserChange( cmbChooserField1->currentItem(), txtChooserField1, 1) ){
904 922
905 txtChooserField1->setText( slChooserValues[index] ); 923 txtChooserField1->setText( slChooserValues[index] );
906 txtChooserField1->setFocus(); 924 txtChooserField1->setFocus();
907 925
908 } 926 }
909 927
910} 928}
911 929
912void ContactEditor::slotCmbChooser2Change( int index ) { 930void ContactEditor::slotCmbChooser2Change( int index ) {
913 qWarning("ContactEditor::slotCmbChooser2Change( %d )", index); 931 qWarning("ContactEditor::slotCmbChooser2Change( %d )", index);
914 932
915 if ( !cmbChooserChange( cmbChooserField2->currentItem(), txtChooserField2, 2) ){ 933 if ( !cmbChooserChange( cmbChooserField2->currentItem(), txtChooserField2, 2) ){
916 934
917 txtChooserField2->setText( slChooserValues[index] ); 935 txtChooserField2->setText( slChooserValues[index] );
918 txtChooserField2->setFocus(); 936 txtChooserField2->setFocus();
919 937
920 } 938 }
921} 939}
922 940
923void ContactEditor::slotCmbChooser3Change( int index ) { 941void ContactEditor::slotCmbChooser3Change( int index ) {
924 qWarning("ContactEditor::slotCmbChooser3Change( %d )", index); 942 qWarning("ContactEditor::slotCmbChooser3Change( %d )", index);
925 943
926 if ( !cmbChooserChange( cmbChooserField3->currentItem(), txtChooserField3, 3) ){ 944 if ( !cmbChooserChange( cmbChooserField3->currentItem(), txtChooserField3, 3) ){
927 945
928 txtChooserField3->setText( slChooserValues[index] ); 946 txtChooserField3->setText( slChooserValues[index] );
929 txtChooserField3->setFocus(); 947 txtChooserField3->setFocus();
930 948
931 } 949 }
932} 950}
933 951
934void ContactEditor::slotCmbChooser4Change( int index ) { 952void ContactEditor::slotCmbChooser4Change( int index ) {
935 qWarning("ContactEditor::slotCmbChooser4Change( %d )", index); 953 qWarning("ContactEditor::slotCmbChooser4Change( %d )", index);
936 954
937 if ( !cmbChooserChange( cmbChooserField4->currentItem(), txtChooserField4, 4) ){ 955 if ( !cmbChooserChange( cmbChooserField4->currentItem(), txtChooserField4, 4) ){
938 956
939 txtChooserField4->setText( slChooserValues[index] ); 957 txtChooserField4->setText( slChooserValues[index] );
940 txtChooserField4->setFocus(); 958 txtChooserField4->setFocus();
941 959
942 } 960 }
943} 961}
944 962
945void ContactEditor::slotAddressTypeChange( int index ) { 963void ContactEditor::slotAddressTypeChange( int index ) {
946 964
965
966 if ( !initializing )
967 contactfields.setFieldOrder( 4, index );
968
969
947 if ( index == 0 ) { 970 if ( index == 0 ) {
948 971
949 txtAddress->setText( slBusinessAddress[0] ); 972 txtAddress->setText( slBusinessAddress[0] );
950 //txtAddress2->setText( (*slBusinessAddress)[1] ); 973 //txtAddress2->setText( (*slBusinessAddress)[1] );
951 //txtPOBox->setText( (*slBusinessAddress)[2] ); 974 //txtPOBox->setText( (*slBusinessAddress)[2] );
952 txtCity->setText( slBusinessAddress[3] ); 975 txtCity->setText( slBusinessAddress[3] );
953 txtState->setText( slBusinessAddress[4] ); 976 txtState->setText( slBusinessAddress[4] );
954 txtZip->setText( slBusinessAddress[5] ); 977 txtZip->setText( slBusinessAddress[5] );
955 QLineEdit *txtTmp = cmbCountry->lineEdit(); 978 QLineEdit *txtTmp = cmbCountry->lineEdit();
956 txtTmp->setText( slBusinessAddress[6] ); 979 txtTmp->setText( slBusinessAddress[6] );
957 980
958 } else { 981 } else {
959 982
960 txtAddress->setText( slHomeAddress[0] ); 983 txtAddress->setText( slHomeAddress[0] );
961 //txtAddress2->setText( (*slHomeAddress)[1] ); 984 //txtAddress2->setText( (*slHomeAddress)[1] );
962 //txtPOBox->setText( (*slHomeAddress)[2] ); 985 //txtPOBox->setText( (*slHomeAddress)[2] );
963 txtCity->setText( slHomeAddress[3] ); 986 txtCity->setText( slHomeAddress[3] );
964 txtState->setText( slHomeAddress[4] ); 987 txtState->setText( slHomeAddress[4] );
965 txtZip->setText( slHomeAddress[5] ); 988 txtZip->setText( slHomeAddress[5] );
966 QLineEdit *txtTmp = cmbCountry->lineEdit(); 989 QLineEdit *txtTmp = cmbCountry->lineEdit();
967 txtTmp->setText( slHomeAddress[6] ); 990 txtTmp->setText( slHomeAddress[6] );
968 991
969 } 992 }
970 993
971} 994}
972 995
973void ContactEditor::slotFullNameChange( const QString &textChanged ) { 996void ContactEditor::slotFullNameChange( const QString &textChanged ) {
974 997
975 int index = cmbFileAs->currentItem(); 998 int index = cmbFileAs->currentItem();
976 999
977 cmbFileAs->clear(); 1000 cmbFileAs->clear();
978 1001
979 cmbFileAs->insertItem( parseName( textChanged, 0 ) ); 1002 cmbFileAs->insertItem( parseName( textChanged, 0 ) );
980 cmbFileAs->insertItem( parseName( textChanged, 1 ) ); 1003 cmbFileAs->insertItem( parseName( textChanged, 1 ) );
981 cmbFileAs->insertItem( parseName( textChanged, 2 ) ); 1004 cmbFileAs->insertItem( parseName( textChanged, 2 ) );
982 cmbFileAs->insertItem( parseName( textChanged, 3 ) ); 1005 cmbFileAs->insertItem( parseName( textChanged, 3 ) );
983 1006
984 cmbFileAs->setCurrentItem( index ); 1007 cmbFileAs->setCurrentItem( index );
985 1008
986 useFullName = true; 1009 useFullName = true;
987 1010
988} 1011}
989 1012
990void ContactEditor::accept() { 1013void ContactEditor::accept() {
991 1014
992 if ( isEmpty() ) { 1015 if ( isEmpty() ) {
993 cleanupFields(); 1016 cleanupFields();
994 reject(); 1017 reject();
@@ -1231,102 +1254,102 @@ QString ContactEditor::parseName( const QString fullName, int type ) {
1231 case NAME_S: 1254 case NAME_S:
1232 return strSuffix; 1255 return strSuffix;
1233 1256
1234 } 1257 }
1235 return QString::null; 1258 return QString::null;
1236} 1259}
1237 1260
1238void ContactEditor::cleanupFields() { 1261void ContactEditor::cleanupFields() {
1239 QStringList::Iterator it = slChooserValues.begin(); 1262 QStringList::Iterator it = slChooserValues.begin();
1240 1263
1241 for ( int i = 0; it != slChooserValues.end(); i++, ++it ) { 1264 for ( int i = 0; it != slChooserValues.end(); i++, ++it ) {
1242 (*it) = ""; 1265 (*it) = "";
1243 } 1266 }
1244 1267
1245 for ( int i = 0; i < 7; i++ ) { 1268 for ( int i = 0; i < 7; i++ ) {
1246 slHomeAddress[i] = ""; 1269 slHomeAddress[i] = "";
1247 slBusinessAddress[i] = ""; 1270 slBusinessAddress[i] = "";
1248 } 1271 }
1249 1272
1250 QListIterator<QLineEdit> itLV( listValue ); 1273 QListIterator<QLineEdit> itLV( listValue );
1251 for ( ; itLV.current(); ++itLV ) { 1274 for ( ; itLV.current(); ++itLV ) {
1252 (*itLV)->setText( "" ); 1275 (*itLV)->setText( "" );
1253 } 1276 }
1254 1277
1255 txtFirstName->setText(""); 1278 txtFirstName->setText("");
1256 txtMiddleName->setText(""); 1279 txtMiddleName->setText("");
1257 txtLastName->setText(""); 1280 txtLastName->setText("");
1258 txtSuffix->setText(""); 1281 txtSuffix->setText("");
1259 txtNote->setText(""); 1282 txtNote->setText("");
1260 txtFullName->setText(""); 1283 txtFullName->setText("");
1261 txtJobTitle->setText(""); 1284 txtJobTitle->setText("");
1262 txtOrganization->setText(""); 1285 txtOrganization->setText("");
1263 txtChooserField1->setText(""); 1286 txtChooserField1->setText("");
1264 txtChooserField2->setText(""); 1287 txtChooserField2->setText("");
1265 txtChooserField3->setText(""); 1288 txtChooserField3->setText("");
1266 txtAddress->setText(""); 1289 txtAddress->setText("");
1267 txtCity->setText(""); 1290 txtCity->setText("");
1268 txtState->setText(""); 1291 txtState->setText("");
1269 txtZip->setText(""); 1292 txtZip->setText("");
1270 QLineEdit *txtTmp = cmbCountry->lineEdit(); 1293 QLineEdit *txtTmp = cmbCountry->lineEdit();
1271 txtTmp->setText(""); 1294 txtTmp->setText("");
1272 txtTmp = cmbFileAs->lineEdit(); 1295 txtTmp = cmbFileAs->lineEdit();
1273 txtTmp->setText(""); 1296 txtTmp->setText("");
1274 1297
1275} 1298}
1276 1299
1277void ContactEditor::setEntry( const OContact &entry ) { 1300void ContactEditor::setEntry( const OContact &entry ) {
1278 1301
1302 initializing = true;
1303
1279 cleanupFields(); 1304 cleanupFields();
1280 1305
1281 ent = entry; 1306 ent = entry;
1282 1307
1283
1284
1285 emails = QStringList(ent.emailList()); 1308 emails = QStringList(ent.emailList());
1286 defaultEmail = ent.defaultEmail(); 1309 defaultEmail = ent.defaultEmail();
1287 if (defaultEmail.isEmpty()) defaultEmail = emails[0]; 1310 if (defaultEmail.isEmpty()) defaultEmail = emails[0];
1288 qDebug("default email=%s",defaultEmail.latin1()); 1311 qDebug("default email=%s",defaultEmail.latin1());
1289 1312
1290 useFullName = false; 1313 useFullName = false;
1291 txtFirstName->setText( ent.firstName() ); 1314 txtFirstName->setText( ent.firstName() );
1292 txtMiddleName->setText( ent.middleName() ); 1315 txtMiddleName->setText( ent.middleName() );
1293 txtLastName->setText( ent.lastName() ); 1316 txtLastName->setText( ent.lastName() );
1294 txtSuffix->setText( ent.suffix() ); 1317 txtSuffix->setText( ent.suffix() );
1295 1318
1296 QString *tmpString = new QString; 1319 QString *tmpString = new QString;
1297 *tmpString = ent.firstName() + " " + ent.middleName() + 1320 *tmpString = ent.firstName() + " " + ent.middleName() +
1298 + " " + ent.lastName() + " " + ent.suffix(); 1321 + " " + ent.lastName() + " " + ent.suffix();
1299 1322
1300 txtFullName->setText( tmpString->simplifyWhiteSpace() ); 1323 txtFullName->setText( tmpString->simplifyWhiteSpace() );
1301 1324
1302 cmbFileAs->setEditText( ent.fileAs() ); 1325 cmbFileAs->setEditText( ent.fileAs() );
1303 1326
1304 //if (hasTitle) 1327 //if (hasTitle)
1305 txtJobTitle->setText( ent.jobTitle() ); 1328 txtJobTitle->setText( ent.jobTitle() );
1306 1329
1307 //if (hasCompany) 1330 //if (hasCompany)
1308 txtOrganization->setText( ent.company() ); 1331 txtOrganization->setText( ent.company() );
1309 1332
1310 //if (hasNotes) 1333 //if (hasNotes)
1311 txtNote->setText( ent.notes() ); 1334 txtNote->setText( ent.notes() );
1312 1335
1313 //if (hasStreet) { 1336 //if (hasStreet) {
1314 slHomeAddress[0] = ent.homeStreet(); 1337 slHomeAddress[0] = ent.homeStreet();
1315 slBusinessAddress[0] = ent.businessStreet(); 1338 slBusinessAddress[0] = ent.businessStreet();
1316 //} 1339 //}
1317 1340
1318 //if (hasCity) { 1341 //if (hasCity) {
1319 slHomeAddress[3] = ent.homeCity(); 1342 slHomeAddress[3] = ent.homeCity();
1320 slBusinessAddress[3] = ent.businessCity(); 1343 slBusinessAddress[3] = ent.businessCity();
1321//} 1344//}
1322 1345
1323//if (hasState) { 1346//if (hasState) {
1324 slHomeAddress[4] = ent.homeState(); 1347 slHomeAddress[4] = ent.homeState();
1325 slBusinessAddress[4] = ent.businessState(); 1348 slBusinessAddress[4] = ent.businessState();
1326//} 1349//}
1327 1350
1328//if (hasZip) { 1351//if (hasZip) {
1329 slHomeAddress[5] = ent.homeZip(); 1352 slHomeAddress[5] = ent.homeZip();
1330 slBusinessAddress[5] = ent.businessZip(); 1353 slBusinessAddress[5] = ent.businessZip();
1331//} 1354//}
1332 1355
@@ -1410,125 +1433,145 @@ void ContactEditor::setEntry( const OContact &entry ) {
1410/* 1433/*
1411 if ( *it == "Car Phone" ) 1434 if ( *it == "Car Phone" )
1412 *itV = ent.carPhone(); 1435 *itV = ent.carPhone();
1413 1436
1414 if ( *it == "ISDN Phone" ) 1437 if ( *it == "ISDN Phone" )
1415 *itV = ent.ISDNPhone(); 1438 *itV = ent.ISDNPhone();
1416 1439
1417 if ( *it == "Other Phone" ) 1440 if ( *it == "Other Phone" )
1418 *itV = ent.otherPhone(); 1441 *itV = ent.otherPhone();
1419*/ 1442*/
1420 if ( ( *it == "Business Pager" ) || ( *it == "Work Pager" ) ) 1443 if ( ( *it == "Business Pager" ) || ( *it == "Work Pager" ) )
1421 *itV = ent.businessPager(); 1444 *itV = ent.businessPager();
1422/* 1445/*
1423 if ( *it == "Home Pager") 1446 if ( *it == "Home Pager")
1424 *itV = ent.homePager(); 1447 *itV = ent.homePager();
1425 1448
1426 if ( *it == "AIM IM" ) 1449 if ( *it == "AIM IM" )
1427 *itV = ent.AIMIM(); 1450 *itV = ent.AIMIM();
1428 1451
1429 if ( *it == "ICQ IM" ) 1452 if ( *it == "ICQ IM" )
1430 *itV = ent.ICQIM(); 1453 *itV = ent.ICQIM();
1431 1454
1432 if ( *it == "Jabber IM" ) 1455 if ( *it == "Jabber IM" )
1433 *itV = ent.jabberIM(); 1456 *itV = ent.jabberIM();
1434 1457
1435 if ( *it == "MSN IM" ) 1458 if ( *it == "MSN IM" )
1436 *itV = ent.MSNIM(); 1459 *itV = ent.MSNIM();
1437 1460
1438 if ( *it == "Yahoo IM" ) 1461 if ( *it == "Yahoo IM" )
1439 *itV = ent.yahooIM(); 1462 *itV = ent.yahooIM();
1440*/ 1463*/
1441 if ( *it == "Home Web Page" ) 1464 if ( *it == "Home Web Page" )
1442 *itV = ent.homeWebpage(); 1465 *itV = ent.homeWebpage();
1443 1466
1444 if ( ( *it == "Business WebPage" ) || ( *it == "Work Web Page" ) ) 1467 if ( ( *it == "Business WebPage" ) || ( *it == "Work Web Page" ) )
1445 *itV = ent.businessWebpage(); 1468 *itV = ent.businessWebpage();
1446 1469
1447 1470
1448 } 1471 }
1449 1472
1450 1473
1451 cmbCat->setCategories( ent.categories(), "Contacts", tr("Contacts") ); 1474 cmbCat->setCategories( ent.categories(), "Contacts", tr("Contacts") );
1452 1475
1453 QString gender = ent.gender(); 1476 QString gender = ent.gender();
1454 cmbGender->setCurrentItem( gender.toInt() ); 1477 cmbGender->setCurrentItem( gender.toInt() );
1455 1478
1456 txtNote->setText( ent.notes() ); 1479 txtNote->setText( ent.notes() );
1457 1480
1481 slotAddressTypeChange( cmbAddress->currentItem() );
1482
1483 // Calling "show()" to arrange all widgets. Otherwise we will get
1484 // a wrong position of the textfields and are unable to put our
1485 // default-email combo over it.. This is very ugly !
1486 // Does anybody has a better solution ?
1487 // Basically we should rethink the strategy to hide
1488 // a textfield with overwriting.. (se)
1489 show();
1490
1491 // Get combo-settings from contact and set preset..
1492 contactfields.loadFromRecord( ent );
1493 cmbChooserField1->setCurrentItem( contactfields.getFieldOrder(0, 0) );
1494 cmbChooserField2->setCurrentItem( contactfields.getFieldOrder(1, 1) );
1495 cmbChooserField3->setCurrentItem( contactfields.getFieldOrder(2, 2) );
1496 cmbChooserField4->setCurrentItem( contactfields.getFieldOrder(3, 5) );
1497 cmbAddress->setCurrentItem( contactfields.getFieldOrder(4, 1) );
1458 slotCmbChooser1Change( cmbChooserField1->currentItem() ); 1498 slotCmbChooser1Change( cmbChooserField1->currentItem() );
1459 slotCmbChooser2Change( cmbChooserField2->currentItem() ); 1499 slotCmbChooser2Change( cmbChooserField2->currentItem() );
1460 slotCmbChooser3Change( cmbChooserField3->currentItem() ); 1500 slotCmbChooser3Change( cmbChooserField3->currentItem() );
1461 1501 slotCmbChooser4Change( cmbChooserField4->currentItem() );
1462 slotAddressTypeChange( cmbAddress->currentItem() ); 1502 slotAddressTypeChange( cmbAddress->currentItem() );
1463 1503
1464 // loadFields(); :SX
1465 updateDatePicker(); 1504 updateDatePicker();
1505
1506 initializing = false;
1466} 1507}
1467void ContactEditor::updateDatePicker() 1508void ContactEditor::updateDatePicker()
1468{ 1509{
1469 // Set DatePicker 1510 // Set DatePicker
1470 if ( !ent.birthday().isNull() ){ 1511 if ( !ent.birthday().isNull() ){
1471 birthdayButton->setText( TimeString::numberDateString( ent.birthday() ) ); 1512 birthdayButton->setText( TimeString::numberDateString( ent.birthday() ) );
1472 birthdayPicker->setDate( ent.birthday() ); 1513 birthdayPicker->setDate( ent.birthday() );
1473 } else 1514 } else
1474 birthdayButton->setText( tr ("Unknown") ); 1515 birthdayButton->setText( tr ("Unknown") );
1475 1516
1476 if ( !ent.anniversary().isNull() ){ 1517 if ( !ent.anniversary().isNull() ){
1477 anniversaryButton->setText( TimeString::numberDateString( ent.anniversary() ) ); 1518 anniversaryButton->setText( TimeString::numberDateString( ent.anniversary() ) );
1478 anniversaryPicker->setDate( ent.anniversary() ); 1519 anniversaryPicker->setDate( ent.anniversary() );
1479 } else 1520 } else
1480 anniversaryButton->setText( tr ("Unknown") ); 1521 anniversaryButton->setText( tr ("Unknown") );
1481 1522
1482} 1523}
1483 1524
1484void ContactEditor::saveEntry() { 1525void ContactEditor::saveEntry() {
1485 1526
1486 1527 // Store current combo into contact
1528 contactfields.saveToRecord( ent );
1529
1487 if ( useFullName ) { 1530 if ( useFullName ) {
1488 txtFirstName->setText( parseName( txtFullName->text(), NAME_F ) ); 1531 txtFirstName->setText( parseName( txtFullName->text(), NAME_F ) );
1489 txtMiddleName->setText( parseName( txtFullName->text(), NAME_M ) ); 1532 txtMiddleName->setText( parseName( txtFullName->text(), NAME_M ) );
1490 txtLastName->setText( parseName( txtFullName->text(), NAME_L ) ); 1533 txtLastName->setText( parseName( txtFullName->text(), NAME_L ) );
1491 txtSuffix->setText( parseName( txtFullName->text(), NAME_S ) ); 1534 txtSuffix->setText( parseName( txtFullName->text(), NAME_S ) );
1492 1535
1493 useFullName = false; 1536 useFullName = false;
1494 } 1537 }
1495 1538
1496 ent.setFirstName( txtFirstName->text() ); 1539 ent.setFirstName( txtFirstName->text() );
1497 ent.setLastName( txtLastName->text() ); 1540 ent.setLastName( txtLastName->text() );
1498 ent.setMiddleName( txtMiddleName->text() ); 1541 ent.setMiddleName( txtMiddleName->text() );
1499 ent.setSuffix( txtSuffix->text() ); 1542 ent.setSuffix( txtSuffix->text() );
1500 1543
1501 ent.setFileAs( cmbFileAs->currentText() ); 1544 ent.setFileAs( cmbFileAs->currentText() );
1502 1545
1503 ent.setCategories( cmbCat->currentCategories() ); 1546 ent.setCategories( cmbCat->currentCategories() );
1504 1547
1505 1548
1506 //if (hasTitle) 1549 //if (hasTitle)
1507 ent.setJobTitle( txtJobTitle->text() ); 1550 ent.setJobTitle( txtJobTitle->text() );
1508 1551
1509 //if (hasCompany) 1552 //if (hasCompany)
1510 ent.setCompany( txtOrganization->text() ); 1553 ent.setCompany( txtOrganization->text() );
1511 1554
1512 //if (hasNotes) 1555 //if (hasNotes)
1513 ent.setNotes( txtNote->text() ); 1556 ent.setNotes( txtNote->text() );
1514 1557
1515 //if (hasStreet) { 1558 //if (hasStreet) {
1516 ent.setHomeStreet( slHomeAddress[0] ); 1559 ent.setHomeStreet( slHomeAddress[0] );
1517 ent.setBusinessStreet( slBusinessAddress[0] ); 1560 ent.setBusinessStreet( slBusinessAddress[0] );
1518 //} 1561 //}
1519 1562
1520 //if (hasCity) { 1563 //if (hasCity) {
1521 ent.setHomeCity( slHomeAddress[3] ); 1564 ent.setHomeCity( slHomeAddress[3] );
1522 ent.setBusinessCity( slBusinessAddress[3] ); 1565 ent.setBusinessCity( slBusinessAddress[3] );
1523 //} 1566 //}
1524 1567
1525 //if (hasState) { 1568 //if (hasState) {
1526 ent.setHomeState( slHomeAddress[4] ); 1569 ent.setHomeState( slHomeAddress[4] );
1527 ent.setBusinessState( slBusinessAddress[4] ); 1570 ent.setBusinessState( slBusinessAddress[4] );
1528 //} 1571 //}
1529 1572
1530 //if (hasZip) { 1573 //if (hasZip) {
1531 ent.setHomeZip( slHomeAddress[5] ); 1574 ent.setHomeZip( slHomeAddress[5] );
1532 ent.setBusinessZip( slBusinessAddress[5] ); 1575 ent.setBusinessZip( slBusinessAddress[5] );
1533 //} 1576 //}
1534 1577
diff --git a/core/pim/addressbook/contacteditor.h b/core/pim/addressbook/contacteditor.h
index 4fa48d1..95f9f2d 100644
--- a/core/pim/addressbook/contacteditor.h
+++ b/core/pim/addressbook/contacteditor.h
@@ -1,181 +1,186 @@
1/* 1/*
2 * Copyright (c) 2002 Michael R. Crawford <mike@tuxnami.org> 2 * Copyright (c) 2002 Michael R. Crawford <mike@tuxnami.org>
3 * 3 *
4 * This file is an add-on for the OPIE Palmtop Environment 4 * This file is an add-on for the OPIE Palmtop Environment
5 * 5 *
6 * This file may be distributed and/or modified under the terms of the 6 * This file may be distributed and/or modified under the terms of the
7 * GNU General Public License version 2 as published by the Free Software 7 * GNU General Public License version 2 as published by the Free Software
8 * Foundation and appearing in the file LICENSE.GPL included in the pacakaging 8 * Foundation and appearing in the file LICENSE.GPL included in the pacakaging
9 * of this file. 9 * of this file.
10 * 10 *
11 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13 * 13 *
14 * 14 *
15 * This is a rewrite of the abeditor.h file, modified to provide a more 15 * This is a rewrite of the abeditor.h file, modified to provide a more
16 * intuitive interface to TrollTech's original Address Book editor. This 16 * intuitive interface to TrollTech's original Address Book editor. This
17 * is made to operate exactly in interface with the exception of name. 17 * is made to operate exactly in interface with the exception of name.
18 * 18 *
19 */ 19 */
20 20
21#ifndef CONTACTEDITOR_H 21#ifndef CONTACTEDITOR_H
22#define CONTACTEDITOR_H 22#define CONTACTEDITOR_H
23 23
24#include <opie/ocontact.h> 24#include <opie/ocontact.h>
25 25
26#include <qpe/datebookmonth.h> 26#include <qpe/datebookmonth.h>
27 27
28#include <qdialog.h> 28#include <qdialog.h>
29#include <qlist.h> 29#include <qlist.h>
30#include <qmap.h> 30#include <qmap.h>
31#include <qstringlist.h> 31#include <qstringlist.h>
32 32
33#include "ocontactfields.h"
34
33const int NAME_LF = 0; 35const int NAME_LF = 0;
34const int NAME_LFM = 1; 36const int NAME_LFM = 1;
35const int NAME_FL = 2; 37const int NAME_FL = 2;
36const int NAME_FMLS = 3; 38const int NAME_FMLS = 3;
37 39
38const int NAME_F = 4; 40const int NAME_F = 4;
39const int NAME_M = 5; 41const int NAME_M = 5;
40const int NAME_L = 6; 42const int NAME_L = 6;
41const int NAME_S = 7; 43const int NAME_S = 7;
42 44
43 45
44class QScrollView; 46class QScrollView;
45class QTabWidget; 47class QTabWidget;
46class QMultiLineEdit; 48class QMultiLineEdit;
47class QLineEdit; 49class QLineEdit;
48class QComboBox; 50class QComboBox;
49class QPushButton; 51class QPushButton;
50class CategorySelect; 52class CategorySelect;
51class QLabel; 53class QLabel;
52 54
53class ContactEditor : public QDialog { 55class ContactEditor : public QDialog {
54 Q_OBJECT 56 Q_OBJECT
55 57
56 public: 58 public:
57 ContactEditor(const OContact &entry, 59 ContactEditor(const OContact &entry,
58 QWidget *parent = 0, 60 QWidget *parent = 0,
59 const char *name = 0, 61 const char *name = 0,
60 WFlags fl = 0 ); 62 WFlags fl = 0 );
61 ~ContactEditor(); 63 ~ContactEditor();
62 void setNameFocus(); 64 void setNameFocus();
63 void setPersonalView( bool personal = true ); 65 void setPersonalView( bool personal = true );
64 OContact entry() const { return ent; } 66 OContact entry() const { return ent; }
65 67
66 public slots: 68 public slots:
67 void slotNote(); 69 void slotNote();
68 void slotName(); 70 void slotName();
69 void setEntry(const OContact &entry); 71 void setEntry(const OContact &entry);
70 72
71 protected slots: 73 protected slots:
72 void accept(); 74 void accept();
73 75
74 private: 76 private:
75 void init(); 77 void init();
76 void saveEntry(); 78 void saveEntry();
77 bool isEmpty(); 79 bool isEmpty();
78 void cleanupFields(); 80 void cleanupFields();
79 void updateDatePicker(); 81 void updateDatePicker();
80 QString parseName( QString fullName, int type ); 82 QString parseName( QString fullName, int type );
81 void chooserError( int index ); 83 void chooserError( int index );
82 private slots: 84 private slots:
83 void slotChooser1Change( const QString &textChanged ); 85 void slotChooser1Change( const QString &textChanged );
84 void slotChooser2Change( const QString &textChanged ); 86 void slotChooser2Change( const QString &textChanged );
85 void slotChooser3Change( const QString &textChanged ); 87 void slotChooser3Change( const QString &textChanged );
86 void slotChooser4Change( const QString &textChanged ); 88 void slotChooser4Change( const QString &textChanged );
87 void slotCmbChooser1Change( int index ); 89 void slotCmbChooser1Change( int index );
88 void slotCmbChooser2Change( int index ); 90 void slotCmbChooser2Change( int index );
89 void slotCmbChooser3Change( int index ); 91 void slotCmbChooser3Change( int index );
90 void slotCmbChooser4Change( int index ); 92 void slotCmbChooser4Change( int index );
91 void slotAddressTypeChange( int index ); 93 void slotAddressTypeChange( int index );
92 void slotAddressChange( const QString &textChanged ); 94 void slotAddressChange( const QString &textChanged );
93 void slotAddress2Change( const QString &textChanged ); 95 void slotAddress2Change( const QString &textChanged );
94 void slotPOBoxChange( const QString &textChanged ); 96 void slotPOBoxChange( const QString &textChanged );
95 void slotCityChange( const QString &textChanged ); 97 void slotCityChange( const QString &textChanged );
96 void slotStateChange( const QString &textChanged ); 98 void slotStateChange( const QString &textChanged );
97 void slotZipChange( const QString &textChanged ); 99 void slotZipChange( const QString &textChanged );
98 void slotCountryChange( const QString &textChanged ); 100 void slotCountryChange( const QString &textChanged );
99 void slotFullNameChange( const QString &textChanged ); 101 void slotFullNameChange( const QString &textChanged );
100 void slotAnniversaryDateChanged( int year, int month, int day); 102 void slotAnniversaryDateChanged( int year, int month, int day);
101 void slotBirthdayDateChanged( int year, int month, int day); 103 void slotBirthdayDateChanged( int year, int month, int day);
102 void slotRemoveBirthday(); 104 void slotRemoveBirthday();
103 void slotRemoveAnniversary(); 105 void slotRemoveAnniversary();
104 void defaultEmailChanged(int); 106 void defaultEmailChanged(int);
105 107
106 private: 108 private:
107 int defaultEmailChooserPosition; 109 int defaultEmailChooserPosition;
108 void populateDefaultEmailCmb(); 110 void populateDefaultEmailCmb();
109 void chooserChange( const QString&, int , QLineEdit*, int ); 111 void chooserChange( const QString&, int , QLineEdit*, int );
110 bool cmbChooserChange( int , QLineEdit*, int ); 112 bool cmbChooserChange( int , QLineEdit*, int );
113 OContactFields contactfields;
111 114
112 bool useFullName; 115 bool useFullName;
113 116
114 OContact ent; 117 OContact ent;
115 118
116 QDialog *dlgNote; 119 QDialog *dlgNote;
117 QDialog *dlgName; 120 QDialog *dlgName;
118 121
119 QList<QLineEdit> listValue; 122 QList<QLineEdit> listValue;
120 QList<QLabel> listName; 123 QList<QLabel> listName;
121 124
122 QStringList slDynamicEntries; 125 QStringList slDynamicEntries;
123 QStringList trlDynamicEntries; 126 QStringList trlDynamicEntries;
124 127
125 bool m_personalView; 128 bool m_personalView;
126 129
127 QStringList slHomeAddress; 130 QStringList slHomeAddress;
128 QStringList slBusinessAddress; 131 QStringList slBusinessAddress;
129 QStringList slChooserNames; 132 QStringList slChooserNames;
130 QStringList slChooserValues; 133 QStringList slChooserValues;
131 QStringList emails; 134 QStringList emails;
132 QString defaultEmail; 135 QString defaultEmail;
133 136
134 QMultiLineEdit *txtNote; 137 QMultiLineEdit *txtNote;
135 QLabel *lblNote; 138 QLabel *lblNote;
136 139
137 //QLineEdit *txtTitle; 140 //QLineEdit *txtTitle;
138 QLineEdit *txtFirstName; 141 QLineEdit *txtFirstName;
139 QLineEdit *txtMiddleName; 142 QLineEdit *txtMiddleName;
140 QLineEdit *txtLastName; 143 QLineEdit *txtLastName;
141 QLineEdit *txtSuffix; 144 QLineEdit *txtSuffix;
142 145
143 QTabWidget *tabMain; 146 QTabWidget *tabMain;
144 QScrollView *svGeneral; 147 QScrollView *svGeneral;
145 QPushButton *btnFullName; 148 QPushButton *btnFullName;
146 QPushButton *btnNote; 149 QPushButton *btnNote;
147 QLineEdit *txtFullName; 150 QLineEdit *txtFullName;
148 QLineEdit *txtJobTitle; 151 QLineEdit *txtJobTitle;
149 QLineEdit *txtOrganization; 152 QLineEdit *txtOrganization;
150 QLineEdit *txtChooserField1; 153 QLineEdit *txtChooserField1;
151 QLineEdit *txtChooserField2; 154 QLineEdit *txtChooserField2;
152 QLineEdit *txtChooserField3; 155 QLineEdit *txtChooserField3;
153 QLineEdit *txtChooserField4; 156 QLineEdit *txtChooserField4;
154 QComboBox *cmbChooserField1; 157 QComboBox *cmbChooserField1;
155 QComboBox *cmbChooserField2; 158 QComboBox *cmbChooserField2;
156 QComboBox *cmbChooserField3; 159 QComboBox *cmbChooserField3;
157 QComboBox *cmbChooserField4; 160 QComboBox *cmbChooserField4;
158 QComboBox *cmbDefaultEmail; 161 QComboBox *cmbDefaultEmail;
159 QComboBox *cmbFileAs; 162 QComboBox *cmbFileAs;
160 CategorySelect *cmbCat; 163 CategorySelect *cmbCat;
161 QLabel *labCat; 164 QLabel *labCat;
162 165
163 QScrollView *svAddress; 166 QScrollView *svAddress;
164 QLineEdit *txtAddress; 167 QLineEdit *txtAddress;
165 //QLineEdit *txtAddress2; 168 //QLineEdit *txtAddress2;
166 //QLineEdit *txtPOBox; 169 //QLineEdit *txtPOBox;
167 QLineEdit *txtCity; 170 QLineEdit *txtCity;
168 QLineEdit *txtState; 171 QLineEdit *txtState;
169 QLineEdit *txtZip; 172 QLineEdit *txtZip;
170 QComboBox *cmbAddress; 173 QComboBox *cmbAddress;
171 QComboBox *cmbCountry; 174 QComboBox *cmbCountry;
172 175
173 QScrollView *svDetails; 176 QScrollView *svDetails;
174 QComboBox *cmbGender; 177 QComboBox *cmbGender;
175 DateBookMonth* birthdayPicker; 178 DateBookMonth* birthdayPicker;
176 QToolButton* birthdayButton; 179 QToolButton* birthdayButton;
177 DateBookMonth* anniversaryPicker; 180 DateBookMonth* anniversaryPicker;
178 QToolButton* anniversaryButton; 181 QToolButton* anniversaryButton;
182
183 bool initializing;
179 }; 184 };
180 185
181#endif 186#endif
diff --git a/core/pim/addressbook/ocontactfields.cpp b/core/pim/addressbook/ocontactfields.cpp
index 0da6a4f..75a7641 100644
--- a/core/pim/addressbook/ocontactfields.cpp
+++ b/core/pim/addressbook/ocontactfields.cpp
@@ -1,56 +1,58 @@
1 1
2#include "ocontactfields.h" 2#include "ocontactfields.h"
3 3
4#include <qstringlist.h> 4#include <qstringlist.h>
5#include <qobject.h> 5#include <qobject.h>
6 6
7// We should use our own enum in the future .. 7// We should use our own enum in the future ..
8#include <qpe/recordfields.h> 8#include <qpe/recordfields.h>
9#include <qpe/config.h>
10#include <opie/ocontact.h>
9 11
10/*! 12/*!
11 \internal 13 \internal
12 Returns a list of details field names for a contact. 14 Returns a list of details field names for a contact.
13*/ 15*/
14QStringList OContactFields::untrdetailsfields( bool sorted ) 16QStringList OContactFields::untrdetailsfields( bool sorted )
15{ 17{
16 QStringList list; 18 QStringList list;
17 19
18 list.append( "Office" ); 20 list.append( "Office" );
19 list.append( "Profession" ); 21 list.append( "Profession" );
20 list.append( "Assistant" ); 22 list.append( "Assistant" );
21 list.append( "Manager" ); 23 list.append( "Manager" );
22 24
23 list.append( "Spouse" ); 25 list.append( "Spouse" );
24 list.append( "Gender" ); 26 list.append( "Gender" );
25 list.append( "Birthday" ); 27 list.append( "Birthday" );
26 list.append( "Anniversary" ); 28 list.append( "Anniversary" );
27 list.append( "Nickname" ); 29 list.append( "Nickname" );
28 list.append( "Children" ); 30 list.append( "Children" );
29 31
30 if (sorted) list.sort(); 32 if (sorted) list.sort();
31 return list; 33 return list;
32} 34}
33 35
34/*! 36/*!
35 \internal 37 \internal
36 Returns a translated list of details field names for a contact. 38 Returns a translated list of details field names for a contact.
37*/ 39*/
38QStringList OContactFields::trdetailsfields( bool sorted ) 40QStringList OContactFields::trdetailsfields( bool sorted )
39{ 41{
40 QStringList list; 42 QStringList list;
41 43
42 list.append( QObject::tr( "Office" ) ); 44 list.append( QObject::tr( "Office" ) );
43 list.append( QObject::tr( "Profession" ) ); 45 list.append( QObject::tr( "Profession" ) );
44 list.append( QObject::tr( "Assistant" ) ); 46 list.append( QObject::tr( "Assistant" ) );
45 list.append( QObject::tr( "Manager" ) ); 47 list.append( QObject::tr( "Manager" ) );
46 48
47 list.append( QObject::tr( "Spouse" ) ); 49 list.append( QObject::tr( "Spouse" ) );
48 list.append( QObject::tr( "Gender" ) ); 50 list.append( QObject::tr( "Gender" ) );
49 list.append( QObject::tr( "Birthday" ) ); 51 list.append( QObject::tr( "Birthday" ) );
50 list.append( QObject::tr( "Anniversary" ) ); 52 list.append( QObject::tr( "Anniversary" ) );
51 list.append( QObject::tr( "Nickname" ) ); 53 list.append( QObject::tr( "Nickname" ) );
52 list.append( QObject::tr( "Children" ) ); 54 list.append( QObject::tr( "Children" ) );
53 55
54 if (sorted) list.sort(); 56 if (sorted) list.sort();
55 return list; 57 return list;
56} 58}
@@ -154,121 +156,214 @@ QStringList OContactFields::trfields( bool sorted )
154/*! 156/*!
155 \internal 157 \internal
156 Returns an untranslated list of field names for a contact. 158 Returns an untranslated list of field names for a contact.
157*/ 159*/
158QStringList OContactFields::untrfields( bool sorted ) 160QStringList OContactFields::untrfields( bool sorted )
159{ 161{
160 QStringList list; 162 QStringList list;
161 163
162 list.append( "Name Title" ); 164 list.append( "Name Title" );
163 list.append( "First Name" ); 165 list.append( "First Name" );
164 list.append( "Middle Name" ); 166 list.append( "Middle Name" );
165 list.append( "Last Name" ); 167 list.append( "Last Name" );
166 list.append( "Suffix" ); 168 list.append( "Suffix" );
167 list.append( "File As" ); 169 list.append( "File As" );
168 170
169 list.append( "Job Title" ); 171 list.append( "Job Title" );
170 list.append( "Department" ); 172 list.append( "Department" );
171 list.append( "Company" ); 173 list.append( "Company" );
172 174
173 list += untrphonefields( sorted ); 175 list += untrphonefields( sorted );
174 176
175 list.append( "Business Street" ); 177 list.append( "Business Street" );
176 list.append( "Business City" ); 178 list.append( "Business City" );
177 list.append( "Business State" ); 179 list.append( "Business State" );
178 list.append( "Business Zip" ); 180 list.append( "Business Zip" );
179 list.append( "Business Country" ); 181 list.append( "Business Country" );
180 list.append( "Business Pager" ); 182 list.append( "Business Pager" );
181 list.append( "Business WebPage" ); 183 list.append( "Business WebPage" );
182 184
183 list.append( "Home Street" ); 185 list.append( "Home Street" );
184 list.append( "Home City" ); 186 list.append( "Home City" );
185 list.append( "Home State" ); 187 list.append( "Home State" );
186 list.append( "Home Zip" ); 188 list.append( "Home Zip" );
187 list.append( "Home Country" ); 189 list.append( "Home Country" );
188 list.append( "Home Web Page" ); 190 list.append( "Home Web Page" );
189 191
190 list += untrdetailsfields( sorted ); 192 list += untrdetailsfields( sorted );
191 193
192 list.append( "Notes" ); 194 list.append( "Notes" );
193 list.append( "Groups" ); 195 list.append( "Groups" );
194 196
195 if (sorted) list.sort(); 197 if (sorted) list.sort();
196 198
197 return list; 199 return list;
198} 200}
199QMap<int, QString> OContactFields::idToTrFields() 201QMap<int, QString> OContactFields::idToTrFields()
200{ 202{
201 QMap<int, QString> ret_map; 203 QMap<int, QString> ret_map;
202 204
203 ret_map.insert( Qtopia::Title, QObject::tr( "Name Title") ); 205 ret_map.insert( Qtopia::Title, QObject::tr( "Name Title") );
204 ret_map.insert( Qtopia::FirstName, QObject::tr( "First Name" ) ); 206 ret_map.insert( Qtopia::FirstName, QObject::tr( "First Name" ) );
205 ret_map.insert( Qtopia::MiddleName, QObject::tr( "Middle Name" ) ); 207 ret_map.insert( Qtopia::MiddleName, QObject::tr( "Middle Name" ) );
206 ret_map.insert( Qtopia::LastName, QObject::tr( "Last Name" ) ); 208 ret_map.insert( Qtopia::LastName, QObject::tr( "Last Name" ) );
207 ret_map.insert( Qtopia::Suffix, QObject::tr( "Suffix" )); 209 ret_map.insert( Qtopia::Suffix, QObject::tr( "Suffix" ));
208 ret_map.insert( Qtopia::FileAs, QObject::tr( "File As" ) ); 210 ret_map.insert( Qtopia::FileAs, QObject::tr( "File As" ) );
209 211
210 ret_map.insert( Qtopia::JobTitle, QObject::tr( "Job Title" ) ); 212 ret_map.insert( Qtopia::JobTitle, QObject::tr( "Job Title" ) );
211 ret_map.insert( Qtopia::Department, QObject::tr( "Department" ) ); 213 ret_map.insert( Qtopia::Department, QObject::tr( "Department" ) );
212 ret_map.insert( Qtopia::Company, QObject::tr( "Company" ) ); 214 ret_map.insert( Qtopia::Company, QObject::tr( "Company" ) );
213 ret_map.insert( Qtopia::BusinessPhone, QObject::tr( "Business Phone" ) ); 215 ret_map.insert( Qtopia::BusinessPhone, QObject::tr( "Business Phone" ) );
214 ret_map.insert( Qtopia::BusinessFax, QObject::tr( "Business Fax" ) ); 216 ret_map.insert( Qtopia::BusinessFax, QObject::tr( "Business Fax" ) );
215 ret_map.insert( Qtopia::BusinessMobile, QObject::tr( "Business Mobile" )); 217 ret_map.insert( Qtopia::BusinessMobile, QObject::tr( "Business Mobile" ));
216 218
217 // email 219 // email
218 ret_map.insert( Qtopia::DefaultEmail, QObject::tr( "Default Email" ) ); 220 ret_map.insert( Qtopia::DefaultEmail, QObject::tr( "Default Email" ) );
219 ret_map.insert( Qtopia::Emails, QObject::tr( "Emails" ) ); 221 ret_map.insert( Qtopia::Emails, QObject::tr( "Emails" ) );
220 222
221 ret_map.insert( Qtopia::HomePhone, QObject::tr( "Home Phone" ) ); 223 ret_map.insert( Qtopia::HomePhone, QObject::tr( "Home Phone" ) );
222 ret_map.insert( Qtopia::HomeFax, QObject::tr( "Home Fax" ) ); 224 ret_map.insert( Qtopia::HomeFax, QObject::tr( "Home Fax" ) );
223 ret_map.insert( Qtopia::HomeMobile, QObject::tr( "Home Mobile" ) ); 225 ret_map.insert( Qtopia::HomeMobile, QObject::tr( "Home Mobile" ) );
224 226
225 // business 227 // business
226 ret_map.insert( Qtopia::BusinessStreet, QObject::tr( "Business Street" ) ); 228 ret_map.insert( Qtopia::BusinessStreet, QObject::tr( "Business Street" ) );
227 ret_map.insert( Qtopia::BusinessCity, QObject::tr( "Business City" ) ); 229 ret_map.insert( Qtopia::BusinessCity, QObject::tr( "Business City" ) );
228 ret_map.insert( Qtopia::BusinessState, QObject::tr( "Business State" ) ); 230 ret_map.insert( Qtopia::BusinessState, QObject::tr( "Business State" ) );
229 ret_map.insert( Qtopia::BusinessZip, QObject::tr( "Business Zip" ) ); 231 ret_map.insert( Qtopia::BusinessZip, QObject::tr( "Business Zip" ) );
230 ret_map.insert( Qtopia::BusinessCountry, QObject::tr( "Business Country" ) ); 232 ret_map.insert( Qtopia::BusinessCountry, QObject::tr( "Business Country" ) );
231 ret_map.insert( Qtopia::BusinessPager, QObject::tr( "Business Pager" ) ); 233 ret_map.insert( Qtopia::BusinessPager, QObject::tr( "Business Pager" ) );
232 ret_map.insert( Qtopia::BusinessWebPage, QObject::tr( "Business WebPage" ) ); 234 ret_map.insert( Qtopia::BusinessWebPage, QObject::tr( "Business WebPage" ) );
233 235
234 ret_map.insert( Qtopia::Office, QObject::tr( "Office" ) ); 236 ret_map.insert( Qtopia::Office, QObject::tr( "Office" ) );
235 ret_map.insert( Qtopia::Profession, QObject::tr( "Profession" ) ); 237 ret_map.insert( Qtopia::Profession, QObject::tr( "Profession" ) );
236 ret_map.insert( Qtopia::Assistant, QObject::tr( "Assistant" ) ); 238 ret_map.insert( Qtopia::Assistant, QObject::tr( "Assistant" ) );
237 ret_map.insert( Qtopia::Manager, QObject::tr( "Manager" ) ); 239 ret_map.insert( Qtopia::Manager, QObject::tr( "Manager" ) );
238 240
239 // home 241 // home
240 ret_map.insert( Qtopia::HomeStreet, QObject::tr( "Home Street" ) ); 242 ret_map.insert( Qtopia::HomeStreet, QObject::tr( "Home Street" ) );
241 ret_map.insert( Qtopia::HomeCity, QObject::tr( "Home City" ) ); 243 ret_map.insert( Qtopia::HomeCity, QObject::tr( "Home City" ) );
242 ret_map.insert( Qtopia::HomeState, QObject::tr( "Home State" ) ); 244 ret_map.insert( Qtopia::HomeState, QObject::tr( "Home State" ) );
243 ret_map.insert( Qtopia::HomeZip, QObject::tr( "Home Zip" ) ); 245 ret_map.insert( Qtopia::HomeZip, QObject::tr( "Home Zip" ) );
244 ret_map.insert( Qtopia::HomeCountry, QObject::tr( "Home Country" ) ); 246 ret_map.insert( Qtopia::HomeCountry, QObject::tr( "Home Country" ) );
245 ret_map.insert( Qtopia::HomeWebPage, QObject::tr( "Home Web Page" ) ); 247 ret_map.insert( Qtopia::HomeWebPage, QObject::tr( "Home Web Page" ) );
246 248
247 //personal 249 //personal
248 ret_map.insert( Qtopia::Spouse, QObject::tr( "Spouse" ) ); 250 ret_map.insert( Qtopia::Spouse, QObject::tr( "Spouse" ) );
249 ret_map.insert( Qtopia::Gender, QObject::tr( "Gender" ) ); 251 ret_map.insert( Qtopia::Gender, QObject::tr( "Gender" ) );
250 ret_map.insert( Qtopia::Birthday, QObject::tr( "Birthday" ) ); 252 ret_map.insert( Qtopia::Birthday, QObject::tr( "Birthday" ) );
251 ret_map.insert( Qtopia::Anniversary, QObject::tr( "Anniversary" ) ); 253 ret_map.insert( Qtopia::Anniversary, QObject::tr( "Anniversary" ) );
252 ret_map.insert( Qtopia::Nickname, QObject::tr( "Nickname" ) ); 254 ret_map.insert( Qtopia::Nickname, QObject::tr( "Nickname" ) );
253 ret_map.insert( Qtopia::Children, QObject::tr( "Children" ) ); 255 ret_map.insert( Qtopia::Children, QObject::tr( "Children" ) );
254 256
255 // other 257 // other
256 ret_map.insert( Qtopia::Notes, QObject::tr( "Notes" ) ); 258 ret_map.insert( Qtopia::Notes, QObject::tr( "Notes" ) );
257 259
258 260
259 return ret_map; 261 return ret_map;
260} 262}
261 263
262QMap<QString, int> OContactFields::trFieldsToId() 264QMap<QString, int> OContactFields::trFieldsToId()
263{ 265{
264 QMap<int, QString> idtostr = idToTrFields(); 266 QMap<int, QString> idtostr = idToTrFields();
265 QMap<QString, int> ret_map; 267 QMap<QString, int> ret_map;
266 268
267 269
268 QMap<int, QString>::Iterator it; 270 QMap<int, QString>::Iterator it;
269 for( it = idtostr.begin(); it != idtostr.end(); ++it ) 271 for( it = idtostr.begin(); it != idtostr.end(); ++it )
270 ret_map.insert( *it, it.key() ); 272 ret_map.insert( *it, it.key() );
271 273
272 274
273 return ret_map; 275 return ret_map;
274} 276}
277
278OContactFields::OContactFields():
279 fieldOrder( DEFAULT_FIELD_ORDER ),
280 changedFieldOrder( false )
281{
282 // Get the global field order from the config file and
283 // use it as a start pattern
284 Config cfg ( "AddressBook" );
285 cfg.setGroup( "ContactFieldOrder" );
286 globalFieldOrder = cfg.readEntry( "General", DEFAULT_FIELD_ORDER );
287}
288
289OContactFields::~OContactFields(){
290
291 // We will store the fieldorder into the config file
292 // to reuse it for the future..
293 if ( changedFieldOrder ){
294 Config cfg ( "AddressBook" );
295 cfg.setGroup( "ContactFieldOrder" );
296 cfg.writeEntry( "General", globalFieldOrder );
297 }
298}
299
300
301
302void OContactFields::saveToRecord( OContact &cnt ){
303
304 qDebug("ocontactfields saveToRecord: >%s<",fieldOrder.latin1());
305
306 // Store fieldorder into this contact.
307 cnt.setCustomField( CONTACT_FIELD_ORDER_NAME, fieldOrder );
308
309 globalFieldOrder = fieldOrder;
310 changedFieldOrder = true;
311
312}
313
314void OContactFields::loadFromRecord( const OContact &cnt ){
315 qDebug("ocontactfields loadFromRecord");
316 qDebug("loading >%s<",cnt.fullName().latin1());
317
318 // Get fieldorder for this contact. If none is defined,
319 // we will use the global one from the config file..
320
321 fieldOrder = cnt.customField( CONTACT_FIELD_ORDER_NAME );
322
323 qDebug("fieldOrder from contact>%s<",fieldOrder.latin1());
324
325 if (fieldOrder.isEmpty()){
326 fieldOrder = globalFieldOrder;
327 }
328
329
330 qDebug("effective fieldOrder in loadFromRecord >%s<",fieldOrder.latin1());
331}
332
333void OContactFields::setFieldOrder( int num, int index ){
334 qDebug("qcontactfields setfieldorder pos %i -> %i",num,index);
335
336 fieldOrder[num] = QString::number( index )[0];
337
338 // We will store this new fieldorder globally to
339 // remember it for contacts which have none
340 globalFieldOrder = fieldOrder;
341 changedFieldOrder = true;
342
343 qDebug("fieldOrder >%s<",fieldOrder.latin1());
344}
345
346int OContactFields::getFieldOrder( int num, int defIndex ){
347 qDebug("ocontactfields getFieldOrder");
348 qDebug("fieldOrder >%s<",fieldOrder.latin1());
349
350 // Get index of combo as char..
351 QChar poschar = fieldOrder[num];
352
353 bool ok;
354 int ret = 0;
355 // Convert char to number..
356 if ( !( poschar == QChar::null ) )
357 ret = QString( poschar ).toInt(&ok, 10);
358 else
359 ok = false;
360
361 // Return default value if index for
362 // num was not set or if anything else happened..
363 if ( !ok ) ret = defIndex;
364
365 qDebug("returning >%i<",ret);
366
367 return ret;
368
369}
diff --git a/core/pim/addressbook/ocontactfields.h b/core/pim/addressbook/ocontactfields.h
index 796bc0a..bf3a7f5 100644
--- a/core/pim/addressbook/ocontactfields.h
+++ b/core/pim/addressbook/ocontactfields.h
@@ -1,24 +1,58 @@
1#ifndef OPIE_CONTACTS_FIELDS 1#ifndef OPIE_CONTACTS_FIELDS
2#define OPIE_CONTACTS_FIELDS 2#define OPIE_CONTACTS_FIELDS
3 3
4class QStringList; 4class QStringList;
5 5
6#include <qmap.h> 6#include <qmap.h>
7#include <qstring.h> 7#include <qstring.h>
8#include <opie/ocontact.h>
8 9
10#define CONTACT_FIELD_ORDER_NAME "opie-contactfield-order"
11#define DEFAULT_FIELD_ORDER "__________"
12
9class OContactFields{ 13class OContactFields{
10 14
11 public: 15 public:
16 OContactFields();
17 ~OContactFields();
18 /** Set the index for combo boxes.
19 * Sets the <b>index</b> of combo <b>num</b>.
20 * @param num selects the number of the combo
21 * @param index sets the index in the combo
22 */
23 void setFieldOrder( int num, int index );
24
25 /** Get the index for combo boxes.
26 * Returns the index of combo <b>num</b> or defindex
27 * if none was defined..
28 * @param num Selects the number of the combo
29 * @param defIndex will be returned if none was defined (either
30 * globally in the config file, nor by the contact which was used
31 * by loadFromRecord() )
32 */
33 int getFieldOrder( int num, int defIndex);
34
35 /** Store fieldorder to contact. */
36 void saveToRecord( OContact& );
37 /** Get Fieldorder from contact. */
38 void loadFromRecord( const OContact& );
39
40 private:
41 QString fieldOrder;
42 QString globalFieldOrder;
43 bool changedFieldOrder;
44
45 public:
12 static QStringList trphonefields( bool sorted = true ); 46 static QStringList trphonefields( bool sorted = true );
13 static QStringList untrphonefields( bool sorted = true ); 47 static QStringList untrphonefields( bool sorted = true );
14 static QStringList trdetailsfields( bool sorted = true ); 48 static QStringList trdetailsfields( bool sorted = true );
15 static QStringList untrdetailsfields( bool sorted = true ); 49 static QStringList untrdetailsfields( bool sorted = true );
16 static QStringList trfields( bool sorted = true ); 50 static QStringList trfields( bool sorted = true );
17 static QStringList untrfields( bool sorted = true ); 51 static QStringList untrfields( bool sorted = true );
18 52
19 static QMap<int, QString> idToTrFields(); 53 static QMap<int, QString> idToTrFields();
20 static QMap<QString, int> trFieldsToId(); 54 static QMap<QString, int> trFieldsToId();
21 55
22}; 56};
23 57
24#endif 58#endif
diff --git a/core/pim/addressbook/version.h b/core/pim/addressbook/version.h
index b740326..e716fe4 100644
--- a/core/pim/addressbook/version.h
+++ b/core/pim/addressbook/version.h
@@ -1,10 +1,10 @@
1#ifndef _VERSION_H_ 1#ifndef _VERSION_H_
2#define _VERSION_H_ 2#define _VERSION_H_
3 3
4#define MAINVERSION "0" 4#define MAINVERSION "0"
5#define SUBVERSION "1" 5#define SUBVERSION "2"
6#define PATCHVERSION "1" 6#define PATCHVERSION "0"
7 7
8#define APPNAME "OPIE_ADDRESSBOOK" 8#define APPNAME "OPIE_ADDRESSBOOK"
9 9
10#endif 10#endif