summaryrefslogtreecommitdiffabout
path: root/kaddressbook
Side-by-side diff
Diffstat (limited to 'kaddressbook') (more/less context) (ignore whitespace changes)
-rw-r--r--kaddressbook/jumpbuttonbar.cpp15
1 files changed, 11 insertions, 4 deletions
diff --git a/kaddressbook/jumpbuttonbar.cpp b/kaddressbook/jumpbuttonbar.cpp
index 184d516..b12d9e7 100644
--- a/kaddressbook/jumpbuttonbar.cpp
+++ b/kaddressbook/jumpbuttonbar.cpp
@@ -98,10 +98,13 @@ QSizePolicy JumpButtonBar::sizePolicy() const
void JumpButtonBar::letterClicked()
{
JumpButton *button = (JumpButton*)sender();
QString character = button->character();
+ if ( character.length() == 2 )
+ character = character.left(1) +"-"+character.right(1);
if ( !character.isNull() )
- emit jumpToLetter( character );
+ emit jumpToLetter( character );
+ //qDebug("emit *%s* ",character.latin1());
}
void JumpButtonBar::recreateButtons()
{
@@ -121,8 +124,9 @@ void JumpButtonBar::recreateButtons()
} else {
setEnabled( false );
return;
}
+ mCharacters.append( "*");
for ( it = ab->begin(); it != ab->end(); ++it ) {
if ( !field->value( *it ).isEmpty() )
character = field->value( *it )[ 0 ].lower();
if ( character != "!" )
@@ -157,14 +161,17 @@ void JumpButtonBar::recreateButtons()
bool skipcurrent = false;
bool state = isUpdatesEnabled();
setUpdatesEnabled( false );
//qDebug("cc %d ",mCharacters.count() );
- JumpButton *button;
+ JumpButton *button = 0;
int row = 0, col = 0;
JumpButton* cur = mButtons.first();
for ( uint i = 0; i < mCharacters.count(); ++i ) {
if ( skipcount > 0 && skipcurrent ) {
--skipcount;
+ if ( button ) {
+ button->setCharacter( button->character() + mCharacters[ i ]);
+ }
} else {
if ( cur ) {
button = cur ;
cur = mButtons.next();
@@ -184,10 +191,10 @@ void JumpButtonBar::recreateButtons()
col++;
} else
row++;
}
-
- skipcurrent = !skipcurrent;
+ if ( i > 0 )
+ skipcurrent = !skipcurrent;
}
while ( cur ) {
cur->hide();
cur = mButtons.next();