summaryrefslogtreecommitdiff
authoreilers <eilers>2002-10-16 10:55:17 (UTC)
committer eilers <eilers>2002-10-16 10:55:17 (UTC)
commit2bfae6336f88a460311abaf727256c3413b27f67 (patch) (unidiff)
treef554fcecb260ef506a839f4d7994f427ad184555
parentf9756ca203a06fa60413ef1a96416d87b9dc1a6b (diff)
downloadopie-2bfae6336f88a460311abaf727256c3413b27f67.zip
opie-2bfae6336f88a460311abaf727256c3413b27f67.tar.gz
opie-2bfae6336f88a460311abaf727256c3413b27f67.tar.bz2
Fixed reload after sync- bug
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/TODO8
-rw-r--r--core/pim/addressbook/abtable.cpp21
-rw-r--r--core/pim/addressbook/abtable.h5
-rw-r--r--core/pim/addressbook/addressbook.cpp56
4 files changed, 25 insertions, 65 deletions
diff --git a/core/pim/addressbook/TODO b/core/pim/addressbook/TODO
index 32d2838..7bc906d 100644
--- a/core/pim/addressbook/TODO
+++ b/core/pim/addressbook/TODO
@@ -1,26 +1,28 @@
1Stuff todo: 1Stuff todo:
2 2
3Urgent: 3Urgent:
4- Syncing: abtable not reloaded after sync. 4
5- Font menu is invisible using german translation
5 6
6Important: 7Important:
7 8
8- Finishing of new View functions (List, Phonebook...) 9- Finishing of new View functions (List, Phonebook...)
9- Reload if contacts were changed externally 10- Reload if contacts were changed externally
10- "What's this" should be added 11- "What's this" should be added
11- The names of the countries are sorted by there english names, only.. 12- The names of the countries are sorted by there english names, only..
12 Even if they are translated.. :S 13 Even if they are translated.. :S
13- Store last settings of combo-boxes 14- Store last settings of combo-boxes
14 15
15Less important: 16Less important:
16 17
17- Find widget should be replaced by something like 18- Find widget should be replaced by something like
18 qpdf has. 19 qpdf has.
19- The picker (alphabetical sort widget) should be 20- The picker (alphabetical sort widget) should be
20 placed verticaly or horizontally (configurable) 21 placed verticaly or horizontally (configurable)
21 22
22 23
23Should be Fixed: 24Should be Fixed (not absolute sure, need validation):
24- "Nonenglish" translation bug has to be fixed. 25- "Nonenglish" translation bug has to be fixed.
25 26
26Fixed: \ No newline at end of file 27Fixed:
28- Syncing: abtable not reloaded after sync.
diff --git a/core/pim/addressbook/abtable.cpp b/core/pim/addressbook/abtable.cpp
index 70c070f..91a7171 100644
--- a/core/pim/addressbook/abtable.cpp
+++ b/core/pim/addressbook/abtable.cpp
@@ -377,225 +377,228 @@ QString AbTable::findContactContact( const OContact &entry, int /* row */ )
377 case Qtopia::BusinessStreet: 377 case Qtopia::BusinessStreet:
378 value = entry.businessStreet(); 378 value = entry.businessStreet();
379 break; 379 break;
380 case Qtopia::BusinessZip: 380 case Qtopia::BusinessZip:
381 value = entry.businessZip(); 381 value = entry.businessZip();
382 break; 382 break;
383 case Qtopia::BusinessCountry: 383 case Qtopia::BusinessCountry:
384 value = entry.businessCountry(); 384 value = entry.businessCountry();
385 break; 385 break;
386 case Qtopia::BusinessWebPage: 386 case Qtopia::BusinessWebPage:
387 value = entry.businessWebpage(); 387 value = entry.businessWebpage();
388 break; 388 break;
389 case Qtopia::JobTitle: 389 case Qtopia::JobTitle:
390 value = entry.jobTitle(); 390 value = entry.jobTitle();
391 break; 391 break;
392 case Qtopia::Department: 392 case Qtopia::Department:
393 value = entry.department(); 393 value = entry.department();
394 break; 394 break;
395 case Qtopia::Office: 395 case Qtopia::Office:
396 value = entry.office(); 396 value = entry.office();
397 break; 397 break;
398 case Qtopia::BusinessPhone: 398 case Qtopia::BusinessPhone:
399 value = entry.businessPhone(); 399 value = entry.businessPhone();
400 break; 400 break;
401 case Qtopia::BusinessFax: 401 case Qtopia::BusinessFax:
402 value = entry.businessFax(); 402 value = entry.businessFax();
403 break; 403 break;
404 case Qtopia::BusinessMobile: 404 case Qtopia::BusinessMobile:
405 value = entry.businessMobile(); 405 value = entry.businessMobile();
406 break; 406 break;
407 case Qtopia::BusinessPager: 407 case Qtopia::BusinessPager:
408 value = entry.businessPager(); 408 value = entry.businessPager();
409 break; 409 break;
410 case Qtopia::Profession: 410 case Qtopia::Profession:
411 value = entry.profession(); 411 value = entry.profession();
412 break; 412 break;
413 case Qtopia::Assistant: 413 case Qtopia::Assistant:
414 value = entry.assistant(); 414 value = entry.assistant();
415 break; 415 break;
416 case Qtopia::Manager: 416 case Qtopia::Manager:
417 value = entry.manager(); 417 value = entry.manager();
418 break; 418 break;
419 case Qtopia::Spouse: 419 case Qtopia::Spouse:
420 value = entry.spouse(); 420 value = entry.spouse();
421 break; 421 break;
422 case Qtopia::Gender: 422 case Qtopia::Gender:
423 value = entry.gender(); 423 value = entry.gender();
424 break; 424 break;
425 case Qtopia::Birthday: 425 case Qtopia::Birthday:
426 value = entry.birthday(); 426 value = entry.birthday();
427 break; 427 break;
428 case Qtopia::Anniversary: 428 case Qtopia::Anniversary:
429 value = entry.anniversary(); 429 value = entry.anniversary();
430 break; 430 break;
431 case Qtopia::Nickname: 431 case Qtopia::Nickname:
432 value = entry.nickname(); 432 value = entry.nickname();
433 break; 433 break;
434 case Qtopia::Children: 434 case Qtopia::Children:
435 value = entry.children(); 435 value = entry.children();
436 break; 436 break;
437 case Qtopia::Notes: 437 case Qtopia::Notes:
438 value = entry.notes(); 438 value = entry.notes();
439 break; 439 break;
440 } 440 }
441 if ( !value.isEmpty() ) 441 if ( !value.isEmpty() )
442 break; 442 break;
443 } 443 }
444 return value; 444 return value;
445} 445}
446 446
447void AbTable::addEntry( const OContact &newCnt ) 447void AbTable::addEntry( const OContact &newCnt )
448{ 448{
449 int row = numRows(); 449 int row = numRows();
450 450
451 setNumRows( row + 1 ); 451 setNumRows( row + 1 );
452 insertIntoTable( newCnt, row ); 452 insertIntoTable( newCnt, row );
453 453
454 qWarning("abtable:AddContact"); 454 qWarning("abtable:AddContact");
455 m_contactdb.add ( newCnt ); 455 m_contactdb.add ( newCnt );
456 456
457 setCurrentCell( row, 0 ); 457 setCurrentCell( row, 0 );
458 // updateVisible(); 458 // updateVisible();
459} 459}
460 460
461void AbTable::resizeRows() { 461void AbTable::resizeRows() {
462 /* 462 /*
463 if (numRows()) { 463 if (numRows()) {
464 for (int i = 0; i < numRows(); i++) { 464 for (int i = 0; i < numRows(); i++) {
465 setRowHeight( i, size ); 465 setRowHeight( i, size );
466 } 466 }
467 } 467 }
468 updateVisible(); 468 updateVisible();
469 */ 469 */
470} 470}
471 471
472 472
473bool AbTable::save( const QString& /* fn */ ) 473bool AbTable::save()
474{ 474{
475 // QTime t; 475 // QTime t;
476 // t.start(); 476 // t.start();
477 qWarning("abtable:Save data"); 477 qWarning("abtable:Save data");
478 m_contactdb.save(); 478
479 479 return m_contactdb.save();
480 return true;
481} 480}
482 481
483void AbTable::load( const QString& /* fn */ ) 482void AbTable::load()
484{ 483{
485 setSorting( false ); 484 setSorting( false );
486 setUpdatesEnabled( FALSE ); 485 setUpdatesEnabled( FALSE );
487 486
488 qWarning("abtable:Load data"); 487 qWarning("abtable:Load data");
489 488
490 OContactAccess::List list = m_contactdb.allRecords(); 489 OContactAccess::List list = m_contactdb.allRecords();
491 OContactAccess::List::Iterator it; 490 OContactAccess::List::Iterator it;
492 setNumRows( list.count() ); 491 setNumRows( list.count() );
493 int row = 0; 492 int row = 0;
494 for ( it = list.begin(); it != list.end(); ++it ) 493 for ( it = list.begin(); it != list.end(); ++it )
495 insertIntoTable( *it, row++ ); 494 insertIntoTable( *it, row++ );
496 495
497 resort();
498
499 setUpdatesEnabled( TRUE ); 496 setUpdatesEnabled( TRUE );
500 497
501 setSorting( true ); 498 setSorting( true );
502 //resort(); 499 resort();
503} 500}
504 501
505 502
503void AbTable::reload()
504{
505 m_contactdb.reload();
506 load();
507}
508
506void AbTable::realignTable( int row ) 509void AbTable::realignTable( int row )
507{ 510{
508 QTableItem *ti1, 511 QTableItem *ti1,
509 *ti2; 512 *ti2;
510 int totalRows = numRows(); 513 int totalRows = numRows();
511 for ( int curr = row; curr < totalRows - 1; curr++ ) { 514 for ( int curr = row; curr < totalRows - 1; curr++ ) {
512 // the same info from the todo list still applies, but I 515 // the same info from the todo list still applies, but I
513 // don't think it is _too_ bad. 516 // don't think it is _too_ bad.
514 ti1 = item( curr + 1, 0 ); 517 ti1 = item( curr + 1, 0 );
515 ti2 = item( curr + 1, 1 ); 518 ti2 = item( curr + 1, 1 );
516 takeItem( ti1 ); 519 takeItem( ti1 );
517 takeItem( ti2 ); 520 takeItem( ti2 );
518 setItem( curr, 0, ti1 ); 521 setItem( curr, 0, ti1 );
519 setItem( curr, 1, ti2 ); 522 setItem( curr, 1, ti2 );
520 } 523 }
521 setNumRows( totalRows - 1 ); 524 setNumRows( totalRows - 1 );
522 resort(); 525 resort();
523} 526}
524 527
525// Add contact into table. 528// Add contact into table.
526void AbTable::insertIntoTable( const OContact &cnt, int row ) 529void AbTable::insertIntoTable( const OContact &cnt, int row )
527{ 530{
528 QString strName, 531 QString strName,
529 strContact; 532 strContact;
530 533
531 strName = findContactName( cnt ); 534 strName = findContactName( cnt );
532 strContact = findContactContact( cnt, row ); 535 strContact = findContactContact( cnt, row );
533 536
534 AbTableItem *ati; 537 AbTableItem *ati;
535 ati = new AbTableItem( this, QTableItem::Never, strName, strContact); 538 ati = new AbTableItem( this, QTableItem::Never, strName, strContact);
536 contactList.insert( ati, cnt ); 539 contactList.insert( ati, cnt );
537 setItem( row, 0, ati ); 540 setItem( row, 0, ati );
538 ati = new AbTableItem( this, QTableItem::Never, strContact, strName); 541 ati = new AbTableItem( this, QTableItem::Never, strContact, strName);
539 setItem( row, 1, ati ); 542 setItem( row, 1, ati );
540 543
541 //### cannot do this; table only has two columns at this point 544 //### cannot do this; table only has two columns at this point
542 // setItem( row, 2, new AbPickItem( this ) ); 545 // setItem( row, 2, new AbPickItem( this ) );
543 546
544 // resort at some point? 547 // resort at some point?
545} 548}
546 549
547 550
548// Replace or add an entry 551// Replace or add an entry
549void AbTable::journalFreeReplace( const OContact &cnt, int row ) 552void AbTable::journalFreeReplace( const OContact &cnt, int row )
550{ 553{
551 QString strName, 554 QString strName,
552 strContact; 555 strContact;
553 AbTableItem *ati = 0l; 556 AbTableItem *ati = 0l;
554 557
555 strName = findContactName( cnt ); 558 strName = findContactName( cnt );
556 strContact = findContactContact( cnt, row ); 559 strContact = findContactContact( cnt, row );
557 ati = static_cast<AbTableItem*>(item(row, 0)); 560 ati = static_cast<AbTableItem*>(item(row, 0));
558 561
559 // Replace element if found in row "row" 562 // Replace element if found in row "row"
560 // or add this element if not. 563 // or add this element if not.
561 if ( ati != 0 ) { // replace 564 if ( ati != 0 ) { // replace
562 // :SX db access -> replace 565 // :SX db access -> replace
563 qWarning ("Replace Contact in DB ! UID: %d", contactList[ati].uid() ); 566 qWarning ("Replace Contact in DB ! UID: %d", contactList[ati].uid() );
564 m_contactdb.replace ( cnt ); 567 m_contactdb.replace ( cnt );
565 568
566 contactList.remove( ati ); 569 contactList.remove( ati );
567 ati->setItem( strName, strContact ); 570 ati->setItem( strName, strContact );
568 contactList.insert( ati, cnt ); 571 contactList.insert( ati, cnt );
569 572
570 ati = static_cast<AbTableItem*>(item(row, 1)); 573 ati = static_cast<AbTableItem*>(item(row, 1));
571 ati->setItem( strContact, strName ); 574 ati->setItem( strContact, strName );
572 575
573 }else{ // add 576 }else{ // add
574 int myrows = numRows(); 577 int myrows = numRows();
575 setNumRows( myrows + 1 ); 578 setNumRows( myrows + 1 );
576 insertIntoTable( cnt, myrows ); 579 insertIntoTable( cnt, myrows );
577 // gets deleted when returning -- Why ? (se) 580 // gets deleted when returning -- Why ? (se)
578 // :SX db access -> add 581 // :SX db access -> add
579 qWarning ("Are you sure to add to database ? -> Currently disabled !!"); 582 qWarning ("Are you sure to add to database ? -> Currently disabled !!");
580 // m_contactdb.add( cnt ); 583 // m_contactdb.add( cnt );
581 } 584 }
582} 585}
583 586
584// Remove entry 587// Remove entry
585void AbTable::journalFreeRemove( int row ) 588void AbTable::journalFreeRemove( int row )
586{ 589{
587 AbTableItem *ati; 590 AbTableItem *ati;
588 ati = static_cast<AbTableItem*>(item(row, 0)); 591 ati = static_cast<AbTableItem*>(item(row, 0));
589 if ( !ati ) 592 if ( !ati )
590 return; 593 return;
591 594
592 // :SX db access -> remove 595 // :SX db access -> remove
593 qWarning ("Remove Contact from DB ! UID: %d",contactList[ati].uid() ); 596 qWarning ("Remove Contact from DB ! UID: %d",contactList[ati].uid() );
594 m_contactdb.remove( contactList[ati].uid() ); 597 m_contactdb.remove( contactList[ati].uid() );
595 598
596 contactList.remove( ati ); 599 contactList.remove( ati );
597 600
598 realignTable( row ); 601 realignTable( row );
599 602
600} 603}
601 604
diff --git a/core/pim/addressbook/abtable.h b/core/pim/addressbook/abtable.h
index 84aef1e..80c3ca0 100644
--- a/core/pim/addressbook/abtable.h
+++ b/core/pim/addressbook/abtable.h
@@ -1,153 +1,154 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt 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 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging 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** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#ifndef ABTABLE_H 21#ifndef ABTABLE_H
22#define ABTABLE_H 22#define ABTABLE_H
23 23
24#include <qpe/categories.h> 24#include <qpe/categories.h>
25#include <opie/ocontact.h> 25#include <opie/ocontact.h>
26 26
27#include <qmap.h> 27#include <qmap.h>
28#include <qtable.h> 28#include <qtable.h>
29#include <qstringlist.h> 29#include <qstringlist.h>
30#include <qcombobox.h> 30#include <qcombobox.h>
31 31
32#include <opie/ocontactaccess.h> 32#include <opie/ocontactaccess.h>
33 33
34class AbTableItem : public QTableItem 34class AbTableItem : public QTableItem
35{ 35{
36public: 36public:
37 AbTableItem( QTable *t, EditType et, const QString &s, 37 AbTableItem( QTable *t, EditType et, const QString &s,
38 const QString &secondSortKey); 38 const QString &secondSortKey);
39 QString entryKey() const; 39 QString entryKey() const;
40 void setEntryKey( const QString & k ); 40 void setEntryKey( const QString & k );
41 virtual int alignment() const; 41 virtual int alignment() const;
42 virtual QString key() const; 42 virtual QString key() const;
43 void setItem( const QString &txt, const QString &secondKey ); 43 void setItem( const QString &txt, const QString &secondKey );
44 44
45private: 45private:
46 QString sortKey; 46 QString sortKey;
47}; 47};
48 48
49class AbPickItem : public QTableItem 49class AbPickItem : public QTableItem
50{ 50{
51public: 51public:
52 AbPickItem( QTable *t ); 52 AbPickItem( QTable *t );
53 53
54 QWidget *createEditor() const; 54 QWidget *createEditor() const;
55 void setContentFromEditor( QWidget *w ); 55 void setContentFromEditor( QWidget *w );
56 56
57private: 57private:
58 QGuardedPtr<QComboBox> cb; 58 QGuardedPtr<QComboBox> cb;
59}; 59};
60 60
61class AbTable : public QTable 61class AbTable : public QTable
62{ 62{
63 Q_OBJECT 63 Q_OBJECT
64 64
65public: 65public:
66 AbTable( const QValueList<int> *ordered, QWidget *parent, const char *name=0 ); 66 AbTable( const QValueList<int> *ordered, QWidget *parent, const char *name=0 );
67 ~AbTable(); 67 ~AbTable();
68 // NEW 68 // NEW
69 void addEntry( const OContact &newContact ); 69 void addEntry( const OContact &newContact );
70 OContact currentEntry(); 70 OContact currentEntry();
71 void replaceCurrentEntry( const OContact &newContact ); 71 void replaceCurrentEntry( const OContact &newContact );
72 72
73 void init(); 73 void init();
74 74
75 void deleteCurrentEntry(); 75 void deleteCurrentEntry();
76 void clear(); 76 void clear();
77 void clearFindRow() { currFindRow = -2; } 77 void clearFindRow() { currFindRow = -2; }
78 void loadFields(); 78 void loadFields();
79 void refresh(); 79 void refresh();
80 bool save( const QString &fn ); 80 bool save();
81 void load( const QString &fn ); 81 void load();
82 void reload();
82 83
83 // addresspicker mode 84 // addresspicker mode
84 void setChoiceNames( const QStringList& list); 85 void setChoiceNames( const QStringList& list);
85 QStringList choiceNames() const; 86 QStringList choiceNames() const;
86 void setChoiceSelection(int index, const QStringList& list); 87 void setChoiceSelection(int index, const QStringList& list);
87 QStringList choiceSelection(int index) const; 88 QStringList choiceSelection(int index) const;
88 void setShowCategory( const QString &b, const QString &c ); 89 void setShowCategory( const QString &b, const QString &c );
89 void setShowByLetter( char c ); 90 void setShowByLetter( char c );
90 QString showCategory() const; 91 QString showCategory() const;
91 QStringList categories(); 92 QStringList categories();
92 93
93 void resizeRows(); 94 void resizeRows();
94 95
95 void show(); 96 void show();
96 void setPaintingEnabled( bool e ); 97 void setPaintingEnabled( bool e );
97 98
98 QString showBook() const; 99 QString showBook() const;
99 100
100public slots: 101public slots:
101 void slotDoFind( const QString &str, bool caseSensitive, bool backwards, 102 void slotDoFind( const QString &str, bool caseSensitive, bool backwards,
102 int category ); 103 int category );
103signals: 104signals:
104 void empty( bool ); 105 void empty( bool );
105 void details(); 106 void details();
106 void signalNotFound(); 107 void signalNotFound();
107 void signalWrapAround(); 108 void signalWrapAround();
108 109
109protected: 110protected:
110 virtual void keyPressEvent( QKeyEvent *e ); 111 virtual void keyPressEvent( QKeyEvent *e );
111 112
112// int rowHeight( int ) const; 113// int rowHeight( int ) const;
113// int rowPos( int row ) const; 114// int rowPos( int row ) const;
114// virtual int rowAt( int pos ) const; 115// virtual int rowAt( int pos ) const;
115 116
116 117
117protected slots: 118protected slots:
118 void moveTo( char ); 119 void moveTo( char );
119 virtual void columnClicked( int col ); 120 virtual void columnClicked( int col );
120 void itemClicked(int,int col); 121 void itemClicked(int,int col);
121 void rowHeightChanged( int row ); 122 void rowHeightChanged( int row );
122 123
123private: 124private:
124 void loadFile( const QString &strFile, bool journalFile ); 125 void loadFile( const QString &strFile, bool journalFile );
125 void fitColumns(); 126 void fitColumns();
126 void resort(); 127 void resort();
127 void updateJournal( const OContact &contact, OContact::journal_action action, 128 void updateJournal( const OContact &contact, OContact::journal_action action,
128 int row = -1 ); 129 int row = -1 );
129 void insertIntoTable( const OContact &contact, int row ); 130 void insertIntoTable( const OContact &contact, int row );
130 QString findContactName( const OContact &entry ); 131 QString findContactName( const OContact &entry );
131 QString findContactContact( const OContact &entry, int row ); 132 QString findContactContact( const OContact &entry, int row );
132 void journalFreeReplace( const OContact &cnt, int row ); 133 void journalFreeReplace( const OContact &cnt, int row );
133 void journalFreeRemove( int row ); 134 void journalFreeRemove( int row );
134 void realignTable( int ); 135 void realignTable( int );
135 void updateVisible(); 136 void updateVisible();
136 int lastSortCol; 137 int lastSortCol;
137 bool asc; 138 bool asc;
138 char showChar; 139 char showChar;
139 QMap<AbTableItem*, OContact> contactList; 140 QMap<AbTableItem*, OContact> contactList;
140 const QValueList<int> *intFields; 141 const QValueList<int> *intFields;
141 int currFindRow; 142 int currFindRow;
142 QString showCat; 143 QString showCat;
143 QStringList choicenames; 144 QStringList choicenames;
144 bool enablePainting; 145 bool enablePainting;
145 Categories mCat; 146 Categories mCat;
146 147
147 QString showBk; 148 QString showBk;
148 bool columnVisible; 149 bool columnVisible;
149 150
150 OContactAccess m_contactdb; 151 OContactAccess m_contactdb;
151 152
152}; 153};
153#endif // ABTABLE_H 154#endif // ABTABLE_H
diff --git a/core/pim/addressbook/addressbook.cpp b/core/pim/addressbook/addressbook.cpp
index 2eb9ddf..93581e8 100644
--- a/core/pim/addressbook/addressbook.cpp
+++ b/core/pim/addressbook/addressbook.cpp
@@ -1,333 +1,302 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt 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 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging 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** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** OContact info@trolltech.com if any conditions of this licensing are 16** OContact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#define QTOPIA_INTERNAL_FD 21#define QTOPIA_INTERNAL_FD
22 22
23#include "contacteditor.h" 23#include "contacteditor.h"
24#include "ablabel.h" 24#include "ablabel.h"
25#include "abtable.h" 25#include "abtable.h"
26#include "addresssettings.h" 26#include "addresssettings.h"
27#include "addressbook.h" 27#include "addressbook.h"
28 28
29 29
30#include <opie/ofileselector.h> 30#include <opie/ofileselector.h>
31#include <opie/ofiledialog.h> 31#include <opie/ofiledialog.h>
32#include <qpe/qpeapplication.h> 32#include <qpe/qpeapplication.h>
33#include <qpe/config.h> 33#include <qpe/config.h>
34#include <opie/ocontact.h> 34#include <opie/ocontact.h>
35 35
36#ifndef MAKE_FOR_SHARP_ROM 36#ifndef MAKE_FOR_SHARP_ROM
37#include <qpe/finddialog.h> 37#include <qpe/finddialog.h>
38#endif 38#endif
39 39
40#include <qpe/global.h> 40#include <qpe/global.h>
41#include <qpe/resource.h> 41#include <qpe/resource.h>
42#include <qpe/ir.h> 42#include <qpe/ir.h>
43#include <qpe/qpemessagebox.h> 43#include <qpe/qpemessagebox.h>
44#include <qpe/qcopenvelope_qws.h> 44#include <qpe/qcopenvelope_qws.h>
45 45
46#include <qaction.h> 46#include <qaction.h>
47#include <qdialog.h> 47#include <qdialog.h>
48#include <qdir.h> 48#include <qdir.h>
49#include <qfile.h> 49#include <qfile.h>
50#include <qimage.h> 50#include <qimage.h>
51#include <qlayout.h> 51#include <qlayout.h>
52#include <qpe/qpemenubar.h> 52#include <qpe/qpemenubar.h>
53#include <qmessagebox.h> 53#include <qmessagebox.h>
54#include <qpixmap.h> 54#include <qpixmap.h>
55#include <qpopupmenu.h> 55#include <qpopupmenu.h>
56#include <qpe/qpetoolbar.h> 56#include <qpe/qpetoolbar.h>
57#include <qstringlist.h> 57#include <qstringlist.h>
58#include <qtoolbutton.h> 58#include <qtoolbutton.h>
59#include <qwhatsthis.h> 59#include <qwhatsthis.h>
60 60
61#include <stdlib.h> 61#include <stdlib.h>
62#include <sys/stat.h> 62#include <sys/stat.h>
63#include <sys/types.h> 63#include <sys/types.h>
64#include <fcntl.h> 64#include <fcntl.h>
65#include <unistd.h> 65#include <unistd.h>
66 66
67#include <qdatetime.h> 67#include <qdatetime.h>
68 68
69#include "picker.h" 69#include "picker.h"
70static QString addressbookOldXMLFilename()
71{
72 QString filename = QPEApplication::documentDir() + "addressbook.xml";
73 return filename;
74}
75
76static QString addressbookXMLFilename()
77{
78 QString filename = Global::applicationFileName("addressbook",
79 "addressbook.xml");
80 return filename;
81}
82 70
83static QString addressbookPersonalVCardName() 71static QString addressbookPersonalVCardName()
84{ 72{
85 QString filename = Global::applicationFileName("addressbook", 73 QString filename = Global::applicationFileName("addressbook",
86 "businesscard.vcf"); 74 "businesscard.vcf");
87 return filename; 75 return filename;
88} 76}
89 77
90 78
91AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name, 79AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name,
92 WFlags f ) 80 WFlags f )
93 : QMainWindow( parent, name, f ), 81 : QMainWindow( parent, name, f ),
94 abEditor(0), 82 abEditor(0),
95 bAbEditFirstTime(TRUE), 83 bAbEditFirstTime(TRUE),
96 syncing(FALSE) 84 syncing(FALSE)
97{ 85{
98 isLoading = true; 86 isLoading = true;
99 87
100 initFields(); 88 initFields();
101 89
102 setCaption( tr("Contacts") ); 90 setCaption( tr("Contacts") );
103 setIcon( Resource::loadPixmap( "AddressBook" ) ); 91 setIcon( Resource::loadPixmap( "AddressBook" ) );
104 92
105 setToolBarsMovable( FALSE ); 93 setToolBarsMovable( FALSE );
106 94
107 // Create Toolbars 95 // Create Toolbars
108 96
109 QPEToolBar *bar = new QPEToolBar( this ); 97 QPEToolBar *bar = new QPEToolBar( this );
110 bar->setHorizontalStretchable( TRUE ); 98 bar->setHorizontalStretchable( TRUE );
111 99
112 QPEMenuBar *mbList = new QPEMenuBar( bar ); 100 QPEMenuBar *mbList = new QPEMenuBar( bar );
113 mbList->setMargin( 0 ); 101 mbList->setMargin( 0 );
114 102
115 QPopupMenu *edit = new QPopupMenu( this ); 103 QPopupMenu *edit = new QPopupMenu( this );
116 mbList->insertItem( tr( "Contact" ), edit ); 104 mbList->insertItem( tr( "Contact" ), edit );
117 105
118 listTools = new QPEToolBar( this, "list operations" ); 106 listTools = new QPEToolBar( this, "list operations" );
119 107
120 108
121 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 109 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null,
122 0, this, 0 ); 110 0, this, 0 );
123 actionNew = a; 111 actionNew = a;
124 connect( a, SIGNAL( activated() ), this, SLOT( slotListNew() ) ); 112 connect( a, SIGNAL( activated() ), this, SLOT( slotListNew() ) );
125 a->addTo( edit ); 113 a->addTo( edit );
126 a->addTo( listTools ); 114 a->addTo( listTools );
127 115
128 a = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ), QString::null, 116 a = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ), QString::null,
129 0, this, 0 ); 117 0, this, 0 );
130 actionEdit = a; 118 actionEdit = a;
131 connect( a, SIGNAL( activated() ), this, SLOT( slotViewEdit() ) ); 119 connect( a, SIGNAL( activated() ), this, SLOT( slotViewEdit() ) );
132 a->addTo( edit ); 120 a->addTo( edit );
133 a->addTo( listTools ); 121 a->addTo( listTools );
134 122
135 a = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ), QString::null, 123 a = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ), QString::null,
136 0, this, 0 ); 124 0, this, 0 );
137 actionTrash = a; 125 actionTrash = a;
138 connect( a, SIGNAL( activated() ), this, SLOT( slotListDelete() ) ); 126 connect( a, SIGNAL( activated() ), this, SLOT( slotListDelete() ) );
139 a->addTo( edit ); 127 a->addTo( edit );
140 a->addTo( listTools ); 128 a->addTo( listTools );
141 129
142 130
143 // make it possible to go directly to businesscard via qcop call 131 // make it possible to go directly to businesscard via qcop call
144#if defined(Q_WS_QWS) 132#if defined(Q_WS_QWS)
145#if !defined(QT_NO_COP) 133#if !defined(QT_NO_COP)
146 QCopChannel *addressChannel = new QCopChannel("QPE/Addressbook" , this ); 134 QCopChannel *addressChannel = new QCopChannel("QPE/Addressbook" , this );
147 connect (addressChannel, SIGNAL( received(const QCString &, const QByteArray &)), 135 connect (addressChannel, SIGNAL( received(const QCString &, const QByteArray &)),
148 this, SLOT ( appMessage(const QCString &, const QByteArray &) ) ); 136 this, SLOT ( appMessage(const QCString &, const QByteArray &) ) );
149#endif 137#endif
150#endif 138#endif
151 139
152 140
153 141
154 142
155 143
156#ifndef MAKE_FOR_SHARP_ROM 144#ifndef MAKE_FOR_SHARP_ROM
157 a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ), 145 a = new QAction( tr( "Find" ), Resource::loadPixmap( "mag" ),
158 QString::null, 0, this, 0 ); 146 QString::null, 0, this, 0 );
159 actionFind = a; 147 actionFind = a;
160 connect( a, SIGNAL(activated()), this, SLOT(slotFind()) ); 148 connect( a, SIGNAL(activated()), this, SLOT(slotFind()) );
161 a->addTo( edit ); 149 a->addTo( edit );
162 a->addTo( listTools ); 150 a->addTo( listTools );
163#endif 151#endif
164 152
165 153
166 a = new QAction( tr( "Write Mail To" ), Resource::loadPixmap( "qtmail/reply" ), 154 a = new QAction( tr( "Write Mail To" ), Resource::loadPixmap( "qtmail/reply" ),
167 QString::null, 0, this, 0 ); 155 QString::null, 0, this, 0 );
168 //a->setEnabled( FALSE ); we got support for it now :) zecke 156 //a->setEnabled( FALSE ); we got support for it now :) zecke
169 actionMail = a; 157 actionMail = a;
170 connect( a, SIGNAL( activated() ), this, SLOT( writeMail() ) ); 158 connect( a, SIGNAL( activated() ), this, SLOT( writeMail() ) );
171 a->addTo( edit ); 159 a->addTo( edit );
172 a->addTo( listTools ); 160 a->addTo( listTools );
173 161
174 162
175 163
176 if ( Ir::supported() ) { 164 if ( Ir::supported() ) {
177 a = new QAction( tr ("Beam Entry" ), Resource::loadPixmap( "beam" ), QString::null, 165 a = new QAction( tr ("Beam Entry" ), Resource::loadPixmap( "beam" ), QString::null,
178 0, this, 0 ); 166 0, this, 0 );
179 actionBeam = a; 167 actionBeam = a;
180 connect( a, SIGNAL( activated() ), this, SLOT( slotBeam() ) ); 168 connect( a, SIGNAL( activated() ), this, SLOT( slotBeam() ) );
181 a->addTo( edit ); 169 a->addTo( edit );
182 a->addTo( listTools ); 170 a->addTo( listTools );
183 } 171 }
184 172
185 edit->insertSeparator(); 173 edit->insertSeparator();
186 174
187 a = new QAction( tr("Import vCard"), QString::null, 0, 0, 0, TRUE ); 175 a = new QAction( tr("Import vCard"), QString::null, 0, 0, 0, TRUE );
188 actionPersonal = a; 176 actionPersonal = a;
189 connect( a, SIGNAL( activated() ), this, SLOT( importvCard() ) ); 177 connect( a, SIGNAL( activated() ), this, SLOT( importvCard() ) );
190 a->addTo( edit ); 178 a->addTo( edit );
191 179
192 edit->insertSeparator(); 180 edit->insertSeparator();
193 181
194 a = new QAction( tr("My Personal Details"), QString::null, 0, 0, 0, TRUE ); 182 a = new QAction( tr("My Personal Details"), QString::null, 0, 0, 0, TRUE );
195 actionPersonal = a; 183 actionPersonal = a;
196 connect( a, SIGNAL( activated() ), this, SLOT( slotPersonalView() ) ); 184 connect( a, SIGNAL( activated() ), this, SLOT( slotPersonalView() ) );
197 a->addTo( edit ); 185 a->addTo( edit );
198 186
199 187
200 a = new QAction( tr( "Arrange Edit Fields"), QString::null, 0, 0 ); 188 a = new QAction( tr( "Arrange Edit Fields"), QString::null, 0, 0 );
201 connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); 189 connect( a, SIGNAL( activated() ), this, SLOT( slotSettings() ) );
202 a->addTo( edit ); 190 a->addTo( edit );
203 191
204 // Create Views 192 // Create Views
205
206 // This is safe to call without checking to see if it exists...
207 // not to mention it also does the necessary stuff for the
208 // journaling...
209 QString str = addressbookXMLFilename();
210 if ( str.isNull() ) {
211 QMessageBox::warning(
212 this,
213 tr("Out of Space"),
214 tr("There is not enough space to create\n"
215 "neccessary startup files.\n"
216 "\nFree up some space before\nentering data!")
217 );
218 }
219
220 listContainer = new QWidget( this ); 193 listContainer = new QWidget( this );
221 194
222 QVBoxLayout *vb = new QVBoxLayout( listContainer ); 195 QVBoxLayout *vb = new QVBoxLayout( listContainer );
223 196
224 abList = new AbTable( &orderedFields, listContainer, "table" ); 197 abList = new AbTable( &orderedFields, listContainer, "table" );
225 vb->addWidget(abList); 198 vb->addWidget(abList);
226 // abList->setHScrollBarMode( QScrollView::AlwaysOff ); 199 // abList->setHScrollBarMode( QScrollView::AlwaysOff );
227 connect( abList, SIGNAL( empty( bool ) ), this, SLOT( listIsEmpty( bool ) ) ); 200 connect( abList, SIGNAL( empty( bool ) ), this, SLOT( listIsEmpty( bool ) ) );
228 connect( abList, SIGNAL( details() ), this, SLOT( slotListView() ) ); 201 connect( abList, SIGNAL( details() ), this, SLOT( slotListView() ) );
229 connect( abList, SIGNAL(currentChanged(int,int)), this, SLOT(slotUpdateToolbar()) ); 202 connect( abList, SIGNAL(currentChanged(int,int)), this, SLOT(slotUpdateToolbar()) );
230 203
231 mView = 0; 204 mView = 0;
232 205
233 abList->load( addressbookXMLFilename() ); 206 abList->load();
234 if ( QFile::exists(addressbookOldXMLFilename()) ) {
235 abList->load( addressbookOldXMLFilename() );
236 QFile::remove(addressbookOldXMLFilename());
237 }
238 207
239 pLabel = new LetterPicker( listContainer ); 208 pLabel = new LetterPicker( listContainer );
240 connect(pLabel, SIGNAL(letterClicked(char)), this, SLOT(slotSetLetter(char))); 209 connect(pLabel, SIGNAL(letterClicked(char)), this, SLOT(slotSetLetter(char)));
241 vb->addWidget(pLabel); 210 vb->addWidget(pLabel);
242 catMenu = new QPopupMenu( this ); 211 catMenu = new QPopupMenu( this );
243 catMenu->setCheckable( TRUE ); 212 catMenu->setCheckable( TRUE );
244 connect( catMenu, SIGNAL(activated(int)), this, SLOT(slotSetCategory(int)) ); 213 connect( catMenu, SIGNAL(activated(int)), this, SLOT(slotSetCategory(int)) );
245 populateCategories(); 214 populateCategories();
246 215
247 mbList->insertItem( tr("View"), catMenu ); 216 mbList->insertItem( tr("View"), catMenu );
248 // setCentralWidget( listContainer ); 217 // setCentralWidget( listContainer );
249 218
250 fontMenu = new QPopupMenu(this); 219 fontMenu = new QPopupMenu(this);
251 fontMenu->setCheckable( true ); 220 fontMenu->setCheckable( true );
252 connect( fontMenu, SIGNAL(activated(int)), this, SLOT(slotSetFont(int))); 221 connect( fontMenu, SIGNAL(activated(int)), this, SLOT(slotSetFont(int)));
253 222
254 fontMenu->insertItem(tr( "Small" ), 0); 223 fontMenu->insertItem(tr( "Small" ), 0);
255 fontMenu->insertItem(tr( "Normal" ), 1); 224 fontMenu->insertItem(tr( "Normal" ), 1);
256 fontMenu->insertItem(tr( "Large" ), 2); 225 fontMenu->insertItem(tr( "Large" ), 2);
257 226
258 defaultFont = new QFont( abList->font() ); 227 defaultFont = new QFont( abList->font() );
259 228
260 slotSetFont(startFontSize); 229 slotSetFont(startFontSize);
261 230
262 mbList->insertItem( tr("Font"), fontMenu); 231 mbList->insertItem( tr("Font"), fontMenu);
263 setCentralWidget(listContainer); 232 setCentralWidget(listContainer);
264 233
265 // qDebug("adressbook contrsuction: t=%d", t.elapsed() ); 234 // qDebug("adressbook contrsuction: t=%d", t.elapsed() );
266 235
267 abList->setCurrentCell( 0, 0 ); 236 abList->setCurrentCell( 0, 0 );
268 237
269 isLoading = false; 238 isLoading = false;
270} 239}
271 240
272 241
273void AddressbookWindow::slotSetFont( int size ) { 242void AddressbookWindow::slotSetFont( int size ) {
274 243
275 if (size > 2 || size < 0) 244 if (size > 2 || size < 0)
276 size = 1; 245 size = 1;
277 246
278 startFontSize = size; 247 startFontSize = size;
279 248
280 QFont *currentFont; 249 QFont *currentFont;
281 250
282 switch (size) { 251 switch (size) {
283 case 0: 252 case 0:
284 fontMenu->setItemChecked(0, true); 253 fontMenu->setItemChecked(0, true);
285 fontMenu->setItemChecked(1, false); 254 fontMenu->setItemChecked(1, false);
286 fontMenu->setItemChecked(2, false); 255 fontMenu->setItemChecked(2, false);
287 abList->setFont( QFont( defaultFont->family(), defaultFont->pointSize() - 2 ) ); 256 abList->setFont( QFont( defaultFont->family(), defaultFont->pointSize() - 2 ) );
288 currentFont = new QFont (abList->font()); 257 currentFont = new QFont (abList->font());
289 // abList->resizeRows(currentFont->pixelSize() + 7); 258 // abList->resizeRows(currentFont->pixelSize() + 7);
290 abList->resizeRows(); 259 abList->resizeRows();
291 break; 260 break;
292 case 1: 261 case 1:
293 fontMenu->setItemChecked(0, false); 262 fontMenu->setItemChecked(0, false);
294 fontMenu->setItemChecked(1, true); 263 fontMenu->setItemChecked(1, true);
295 fontMenu->setItemChecked(2, false); 264 fontMenu->setItemChecked(2, false);
296 abList->setFont( *defaultFont ); 265 abList->setFont( *defaultFont );
297 currentFont = new QFont (abList->font()); 266 currentFont = new QFont (abList->font());
298 // abList->resizeRows(currentFont->pixelSize() + 7); 267 // abList->resizeRows(currentFont->pixelSize() + 7);
299 abList->resizeRows(); 268 abList->resizeRows();
300 break; 269 break;
301 case 2: 270 case 2:
302 fontMenu->setItemChecked(0, false); 271 fontMenu->setItemChecked(0, false);
303 fontMenu->setItemChecked(1, false); 272 fontMenu->setItemChecked(1, false);
304 fontMenu->setItemChecked(2, true); 273 fontMenu->setItemChecked(2, true);
305 abList->setFont( QFont( defaultFont->family(), defaultFont->pointSize() + 2 ) ); 274 abList->setFont( QFont( defaultFont->family(), defaultFont->pointSize() + 2 ) );
306 currentFont = new QFont (abList->font()); 275 currentFont = new QFont (abList->font());
307 //abList->resizeRows(currentFont->pixelSize() + 7); 276 //abList->resizeRows(currentFont->pixelSize() + 7);
308 abList->resizeRows(); 277 abList->resizeRows();
309 break; 278 break;
310 } 279 }
311} 280}
312 281
313 282
314 283
315void AddressbookWindow::importvCard() { 284void AddressbookWindow::importvCard() {
316 QString str = OFileDialog::getOpenFileName( 1,"/");//,"", "*", this ); 285 QString str = OFileDialog::getOpenFileName( 1,"/");//,"", "*", this );
317 if(!str.isEmpty() ) 286 if(!str.isEmpty() )
318 setDocument((const QString&) str ); 287 setDocument((const QString&) str );
319 288
320} 289}
321 290
322void AddressbookWindow::setDocument( const QString &filename ) 291void AddressbookWindow::setDocument( const QString &filename )
323{ 292{
324 if ( filename.find(".vcf") != int(filename.length()) - 4 ) 293 if ( filename.find(".vcf") != int(filename.length()) - 4 )
325 return; 294 return;
326 295
327 QValueList<OContact> cl = OContact::readVCard( filename ); 296 QValueList<OContact> cl = OContact::readVCard( filename );
328 for( QValueList<OContact>::Iterator it = cl.begin(); it != cl.end(); ++it ) { 297 for( QValueList<OContact>::Iterator it = cl.begin(); it != cl.end(); ++it ) {
329 // QString msg = tr("You received a vCard for\n%1.\nDo You want to add it to your\naddressbook?") 298 // QString msg = tr("You received a vCard for\n%1.\nDo You want to add it to your\naddressbook?")
330 // .arg( (*it).fullName() ); 299 // .arg( (*it).fullName() );
331 // if ( QMessageBox::information( this, tr("received contact"), msg, QMessageBox::Ok, QMessageBox::Cancel ) == 300 // if ( QMessageBox::information( this, tr("received contact"), msg, QMessageBox::Ok, QMessageBox::Cancel ) ==
332 // QMessageBox::Ok ) { 301 // QMessageBox::Ok ) {
333 abList->addEntry( *it ); 302 abList->addEntry( *it );
@@ -616,265 +585,250 @@ void AddressbookWindow::editPersonal()
616 // fix the foxus... 585 // fix the foxus...
617 abEditor->setNameFocus(); 586 abEditor->setNameFocus();
618 if ( abEditor->exec() ) { 587 if ( abEditor->exec() ) {
619 setFocus(); 588 setFocus();
620 OContact new_personal = abEditor->entry(); 589 OContact new_personal = abEditor->entry();
621 QString fname = addressbookPersonalVCardName(); 590 QString fname = addressbookPersonalVCardName();
622 OContact::writeVCard( fname, new_personal ); 591 OContact::writeVCard( fname, new_personal );
623 abView()->init(new_personal); 592 abView()->init(new_personal);
624 abView()->sync(); 593 abView()->sync();
625 } 594 }
626 abEditor->setCaption( tr("Edit Address") ); 595 abEditor->setCaption( tr("Edit Address") );
627} 596}
628 597
629void AddressbookWindow::slotPersonalView() 598void AddressbookWindow::slotPersonalView()
630{ 599{
631 if (!actionPersonal->isOn()) { 600 if (!actionPersonal->isOn()) {
632 // we just turned it off 601 // we just turned it off
633 setCaption( tr("Contacts") ); 602 setCaption( tr("Contacts") );
634 actionNew->setEnabled(TRUE); 603 actionNew->setEnabled(TRUE);
635 actionTrash->setEnabled(TRUE); 604 actionTrash->setEnabled(TRUE);
636#ifndef MAKE_FOR_SHARP_ROM 605#ifndef MAKE_FOR_SHARP_ROM
637 actionFind->setEnabled(TRUE); 606 actionFind->setEnabled(TRUE);
638#endif 607#endif
639 slotUpdateToolbar(); // maybe some of the above could be moved there 608 slotUpdateToolbar(); // maybe some of the above could be moved there
640 showList(); 609 showList();
641 return; 610 return;
642 } 611 }
643 612
644 // XXX need to disable some QActions. 613 // XXX need to disable some QActions.
645 actionNew->setEnabled(FALSE); 614 actionNew->setEnabled(FALSE);
646 actionTrash->setEnabled(FALSE); 615 actionTrash->setEnabled(FALSE);
647#ifndef MAKE_FOR_SHARP_ROM 616#ifndef MAKE_FOR_SHARP_ROM
648 actionFind->setEnabled(FALSE); 617 actionFind->setEnabled(FALSE);
649#endif 618#endif
650 actionMail->setEnabled(FALSE); 619 actionMail->setEnabled(FALSE);
651 620
652 setCaption( tr("Contacts - My Personal Details") ); 621 setCaption( tr("Contacts - My Personal Details") );
653 QString filename = addressbookPersonalVCardName(); 622 QString filename = addressbookPersonalVCardName();
654 OContact me; 623 OContact me;
655 if (QFile::exists(filename)) 624 if (QFile::exists(filename))
656 me = OContact::readVCard( filename )[0]; 625 me = OContact::readVCard( filename )[0];
657 626
658 abView()->init( me ); 627 abView()->init( me );
659 abView()->sync(); 628 abView()->sync();
660 listContainer->hide(); 629 listContainer->hide();
661 setCentralWidget( abView() ); 630 setCentralWidget( abView() );
662 mView->show(); 631 mView->show();
663 mView->setFocus(); 632 mView->setFocus();
664} 633}
665 634
666void AddressbookWindow::editEntry( EntryMode entryMode ) 635void AddressbookWindow::editEntry( EntryMode entryMode )
667{ 636{
668 OContact entry; 637 OContact entry;
669 if ( bAbEditFirstTime ) { 638 if ( bAbEditFirstTime ) {
670 abEditor = new ContactEditor( entry, &orderedFields, &slOrderedFields, 639 abEditor = new ContactEditor( entry, &orderedFields, &slOrderedFields,
671 this, "editor" ); 640 this, "editor" );
672 bAbEditFirstTime = FALSE; 641 bAbEditFirstTime = FALSE;
673 if ( entryMode == EditEntry ) 642 if ( entryMode == EditEntry )
674 abEditor->setEntry( abList->currentEntry() ); 643 abEditor->setEntry( abList->currentEntry() );
675 } 644 }
676 // other things may chane the caption. 645 // other things may chane the caption.
677 abEditor->setCaption( tr("Edit Address") ); 646 abEditor->setCaption( tr("Edit Address") );
678 647
679#if defined(Q_WS_QWS) || defined(_WS_QWS_) 648#if defined(Q_WS_QWS) || defined(_WS_QWS_)
680 abEditor->showMaximized(); 649 abEditor->showMaximized();
681#endif 650#endif
682 // fix the foxus... 651 // fix the foxus...
683 abEditor->setNameFocus(); 652 abEditor->setNameFocus();
684 if ( abEditor->exec() ) { 653 if ( abEditor->exec() ) {
685 setFocus(); 654 setFocus();
686 if ( entryMode == NewEntry ) { 655 if ( entryMode == NewEntry ) {
687 OContact insertEntry = abEditor->entry(); 656 OContact insertEntry = abEditor->entry();
688 insertEntry.assignUid(); 657 insertEntry.assignUid();
689 abList->addEntry( insertEntry ); 658 abList->addEntry( insertEntry );
690 } else { 659 } else {
691 OContact replaceEntry = abEditor->entry(); 660 OContact replaceEntry = abEditor->entry();
692 if ( !replaceEntry.isValidUid() ) 661 if ( !replaceEntry.isValidUid() )
693 replaceEntry.assignUid(); 662 replaceEntry.assignUid();
694 abList->replaceCurrentEntry( replaceEntry ); 663 abList->replaceCurrentEntry( replaceEntry );
695 } 664 }
696 } 665 }
697 populateCategories(); 666 populateCategories();
698 showList(); 667 showList();
699} 668}
700 669
701void AddressbookWindow::listIsEmpty( bool empty ) 670void AddressbookWindow::listIsEmpty( bool empty )
702{ 671{
703 if ( !empty ) { 672 if ( !empty ) {
704 deleteButton->setEnabled( TRUE ); 673 deleteButton->setEnabled( TRUE );
705 } 674 }
706} 675}
707 676
708void AddressbookWindow::reload() 677void AddressbookWindow::reload()
709{ 678{
710 syncing = FALSE; 679 syncing = FALSE;
711 abList->clear(); 680 abList->clear();
712 abList->load( addressbookXMLFilename() ); 681 abList->reload();
713} 682}
714 683
715void AddressbookWindow::flush() 684void AddressbookWindow::flush()
716{ 685{
717 syncing = TRUE; 686 syncing = TRUE;
718 abList->save( addressbookXMLFilename() ); 687 abList->save();
719} 688}
720 689
721 690
722void AddressbookWindow::closeEvent( QCloseEvent *e ) 691void AddressbookWindow::closeEvent( QCloseEvent *e )
723{ 692{
724 if ( centralWidget() == mView ) { 693 if ( centralWidget() == mView ) {
725 if (actionPersonal->isOn()) { 694 if (actionPersonal->isOn()) {
726 // pretend we clicked it off 695 // pretend we clicked it off
727 actionPersonal->setOn(FALSE); 696 actionPersonal->setOn(FALSE);
728 slotPersonalView(); 697 slotPersonalView();
729 } else { 698 } else {
730 showList(); 699 showList();
731 } 700 }
732 e->ignore(); 701 e->ignore();
733 return; 702 return;
734 } 703 }
735 704
736 if(syncing) { 705 if(syncing) {
737 /* shouldn't we save, I hear you say? well its already been set 706 /* shouldn't we save, I hear you say? well its already been set
738 so that an edit can not occur during a sync, and we flushed 707 so that an edit can not occur during a sync, and we flushed
739 at the start of the sync, so there is no need to save 708 at the start of the sync, so there is no need to save
740 Saving however itself would cause problems. */ 709 Saving however itself would cause problems. */
741 e->accept(); 710 e->accept();
742 return; 711 return;
743 } 712 }
744 //################## shouldn't always save 713 //################## shouldn't always save
745 // True, but the database handles this automatically ! (se) 714 // True, but the database handles this automatically ! (se)
746 if ( save() ) 715 if ( save() )
747 e->accept(); 716 e->accept();
748 else 717 else
749 e->ignore(); 718 e->ignore();
750} 719}
751 720
752/* 721/*
753 Returns TRUE if it is OK to exit 722 Returns TRUE if it is OK to exit
754*/ 723*/
755 724
756bool AddressbookWindow::save() 725bool AddressbookWindow::save()
757{ 726{
758 QString str = addressbookXMLFilename(); 727 if ( !abList->save() ) {
759 if ( str.isNull() ) { 728 if ( QMessageBox::critical( 0, tr( "Out of space" ),
760 if ( QMessageBox::critical( 0, tr("Out of space"),
761 tr("Unable to save information.\n" 729 tr("Unable to save information.\n"
762 "Free up some space\n" 730 "Free up some space\n"
763 "and try again.\n" 731 "and try again.\n"
764 "\nQuit anyway?"), 732 "\nQuit anyway?"),
765 QMessageBox::Yes|QMessageBox::Escape, 733 QMessageBox::Yes|QMessageBox::Escape,
766 QMessageBox::No|QMessageBox::Default ) 734 QMessageBox::No|QMessageBox::Default )
767 != QMessageBox::No ) 735 != QMessageBox::No )
768 return TRUE; 736 return TRUE;
769 else 737 else
770 return FALSE; 738 return FALSE;
771 } else {
772 if ( !abList->save( str ) ) {
773 if ( QMessageBox::critical( 0, tr( "Out of space" ),
774 tr("Unable to save information.\n"
775 "Free up some space\n"
776 "and try again.\n"
777 "\nQuit anyway?"),
778 QMessageBox::Yes|QMessageBox::Escape,
779 QMessageBox::No|QMessageBox::Default )
780 != QMessageBox::No )
781 return TRUE;
782 else
783 return FALSE;
784 }
785 } 739 }
786 return TRUE; 740 return TRUE;
787} 741}
788 742
789void AddressbookWindow::slotSettings() 743void AddressbookWindow::slotSettings()
790{ 744{
791 AddressSettings frmSettings( this ); 745 AddressSettings frmSettings( this );
792#if defined(Q_WS_QWS) || defined(_WS_QWS_) 746#if defined(Q_WS_QWS) || defined(_WS_QWS_)
793 frmSettings.showMaximized(); 747 frmSettings.showMaximized();
794#endif 748#endif
795 749
796 if ( frmSettings.exec() ) { 750 if ( frmSettings.exec() ) {
797 allFields.clear(); 751 allFields.clear();
798 orderedFields.clear(); 752 orderedFields.clear();
799 slOrderedFields.clear(); 753 slOrderedFields.clear();
800 initFields(); 754 initFields();
801 if ( abEditor ) 755 if ( abEditor )
802 abEditor->loadFields(); 756 abEditor->loadFields();
803 abList->refresh(); 757 abList->refresh();
804 } 758 }
805} 759}
806 760
807 761
808void AddressbookWindow::initFields() 762void AddressbookWindow::initFields()
809{ 763{
810 // we really don't need the things from the configuration, anymore 764 // we really don't need the things from the configuration, anymore
811 // only thing that is important are the important categories. So, 765 // only thing that is important are the important categories. So,
812 // Call the contact functions that correspond to these old functions... 766 // Call the contact functions that correspond to these old functions...
813 767
814 QStringList xmlFields = OContact::fields(); 768 QStringList xmlFields = OContact::fields();
815 QStringList visibleFields = OContact::untrfields(); 769 QStringList visibleFields = OContact::untrfields();
816 // QStringList trFields = OContact::trfields(); 770 // QStringList trFields = OContact::trfields();
817 771
818 xmlFields.remove( "Title" ); 772 xmlFields.remove( "Title" );
819 visibleFields.remove( "Name Title" ); 773 visibleFields.remove( "Name Title" );
820 visibleFields.remove( "Notes" ); 774 visibleFields.remove( "Notes" );
821 775
822 int i, version; 776 int i, version;
823 Config cfg( "AddressBook" ); 777 Config cfg( "AddressBook" );
824 QString zn; 778 QString zn;
825 779
826 // ### Write a function to keep this from happening again... 780 // ### Write a function to keep this from happening again...
827 QStringList::ConstIterator it; 781 QStringList::ConstIterator it;
828 for ( i = 0, it = xmlFields.begin(); it != xmlFields.end(); ++it, i++ ) { 782 for ( i = 0, it = xmlFields.begin(); it != xmlFields.end(); ++it, i++ ) {
829 allFields.append( i + 3 ); 783 allFields.append( i + 3 );
830 } 784 }
831 785
832 cfg.setGroup( "Version" ); 786 cfg.setGroup( "Version" );
833 version = cfg.readNumEntry( "version" ); 787 version = cfg.readNumEntry( "version" );
834 i = 0; 788 i = 0;
835 startFontSize = 1; 789 startFontSize = 1;
836 790
837 if ( version >= ADDRESSVERSION ) { 791 if ( version >= ADDRESSVERSION ) {
838 792
839 cfg.setGroup( "ImportantCategory" ); 793 cfg.setGroup( "ImportantCategory" );
840 794
841 zn = cfg.readEntry( "Category" + QString::number(i), QString::null ); 795 zn = cfg.readEntry( "Category" + QString::number(i), QString::null );
842 while ( !zn.isNull() ) { 796 while ( !zn.isNull() ) {
843 if ( zn.contains( "Work" ) || zn.contains( "Mb" ) ) { 797 if ( zn.contains( "Work" ) || zn.contains( "Mb" ) ) {
844 slOrderedFields.clear(); 798 slOrderedFields.clear();
845 break; 799 break;
846 } 800 }
847 slOrderedFields.append( zn ); 801 slOrderedFields.append( zn );
848 zn = cfg.readEntry( "Category" + QString::number(++i), QString::null ); 802 zn = cfg.readEntry( "Category" + QString::number(++i), QString::null );
849 } 803 }
850 cfg.setGroup( "Font" ); 804 cfg.setGroup( "Font" );
851 startFontSize = cfg.readNumEntry( "fontSize", 1 ); 805 startFontSize = cfg.readNumEntry( "fontSize", 1 );
852 806
853 807
854 } else { 808 } else {
855 QString str; 809 QString str;
856 str = getenv("HOME"); 810 str = getenv("HOME");
857 str += "/Settings/AddressBook.conf"; 811 str += "/Settings/AddressBook.conf";
858 QFile::remove( str ); 812 QFile::remove( str );
859 } 813 }
860 814
861 if ( slOrderedFields.count() > 0 ) { 815 if ( slOrderedFields.count() > 0 ) {
862 for( QStringList::ConstIterator it = slOrderedFields.begin(); 816 for( QStringList::ConstIterator it = slOrderedFields.begin();
863 it != slOrderedFields.end(); ++it ) { 817 it != slOrderedFields.end(); ++it ) {
864 QValueList<int>::ConstIterator itVl; 818 QValueList<int>::ConstIterator itVl;
865 QStringList::ConstIterator itVis; 819 QStringList::ConstIterator itVis;
866 itVl = allFields.begin(); 820 itVl = allFields.begin();
867 for ( itVis = visibleFields.begin(); 821 for ( itVis = visibleFields.begin();
868 itVis != visibleFields.end() && itVl != allFields.end(); 822 itVis != visibleFields.end() && itVl != allFields.end();
869 ++itVis, ++itVl ) { 823 ++itVis, ++itVl ) {
870 if ( *it == *itVis && itVl != allFields.end() ) { 824 if ( *it == *itVis && itVl != allFields.end() ) {
871 orderedFields.append( *itVl ); 825 orderedFields.append( *itVl );
872 } 826 }
873 } 827 }
874 } 828 }
875 } else { 829 } else {
876 QValueList<int>::ConstIterator it; 830 QValueList<int>::ConstIterator it;
877 for ( it = allFields.begin(); it != allFields.end(); ++it ) 831 for ( it = allFields.begin(); it != allFields.end(); ++it )
878 orderedFields.append( *it ); 832 orderedFields.append( *it );
879 833
880 slOrderedFields = visibleFields; 834 slOrderedFields = visibleFields;