1
0
mirror of https://github.com/tomahawk-player/tomahawk.git synced 2025-08-13 17:43:59 +02:00

* Use FlexibleHeader in FlexibleView.

This commit is contained in:
Christian Muehlhaeuser
2012-07-14 09:50:06 +02:00
parent a62a4c354f
commit 7ab179e23f
2 changed files with 45 additions and 49 deletions

View File

@@ -22,11 +22,11 @@
#include <QStackedWidget> #include <QStackedWidget>
#include <QVBoxLayout> #include <QVBoxLayout>
#include "playlist/FlexibleHeader.h"
#include "playlist/PlayableModel.h" #include "playlist/PlayableModel.h"
#include "playlist/TrackView.h" #include "playlist/TrackView.h"
#include "playlist/GridView.h" #include "playlist/GridView.h"
#include "playlist/PlaylistLargeItemDelegate.h" #include "playlist/PlaylistLargeItemDelegate.h"
#include "utils/Closure.h"
#include "utils/TomahawkUtilsGui.h" #include "utils/TomahawkUtilsGui.h"
#include "utils/Logger.h" #include "utils/Logger.h"
@@ -35,6 +35,7 @@ using namespace Tomahawk;
FlexibleView::FlexibleView( QWidget* parent ) FlexibleView::FlexibleView( QWidget* parent )
: QWidget( parent ) : QWidget( parent )
, m_header( new FlexibleHeader( this ) )
, m_trackView( new TrackView() ) , m_trackView( new TrackView() )
, m_detailedView( new TrackView() ) , m_detailedView( new TrackView() )
, m_gridView( new GridView() ) , m_gridView( new GridView() )
@@ -51,54 +52,16 @@ FlexibleView::FlexibleView( QWidget* parent )
setLayout( new QVBoxLayout() ); setLayout( new QVBoxLayout() );
TomahawkUtils::unmarginLayout( layout() ); TomahawkUtils::unmarginLayout( layout() );
QWidget* modeBar = new QWidget(); layout()->addWidget( m_header );
modeBar->setLayout( new QHBoxLayout() );
TomahawkUtils::unmarginLayout( modeBar->layout() );
QWidget* modeWidget = new QWidget();
modeWidget->setLayout( new QHBoxLayout() );
modeWidget->setFixedSize( QSize( 87, 30 ) );
TomahawkUtils::unmarginLayout( modeWidget->layout() );
QRadioButton* radioNormal = new QRadioButton();
radioNormal->setObjectName( "radioNormal" );
QRadioButton* radioDetailed = new QRadioButton();
radioDetailed->setObjectName( "radioDetailed" );
QRadioButton* radioCloud = new QRadioButton();
radioCloud->setObjectName( "radioCloud" );
radioNormal->setFocusPolicy( Qt::NoFocus );
radioDetailed->setFocusPolicy( Qt::NoFocus );
radioCloud->setFocusPolicy( Qt::NoFocus );
QFile f( RESPATH "stylesheets/topbar-radiobuttons.css" );
f.open( QFile::ReadOnly );
QString css = QString::fromAscii( f.readAll() );
f.close();
modeWidget->setStyleSheet( css );
modeWidget->layout()->addWidget( radioNormal );
modeWidget->layout()->addWidget( radioDetailed );
modeWidget->layout()->addWidget( radioCloud );
modeWidget->layout()->addItem( new QSpacerItem( 1, 1, QSizePolicy::Expanding, QSizePolicy::Fixed ) );
modeBar->layout()->addItem( new QSpacerItem( 1, 1, QSizePolicy::Expanding, QSizePolicy::Fixed ) );
modeBar->layout()->addWidget( modeWidget );
modeBar->layout()->addItem( new QSpacerItem( 1, 1, QSizePolicy::Expanding, QSizePolicy::Fixed ) );
layout()->addWidget( modeBar );
layout()->addWidget( m_stack ); layout()->addWidget( m_stack );
m_stack->addWidget( m_trackView ); m_stack->addWidget( m_trackView );
m_stack->addWidget( m_detailedView ); m_stack->addWidget( m_detailedView );
m_stack->addWidget( m_gridView ); m_stack->addWidget( m_gridView );
radioNormal->setChecked( true );
setCurrentMode( Flat ); setCurrentMode( Flat );
NewClosure( radioNormal, SIGNAL( clicked() ), const_cast< FlexibleView* >( this ), SLOT( setCurrentMode( FlexibleViewMode ) ), Flat )->setAutoDelete( false ); connect( m_header, SIGNAL( filterTextChanged( QString ) ), SLOT( setFilter( QString ) ) );
NewClosure( radioDetailed, SIGNAL( clicked() ), const_cast< FlexibleView* >( this ), SLOT( setCurrentMode( FlexibleViewMode ) ), Detailed )->setAutoDelete( false );
NewClosure( radioCloud, SIGNAL( clicked() ), const_cast< FlexibleView* >( this ), SLOT( setCurrentMode( FlexibleViewMode ) ), Grid )->setAutoDelete( false );
} }
@@ -166,6 +129,10 @@ FlexibleView::setPlayableModel( PlayableModel* model )
m_trackView->proxyModel()->sort( -1 ); m_trackView->proxyModel()->sort( -1 );
m_detailedView->proxyModel()->sort( -1 ); m_detailedView->proxyModel()->sort( -1 );
m_gridView->proxyModel()->sort( -1 ); m_gridView->proxyModel()->sort( -1 );
m_header->setPixmap( m_pixmap );
m_header->setCaption( model->title() );
m_header->setDescription( model->description() );
} }
@@ -223,7 +190,7 @@ FlexibleView::description() const
QPixmap QPixmap
FlexibleView::pixmap() const FlexibleView::pixmap() const
{ {
return m_trackView->pixmap(); return m_pixmap;
} }
@@ -238,13 +205,30 @@ FlexibleView::jumpToCurrentTrack()
bool bool
FlexibleView::setFilter( const QString& filter ) FlexibleView::setFilter( const QString& pattern )
{ {
ViewPage::setFilter( filter ); ViewPage::setFilter( pattern );
m_trackView->setFilter( filter ); m_trackView->setFilter( pattern );
m_detailedView->setFilter( filter ); m_detailedView->setFilter( pattern );
m_gridView->setFilter( filter ); m_gridView->setFilter( pattern );
return true; return true;
} }
void
FlexibleView::setEmptyTip( const QString& tip )
{
m_trackView->setEmptyTip( tip );
m_detailedView->setEmptyTip( tip );
m_gridView->setEmptyTip( tip );
}
void
FlexibleView::setPixmap( const QPixmap& pixmap )
{
m_pixmap = pixmap;
m_header->setPixmap( pixmap );
}

View File

@@ -28,6 +28,7 @@ class QStackedWidget;
class GridView; class GridView;
class TrackView; class TrackView;
class PlayableModel; class PlayableModel;
class FlexibleHeader;
class DLLEXPORT FlexibleView : public QWidget, public Tomahawk::ViewPage class DLLEXPORT FlexibleView : public QWidget, public Tomahawk::ViewPage
{ {
@@ -47,23 +48,34 @@ public:
virtual QString description() const; virtual QString description() const;
virtual QPixmap pixmap() const; virtual QPixmap pixmap() const;
virtual bool showFilter() const { return true; } virtual bool showInfoBar() const { return false; }
virtual bool setFilter( const QString& filter );
virtual bool jumpToCurrentTrack(); virtual bool jumpToCurrentTrack();
TrackView* trackView() const { return m_trackView; }
TrackView* detailedView() const { return m_detailedView; }
GridView* gridView() const { return m_gridView; }
void setTrackView( TrackView* view ); void setTrackView( TrackView* view );
void setDetailedView( TrackView* view ); void setDetailedView( TrackView* view );
void setGridView( GridView* view ); void setGridView( GridView* view );
void setPixmap( const QPixmap& pixmap );
void setPlayableModel( PlayableModel* model ); void setPlayableModel( PlayableModel* model );
void setEmptyTip( const QString& tip );
public slots: public slots:
void setCurrentMode( FlexibleViewMode mode ); void setCurrentMode( FlexibleViewMode mode );
virtual bool setFilter( const QString& pattern );
signals: signals:
void modeChanged( FlexibleViewMode mode ); void modeChanged( FlexibleViewMode mode );
private slots:
private: private:
FlexibleHeader* m_header;
QPixmap m_pixmap;
TrackView* m_trackView; TrackView* m_trackView;
TrackView* m_detailedView; TrackView* m_detailedView;
GridView* m_gridView; GridView* m_gridView;