Commit 0dd7de57 authored by Francois Cartegnie's avatar Francois Cartegnie

Qt: addons: tag addons with colors

parent d839410a
...@@ -57,7 +57,6 @@ ...@@ -57,7 +57,6 @@
#include <QCheckBox> #include <QCheckBox>
#include <QPixmap> #include <QPixmap>
#include <QStylePainter> #include <QStylePainter>
#include <QGraphicsColorizeEffect>
#include <QProgressBar> #include <QProgressBar>
#include <QTextEdit> #include <QTextEdit>
#include <QUrl> #include <QUrl>
...@@ -846,6 +845,32 @@ bool AddonsListModel::setData( const QModelIndex &index, const QVariant &value, ...@@ -846,6 +845,32 @@ bool AddonsListModel::setData( const QModelIndex &index, const QVariant &value,
return true; return true;
} }
QColor AddonsListModel::getColorByAddonType( int i_type )
{
QColor color;
switch( i_type )
{
case ADDON_EXTENSION:
color = QColor(0xDB, 0xC5, 0x40);
break;
case ADDON_PLAYLIST_PARSER:
color = QColor(0x36, 0xBB, 0x59);
break;
case ADDON_SERVICE_DISCOVERY:
color = QColor(0xDB, 0x52, 0x40);
break;
case ADDON_SKIN2:
color = QColor(0x8B, 0xD6, 0xFC);
break;
case ADDON_PLUGIN:
case ADDON_UNKNOWN:
case ADDON_OTHER:
default:
break;
}
return color;
}
QVariant AddonsListModel::data( const QModelIndex& index, int role ) const QVariant AddonsListModel::data( const QModelIndex& index, int role ) const
{ {
if( !index.isValid() ) if( !index.isValid() )
...@@ -1004,7 +1029,24 @@ void AddonItemDelegate::paint( QPainter *painter, ...@@ -1004,7 +1029,24 @@ void AddonItemDelegate::paint( QPainter *painter,
{ {
QStyleOptionViewItemV4 newopt = option; QStyleOptionViewItemV4 newopt = option;
int i_state = index.data( AddonsListModel::StateRole ).toInt(); int i_state = index.data( AddonsListModel::StateRole ).toInt();
int i_type = index.data( AddonsListModel::TypeRole ).toInt();
/* Draw Background gradient by addon type */
QColor backgroundColor = AddonsListModel::getColorByAddonType( i_type );
if ( backgroundColor.isValid() )
{
painter->save();
QLinearGradient gradient(
QPoint( option.rect.right() - 50, option.rect.top() ),
option.rect.bottomRight() );
gradient.setColorAt( 0, Qt::transparent );
gradient.setColorAt( 1.0, backgroundColor );
painter->fillRect( option.rect, gradient );
painter->restore();
}
/* Draw base info from parent */
ExtensionItemDelegate::paint( painter, newopt, index ); ExtensionItemDelegate::paint( painter, newopt, index );
initStyleOption( &newopt, index ); initStyleOption( &newopt, index );
......
...@@ -227,6 +227,8 @@ public: ...@@ -227,6 +227,8 @@ public:
ScoreRole ScoreRole
}; };
static QColor getColorByAddonType( int );
protected slots: protected slots:
void addonAdded( addon_entry_t * ); void addonAdded( addon_entry_t * );
void addonChanged( const addon_entry_t * ); void addonChanged( const addon_entry_t * );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment