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:
@@ -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 );
|
||||||
|
}
|
||||||
|
@@ -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;
|
||||||
|
Reference in New Issue
Block a user