diff --git a/modules/gui/qt4/components/playlist/playlist.cpp b/modules/gui/qt4/components/playlist/playlist.cpp index c2d6334ddbdce23eb43b89df7931e676d2c35f4c..54396ec25fd88f5b1e1c6554d4afd1bd9f6104c0 100644 --- a/modules/gui/qt4/components/playlist/playlist.cpp +++ b/modules/gui/qt4/components/playlist/playlist.cpp @@ -144,9 +144,9 @@ PlaylistWidget::PlaylistWidget( intf_thread_t *_p_i, QWidget *_par ) layout->setColumnStretch( 3, 3 ); /* Connect the activation of the selector to a redefining of the PL */ - DCONNECT( selector, activated( playlist_item_t * ), - mainView, setRoot( playlist_item_t * ) ); - mainView->setRoot( p_root ); + DCONNECT( selector, activated( playlist_item_t *, bool ), + mainView, setRoot( playlist_item_t *, bool ) ); + mainView->setRoot( p_root, false ); /* */ split = new PlaylistSplitter( this ); diff --git a/modules/gui/qt4/components/playlist/selector.cpp b/modules/gui/qt4/components/playlist/selector.cpp index e2ed853ea13dc82326caa73f9348e271f876eb82..4f9a9dac138c816f27da9b0e400deab5db84a2d0 100644 --- a/modules/gui/qt4/components/playlist/selector.cpp +++ b/modules/gui/qt4/components/playlist/selector.cpp @@ -192,6 +192,9 @@ void PLSelector::createItems() THEPL->p_media_library ); ml->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_ML ) ); + /* SQL ML */ + QTreeWidgetItem *sql_ml = addItem( SQL_ML, "SQL Media Library" )->treeItem(); + /* SD nodes */ QTreeWidgetItem *mycomp = addItem( CATEGORY_TYPE, N_("My Computer") )->treeItem(); QTreeWidgetItem *devices = addItem( CATEGORY_TYPE, N_("Devices") )->treeItem(); @@ -271,11 +274,18 @@ void PLSelector::setSource( QTreeWidgetItem *item ) if( !sd_loaded ) playlist_ServicesDiscoveryAdd( THEPL, qtu( qs ) ); } + else if( i_type == SQL_ML ) + { + emit activated( NULL, true ); + return; + } /* */ playlist_Lock( THEPL ); playlist_item_t *pl_item = NULL; + /* Special case for podcast */ + // FIXME: simplify if( i_type == SD_TYPE ) { /* Find the right item for the SD */ @@ -301,7 +311,7 @@ void PLSelector::setSource( QTreeWidgetItem *item ) /* */ if( pl_item ) - emit activated( pl_item ); + emit activated( pl_item, false ); } PLSelItem * PLSelector::addItem ( diff --git a/modules/gui/qt4/components/playlist/selector.hpp b/modules/gui/qt4/components/playlist/selector.hpp index d97335e7adea1da54892b839c118339d509afcf2..ddac879b0cb78a34382572aeb6acf461f0a4c96e 100644 --- a/modules/gui/qt4/components/playlist/selector.hpp +++ b/modules/gui/qt4/components/playlist/selector.hpp @@ -43,7 +43,8 @@ class QLabel; enum SelectorItemType { CATEGORY_TYPE, SD_TYPE, - PL_ITEM_TYPE + PL_ITEM_TYPE, + SQL_ML }; enum SpecialData { @@ -144,7 +145,7 @@ private slots: void podcastRemove( PLSelItem* ); signals: - void activated( playlist_item_t * ); + void activated( playlist_item_t *, bool ); }; #endif diff --git a/modules/gui/qt4/components/playlist/standardpanel.cpp b/modules/gui/qt4/components/playlist/standardpanel.cpp index ae19f712880d59631a62f29c5ffc0629d09b413e..54189c3ef1a6375b99d4b62c5c43474debf792eb 100644 --- a/modules/gui/qt4/components/playlist/standardpanel.cpp +++ b/modules/gui/qt4/components/playlist/standardpanel.cpp @@ -86,7 +86,7 @@ StandardPLPanel::StandardPLPanel( PlaylistWidget *_parent, this, handleExpansion( const QModelIndex& ) ); CONNECT( model, rootChanged(), this, handleRootChange() ); - setRoot( p_root ); + setRoot( p_root, false ); } StandardPLPanel::~StandardPLPanel() @@ -189,8 +189,11 @@ void StandardPLPanel::searchDelayed( const QString& searchText ) /* Set the root of the new Playlist */ /* This activated by the selector selection */ -void StandardPLPanel::setRoot( playlist_item_t *p_item ) +void StandardPLPanel::setRoot( playlist_item_t *p_item, bool b ) { + if( b ) //SQLML + return; + model->rebuild( p_item ); } diff --git a/modules/gui/qt4/components/playlist/standardpanel.hpp b/modules/gui/qt4/components/playlist/standardpanel.hpp index 3853918fdde104368b9f1d56ee01c5ab893de08a..4520ff8a0ef4c37add8a7a439fca74f506f08064 100644 --- a/modules/gui/qt4/components/playlist/standardpanel.hpp +++ b/modules/gui/qt4/components/playlist/standardpanel.hpp @@ -99,7 +99,7 @@ private: bool eventFilter ( QObject * watched, QEvent * event ); public slots: - void setRoot( playlist_item_t * ); + void setRoot( playlist_item_t *, bool ); void browseInto( const QModelIndex& ); private slots: