Keyboard: try a little harder to match keyboard layouts with selected system language
This commit is contained in:
parent
9b9801d48d
commit
6704121946
@ -259,15 +259,32 @@ KeyboardPage::guessLayout( const QStringList& langParts )
|
|||||||
for ( int i = 0; i < klm->rowCount(); ++i )
|
for ( int i = 0; i < klm->rowCount(); ++i )
|
||||||
{
|
{
|
||||||
QModelIndex idx = klm->index( i );
|
QModelIndex idx = klm->index( i );
|
||||||
if ( idx.isValid() &&
|
QString name = idx.isValid() ? idx.data( KeyboardLayoutModel::KeyboardLayoutKeyRole ).toString() : QString();
|
||||||
( idx.data( KeyboardLayoutModel::KeyboardLayoutKeyRole ).toString().compare( *countryPart, Qt::CaseInsensitive ) == 0 ) )
|
if ( idx.isValid() && ( name.compare( *countryPart, Qt::CaseInsensitive ) == 0 ) )
|
||||||
{
|
{
|
||||||
cDebug() << " .. matched" << idx.data( KeyboardLayoutModel::KeyboardLayoutKeyRole ).toString();
|
cDebug() << " .. matched" << name;
|
||||||
ui->listLayout->setCurrentIndex( idx );
|
ui->listLayout->setCurrentIndex( idx );
|
||||||
foundCountryPart = true;
|
foundCountryPart = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ( foundCountryPart )
|
||||||
|
{
|
||||||
|
++countryPart;
|
||||||
|
if ( countryPart != langParts.rend() )
|
||||||
|
{
|
||||||
|
cDebug() << "Next level:" << *countryPart;
|
||||||
|
for (int variantnumber = 0; variantnumber < ui->listVariant->count(); ++variantnumber)
|
||||||
|
{
|
||||||
|
LayoutItem *variantdata = dynamic_cast< LayoutItem* >( ui->listVariant->item( variantnumber ) );
|
||||||
|
if ( variantdata && (variantdata->data.compare( *countryPart, Qt::CaseInsensitive ) == 0) )
|
||||||
|
{
|
||||||
|
ui->listVariant->setCurrentItem( variantdata );
|
||||||
|
cDebug() << " .. matched variant" << variantdata->data << ' ' << variantdata->text();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,6 +292,12 @@ KeyboardPage::guessLayout( const QStringList& langParts )
|
|||||||
void
|
void
|
||||||
KeyboardPage::onActivate()
|
KeyboardPage::onActivate()
|
||||||
{
|
{
|
||||||
|
static auto specialCaseMap = QMap<std::string, std::string>( {
|
||||||
|
{ "ar_EG", "ara" },
|
||||||
|
{ "ca_ES", "cat_ES" },
|
||||||
|
{ "as_ES", "ast_ES" },
|
||||||
|
} );
|
||||||
|
|
||||||
ui->listLayout->setFocus();
|
ui->listLayout->setFocus();
|
||||||
|
|
||||||
// Try to preselect a layout, depending on language and locale
|
// Try to preselect a layout, depending on language and locale
|
||||||
@ -293,6 +316,15 @@ KeyboardPage::onActivate()
|
|||||||
lang.truncate( index );
|
lang.truncate( index );
|
||||||
|
|
||||||
lang.replace( '-', '_' ); // Normalize separators
|
lang.replace( '-', '_' ); // Normalize separators
|
||||||
|
}
|
||||||
|
if ( !lang.isEmpty() && specialCaseMap.contains( lang.toStdString() ) )
|
||||||
|
{
|
||||||
|
QLatin1String newLang( specialCaseMap.value( lang.toStdString() ).c_str() );
|
||||||
|
cDebug() << " .. special case language" << lang << '>' << newLang;
|
||||||
|
lang = newLang;
|
||||||
|
}
|
||||||
|
if ( !lang.isEmpty() )
|
||||||
|
{
|
||||||
const auto langParts = lang.split( '_', QString::SkipEmptyParts );
|
const auto langParts = lang.split( '_', QString::SkipEmptyParts );
|
||||||
|
|
||||||
QString country = QLocale::countryToString( QLocale( lang ).country() );
|
QString country = QLocale::countryToString( QLocale( lang ).country() );
|
||||||
|
Loading…
Reference in New Issue
Block a user