******************************************************************************/
#include "dialogs/playlist.hpp"
-#include "util/qvlcframe.hpp"
-#include "qt4.hpp"
-#include "components/playlist/panels.hpp"
-#include "components/playlist/selector.hpp"
-#include <QHBoxLayout>
+
+#include "main_interface.hpp"
+#include "components/playlist/playlist.hpp"
+#include "dialogs_provider.hpp"
#include "menus.hpp"
+#include <QUrl>
+#include <QHBoxLayout>
+#include <QSignalMapper>
+#include <QMenu>
+#include <QAction>
+#include <QMenuBar>
+
PlaylistDialog *PlaylistDialog::instance = NULL;
-PlaylistDialog::PlaylistDialog( intf_thread_t *_p_intf ) : QVLCMW( _p_intf )
+PlaylistDialog::PlaylistDialog( intf_thread_t *_p_intf )
+ : QVLCMW( _p_intf )
{
QWidget *main = new QWidget( this );
setCentralWidget( main );
setWindowTitle( qtr( "Playlist" ) );
- QVLCMenu::createPlMenuBar( menuBar(), p_intf );
+ setWindowOpacity( config_GetFloat( p_intf, "qt-opacity" ) );
- selector = new PLSelector( centralWidget(), p_intf, THEPL );
- selector->setMaximumWidth( 130 );
+ QHBoxLayout *l = new QHBoxLayout( centralWidget() );
+ PlaylistWidget *plw = new PlaylistWidget( p_intf, NULL );
+ l->addWidget( plw );
- playlist_item_t *p_root = playlist_GetPreferredNode( THEPL,
- THEPL->p_local_category );
-
- rightPanel = qobject_cast<PLPanel *>(new StandardPLPanel( centralWidget(),
- p_intf, THEPL, p_root ) );
- connect( selector, SIGNAL( activated( int ) ),
- rightPanel, SLOT( setRoot( int ) ) );
-
- QHBoxLayout *layout = new QHBoxLayout();
- layout->addWidget( selector, 0 );
- layout->addWidget( rightPanel, 10 );
- centralWidget()->setLayout( layout );
readSettings( "playlist", QSize( 600,700 ) );
}
{
writeSettings( "playlist" );
}
+
+void PlaylistDialog::dropEvent( QDropEvent *event )
+{
+ const QMimeData *mimeData = event->mimeData();
+ foreach( QUrl url, mimeData->urls() ) {
+ QString s = url.toString();
+ if( s.length() > 0 ) {
+ playlist_Add( THEPL, qtu(s), NULL,
+ PLAYLIST_APPEND, PLAYLIST_END, VLC_TRUE, VLC_FALSE );
+ }
+ }
+ event->acceptProposedAction();
+}
+void PlaylistDialog::dragEnterEvent( QDragEnterEvent *event )
+{
+ event->acceptProposedAction();
+}
+void PlaylistDialog::dragMoveEvent( QDragMoveEvent *event )
+{
+ event->acceptProposedAction();
+}
+void PlaylistDialog::dragLeaveEvent( QDragLeaveEvent *event )
+{
+ event->accept();
+}
+