summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/pim/addressbook/TODO4
-rw-r--r--core/pim/addressbook/abtable.cpp18
-rw-r--r--core/pim/addressbook/abtable.h2
-rw-r--r--core/pim/addressbook/addressbook.cpp75
-rw-r--r--core/pim/addressbook/addressbook.h6
-rw-r--r--core/pim/addressbook/addressbook.pro9
-rw-r--r--core/pim/addressbook/configdlg.cpp45
-rw-r--r--core/pim/addressbook/configdlg.h25
-rw-r--r--core/pim/addressbook/configdlg_base.ui232
-rw-r--r--core/pim/addressbook/ofloatbar.h2
10 files changed, 381 insertions, 37 deletions
diff --git a/core/pim/addressbook/TODO b/core/pim/addressbook/TODO
index d8720b3..0accd87 100644
--- a/core/pim/addressbook/TODO
+++ b/core/pim/addressbook/TODO
@@ -15,15 +15,17 @@ Important:
15- Mail-Icon is missing 15- Mail-Icon is missing
16 16
17Less important: 17Less important:
18 18
19- Find widget should be replaced by something like 19- Find widget should be replaced by something like
20 qpdf has. 20 qpdf has.
21- The picker (alphabetical sort widget) should be 21- The picker (alphabetical sort widget) should be
22 placed verticaly or horizontally (configurable) 22 placed verticaly or horizontally (configurable)
23 23- Use advanced database functions in abtable to decrease
24 memory footprint and to make everything more easy !
25 (abtable should store Iterator for selected Category)
24 26
25Should be Fixed (not absolute sure, need validation): 27Should be Fixed (not absolute sure, need validation):
26- "Nonenglish" translation bug has to be fixed. 28- "Nonenglish" translation bug has to be fixed.
27 29
28Fixed: 30Fixed:
29- Syncing: abtable not reloaded after sync. 31- Syncing: abtable not reloaded after sync.
diff --git a/core/pim/addressbook/abtable.cpp b/core/pim/addressbook/abtable.cpp
index 9297d6a..97f4a8f 100644
--- a/core/pim/addressbook/abtable.cpp
+++ b/core/pim/addressbook/abtable.cpp
@@ -123,17 +123,17 @@ AbTable::AbTable( const QValueList<int> *order, QWidget *parent, const char *nam
123 // #ifdef QT_QTABLE_NOHEADER_CONSTRUCTOR 123 // #ifdef QT_QTABLE_NOHEADER_CONSTRUCTOR
124 // : QTable( 0, 0, parent, name, TRUE ), 124 // : QTable( 0, 0, parent, name, TRUE ),
125 // #else 125 // #else
126 : QTable( parent, name ), 126 : QTable( parent, name ),
127 // #endif 127 // #endif
128 lastSortCol( -1 ), 128 lastSortCol( -1 ),
129 asc( TRUE ), 129 asc( TRUE ),
130 intFields( order ), 130 intFields( order ),
131 currFindRow( -2 ), 131 currFindRow( -1 ),
132 mCat( 0 ), 132 mCat( 0 ),
133 m_contactdb ("addressbook", 0l, 0l, false) // Handle syncing myself.. ! 133 m_contactdb ("addressbook", 0l, 0l, false) // Handle syncing myself.. !
134{ 134{
135 mCat.load( categoryFileName() ); 135 mCat.load( categoryFileName() );
136 setSelectionMode( NoSelection ); 136 setSelectionMode( NoSelection );
137 init(); 137 init();
138 setSorting( TRUE ); 138 setSorting( TRUE );
139 connect( this, SIGNAL(clicked(int,int,int,const QPoint &)), 139 connect( this, SIGNAL(clicked(int,int,int,const QPoint &)),
@@ -633,45 +633,47 @@ void QTable::paintEmptyArea( QPainter *p, int cx, int cy, int cw, int ch )
633// { 633// {
634// return QMIN( pos/18, numRows()-1 ); 634// return QMIN( pos/18, numRows()-1 );
635// } 635// }
636 636
637void AbTable::slotDoFind( const QString &findString, bool caseSensitive, 637void AbTable::slotDoFind( const QString &findString, bool caseSensitive,
638 bool backwards, QString cat /* int category */ ) 638 bool backwards, QString cat /* int category */ )
639{ 639{
640 int category = 0; 640 int category = 0;
641
642 // Use the current Category if nothing else selected
641 if ( cat.isEmpty() ) 643 if ( cat.isEmpty() )
642 category = -2; // mCat.id("Contacts", "All"); 644 category = mCat.id( "Contacts", showCat );
643 else 645 else{
644 category = mCat.id("Contacts", cat ); 646 category = mCat.id("Contacts", cat );
647 }
645 648
646 qWarning ("Found in Category %d", category); 649 qWarning ("Found in Category %d", category);
647 650
648 if ( currFindRow < -1 ) 651 if ( currFindRow < -1 )
649 currFindRow = currentRow() - 1; 652 currFindRow = - 1;
653
650 clearSelection( TRUE ); 654 clearSelection( TRUE );
651 int rows, row; 655 int rows, row;
652 AbTableItem *ati; 656 AbTableItem *ati;
653 QRegExp r( findString ); 657 QRegExp r( findString );
654 r.setCaseSensitive( caseSensitive ); 658 r.setCaseSensitive( caseSensitive );
655 rows = numRows(); 659 rows = numRows();
656 static bool wrapAround = true; 660 static bool wrapAround = true;
657 661
658 if ( !backwards ) { 662 if ( !backwards ) {
659 for ( row = currFindRow + 1; row < rows; row++ ) { 663 for ( row = currFindRow + 1; row < rows; row++ ) {
660 ati = static_cast<AbTableItem*>( item(row, 0) ); 664 ati = static_cast<AbTableItem*>( item(row, 0) );
661 if ( contactCompare( contactList[ati], r, category ) ) 665 if ( contactCompare( contactList[ati], r, category ) )
662 //if ( contactCompare( contactList[row], r, category ) )
663 break; 666 break;
664 } 667 }
665 } else { 668 } else {
666 for ( row = currFindRow - 1; row > -1; row-- ) { 669 for ( row = currFindRow - 1; row > -1; row-- ) {
667 ati = static_cast<AbTableItem*>( item(row, 0) ); 670 ati = static_cast<AbTableItem*>( item(row, 0) );
668 if ( contactCompare( contactList[ati], r, category ) ) 671 if ( contactCompare( contactList[ati], r, category ) )
669 //if ( contactCompare( contactList[row], r, category ) )
670 break; 672 break;
671 } 673 }
672 } 674 }
673 if ( row >= rows || row < 0 ) { 675 if ( row >= rows || row < 0 ) {
674 if ( row < 0 ) 676 if ( row < 0 )
675 currFindRow = rows; 677 currFindRow = rows;
676 else 678 else
677 currFindRow = -1; 679 currFindRow = -1;
@@ -683,29 +685,29 @@ void AbTable::slotDoFind( const QString &findString, bool caseSensitive,
683 685
684 wrapAround = !wrapAround; 686 wrapAround = !wrapAround;
685 } else { 687 } else {
686 currFindRow = row; 688 currFindRow = row;
687 QTableSelection foundSelection; 689 QTableSelection foundSelection;
688 foundSelection.init( currFindRow, 0 ); 690 foundSelection.init( currFindRow, 0 );
689 foundSelection.expandTo( currFindRow, numCols() - 1 ); 691 foundSelection.expandTo( currFindRow, numCols() - 1 );
690 addSelection( foundSelection ); 692 addSelection( foundSelection );
691 setCurrentCell( currFindRow, numCols() - 1 ); 693 setCurrentCell( currFindRow, 0 /* numCols() - 1 */ );
692 wrapAround = true; 694 wrapAround = true;
693 } 695 }
694} 696}
695 697
696static bool contactCompare( const OContact &cnt, const QRegExp &r, int category ) 698static bool contactCompare( const OContact &cnt, const QRegExp &r, int category )
697{ 699{
698 bool returnMe; 700 bool returnMe;
699 QArray<int> cats; 701 QArray<int> cats;
700 cats = cnt.categories(); 702 cats = cnt.categories();
701 703
702 returnMe = false; 704 returnMe = false;
703 if ( (category == -1 && cats.count() == 0) || category == -2 ) 705 if ( (cats.count() == 0) || (category == 0) )
704 returnMe = cnt.match( r ); 706 returnMe = cnt.match( r );
705 else { 707 else {
706 int i; 708 int i;
707 for ( i = 0; i < int(cats.count()); i++ ) { 709 for ( i = 0; i < int(cats.count()); i++ ) {
708 if ( cats[i] == category ) { 710 if ( cats[i] == category ) {
709 returnMe = cnt.match( r ); 711 returnMe = cnt.match( r );
710 break; 712 break;
711 } 713 }
diff --git a/core/pim/addressbook/abtable.h b/core/pim/addressbook/abtable.h
index a603e17..1039e66 100644
--- a/core/pim/addressbook/abtable.h
+++ b/core/pim/addressbook/abtable.h
@@ -69,17 +69,17 @@ public:
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 = -1; }
78 void loadFields(); 78 void loadFields();
79 void refresh(); 79 void refresh();
80 bool save(); 80 bool save();
81 void load(); 81 void load();
82 void reload(); 82 void reload();
83 83
84 // addresspicker mode 84 // addresspicker mode
85 void setChoiceNames( const QStringList& list); 85 void setChoiceNames( const QStringList& list);
diff --git a/core/pim/addressbook/addressbook.cpp b/core/pim/addressbook/addressbook.cpp
index 8335d8b..84e66fb 100644
--- a/core/pim/addressbook/addressbook.cpp
+++ b/core/pim/addressbook/addressbook.cpp
@@ -28,20 +28,16 @@
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
37#include <qpe/finddialog.h>
38#endif
39
40#include <qpe/global.h> 36#include <qpe/global.h>
41#include <qpe/resource.h> 37#include <qpe/resource.h>
42#include <qpe/ir.h> 38#include <qpe/ir.h>
43#include <qpe/qpemessagebox.h> 39#include <qpe/qpemessagebox.h>
44#include <qpe/qcopenvelope_qws.h> 40#include <qpe/qcopenvelope_qws.h>
45 41
46#include <qaction.h> 42#include <qaction.h>
47#include <qdialog.h> 43#include <qdialog.h>
@@ -62,29 +58,33 @@
62#include <sys/stat.h> 58#include <sys/stat.h>
63#include <sys/types.h> 59#include <sys/types.h>
64#include <fcntl.h> 60#include <fcntl.h>
65#include <unistd.h> 61#include <unistd.h>
66 62
67#include <qdatetime.h> 63#include <qdatetime.h>
68 64
69#include "picker.h" 65#include "picker.h"
66#include "configdlg.h"
70 67
71static QString addressbookPersonalVCardName() 68static QString addressbookPersonalVCardName()
72{ 69{
73 QString filename = Global::applicationFileName("addressbook", 70 QString filename = Global::applicationFileName("addressbook",
74 "businesscard.vcf"); 71 "businesscard.vcf");
75 return filename; 72 return filename;
76} 73}
77 74
78 75
79AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name, 76AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name,
80 WFlags f ) 77 WFlags f )
81 : QMainWindow( parent, name, f ), 78 : QMainWindow( parent, name, f ),
82 abEditor(0), 79 abEditor(0),
80 useRegExp(false),
81 DoSignalWrapAround(false),
82 caseSensitive(false),
83 bAbEditFirstTime(TRUE), 83 bAbEditFirstTime(TRUE),
84 syncing(FALSE) 84 syncing(FALSE)
85{ 85{
86 isLoading = true; 86 isLoading = true;
87 87
88 initFields(); 88 initFields();
89 89
90 setCaption( tr("Contacts") ); 90 setCaption( tr("Contacts") );
@@ -203,17 +203,21 @@ AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name,
203 203
204#ifdef __DEBUG_RELEASE 204#ifdef __DEBUG_RELEASE
205 // Remove this function for public Release ! This is only 205 // Remove this function for public Release ! This is only
206 // for debug purposes .. 206 // for debug purposes ..
207 a = new QAction( tr( "Save all Data"), QString::null, 0, 0 ); 207 a = new QAction( tr( "Save all Data"), QString::null, 0, 0 );
208 connect( a, SIGNAL( activated() ), this , SLOT( slotSave() ) ); 208 connect( a, SIGNAL( activated() ), this , SLOT( slotSave() ) );
209 a->addTo( edit ); 209 a->addTo( edit );
210#endif 210#endif
211 211 a = new QAction( tr( "Config" ), Resource::loadPixmap( "today/config" ), QString::null,
212 0, this, 0 );
213 connect( a, SIGNAL( activated() ), this, SLOT( slotConfig() ) );
214 a->addTo( edit );
215
212 // Create Views 216 // Create Views
213 listContainer = new QWidget( this ); 217 listContainer = new QWidget( this );
214 218
215 QVBoxLayout *vb = new QVBoxLayout( listContainer ); 219 QVBoxLayout *vb = new QVBoxLayout( listContainer );
216 220
217 abList = new AbTable( &orderedFields, listContainer, "table" ); 221 abList = new AbTable( &orderedFields, listContainer, "table" );
218 vb->addWidget(abList); 222 vb->addWidget(abList);
219 // abList->setHScrollBarMode( QScrollView::AlwaysOff ); 223 // abList->setHScrollBarMode( QScrollView::AlwaysOff );
@@ -249,21 +253,46 @@ AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name,
249 slotSetFont(startFontSize); 253 slotSetFont(startFontSize);
250 254
251 mbList->insertItem( tr("Font"), fontMenu); 255 mbList->insertItem( tr("Font"), fontMenu);
252 setCentralWidget(listContainer); 256 setCentralWidget(listContainer);
253 257
254 // qDebug("adressbook contrsuction: t=%d", t.elapsed() ); 258 // qDebug("adressbook contrsuction: t=%d", t.elapsed() );
255 259
256 abList->setCurrentCell( 0, 0 ); 260 abList->setCurrentCell( 0, 0 );
261
262 // Read Config settings
263 Config cfg("AddressBook");
264 cfg.setGroup("Search");
265 useRegExp = cfg.readBoolEntry( "useRegExp" );
266 caseSensitive = cfg.readBoolEntry( "caseSensitive" );
267 DoSignalWrapAround = cfg.readBoolEntry( "signalWrapAround" );
257 268
258 isLoading = false; 269 isLoading = false;
259} 270}
260 271
261 272
273void AddressbookWindow::slotConfig()
274{
275 ConfigDlg* dlg = new ConfigDlg( this, "Config" );
276 dlg -> setUseRegExp ( useRegExp );
277 dlg -> setBeCaseSensitive( caseSensitive );
278 dlg -> setSignalWrapAround( DoSignalWrapAround );
279 dlg -> showMaximized();
280 if ( dlg -> exec() ) {
281 qWarning ("Config Dialog accepted !");
282 useRegExp = dlg -> useRegExp();
283 caseSensitive = dlg -> beCaseSensitive();
284 DoSignalWrapAround = dlg -> signalWrapAround();
285 }
286
287 delete dlg;
288}
289
290
262void AddressbookWindow::slotSetFont( int size ) { 291void AddressbookWindow::slotSetFont( int size ) {
263 292
264 if (size > 2 || size < 0) 293 if (size > 2 || size < 0)
265 size = 1; 294 size = 1;
266 295
267 startFontSize = size; 296 startFontSize = size;
268 297
269 QFont *currentFont; 298 QFont *currentFont;
@@ -335,16 +364,21 @@ void AddressbookWindow::resizeEvent( QResizeEvent *e )
335 showView(); 364 showView();
336} 365}
337 366
338AddressbookWindow::~AddressbookWindow() 367AddressbookWindow::~AddressbookWindow()
339{ 368{
340 Config cfg("AddressBook"); 369 Config cfg("AddressBook");
341 cfg.setGroup("Font"); 370 cfg.setGroup("Font");
342 cfg.writeEntry("fontSize", startFontSize); 371 cfg.writeEntry("fontSize", startFontSize);
372
373 cfg.setGroup("Search");
374 cfg.writeEntry("useRegExp", useRegExp);
375 cfg.writeEntry("caseSensitive", caseSensitive);
376 cfg.writeEntry("signalWrapAround", DoSignalWrapAround);
343} 377}
344 378
345void AddressbookWindow::slotUpdateToolbar() 379void AddressbookWindow::slotUpdateToolbar()
346{ 380{
347 OContact ce = abList->currentEntry(); 381 OContact ce = abList->currentEntry();
348 actionMail->setEnabled( !ce.defaultEmail().isEmpty() ); 382 actionMail->setEnabled( !ce.defaultEmail().isEmpty() );
349} 383}
350 384
@@ -889,63 +923,58 @@ AbLabel *AddressbookWindow::abView()
889 connect( mView, SIGNAL( okPressed() ), this, SLOT( slotListView() ) ); 923 connect( mView, SIGNAL( okPressed() ), this, SLOT( slotListView() ) );
890 } 924 }
891 return mView; 925 return mView;
892} 926}
893 927
894void AddressbookWindow::slotFindOpen() 928void AddressbookWindow::slotFindOpen()
895{ 929{
896 searchBar->show(); 930 searchBar->show();
931 searchEdit->setFocus();
897} 932}
898void AddressbookWindow::slotFindClose() 933void AddressbookWindow::slotFindClose()
899{ 934{
900 searchBar->hide(); 935 searchBar->hide();
936 abList->setFocus();
901} 937}
902void AddressbookWindow::slotFindNext() 938void AddressbookWindow::slotFindNext()
903{ 939{
904}
905
906void AddressbookWindow::slotFind()
907{
908 if ( centralWidget() == abView() ) 940 if ( centralWidget() == abView() )
909 showList(); 941 showList();
910 942
911 // FindDialog frmFind( "Contacts", this ); 943 // Maybe we should react on Wraparound and notfound ?
912 // QObject::connect( abList, SIGNAL(signalNotFound()), &frmFind, SLOT(slotNotFound()) ); 944 // QObject::connect( abList, SIGNAL(signalNotFound()), &frmFind, SLOT(slotNotFound()) );
913 // QObject::connect( abList, SIGNAL(signalWrapAround()), &frmFind, SLOT(slotWrapAround()) ); 945 // QObject::connect( abList, SIGNAL(signalWrapAround()), &frmFind, SLOT(slotWrapAround()) );
914 // frmFind.exec();
915 946
916 // QStringList categories = abList->categories();
917 // abList->setShowCategory( book, cat );
918 abList->slotDoFind( searchEdit->text(), false, false); 947 abList->slotDoFind( searchEdit->text(), false, false);
919 948
920 949
921 if ( abList->numSelections() ) 950 if ( abList->numSelections() )
922 abList->clearSelection(); 951 abList->clearSelection();
952
953}
954
955void AddressbookWindow::slotFind()
956{
923 957
924 abList->clearFindRow(); 958 abList->clearFindRow();
959 slotFindNext();
925} 960}
926 961
927void AddressbookWindow::slotSetCategory( int c ) 962void AddressbookWindow::slotSetCategory( int c )
928{ 963{
929 964
930 QString cat, book; 965 QString cat, book;
931 966
932 if ( c <= 0 ) 967 if ( c <= 0 )
933 return; 968 return;
934 969
935 // Checkmark Book Menu Item Selected 970 // Set checkItem for selected one
936 if ( c < 6 ) 971 for ( unsigned int i = 1; i < catMenu->count(); i++ )
937 for ( unsigned int i = 1; i < 6; i++ ) 972 catMenu->setItemChecked( i, c == (int)i );
938 catMenu->setItemChecked( i, c == (int)i );
939
940 // Checkmark Category Menu Item Selected
941 else
942 for ( unsigned int i = 6; i < catMenu->count(); i++ )
943 catMenu->setItemChecked( i, c == (int)i );
944 973
945 for ( unsigned int i = 1; i < catMenu->count(); i++ ) { 974 for ( unsigned int i = 1; i < catMenu->count(); i++ ) {
946 if (catMenu->isItemChecked( i )) { 975 if (catMenu->isItemChecked( i )) {
947 if ( i == 1 ) // default List view 976 if ( i == 1 ) // default List view
948 book = QString::null; 977 book = QString::null;
949 else if ( i == 2 ) 978 else if ( i == 2 )
950 book = "Phone"; 979 book = "Phone";
951 else if ( i == 3 ) 980 else if ( i == 3 )
diff --git a/core/pim/addressbook/addressbook.h b/core/pim/addressbook/addressbook.h
index b7cf355..18b083f 100644
--- a/core/pim/addressbook/addressbook.h
+++ b/core/pim/addressbook/addressbook.h
@@ -84,16 +84,18 @@ private slots:
84 void slotUpdateToolbar(); 84 void slotUpdateToolbar();
85 void slotSetFont(int); 85 void slotSetFont(int);
86 86
87 void slotFindOpen(); 87 void slotFindOpen();
88 void slotFindClose(); 88 void slotFindClose();
89 void slotFind(); 89 void slotFind();
90 void slotFindNext(); 90 void slotFindNext();
91 91
92 void slotConfig();
93
92private: 94private:
93 void initFields(); // inititialize our fields... 95 void initFields(); // inititialize our fields...
94 AbLabel *abView(); 96 AbLabel *abView();
95 void populateCategories(); 97 void populateCategories();
96 98
97 QPopupMenu *catMenu, *fontMenu; 99 QPopupMenu *catMenu, *fontMenu;
98 QPEToolBar *listTools; 100 QPEToolBar *listTools;
99 QToolButton *deleteButton; 101 QToolButton *deleteButton;
@@ -101,18 +103,22 @@ private:
101 QStringList slOrderedFields; 103 QStringList slOrderedFields;
102 enum Panes { paneList=0, paneView, paneEdit }; 104 enum Panes { paneList=0, paneView, paneEdit };
103 ContactEditor *abEditor; 105 ContactEditor *abEditor;
104 AbLabel *mView; 106 AbLabel *mView;
105 LetterPicker *pLabel; 107 LetterPicker *pLabel;
106 AbTable *abList; 108 AbTable *abList;
107 QWidget *listContainer; 109 QWidget *listContainer;
108 110
111 // Searching stuff
109 OFloatBar* searchBar; 112 OFloatBar* searchBar;
110 QLineEdit* searchEdit; 113 QLineEdit* searchEdit;
114 bool useRegExp;
115 bool DoSignalWrapAround;
116 bool caseSensitive;
111 117
112 QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, *actionPersonal, *actionMail; 118 QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, *actionPersonal, *actionMail;
113 119
114 bool bAbEditFirstTime; 120 bool bAbEditFirstTime;
115 int viewMargin; 121 int viewMargin;
116 122
117 bool syncing; 123 bool syncing;
118 QFont *defaultFont; 124 QFont *defaultFont;
diff --git a/core/pim/addressbook/addressbook.pro b/core/pim/addressbook/addressbook.pro
index 05aa5ec..9ed2f68 100644
--- a/core/pim/addressbook/addressbook.pro
+++ b/core/pim/addressbook/addressbook.pro
@@ -2,25 +2,28 @@ TEMPLATE = app
2 CONFIG = qt warn_on release 2 CONFIG = qt warn_on release
3 DESTDIR = $(OPIEDIR)/bin 3 DESTDIR = $(OPIEDIR)/bin
4 HEADERS= addressbook.h \ 4 HEADERS= addressbook.h \
5 contacteditor.h \ 5 contacteditor.h \
6 ablabel.h \ 6 ablabel.h \
7 abtable.h \ 7 abtable.h \
8 addresssettings.h \ 8 addresssettings.h \
9 picker.h \ 9 picker.h \
10 ofloatbar.h 10 ofloatbar.h \
11 configdlg.h
11 SOURCES= main.cpp \ 12 SOURCES= main.cpp \
12 addressbook.cpp \ 13 addressbook.cpp \
13 contacteditor.cpp \ 14 contacteditor.cpp \
14 ablabel.cpp \ 15 ablabel.cpp \
15 abtable.cpp \ 16 abtable.cpp \
16 addresssettings.cpp \ 17 addresssettings.cpp \
17 picker.cpp 18 picker.cpp \
18 INTERFACES= addresssettingsbase.ui 19 configdlg.cpp
20
21 INTERFACES= addresssettingsbase.ui configdlg_base.ui
19 TARGET = addressbook 22 TARGET = addressbook
20INCLUDEPATH += $(OPIEDIR)/include 23INCLUDEPATH += $(OPIEDIR)/include
21 DEPENDPATH+= $(OPIEDIR)/include 24 DEPENDPATH+= $(OPIEDIR)/include
22LIBS += -lqpe -lopie 25LIBS += -lqpe -lopie
23 26
24TRANSLATIONS = ../../../i18n/de/addressbook.ts \ 27TRANSLATIONS = ../../../i18n/de/addressbook.ts \
25 ../../../i18n/en/addressbook.ts \ 28 ../../../i18n/en/addressbook.ts \
26 ../../../i18n/es/addressbook.ts \ 29 ../../../i18n/es/addressbook.ts \
diff --git a/core/pim/addressbook/configdlg.cpp b/core/pim/addressbook/configdlg.cpp
new file mode 100644
index 0000000..b7c3b77
--- a/dev/null
+++ b/core/pim/addressbook/configdlg.cpp
@@ -0,0 +1,45 @@
1#include "configdlg.h"
2#include <qcheckbox.h>
3#include <qradiobutton.h>
4
5ConfigDlg::ConfigDlg( QWidget *parent = 0, const char *name = 0 ):
6 ConfigDlg_Base(parent, name, true )
7{}
8
9
10bool ConfigDlg::useRegExp() const
11{
12 return m_useRegExp->isOn();
13}
14bool ConfigDlg::useWildCards() const
15{
16 return m_useWildCard->isOn();
17}
18bool ConfigDlg::beCaseSensitive() const
19{
20 return m_useCaseSensitive->isChecked();
21}
22bool ConfigDlg::signalWrapAround() const
23{
24 return m_signalWrapAround->isChecked();
25}
26void ConfigDlg::setUseRegExp( bool v )
27{
28 m_useRegExp->setChecked( v );
29}
30void ConfigDlg::setUseWildCards( bool v )
31{
32 m_useWildCard->setChecked( v );
33}
34void ConfigDlg::setBeCaseSensitive( bool v )
35{
36 m_useCaseSensitive->setChecked( v );
37}
38void ConfigDlg::setSignalWrapAround( bool v )
39{
40 m_signalWrapAround->setChecked( v );
41}
42
43
44
45
diff --git a/core/pim/addressbook/configdlg.h b/core/pim/addressbook/configdlg.h
new file mode 100644
index 0000000..8be469b
--- a/dev/null
+++ b/core/pim/addressbook/configdlg.h
@@ -0,0 +1,25 @@
1#ifndef _CONFIGDLG_H_
2#define _CONFIGDLG_H_
3
4#include "configdlg_base.h"
5
6class ConfigDlg: public ConfigDlg_Base
7{
8 Q_OBJECT
9public:
10 ConfigDlg( QWidget *parent = 0, const char *name = 0 );
11
12 // Search Settings
13 bool useRegExp() const;
14 bool useWildCards() const;
15 bool beCaseSensitive() const;
16 bool signalWrapAround() const;
17
18 void setUseRegExp( bool v );
19 void setUseWildCards( bool v );
20 void setBeCaseSensitive( bool v );
21 void setSignalWrapAround( bool v );
22};
23
24
25#endif
diff --git a/core/pim/addressbook/configdlg_base.ui b/core/pim/addressbook/configdlg_base.ui
new file mode 100644
index 0000000..e082702
--- a/dev/null
+++ b/core/pim/addressbook/configdlg_base.ui
@@ -0,0 +1,232 @@
1<!DOCTYPE UI><UI>
2<class>ConfigDlg_Base</class>
3<author>Stefan Eilers</author>
4<widget>
5 <class>QDialog</class>
6 <property stdset="1">
7 <name>name</name>
8 <cstring>Configuration</cstring>
9 </property>
10 <property stdset="1">
11 <name>geometry</name>
12 <rect>
13 <x>0</x>
14 <y>0</y>
15 <width>227</width>
16 <height>287</height>
17 </rect>
18 </property>
19 <property stdset="1">
20 <name>caption</name>
21 <string>MyDialog1</string>
22 </property>
23 <property stdset="1">
24 <name>sizeGripEnabled</name>
25 <bool>true</bool>
26 </property>
27 <vbox>
28 <property stdset="1">
29 <name>margin</name>
30 <number>11</number>
31 </property>
32 <property stdset="1">
33 <name>spacing</name>
34 <number>6</number>
35 </property>
36 <widget>
37 <class>QTabWidget</class>
38 <property stdset="1">
39 <name>name</name>
40 <cstring>configDlg_base</cstring>
41 </property>
42 <property>
43 <name>layoutMargin</name>
44 </property>
45 <widget>
46 <class>QWidget</class>
47 <property stdset="1">
48 <name>name</name>
49 <cstring>Widget5</cstring>
50 </property>
51 <attribute>
52 <name>title</name>
53 <string>Search</string>
54 </attribute>
55 <vbox>
56 <property stdset="1">
57 <name>margin</name>
58 <number>5</number>
59 </property>
60 <property stdset="1">
61 <name>spacing</name>
62 <number>6</number>
63 </property>
64 <widget>
65 <class>QButtonGroup</class>
66 <property stdset="1">
67 <name>name</name>
68 <cstring>ButtonGroup1</cstring>
69 </property>
70 <property stdset="1">
71 <name>title</name>
72 <string>Query Style</string>
73 </property>
74 <vbox>
75 <property stdset="1">
76 <name>margin</name>
77 <number>11</number>
78 </property>
79 <property stdset="1">
80 <name>spacing</name>
81 <number>6</number>
82 </property>
83 <widget>
84 <class>QRadioButton</class>
85 <property stdset="1">
86 <name>name</name>
87 <cstring>m_useRegExp</cstring>
88 </property>
89 <property stdset="1">
90 <name>text</name>
91 <string>Use Regular Expressions</string>
92 </property>
93 </widget>
94 <widget>
95 <class>QRadioButton</class>
96 <property stdset="1">
97 <name>name</name>
98 <cstring>m_useWildCard</cstring>
99 </property>
100 <property stdset="1">
101 <name>text</name>
102 <string>Use Wildcards (*,?)</string>
103 </property>
104 <property stdset="1">
105 <name>checked</name>
106 <bool>true</bool>
107 </property>
108 </widget>
109 </vbox>
110 </widget>
111 <widget>
112 <class>QCheckBox</class>
113 <property stdset="1">
114 <name>name</name>
115 <cstring>m_useCaseSensitive</cstring>
116 </property>
117 <property stdset="1">
118 <name>text</name>
119 <string>Case Sensitive</string>
120 </property>
121 </widget>
122 <widget>
123 <class>QCheckBox</class>
124 <property stdset="1">
125 <name>name</name>
126 <cstring>m_signalWrapAround</cstring>
127 </property>
128 <property stdset="1">
129 <name>text</name>
130 <string>Signal Wrap Around</string>
131 </property>
132 </widget>
133 <spacer>
134 <property>
135 <name>name</name>
136 <cstring>Spacer3</cstring>
137 </property>
138 <property stdset="1">
139 <name>orientation</name>
140 <enum>Vertical</enum>
141 </property>
142 <property stdset="1">
143 <name>sizeType</name>
144 <enum>Expanding</enum>
145 </property>
146 <property>
147 <name>sizeHint</name>
148 <size>
149 <width>20</width>
150 <height>20</height>
151 </size>
152 </property>
153 </spacer>
154 </vbox>
155 </widget>
156 </widget>
157 <widget>
158 <class>QLayoutWidget</class>
159 <property stdset="1">
160 <name>name</name>
161 <cstring>Layout1</cstring>
162 </property>
163 <hbox>
164 <property stdset="1">
165 <name>margin</name>
166 <number>0</number>
167 </property>
168 <property stdset="1">
169 <name>spacing</name>
170 <number>6</number>
171 </property>
172 <widget>
173 <class>QPushButton</class>
174 <property stdset="1">
175 <name>name</name>
176 <cstring>buttonOk</cstring>
177 </property>
178 <property stdset="1">
179 <name>text</name>
180 <string>&amp;OK</string>
181 </property>
182 <property stdset="1">
183 <name>autoDefault</name>
184 <bool>true</bool>
185 </property>
186 <property stdset="1">
187 <name>default</name>
188 <bool>true</bool>
189 </property>
190 </widget>
191 <widget>
192 <class>QPushButton</class>
193 <property stdset="1">
194 <name>name</name>
195 <cstring>buttonCancel</cstring>
196 </property>
197 <property stdset="1">
198 <name>text</name>
199 <string>&amp;Cancel</string>
200 </property>
201 <property stdset="1">
202 <name>autoDefault</name>
203 <bool>true</bool>
204 </property>
205 </widget>
206 </hbox>
207 </widget>
208 </vbox>
209</widget>
210<connections>
211 <connection>
212 <sender>buttonOk</sender>
213 <signal>clicked()</signal>
214 <receiver>Configuration</receiver>
215 <slot>accept()</slot>
216 </connection>
217 <connection>
218 <sender>buttonCancel</sender>
219 <signal>clicked()</signal>
220 <receiver>Configuration</receiver>
221 <slot>reject()</slot>
222 </connection>
223</connections>
224<tabstops>
225 <tabstop>configDlg_base</tabstop>
226 <tabstop>m_useWildCard</tabstop>
227 <tabstop>m_useCaseSensitive</tabstop>
228 <tabstop>m_signalWrapAround</tabstop>
229 <tabstop>buttonOk</tabstop>
230 <tabstop>buttonCancel</tabstop>
231</tabstops>
232</UI>
diff --git a/core/pim/addressbook/ofloatbar.h b/core/pim/addressbook/ofloatbar.h
index 85a0c4f..f9c49d6 100644
--- a/core/pim/addressbook/ofloatbar.h
+++ b/core/pim/addressbook/ofloatbar.h
@@ -2,17 +2,17 @@
2#define __OFLOATBAR_H 2#define __OFLOATBAR_H
3 3
4#include <qtoolbar.h> 4#include <qtoolbar.h>
5#include <qevent.h> 5#include <qevent.h>
6 6
7class OFloatBar : public QToolBar 7class OFloatBar : public QToolBar
8{ 8{
9 Q_OBJECT 9 Q_OBJECT
10 virtual void hideEvent(QHideEvent* e) 10 virtual void hideEvent(QHideEvent* /* e */)
11 { 11 {
12 /*if (e->spontaneous())*/ emit OnHide(); 12 /*if (e->spontaneous())*/ emit OnHide();
13 } 13 }
14 public: 14 public:
15 OFloatBar(char* t, QMainWindow* mw, QMainWindow::ToolBarDock td, bool f) : QToolBar(t, mw, td, f) {} 15 OFloatBar(char* t, QMainWindow* mw, QMainWindow::ToolBarDock td, bool f) : QToolBar(t, mw, td, f) {}
16 signals: 16 signals:
17 void OnHide(); 17 void OnHide();
18}; 18};