@ -65,10 +65,11 @@ ThemesModel::roleNames() const
void
void
ThemesModel : : setThemeImage ( const QString & id , const QString & imagePath )
ThemesModel : : setThemeImage ( const QString & id , const QString & imagePath )
{
{
auto * theme = m_themes . find ById( id ) ;
auto [ i , theme ] = m_themes . index ById( id ) ;
if ( theme )
if ( theme )
{
{
theme - > imagePath = imagePath ;
theme - > imagePath = imagePath ;
emit dataChanged ( index ( i , 0 ) , index ( i , 0 ) , { ImageRole } ) ;
}
}
}
}
@ -80,20 +81,25 @@ ThemesModel::setThemeImage( const QMap< QString, QString >& images )
return ;
return ;
}
}
// Don't emit signals from each call, aggregate to one call (below this block)
{
QSignalBlocker b ( this ) ;
for ( const auto & k : images )
for ( const auto & k : images )
{
{
setThemeImage ( k , images [ k ] ) ;
setThemeImage ( k , images [ k ] ) ;
}
}
}
emit dataChanged ( index ( 0 , 0 ) , index ( m_themes . count ( ) - 1 ) , { ImageRole } ) ;
emit dataChanged ( index ( 0 , 0 ) , index ( m_themes . count ( ) - 1 ) , { ImageRole } ) ;
}
}
void
void
ThemesModel : : showTheme ( const QString & id , bool show )
ThemesModel : : showTheme ( const QString & id , bool show )
{
{
auto * theme = m_themes . find ById( id ) ;
auto [ i , theme ] = m_themes . index ById( id ) ;
if ( theme )
if ( theme )
{
{
theme - > show = show ;
theme - > show = show ;
emit dataChanged ( index ( i , 0 ) , index ( i , 0 ) , { ShownRole } ) ;
}
}
}
}
@ -105,6 +111,8 @@ ThemesModel::showOnlyThemes( const QMap< QString, QString >& onlyThese )
return ;
return ;
}
}
// No signal blocker block needed here because we're not calling showTheme()
// QSignalBlocker b( this );
for ( auto & t : m_themes )
for ( auto & t : m_themes )
{
{
t . show = onlyThese . contains ( t . id ) ;
t . show = onlyThese . contains ( t . id ) ;