author | tux_mike <tux_mike> | 2002-04-17 20:46:18 (UTC) |
---|---|---|
committer | tux_mike <tux_mike> | 2002-04-17 20:46:18 (UTC) |
commit | 7b19e1d98d5acf01102ac057ec077fc036c034c6 (patch) (unidiff) | |
tree | a5ec8752ba8cbf9c5c037f1ec3552be544cc8b3f | |
parent | 106073977316103f057930daf45f3a083114d48d (diff) | |
download | opie-7b19e1d98d5acf01102ac057ec077fc036c034c6.zip opie-7b19e1d98d5acf01102ac057ec077fc036c034c6.tar.gz opie-7b19e1d98d5acf01102ac057ec077fc036c034c6.tar.bz2 |
Added a Letter Picker
-rw-r--r-- | core/pim/addressbook/abtable.cpp | 86 | ||||
-rw-r--r-- | core/pim/addressbook/addressbook.cpp | 27 | ||||
-rw-r--r-- | core/pim/addressbook/addressbook.h | 1 | ||||
-rw-r--r-- | core/pim/addressbook/picker.cpp | 7 |
4 files changed, 98 insertions, 23 deletions
diff --git a/core/pim/addressbook/abtable.cpp b/core/pim/addressbook/abtable.cpp index 759cb48..124ff6c 100644 --- a/core/pim/addressbook/abtable.cpp +++ b/core/pim/addressbook/abtable.cpp | |||
@@ -1000,33 +1000,32 @@ QStringList AbTable::choiceSelection(int /*index*/) const | |||
1000 | } | 1000 | } |
1001 | } | 1001 | } |
1002 | 1002 | ||
1003 | */ | 1003 | */ |
1004 | return r; | 1004 | return r; |
1005 | } | 1005 | } |
1006 | 1006 | ||
1007 | void AbTable::setShowCategory( const QString &c ) | 1007 | void AbTable::setShowCategory( const QString &c ) |
1008 | { | 1008 | { |
1009 | showCat = c; | 1009 | showCat = c; |
1010 | updateVisible(); | 1010 | updateVisible(); |
1011 | } | 1011 | } |
1012 | 1012 | ||
1013 | void AbTable::setShowByLetter( char c ) | 1013 | void AbTable::setShowByLetter( char c ) |
1014 | { | 1014 | { |
1015 | showChar = tolower(c); | 1015 | showChar = tolower(c); |
1016 | qDebug( "AbTable::setShowByLetter %c", showChar); | ||
1017 | updateVisible(); | 1016 | updateVisible(); |
1018 | } | 1017 | } |
1019 | 1018 | ||
1020 | QString AbTable::showCategory() const | 1019 | QString AbTable::showCategory() const |
1021 | { | 1020 | { |
1022 | return showCat; | 1021 | return showCat; |
1023 | } | 1022 | } |
1024 | 1023 | ||
1025 | 1024 | ||
1026 | QStringList AbTable::categories() | 1025 | QStringList AbTable::categories() |
1027 | { | 1026 | { |
1028 | mCat.load( categoryFileName() ); | 1027 | mCat.load( categoryFileName() ); |
1029 | QStringList categoryList = mCat.labels( "Contacts" ); | 1028 | QStringList categoryList = mCat.labels( "Contacts" ); |
1030 | return categoryList; | 1029 | return categoryList; |
1031 | } | 1030 | } |
1032 | 1031 | ||
@@ -1064,38 +1063,115 @@ void AbTable::updateVisible() | |||
1064 | // do some comparing | 1063 | // do some comparing |
1065 | if ( !hide ) { | 1064 | if ( !hide ) { |
1066 | hide = true; | 1065 | hide = true; |
1067 | totalCats = int(cats.count()); | 1066 | totalCats = int(cats.count()); |
1068 | for ( it = 0; it < totalCats; it++ ) { | 1067 | for ( it = 0; it < totalCats; it++ ) { |
1069 | if ( cats[it] == id ) { | 1068 | if ( cats[it] == id ) { |
1070 | hide = false; | 1069 | hide = false; |
1071 | break; | 1070 | break; |
1072 | } | 1071 | } |
1073 | } | 1072 | } |
1074 | } | 1073 | } |
1075 | } | 1074 | } |
1076 | } | 1075 | } |
1077 | if ( showChar != '\0' ) { | 1076 | if ( showChar != '\0' ) { |
1078 | tmpStr = fileAsName.left(1); | 1077 | tmpStr = fileAsName.left(1); |
1079 | tmpStr = tmpStr.lower(); | 1078 | tmpStr = tmpStr.lower(); |
1080 | qDebug( "updateVisible "); | 1079 | if ( tmpStr != QString(QChar(showChar)) && showChar != '#' ) { |
1081 | qDebug( tmpStr ); | ||
1082 | qDebug( "updateVisible2 %c", showChar ); | ||
1083 | if ( tmpStr != QString(QChar(showChar)) ) { | ||
1084 | hide = true; | 1080 | hide = true; |
1085 | } | 1081 | } |
1082 | if ( showChar == '#' ) { | ||
1083 | if (tmpStr == "a") | ||
1084 | hide = true; | ||
1085 | |||
1086 | if (tmpStr == "b") | ||
1087 | hide = true; | ||
1088 | |||
1089 | if (tmpStr == "c") | ||
1090 | hide = true; | ||
1091 | |||
1092 | if (tmpStr == "d") | ||
1093 | hide = true; | ||
1094 | |||
1095 | if (tmpStr == "e") | ||
1096 | hide = true; | ||
1097 | |||
1098 | if (tmpStr == "f") | ||
1099 | hide = true; | ||
1100 | |||
1101 | if (tmpStr == "g") | ||
1102 | hide = true; | ||
1103 | |||
1104 | if (tmpStr == "h") | ||
1105 | hide = true; | ||
1106 | |||
1107 | if (tmpStr == "i") | ||
1108 | hide = true; | ||
1109 | |||
1110 | if (tmpStr == "j") | ||
1111 | hide = true; | ||
1112 | |||
1113 | if (tmpStr == "k") | ||
1114 | hide = true; | ||
1115 | |||
1116 | if (tmpStr == "l") | ||
1117 | hide = true; | ||
1118 | |||
1119 | if (tmpStr == "m") | ||
1120 | hide = true; | ||
1121 | |||
1122 | if (tmpStr == "n") | ||
1123 | hide = true; | ||
1124 | |||
1125 | if (tmpStr == "o") | ||
1126 | hide = true; | ||
1127 | |||
1128 | if (tmpStr == "p") | ||
1129 | hide = true; | ||
1130 | |||
1131 | if (tmpStr == "q") | ||
1132 | hide = true; | ||
1133 | |||
1134 | if (tmpStr == "r") | ||
1135 | hide = true; | ||
1136 | |||
1137 | if (tmpStr == "s") | ||
1138 | hide = true; | ||
1139 | |||
1140 | if (tmpStr == "t") | ||
1141 | hide = true; | ||
1142 | |||
1143 | if (tmpStr == "u") | ||
1144 | hide = true; | ||
1145 | |||
1146 | if (tmpStr == "v") | ||
1147 | hide = true; | ||
1148 | |||
1149 | if (tmpStr == "w") | ||
1150 | hide = true; | ||
1151 | |||
1152 | if (tmpStr == "x") | ||
1153 | hide = true; | ||
1154 | |||
1155 | if (tmpStr == "y") | ||
1156 | hide = true; | ||
1157 | |||
1158 | if (tmpStr == "z") | ||
1159 | hide = true; | ||
1160 | } | ||
1161 | |||
1086 | } | 1162 | } |
1087 | if ( hide ) { | 1163 | if ( hide ) { |
1088 | if ( currentRow() == row ) | 1164 | if ( currentRow() == row ) |
1089 | setCurrentCell( -1, 0 ); | 1165 | setCurrentCell( -1, 0 ); |
1090 | if ( rowHeight(row) > 0 ) | 1166 | if ( rowHeight(row) > 0 ) |
1091 | hideRow( row ); | 1167 | hideRow( row ); |
1092 | } else { | 1168 | } else { |
1093 | if ( rowHeight(row) == 0 ) { | 1169 | if ( rowHeight(row) == 0 ) { |
1094 | showRow( row ); | 1170 | showRow( row ); |
1095 | adjustRow( row ); | 1171 | adjustRow( row ); |
1096 | } | 1172 | } |
1097 | visible++; | 1173 | visible++; |
1098 | } | 1174 | } |
1099 | } | 1175 | } |
1100 | if ( !visible ) | 1176 | if ( !visible ) |
1101 | setCurrentCell( -1, 0 ); | 1177 | setCurrentCell( -1, 0 ); |
diff --git a/core/pim/addressbook/addressbook.cpp b/core/pim/addressbook/addressbook.cpp index e502cf6..beb953a 100644 --- a/core/pim/addressbook/addressbook.cpp +++ b/core/pim/addressbook/addressbook.cpp | |||
@@ -86,33 +86,32 @@ static QString addressbookPersonalVCardName() | |||
86 | 86 | ||
87 | 87 | ||
88 | AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name, | 88 | AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name, |
89 | WFlags f ) | 89 | WFlags f ) |
90 | : QMainWindow( parent, name, f ), | 90 | : QMainWindow( parent, name, f ), |
91 | abEditor(0), | 91 | abEditor(0), |
92 | bAbEditFirstTime(TRUE), | 92 | bAbEditFirstTime(TRUE), |
93 | syncing(FALSE) | 93 | syncing(FALSE) |
94 | { | 94 | { |
95 | initFields(); | 95 | initFields(); |
96 | 96 | ||
97 | setCaption( tr("Contacts") ); | 97 | setCaption( tr("Contacts") ); |
98 | setIcon( Resource::loadPixmap( "AddressBook" ) ); | 98 | setIcon( Resource::loadPixmap( "AddressBook" ) ); |
99 | 99 | ||
100 | setToolBarsMovable( FALSE ); | 100 | setToolBarsMovable( FALSE ); |
101 | 101 | ||
102 | QBoxLayout *vb = new QVBoxLayout( this, 0, 0 ); | ||
103 | // Create Toolbars | 102 | // Create Toolbars |
104 | 103 | ||
105 | QPEToolBar *bar = new QPEToolBar( this ); | 104 | QPEToolBar *bar = new QPEToolBar( this ); |
106 | bar->setHorizontalStretchable( TRUE ); | 105 | bar->setHorizontalStretchable( TRUE ); |
107 | 106 | ||
108 | QPEMenuBar *mbList = new QPEMenuBar( bar ); | 107 | QPEMenuBar *mbList = new QPEMenuBar( bar ); |
109 | mbList->setMargin( 0 ); | 108 | mbList->setMargin( 0 ); |
110 | 109 | ||
111 | QPopupMenu *edit = new QPopupMenu( this ); | 110 | QPopupMenu *edit = new QPopupMenu( this ); |
112 | mbList->insertItem( tr( "Contact" ), edit ); | 111 | mbList->insertItem( tr( "Contact" ), edit ); |
113 | 112 | ||
114 | listTools = new QPEToolBar( this, "list operations" ); | 113 | listTools = new QPEToolBar( this, "list operations" ); |
115 | 114 | ||
116 | 115 | ||
117 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, | 116 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, |
118 | 0, this, 0 ); | 117 | 0, this, 0 ); |
@@ -177,75 +176,79 @@ AddressbookWindow::AddressbookWindow( QWidget *parent, const char *name, | |||
177 | a->addTo( edit ); | 176 | a->addTo( edit ); |
178 | 177 | ||
179 | // Create Views | 178 | // Create Views |
180 | 179 | ||
181 | // This is safe to call without checking to see if it exists... | 180 | // This is safe to call without checking to see if it exists... |
182 | // not to mention it also does the necessary stuff for the | 181 | // not to mention it also does the necessary stuff for the |
183 | // journaling... | 182 | // journaling... |
184 | QString str = addressbookXMLFilename(); | 183 | QString str = addressbookXMLFilename(); |
185 | if ( str.isNull() ) { | 184 | if ( str.isNull() ) { |
186 | QMessageBox::warning( this, tr("Out of Space"), | 185 | QMessageBox::warning( this, tr("Out of Space"), |
187 | tr("There is not enough space to create\n" | 186 | tr("There is not enough space to create\n" |
188 | "neccessary startup files.\n" | 187 | "neccessary startup files.\n" |
189 | "\nFree up some space before\nentering data!") | 188 | "\nFree up some space before\nentering data!") |
190 | ); | 189 | ); |
191 | } | 190 | } |
192 | 191 | ||
193 | abList = new AbTable( &orderedFields, this, "table" ); | 192 | listContainer = new QWidget( this ); |
194 | vb->insertWidget(0,abList); | 193 | |
194 | QVBoxLayout *vb = new QVBoxLayout( listContainer ); | ||
195 | |||
196 | abList = new AbTable( &orderedFields, listContainer, "table" ); | ||
197 | vb->addWidget(abList); | ||
195 | abList->setHScrollBarMode( QScrollView::AlwaysOff ); | 198 | abList->setHScrollBarMode( QScrollView::AlwaysOff ); |
196 | connect( abList, SIGNAL( empty( bool ) ), | 199 | connect( abList, SIGNAL( empty( bool ) ), |
197 | this, SLOT( listIsEmpty( bool ) ) ); | 200 | this, SLOT( listIsEmpty( bool ) ) ); |
198 | connect( abList, SIGNAL( details() ), | 201 | connect( abList, SIGNAL( details() ), |
199 | this, SLOT( slotListView() ) ); | 202 | this, SLOT( slotListView() ) ); |
200 | connect( abList, SIGNAL(currentChanged(int,int)), | 203 | connect( abList, SIGNAL(currentChanged(int,int)), |
201 | this, SLOT(slotUpdateToolbar()) ); | 204 | this, SLOT(slotUpdateToolbar()) ); |
202 | 205 | ||
203 | mView = 0; | 206 | mView = 0; |
204 | 207 | ||
205 | abList->load( addressbookXMLFilename() ); | 208 | abList->load( addressbookXMLFilename() ); |
206 | if ( QFile::exists(addressbookOldXMLFilename()) ) { | 209 | if ( QFile::exists(addressbookOldXMLFilename()) ) { |
207 | abList->load( addressbookOldXMLFilename() ); | 210 | abList->load( addressbookOldXMLFilename() ); |
208 | QFile::remove(addressbookOldXMLFilename()); | 211 | QFile::remove(addressbookOldXMLFilename()); |
209 | } | 212 | } |
210 | 213 | ||
211 | pLabel = new LetterPicker( abList ); | 214 | pLabel = new LetterPicker( listContainer ); |
212 | connect(pLabel, SIGNAL(letterClicked(char)), this, SLOT(slotSetLetter(char))); | 215 | connect(pLabel, SIGNAL(letterClicked(char)), this, SLOT(slotSetLetter(char))); |
213 | vb->insertWidget(1,pLabel); | 216 | vb->addWidget(pLabel); |
214 | catMenu = new QPopupMenu( this ); | 217 | catMenu = new QPopupMenu( this ); |
215 | catMenu->setCheckable( TRUE ); | 218 | catMenu->setCheckable( TRUE ); |
216 | connect( catMenu, SIGNAL(activated(int)), this, SLOT(slotSetCategory(int)) ); | 219 | connect( catMenu, SIGNAL(activated(int)), this, SLOT(slotSetCategory(int)) ); |
217 | populateCategories(); | 220 | populateCategories(); |
218 | 221 | ||
219 | mbList->insertItem( tr("View"), catMenu ); | 222 | mbList->insertItem( tr("View"), catMenu ); |
220 | setCentralWidget( abList ); | 223 | setCentralWidget( listContainer ); |
221 | 224 | ||
222 | fontMenu = new QPopupMenu(this); | 225 | fontMenu = new QPopupMenu(this); |
223 | fontMenu->setCheckable( true ); | 226 | fontMenu->setCheckable( true ); |
224 | connect( fontMenu, SIGNAL(activated(int)), this, SLOT(slotSetFont(int))); | 227 | connect( fontMenu, SIGNAL(activated(int)), this, SLOT(slotSetFont(int))); |
225 | 228 | ||
226 | fontMenu->insertItem(tr( "Small" ), 0); | 229 | fontMenu->insertItem(tr( "Small" ), 0); |
227 | fontMenu->insertItem(tr( "Normal" ), 1); | 230 | fontMenu->insertItem(tr( "Normal" ), 1); |
228 | fontMenu->insertItem(tr( "Large" ), 2); | 231 | fontMenu->insertItem(tr( "Large" ), 2); |
229 | 232 | ||
230 | defaultFont = new QFont( abList->font() ); | 233 | defaultFont = new QFont( abList->font() ); |
231 | 234 | ||
232 | slotSetFont(startFontSize); | 235 | slotSetFont(startFontSize); |
233 | 236 | ||
234 | mbList->insertItem( tr("Font"), fontMenu); | 237 | mbList->insertItem( tr("Font"), fontMenu); |
235 | setCentralWidget(abList); | 238 | setCentralWidget(listContainer); |
236 | 239 | ||
237 | // qDebug("adressbook contrsuction: t=%d", t.elapsed() ); | 240 | // qDebug("adressbook contrsuction: t=%d", t.elapsed() ); |
238 | } | 241 | } |
239 | void AddressbookWindow::slotSetFont( int size ) { | 242 | void AddressbookWindow::slotSetFont( int size ) { |
240 | 243 | ||
241 | if (size > 2 || size < 0) | 244 | if (size > 2 || size < 0) |
242 | size = 1; | 245 | size = 1; |
243 | 246 | ||
244 | startFontSize = size; | 247 | startFontSize = size; |
245 | 248 | ||
246 | QFont *currentFont; | 249 | QFont *currentFont; |
247 | 250 | ||
248 | switch (size) { | 251 | switch (size) { |
249 | case 0: | 252 | case 0: |
250 | fontMenu->setItemChecked(0, true); | 253 | fontMenu->setItemChecked(0, true); |
251 | fontMenu->setItemChecked(1, false); | 254 | fontMenu->setItemChecked(1, false); |
@@ -281,64 +284,64 @@ void AddressbookWindow::setDocument( const QString &filename ) | |||
281 | QValueList<Contact> cl = Contact::readVCard( filename ); | 284 | QValueList<Contact> cl = Contact::readVCard( filename ); |
282 | for( QValueList<Contact>::Iterator it = cl.begin(); it != cl.end(); ++it ) { | 285 | for( QValueList<Contact>::Iterator it = cl.begin(); it != cl.end(); ++it ) { |
283 | // QString msg = tr("You received a vCard for\n%1.\nDo You want to add it to your\naddressbook?") | 286 | // QString msg = tr("You received a vCard for\n%1.\nDo You want to add it to your\naddressbook?") |
284 | // .arg( (*it).fullName() ); | 287 | // .arg( (*it).fullName() ); |
285 | // if ( QMessageBox::information( this, tr("received contact"), msg, QMessageBox::Ok, QMessageBox::Cancel ) == | 288 | // if ( QMessageBox::information( this, tr("received contact"), msg, QMessageBox::Ok, QMessageBox::Cancel ) == |
286 | // QMessageBox::Ok ) { | 289 | // QMessageBox::Ok ) { |
287 | abList->addEntry( *it ); | 290 | abList->addEntry( *it ); |
288 | // } | 291 | // } |
289 | } | 292 | } |
290 | 293 | ||
291 | } | 294 | } |
292 | 295 | ||
293 | void AddressbookWindow::resizeEvent( QResizeEvent *e ) | 296 | void AddressbookWindow::resizeEvent( QResizeEvent *e ) |
294 | { | 297 | { |
295 | QMainWindow::resizeEvent( e ); | 298 | QMainWindow::resizeEvent( e ); |
296 | 299 | ||
297 | if ( centralWidget() == abList ) | 300 | if ( centralWidget() == listContainer ) |
298 | showList(); | 301 | showList(); |
299 | else if ( centralWidget() == mView ) | 302 | else if ( centralWidget() == mView ) |
300 | showView(); | 303 | showView(); |
301 | } | 304 | } |
302 | 305 | ||
303 | AddressbookWindow::~AddressbookWindow() | 306 | AddressbookWindow::~AddressbookWindow() |
304 | { | 307 | { |
305 | Config cfg("AddressBook"); | 308 | Config cfg("AddressBook"); |
306 | cfg.setGroup("Font"); | 309 | cfg.setGroup("Font"); |
307 | cfg.writeEntry("fontSize", startFontSize); | 310 | cfg.writeEntry("fontSize", startFontSize); |
308 | } | 311 | } |
309 | 312 | ||
310 | void AddressbookWindow::slotUpdateToolbar() | 313 | void AddressbookWindow::slotUpdateToolbar() |
311 | { | 314 | { |
312 | Contact ce = abList->currentEntry(); | 315 | Contact ce = abList->currentEntry(); |
313 | actionMail->setEnabled( !ce.defaultEmail().isEmpty() ); | 316 | actionMail->setEnabled( !ce.defaultEmail().isEmpty() ); |
314 | } | 317 | } |
315 | 318 | ||
316 | void AddressbookWindow::showList() | 319 | void AddressbookWindow::showList() |
317 | { | 320 | { |
318 | if ( mView ) mView->hide(); | 321 | if ( mView ) mView->hide(); |
319 | setCentralWidget( abList ); | 322 | setCentralWidget( listContainer ); |
320 | abList->show(); | 323 | listContainer->show(); |
321 | // update our focues... (or use a stack widget!); | 324 | // update our focues... (or use a stack widget!); |
322 | abList->setFocus(); | 325 | abList->setFocus(); |
323 | } | 326 | } |
324 | 327 | ||
325 | void AddressbookWindow::showView() | 328 | void AddressbookWindow::showView() |
326 | { | 329 | { |
327 | if ( abList->numRows() > 0 ) { | 330 | if ( abList->numRows() > 0 ) { |
328 | abList->hide(); | 331 | listContainer->hide(); |
329 | setCentralWidget( abView() ); | 332 | setCentralWidget( abView() ); |
330 | mView->show(); | 333 | mView->show(); |
331 | mView->setFocus(); | 334 | mView->setFocus(); |
332 | } | 335 | } |
333 | } | 336 | } |
334 | 337 | ||
335 | void AddressbookWindow::slotListNew() | 338 | void AddressbookWindow::slotListNew() |
336 | { | 339 | { |
337 | Contact cnt; | 340 | Contact cnt; |
338 | if( !syncing ) { | 341 | if( !syncing ) { |
339 | if ( abEditor ) | 342 | if ( abEditor ) |
340 | abEditor->setEntry( cnt ); | 343 | abEditor->setEntry( cnt ); |
341 | abView()->init( cnt ); | 344 | abView()->init( cnt ); |
342 | editEntry( NewEntry ); | 345 | editEntry( NewEntry ); |
343 | } else { | 346 | } else { |
344 | QMessageBox::warning(this, tr("Contacts"), | 347 | QMessageBox::warning(this, tr("Contacts"), |
@@ -588,33 +591,33 @@ void AddressbookWindow::slotPersonalView() | |||
588 | // XXX need to disable some QActions. | 591 | // XXX need to disable some QActions. |
589 | actionNew->setEnabled(FALSE); | 592 | actionNew->setEnabled(FALSE); |
590 | actionTrash->setEnabled(FALSE); | 593 | actionTrash->setEnabled(FALSE); |
591 | #ifndef MAKE_FOR_SHARP_ROM | 594 | #ifndef MAKE_FOR_SHARP_ROM |
592 | actionFind->setEnabled(FALSE); | 595 | actionFind->setEnabled(FALSE); |
593 | #endif | 596 | #endif |
594 | actionMail->setEnabled(FALSE); | 597 | actionMail->setEnabled(FALSE); |
595 | 598 | ||
596 | setCaption( tr("Contacts - My Personal Details") ); | 599 | setCaption( tr("Contacts - My Personal Details") ); |
597 | QString filename = addressbookPersonalVCardName(); | 600 | QString filename = addressbookPersonalVCardName(); |
598 | Contact me; | 601 | Contact me; |
599 | if (QFile::exists(filename)) | 602 | if (QFile::exists(filename)) |
600 | me = Contact::readVCard( filename )[0]; | 603 | me = Contact::readVCard( filename )[0]; |
601 | 604 | ||
602 | abView()->init( me ); | 605 | abView()->init( me ); |
603 | abView()->sync(); | 606 | abView()->sync(); |
604 | abList->hide(); | 607 | listContainer->hide(); |
605 | setCentralWidget( abView() ); | 608 | setCentralWidget( abView() ); |
606 | mView->show(); | 609 | mView->show(); |
607 | mView->setFocus(); | 610 | mView->setFocus(); |
608 | } | 611 | } |
609 | 612 | ||
610 | void AddressbookWindow::editEntry( EntryMode entryMode ) | 613 | void AddressbookWindow::editEntry( EntryMode entryMode ) |
611 | { | 614 | { |
612 | Contact entry; | 615 | Contact entry; |
613 | if ( bAbEditFirstTime ) { | 616 | if ( bAbEditFirstTime ) { |
614 | abEditor = new ContactEditor( entry, &orderedFields, &slOrderedFields, | 617 | abEditor = new ContactEditor( entry, &orderedFields, &slOrderedFields, |
615 | this, "editor" ); | 618 | this, "editor" ); |
616 | bAbEditFirstTime = FALSE; | 619 | bAbEditFirstTime = FALSE; |
617 | if ( entryMode == EditEntry ) | 620 | if ( entryMode == EditEntry ) |
618 | abEditor->setEntry( abList->currentEntry() ); | 621 | abEditor->setEntry( abList->currentEntry() ); |
619 | } | 622 | } |
620 | // other things may chane the caption. | 623 | // other things may chane the caption. |
diff --git a/core/pim/addressbook/addressbook.h b/core/pim/addressbook/addressbook.h index 31c4660..8e8c883 100644 --- a/core/pim/addressbook/addressbook.h +++ b/core/pim/addressbook/addressbook.h | |||
@@ -76,29 +76,30 @@ private slots: | |||
76 | private: | 76 | private: |
77 | void initFields();// inititialize our fields... | 77 | void initFields();// inititialize our fields... |
78 | AbLabel *abView(); | 78 | AbLabel *abView(); |
79 | void populateCategories(); | 79 | void populateCategories(); |
80 | 80 | ||
81 | QPopupMenu *catMenu, *fontMenu; | 81 | QPopupMenu *catMenu, *fontMenu; |
82 | QPEToolBar *listTools; | 82 | QPEToolBar *listTools; |
83 | QToolButton *deleteButton; | 83 | QToolButton *deleteButton; |
84 | QValueList<int> allFields, | 84 | QValueList<int> allFields, |
85 | orderedFields; | 85 | orderedFields; |
86 | QStringList slOrderedFields; | 86 | QStringList slOrderedFields; |
87 | enum Panes { paneList=0, paneView, paneEdit }; | 87 | enum Panes { paneList=0, paneView, paneEdit }; |
88 | ContactEditor *abEditor; | 88 | ContactEditor *abEditor; |
89 | AbLabel *mView; | 89 | AbLabel *mView; |
90 | LetterPicker *pLabel; | 90 | LetterPicker *pLabel; |
91 | AbTable *abList; | 91 | AbTable *abList; |
92 | QWidget *listContainer; | ||
92 | 93 | ||
93 | QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, | 94 | QAction *actionNew, *actionEdit, *actionTrash, *actionFind, *actionBeam, |
94 | *actionPersonal, *actionMail; | 95 | *actionPersonal, *actionMail; |
95 | 96 | ||
96 | bool bAbEditFirstTime; | 97 | bool bAbEditFirstTime; |
97 | int viewMargin; | 98 | int viewMargin; |
98 | 99 | ||
99 | bool syncing; | 100 | bool syncing; |
100 | QFont *defaultFont; | 101 | QFont *defaultFont; |
101 | int startFontSize; | 102 | int startFontSize; |
102 | }; | 103 | }; |
103 | 104 | ||
104 | #endif | 105 | #endif |
diff --git a/core/pim/addressbook/picker.cpp b/core/pim/addressbook/picker.cpp index 06dcc7d..a165451 100644 --- a/core/pim/addressbook/picker.cpp +++ b/core/pim/addressbook/picker.cpp | |||
@@ -66,84 +66,80 @@ void PickerLabel::clearLetter() | |||
66 | tmpStr = "<qt>"; | 66 | tmpStr = "<qt>"; |
67 | tmpStr += letter1; | 67 | tmpStr += letter1; |
68 | tmpStr += letter2; | 68 | tmpStr += letter2; |
69 | tmpStr += letter3; | 69 | tmpStr += letter3; |
70 | tmpStr += "</qt>"; | 70 | tmpStr += "</qt>"; |
71 | 71 | ||
72 | setText(tmpStr); | 72 | setText(tmpStr); |
73 | 73 | ||
74 | currentLetter = 0; | 74 | currentLetter = 0; |
75 | 75 | ||
76 | } | 76 | } |
77 | 77 | ||
78 | void PickerLabel::mouseReleaseEvent( QMouseEvent *e ) | 78 | void PickerLabel::mouseReleaseEvent( QMouseEvent *e ) |
79 | { | 79 | { |
80 | QString tmpStr; | 80 | QString tmpStr; |
81 | 81 | ||
82 | if (lastLetter != letter1 && lastLetter != letter2 && lastLetter != letter3) | 82 | if (lastLetter != letter1 && lastLetter != letter2 && lastLetter != letter3 && lastLetter != '\0') |
83 | QTimer::singleShot( 0, this, SLOT(emitClearSignal()) ); | 83 | QTimer::singleShot( 0, this, SLOT(emitClearSignal()) ); |
84 | 84 | ||
85 | qDebug( "a" ); | ||
86 | switch (currentLetter) { | 85 | switch (currentLetter) { |
87 | case 0: | 86 | case 0: |
88 | tmpStr = "<qt><font color=\"#7F0000\">"; | 87 | tmpStr = "<qt><font color=\"#7F0000\">"; |
89 | tmpStr += letter1; | 88 | tmpStr += letter1; |
90 | tmpStr += "</font>"; | 89 | tmpStr += "</font>"; |
91 | tmpStr += letter2; | 90 | tmpStr += letter2; |
92 | tmpStr += letter3; | 91 | tmpStr += letter3; |
93 | tmpStr += "</qt>"; | 92 | tmpStr += "</qt>"; |
94 | 93 | ||
95 | setText(tmpStr); | 94 | setText(tmpStr); |
96 | 95 | ||
97 | currentLetter++; | 96 | currentLetter++; |
98 | lastLetter = letter1; | 97 | lastLetter = letter1; |
99 | emit selectedLetter( letter1 ); | 98 | emit selectedLetter( letter1 ); |
100 | qDebug( "PickerLabel::mouseReleaseEvent %c", letter1 ); | ||
101 | break; | 99 | break; |
102 | 100 | ||
103 | case 1: | 101 | case 1: |
104 | tmpStr = "<qt>"; | 102 | tmpStr = "<qt>"; |
105 | tmpStr += letter1; | 103 | tmpStr += letter1; |
106 | tmpStr += "<font color=\"#7F0000\">"; | 104 | tmpStr += "<font color=\"#7F0000\">"; |
107 | tmpStr += letter2; | 105 | tmpStr += letter2; |
108 | tmpStr += "</font>"; | 106 | tmpStr += "</font>"; |
109 | tmpStr += letter3; | 107 | tmpStr += letter3; |
110 | tmpStr += "</qt>"; | 108 | tmpStr += "</qt>"; |
111 | 109 | ||
112 | setText(tmpStr); | 110 | setText(tmpStr); |
113 | 111 | ||
114 | currentLetter++; | 112 | currentLetter++; |
115 | lastLetter = letter2; | 113 | lastLetter = letter2; |
116 | emit selectedLetter( letter2 ); | 114 | emit selectedLetter( letter2 ); |
117 | qDebug( "PickerLabel::mouseReleaseEvent %c", letter2 ); | ||
118 | break; | 115 | break; |
119 | 116 | ||
120 | case 2: | 117 | case 2: |
121 | tmpStr = "<qt>"; | 118 | tmpStr = "<qt>"; |
122 | tmpStr += letter1; | 119 | tmpStr += letter1; |
123 | tmpStr += letter2; | 120 | tmpStr += letter2; |
124 | tmpStr += "<font color=\"#7F0000\">"; | 121 | tmpStr += "<font color=\"#7F0000\">"; |
125 | tmpStr += letter3; | 122 | tmpStr += letter3; |
126 | tmpStr += "</font></qt>"; | 123 | tmpStr += "</font></qt>"; |
127 | 124 | ||
128 | setText(tmpStr); | 125 | setText(tmpStr); |
129 | 126 | ||
130 | currentLetter++; | 127 | currentLetter++; |
131 | lastLetter = letter3; | 128 | lastLetter = letter3; |
132 | emit selectedLetter( letter3 ); | 129 | emit selectedLetter( letter3 ); |
133 | qDebug( "PickerLabel::mouseReleaseEvent %c", letter3 ); | ||
134 | break; | 130 | break; |
135 | 131 | ||
136 | default: | 132 | default: |
137 | clearLetter(); | 133 | clearLetter(); |
138 | lastLetter = '\0'; | 134 | lastLetter = '\0'; |
139 | emit selectedLetter( '\0' ); | 135 | emit selectedLetter( '\0' ); |
140 | 136 | ||
141 | 137 | ||
142 | } | 138 | } |
143 | } | 139 | } |
144 | 140 | ||
145 | void PickerLabel::emitClearSignal() { | 141 | void PickerLabel::emitClearSignal() { |
146 | emit clearAll(); | 142 | emit clearAll(); |
147 | } | 143 | } |
148 | 144 | ||
149 | LetterPicker::LetterPicker( QWidget *parent, const char *name ) | 145 | LetterPicker::LetterPicker( QWidget *parent, const char *name ) |
@@ -215,20 +211,19 @@ LetterPicker::~LetterPicker() | |||
215 | 211 | ||
216 | void LetterPicker::clear() | 212 | void LetterPicker::clear() |
217 | { | 213 | { |
218 | lblABC->clearLetter(); | 214 | lblABC->clearLetter(); |
219 | lblDEF->clearLetter(); | 215 | lblDEF->clearLetter(); |
220 | lblGHI->clearLetter(); | 216 | lblGHI->clearLetter(); |
221 | lblJKL->clearLetter(); | 217 | lblJKL->clearLetter(); |
222 | lblMNO->clearLetter(); | 218 | lblMNO->clearLetter(); |
223 | lblPQR->clearLetter(); | 219 | lblPQR->clearLetter(); |
224 | lblSTU->clearLetter(); | 220 | lblSTU->clearLetter(); |
225 | lblVWX->clearLetter(); | 221 | lblVWX->clearLetter(); |
226 | lblYZ->clearLetter(); | 222 | lblYZ->clearLetter(); |
227 | } | 223 | } |
228 | 224 | ||
229 | void LetterPicker::newLetter( char letter ) | 225 | void LetterPicker::newLetter( char letter ) |
230 | { | 226 | { |
231 | qDebug( "LetterPicker::newLetter %c", letter ); | ||
232 | emit letterClicked( letter ); | 227 | emit letterClicked( letter ); |
233 | 228 | ||
234 | } | 229 | } |